website/src/docs/nitro/integrations/express.md
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.
First, you need to install this package and the required peer dependencies in your project:
npm install @chillicream/nitro-express-middleware --save-dev
# or
yarn add @chillicream/nitro-express-middleware --dev
# or
pnpm add @chillicream/nitro-express-middleware --save-dev
Note: @chillicream/nitro-embedded is optional and only needed if you prefer to self host the app.
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
To pin a specific version instead of using "latest":
nitroMiddleware({
mode: "cdn",
target: { version: "3.0.0" },
});
To use your own infrastructure:
nitroMiddleware({
mode: "cdn",
target: "https://mycompany.com/nitro",
});
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) |
Below are examples of how to use Nitro Express Middleware with different GraphQL server setups.
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`);
});
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`);
});
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`);
});
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`);
});