marcinjean / minisnowflake
A lightweight, case-insensitive, short ID generator using a mini Snowflake algorithm.
Fund package maintenance!
marcinjean
Requires
- php: >=7.4
Requires (Dev)
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2025-04-28 01:27:35 UTC
README
A lightweight, case-insensitive, 9-character unique ID generator based on a mini Snowflake algorithm, written in PHP.
Built for high-performance systems needing short, collision-resistant IDs without long UUIDs.
Features
- ✅ 9-character alphanumeric IDs
- ✅ Based on a customizable epoch (like Twitter Snowflake)
- ✅ No collision up to 256 IDs per millisecond
- ✅ Case-insensitive for user input
- ✅ Optional CLI tool for generating IDs
- ✅ Fully unit-tested with PHPUnit
- ✅ PSR-4 autoloaded, Composer ready
Installation
Install via Composer:
composer require marcinjean/minisnowflake
Basic Usage
use MarcinJean\MiniSnowflake\MiniSnowflake; // Generate a new ID $id = MiniSnowflake::generateId(); echo $id; // Example: "00D2D87XE" // Validate an ID if (MiniSnowflake::isValidId($id)) { echo "ID is valid!"; } // Decode an ID $data = MiniSnowflake::decodeId($id); print_r($data); /* Array ( [timestamp] => 1714256780000 [datetime] => 2025-04-27 22:19:40 [sequence] => 123 ) */
Custom Epoch
By default, IDs are generated relative to January 1st, 2025.
You can customize the epoch globally:
// Set a custom epoch (in milliseconds) MiniSnowflake::setEpoch(strtotime('2024-01-01 00:00:00') * 1000); // Reset to default epoch (2025-01-01) MiniSnowflake::resetEpoch();
Or pass a custom epoch per call:
$customEpoch = strtotime('2023-01-01 00:00:00') * 1000; $id = MiniSnowflake::generateId($customEpoch); $data = MiniSnowflake::decodeId($id, $customEpoch);
CLI Usage
After installing:
php bin/generate-id.php
Example output:
Generated ID: 00D2D87XE
Decoded Info:
- Timestamp: 1714256780000
- Datetime: 2025-04-27 22:19:40
- Sequence: 123
You can also specify a custom epoch:
php bin/generate-id.php --epoch=1704067200000
Running Tests
This package is fully unit-tested with PHPUnit.
Install dev dependencies:
composer install
Run tests:
composer test
You should see:
OK (4 tests, 10 assertions)
License
This package is open-sourced software licensed under the MIT license.