1.0.0 • Published 2 years ago

snowflaketmpscoped v1.0.0

Weekly downloads
-
License
AGPL-3.0-or-later
Repository
github
Last release
2 years ago

Snowflake-UUID

Twitter's Snowflake generator for NodeJS.

  • Speedy
  • Lightweight
  • Zero dependencies

Snowflake-UUID can generate unique Id numbers at high scale with some simple guarantees.

Installing

npm install snowflake-uuid
// or
yarn add snowflake-uuid
// or
pnpm add snowflake-uuid

Example

import { Worker } from 'snowflake-uuid';
// const { Worker } = require('snowflake-uuid');

const generator = new Worker(0, 1, {
	workerIdBits: 5,
	datacenterIdBits: 5,
	sequenceBits: 12,
});

generator.nextId(); // 87559690812260352n
generator.nextId().toString(); // '87559690833231872'

generator.currentSequence; // 0n
generator.datacenterId; // 1n
generator.lastTimestamp; // 1630335057075n
generator.workerId; // 0n

Generated IDs are BigInt and can be easily converted into strings.

Constructor Options

PropertyDescriptionOptional?TypeDefault Value
workerIdId for the workerYesNumber or BigInt0
datacenterIdIdentifier of the datacenter to which the worker belongsYesNumber or BigInt0
optionsCustom options for the workerYesObjectundefined
options.epochCustom epoch for timestamp generation. By default, the number of milliseconds since the first second of 2021YesNumber or BigInt1609459200000
options.workerIdBitsNumber of usable bits for Worker Id. 5 by default, allows up to 31 WorkersYesNumber or BigInt5
options.datacenterIdBitsNumber of usable bits for Datacenter Id. 5 by default, allows up to 31 DatacentersYesNumber or BigInt5
options.sequenceFor every Id that is generated on that process, this number is incrementedYesNumber or BigInt0
options.sequenceBitsNumber of usable bits for Sequence Id. 12 by default, allows up to 4095 generations per millisecond per Worker per DatacenterYesNumber or BigInt12

Useful Links

License

Refer to the LICENSE file.

1.0.0

2 years ago