oanhnn/laravel-fakeid is a Laravel package for using fake id on url in laravel application.
It currently has 2 GitHub stars and 319 downloads on Packagist (latest version v2.0.0).
Install it with composer require oanhnn/laravel-fakeid.
Discover more Laravel packages by oanhnn
or browse all Laravel packages to compare alternatives.
Last updated
Easy fake model ID on URL Laravel Application.
Laravel 5.5+ using version 1.x (require php 7.1.3+)
Begin by pulling in the package through Composer.
$ composer require oanhnn/laravel-fakeid
Publish config file with
$ php artisan vendor:publish --provider="Laravel\\FakeId\\ServiceProvider"
or
php artisan vendor:publish --tag=laravel-fakeid-config
Edit config/fakeid.php for config specific drivers.
In your model class, add implement interface ShouldFakeId and a trait RoutesWithFakeId:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use Laravel\FakeId\Contracts\ShouldFakeId;
use Laravel\FakeId\RoutesWithFakeId;
class MyModel extends Model implements ShouldFakeId
{
use RoutesWithFakeId;
// other logic
}
By default, RoutesWithFakeId use default driver, it is set in config file. You can override getFakeIdDriver() method to use specific driver:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use Laravel\FakeId\Contracts\ShouldFakeId;
use Laravel\FakeId\Contracts\Driver;
use Laravel\FakeId\Facades\FakeId;
use Laravel\FakeId\RoutesWithFakeId;
class MyModel extends Model implements ShouldFakeId
{
use RoutesWithFakeId;
/**
* @return \Laravel\FakeId\Contracts\Driver
*/
public function getFakeIdDriver() : Driver
{
return FakeId::driver('hex');
// or create driver instance
// return new HexDriver();
}
}
Note With each drivers, the input data format may be different, but the output data after decode is same with input
| Driver | Input type | Encoded type | Decoded type | |-----------|------------|--------------|--------------| | base64 | string | string | string | | hashids | int[] | string | int[] | | hex | string | string | string | | optimus | int | int | int | | prefix | string | string | string | | chain | string | string | string |
You can also create custom driver by implements Laravel\FakeId\Contracts\Driver interface
namespace App;
use Laravel\FakeId\Contracts\Driver;
class CustomDriver implements Driver
{
// your driver logic
}
And register with FakeId Manager by add below code to AppServiceProvider::boot() method
<?php
namespace App\Providers;
use App\CustomDriver;
use Illuminate\Support\ServiceProvider;
use Laravel\FakeId\Facades\FakeId;
class AppServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
FakeId::extend('custom', function($app) {
return new CustomDriver();
});
// other logic
}
}
Now, you can use it
<?php
use Laravel\FakeId\Facades\FakeId;
FakeId::driver('custom')->encode('123');
See all change logs in CHANGELOG
$ git clone [email protected]/oanhnn/laravel-fakeid.git /path
$ cd /path
$ composer install
$ composer test
Please see CONTRIBUTING for details.
If you discover any security related issues, please email to Oanh Nguyen instead of using the issue tracker.
This project is released under the MIT License.
Copyright © Oanh Nguyen.