Files
François Voron c4de66b81c Revamp authentication (#831)
* Implement Transport classes

* Implement authentication strategy classes

* Revamp authentication with Transport and Strategy

* Revamp strategy and OAuth so that they can use a callable dependency

* Update docstring

* Make ErrorCode a proper Enum and cleanup unused OpenAPI utils

* Remove useless check

* Tweak typing in authenticator

* Update docs

* Improve logout/destroy token logic

* Update docs

* Update docs

* Update docs and full examples

* Apply formatting to examples

* Update OAuth doc and examples

* Add migration doc

* Implement Redis session token

* Add Redis Session documentation

* RedisSession -> Redis

* Fix links in docs
2021-12-30 15:22:07 +01:00

54 lines
1.7 KiB
Python

from typing import Any
from fastapi import Response, status
from fastapi.security import OAuth2PasswordBearer
from pydantic import BaseModel
from fastapi_users.authentication.transport.base import (
Transport,
TransportLogoutNotSupportedError,
)
from fastapi_users.openapi import OpenAPIResponseType
class BearerResponse(BaseModel):
access_token: str
token_type: str
class BearerTransport(Transport):
scheme: OAuth2PasswordBearer
def __init__(self, tokenUrl: str):
self.scheme = OAuth2PasswordBearer(tokenUrl, auto_error=False)
async def get_login_response(self, token: str, response: Response) -> Any:
return BearerResponse(access_token=token, token_type="bearer")
async def get_logout_response(self, response: Response) -> Any:
raise TransportLogoutNotSupportedError()
@staticmethod
def get_openapi_login_responses_success() -> OpenAPIResponseType:
return {
status.HTTP_200_OK: {
"model": BearerResponse,
"content": {
"application/json": {
"example": {
"access_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1"
"c2VyX2lkIjoiOTIyMWZmYzktNjQwZi00MzcyLTg2Z"
"DMtY2U2NDJjYmE1NjAzIiwiYXVkIjoiZmFzdGFwaS"
"11c2VyczphdXRoIiwiZXhwIjoxNTcxNTA0MTkzfQ."
"M10bjOe45I5Ncu_uXvOmVV8QxnL-nZfcH96U90JaocI",
"token_type": "bearer",
}
}
},
},
}
@staticmethod
def get_openapi_logout_responses_success() -> OpenAPIResponseType:
return {}