Using a different version of graphql-tools
Apollo Server includes graphql-tools
version 4 by default. If you want to use a newer version, you can do so with the following steps:
-
Install
graphql-tools
separately in your project. -
Update your
ApolloServer
constructor to provide theschema
option instead oftypeDefs
,resolvers
, andschemaDirectives
. You instead pass these options to themakeExecutableSchema
function, which you provide as the value ofschema
:index.jsconst { ApolloServer, gql } = require("apollo-server");const { makeExecutableSchema } = require("@graphql-tools/schema");const server = new ApolloServer({schema: makeExecutableSchema({typeDefs,resolvers,schemaDirectives: {// ...directive subclasses...}}),// ...other options...}); -
Add the following definitions to your schema
typeDefs
:schema.graphqlenum CacheControlScope {PUBLICPRIVATE}directive @cacheControl(maxAge: Intscope: CacheControlScope) on FIELD_DEFINITION | OBJECT | INTERFACEscalar UploadApollo Server uses these types for its caching and file upload functionality. It usually defines these types automatically on startup, but it doesn't if you provide the
schema
option to theApolloServer
constructor.
For more information on the latest version of graphql-tools
, see the official documentation.