如何使用Apollo分离GraphQL模式和解析器文件?

问题描述 投票:-1回答:1

我有一个简单的GraphQL Apollo服务器,当它都在一个文件中时,我可以工作,但当我将模式和解析器 "模块化 "到它们自己的文件时,我遇到了麻烦。

/index.js

require('dotenv').config()
const { MongoClient } = require('mongodb')
const { ApolloServer, makeExecutableSchema } = require('apollo-server')

const { Query } = require('./resolvers/Query')

// database connection
MongoClient.connect(process.env.DB_URL, {
  poolSize: 25,
  useUnifiedTopology: true,
  wtimeout: 2500
}).catch(error => {
  console.log('Error connecting to MongoDB.', error.stack)
  process.exit(1)
}).then(async client => {
  console.log(`Connected to database: ${process.env.DB_NAME}`)

  const dbConnection = client.db(process.env.DB_NAME)

  const resolvers = {
    Query
  }

  const schema = makeExecutableSchema({
    typeDefs: './schema.graphql',
    resolvers
  })

  const server = new ApolloServer({
    schema: schema
  })

  server.listen().then(({ url }) => {
    console.log(`Server ready at ${url}.`)
  })
})

/schema.graphql

type CourseType {
  _id: String!
  name: String!
}

type Query {
  courseType(_id: String): CourseType
  courseTypes: [CourseType]!
}

/resolvers/Query.js

const { ObjectId } = require('mongodb')

const courseTypesCollection = dbConnection.collection(process.env.DB_COLLECTION_COURSE_TYPES)

const Query = {
  courseType: async (root, { _id }) => {
    return courseTypesCollection.findOne(ObjectId(_id))
  },
  courseTypes: async () => {
    return courseTypesCollection.find({}).toArray()
  }
}

module.exports = {
  Query
}

当我尝试运行 index.js 文件,我得到了错误。UnhandledPromiseRejectionWarning: GraphQLError: Syntax Error: Cannot parse the unexpected character ".". 这似乎是我没有正确加载使用模式文件。我想在不添加更多库的情况下让它工作,如果 apollo-server 可以自行处理。

node.js mongodb graphql apollo apollo-server
1个回答
1
投票

makeExecutableSchema 期待 typeDefs 为类型定义的字符串,或者是一个 DocumentNode 对象代表类型定义解析成AST,前者的任何一个数组将被合并在一起。在这里,你似乎是将一个文件路径传递给了 typeDefs 而不是文件的内容。

你可以改变 /schema.graphql 文件到一个简单的代码文件,例如这样。

const schema = `
  type CourseType {
    _id: String!
    name: String!
  }

  type Query {
    courseType(_id: String): CourseType
    courseTypes: [CourseType]!
  }
`
module.exports = schema

然后加载到 typedef

  const graphQLSchema = require('./schema.graphql')
  //...

  const schema = makeExecutableSchema({
    typeDefs: graphQLSchema,
    resolvers
  })

如果你将一个数组传递给 typeDefs

© www.soinside.com 2019 - 2024. All rights reserved.