strong_id
Strongly typed IDs which optionally satisfy the TypeID specification.
A StrongId is any type which implements StrongId<T: Id>.
The Id trait is implemented for u8, u16, u32, u64, u128, usize and when the "uuid" feature is enabled,
Uuid.
TypeID
With default-features = false and the typeid feature enabled, StrongID will follow the TypeID specification.
StrongID is verified against the TypeID spec with the typeid workflow every 6 hours.
Examples
Dynamic StrongIds
ID with a prefix
use ;
let user_id = new.unwrap;
println!; // user_0343
let user_id = "user_0343"..unwrap;
println!;
// DynamicStrongId {
// prefix: Some(
// Prefix {
// inner: "user",
// },
// ),
// suffix: 3203,
// }
ID without a prefix
use ;
let id = new_plain;
println!; // 0343
let id = "0343"..unwrap;
println!;
// DynamicStrongId {
// prefix: None,
// suffix: 3203,
// }
TypeId with a prefix
use ;
let user_id = now_v7.unwrap;
println!; // user_01h536gfwffx2rm6pa0xg63337
let user_id = "user_01h536gfwffx2rm6pa0xg63337"
.
.unwrap;
println!;
// DynamicStrongId {
// prefix: Some(
// Prefix {
// inner: "user",
// },
// ),
// suffix: 01894668-3f8f-7f45-8a1a-ca0760618c67,
// }
TypeId without a prefix
use ;
let id = now_v7_plain;
println!; // 01h536gfwffx2rm6pa0xg63337
let id = "01h536gfwffx2rm6pa0xg63337"
.
.unwrap;
println!;
// DynamicStrongId {
// prefix: None,
// suffix: 01894668-3f8f-7f45-8a1a-ca0760618c67,
// }
Generated StrongIds
ID with a prefix
use strong_id;
strong_id!;
let user_id = from;
println!; // user_0343
let user_id = "user_0343"..unwrap;
println!;
// UserId {
// suffix: 3203,
// }
ID without a prefix
use strong_id;
strong_id!;
let id = from;
println!; // user_0343
let id = "0343"..unwrap;
println!;
// Id {
// suffix: 3203,
// }
Generated TypeId with a prefix
use ;
strong_uuid!;
// strong_uuid!(struct UserId(Uuid => "user"));
/*
strong_id! {
#[derive(StrongUuid)]
pub struct UserId(pub Uuid => "user")
}
*/
let user_id = now_v7;
println!; // user_01h536z8abez196j2nzz06y8c8
let user_id = "user_01h536z8abez196j2nzz06y8c8"..unwrap;
println!;
// UserId {
// suffix: 0189466f-a14b-77c2-9348-55ffc06f2188,
// }
Generated TypeId without a prefix
use ;
strong_uuid!;
// strong_uuid!(struct Id(Uuid));
/*
strong_id! {
#[derive(StrongUuid)]
pub struct Id(pub Uuid)
}
*/
let id = now_v7;
println!; // 01h5372sq2egxb6ps3taq7p6np
let id = "01h5372sq2egxb6ps3taq7p6np"..unwrap;
println!;
// UserId {
// suffix: 01894671-66e2-743a-b35b-23d2ae7b1ab6,
// }
Features
delimited- Enables underscore delimited prefixes. On by default.serde- Enables serde support in code generation.uuid- Enable uuid functionality.uuid-v1- corresponds with uuid "v1" featureuuid-v3- corresponds with uuid "v3" featureuuid-v4- corresponds with uuid "v4" featureuuid-v5- corresponds with uuid "v5" featureuuid-v6- corresponds with uuid "v6" featureuuid-v7- corresponds with uuid "v7" featureuuid-v8- corresponds with uuid "v8" feature
typeid- Enable features which satisfy the TypeId specification.