7 unstable releases (3 breaking)
0.4.3 | Dec 2, 2024 |
---|---|
0.4.2 | Dec 2, 2024 |
0.3.0 | Sep 22, 2024 |
0.2.0 | Sep 17, 2024 |
0.1.0 | Sep 11, 2024 |
#1121 in Database interfaces
299 downloads per month
16KB
295 lines
Prefixed TSIDs
This library allows you to easily create and manage Stripe-style prefixed IDs for your database, using the tsid
crate. For example:
org_0GTM2MERJJE1T
Each type of resource gets its own unique prefix, and is represented as a type-safe ID in your code. You can declare resources manually or using our handy macro:
id_resource_type!(IDOrganisation, "org");
// equals:
#[derive(Eq, PartialEq, Clone, Copy, Debug, Hash)]
pub struct IDOrganisation;
impl TSIDResource for IDOrganisation {
fn prefix() -> Option<String> {
Some("org".to_owned())
}
}
Then, you can easily create a random instance of the ID:
let org_id = TSIDDatabaseID::<IDOrganisation>::random();
When stringified (or serialised using the serde
feature), it will always include the prefix in the TSIDResource
type.
When stored in your database, it's simply a u64
without the prefix information, since your database presumably keeps different resources in different tables anyway. The library comes with a built-in sea-orm
integration.
Features
By default, only serde
is enabled.
serde
: serialize/deserialize integration. Adds the correct prefix when serializing, and returns an error if the prefix is missing or is wrong during deserialization.rocket
: integration forFromParam
andFromFormField
so you can use aTSIDDatabaseID
in path components, query parameters, form requests, etc.sea-orm
: allows you to useTSIDDatabaseID
in your entity structs, so the ID gets turned into au64
and vice versa.schemars
: allows generating JSON Schema containing a RegEx to match your prefixed ID.ts-rs
: for extra-nice WASM compatibility, allows generating a string type to represent the ID type in Typescript.
License
Made by Palform Ltd (registered company 15796859 in the UK) under the MIT License.
Dependencies
~3–36MB
~565K SLoC