#id #prefixed #resources #database-schema #serialization #prefix

prefixed-tsid

Create Stripe-style prefixed database IDs that are type-safe and portable

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

Download history 445/week @ 2024-09-11 268/week @ 2024-09-18 46/week @ 2024-09-25 16/week @ 2024-10-02 5/week @ 2024-10-09 4/week @ 2024-10-16 1/week @ 2024-10-30 4/week @ 2024-11-06 12/week @ 2024-11-13 16/week @ 2024-11-20 399/week @ 2024-11-27 153/week @ 2024-12-04 15/week @ 2024-12-11

299 downloads per month

MIT license

16KB
295 lines

Prefixed TSIDs

Documentation

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 for FromParam and FromFormField so you can use a TSIDDatabaseID in path components, query parameters, form requests, etc.
  • sea-orm: allows you to use TSIDDatabaseID in your entity structs, so the ID gets turned into a u64 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