Skip to main content

Modern Python 3.11+ Framework: Flask/FastAPI orchestration, and strict runtime enforcement.

Project description

🛡️ py_aide

Modern Python 3.11+ Framework: Flask/FastAPI Orchestration & Strict Runtime Enforcement

py_aide is a robust, developer-centric framework designed to bring safety, structure, and consistency to Python web applications. It provides a unique "Strict Runtime Enforcement" layer that ensures your code remains clean, documented, and type-safe at execution time.


🚀 Key Features

  • Strict Runtime Enforcement: A powerful decorator that enforces type hints, docstrings, and calling conventions at runtime.
  • Unified Server Portal: Seamlessly orchestrate Flask and FastAPI applications with shared security gates.
  • Circuit Breaker Resilience: Industrial-grade protection against cascading failures.
  • Thread-Safe SQL: A thread-level multiton SQLite manager with automatic JSON serialization and a custom DSL.
  • Modern Security: Argon2id password hashing with background rehashing and Fernet-based encryption.
  • Enterprise HTTP Client: A standardized, "always resolve" HTTP client with built-in retries and interceptors.

📚 Documentation Roadmap

We recommend exploring the framework in this order:

⚙️ Core System

  • Structural Enforcement: Learn about the @enforce_requirements decorator and the validation engine.
  • Global Utilities: Discover helpers for dates, image processing, secure codes, and file system operations.

🌐 Server & API

  • Service Portals: Documentation for Flask/FastAPI orchestration, security gates, and WebSockets.
  • HTTP Client & Response: Master the "Always Resolve" strategy and the unified Response protocol.

🧵 Persistence & Concurrency

🔐 Security


⚙️ Core Philosophy: Strict Enforcement

At the heart of py_aide is the @enforce_requirements decorator. It prevents "sloppy" code by failing early (at boot-time or runtime) if your contracts are violated.

from py_aide.enforcer import enforce_requirements
from py_aide.customTypes import Options

@enforce_requirements
def create_user(*, name: str, role: Options[str, ["admin", "user"]]) -> dict:
    """Creates a new user record with runtime type and choice validation."""
    return {"name": name, "role": role}

📦 Installation

# Core only (Encryption, Tokens, Threading, Base Requests)
pip install py_aide

# With Flask Portal & WebSockets
pip install "py_aide[flask]"

# With FastAPI Portal & Uvicorn
pip install "py_aide[fastapi]"

# With Database/Cache drivers
pip install "py_aide[postgres,redis,sqlite]"

# Install everything
pip install "py_aide[all]"

Note: py_aide requires Python 3.11+ and is currently optimized for Linux environments.


📄 License

This project is licensed under the MIT License.

👥 Authors

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

py_aide-0.32.0.tar.gz (217.5 kB view details)

Uploaded Source

Built Distribution

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

py_aide-0.32.0-py3-none-any.whl (214.7 kB view details)

Uploaded Python 3

File details

Details for the file py_aide-0.32.0.tar.gz.

File metadata

  • Download URL: py_aide-0.32.0.tar.gz
  • Upload date:
  • Size: 217.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for py_aide-0.32.0.tar.gz
Algorithm Hash digest
SHA256 03919d02ba8caa94c814e7781206852636acee2079081b39d858df0b1ff17daf
MD5 118d7a216559cdcadc0a1322128d85e2
BLAKE2b-256 1c369f75174b3804ebbdfe22c4f508d76b91e1b2c47ec96d6bbc3e26764de5f2

See more details on using hashes here.

File details

Details for the file py_aide-0.32.0-py3-none-any.whl.

File metadata

  • Download URL: py_aide-0.32.0-py3-none-any.whl
  • Upload date:
  • Size: 214.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for py_aide-0.32.0-py3-none-any.whl
Algorithm Hash digest
SHA256 356675da511763277e11e38ef1be6dd6f5152aca74498b9bb0aea34c16d4d9f4
MD5 46bf8a24d9eede85e431e48a4ac24e25
BLAKE2b-256 f83f7dbdc426c3b5d62e51afe5e3701de86c1f8e4b4977beb0318afa060b9f70

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