rustflake 0.1.1

Thread-safe 'twitter' snowflakes.
Documentation
  • Coverage
  • 0%
    0 out of 8 items documented0 out of 7 items with examples
  • Size
  • Source code size: 16.68 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 1.57 MB This is the summed size of all files generated by rustdoc for all configured targets
  • Ø build duration
  • this release: 18s Average build duration of successful builds.
  • all releases: 18s Average build duration of successful builds in releases after 2024-10-23.
  • Links
  • iCrawl/rustflake
    40 2 0
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • iCrawl

rustflake

Thread-safe "twitter" snowflakes.

By default the original Twitter snowflake format defines:

  • 41 bits are used to store a custom epoch with millisecond precision
  • 10 bits are used to store worker and datacenter information
  • 12 bits are used to store a sequence number

This crate lets you customize your own epoch and worker/datacenter information.

Usage

Add this to your Cargo.toml:

[dependencies]
rustflake = "0.1.0"

and this to your crate root:

use rustflake;

Example

use rustflake::Snowflake;

fn main() {
    let mut snowflake = Snowflake::default();
    println!("{}", &snowflake.generate());
}
use rustflake::Snowflake;

fn main() {
    // Discord Epoch
    // Though those are not "real" discord Ids,
    // because discord increases the sequence
    // for *every* generated Id on that process
    let mut snowflake = Snowflake::new(1420070400000, 1, 1);
    println!("{}", &snowflake.generate());
}
use rustflake::Snowflake;

fn main() {
    // Using a builder approach
    let mut snowflake = Snowflake::default()
        .epoch(1_564_790_400_000)
        .worker_id(2)
        .datacenter_id(3);
    println!("{}", &snowflake.generate());
}