Giter Site home page Giter Site logo

leodutra / simpleflakes Goto Github PK

View Code? Open in Web Editor NEW
33.0 4.0 1.0 232 KB

Fast and test-driven distributed 64-bit ID generation, using pure JavaScript, for Node.js.

Home Page: https://www.npmjs.com/package/simpleflakes

License: Other

JavaScript 100.00%
uid generator guid sharding microservices

simpleflakes's Introduction

simpleflakes

travis status npm

coveralls status FOSSA Status

tonicdev demo david dep status david dev dep status

Simpleflake is the smartest way to generate a 64-bit + time-ordered + snowflake based ID. See the presentation!

Test-driven, pure JavaScript

This port is test-driven and no release goes out without tests.
Also, this library does not rely on low-level bindings, with OpenSSL, libgmp or anything beyond pure JavaScript.

Assumes original Python implementation as reference and fixes epoch (starts on 2000-01-01T00:00:00.000Z (UTC) while Python API v0.1.5 epoch starts on 2000-01-01T05:00:00.000Z).

simpleflakes uses the TC39 BigInt implementation when running on newer versions of Node.js. When BigInt is not available, Fedor Indutny's big number library (bn.js) is used as the fastest fallback for big number calculations.

How to Install:

npm install simpleflakes --save

Usage:

const { simpleflake } = require('simpleflakes');

const flakeBigInt = simpleflake()

// simpleflake(
//    timestamp = Date.now(), 
//    random_bits = 23-bit random, 
//     epoch = Date.UTC(2000, 0, 1)
// )
// returns BigInt on newer Node.js or bn.js BigNum on older engines.

flakeBigInt.toString();       // 4234673179811182512
flakeBigInt.toString(16);     // 3ac494d21e84f7b0
flakeBigInt.toString(2);      // 11101011000100...
flakeBigInt.toString(36);     // 20rfh5

You can check the original Python API 0.1.5 documentation for more info.

Reference

// Main flake function and its defaults
simpleflake(
    timestamp = Date.now(), 
    random_bits = 23-bit random, 
    epoch = Date.UTC(2000, 0, 1)
)

// Static constant epoch for simpleflake timestamps, starts at the year 2000  
simpleflake.SIMPLEFLAKE_EPOCH // const = 946702800

// Show binary digits of a number, pads to 64 bits unless specified.
simpleflake.binary(number, padding=true)

// Extract a portion of a bit string. Similar to substr().
simpleflake.extractBits(data, shift, length)

// Parses a simpleflake and returns a named tuple with the parts.
simpleflake.parseSimpleflake(flake)

// original API alias for SimpleFlake class, from the Python API
simpleflake.simpleflakeStruct

// same as simpleflake.simpleflakeStruct
SimpleFlake.SimpleFlakeStruct

License:

MIT

FOSSA Status

simpleflakes's People

Contributors

dependabot[bot] avatar fossabot avatar leodutra avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar

Forkers

fossabot

simpleflakes's Issues

minor readme correction?

In the example showing the function signature for simpleflake I see this: ,random_bits=23-bit random,.

Is that supposed to be 32-bit?

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.