1.0.0 • Published 6 years ago

@ch1/uid v1.0.0

Weekly downloads
1
License
LGPL-3.0
Repository
github
Last release
6 years ago

CH1 UID

CircleCI

This is not well maintained

Installation

yarn add @ch1/uid

Usage

import { createUid } from '@ch1/uid';

const uid = createUid();

const someId = uid();
const someOtherId = uid();
const someOtherIdStartingWithFoo = uid('Foo');

Ids have the following formats:

prefix-id-date-rollover-entropy

or

id-date-rollover-entropy

  • Where all numbers (id, date, rollover, and entropy) are in base 32.
  • Where id is internally generated at the createUid call
  • Where dates are timestamps in milliseconds
  • Where rollover is an internal numeric counter that increments to a maximum and then "rolls over"
  • Where entropy is random data added to the end

Customizing

There are options!

const uid = createUid(
  random: () => number, // random number generator, ideally returns `0 <= x < 1`
  date: () => number,   // timestamp in ms
  rolloverMax: number,  // internal rollover counter
  entropyMax: number,   // multiplier of `random()` for ends of uids
);

const someId = uid();

License

LGPL

1.0.0

6 years ago

0.3.0

6 years ago

0.2.0

6 years ago

0.1.0

6 years ago