Add an experimental GraphQL API endpoint.
This change introduces a new endpoint at /graphql
, which handles GraphQL requests. The endpoint accepts POST requests with the body containing a valid GraphQL query. The schema for the API is generated by functions that map existing WebAPIResource
's into GraphQL types. This change also includes the query resolvers, which are called by the py-gql
function graphql_blocking
, that query, filter, and return data from the database. Currently, only the User
and ReviewRequest
objects have been defined in the schema and have resolvers.
The filtering logic in resolve_review_requests
uses essentially the same logic as the filtering in the review_request
resource, with some slight changes due to the difference in GrapgQL schema and REST query parameters. Ideally, this code would be refactored and DRY'ed out. Additionally, when building the schema we may eventually want to define the ResourceList
and Resource
types as a nested type, to take full advantage of the technology. For now, these are typed as objects with href
, method
, and title
as they currently are in the other API resources.