Path Operation Configuration
Part of: FastAPI Basics
Learn to configure path operations with status codes, tags, descriptions, and metadata.
What You'll Learn
- Configure response status codes using status constants
- Organize endpoints with tags and metadata
- Add descriptions using docstrings and parameters
- Mark endpoints as deprecated
Theory and Concepts
Path Operation Configuration
šÆ What You'll Learn
- Configure response status codes using status constants
- Organize endpoints with tags and metadata
- Add descriptions using docstrings and parameters
- Mark endpoints as deprecated
š Theory
There are several parameters that you can pass to your path operation decorator to configure it.
ā ļø Important: Notice that these parameters are passed directly to the path operation decorator, not to your path operation function.
Response Status Code
You can define the (HTTP) status_code to be used in the response of your path operation.
You can pass directly the int code, like 404.
But if you don't remember what each number code is for, you can use the shortcut constants in status:
[Code Example]
That status code will be used in the response and will be added to the OpenAPI schema.
Tags
You can add tags to your path operation, pass the parameter tags with a list of str (commonly just one str):
[Code Example]
They will be added to the OpenAPI schema and used by the automatic documentation interfaces.
Tags with Enums
If you have a big application, you might end up accumulating several tags, and you would want to make sure you always use the same tag for related path operations.
In these cases, it could make sense to store the tags in an Enum.
FastAPI supports that the same way as with plain strings:
[Code Example]
Summary and description
You can add a summary and description:
[Code Example]
Description from docstring
As descriptions tend to be long and cover multiple lines, you can declare the path operation description in the function docstring and FastAPI will read it from there.
You can write Markdown in the docstring, it will be interpreted and displayed correctly (taking into account docstring indentation).
[Code Example]
Deprecate a path operation
If you need to mark a path operation as deprecated, but without removing it, pass the parameter deprecated:
[Code Example]
It will be clearly marked as deprecated in the interactive docs.
š§ Key Concepts
- Status Constants: Use status.HTTP_201_CREATED instead of 201
- Tags: Organize endpoints into logical groups
- Docstrings: Multi-line descriptions with Markdown support
- Deprecation: Mark endpoints as obsolete without removing them
š Recap
You can configure and add metadata for your path operations easily by passing parameters to the path operation decorators.
š” Best Practices
- Always use status constants for better code readability
- Group related endpoints with consistent tags
- Use docstrings for complex endpoint descriptions
- Mark deprecated endpoints instead of immediately removing them
- Keep response descriptions specific and helpful
š Additional Resources
- FastAPI Path Operation Configuration
- HTTP Status Codes
Helpful Hint
Path operation configuration parameters are passed to the decorator, not the function. Use status constants instead of numeric codes for better readability.
