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

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.