Base Class and Interfaces¶
Base class¶
Arokettu\Uuid\AbstractUuid
class and Arokettu\Uuid\Uuid
interface.
Direct creation¶
The base constructor is inherited by most of the descendants. It accepts a string of lowercase hexadecimal digits (0-9, a-f):
<?php
use Arokettu\Uuid\GenericUuid;
// {12345678-9abc-def0-1234-56789abcdef0}
$uuid = new GenericUuid('123456789abcdef0123456789abcdef0');
Note
UuidParser::fromRfcFormat()
and UlidParser::fromRfcFormat()
can parse UUIDs/ULIDs in hex in case-insensitive manner.
Subclasses may also check the string for additional validity.
Conversion to Bytes¶
Added in version 1.2: toGuidBytes()
Methods to convert UUID object to a byte sequence:
toBytes()
to the raw big-endian byte sequencetoGuidBytes()
to the Microsoft GUID mixed-endian byte sequence
Conversion to String¶
Added in version 2.1: toDecimal()
Methods to convert UUID object to string:
toString()
. Converts UUIDs to the RFC Format and ULIDs to Base32.toRfcFormat()
to RFC 9562 form. Aliases:toRfc4122()
,toRfc9562()
. Example:"6ba7b811-9dad-11d1-80b4-00c04fd430c8"
toBase32()
to Base32. Example:"3BMYW137DD278R1D00R17X8C68"
toDecimal()
to decimal. Example:"143098242483405524118141958906375844040"
Note
toDecimal()
can be used to create OID representation of the UUID:
<?php
// add OID UUID prefix: 2.25
$oid = '2.25.' . $uuid->toDecimal(); // 2.25.143098242483405524118141958906375844040
Comparison¶
Methods to compare two UUID objects.
compare(): int
. Returns same thing as strcmp.equalTo(): bool
. In strict mode (by default) returns true if bytes and types of the two objects are equal. In non-strict mode compares only byte values.
<?php
use Arokettu\Uuid\UlidParser;
use Arokettu\Uuid\UuidParser;
$uuid = UuidParser::fromString('6ba7b811-9dad-11d1-80b4-00c04fd430c8');
$ulid = UlidParser::fromString('3BMYW137DD278R1D00R17X8C68');
var_dump($uuid->compare($ulid)); // 0
var_dump($uuid->equalTo($ulid)); // false
var_dump($uuid->equalTo($ulid, strict: false)); // true
Variant10xxUuid¶
Added in version 1.1.
Changed in version 1.2: renamed from Rfc4122Variant1Uuid to Rfc4122Variant10xxUuid
Changed in version 3.0: renamed from Rfc4122Variant10xxUuid to Variant10xxUuid
RFC 9562 Variant 10xx UUID versions (all except for Nil and Max) extend this interface. This interface is most useful to check that it is a standard based UUID as opposed to Nil, Max, ULID or unrecognized generic.
<?php
use Arokettu\Uuid\UlidFactory;
use Arokettu\Uuid\UuidFactory;
use Arokettu\Uuid\Variant10xxUuid;
$uuid = UuidFactory::v4();
var_dump($uuid instanceof Variant10xxUuid); // true
var_dump($uuid->getVersion()); // 4
$ulid = UlidFactory::ulid();
var_dump($ulid instanceof Variant10xxUuid); // false
Rfc4122Uuid¶
Changed in version 1.1: Now includes Nil and Max
Changed in version 3.0: No longer contains Max, UUIDv2, UUIDv6, UUIDv7, UUIDv8
All UUIDs mentioned in RFC 4122, i.e. Nil, and Variant10xxUuid versions 1-5 excluding 2.
Rfc9562Uuid¶
Added in version 3.0.
All UUIDs mentioned in RFC 9562, i.e. Nil, Max, Variant10xxUuid versions 1-8 excluding 2.
TimeBasedUuid¶
UUIDv1, UUIDv2, UUIDv6, UUIDv7, and ULID extend this interface because they encode timestamp with various precisions:
<?php
use Arokettu\Uuid\UuidFactory;
$uuid = UuidFactory::v7();
var_dump($uuid->getDateTime()->format('c')); // current time
NodeBasedUuid¶
Added in version 4.0.
UUIDv1, UUIDv2, and UUIDv6 extend this interface because they are based on a Node and a Clock Sequence:
<?php
use Arokettu\Uuid\UuidFactory;
$uuid = UuidFactory::v6();
var_dump($uuid->getNode()); // Node value (MAC address or MAC-like pseudo-value)
var_dump($uuid->getClockSequence()); // Clock Sequence value