pwm / uuid-v4
Implementation of the RFC 4122 UUID version 4 (variant 1) data type
Installs: 2 204
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: >=7.1.0
Requires (Dev)
- infection/infection: ^0.8
- phpstan/phpstan: ^0.7
- phpunit/phpunit: ^6.1
- squizlabs/php_codesniffer: ^3.0
This package is auto-updated.
Last update: 2025-03-29 00:40:17 UTC
README
Implementation of the RFC 4122 UUID version 4 (variant 1) data type. UUID stands for Universally Unique Identifier.
Table of Contents
Why
We already have comprehensive UUID libraries in PHP, eg. ramsey/uuid.
My goal was to create a minimalistic implementation of the version 4 UUID spec. UUIDv4-s are randomly generated which makes implementation trivial as it requires nothing other than a random external seed value.
The decision to only implement version 4 resulted in a tiny functional library capturing the UUIDv4 data type that can be understood in minutes. Creation happens using a pure function that takes the random seed and is trivially testable.
Requirements
PHP 7.1+
Installation
$ composer require pwm/uuid-v4
Usage
Creating a UUIDv4 data type from a valid string:
$uuidV4String = '30313233-3435-4637-b839-616263646566'; $uuidV4 = new UuidV4($uuidV4String); // the data type assert($uuidV4 instanceof UuidV4); assert($uuidV4String === (string)$uuidV4);
Creating a random UUIDv4 from a 16 byte random seed:
$uuidV4 = UuidV4::createFrom(random_bytes(16)); assert($uuidV4 instanceof UuidV4);
Creating from the same seed produces the same UUIDv4:
$seed = random_bytes(16); assert((string)UuidV4::createFrom($seed) === (string)UuidV4::createFrom($seed));
How it works
UUID version 4 is defined in RFC 4122 as a sequence of 128 bits, where 6 bits are fixed (4 for the version, 2 for the variant) leaving 122 randomly generated bits for entropy.
UuidV4
is a simple data type that can only be created from valid UUIDv4 strings. It comes with a createFrom()
function that facilitates the creation of random UUIDv4-s from 16 byte random seeds. It is to be used with PHP's random_bytes()
function.
Tests
$ vendor/bin/phpunit
$ composer phpcs
$ composer phpstan
$ composer infection