hafael / laraflake by hafael

Laravel Package based on Twitter Snowflake ID Generator (64 bit ID).
6,758
26
3
Package Data
Maintainer Username: hafael
Maintainer Contact: villa655321verde@gmail.com (Rafael Villa-Verde)
Package Create Date: 2016-07-21
Package Last Update: 2022-12-10
Language: PHP
License: Apache-2.0
Last Refreshed: 2024-05-08 03:14:21
Package Statistics
Total Downloads: 6,758
Monthly Downloads: 48
Daily Downloads: 1
Total Stars: 26
Total Watchers: 3
Total Forks: 6
Total Open Issues: 1

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.