Skip to content

Commit

Permalink
feat!: ✨ update snowflake generation logic (#18)
Browse files Browse the repository at this point in the history
* feat: ♻️ refactored snowflake generation logic

* fix: 🐛 remove .only

* build(deps): ⬆️ packages bumped up

BREAKING CHANGE: core logic for generating snowflake if updated
  • Loading branch information
AkashRajpurohit committed Oct 31, 2023
1 parent e65cdaf commit 4e31c45
Show file tree
Hide file tree
Showing 7 changed files with 716 additions and 1,386 deletions.
20 changes: 4 additions & 16 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -62,8 +62,6 @@ import { SnowflakeId } from '@akashrajpurohit/snowflake-id';

const snowflake = SnowflakeId({
workerId: 1,
nodeIdBits: 10,
sequenceBits: 12,
epoch: 1597017600000,
});

Expand All @@ -76,18 +74,10 @@ This will generate a unique ID in string format.

The SnowflakeId constructor takes an options object with the following properties:

- `workerId` (optional): A number between 0 and (2^`nodeIdBits`)-1 that represents the ID of the worker generating the IDs.
- `workerId` (optional): A ID of the worker generating the Snowflake IDs.

Defaults to 0 if not specified.

- `nodeIdBits` (optional): The number of bits used to represent the worker ID.

Defaults to 10 if not specified.

- `sequenceBits` (optional): The number of bits used to represent the sequence number.

Defaults to 12 if not specified.

- `epoch` (optional): A timestamp in milliseconds representing the start of the ID generation.

Defaults to August 10, 2020 at 00:00:00 UTC if not specified.
Expand All @@ -100,11 +90,11 @@ The SnowflakeId instance has the following methods:

## Error Handling 😱

The SnowflakeId instance throws an error if the clock moves backwards, i.e., if the current timestamp is less than the last timestamp.
There are two errors that can be thrown by the SnowflakeId instance:

This can happen if the system clock is adjusted manually or if the system clock drifts significantly.
- `Invalid Epoch Error`: The SnowflakeId instance throws an error if the epoch timestamp is invalid, i.e., if the epoch timestamp is greater than the current timestamp.

If this happens, the library throws an Error with the message `Clock is moving backwards!`.
- `Clock Backwards Error`: The SnowflakeId instance throws an error if the clock moves backwards, i.e., if the current timestamp is less than the last timestamp.

## Examples 🔠

Expand Down Expand Up @@ -148,8 +138,6 @@ console.log(id);

## Notes 📝

- It is recommended to use a higher `nodeIdBits` or `sequenceBits` value if you expect to generate IDs on multiple machines, as this reduces the chance of ID collisions.

- The `workerId` parameter can be omitted, in which case the `workerId` would be set to 0. However, if you expect to generate IDs on multiple machines, it is recommended to set a specific workerId value to reduce the chance of ID collisions.

- The epoch timestamp should be set as close to the current time as possible to maximize the lifespan of the generator. If the epoch is set too far in the past or future, the generator may not be able to generate IDs for the full lifespan of the generator.
Expand Down
16 changes: 8 additions & 8 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -47,14 +47,14 @@
"semantic-release": "semantic-release"
},
"devDependencies": {
"@types/node": "^20.1.3",
"@vitest/coverage-v8": "^0.34.1",
"conventional-changelog-conventionalcommits": "^6.0.0",
"prettier": "^3.0.0",
"semantic-release": "^21.0.2",
"tsup": "^7.0.0",
"typescript": "^5.0.4",
"vitest": "^0.33.0"
"@types/node": "^20.8.10",
"@vitest/coverage-v8": "^0.34.6",
"conventional-changelog-conventionalcommits": "^7.0.2",
"prettier": "^3.0.3",
"semantic-release": "^22.0.6",
"tsup": "^7.2.0",
"typescript": "^5.2.2",
"vitest": "^0.34.6"
},
"publishConfig": {
"access": "public"
Expand Down
Loading

0 comments on commit 4e31c45

Please sign in to comment.