Decorate FastAPI endpoints with custom decorators.
Project description
FastAPI decorators
Small Python utility for wrapping your FastAPI endpoints in custom decorators.
Installation
pip install fastapi-decorators
Usage
Create a simple decorator that rejects unauthorized requests:
oauth2_scheme = OAuth2PasswordBearer(
tokenUrl="/api/v1/auth/login",
auto_error=False,
)
def authorize(*required_scopes: str):
def decorator(func):
def dependency(
token: Optional[str] = Depends(oauth2_password_scheme),
db_session: Session = Depends(get_db),
):
# Execute your auth logic here
...
return add_dependencies(Depends(dependency))(func)
return decorator
The decorator can be used like so:
@app.put("/users/{user_id}")
@authorize("users:write")
def update_user(*, user_id: int, user_update: UserUpdate):
...
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
Close
Hashes for fastapi_decorators-0.0.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 426fbd3851fe367213947c34bd1dea98d726d8346c52b8c645fce7364b85a4cb |
|
MD5 | 7d70cb1ca95e05b117b733d600785dd7 |
|
BLAKE2b-256 | 5597b4d5b2d04558dfd24abc6dbba43e496a7fb3b24dd596373145b803c2cb06 |