Skip to content

Type-safe, K-sortable, globally unique identifier inspired by Stripe IDs implemented in Zig.

License

Notifications You must be signed in to change notification settings

nikoksr/typeid-zig

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

 

typeid-zig

Type-safe, K-sortable, globally unique identifier inspired by Stripe IDs implemented in Zig.

 

Zig CI

 

About

Implementation of Type-IDs in Zig. Implemented as described by the official specification:

This implementation is part of the official list of community provided TypeID implementations.

What are Type-IDs?

As per the official specification:

TypeIDs are a modern, type-safe extension of UUIDv7. Inspired by a similar use of prefixes in Stripe's APIs.

TypeIDs are canonically encoded as lowercase strings consisting of three parts:

  1. A type prefix (at most 63 characters in all lowercase snake_case ASCII [a-z_]).
  2. An underscore '_' separator
  3. A 128-bit UUIDv7 encoded as a 26-character string using a modified base32 encoding.

Here's an example of a TypeID of type user:

user_2x4y6z8a0b1c2d3e4f5g6h7j8k
  │    │
  │    └── 26-character base32-encoded UUIDv7
  │
  └── Type prefix (snake_case [a-z_])
        Max length: 63 characters

A formal specification defines the encoding in more detail.

Installation

  1. Add as a dependency in your build.zig.zon:
zig fetch --save git+/~https://github.com/nikoksr/typeid-zig#main
  1. In your build.zig, add the typeid module as a dependency:
const typeid = b.dependency("typeid", .{
    .target = target,
    .optimize = optimize,
});

exe.root_module.addImport("typeid", typeid.module("typeid"));

Usage

const typeid = @import("typeid");
const TypeID = typeid.TypeID;
const StringBuf = typeid.StringBuf;

// Create a new TypeID with prefix
const tid = try TypeID.init("user");

// Get string representation.
// StringBuf is simply a convenience buffer that's big enough to hold a TypeID of any size.
//     => pub const StringBuf = [90]u8;
var str_buf: StringBuf = undefined;
const str = tid.toString(&str_buf); // "user_01h455vb4pex5vsknk084sn02q"

// Parse existing TypeID string
const parsed = try TypeID.fromString("post_01h455vb4pex5vsknk084sn02q");

Tests

zig build test

About

Type-safe, K-sortable, globally unique identifier inspired by Stripe IDs implemented in Zig.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages