hafael / laraflake
Laravel Package based on Twitter Snowflake ID Generator (64 bit ID).
Installs: 7 220
Dependents: 1
Suggesters: 0
Security: 0
Stars: 27
Watchers: 3
Forks: 6
Open Issues: 1
Requires
- php: >=5.3.0
- illuminate/support: >=5.3.0
Requires (Dev)
- laravel/framework: >=5.3.0
- orchestra/testbench: ~3.0
- phpunit/phpunit: >=4.0.0
This package is auto-updated.
Last update: 2024-11-17 18:18:26 UTC
README
LaraFlake
LaraFlake is a Laravel 5.x Package based on Twitter Snowflake ID Generator (64 bit ID).
- Generate unique identifiers like 4685142323047173636 (64bit)
- 41bit for time
- 10bits for shard database identifier from 1 to 512
- 12bits for randomic number from 1 to 2048
Only supports MySQL database. :(
Waiting for your pull request to solve this issue...
How to use
Run the composer require command from your terminal:
$ composer require hafael/laraflake
Open rootproject/config/app.php and register the required service provider above your application providers.
'providers' => [ /* * Application Service Providers... */ ... Hafael\LaraFlake\LaraFlakeServiceProvider::class, ],
Run Artisan command to publish vendor config file in rootproject/config/laraflake.php
$ php artisan vendor:publish --provider="Hafael\LaraFlake\LaraFlakeServiceProvider"
Import the LaraFlakeTrait in your model and set $incrementing to false:
class User extends Authenticatable { use LaraFlakeTrait; protected $table = "users"; /** * Indicates if the IDs are auto-incrementing. * @var bool */ public $incrementing = false; ...
And update the migration files to use BIGINT(20) UNSIGNED:
class CreateUsersTable extends Migration { /** * Run the migrations. * @return void */ public function up() { Schema::create('users', function (Blueprint $table) { $table->bigInteger('id')->unsigned()->primary(); $table->string('name'); $table->string('email')->unique(); $table->string('password'); $table->rememberToken(); $table->timestamps(); }); } ...
Development
Want to contribute? Great! Just create a pull request.
Todos
- Write Tests
- Write Benchmark Tests
- Implement support for other databases
License
Apache 2.0
Inspiration
Inspired on simplicity from Particle by Silviu Schiau.