Skip to main content

Gid is a small library for generating short globally unique, sortable uri safe identifiers.

Project description

Gid
Release Linting and Tests codecov License: MIT

Gid is a small library for generating short globally unique, sortable uri safe identifiers.

Features

  • Generated ids are sortable
  • Generated ids carry creation time expressed in microseconds
  • Generated ids are globally unique
  • Minimal footprint
  • High performance

Installation

With pip,

pip install gid

or through poetry

poetry add gid

Example ids

ShmX2HaaUB9UQL02 
ShmX2JGvSk4ZyZ13 
ShmX2Ku8mDizRc23 
ShmX2MWQVL5J7022 
ShmX2OCegs4MdP22 
ShmX2Pu2MDVFHa02 
ShmX2RYngGET4Z32 
ShmX2TCM6v701q23 
ShmX2UrBjxNGYM11

Usage

Generating id

from gid import Guid

some_id = Guid()
some_id.timestamp # contains timestamp expressed in milliseconds
str(some_id) # can be cast to a string

Recreating id from string

from gid import Guid
my_id = Guid()

same_id = Guid(str(my_id))

assert same_id == my_id
assert same_id.timestamp == my_id.timestamp

Id structure

Generated identifiers are case-sensitive, which means string functions (like lowercase or uppercase) on generated identifiers may break it because Sbt5LrD9iSAwb300 is not the same value as Sbt5LrD9iSAwB300.

The below diagram represents single identifier's structure, which is 16-character long:

    Sbt5LrD9iSAwb300
    |      |      |
    +- first 7 characters for millisecond timestamp
           |      |
           +- next 7 characters is randomly generated hash
                  |
                  + last two characters to ensure uniqueness of guid in a single millisecond

Within 1 ms there can be (62^2 - 620) unique generated ids on a single machine.

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

gid-1.0.1.tar.gz (4.3 kB view details)

Uploaded Source

Built Distribution

gid-1.0.1-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

Details for the file gid-1.0.1.tar.gz.

File metadata

  • Download URL: gid-1.0.1.tar.gz
  • Upload date:
  • Size: 4.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.8 CPython/3.8.11 Linux/5.8.0-1039-azure

File hashes

Hashes for gid-1.0.1.tar.gz
Algorithm Hash digest
SHA256 822c77f9129ebb37f6e8b85a46d7faca4f9ec1163cb669273f23b0a3eaa4f6bd
MD5 a2f384a134927dc062e1de3ea1524f1e
BLAKE2b-256 22b786689440004e26be666795c04bd3a1ec1a97334f86cb5992a3301d62e6bd

See more details on using hashes here.

File details

Details for the file gid-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: gid-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 4.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.8 CPython/3.8.11 Linux/5.8.0-1039-azure

File hashes

Hashes for gid-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4f8cd8e491416258a0c1d0244a25b75db37eef5cf271f4f8e42c9c1e662bc24b
MD5 231e9b7046178a15d09595f6cff0e01d
BLAKE2b-256 97cfebd1b84f1308b2b3c8f88d9592c6ca6cf54161b3a3369e2ca2fe60adac1a

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