#uuid #short #generate #npm-package #alphabet #parse #string

no-std short-uuid

A library to generate and parse short uuids

6 releases

new 0.2.0 Feb 9, 2025
0.1.4 Nov 16, 2024
0.1.3 Aug 29, 2024
0.1.2 Feb 23, 2024

#242 in Data structures

Download history 2691/week @ 2024-10-25 2679/week @ 2024-11-01 2474/week @ 2024-11-08 2930/week @ 2024-11-15 1206/week @ 2024-11-22 1999/week @ 2024-11-29 2380/week @ 2024-12-06 2386/week @ 2024-12-13 995/week @ 2024-12-20 504/week @ 2024-12-27 1792/week @ 2025-01-03 2329/week @ 2025-01-10 2022/week @ 2025-01-17 2155/week @ 2025-01-24 2533/week @ 2025-01-31 2192/week @ 2025-02-07

9,298 downloads per month
Used in 2 crates

MIT license

28KB
401 lines

short-uuid

Generate and translate standard UUIDs into shorter or just different formats and back.

A port of the JavaScript npm package short-uuid so big thanks to the author.

An example of short uuid string in default flickrBase58 alphabet:

mhvXdrZT4jP5T8vBxuvm75

Getting started

Install the package with cargo:

cargo add short-uuid

or add it to your Cargo.toml:

[dependencies]
short-uuid = "0.2.0"

Examples

Generate short uuidv4 encoded in flickrBase58 format:

use short_uuid::ShortUuid;

let shortened_uuid = ShortUuid::generate();

Generate short uuidv4 encoded in flickrBase58 format using macro:

use short_uuid::short;

let shortened_uuid = short!();

Generate short uuidv4 using custom alphabet:

use short_uuid::{ShortUuidCustom, CustomTranslator};

let custom_alphabet = "abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ";
let translator = CustomTranslator::new(custom_alphabet).unwrap();

let custom_short = ShortUuidCustom::generate(&translator);
let custom_short_string = custom_short.to_string();

Get shortened uuid from standard uuid:

use short_uuid::ShortUuid;
// create normal uuid v4
let uuid = uuid::Uuid::new_v4();

let short = ShortUuid::from_uuid(&uuid);

Get shortened uuid from standard uuid using custom alphabet:

use short_uuid::{ShortUuidCustom, CustomTranslator};

let custom_alphabet = "abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ";
let translator = CustomTranslator::new(custom_alphabet).unwrap();

let uuid = uuid::Uuid::new_v4();
let short_custom = ShortUuidCustom::from_uuid(&uuid, &translator);
let short_custom_string = short_custom.to_string();

Get shortened uuid from uuid string:

use short_uuid::ShortUuid;

let uuid_str = "3cfb46e7-c391-42ef-90b8-0c1d9508e752";
let short_uuid = ShortUuid::from_uuid_str(&uuid_str);

Get shortened uuid from uuid string using custom alphabet:

use short_uuid::{ShortUuidCustom, CustomTranslator};

let custom_alphabet = "abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ";
let translator = CustomTranslator::new(custom_alphabet).unwrap();

let uuid_str = "3cfb46e7-c391-42ef-90b8-0c1d9508e752";
let short_custom = ShortUuidCustom::from_uuid_str(&uuid_str, &translator).unwrap();
let short_custom_string = short_custom.to_string();

Serialize and deserialize struct with short uuid (you must enable the serde feature):

[dependencies]
short-uuid = { version = "0.2.0", features = ["serde"] }

Example usage:

#[cfg(feature = "serde")]
#[derive(Serialize, Deserialize, PartialEq, Debug)]
struct TestStruct {
    id: ShortUuid,
}

#[cfg(feature = "serde")]
fn example() {
    let uuid_str = "0408510d-ce4f-4761-ab67-2dfe2931c898";
    let short_id = ShortUuid::from_uuid_str(uuid_str).unwrap();

    let test_struct = TestStruct {
        id: short_id,
    };

    let serialized = serde_json::to_string(&test_struct).unwrap();
}

References

Dependencies

~220–390KB