Download the PHP package codiliateur/smart-uuid without Composer
On this page you can find all versions of the php package codiliateur/smart-uuid. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package smart-uuid
smart-uuid
Package provides any functions to generate and analyze UUID.
There used a specific (non-standard) algorithm to generate UUID that enables to include into UUID next information:
- creating timestamp
- user defined application code
- user defined entity code
Generated UUID has a next structure:
SSSSSSSS-UUUU-UAAA-EEEE-RRRRRRRRRRRR
S
- 8 hex digits is seconds value of UUID generating timestampU
- 5 hex digits is microseconds value of UUID generating timestampA
- 3 hex digits is custom application codeE
- 4 hex digits is custom entity codeR
- 12 hex digits is random value
The application code and the object code are integer values that are packed into the generated UUID. These codes allow you to identify (programmatically or even visually) the entity and application for which the UUID was generated. Also, a UUID generation timestamp is packed into the UUID with an accuracy of microseconds.
Installing
To install a package run command:
composer require codiliateur/smart-uuid
Using trait HasUuidPrimaryKey
Use trait /Codiliateur/SmartUuid/Models/HasUuidPrimaryKey
in your model if you need to use UUID primary key.
Declare public properties $appCode
and $entityCode
in your model to tune UUID generating.
This trait overwrites getIncrementing()
and getKeyType()
methods. You must not to fill properties $incrementing
and $keyType
in the model.
The trait registers model event handler for creating-event to generating UUID and filling model key.
Example:
Helper functions
generate_uuid()
Use generate_uuid() to generate uuid.
Syntax:
generate_uuid( [[int $entityCode] , int $appCode] ) : string
Arguments:
$entityCode
- integer entity code (default - 0) in range from 0 to 65535$appCode
- integer application code (default - 0) in range from 0 to 4095
Returning: Generated UUID as string.
extract_uuid_part()
Extracts timestamp, application or entity code from UUID.
Syntax:
extract_uuid_part( string $uuid, $part [, string $format] ) : mixed
Arguments:
$uuid
- analyzed UUID;$part
- extracting part:- 'timestamp' - to retrieve creating uuid timestamp
- 'app_code' - to retrieve application code
- 'entity_code' - to retrieve entity code
$format
- returning value format:- 1 - (default) \Carbon\Carbon object;
- 2 - \DateTime object;
- or format string to return formatted data string. Example:
'Y-m-d H:i:s.u'
Returning: \Carbon\Carbon | \DateTime | string.
Extracting timestamp examples:
Extracting application code example:
Extracting entity code example:
Constants
You can use next constants
// $part constants
Codiliateur\SmartUuid\Uuid::TIMESTAMP = 'timestamp'
Codiliateur\SmartUuid\Uuid::APP_CODE = 'app_code'
Codiliateur\SmartUuid\Uuid::ENTITY_CODE = 'entity_code'
// $format constants
Codiliateur\SmartUuid\Uuid::TS_FORMAT_CARBON = 1
Codiliateur\SmartUuid\Uuid::TS_FORMAT_DTETIME = 2
All versions of smart-uuid with dependencies
laravel/framework Version ^8.0|^9.0|^10.0|^11.0
nesbot/carbon Version ^2.53.1|^3.0.0