Crates.io | cuid2-timeless |
lib.rs | cuid2-timeless |
version | 0.1.6 |
source | src |
created_at | 2024-05-19 00:55:01.755321 |
updated_at | 2024-06-08 07:12:33.88828 |
description | An unstable, barely tested, probably giving wrong output and might panic out of nowhere CUID2 implementation in Rust |
homepage | |
repository | https://github.com/timelessnesses/cuid2-timeless |
max_upload_size | |
id | 1244584 |
size | 20,848 |
An unstable, barely tested, probably giving wrong output and might panic out of nowhere CUID2 implementation in Rust. Built for learning more rust and I don't know how to test it.
[!CAUTION] This library is slower than cuid-rust by a whole lot!
benchmark cuid2-timeless cuid2 (cuid-rust) single cuid generation 53.180 µs 2.8162 µs 10,000 cuids generation 553.52 ms 28.900 ms This library is for learning purposes. Please don't use this library in production! Use cuid-rust instead!
cargo add cuid2_timeless --features sha3
(or you can use sha2 if you wanted to)
Either use the cuid2_timeless::cuid_wrapper()
and call it again to get ID or get some customization with cuid2_timeless::Cuid
use cuid2_timeless;
let mut cuid = cuid2_timeless::cuid_wrapper();
println!("{}", cuid().unwrap());
or some customization
use cuid2_timeless;
use rand::{self, Rng};
let mut cuid = cuid2_timeless::Cuid::new(
Box::new( // A randomizer function
|| {
rand::thread_rng().gen()
}
),
Box::new( // Your very own counter function
|mut i| {
Box::new(move || {
i += 1;
i
})
}
),
24, // Length
Box::new(cuid2_timeless::utils::create_fingerprint) // And a fingerprint creator function (im too lazy to implement)
);
cuid.generate(None).unwrap();
or verify if it actually is CUID
use cuid2_timeless;
println!("{}", cuid2_timeless::is_cuid("f9ovgvsnly7h6khwt4nx08kom".to_string(), None, None));
regex
is a feature for either remove or add regex
crate to the module. Turning this off will remove the is_cuid
function (enabled by default)random
is a feature for either remove or add rand
crate to the module. Turning this off will remove Default
trait from Cuid
(enabled by default)sha2
is a feature for either remove or add sha2
crate to the module. Turning this off will remove SHA2 hashing algorithm, but turning this feature on will uses sha2
for hashing (cannot enabled with sha3
present, compiling will error if sha2
and sha3
is enabled, not enabled by default)sha3
is a feature for either remove or add sha3
crate to the module. Turning this off will remove SHA3 hashing algorithm, but turning this feature on will uses sha3
for hashing (cannot enabled with sha2
present, compiling will error if sha2
and sha3
is enabled, enabled by default)