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.0.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.0-py3-none-any.whl (215.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: py_aide-0.33.0.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.0.tar.gz
Algorithm Hash digest
SHA256 4e2f80f531f407af1c2e681d044cf0ac08cc670a06e481e0003f2a9a36e6d55f
MD5 8265a3fa0b1f888bb52be2e1fa21543a
BLAKE2b-256 4df41ed28612fa9a4ddaf1b401814f983dd86c77c76b4c36dbf1244ba27686d3

See more details on using hashes here.

File details

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

File metadata

  • Download URL: py_aide-0.33.0-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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 37e25c92a29ea2bea20c931f72101b277756333e32411845522cee6c53adaa69
MD5 54782f6295d76b2681dbb7b46dd24e18
BLAKE2b-256 ca8d73933bfe6d6875508fd2e419c7c9534bd1d5daa1701953a806086eddc602

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