Как мы можем передать источник данных и объединенную схему и преобразователи graphql в ApolloServer из модуля apollo-server? - PullRequest
0 голосов
/ 02 января 2019

У меня есть ситуация, когда у меня есть схема и револьверы сидят в разных файлах.Я импортировал схему и преобразователь в файл server.js, который отвечает за создание сервера apollo.На данный момент один набор распознавателя и запросов, который я импортирую, а другой набор запросов и распознавателя уже находится в файле server.js.

Это содержимое файла server.js.

    import "graphql-import-node";
import { ApolloServer, gql } from "apollo-server";
import { makeExecutableSchema } from "graphql-tools";
import merge from "lodash/merge";
import GithubFetchHelper from "./github/GithubFetchHelper";
import {
  resolvers as GithubResolvers,
  typeDefs as GithubTypeDef
} from "./github";

/**
 * Error Handler. Provides full stack - remove for production
 */

const books = [
  {
    title: "Harry Potter and the Chamber of Secrets",
    author: "J.K. Rowling"
  },
  {
    title: "Jurassic Park",
    author: "Michael Crichton"
  }
];

const typeDefs = gql`
  # Comments in GraphQL are defined with the hash (#) symbol.

  # This "Book" type can be used in other type declarations.
  type Book {
    title: String
    author: String
  }

  # The "Query" type is the root of all GraphQL queries.
  # (A "Mutation" type will be covered later on.)
  type Query {
    books: [Book]
  }
`;

const resolvers = {
  Query: {
    books: () => books
  }
};

// typeDefs: [
//   project.typeDefs,
//   task.typeDefs,
//   search.typeDefs
// ].join(' '),
// resolvers: merge({}, project.resolvers, task.resolvers, search.resolvers),
// context: {
//   models: {
//     project: project.model,
//     task: task.model
//   },
//   loaders: loaders()
// }

const server = new ApolloServer({
  typeDefs: [typeDefs, GithubTypeDef],
  resolvers: merge({}, resolvers, GithubResolvers),
  dataSources: () => {
    return {
      gitHubApi: new GithubFetchHelper()
    };
  }
});

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

export default server;

Теперь, когда я запускаю сервер, я получаю следующую ошибку.Любая помощь приветствуется.

Error: Type "Query" was defined more than once.

Мои попытки Я сослался на документацию apollo для источников данных и для объединения нескольких схем и преобразователей с использованием gql из graphql-tools.Но я не получил никакой реализации gql, где они также использовали источники данных.

Любая помощь приветствуется.

Примечание: я довольно новичок в Graphql

Ответы [ 2 ]

0 голосов
/ 23 января 2019

Предполагая, что вы импортировали схемы и резолверы в ваш основной js-файл, вы можете сшить их следующим образом.Вы можете использовать модуль require-graphql-file для упрощения импорта схемы graphQL.

import {merge } from 'lodash'
import requireGraphQLFile from 'require-graphql-file';
import {makeExecutableSchema } from 'apollo-server';

import resolver1 from  './resolvers/resolver1';
import resolver2 from  './resolvers/resolver2';
import resolver3 from  './resolvers/resolver3';

const schema1= requireGraphQLFile('./schema/schema1');
const schema2= requireGraphQLFile('./schema/schema2');
const schema3= requireGraphQLFile('./schema/schema3');

const resolvers = merge(resolver1, resolver2, resolver3)
const typeDef = gql `
type Query {
getData(filters:Filter,limit:Int,offset:Int):Result
}`;

const schema = makeExecutableSchema({
typeDefs: [typeDef, schema1,schema2, schema3],
resolvers
});

const server = new ApolloServer({
    schema
});
0 голосов
/ 03 января 2019

Из кода вы передаете 2 определения типа в виде массива, вероятно, причина, по которой вы получаете ошибку.Вы должны сшить схему вместе.См .:

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...