Skip to main content

Shared utilities and models for TL;DR.tv platform

Project description

Common Module

Shared utilities and models for the TL;DR.tv platform.

Structure

common/
├── src/common/
│   ├── core/          # Core functionality (config, exceptions, dependencies)
│   ├── dao/           # Data Access Objects
│   ├── database/      # Database connectivity
│   ├── logging/       # Logging configuration
│   ├── message/       # Message queue models
│   ├── models/        # Domain models
│   ├── platform/      # Platform-specific APIs (Twitch, Kick)
│   └── utils/         # Utility functions
└── tests/
    ├── unit/          # Unit tests
    └── integration/   # Integration tests

Installation

The common module is part of the uv workspace and is automatically available to other services.

For development:

uv pip install -e common

Usage

Data Access Objects (DAOs)

from common.dao import UserDAO, StreamDAO, ClipDAO
from common.database import Db, DBConfig

# Initialize database
db = Db(DBConfig())

# Create DAOs
user_dao = UserDAO(db)
stream_dao = StreamDAO(db)
clip_dao = ClipDAO(db)

Platform APIs

from common.platform.twitch import TwitchApi, TwitchApiConfig
from common.platform.kick import KickApi, KickApiConfig

# Initialize APIs
twitch_api = TwitchApi(config=TwitchApiConfig())
kick_api = KickApi(config=KickApiConfig())

Message Models

from common.message import StreamOnlineMessage, StreamOfflineMessage

# Create messages for RabbitMQ
message = StreamOnlineMessage(
    stream_id="12345",
    user_id=67890,
    platform="twitch",
    started_at=datetime.now()
)

Exception Handling

from common.core.exceptions import (
    DatabaseError,
    TwitchError,
    KickError,
    ValidationError,
    RateLimitError
)

try:
    # Database operation
    user = await user_dao.get_user_by_id(user_id)
except DatabaseError as e:
    logger.error(f"Database error: {e}")

Testing

Run all tests:

uv run pytest common/tests/

Run unit tests only:

uv run pytest common/tests/unit/

Run integration tests:

uv run pytest common/tests/integration/

Type Checking

The module includes type information (py.typed). Run type checking with:

uv run ty check common/

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

tldr_common-0.1.10.tar.gz (116.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tldr_common-0.1.10-py3-none-any.whl (142.0 kB view details)

Uploaded Python 3

File details

Details for the file tldr_common-0.1.10.tar.gz.

File metadata

  • Download URL: tldr_common-0.1.10.tar.gz
  • Upload date:
  • Size: 116.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for tldr_common-0.1.10.tar.gz
Algorithm Hash digest
SHA256 4c93ada71a9d20930855fdf4932c486510190f063f89d39545127d2d1936b4e2
MD5 e5c1b0d79423c82c7010d91d46613f25
BLAKE2b-256 d22c9c3a9eb942d6f33672704b9a4ef9a51b732c3490fee6da8037a965970f11

See more details on using hashes here.

File details

Details for the file tldr_common-0.1.10-py3-none-any.whl.

File metadata

  • Download URL: tldr_common-0.1.10-py3-none-any.whl
  • Upload date:
  • Size: 142.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for tldr_common-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 a5efa01c754e77ee3da2b931ac3eddcdbd51e95a2a54498dc109da1ca473f92d
MD5 362e428d5b3020ac656133c3afd87f0a
BLAKE2b-256 fd664b5b98372c4d3666b06a7249d7dd3366b61896ee9d5c12e897c9a8884ea9

See more details on using hashes here.

Supported by

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