from fastapi import routing
from fastapi.openapi.docs import get_redoc_html, get_swagger_ui_html
from fastapi.openapi.utils import get_openapi
+from fastapi.openapi.models import AdditionalResponse, AdditionalResponseDescription
from pydantic import BaseModel
from starlette.applications import Starlette
from starlette.exceptions import ExceptionMiddleware, HTTPException
self.add_exception_handler(HTTPException, http_exception)
def add_api_route(
- self,
- path: str,
- endpoint: Callable,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- methods: List[str] = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ endpoint: Callable,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ methods: List[str] = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> None:
self.router.add_api_route(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=methods,
operation_id=operation_id,
)
def api_route(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- methods: List[str] = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ methods: List[str] = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
def decorator(func: Callable) -> Callable:
self.router.add_api_route(
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=methods,
operation_id=operation_id,
return decorator
def include_router(
- self, router: routing.APIRouter, *, prefix: str = "", tags: List[str] = None
+ self,
+ router: routing.APIRouter,
+ *,
+ prefix: str = "",
+ tags: List[str] = None,
+ additional_responses: AdditionalResponse = [],
) -> None:
- self.router.include_router(router, prefix=prefix, tags=tags)
+ self.router.include_router(router, prefix=prefix, tags=tags, additional_responses=additional_responses,)
def get(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.get(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
)
def put(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.put(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
)
def post(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.post(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
)
def delete(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.delete(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
)
def options(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.options(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
)
def head(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.head(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
)
def patch(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.patch(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
)
def trace(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.router.trace(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
operation_id=operation_id,
include_in_schema=include_in_schema,
import asyncio
import inspect
import logging
-from typing import Any, Callable, List, Optional, Type
+from typing import Any, Callable, List, Optional, Type, Dict, Union
from fastapi import params
from fastapi.dependencies.models import Dependant
from fastapi.dependencies.utils import get_body_field, get_dependant, solve_dependencies
from fastapi.encoders import jsonable_encoder
from fastapi.utils import UnconstrainedConfig
+from fastapi.openapi.models import AdditionalResponse, AdditionalResponseDescription
from pydantic import BaseModel, Schema
from pydantic.error_wrappers import ErrorWrapper, ValidationError
from pydantic.fields import Field
summary: str = None,
description: str = None,
response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
deprecated: bool = None,
name: str = None,
methods: List[str] = None,
self.summary = summary
self.description = description or self.endpoint.__doc__
self.response_description = response_description
+ self.additional_responses: Dict[int, AdditionalResponseDescription] = {}
+ existed_codes = [self.status_code, 422]
+ if isinstance(additional_responses, dict):
+ self.additional_responses = additional_responses.copy()
+ for add_response in additional_responses:
+ if isinstance(add_response, int):
+ continue
+ assert add_response.status_code not in existed_codes, f"(Duplicated Status Code): Response with status code [{add_response.status_code}] already defined!"
+ existed_codes.append(add_response.status_code)
+ response_models = [
+ m for m in\
+ add_response.models
+ ]
+ valid_response_models = True
+ try:
+ valid_response_models = all([
+ issubclass(m, BaseModel)
+ for m in response_models
+ ])
+ except TypeError as te:
+ valid_response_models = False
+ if not valid_response_models:
+ raise ValueError(
+ "All response models must be "
+ "a subclass of `pydantic.BaseModel` "
+ "model.",
+ )
+ if (add_response.content_type == 'application/json' or lenient_issubclass(
+ content_type, JSONResponse)):
+ if len(response_models):
+ schema_field = Field(
+ name=f'Additional_response_{add_response.status_code}',
+ type_=Union[tuple(response_models)],
+ class_validators=[],
+ default=None,
+ required=False,
+ model_config=UnconstrainedConfig,
+ schema=Schema(None),
+ )
+ else:
+ schema_field = None
+ else:
+ schema_field = None
+ add_resp_description = AdditionalResponseDescription(
+ description=add_response.description,
+ content_type=add_response.content_type,
+ schema_field=schema_field,
+ )
+ self.additional_responses[add_response.status_code] = \
+ add_resp_description
self.deprecated = deprecated
if methods is None:
methods = ["GET"]
class APIRouter(routing.Router):
def add_api_route(
- self,
- path: str,
- endpoint: Callable,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- methods: List[str] = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ endpoint: Callable,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ methods: List[str] = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> None:
route = APIRoute(
path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=methods,
operation_id=operation_id,
self.routes.append(route)
def api_route(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- methods: List[str] = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ methods: List[str] = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
def decorator(func: Callable) -> Callable:
self.add_api_route(
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=methods,
operation_id=operation_id,
return decorator
def include_router(
- self, router: "APIRouter", *, prefix: str = "", tags: List[str] = None
+ self,
+ router: "APIRouter",
+ *,
+ prefix: str = "",
+ tags: List[str] = None,
+ additional_responses: AdditionalResponse = [],
) -> None:
if prefix:
assert prefix.startswith("/"), "A path prefix must start with '/'"
), "A path prefix must not end with '/', as the routes will start with '/'"
for route in router.routes:
if isinstance(route, APIRoute):
+ # really ugly hack and repitition
+ prev_add_resp = route.additional_responses
+ existed_codes = [422, route.status_code
+ ] + [int(c) for c in prev_add_resp.keys()]
+ for add_response in additional_responses:
+ assert add_response.status_code not in existed_codes, f"(Duplicated Status Code): Response with status code [{add_response.status_code}] already defined!"
+ existed_codes.append(add_response.status_code)
+ response_models = [
+ m for m in\
+ add_response.models
+ ]
+ valid_response_models = True
+ try:
+ valid_response_models = all([
+ issubclass(m, BaseModel) for m in response_models
+ ])
+ except AttributeError as ae:
+ valid_response_models = False
+ if not valid_response_models:
+ raise ValueError(
+ "All response models must be"
+ "a subclass of `pydantic.BaseModel`"
+ "model."
+ )
+ if (add_response.content_type == 'application/json' or lenient_issubclass(
+ route.content_type, JSONResponse)):
+ if len(response_models):
+ schema_field = Field(
+ name=f'Additional_response_{add_response.status_code}',
+ type_=Union[tuple(response_models)],
+ class_validators=[],
+ default=None,
+ required=False,
+ model_config=UnconstrainedConfig,
+ schema=Schema(None),
+ )
+ else:
+ schema_field = None
+ else:
+ schema_field = None
+ add_resp_description = AdditionalResponseDescription(
+ description=add_response.description,
+ content_type=add_response.content_type,
+ schema_field=schema_field,
+ )
+ route.additional_responses[add_response.status_code] = \
+ add_resp_description
self.add_api_route(
prefix + route.path,
route.endpoint,
summary=route.summary,
description=route.description,
response_description=route.response_description,
+ additional_responses=route.additional_responses,
deprecated=route.deprecated,
methods=route.methods,
operation_id=route.operation_id,
)
def get(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["GET"],
operation_id=operation_id,
)
def put(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["PUT"],
operation_id=operation_id,
)
def post(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["POST"],
operation_id=operation_id,
)
def delete(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["DELETE"],
operation_id=operation_id,
)
def options(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["OPTIONS"],
operation_id=operation_id,
)
def head(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["HEAD"],
operation_id=operation_id,
)
def patch(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["PATCH"],
operation_id=operation_id,
)
def trace(
- self,
- path: str,
- *,
- response_model: Type[BaseModel] = None,
- status_code: int = 200,
- tags: List[str] = None,
- summary: str = None,
- description: str = None,
- response_description: str = "Successful Response",
- deprecated: bool = None,
- operation_id: str = None,
- include_in_schema: bool = True,
- content_type: Type[Response] = JSONResponse,
- name: str = None,
+ self,
+ path: str,
+ *,
+ response_model: Type[BaseModel] = None,
+ status_code: int = 200,
+ tags: List[str] = None,
+ summary: str = None,
+ description: str = None,
+ response_description: str = "Successful Response",
+ additional_responses: AdditionalResponse = [],
+ deprecated: bool = None,
+ operation_id: str = None,
+ include_in_schema: bool = True,
+ content_type: Type[Response] = JSONResponse,
+ name: str = None,
) -> Callable:
return self.api_route(
path=path,
summary=summary,
description=description,
response_description=response_description,
+ additional_responses=additional_responses,
deprecated=deprecated,
methods=["TRACE"],
operation_id=operation_id,