graphi
hapi GraphQL server plugin

Options
graphqlPath
- HTTP path to serve graphql requests. Default is /graphql
graphiqlPath
- HTTP path to serve the GraphiQL UI. Set to '' or false to disable. Default is /graphiql
schema
- graphql schema either as a string or as a GraphQLSchema instance
resolvers
- query and mutation functions mapped to their respective keys. Resolvers should return a promise when performing asynchronous operations.
Usage
const schema = `
type Person {
firstname: String!
lastname: String!
}
type Query {
person(firstname: String!): Person!
}
`;
const getPerson = function (args, request) {
return { firstname: 'billy', lastname: 'jean' };
};
const resolvers = {
person: getPerson
};
const server = Hapi.server();
await server.register({ plugin: Graphi, options: { schema, resolvers } });
With GraphQLSchema Instance
const schema = new GraphQLSchema({
query: new GraphQLObjectType({
name: 'RootQueryType',
fields: {
person: {
type: GraphQLString,
args: {
firstname: { type: new Scalars.JoiString({ min: [2, 'utf8'], max: 10 }) }
},
resolve: (root, { firstname }, request) => {
return firstname;
}
}
}
})
});
const server = Hapi.server();
await server.register({ plugin: Graphi, options: { schema } });