lekoala / silverstripe-uuid
Uuid data extension for SilverStripe
                                    Fund package maintenance!
                                                                            
                                                                                                                                        lekoala
                                                                                    
                                                                
Installs: 2 691
Dependents: 1
Suggesters: 0
Security: 0
Stars: 2
Watchers: 3
Forks: 3
Open Issues: 0
Type:silverstripe-vendormodule
pkg:composer/lekoala/silverstripe-uuid
Requires
- php: ^8.3
- ramsey/uuid: ^4
- silverstripe/framework: ^6
- tuupola/base62: ^2.1
Requires (Dev)
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.
Populate Uuids of existing DataObjects
Apply the PrepopulateUuidExtension to have Uuids for existing DataObjects generated on dev/build.
MyUuidDataObject: extensions: - LeKoala\Uuid\PrepopulateUuidExtension
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 SilverStripe 6 and up
For 4.x and 5.x, see branch 1
Maintainer
LeKoala - thomas@lekoala.be