Custom CORS Middleware for Swarmauri Framework
Project description
Swarmauri Middleware CORS
Custom CORS middleware for the Swarmauri framework that integrates with FastAPI applications.
Features
- Handles CORS preflight (
OPTIONS) requests directly and returns a200response with your configured headers. - Adds CORS headers to downstream responses produced by your FastAPI routes.
- Rejects requests with a missing
Originheader or an origin that is not explicitly allowed, returning a403response. - Allows fine-grained control of the exposed headers, allowed methods, credentials support, and cache duration of the CORS policy.
Installation
pip
pip install swarmauri_middleware_cors
Poetry
poetry add swarmauri_middleware_cors
uv
uv venv
source .venv/bin/activate # Use .\.venv\Scripts\activate on Windows
uv add swarmauri_middleware_cors
Usage
Configure the middleware with the exact origins, methods, and headers you want to allow. Origins are matched literally—if you use the default ['*'] setting, every request must send an Origin: * header. In practice you should list the concrete origins your frontend sends.
Python example
from fastapi import FastAPI
from fastapi.testclient import TestClient
from swarmauri_middleware_cors import CustomCORSMiddleware
app = FastAPI()
cors = CustomCORSMiddleware(
allow_origins=["https://frontend.example"],
allow_methods=["GET", "OPTIONS"],
allow_headers=["Authorization"],
expose_headers=["X-App-Version"],
max_age=300,
)
@app.middleware("http")
async def apply_custom_cors(request, call_next):
return await cors.dispatch(request, call_next)
@app.get("/ping")
async def ping():
return {"status": "ok"}
client = TestClient(app)
if __name__ == "__main__":
options_response = client.options(
"/ping", headers={"Origin": "https://frontend.example"}
)
print(
"Allowed origin header:",
options_response.headers["Access-Control-Allow-Origin"],
)
response = client.get(
"/ping", headers={"Origin": "https://frontend.example"}
)
print("Response JSON:", response.json())
Running the example prints the allowed origin configured on the middleware and the JSON payload returned by the GET /ping route.
Want to help?
If you want to contribute to swarmauri-sdk, read up on our guidelines for contributing that will help you get started.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swarmauri_middleware_cors-0.8.0.dev45.tar.gz.
File metadata
- Download URL: swarmauri_middleware_cors-0.8.0.dev45.tar.gz
- Upload date:
- Size: 8.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4a18049850b271841611e37514495737ba15f4edb7db4bc37bfb76af7880f95d
|
|
| MD5 |
dfeea8c94620f493941d92fca39c2666
|
|
| BLAKE2b-256 |
b2b2ca7202e5822429c80ed5cbb0181e20a62080f947b31520a57322df21b8cc
|
File details
Details for the file swarmauri_middleware_cors-0.8.0.dev45-py3-none-any.whl.
File metadata
- Download URL: swarmauri_middleware_cors-0.8.0.dev45-py3-none-any.whl
- Upload date:
- Size: 9.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f04f17afcddd1529ff18f445582b1bc5339a70f6bd51d1ac66c15ed1874855b5
|
|
| MD5 |
acb372c67660ae0a93c0450c22dbc199
|
|
| BLAKE2b-256 |
ad8b6fc909868a808a3ca9a4d8bd402264c684cb317c7c4a98c90c24e1090513
|