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.
1.4 KiB
1.4 KiB
FastAPI has optional support for GraphQL (provided by Starlette directly), using the graphene
library.
You can combine normal FastAPI path operations with GraphQL on the same application.
Import and use graphene
GraphQL is implemented with Graphene, you can check Graphene's docs for more details.
Import graphene
and define your GraphQL data:
{!./src/graphql/tutorial001.py!}
Add Starlette's GraphQLApp
Then import and add Starlette's GraphQLApp
:
{!./src/graphql/tutorial001.py!}
!!! info
Here we are using .add_route
, that is the way to add a route in Starlette (inherited by FastAPI) without declaring the specific operation (as would be with .get()
, .post()
, etc).
Check it
Run it with Uvicorn and open your browser at http://127.0.0.1:8000.
You will see GraphiQL web user interface:

More details
For more details, including:
- Accessing request information
- Adding background tasks
- Using normal or async functions
check the official Starlette GraphQL docs.