Dynamically create a hash of an Eloquent model id value to avoid exposing a record's actual database id.
use Netsells\HashModelIds\HashesModelIdsTrait;
class Model extends BaseModel
{
use HashesModelIdsTrait;
}Use the HashesModelIdsTrait in an Eloquent model to enable the following functionality:
- Access a model's hashed id value:
$model->hashed_id - Filter a model by an array of or a single hashed id:
Model::whereHashedId($hashedId)Model::whereHashedIds($hashedIds)
- Define routes with models bound by their hashed id:
Route::get('models/{model}', function (Model $model) { return $model; }); $url = url("models/$model->hashed_id");
- Check for model existence in form request classes using a bespoke rule, optionally including additional chained constraints:
public function rules() { return [ 'hashed_id' => [ ExistsWithHashedIdRule::make(Model::class) ->where(function ($query) { $query->where('type', 'test'); }) ->where('foo', 'bar'), ], ]; }
Install the package with:
composer require netsells/hash-model-ids
Publish the package config file:
php artisan vendor:publish --tag=hash-model-ids-config
Optionally set a HASH_MODEL_IDS_SALT in .env.
Publish the package translations file:
php artisan vendor:publish --tag=hash-model-ids-lang
Sometimes, during development, it can be awkward dealing with hashed ids. Set HASH_MODEL_IDS_ENABLED=false in your environment file to enable use of a (configurable) prefixed version of a model's actual id rather than the default hashed version.
./vendor/bin/phpunit