Easily get started and create your graphql server using:
- graphql-server-express
- graphql-subscriptions
- graphql-tools
- merge-graphql-schemas
- mongoose
- babel-cli
This project demonstrates how to add Queries, Mutations and Subscriptions in a modular way.
Clone the repository and run npm install
git clone https://github.com/tomyitav/graphql-server-seed.git
npm install
npm start
The server will run on port 8080. You can change this by editing config file.
We use the function makeExecutableSchema()
from graphql-tools to to combine our
types and resolvers. Instead of passing one large string for our schema, we
split our types and resolvers to multiple files, located in graphql directory in
types and resolvers directories. This way, we avoid schema complexity by using
merge-graphql-schemas:
import path from "path";
import { makeExecutableSchema } from 'graphql-tools';
import { fileLoader, mergeTypes, mergeResolvers } from 'merge-graphql-schemas';
const typesArray = fileLoader(path.join(__dirname, '../types'), { recursive: true });
const resolversArray = fileLoader(path.join(__dirname, '../resolvers'));
const allTypes = mergeTypes(typesArray);
const allResolvers = mergeResolvers(resolversArray);
const schema = makeExecutableSchema({
typeDefs: allTypes,
resolvers: allResolvers
});
export default schema;
So as your project grows - you can extend the schema by adding new type in types directory, and adding matching resolver file in resolvers directory. The schema is updated automatically.
Set babel-node executable as the node interpreter. Pass node parameters of --preset=babel-preset-es2015
After npm intalling the project, go to project root directory, open shell and run:
docker build -t graphql-server-seed .
Instructions about running the container are available here
See the following example on how to connect to the server using apollo-angular. The project demonstrates using Queries, Mutations and Subscriptions.