lekoala / silverstripe-uuid
Uuid data extension for SilverStripe
Fund package maintenance!
lekoala
Installs: 2 070
Dependents: 1
Suggesters: 0
Security: 0
Stars: 2
Watchers: 4
Forks: 1
Open Issues: 1
Type:silverstripe-vendormodule
Requires
- php: ^7.4 || ^8
- ramsey/uuid: ^3 || ^4
- silverstripe/framework: ^4.4 || ^5
- silverstripe/recipe-plugin: ^1 || ^2
- silverstripe/vendor-plugin: ^1 || ^2
- silverstripe/versioned: ^1 || ^2
- tuupola/base62: ^2.1
Requires (Dev)
- phpunit/phpunit: ^9.5
- squizlabs/php_codesniffer: ^3.0
README
Easily add uuid to your DataObjects
Getting started
Simply add the extension to your DataObject
MyDataObject: extensions: - LeKoala\Uuid\UuidExtension
Call UuidExtension::getByUuid(MyDataObject::class, $uuid)
to retrieve the record by Uuid.
Since that's really ugly, you can also use the HasUuid
trait on your classes to return a properly type hinted class.
Usage in templates
In your templates, use UuidSegment to ensure Uuid value is generated on the record. UuidSegment are base62 encoded in order to be shorter and more readable.
Getting readable values
Since Uuid's are stored in binary format for performance reason, you need to call $myObject->dbObject('Uuid')->Nice() to get a readable value.
Upgrade to Ramsey v4
If you happen to upgrade from previous versions you might want to check this guide
TODO
- Postgres compat
Worth reading
Storing UUID Values in MySQL GUID/UUID Performance Laravel: The mysterious “Ordered UUID”: offer a good overview of the situation although it's a bit laravel specific
Compatibility
Tested with 4.4 and up
Maintainer
LeKoala - thomas@lekoala.be