Pretty cool IDs for your APIs
Project description
PrettyId
Pretty cool IDs for your APIs.
poetry add prettyid
Synopsis
Generate prefixed IDs, like Stripe does:
>>> from pretty_id import PrettyId
>>> pid = PrettyId.random("task")
PrettyId("task_068n34jrjdth1fqr2nm9a0sh50")
>>> pid.type, pid.id
('task', '068n34jrjdth1fqr2nm9a0sh50')
>>> pid.bytes
b'...'
Backwards compatible with UUID:
>>> pid = PrettyId.from_uuid("1d4e2ea4-c1ab-4a98-8eeb-898051ef0f71", type="task")
PrettyId("task_3n72x961nd59h3qbh6053vrfe4")
>>> pid.uuid
UUID('1d4e2ea4-c1ab-4a98-8eeb-898051ef0f71')
Works with Pydantic and FastAPI:
@app.route("/tasks/{id}")
def get_task_by_id(id: FriendlyId):
if id.type != "task":
raise HTTPException(status_code=400, detail="ID should start with 'task_'")
return {
"id": id,
"title": "TODO",
}
And with SQLAlchemy:
from pretty_id.ext.sqlalchemy import PrettyIdBinaryType
class TaskModel(Base):
id: Mapped[PrettyId] = mapped_column(
PrettyIdBinaryType("task"),
index=True,
unique=True,
primary_key=True,
default=partial(PrettyId.random, "task")
)
title: Mapped[str]
# Pass PrettyId instance or just string
select(TaskModel).filter(
TaskModel.id == "task_068n34jrjdth1fqr2nm9a0sh50"
)
Design
Generated IDs use UUIDv7 underneath:
>>> u = UUID(bytes=pid.bytes)
UUID('01917192-7b9b-7b10-bf5b-15ec95039128')
>>> u.version
7
This means they inherit some useful properties:
-
Natural Sorting: UUIDv7 values are time-sortable, which means you can sort them in increasing order based on when they were generated. Databases often require additional timestamp columns to sort records based on creation time. With PrettyId, you can achieve this sorting using the ID itself, eliminating the need for extra columns.
-
Optimized Indexing: Since UUIDv7 is time-sortable, database indexing mechanisms can better optimize the storage and retrieval processes, leading to faster query times especially for time-based queries.
-
Concurrency and Distribution: In distributed systems, generating unique, sequential IDs can be a challenge. UUIDv7 can be generated concurrently across multiple nodes without the risk of collisions, making it suitable for distributed architectures.
IDs are encoded as lowercase Base32 using Douglas Crockford’s alphabet. This makes them compact, readable, and case-insensitive.
In database, IDs are stored without prefix using a native UUID type or BINARY(16)
. (We assume that the prefix can be determined from the table name.)
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
Built Distribution
File details
Details for the file prettyid-0.3.0.tar.gz
.
File metadata
- Download URL: prettyid-0.3.0.tar.gz
- Upload date:
- Size: 8.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.9.12-401.asahi.fc40.aarch64+16k
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e93f3f90ceefbb61a201aa4c9561b959ab42bae7d4a10142a746cb338a86692d |
|
MD5 | 53a3c86791c571edc4eb1399395fd6e0 |
|
BLAKE2b-256 | 2d9b9c0b5af9de60939c3c52c1a5568f8b5dddad87f8aa17da3ce69923d132a8 |
File details
Details for the file prettyid-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: prettyid-0.3.0-py3-none-any.whl
- Upload date:
- Size: 9.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.9.12-401.asahi.fc40.aarch64+16k
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ce14852ed8d934c545a033723a336f509258dc322976060b755dc9a8390dd834 |
|
MD5 | 1eec1f6353d61960afbfe94993364760 |
|
BLAKE2b-256 | ab8a3dff7e27d0d919ef714038c385650b13fd4dd588ef3454fe2273e191a98d |