Skip to main content

Config-driven helpers for Python projects (dynamic config, secure secrets, preset logging, and more…)

Project description

Kstlib Logo

Config-driven Python toolkit for resilient applications

CI Documentation PyPI Python License


kstlib is a personal Python toolkit built over 7 years of learning and experimentation.

It started as a way to explore Python best practices, evolved into utilities for personal automation, and now serves as the foundation for study projects in algorithmic trading and market analysis.

The focus has always been on building resilient, secure, and performant systems.

Note: Everything works via Python, but since kstlib is heavily config-driven, the Examples Gallery showcases a YAML-first approach.

Core Modules

Module Purpose
config Cascading config files, includes, SOPS encryption, Box access
secrets Multi-provider resolver (env, keyring, SOPS, KMS) with guardrails
logging Rich console, rotating files, TRACE level, structlog integration
auth OIDC/OAuth2 with PKCE, token storage, auto-refresh
mail Jinja templates, transports (SMTP, Gmail API, Resend, AWS SES)
alerts Multi-channel (Slack, Email), throttling, severity levels
websocket Resilient connections, auto-reconnect, heartbeat, watchdog
rapi Config-driven REST client with HMAC signing
pipeline Declarative sequential workflows (shell/python/callable steps), error policies, conditional execution
monitoring Collectors + Jinja rendering + delivery (file, mail)
resilience Circuit breaker, rate limiter, graceful shutdown
ops Session manager (tmux), containers (Docker/Podman)
helpers TimeTrigger, formatting, secure delete, validators

Quick Start

Installation

pip install kstlib

Basic Usage

from kstlib.config import load_from_file
from kstlib import cache

config = load_from_file("config.yml")

@cache(ttl=300)
def expensive_computation(x: int) -> int:
    return x ** 2

result = expensive_computation(5)

Minimal Configuration

app:
  name: "My Application"
  debug: true

database:
  host: "localhost"
  port: 5432

Documentation

Full documentation available at kstlib.readthedocs.io

Installation Options

# Standard install
pip install kstlib

# With uv (faster)
uv pip install kstlib

# Development install
pip install "kstlib[dev]"

# All extras
pip install "kstlib[all]"

# From GitHub (latest)
pip install "git+https://github.com/KaminoU/kstlib.git"

License

MIT License - Copyright 2025 Michel TRUONG

See LICENSE for full text.

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

kstlib-1.7.1.tar.gz (335.2 kB view details)

Uploaded Source

Built Distribution

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

kstlib-1.7.1-py3-none-any.whl (412.9 kB view details)

Uploaded Python 3

File details

Details for the file kstlib-1.7.1.tar.gz.

File metadata

  • Download URL: kstlib-1.7.1.tar.gz
  • Upload date:
  • Size: 335.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kstlib-1.7.1.tar.gz
Algorithm Hash digest
SHA256 3d71a72e54d32831499e92f58a3b62f324cc48b8a3414eac3f431b052cda4c3e
MD5 c2380f0ab0f4138fd0c1d15f2dea22d2
BLAKE2b-256 8f99dec6dc9054741813ce6e9b6550b6bb6df5af203ad1ba5d43be5f48f1cd89

See more details on using hashes here.

Provenance

The following attestation bundles were made for kstlib-1.7.1.tar.gz:

Publisher: ci.yml on KaminoU/kstlib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kstlib-1.7.1-py3-none-any.whl.

File metadata

  • Download URL: kstlib-1.7.1-py3-none-any.whl
  • Upload date:
  • Size: 412.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kstlib-1.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9b5257f2ac6968e3f7f5ad79024663e16e5c85e955ad70c447393a7a0ff4e53d
MD5 254e3ab2533b39d87ee23d2dedb2f659
BLAKE2b-256 26260968ed25f3058ec058474d5b443973d57a6a5548c66ad58f3cc8ada4984f

See more details on using hashes here.

Provenance

The following attestation bundles were made for kstlib-1.7.1-py3-none-any.whl:

Publisher: ci.yml on KaminoU/kstlib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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