Laravel Redacted Model makes it easier to hide or modify fields on a model based on given conditions in order to reduce data leakage in Laravel applications.
Laravel Redacted Model can be installed using composer. Run the following command in your project.
composer require langleyfoxall/laravel-redacted-modelIf you have never used the Composer dependency manager before, head to the Composer website for more information on how to get started.
To redact fields simply extend RedactedModel in your model and set the redacted variable to an array of the fields you want to protect. By default when accesed these fields will return [Hidden Data].
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
}To conditionally redact fields override shouldRedactField on your model. The name of the field will be passed into this method. This will return true by default until you override it.
Note: Only fields specified in $redacted will be redacted regardless of what's returned from this method.
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
public function shouldRedactField($key)
{
return !\Auth::user()->canSeeSensitiveFields();
}
}To change the message returned you can set the redactedString on your model. This will then be returned instead of [Hidden Data].
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
protected $redactedString = '[Top Secret]';
}If you want to completely omit the field instead of redacting it you can set the redact variable on your model to false.
Note: If redactKeys is set to true, when the model is serialised the keys of redacted fields will also be omitted.
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
protected $redact = false;
}By default the array key of fields that return null and are in the redacted fields list will too be omitted in case the field name is Sensitive. To disable this set $redactKeys to false on your model.
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
protected $redactKeys = false;
}Accesors can be used to define the value of specific fields if they're redacted. Redacted value accessors are defined the same way as Laravel Accessors but ending in RedactedValue instead of Accessor.
The original value is passed into the method, this allows you to abstract the value instead of omitting or redacting it.
For example if instead of returning the name from the model you want to only return the first and last letter:
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
public function getNameRedactedValue($value)
{
return subStr($value, 0, 1).'***'.subStr($value, -1 ,1);
}
}
...
$instanceOfRedactedModel->name // Returns K***y instead of Kathryn JanewayBy default redacted values will be returned as [Hidden Value] or null depending on the value of $redacted. You can bypass this by overriding defaultRedactedValue on the model.
This is useful if you want to derive the redacted value from the original value, as the field name and original value are passed into it. For example if you want to replace all characters with stars:
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
public function defaultRedactedValue($key, $value)
{
return str_repeat("*", strlen($value));
}
}
...
$instanceOfRedactedModel->name // Returns ********** instead of Section 31If you want to temporarily disable field redaction or omission you can call disableProtection() on the model to disable protection and enableProtection() to re-enable it. This has to be used on a per-instance basis.
class SensitiveModel extends RedactedModel
{
protected $redacted = ['name'];
}
...
$instanceOfRedactedModel->name // Returns [Hidden Data]
$instanceOfRedactedModel->disableProtection();
$instanceOfRedactedModel->name // Returns Reginald BarclayIf you want to change or add to the redacted fields of a model after it has been instantiated you can call the setRedacted method on the model.
If you call it with an array as the parameter the redacted variable will be overridden but anything else will be appended to the existing array.