pythonasyncioapiasyncfastapiframeworkjsonjson-schemaopenapiopenapi3pydanticpython-typespython3redocreststarletteswaggerswagger-uiuvicornweb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
839 lines
31 KiB
839 lines
31 KiB
import asyncio
|
|
import inspect
|
|
import logging
|
|
import re
|
|
from typing import Any, Callable, Dict, List, Optional, Set, Type, Union
|
|
|
|
from fastapi import params
|
|
from fastapi.dependencies.models import Dependant
|
|
from fastapi.dependencies.utils import (
|
|
get_body_field,
|
|
get_dependant,
|
|
get_parameterless_sub_dependant,
|
|
solve_dependencies,
|
|
)
|
|
from fastapi.encoders import jsonable_encoder
|
|
from fastapi.exceptions import RequestValidationError, WebSocketRequestValidationError
|
|
from pydantic import BaseConfig, BaseModel, Schema
|
|
from pydantic.error_wrappers import ErrorWrapper, ValidationError
|
|
from pydantic.fields import Field
|
|
from pydantic.utils import lenient_issubclass
|
|
from starlette import routing
|
|
from starlette.concurrency import run_in_threadpool
|
|
from starlette.exceptions import HTTPException
|
|
from starlette.requests import Request
|
|
from starlette.responses import JSONResponse, Response
|
|
from starlette.routing import (
|
|
compile_path,
|
|
get_name,
|
|
request_response,
|
|
websocket_session,
|
|
)
|
|
from starlette.status import WS_1008_POLICY_VIOLATION
|
|
from starlette.types import ASGIApp
|
|
from starlette.websockets import WebSocket
|
|
|
|
|
|
def serialize_response(
|
|
*,
|
|
field: Field = None,
|
|
response: Response,
|
|
include: Set[str] = None,
|
|
exclude: Set[str] = set(),
|
|
by_alias: bool = True,
|
|
skip_defaults: bool = False,
|
|
) -> Any:
|
|
|
|
encoded = jsonable_encoder(
|
|
response,
|
|
include=include,
|
|
exclude=exclude,
|
|
by_alias=by_alias,
|
|
skip_defaults=skip_defaults,
|
|
)
|
|
if field:
|
|
errors = []
|
|
value, errors_ = field.validate(encoded, {}, loc=("response",))
|
|
if isinstance(errors_, ErrorWrapper):
|
|
errors.append(errors_)
|
|
elif isinstance(errors_, list):
|
|
errors.extend(errors_)
|
|
if errors:
|
|
raise ValidationError(errors)
|
|
return jsonable_encoder(
|
|
value,
|
|
include=include,
|
|
exclude=exclude,
|
|
by_alias=by_alias,
|
|
skip_defaults=skip_defaults,
|
|
)
|
|
else:
|
|
return encoded
|
|
|
|
|
|
def get_app(
|
|
dependant: Dependant,
|
|
body_field: Field = None,
|
|
status_code: int = 200,
|
|
response_class: Type[Response] = JSONResponse,
|
|
response_field: Field = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
dependency_overrides_provider: Any = None,
|
|
) -> Callable:
|
|
assert dependant.call is not None, "dependant.call must be a function"
|
|
is_coroutine = asyncio.iscoroutinefunction(dependant.call)
|
|
is_body_form = body_field and isinstance(body_field.schema, params.Form)
|
|
|
|
async def app(request: Request) -> Response:
|
|
try:
|
|
body = None
|
|
if body_field:
|
|
if is_body_form:
|
|
body = await request.form()
|
|
else:
|
|
body_bytes = await request.body()
|
|
if body_bytes:
|
|
body = await request.json()
|
|
except Exception as e:
|
|
logging.error(f"Error getting request body: {e}")
|
|
raise HTTPException(
|
|
status_code=400, detail="There was an error parsing the body"
|
|
) from e
|
|
solved_result = await solve_dependencies(
|
|
request=request,
|
|
dependant=dependant,
|
|
body=body,
|
|
dependency_overrides_provider=dependency_overrides_provider,
|
|
)
|
|
values, errors, background_tasks, sub_response, _ = solved_result
|
|
if errors:
|
|
raise RequestValidationError(errors)
|
|
else:
|
|
assert dependant.call is not None, "dependant.call must be a function"
|
|
if is_coroutine:
|
|
raw_response = await dependant.call(**values)
|
|
else:
|
|
raw_response = await run_in_threadpool(dependant.call, **values)
|
|
if isinstance(raw_response, Response):
|
|
if raw_response.background is None:
|
|
raw_response.background = background_tasks
|
|
return raw_response
|
|
response_data = serialize_response(
|
|
field=response_field,
|
|
response=raw_response,
|
|
include=response_model_include,
|
|
exclude=response_model_exclude,
|
|
by_alias=response_model_by_alias,
|
|
skip_defaults=response_model_skip_defaults,
|
|
)
|
|
response = response_class(
|
|
content=response_data,
|
|
status_code=status_code,
|
|
background=background_tasks,
|
|
)
|
|
response.headers.raw.extend(sub_response.headers.raw)
|
|
if sub_response.status_code:
|
|
response.status_code = sub_response.status_code
|
|
return response
|
|
|
|
return app
|
|
|
|
|
|
def get_websocket_app(
|
|
dependant: Dependant, dependency_overrides_provider: Any = None
|
|
) -> Callable:
|
|
async def app(websocket: WebSocket) -> None:
|
|
solved_result = await solve_dependencies(
|
|
request=websocket,
|
|
dependant=dependant,
|
|
dependency_overrides_provider=dependency_overrides_provider,
|
|
)
|
|
values, errors, _, _2, _3 = solved_result
|
|
if errors:
|
|
await websocket.close(code=WS_1008_POLICY_VIOLATION)
|
|
raise WebSocketRequestValidationError(errors)
|
|
assert dependant.call is not None, "dependant.call must me a function"
|
|
await dependant.call(**values)
|
|
|
|
return app
|
|
|
|
|
|
class APIWebSocketRoute(routing.WebSocketRoute):
|
|
def __init__(
|
|
self,
|
|
path: str,
|
|
endpoint: Callable,
|
|
*,
|
|
name: str = None,
|
|
dependency_overrides_provider: Any = None,
|
|
) -> None:
|
|
self.path = path
|
|
self.endpoint = endpoint
|
|
self.name = get_name(endpoint) if name is None else name
|
|
self.dependant = get_dependant(path=path, call=self.endpoint)
|
|
self.app = websocket_session(
|
|
get_websocket_app(
|
|
dependant=self.dependant,
|
|
dependency_overrides_provider=dependency_overrides_provider,
|
|
)
|
|
)
|
|
regex = "^" + path + "$"
|
|
regex = re.sub("{([a-zA-Z_][a-zA-Z0-9_]*)}", r"(?P<\1>[^/]+)", regex)
|
|
self.path_regex, self.path_format, self.param_convertors = compile_path(path)
|
|
|
|
|
|
class APIRoute(routing.Route):
|
|
def __init__(
|
|
self,
|
|
path: str,
|
|
endpoint: Callable,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
name: str = None,
|
|
methods: List[str] = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
dependency_overrides_provider: Any = None,
|
|
) -> None:
|
|
assert path.startswith("/"), "Routed paths must always start with '/'"
|
|
self.path = path
|
|
self.endpoint = endpoint
|
|
self.name = get_name(endpoint) if name is None else name
|
|
self.response_model = response_model
|
|
if self.response_model:
|
|
assert lenient_issubclass(
|
|
response_class, JSONResponse
|
|
), "To declare a type the response must be a JSON response"
|
|
response_name = "Response_" + self.name
|
|
self.response_field: Optional[Field] = Field(
|
|
name=response_name,
|
|
type_=self.response_model,
|
|
class_validators={},
|
|
default=None,
|
|
required=False,
|
|
model_config=BaseConfig,
|
|
schema=Schema(None),
|
|
)
|
|
else:
|
|
self.response_field = None
|
|
self.status_code = status_code
|
|
self.tags = tags or []
|
|
self.dependencies = dependencies or []
|
|
self.summary = summary
|
|
self.description = description or inspect.cleandoc(self.endpoint.__doc__ or "")
|
|
self.response_description = response_description
|
|
self.responses = responses or {}
|
|
response_fields = {}
|
|
for additional_status_code, response in self.responses.items():
|
|
assert isinstance(response, dict), "An additional response must be a dict"
|
|
model = response.get("model")
|
|
if model:
|
|
assert lenient_issubclass(
|
|
model, BaseModel
|
|
), "A response model must be a Pydantic model"
|
|
response_name = f"Response_{additional_status_code}_{self.name}"
|
|
response_field = Field(
|
|
name=response_name,
|
|
type_=model,
|
|
class_validators=None,
|
|
default=None,
|
|
required=False,
|
|
model_config=BaseConfig,
|
|
schema=Schema(None),
|
|
)
|
|
response_fields[additional_status_code] = response_field
|
|
if response_fields:
|
|
self.response_fields: Dict[Union[int, str], Field] = response_fields
|
|
else:
|
|
self.response_fields = {}
|
|
self.deprecated = deprecated
|
|
if methods is None:
|
|
methods = ["GET"]
|
|
self.methods = methods
|
|
self.operation_id = operation_id
|
|
self.response_model_include = response_model_include
|
|
self.response_model_exclude = response_model_exclude
|
|
self.response_model_by_alias = response_model_by_alias
|
|
self.response_model_skip_defaults = response_model_skip_defaults
|
|
self.include_in_schema = include_in_schema
|
|
self.response_class = response_class
|
|
|
|
self.path_regex, self.path_format, self.param_convertors = compile_path(path)
|
|
assert inspect.isfunction(endpoint) or inspect.ismethod(
|
|
endpoint
|
|
), f"An endpoint must be a function or method"
|
|
self.dependant = get_dependant(path=self.path_format, call=self.endpoint)
|
|
for depends in self.dependencies[::-1]:
|
|
self.dependant.dependencies.insert(
|
|
0,
|
|
get_parameterless_sub_dependant(depends=depends, path=self.path_format),
|
|
)
|
|
self.body_field = get_body_field(dependant=self.dependant, name=self.name)
|
|
self.dependency_overrides_provider = dependency_overrides_provider
|
|
self.app = request_response(
|
|
get_app(
|
|
dependant=self.dependant,
|
|
body_field=self.body_field,
|
|
status_code=self.status_code,
|
|
response_class=self.response_class,
|
|
response_field=self.response_field,
|
|
response_model_include=self.response_model_include,
|
|
response_model_exclude=self.response_model_exclude,
|
|
response_model_by_alias=self.response_model_by_alias,
|
|
response_model_skip_defaults=self.response_model_skip_defaults,
|
|
dependency_overrides_provider=self.dependency_overrides_provider,
|
|
)
|
|
)
|
|
|
|
|
|
class APIRouter(routing.Router):
|
|
def __init__(
|
|
self,
|
|
routes: List[routing.BaseRoute] = None,
|
|
redirect_slashes: bool = True,
|
|
default: ASGIApp = None,
|
|
dependency_overrides_provider: Any = None,
|
|
) -> None:
|
|
super().__init__(
|
|
routes=routes, redirect_slashes=redirect_slashes, default=default
|
|
)
|
|
self.dependency_overrides_provider = dependency_overrides_provider
|
|
|
|
def add_api_route(
|
|
self,
|
|
path: str,
|
|
endpoint: Callable,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
methods: List[str] = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> None:
|
|
route = APIRoute(
|
|
path,
|
|
endpoint=endpoint,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=methods,
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
dependency_overrides_provider=self.dependency_overrides_provider,
|
|
)
|
|
self.routes.append(route)
|
|
|
|
def api_route(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
methods: List[str] = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
def decorator(func: Callable) -> Callable:
|
|
self.add_api_route(
|
|
path,
|
|
func,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=methods,
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
return func
|
|
|
|
return decorator
|
|
|
|
def add_api_websocket_route(
|
|
self, path: str, endpoint: Callable, name: str = None
|
|
) -> None:
|
|
route = APIWebSocketRoute(path, endpoint=endpoint, name=name)
|
|
self.routes.append(route)
|
|
|
|
def websocket(self, path: str, name: str = None) -> Callable:
|
|
def decorator(func: Callable) -> Callable:
|
|
self.add_api_websocket_route(path, func, name=name)
|
|
return func
|
|
|
|
return decorator
|
|
|
|
def include_router(
|
|
self,
|
|
router: "APIRouter",
|
|
*,
|
|
prefix: str = "",
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
) -> None:
|
|
if prefix:
|
|
assert prefix.startswith("/"), "A path prefix must start with '/'"
|
|
assert not prefix.endswith(
|
|
"/"
|
|
), "A path prefix must not end with '/', as the routes will start with '/'"
|
|
if responses is None:
|
|
responses = {}
|
|
for route in router.routes:
|
|
if isinstance(route, APIRoute):
|
|
combined_responses = {**responses, **route.responses}
|
|
self.add_api_route(
|
|
prefix + route.path,
|
|
route.endpoint,
|
|
response_model=route.response_model,
|
|
status_code=route.status_code,
|
|
tags=(route.tags or []) + (tags or []),
|
|
dependencies=(dependencies or []) + (route.dependencies or []),
|
|
summary=route.summary,
|
|
description=route.description,
|
|
response_description=route.response_description,
|
|
responses=combined_responses,
|
|
deprecated=route.deprecated,
|
|
methods=route.methods,
|
|
operation_id=route.operation_id,
|
|
response_model_include=route.response_model_include,
|
|
response_model_exclude=route.response_model_exclude,
|
|
response_model_by_alias=route.response_model_by_alias,
|
|
response_model_skip_defaults=route.response_model_skip_defaults,
|
|
include_in_schema=route.include_in_schema,
|
|
response_class=route.response_class,
|
|
name=route.name,
|
|
)
|
|
elif isinstance(route, routing.Route):
|
|
self.add_route(
|
|
prefix + route.path,
|
|
route.endpoint,
|
|
methods=route.methods,
|
|
include_in_schema=route.include_in_schema,
|
|
name=route.name,
|
|
)
|
|
elif isinstance(route, APIWebSocketRoute):
|
|
self.add_api_websocket_route(
|
|
prefix + route.path, route.endpoint, name=route.name
|
|
)
|
|
elif isinstance(route, routing.WebSocketRoute):
|
|
self.add_websocket_route(
|
|
prefix + route.path, route.endpoint, name=route.name
|
|
)
|
|
|
|
def get(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["GET"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|
|
def put(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["PUT"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|
|
def post(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["POST"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|
|
def delete(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["DELETE"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|
|
def options(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["OPTIONS"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|
|
def head(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["HEAD"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|
|
def patch(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["PATCH"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|
|
def trace(
|
|
self,
|
|
path: str,
|
|
*,
|
|
response_model: Type[Any] = None,
|
|
status_code: int = 200,
|
|
tags: List[str] = None,
|
|
dependencies: List[params.Depends] = None,
|
|
summary: str = None,
|
|
description: str = None,
|
|
response_description: str = "Successful Response",
|
|
responses: Dict[Union[int, str], Dict[str, Any]] = None,
|
|
deprecated: bool = None,
|
|
operation_id: str = None,
|
|
response_model_include: Set[str] = None,
|
|
response_model_exclude: Set[str] = set(),
|
|
response_model_by_alias: bool = True,
|
|
response_model_skip_defaults: bool = False,
|
|
include_in_schema: bool = True,
|
|
response_class: Type[Response] = JSONResponse,
|
|
name: str = None,
|
|
) -> Callable:
|
|
return self.api_route(
|
|
path=path,
|
|
response_model=response_model,
|
|
status_code=status_code,
|
|
tags=tags or [],
|
|
dependencies=dependencies or [],
|
|
summary=summary,
|
|
description=description,
|
|
response_description=response_description,
|
|
responses=responses or {},
|
|
deprecated=deprecated,
|
|
methods=["TRACE"],
|
|
operation_id=operation_id,
|
|
response_model_include=response_model_include,
|
|
response_model_exclude=response_model_exclude,
|
|
response_model_by_alias=response_model_by_alias,
|
|
response_model_skip_defaults=response_model_skip_defaults,
|
|
include_in_schema=include_in_schema,
|
|
response_class=response_class,
|
|
name=name,
|
|
)
|
|
|