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.33.1.tar.gz (217.9 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.33.1-py3-none-any.whl (215.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: py_aide-0.33.1.tar.gz
  • Upload date:
  • Size: 217.9 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.33.1.tar.gz
Algorithm Hash digest
SHA256 0adfe44b302b4c139d8191098b57b07bc938ff1c1561a72a84f265c93d6e5a22
MD5 c1c92ec5610839188c89bb4a9b23c153
BLAKE2b-256 fc7cfc478854f8a5eed87b8a55539ad7319341eafce8bf92394dfbc35352f9ec

See more details on using hashes here.

File details

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

File metadata

  • Download URL: py_aide-0.33.1-py3-none-any.whl
  • Upload date:
  • Size: 215.0 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.33.1-py3-none-any.whl
Algorithm Hash digest
SHA256 55ddcd06e7adcb932cdbec0ad60ff57f3a9a8dca778e635f4004294c5f136d6b
MD5 0ba99bc407b14ca1be50bac0a3d614a0
BLAKE2b-256 f65a9e408f8e4525f33436efb07cdab8a8e41af4889f5b501c6bc7b19cc58627

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