You can easily integrate Nitro GraphQL IDE with your server app using the @chillicream/nitro-express-middleware
package.
You can either use a CDN hosted version of the app or a self-hosted version using the dedicated package.
Installation
First, you need to install this package and the required peer dependencies in your project:
npm install @chillicream/nitro-express-middleware --save-dev# oryarn add @chillicream/nitro-express-middleware --dev# orpnpm add @chillicream/nitro-express-middleware --save-dev
Note: @chillicream/nitro-embedded
is optional and only needed if you prefer to self host the app.
Usage
To use the middleware, simply import it and add it to your Express app.
import express from "express";import { graphqlHTTP } from "express-graphql";import { GraphQLObjectType, GraphQLSchema, GraphQLString } from "graphql";
import nitroMiddleware from "@chillicream/nitro-express-middleware";
const schema = new GraphQLSchema({ query: new GraphQLObjectType({ name: "Query", fields: { greeting: { type: GraphQLString, resolve(_parent, _args) { return "Hello, World!"; }, }, }, }),});
const app = express();
app.use( "/graphql",
// for `cdn` hosted version nitroMiddleware({ mode: "cdn" }),
// for `embedded` version // nitroMiddleware({ mode: "embedded" }),
graphqlHTTP({ schema, graphiql: false, }));
app.listen(3000, () => { console.log(`GraphQL on http://localhost:3000/graphql`);});
You can also use it in the embedded
mode for a self-hosted version:
nitroMiddleware({ mode: "embedded" }); // for `embedded` version
Extended configuration
Pin a specific version
To pin a specific version instead of using "latest":
nitroMiddleware({ mode: "cdn", target: { version: "3.0.0" },});
Use your own infrastructure
To use your own infrastructure:
nitroMiddleware({ mode: "cdn", target: "https://mycompany.com/nitro",});
Custom options
To pass options supported by Nitro GraphQL IDE:
nitroMiddleware({ mode: "cdn", options: { title: "Nitro", },});
Property | Description | Type |
---|---|---|
title | The title of the Nitro IDE. | string (optional) |
graphQLDocument | Specifies the GraphQL document (query/mutation/subscription). | string (optional) |
variables | Specifies the variables used in the GraphQL document. | Record<string, any> (optional) |
includeCookies | If true , includes cookies in the request. | boolean (optional) |
httpHeaders | Specifies HTTP headers for the request. | HttpHeaderDictionary (optional) |
endpoint | The GraphQL endpoint. | string (optional) |
useGet | If true , uses GET method for sending the request. | boolean (optional) |
useBrowserUrlAsEndpoint | If true , uses the browser's URL as the GraphQL endpoint. | boolean |
subscriptionProtocol | Specifies the protocol used for GraphQL subscriptions. | SubscriptionProtocol (optional) |
Recipes
Below are examples of how to use Nitro Express Middleware with different GraphQL server setups.
graphql-http
import express from "express";import { createHandler } from "graphql-http";//... rest of the imports
const app = express();//... rest of the app setup
app.use( "/graphql", nitroMiddleware({ mode: "cdn" }), // or nitroMiddleware({ mode: "embedded" }), async (req, res) => { //... rest of the middleware });
app.listen(3000, () => { console.log(`GraphQL on http://localhost:3000/graphql`);});
graphql-yoga
import express from "express";import { createYoga, createSchema } from "graphql-yoga";//... rest of the imports
const app = express();//... rest of the app setup
app.use( "/graphql", nitroMiddleware({ mode: "cdn" }), // or nitroMiddleware({ mode: "embedded" }), graphQLServer);
app.listen(3000, () => { console.log(`GraphQL on http://localhost:3000/graphql`);});
express-graphql
import express from "express";import { graphqlHTTP } from "express-graphql";//... rest of the imports
const app = express();//... rest of the app setup
app.use( "/graphql", nitroMiddleware({ mode: "cdn" }), // or nitroMiddleware({ mode: "embedded" }), graphqlHTTP({ schema, graphiql: false, }));
app.listen(3000, () => { console.log(`GraphQL on http://localhost:3000/graphql`);});
Apollo Server
import { ApolloServer } from "@apollo/server";//... rest of the imports
const app = express();//... rest of the app setup
app.use( "/graphql", nitroMiddleware({ mode: "cdn" }), // or nitroMiddleware({ mode: "embedded" }), cors(), bodyParser.json(), expressMiddleware(server, { context: async ({ req }) => ({ token: req.headers.token }), }));
httpServer.listen({ port: 3000 }, () => { console.log(`GraphQL on http://localhost:3000/graphql`);});