A Laravel package to reference Models by using custom string tokens instead of IDs.
- You want to hide ID information on your endpoints.
/api/user/32
ends as/api/user/5cb0b0dddf8ae37a6e8066d4ffd838d91c94bdc7
. - You need to create temporary references to your models. For instance, a link for resetting a password that will expire in two hours
reset/password/user/3f6e660c376c9fcaeaddeb50b0893d73e772100f
.
Install package using Composer.
$ composer require tpenaranda/aiditokens
Run migrations.
$ php artisan migrate
- Include Tokens trait on desired Laravel model.
class User extends Model
{
use TPenaranda\Aiditokens\Traits\Tokens;
- Get (create if necessary) a token:
>>> $userModel->getToken();
=> "5cb0b0dddf8ae37a6e8066d4ffd838d91c94bdc7"
>>>
>>> $userModel->getToken($expireInHours = 2);
=> "efbbc5efa8e0838f58aa86f2f20a468af8262a43"
>>>
- Retrieve a model by token:
$user = User::firstByToken('5cb0b0dddf8ae37a6e8066d4ffd838d91c94bdc7');
=> App\User {#3214
id: 53,
first_name: "John",
last_name: "Doe",
created_at: "2019-11-15 07:22:59",
updated_at: "2019-11-15 07:23:04",
- Custom token generation
class User extends Model
{
use TPenaranda\Aiditokens\Traits\Tokens;
public function generateToken(): string
{
return str_random(); // Your custom logic goes here.
}
- Bind on RouteServiceProvider for route model explicit binding
class RouteServiceProvider extends ServiceProvider
{
public function boot()
{
Route::pattern('userToken', '^.{40}$'); // Watch out this regex if you're using custom tokens.
Route::bind('userToken', function ($value) {
return User::firstByToken($value) ?? abort(404);
});
- Route file
Route::get('users/{userToken}', 'UserController@get');
Happy coding!