Skip to content

🔑 Eloquent Custom ID Generation Trait for Laravel 6 and above

License

Notifications You must be signed in to change notification settings

timyourivh/laravel-customid

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Total Downloads MIT licensed

laravel-customid

Note

laravel now supports using UUID's and custom ID's by default. Check out their documentation to see if it fits your needs.

Eloquent custom ID generation trait for Laravel 6 and above.

A simple trait that allows you to generate and lock a (unique) custom generated id.

Installation

composer require timyouri/laravel-customid

Usage

In your migrations

Prepare your migration(s) where you would like to use random ID's. It would be best when creating the table, because updating a table may not work for you as it will most likely require you to use ->default() or ->nullable().

// Example of 2014_10_12_000000_create_users_table.php:

Schema::create('users', function (Blueprint $table) {
-   $table->id();
+   $table->string('id')->primary()->unique();
    $table->string('name');
    $table->string('email')->unique();
    $table->timestamp('email_verified_at')->nullable();
    $table->string('password');
    $table->rememberToken();
    $table->timestamps();
});

In your models

Basic usage

The basic usage is just using the trait and and setting the keytype and it will automatically generate random ID's for you.

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use TimYouri\CustomId\Traits\GeneratesCustomId;

class User extends Model
{
    use GeneratesCustomId;
    
    protected $keyType = 'string';
}

By default it will generate a 12 character long random id (Example: p0GWJskcTqUX). The length of the default id generation can be configured by setting $customIdLength:

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use TimYouri\CustomId\Traits\GeneratesCustomId;

class User extends Model
{
    use GeneratesCustomId;
    
    protected $keyType = 'string';

    // Sets default id lenght to 24, output example: 0BENc3Cvj5A9g3WCMPVCJLOK
+   protected $customIdLength = 24;
}

Advanced usage

All props to configure the beavior of the trait are listed below along with a description and its default value.

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use TimYouri\CustomId\Traits\GeneratesCustomId;

class User extends Model
{
    use GeneratesCustomId;
    
    // This is a default Laravel prop.
    // Required if using a string as ID.
    protected $keyType = 'string';
    
    // Determines if the generated id should be unique.
    protected $uniqueCustomId = true; 

    // If `$uniqueCustomId` is true, this prop defines the maximum amount of attemts for validating uniqueness before inserting.
    // When exceeded, it will throw an exception.
    protected $customIdAttempts = 10; 

    // Determines if you are allowed to change the id. If true it will revert to the previous value when trying to update the id.
    protected $lockCustomId = true; 

    // Config parameter for defining the length of the id in the default id generation method.
    protected $customIdLength = 12; 

    // Overwrite the default id generation method
    protected function generateId(int $attempts)
    {
        // `$attempts` is passed to write your own logic based on tried attempts. The default method does not make use of this param.

        // Default:
        return (string) Str::random($this->customIdLength);

        // Example random number:
        return (int) random_int(100000, 999999);        
    }
}

Unit tests

To run the tests, just run composer install and composer test.

About

🔑 Eloquent Custom ID Generation Trait for Laravel 6 and above

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%