Skip to main content

A lean backend framework for type-safe Python APIs — file-based routing, typed config/DI, scoped providers, plugin registry, and background tasks.

Project description

causeway (Python)

A lean backend framework for type-safe Python APIs.

uv add 'causeway==0.1.0a0'   # alpha — drop the pin once v0.1.0 ships

This is the core Python package of Causeway. It ships:

  • A file-based router that walks src/app/routes/**/*.py, picks up [id].py, (group)/, _middleware.py, and _scope.py, and registers handlers into the app's route table.
  • A typed config layer that wraps pydantic-settings and exposes non-secret fields to the generated TypeScript client.
  • A scoped DI container driven by _scope.py providers.
  • A @task contract for background jobs with a Dramatiq reference adapter.
  • A plugin registry with Python-entry-point discovery and per-environment activation.
  • A CLI (causeway new, causeway dev, causeway build, causeway deploy <target>) that runs the whole loop.

For the full story, the design rationale, and a side-by-side vs. FastAPI / Django + Ninja / Encore.ts / NestJS, see the repo README.

30-second example

my-app/
├── pyproject.toml
├── causeway.toml
└── src/app/
    ├── config.py
    ├── plugins.py
    └── routes/
        ├── _middleware.py
        ├── index.py
        └── users/
            ├── _scope.py
            ├── index.py
            └── [id].py
# src/app/routes/users/[id].py
from typing import Annotated
from uuid import UUID
from msgspec import Struct
from causeway import get, raises
from causeway.errors import NotFound

class User(Struct):
    id: UUID
    name: str

@get
@raises(NotFound)
async def show(id: UUID) -> User:
    ...

Run it:

causeway dev

causeway dev discovers the routes, boots uvicorn, regenerates a typed client.ts for your frontend on every save, and exposes /__causeway with the route tree, registered tasks, current config, and plugin list.

Primitives in this package

Primitive Purpose
File router ([id].py, (group)/) Discovery + URL pattern generation.
_middleware.py / _scope.py Per-subtree middleware + scoped DI providers.
Settings (wraps pydantic-settings) Typed config with allowlisted exposure to the generated client.
@get / @post / @put / @patch / @delete HTTP method decorators.
@task(...) Background-job contract; adapter-agnostic.
@cron(...) Scheduled tasks via the same adapter.
register(...) Plugin registration (TaskAdapter, Storage, KV, AuthProvider, …).
TestApp Test client with DI overrides and tasks_eager() mode.
causeway CLI new, dev, build, plugins, deploy <target>.

Full reference: https://github.com/tamimbinhakim/causeway/tree/main/docs/api-reference

Optional extras

uv add 'causeway[dramatiq]'  # reference task adapter
uv add 'causeway[otel]'      # OpenTelemetry middleware hooks
uv add 'causeway[all]'       # everything

Scope

Causeway ships project shape and a small set of contracts. It does not ship vertical integrations — no ORM, no admin panel, no template engine, no infrastructure provisioning. Those layers compose on top of the fundamentals and live in their own plugin packages or in user code.

License

MIT

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

causeway-0.3.0.tar.gz (83.7 kB view details)

Uploaded Source

Built Distribution

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

causeway-0.3.0-py3-none-any.whl (81.4 kB view details)

Uploaded Python 3

File details

Details for the file causeway-0.3.0.tar.gz.

File metadata

  • Download URL: causeway-0.3.0.tar.gz
  • Upload date:
  • Size: 83.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for causeway-0.3.0.tar.gz
Algorithm Hash digest
SHA256 630fb7122b242ffe96483c0e7a2d98c31b2d45bbe35db5fa6e3c785c5baba60d
MD5 63a591bdfd702f132227091f9e8484d1
BLAKE2b-256 28921dd1d41a310afe2ec006893e02d80855ef71fbd467a650be9c63c8d54394

See more details on using hashes here.

Provenance

The following attestation bundles were made for causeway-0.3.0.tar.gz:

Publisher: release.yml on tamimbinhakim/causeway

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

File details

Details for the file causeway-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: causeway-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 81.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for causeway-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e07a66079075eb40a13934dba616f7e1de53214d4ba482f3c28c682e48aa81c1
MD5 d7b823d610db7e095b36a4539679bc84
BLAKE2b-256 a19c887a0c2b1da54b77526b8b9be61d8d2d59b8abe2b9d6be146b9a6317b7e1

See more details on using hashes here.

Provenance

The following attestation bundles were made for causeway-0.3.0-py3-none-any.whl:

Publisher: release.yml on tamimbinhakim/causeway

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