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.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c4bfea325f5b09d9f7fb941dc314b0e9955e626e09b9c0d03ca29c2b43ae4c98 |
|
MD5 | c8ce1ceb918bcee82dbc0de45bd6685a |
|
BLAKE2b-256 | 9225fb6eee9c706578a90cbfd332036adac4361a8d6b74f19fc18e48f7cbfa03 |