How to add a GraphQL query
This guide documents how to add a new query to the GraphQL API. It explains what needs to be added to the Go code, as well as how to then use that query in the UI.
GraphQL backend
Each GraphQL query usually retrieves data from a data store. In the case of Sourcegraph, this is usually Postgres. So there needs to be some mechanism in the backend that does this.
Query function
The data query functions are split across multiple files depending on their function, which can be found in cmd/frontend/graphqlbackend. To use an existing function as an example, in cmd/frontend/graphqlbackend/feature_flags.go you'll find a function named OrganizationFeatureFlagValue
that takes OrgID
and FlagName
as arguments and fetches the relevant data from the database.
The schemaResolver
struct of each function is tied to is what allows GraphQL to link the GraphQL query to an actual operation. To create a new GraphQL query, create a function that's tied to the schemaResolver
struct. It needs to be a public function, so in Go, it has to start with a capital letter. You can use an existing function as a guiding example (find functions by searching for schemaResolver
).
func (r *schemaResolver) NewQuery(ctx context.Context, args *struct { SomeArg string }) (bool, error) { // some code that fetches and returns data from the database }
The GraphQL schema also needs to know about this new function and what it returns. An example GraphQL schema can be found in cmd/frontend/graphqlbackend/schema.graphql
, but this is not the only GraphQL schema (schema files have the .graphql
extension). To continue with the OrganizationFeatureFlagValue
example, you'll find a entry for organizationFeatureFlagValue
in the schema file. The name has to be the exact same as the Go function, except it starts with a lower case letter instead of a capital letter.
newQuery(someArg: String!): Boolean!
UI
The UI needs to know about the GraphQL query as well. graphql-operations.ts
files are generated from strings tagged with gql
in the TypeScript files. These graphql-operations.ts
files (which are excluded from the repository) are where the TypeScript functions, argument values, and return types are defined.
Searching for organizationFeatureFlagValue
will reveal a gql
tagged string in client/web/src/org/backend.ts
. You'll see the query is given a name, namely OrgFeatureFlagValue
along with some parameters that are then used in the actual GraphQL function call. This is what the code generator uses to generate the TypeScript files.
So in order to add a new GraphQL function, simply add another gql
tagged string with a similar structure. Don't forget that you can search for other gql
tagged strings if you need other references.
const USE_NEW_QUERY = gql` query UseNewQuery($someArg: String!) { newQuery(someArg: $someArg) } `
yarn generate
or simply saving while your local instance of Sourcegraph is running will generate new graphql-operations.ts
files with the appropriate functions and types defined.
You can now use this function in your TypeScript code. As an example of how to do this, you could perhaps look at this. Also, refer to Working with GraphQL