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.

5.0 KiB

FastAPI allows you to declare additonal information and validation for your parameters.

Let's take this application as example:

{!./tutorial/src/query-params-schema/tutorial001.py!}

The query parameter q is of type str, and by default is None, so it is optional.

Additional validation

We are going to enforce that even though q is optional, whenever it is provided, it doesn't exceed a length of 50 characters.

Import Query

To achieve that, first import Query from fastapi:

{!./tutorial/src/query-params-schema/tutorial002.py!}

Use Query as the default value

And now use it as the default value of your parameter, setting the parameter max_length to 50:

{!./tutorial/src/query-params-schema/tutorial002.py!}

As we have to replace the default value None with Query(None), the first parameter to Query serves the same purpose of defining that default value.

So:

q: str = Query(None)

...makes the parameter optional, the same as:

q: str = None

But it declares it explicitly as being a query parameter.

And then, we can pass more parameters to Query. In this case, the max_length parameter that applies to strings:

q: str = Query(None, max_length=50)

This will validate the data, show a clear error when the data is not valid, and document the parameter in the OpenAPI schema endpoint.

Add more validations

You can also add a parameter min_length:

{!./tutorial/src/query-params-schema/tutorial003.py!}

Add regular expressions

You can define a regular expression that the parameter should match:

{!./tutorial/src/query-params-schema/tutorial004.py!}

This specific regular expression checks that the received parameter value:

  • ^: starts with the following characters, doesn't have characters before.
  • fixedquery: has the exact value fixedquery.
  • $: ends there, doesn't have any more characters after fixedquery.

If you feel lost with all these "regular expression" ideas, don't worry. They are a hard topic for many people. You can still do a lot of stuff without needing regular expressions yet.

But whenever you need them and go and learn them, know that you can already use them directly in FastAPI.

Default values

The same way that you can pass None as the first argument to be used as the default value, you can pass other values.

Let's say that you want to declare the q query parameter to have a min_length of 3, and to have a default value of "fixedquery":

{!./tutorial/src/query-params-schema/tutorial005.py!}

!!! note Having a default value also makes the parameter optional.

Make it required

When we don't need to declare more validations or metadata, we can make the q query parameter required just by not declaring a default value, like:

q: str

instead of:

q: str = None

But we are now declaring it with Query, for example like:

q: str = Query(None, min_length=3)

So, when you need to declare a value as required while using Query, you can use ... as the first argument:

{!./tutorial/src/query-params-schema/tutorial006.py!}

!!! info If you hadn't seen that ... before: it is a a special single value, it is part of Python and is called "Ellipsis".

This will let FastAPI know that this parameter is required.

Declare more metadata

You can add more information about the parameter.

That information will be included in the generated OpenAPI and used by the documentation user interfaces and external tools.

You can add a title:

{!./tutorial/src/query-params-schema/tutorial007.py!}

And a description:

{!./tutorial/src/query-params-schema/tutorial008.py!}

Alias parameters

Imagine that you want the parameter to be item-query.

Like in:

http://127.0.0.1:8000/items/?item-query=foobaritems

But item-query is not a valid Python variable name.

The closest would be item_query.

But you still need it to be exactly item-query...

Then you can declare an alias, and that alias is what will be used to find the parameter value:

{!./tutorial/src/query-params-schema/tutorial009.py!}

Deprecating parameters

Now let's say you don't like this parameter anymore.

You have to leave it there a while because there are clients using it, but you want the docs to clearly show it as deprecated.

Then pass the parameter deprecated=True to Query:

{!./tutorial/src/query-params-schema/tutorial010.py!}

The docs will show it like this: