Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/icrawl/rustflake

Thread-safe "twitter" snowflakes.
https://github.com/icrawl/rustflake

crate epoch rust snowflakes twitter

Last synced: 3 months ago
JSON representation

Thread-safe "twitter" snowflakes.

Awesome Lists containing this project

README

        

# 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`:

```toml
[dependencies]
rustflake = "0.1.0"
```

and this to your crate root:

```rust
use rustflake;
```

## Example

```rust
use rustflake::Snowflake;

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

```rust
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());
}
```

```rust
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());
}
```