13 releases (4 stable)
1.0.3 | Feb 24, 2024 |
---|---|
1.0.2 | May 24, 2023 |
1.0.1 | Apr 26, 2023 |
1.0.0 | Feb 15, 2023 |
0.1.2 | Jun 14, 2022 |
#814 in Rust patterns
724 downloads per month
Used in 3 crates
41KB
737 lines
Snowflaked
A crate for creating and working with snowflake ids.
Usage
Add snowflaked
to your Cargo.toml
:
snowflaked = "1.0.0"
This crate provides APIs for generating new snowflake ids and defining custom snowflake types.
Snowflake Generation
Use the Generator
type to create new snowflake ids:
use snowflaked::Generator;
let mut generator = Generator::new(0);
let id: u64 = generator.generate();
Or use the thread-safe sync::Generator
type (requires the optional sync
feature):
use snowflaked::sync::Generator;
static GENERATOR: Generator = Generator::new(0);
fn generate_id() -> u64 {
GENERATOR.generate()
}
Using custom snowflake types
Custom snowflake types can be defined with the Snowflake
trait. This trait is currently
implemented for u64
and i64
and can be used to define your custom types:
use snowflaked::Snowflake;
struct UserId(u64);
impl Snowflake for UserId {
fn from_parts(timestamp: u64, instance: u64, sequence: u64) -> Self {
Self(u64::from_parts(timestamp, instance, sequence))
}
fn timestamp(&self) -> u64 {
self.0.timestamp()
}
fn instance(&self) -> u64 {
self.0.instance()
}
fn sequence(&self) -> u64 {
self.0.sequence()
}
}
License
Licensed under either
- MIT License or
- Apache License, Version 2.0 at your option.
Dependencies
~0–27MB
~330K SLoC