cloudcake / laravel-uuid
UUID's for Laravel's Eloquent models.
Installs: 131
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 0
Forks: 0
Open Issues: 1
pkg:composer/cloudcake/laravel-uuid
Requires
- php: >=7.0.0
- moontoast/math: ^1.2
- ramsey/uuid: ^3.0
This package is auto-updated.
Last update: 2025-09-27 08:16:14 UTC
README
Since Laravel 9.x, UUID support for Eloquent is baked right into Laravel.
See Illuminate/Database/Eloquent/Concerns/HasUuids.
This package is now redundant.
Installation
Install via composer using composer require cloudcake/laravel-uuid
Usage
Primary Key UUID's
If you want to use UUID's as your model's primary key, this is for you.
- Add the Uuid\Traits\UuidPrimaryKeytrait to the eloquent model
- Add the primary key column name if you're not using the default of id(Optional)
use Uuid\Traits\UuidPrimaryKey; class User extends Authenticatable { use UuidPrimaryKey; protected $primaryKey = 'id'; }
Now you'll be able to call User::find('<uuid-here>');.
Additional Field UUID's
In some situations you may want to retain your regular integer based primary key, but add an additional UUID column to your models, for this case, use the Uuid trait.
- Add the Uuid\Traits\Uuidtrait to the eloquent model
- Add the name of the UUID column
use Uuid\Traits\Uuid; class User extends Authenticatable { use Uuid; protected static $uuidKeyName = 'uuid'; }
And query it as you would any other attribute, User::where('uuid', '<uuid-here>')->first().
Additional Options
Add any/all of the following to your model(s) to fine-tune the package to your needs.
| Attribute | Description | 
|---|---|
| $uuidKey | The name of the UUID column in the database. Defaults to uuid. | 
| $uuidOrdered | Whether or not the UUID should use timestamp ordering. Defaults to true. | 
Example:
use Uuid\Traits\Uuid; use Illuminate\Database\Eloquent\Model; class Comment extends Model { use Uuid; /** * The name of the UUID column in the database. * * @var string */ protected static $uuidKey = 'universally_unique_id'; /** * Whether or not the UUID should use timestamp ordering. * * @var bool */ protected static $uuidOrdered = true; }