@chronark/prefixed-id
TypeScript icon, indicating that this package has built-in type declarations

0.4.1 • Public • Published

@chronark/prefixed-id

pre_JUbF9zRGz9hrFXUyNJLXcowD9GsqCD

A minimal library to generate Stripe inspired predixed ids for your application. Prefixed ids look like this: pre_JUbF9zRGz9hrFXUyNJLXcowD9GsqCD. They can be very useful if you have different entities and want to quickly identify them.

Generated ids rely on the provided crypto implementation. If you use either window.crypto or crypto from "node:crypto", the ids will be cryptographically secure.

Works in

  • Nodejs
  • Cloudflare Workers
  • Vercel Edge

Install

npm i @chronark/prefixed-id

Usage

Nodejs

import nodeCrypto from "node:crypto"

const idGenerator = new IdGenerator({
    prefixes: {
        "user": "u",
    },
    crypto: nodeCrypto
})

console.log(idGenerator.id("user"))
// u_PtbBA7NGcYYDpae6ULWujk

WebCrypto

  • Cloudflare Workers
  • Vercel Edge
const idGenerator = new IdGenerator({
    prefixes: {
        "user": "u",
    },
    crypto: crypto // will be globally defined
})

console.log(idGenerator.id("user"))
// u_PtbBA7NGcYYDpae6ULWujk

Options

You may pass these options to the constructor to customize the id generation.

{
	/**
	 *
	 * @default "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"
	 */
	alphabet?: string;

	/**
	 * Either window.crypto or crypto from node
	 *
	 * @default window?.crypto
	 */
	crypto?: Crypto;

	/**
	 * Byte size of the generated id
	 */
	size?: number;
};

Readme

Keywords

none

Package Sidebar

Install

npm i @chronark/prefixed-id

Weekly Downloads

29

Version

0.4.1

License

ISC

Unpacked Size

25.4 kB

Total Files

8

Last publish

Collaborators

  • chronark