Skip to main content

EasyFlake is a Python package for generating 64-bit IDs similar to Snowflake or Sonyflake.

Project description

EasyFlake

Test passing codecov PyPI PyPI - Python Version License

EasyFlake is a Python package for generating 64-bit IDs similar to Snowflake or Sonyflake. It provides a simple way to generate unique and sortable IDs that can be used as primary keys in databases, message queue messages, or other distributed systems.

Installation

Install the latest version of EasyFlake using pip:

pip install easyflake

Usage

To use EasyFlake, simply create an instance of the EasyFlake class, passing in a unique node ID:

from easyflake import EasyFlake

ef = EasyFlake(node_id=1)
print(ef.get_id())

The get_id() method generates the next ID by the current timestamp. You can customize the number of bits used for the node ID and sequence ID parts, as well as the epoch timestamp and time scale.

ef = EasyFlake(node_id=0, node_id_bits=4, sequence_bits=6)
print(ef.get_id())

Arguments

  • node_id (int): A unique ID for the current node. This ID should be between 0 and (2 ^ node_id_bits) - 1. If no argument is given, a random value is assigned to the node ID.
  • node_id_bits (int): The maximum number of bits used to represent the node ID. This argument defaults to 8 / max node ID is 255.
  • sequence_bits (int): The maximum number of bits used to represent the sequence number. This argument defaults to 8 / max sequence number is 255.
  • epoch (float): A timestamp used as a reference when generating the timestamp section of the ID. This argument defaults to 1675859040 (2023-02-08T12:24:00Z).
  • time_scale (int): The number of decimal places used to represent the timestamp. This argument defaults to 3 (milliseconds).

Contributing

See the contributing guide.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

easyflake-0.0.4.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

easyflake-0.0.4-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file easyflake-0.0.4.tar.gz.

File metadata

  • Download URL: easyflake-0.0.4.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.10.6 Linux/5.15.0-60-generic

File hashes

Hashes for easyflake-0.0.4.tar.gz
Algorithm Hash digest
SHA256 784940fd84941f0ddb6bd5a7d55269e5761f802ebd97fb7c8f9186859ae1bef8
MD5 a79c17efbe75a2e0dfc0c71ab4ee9956
BLAKE2b-256 482a492a25df9e44187c693435731ffb502fc578c436480c7478a1f6e02102b0

See more details on using hashes here.

File details

Details for the file easyflake-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: easyflake-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 6.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.10.6 Linux/5.15.0-60-generic

File hashes

Hashes for easyflake-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 bf1ae2f6b6c1dc52665e8e2106da737c27d4cfe2874ea43f831120b79ea6151a
MD5 81237a902d0a41c4560917b9c52acbd1
BLAKE2b-256 5aa5aeb5ed1eeff4e97924951a8b6799de9da89e4efce4ac3399161b70013826

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page