From d816a498f45e6be2361663f5fc0efcfc07ebce1a Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 10:34:45 +0200 Subject: [PATCH 1/8] document express customization of express endpoint --- .../integrations/integration-with-express.mdx | 21 +++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/website/src/pages/docs/integrations/integration-with-express.mdx b/website/src/pages/docs/integrations/integration-with-express.mdx index cdbe32d1e3..dc767308d4 100644 --- a/website/src/pages/docs/integrations/integration-with-express.mdx +++ b/website/src/pages/docs/integrations/integration-with-express.mdx @@ -37,3 +37,24 @@ app.listen(4000, () => { ``` > You can also check a full example on our GitHub repository [here](https://github.com/dotansimha/graphql-yoga/tree/v3/examples/express) + +## Custom endpoint + +By default, GraphQL Yoga will bind to the `/graphql` endpoint. You can change this behavior by passing a `graphqlEndpoint` option to the `createYoga` function. + +```ts +import express from 'express' +import { createYoga } from 'graphql-yoga' + +const app = express() + +const yoga = createYoga({ + graphqlEndpoint: '/custom/endpoint' +}) + +app.use('/custom/endpoint', yoga) + +app.listen(4000, () => { + console.log('Running a GraphQL API server at http://localhost:4000/graphql') +}) +``` From 7da44655783554a1b05a69bd43f3427513ba7d14 Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 10:47:01 +0200 Subject: [PATCH 2/8] document express customization of fastify endpoint --- .../integrations/integration-with-fastify.mdx | 54 +++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/website/src/pages/docs/integrations/integration-with-fastify.mdx b/website/src/pages/docs/integrations/integration-with-fastify.mdx index bcfc332068..f55f212972 100644 --- a/website/src/pages/docs/integrations/integration-with-fastify.mdx +++ b/website/src/pages/docs/integrations/integration-with-fastify.mdx @@ -79,3 +79,57 @@ app.addContentTypeParser('multipart/form-data', {}, (req, payload, done) => ``` > You can also check a full example on our GitHub repository [here](https://github.com/dotansimha/graphql-yoga/tree/v3/examples/fastify) + +## Customize endpoint + +By default GraphQL Yoga will expose a `/graphql` endpoint. You can customize it by passing a `graphqlEndpoint` option to `createYoga`: + +```ts +import { createYoga } from 'graphql-yoga' +import fastify, { FastifyRequest, FastifyReply } from 'fastify' + +// This is the fastify instance you have created +const app = fastify({ logger: true }) + +const yoga = createYoga<{ + req: FastifyRequest + reply: FastifyReply +}>({ + graphqlEndpoint: '/custom/endpoint', + // Integrate Fastify logger + logging: { + debug: (...args) => args.forEach((arg) => app.log.debug(arg)), + info: (...args) => args.forEach((arg) => app.log.info(arg)), + warn: (...args) => args.forEach((arg) => app.log.warn(arg)), + error: (...args) => args.forEach((arg) => app.log.error(arg)) + } +}) + +/** + * We pass the incoming HTTP request to GraphQL Yoga + * and handle the response using Fastify's `reply` API + * Learn more about `reply` https://www.fastify.io/docs/latest/Reply/ + **/ +app.route({ + url: '/custom/endpoint', + method: ['GET', 'POST', 'OPTIONS'], + handler: async (req, reply) => { + // Second parameter adds Fastify's `req` and `reply` to the GraphQL Context + const response = await yoga.handleNodeRequest(req, { + req, + reply + }) + response.headers.forEach((value, key) => { + reply.header(key, value) + }) + + reply.status(response.status) + + reply.send(response.body) + + return reply + } +}) + +app.listen(4000) +``` From 78b51212ccc37807162ea47acf0197a711a5ccf8 Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 11:04:47 +0200 Subject: [PATCH 3/8] better endpoint binding in documentation --- .../integrations/integration-with-deno.mdx | 4 +- .../integrations/integration-with-express.mdx | 25 +------- .../integrations/integration-with-fastify.mdx | 57 +------------------ .../integrations/integration-with-koa.mdx | 4 +- 4 files changed, 10 insertions(+), 80 deletions(-) diff --git a/website/src/pages/docs/integrations/integration-with-deno.mdx b/website/src/pages/docs/integrations/integration-with-deno.mdx index 8e9ba33d14..002dd00861 100644 --- a/website/src/pages/docs/integrations/integration-with-deno.mdx +++ b/website/src/pages/docs/integrations/integration-with-deno.mdx @@ -43,7 +43,9 @@ const yoga = createYoga({ serve(yoga, { onListen({ hostname, port }) { - console.log(`Listening on http://${hostname}:${port}/graphql`) + console.log( + `Listening on http://${hostname}:${port}/${yoga.graphqlEndpoint}}` + ) } }) ``` diff --git a/website/src/pages/docs/integrations/integration-with-express.mdx b/website/src/pages/docs/integrations/integration-with-express.mdx index dc767308d4..82ac601051 100644 --- a/website/src/pages/docs/integrations/integration-with-express.mdx +++ b/website/src/pages/docs/integrations/integration-with-express.mdx @@ -28,8 +28,8 @@ const app = express() const yoga = createYoga() -// Bind GraphQL Yoga to `/graphql` endpoint -app.use('/graphql', yoga) +// Bind GraphQL Yoga to the graphql endpoint to avoid rendering the playground on any path +app.use(yoga.graphqlEndpoint, yoga) app.listen(4000, () => { console.log('Running a GraphQL API server at http://localhost:4000/graphql') @@ -37,24 +37,3 @@ app.listen(4000, () => { ``` > You can also check a full example on our GitHub repository [here](https://github.com/dotansimha/graphql-yoga/tree/v3/examples/express) - -## Custom endpoint - -By default, GraphQL Yoga will bind to the `/graphql` endpoint. You can change this behavior by passing a `graphqlEndpoint` option to the `createYoga` function. - -```ts -import express from 'express' -import { createYoga } from 'graphql-yoga' - -const app = express() - -const yoga = createYoga({ - graphqlEndpoint: '/custom/endpoint' -}) - -app.use('/custom/endpoint', yoga) - -app.listen(4000, () => { - console.log('Running a GraphQL API server at http://localhost:4000/graphql') -}) -``` diff --git a/website/src/pages/docs/integrations/integration-with-fastify.mdx b/website/src/pages/docs/integrations/integration-with-fastify.mdx index f55f212972..26b6be3725 100644 --- a/website/src/pages/docs/integrations/integration-with-fastify.mdx +++ b/website/src/pages/docs/integrations/integration-with-fastify.mdx @@ -44,7 +44,8 @@ const yoga = createYoga<{ * Learn more about `reply` https://www.fastify.io/docs/latest/Reply/ **/ app.route({ - url: '/graphql', + // Bind to the Yoga's endpoint to avoid rendering on any path + url: yoga.graphqlEndpoint, method: ['GET', 'POST', 'OPTIONS'], handler: async (req, reply) => { // Second parameter adds Fastify's `req` and `reply` to the GraphQL Context @@ -79,57 +80,3 @@ app.addContentTypeParser('multipart/form-data', {}, (req, payload, done) => ``` > You can also check a full example on our GitHub repository [here](https://github.com/dotansimha/graphql-yoga/tree/v3/examples/fastify) - -## Customize endpoint - -By default GraphQL Yoga will expose a `/graphql` endpoint. You can customize it by passing a `graphqlEndpoint` option to `createYoga`: - -```ts -import { createYoga } from 'graphql-yoga' -import fastify, { FastifyRequest, FastifyReply } from 'fastify' - -// This is the fastify instance you have created -const app = fastify({ logger: true }) - -const yoga = createYoga<{ - req: FastifyRequest - reply: FastifyReply -}>({ - graphqlEndpoint: '/custom/endpoint', - // Integrate Fastify logger - logging: { - debug: (...args) => args.forEach((arg) => app.log.debug(arg)), - info: (...args) => args.forEach((arg) => app.log.info(arg)), - warn: (...args) => args.forEach((arg) => app.log.warn(arg)), - error: (...args) => args.forEach((arg) => app.log.error(arg)) - } -}) - -/** - * We pass the incoming HTTP request to GraphQL Yoga - * and handle the response using Fastify's `reply` API - * Learn more about `reply` https://www.fastify.io/docs/latest/Reply/ - **/ -app.route({ - url: '/custom/endpoint', - method: ['GET', 'POST', 'OPTIONS'], - handler: async (req, reply) => { - // Second parameter adds Fastify's `req` and `reply` to the GraphQL Context - const response = await yoga.handleNodeRequest(req, { - req, - reply - }) - response.headers.forEach((value, key) => { - reply.header(key, value) - }) - - reply.status(response.status) - - reply.send(response.body) - - return reply - } -}) - -app.listen(4000) -``` diff --git a/website/src/pages/docs/integrations/integration-with-koa.mdx b/website/src/pages/docs/integrations/integration-with-koa.mdx index e0da7a211b..968fd84531 100644 --- a/website/src/pages/docs/integrations/integration-with-koa.mdx +++ b/website/src/pages/docs/integrations/integration-with-koa.mdx @@ -41,7 +41,9 @@ app.use(async (ctx) => { }) app.listen(4000, () => { - console.log('Running a GraphQL API server at http://localhost:4000') + console.log( + `Running a GraphQL API server at http://localhost:4000/${yoga.graphqlEndpoint}` + ) }) ``` From 628b818aed61471128a94164edaf43798c5d4b2d Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 11:39:55 +0200 Subject: [PATCH 4/8] update examples to explicitly use graphqlEndpoint --- examples/cookies/src/index.ts | 4 +++- examples/defer-stream/src/index.ts | 4 +++- examples/deno/index.ts | 4 +++- examples/express/src/app.ts | 2 +- examples/fastify-modules/src/app.ts | 14 ++++++++++---- examples/fastify/src/app.ts | 2 +- examples/file-upload-nexus/index.ts | 4 +++- examples/file-upload/index.ts | 4 +++- examples/generic-auth/src/main.ts | 4 +++- examples/graphql-armor/src/main.ts | 4 +++- examples/hackernews/src/main.ts | 4 +++- examples/hello-world/index.js | 2 +- examples/issue-template/src/main.ts | 4 +++- examples/live-query/src/main.ts | 4 +++- examples/node-esm/index.mjs | 2 +- examples/node-ts/src/index.ts | 2 +- examples/pothos/src/index.ts | 4 +++- examples/uwebsockets/src/app.ts | 4 +++- 18 files changed, 51 insertions(+), 21 deletions(-) diff --git a/examples/cookies/src/index.ts b/examples/cookies/src/index.ts index 95b8da08df..c3d360e128 100644 --- a/examples/cookies/src/index.ts +++ b/examples/cookies/src/index.ts @@ -3,5 +3,7 @@ import { app } from './app' const server = createServer(app) server.listen(4000, () => { - console.info(`Server is running on http://localhost:4000/graphql`) + console.info( + `Server is running on http://localhost:4000/${app.graphqlEndpoint}`, + ) }) diff --git a/examples/defer-stream/src/index.ts b/examples/defer-stream/src/index.ts index 715fca71e9..a208d2fe7d 100644 --- a/examples/defer-stream/src/index.ts +++ b/examples/defer-stream/src/index.ts @@ -3,5 +3,7 @@ import { createServer } from 'http' const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/deno/index.ts b/examples/deno/index.ts index 75950064d9..35b44f873c 100644 --- a/examples/deno/index.ts +++ b/examples/deno/index.ts @@ -3,6 +3,8 @@ import { yoga } from './yoga.ts' serve(yoga, { onListen({ hostname, port }) { - console.log(`Listening on http://${hostname}:${port}/graphql`) + console.log( + `Listening on http://${hostname}:${port}/${yoga.graphqlEndpoint}`, + ) }, }) diff --git a/examples/express/src/app.ts b/examples/express/src/app.ts index 3c13994f7a..2d899ab237 100644 --- a/examples/express/src/app.ts +++ b/examples/express/src/app.ts @@ -38,7 +38,7 @@ export function buildApp(app: ReturnType) { logging: false, }) - app.use('/graphql', graphQLServer) + app.use(graphQLServer.graphqlEndpoint, graphQLServer) return app } diff --git a/examples/fastify-modules/src/app.ts b/examples/fastify-modules/src/app.ts index 180f125139..2f04764cc5 100644 --- a/examples/fastify-modules/src/app.ts +++ b/examples/fastify-modules/src/app.ts @@ -15,7 +15,9 @@ export function createGraphQLApp() { }) } -export function createGraphQLHandler(): RouteHandlerMethod { +export function createGraphQLHandler(): RouteHandlerMethod & { + endpoint: string +} { const graphQLServer = createYoga<{ req: FastifyRequest reply: FastifyReply @@ -24,7 +26,7 @@ export function createGraphQLHandler(): RouteHandlerMethod { plugins: [useGraphQLModules(createGraphQLApp())], }) - return async (req, reply) => { + const handler = async (req, reply) => { const response = await graphQLServer.handleNodeRequest(req, { req, reply, @@ -39,15 +41,19 @@ export function createGraphQLHandler(): RouteHandlerMethod { return reply } + + handler.endpoint = graphQLServer.graphqlEndpoint + return handler } export function buildApp() { const app = fastify({ logger: false }) + const handler = createGraphQLHandler() app.route({ - url: '/graphql', + url: handler.endpoint, method: ['GET', 'POST', 'OPTIONS'], - handler: createGraphQLHandler(), + handler, }) return app diff --git a/examples/fastify/src/app.ts b/examples/fastify/src/app.ts index 39662c1c22..b0d73828ec 100644 --- a/examples/fastify/src/app.ts +++ b/examples/fastify/src/app.ts @@ -68,7 +68,7 @@ export function buildApp(logging = true) { ) app.route({ - url: '/graphql', + url: graphQLServer.graphqlEndpoint, method: ['GET', 'POST', 'OPTIONS'], handler: async (req, reply) => { const response = await graphQLServer.handleNodeRequest(req, { diff --git a/examples/file-upload-nexus/index.ts b/examples/file-upload-nexus/index.ts index c7ef78a842..cb97f14738 100644 --- a/examples/file-upload-nexus/index.ts +++ b/examples/file-upload-nexus/index.ts @@ -5,5 +5,7 @@ const server = createServer(yoga) // Start the server and explore http://localhost:4000/graphql server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/file-upload/index.ts b/examples/file-upload/index.ts index 7abe44795a..dac736c004 100644 --- a/examples/file-upload/index.ts +++ b/examples/file-upload/index.ts @@ -3,5 +3,7 @@ import { yoga } from './yoga' const server = http.createServer(yoga) server.listen(4000, () => { - console.log('Server listening on http://localhost:4000/graphql') + console.log( + `Server listening on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/generic-auth/src/main.ts b/examples/generic-auth/src/main.ts index e4246f7025..7fdb0875d6 100644 --- a/examples/generic-auth/src/main.ts +++ b/examples/generic-auth/src/main.ts @@ -3,5 +3,7 @@ import { yoga } from './app' const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/graphql-armor/src/main.ts b/examples/graphql-armor/src/main.ts index 49582014db..ed84ae664b 100644 --- a/examples/graphql-armor/src/main.ts +++ b/examples/graphql-armor/src/main.ts @@ -3,5 +3,7 @@ import { yoga } from './yoga' const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/hackernews/src/main.ts b/examples/hackernews/src/main.ts index 4df5e2044f..9845340a3a 100644 --- a/examples/hackernews/src/main.ts +++ b/examples/hackernews/src/main.ts @@ -7,7 +7,9 @@ function main() { const yoga = createYoga({ schema, context: createContext }) const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) } diff --git a/examples/hello-world/index.js b/examples/hello-world/index.js index ee0c692afe..07f927a235 100644 --- a/examples/hello-world/index.js +++ b/examples/hello-world/index.js @@ -30,5 +30,5 @@ const yoga = createYoga({ const server = createServer(yoga) server.listen(4000, () => { - console.log('Server is running on http://localhost:4000/graphql') + console.log(`Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`) }) diff --git a/examples/issue-template/src/main.ts b/examples/issue-template/src/main.ts index 0d8ea1951b..df959fce8b 100644 --- a/examples/issue-template/src/main.ts +++ b/examples/issue-template/src/main.ts @@ -27,5 +27,7 @@ const yoga = createYoga({ const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/live-query/src/main.ts b/examples/live-query/src/main.ts index 07b18fc2c1..5e6e00d01f 100644 --- a/examples/live-query/src/main.ts +++ b/examples/live-query/src/main.ts @@ -44,5 +44,7 @@ const yoga = createYoga<{ greetings: Array }>({ const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/node-esm/index.mjs b/examples/node-esm/index.mjs index 73ba52ca0d..aa15e73f70 100644 --- a/examples/node-esm/index.mjs +++ b/examples/node-esm/index.mjs @@ -3,5 +3,5 @@ import { createServer } from 'http' const server = createServer(yoga) server.listen(4000, () => { - console.info('Server started on http://localhost:4000/graphql') + console.info(`Server started on http://localhost:4000/${yoga.graphqlEndpoint}`) }) diff --git a/examples/node-ts/src/index.ts b/examples/node-ts/src/index.ts index c7d8a43de7..9ca9253b07 100644 --- a/examples/node-ts/src/index.ts +++ b/examples/node-ts/src/index.ts @@ -3,5 +3,5 @@ import { yoga } from './yoga' const server = createServer(yoga) server.listen(4000, () => { - console.log(`Listening on http://localhost:4000/graphql`) + console.log(`Listening on http://localhost:4000/${yoga.graphqlEndpoint}`) }) diff --git a/examples/pothos/src/index.ts b/examples/pothos/src/index.ts index 0d199a8d24..386c9b7e19 100644 --- a/examples/pothos/src/index.ts +++ b/examples/pothos/src/index.ts @@ -4,5 +4,7 @@ import { yoga } from './yoga' const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/uwebsockets/src/app.ts b/examples/uwebsockets/src/app.ts index 97d7734565..89a18675af 100644 --- a/examples/uwebsockets/src/app.ts +++ b/examples/uwebsockets/src/app.ts @@ -133,4 +133,6 @@ const wsHandler = makeBehavior({ }, }) -export const app = App().any('/*', yogaHandler).ws('/graphql', wsHandler) +export const app = App() + .any('/*', yogaHandler) + .ws(yoga.graphqlEndpoint, wsHandler) From 6e9a9b603a04f39159cf560fd533eb7e2410fd7b Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 14:26:23 +0200 Subject: [PATCH 5/8] fix start message --- examples/apollo-federation/gateway/index.js | 2 +- examples/cookies/src/index.ts | 2 +- examples/defer-stream/src/index.ts | 2 +- examples/deno/index.ts | 2 +- examples/error-handling/src/index.ts | 4 +++- examples/express/src/app.ts | 2 +- examples/express/src/index.ts | 4 ++-- examples/fastify-modules/src/app.ts | 2 +- examples/fastify-modules/src/index.ts | 4 ++-- examples/fastify/src/app.ts | 2 +- examples/fastify/src/index.ts | 4 ++-- examples/file-upload-nexus/index.ts | 2 +- examples/file-upload/index.ts | 2 +- examples/generic-auth/src/main.ts | 2 +- examples/graphql-armor/src/main.ts | 2 +- examples/hackernews/src/main.ts | 2 +- examples/hello-world/index.js | 2 +- examples/issue-template/src/main.ts | 2 +- examples/live-query/src/main.ts | 2 +- examples/node-esm/index.mjs | 2 +- examples/node-ts/src/index.ts | 2 +- examples/pothos/src/index.ts | 2 +- examples/sofa/src/index.ts | 20 +++++++++++--------- examples/sofa/src/yoga.ts | 7 +++++-- 24 files changed, 43 insertions(+), 36 deletions(-) diff --git a/examples/apollo-federation/gateway/index.js b/examples/apollo-federation/gateway/index.js index 83d7c9033f..6ff87c4afc 100644 --- a/examples/apollo-federation/gateway/index.js +++ b/examples/apollo-federation/gateway/index.js @@ -15,7 +15,7 @@ async function main() { // Start the server and explore http://localhost:4000/graphql const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info(`Server is running on http://localhost:4000${yoga.graphqlEndpoint}`) }) } diff --git a/examples/cookies/src/index.ts b/examples/cookies/src/index.ts index c3d360e128..c84a79f642 100644 --- a/examples/cookies/src/index.ts +++ b/examples/cookies/src/index.ts @@ -4,6 +4,6 @@ import { app } from './app' const server = createServer(app) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${app.graphqlEndpoint}`, + `Server is running on http://localhost:4000${app.graphqlEndpoint}`, ) }) diff --git a/examples/defer-stream/src/index.ts b/examples/defer-stream/src/index.ts index a208d2fe7d..ae3fb5c2ee 100644 --- a/examples/defer-stream/src/index.ts +++ b/examples/defer-stream/src/index.ts @@ -4,6 +4,6 @@ import { createServer } from 'http' const server = createServer(yoga) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/deno/index.ts b/examples/deno/index.ts index 35b44f873c..4476b906b9 100644 --- a/examples/deno/index.ts +++ b/examples/deno/index.ts @@ -4,7 +4,7 @@ import { yoga } from './yoga.ts' serve(yoga, { onListen({ hostname, port }) { console.log( - `Listening on http://${hostname}:${port}/${yoga.graphqlEndpoint}`, + `Listening on http://${hostname}:${port}${yoga.graphqlEndpoint}`, ) }, }) diff --git a/examples/error-handling/src/index.ts b/examples/error-handling/src/index.ts index 7bf6ff0c14..113c482876 100644 --- a/examples/error-handling/src/index.ts +++ b/examples/error-handling/src/index.ts @@ -4,5 +4,7 @@ import { yoga } from './yoga' // Start the server and explore http://localhost:4000/graphql const server = createServer(yoga) server.listen(4000, () => { - console.info('Server is running on http://localhost:4000/graphql') + console.info( + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, + ) }) diff --git a/examples/express/src/app.ts b/examples/express/src/app.ts index 2d899ab237..e943db1e36 100644 --- a/examples/express/src/app.ts +++ b/examples/express/src/app.ts @@ -40,5 +40,5 @@ export function buildApp(app: ReturnType) { app.use(graphQLServer.graphqlEndpoint, graphQLServer) - return app + return graphQLServer.graphqlEndpoint } diff --git a/examples/express/src/index.ts b/examples/express/src/index.ts index ce8530479d..5d4fca842a 100644 --- a/examples/express/src/index.ts +++ b/examples/express/src/index.ts @@ -3,8 +3,8 @@ import { buildApp } from './app' const app = express() -buildApp(app) +const endpoint = buildApp(app) app.listen(4000, () => { - console.log('GraphQL API located at http://localhost:4000/graphql') + console.log(`GraphQL API located at http://localhost:4000${endpoint}`) }) diff --git a/examples/fastify-modules/src/app.ts b/examples/fastify-modules/src/app.ts index 2f04764cc5..0be87cee8f 100644 --- a/examples/fastify-modules/src/app.ts +++ b/examples/fastify-modules/src/app.ts @@ -56,5 +56,5 @@ export function buildApp() { handler, }) - return app + return [app, handler.endpoint] as const } diff --git a/examples/fastify-modules/src/index.ts b/examples/fastify-modules/src/index.ts index b45d7faad0..9c16cdf771 100644 --- a/examples/fastify-modules/src/index.ts +++ b/examples/fastify-modules/src/index.ts @@ -1,13 +1,13 @@ import { buildApp } from './app' -const app = buildApp() +const [app, endpoint] = buildApp() app .listen({ port: 4000, }) .then((serverUrl) => { - app.log.info(`GraphQL API located at ${serverUrl}/graphql`) + app.log.info(`GraphQL API located at ${serverUrl}${endpoint}`) }) .catch((err) => { app.log.error(err) diff --git a/examples/fastify/src/app.ts b/examples/fastify/src/app.ts index b0d73828ec..27256241a7 100644 --- a/examples/fastify/src/app.ts +++ b/examples/fastify/src/app.ts @@ -87,5 +87,5 @@ export function buildApp(logging = true) { }, }) - return app + return [app, graphQLServer.graphqlEndpoint] as const } diff --git a/examples/fastify/src/index.ts b/examples/fastify/src/index.ts index f3f7fca4e9..30db3235e7 100644 --- a/examples/fastify/src/index.ts +++ b/examples/fastify/src/index.ts @@ -1,13 +1,13 @@ import { buildApp } from './app' -const app = buildApp(true) +const [app, endpoint] = buildApp(true) app .listen({ port: 4000, }) .then((serverUrl) => { - app.log.info(`GraphQL API located at ${serverUrl}/graphql`) + app.log.info(`GraphQL API located at ${serverUrl}${endpoint}`) }) .catch((err) => { app.log.error(err) diff --git a/examples/file-upload-nexus/index.ts b/examples/file-upload-nexus/index.ts index cb97f14738..47793db01c 100644 --- a/examples/file-upload-nexus/index.ts +++ b/examples/file-upload-nexus/index.ts @@ -6,6 +6,6 @@ const server = createServer(yoga) // Start the server and explore http://localhost:4000/graphql server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/file-upload/index.ts b/examples/file-upload/index.ts index dac736c004..8f3d66af2e 100644 --- a/examples/file-upload/index.ts +++ b/examples/file-upload/index.ts @@ -4,6 +4,6 @@ import { yoga } from './yoga' const server = http.createServer(yoga) server.listen(4000, () => { console.log( - `Server listening on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server listening on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/generic-auth/src/main.ts b/examples/generic-auth/src/main.ts index 7fdb0875d6..d9f93610fc 100644 --- a/examples/generic-auth/src/main.ts +++ b/examples/generic-auth/src/main.ts @@ -4,6 +4,6 @@ import { yoga } from './app' const server = createServer(yoga) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/graphql-armor/src/main.ts b/examples/graphql-armor/src/main.ts index ed84ae664b..721b731f9c 100644 --- a/examples/graphql-armor/src/main.ts +++ b/examples/graphql-armor/src/main.ts @@ -4,6 +4,6 @@ import { yoga } from './yoga' const server = createServer(yoga) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/hackernews/src/main.ts b/examples/hackernews/src/main.ts index 9845340a3a..848b630937 100644 --- a/examples/hackernews/src/main.ts +++ b/examples/hackernews/src/main.ts @@ -8,7 +8,7 @@ function main() { const server = createServer(yoga) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) } diff --git a/examples/hello-world/index.js b/examples/hello-world/index.js index 07f927a235..b1c79dd5bd 100644 --- a/examples/hello-world/index.js +++ b/examples/hello-world/index.js @@ -30,5 +30,5 @@ const yoga = createYoga({ const server = createServer(yoga) server.listen(4000, () => { - console.log(`Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`) + console.log(`Server is running on http://localhost:4000${yoga.graphqlEndpoint}`) }) diff --git a/examples/issue-template/src/main.ts b/examples/issue-template/src/main.ts index df959fce8b..ff1207d929 100644 --- a/examples/issue-template/src/main.ts +++ b/examples/issue-template/src/main.ts @@ -28,6 +28,6 @@ const yoga = createYoga({ const server = createServer(yoga) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/live-query/src/main.ts b/examples/live-query/src/main.ts index 5e6e00d01f..1b849d3f7d 100644 --- a/examples/live-query/src/main.ts +++ b/examples/live-query/src/main.ts @@ -45,6 +45,6 @@ const yoga = createYoga<{ greetings: Array }>({ const server = createServer(yoga) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/node-esm/index.mjs b/examples/node-esm/index.mjs index aa15e73f70..34c929cf27 100644 --- a/examples/node-esm/index.mjs +++ b/examples/node-esm/index.mjs @@ -3,5 +3,5 @@ import { createServer } from 'http' const server = createServer(yoga) server.listen(4000, () => { - console.info(`Server started on http://localhost:4000/${yoga.graphqlEndpoint}`) + console.info(`Server started on http://localhost:4000${yoga.graphqlEndpoint}`) }) diff --git a/examples/node-ts/src/index.ts b/examples/node-ts/src/index.ts index 9ca9253b07..b44b6b6ac8 100644 --- a/examples/node-ts/src/index.ts +++ b/examples/node-ts/src/index.ts @@ -3,5 +3,5 @@ import { yoga } from './yoga' const server = createServer(yoga) server.listen(4000, () => { - console.log(`Listening on http://localhost:4000/${yoga.graphqlEndpoint}`) + console.log(`Listening on http://localhost:4000${yoga.graphqlEndpoint}`) }) diff --git a/examples/pothos/src/index.ts b/examples/pothos/src/index.ts index 386c9b7e19..f10eb1f31e 100644 --- a/examples/pothos/src/index.ts +++ b/examples/pothos/src/index.ts @@ -5,6 +5,6 @@ const server = createServer(yoga) server.listen(4000, () => { console.info( - `Server is running on http://localhost:4000/${yoga.graphqlEndpoint}`, + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, ) }) diff --git a/examples/sofa/src/index.ts b/examples/sofa/src/index.ts index 40559bb0b9..2fd3ddb427 100644 --- a/examples/sofa/src/index.ts +++ b/examples/sofa/src/index.ts @@ -1,4 +1,4 @@ -import { yoga } from './yoga' +import { yoga, swaggerEndpoint, restEndpoint } from './yoga' import { createServer } from 'http' import { titleBold, infoColor } from 'graphql-yoga' @@ -12,18 +12,20 @@ server.listen(4000, async () => { } console.log(` - ${titleBold('Swagger UI: ')} ${printUrl('/swagger')} + ${titleBold('Swagger UI: ')} ${printUrl(swaggerEndpoint)} - ${titleBold('GraphQL:')} ${printUrl('/graphql')} + ${titleBold('GraphQL:')} ${printUrl(yoga.graphqlEndpoint)} ${titleBold('Queries:')} - me: ${printUrl('/rest/me')} - users: ${printUrl('/rest/users')} - user: ${printUrl('/rest/user/1')} - books: ${printUrl('/rest/books')} - book: ${printUrl('/rest/book/1')} + me: ${printUrl(`${restEndpoint}/me`)} + users: ${printUrl(`${restEndpoint}/users`)} + user: ${printUrl(`${restEndpoint}/user/1`)} + books: ${printUrl(`${restEndpoint}/books`)} + book: ${printUrl(`${restEndpoint}/book/1`)} ${titleBold('Mutations:')} - addBook: ${printUrl('/rest/add-book')} ${infoColor('POST: {title}')} + addBook: ${printUrl(`${restEndpoint}/add-book`)} ${infoColor( + 'POST: {title}', + )} `) }) diff --git a/examples/sofa/src/yoga.ts b/examples/sofa/src/yoga.ts index 5995fbc1e6..3e6ea87265 100644 --- a/examples/sofa/src/yoga.ts +++ b/examples/sofa/src/yoga.ts @@ -218,12 +218,15 @@ const schema = createSchema({ }, }) +export const swaggerEndpoint = '/swagger' +export const restEndpoint = '/rest' + export const yoga = createYoga({ schema, plugins: [ useSofaWithSwaggerUI({ - basePath: '/rest', - swaggerUIEndpoint: '/swagger', + basePath: restEndpoint, + swaggerUIEndpoint: swaggerEndpoint, servers: [ { url: '/', // Specify Server's URL. From bba94d5c68f25ded0848c31f0a36e129baacaf96 Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 14:51:11 +0200 Subject: [PATCH 6/8] fix fastify example tests --- examples/fastify/__integration-tests__/fastify.spec.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/examples/fastify/__integration-tests__/fastify.spec.ts b/examples/fastify/__integration-tests__/fastify.spec.ts index ad6f2b75b7..2d0a0681d6 100644 --- a/examples/fastify/__integration-tests__/fastify.spec.ts +++ b/examples/fastify/__integration-tests__/fastify.spec.ts @@ -2,7 +2,7 @@ import request from 'supertest' import { buildApp } from '../src/app.js' describe('fastify example integration', () => { - const app = buildApp(false) + const [app] = buildApp(false) beforeAll(async () => { await app.ready() From c6dd2b1f79327ff0b2f3e3d28b4759775e1acaf3 Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 16:32:48 +0200 Subject: [PATCH 7/8] fix fastify-modules example tests --- .../__integration-test__/fastify-modules.spec.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/examples/fastify-modules/__integration-test__/fastify-modules.spec.ts b/examples/fastify-modules/__integration-test__/fastify-modules.spec.ts index c9cf3a7603..d4ef84216f 100644 --- a/examples/fastify-modules/__integration-test__/fastify-modules.spec.ts +++ b/examples/fastify-modules/__integration-test__/fastify-modules.spec.ts @@ -3,7 +3,7 @@ import request from 'supertest' import { buildApp } from '../src/app.js' describe('fastify-modules example integration', () => { - const app = buildApp() + const [app] = buildApp() beforeAll(async () => { await app.ready() From 3701dcf4644faae04637a61b144c19cb7d6dda12 Mon Sep 17 00:00:00 2001 From: Valentin Cocaud Date: Fri, 28 Apr 2023 22:03:25 +0200 Subject: [PATCH 8/8] run prettier --- examples/apollo-federation/gateway/index.js | 4 +++- examples/hello-world/index.js | 4 +++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/examples/apollo-federation/gateway/index.js b/examples/apollo-federation/gateway/index.js index 6ff87c4afc..43e5e014da 100644 --- a/examples/apollo-federation/gateway/index.js +++ b/examples/apollo-federation/gateway/index.js @@ -15,7 +15,9 @@ async function main() { // Start the server and explore http://localhost:4000/graphql const server = createServer(yoga) server.listen(4000, () => { - console.info(`Server is running on http://localhost:4000${yoga.graphqlEndpoint}`) + console.info( + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, + ) }) } diff --git a/examples/hello-world/index.js b/examples/hello-world/index.js index b1c79dd5bd..94b10a9703 100644 --- a/examples/hello-world/index.js +++ b/examples/hello-world/index.js @@ -30,5 +30,7 @@ const yoga = createYoga({ const server = createServer(yoga) server.listen(4000, () => { - console.log(`Server is running on http://localhost:4000${yoga.graphqlEndpoint}`) + console.log( + `Server is running on http://localhost:4000${yoga.graphqlEndpoint}`, + ) })