Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Nest.js server support in grafserv? #2254

Open
dourkk opened this issue Nov 28, 2024 · 5 comments
Open

Nest.js server support in grafserv? #2254

dourkk opened this issue Nov 28, 2024 · 5 comments

Comments

@dourkk
Copy link

dourkk commented Nov 28, 2024

Summary

Hi, we are using Nestjs, and we would like to migrate from v4 to v5, but we were not able to find info about postgraphileMiddleware.graphqlRouteHandler is it still supported or what is the new way to achieve the following?

Additional context

Here are our postgraphile.middleware.ts config

import { postgraphile } from 'postgraphile';
import ConnectionFilterPlugin from 'postgraphile-plugin-connection-filter';
import PgAggregatesPlugin from '@graphile/pg-aggregates';
import { getConfig } from '../config';

const postgraphileMiddleware = postgraphile(
  `postgres://${process.env.SVC_USERNAME}:${process.env.SVC_PASSWORD}@${process.env.DB_HOST ?? getConfig('database_url')}:5432/${process.env.DB_DATABASE}`,
  getConfig('schema'),
  {
    graphiql: true,
    enhanceGraphiql: true,
    graphqlRoute: '/api/graphql',
    graphiqlRoute: '/api/graphiql',
    retryOnInitFail: true,
    appendPlugins: [ConnectionFilterPlugin, PgAggregatesPlugin],
    watchPg: true,
    ownerConnectionString: `postgres://${process.env.ROOT_USERNAME}:${process.env.ROOT_PASSWORD}@${process.env.DB_HOST ?? getConfig('database_url')}:5432/${process.env.DB_DATABASE}`,
  },
);

export default postgraphileMiddleware;

Here is our postgraphile.controller.ts controller

import { Controller, Post, Get, Req, Next, Res } from '@nestjs/common';
import { Request, Response, NextFunction } from 'express';
import { PostGraphileResponseNode } from 'postgraphile';
import postgraphileMiddleware from './postgraphile.middleware';
import { RequiredPermissions } from '../guards/authorization.guard';
import { USER_ROLE } from '../guards/token-roles';
import { ApiBearerAuth } from '@nestjs/swagger';

@RequiredPermissions({ role: USER_ROLE })
@ApiBearerAuth()
@Controller('/')
export class PostGraphileController {
  @Get('graphiql')
  graphiql(@Req() request: Request, @Res() response: Response, @Next() next: NextFunction) {
    return postgraphileMiddleware.graphiqlRouteHandler!(
      new PostGraphileResponseNode(request, response, next),
    );
  }

  @Post('graphql')
  graphql(@Req() request: Request, @Res() response: Response, @Next() next: NextFunction) {
    return postgraphileMiddleware.graphqlRouteHandler(
      new PostGraphileResponseNode(request, response, next),
    );
  }
}
@github-project-automation github-project-automation bot moved this to 🌳 Triage in V5.0.0 Nov 28, 2024
@benjie
Copy link
Member

benjie commented Nov 28, 2024

Hello! Ideally someone would build a Nest.js optimized server adaptor for Grafserv, like these: https://github.com/graphile/crystal/tree/main/grafast/grafserv/src/servers

But given you had it working in V4 it's likely you can hack something together using the node adaptor; see

https://postgraphile.org/postgraphile/next/usage-library

and

https://grafast.org/grafserv/servers/node

But rather than doing serv.addTo(server) you can use serv's handlers directly:

  • serv.graphqlHandler,
  • serv.graphiqlHandler,
  • etc

Doing so will mean that certain plugin middlewares won't be called, so be aware of that. If you want to submit a Nest.js adaptor I'd be happy to pair program with you for a couple of hours to help develop it if you want; the session would be public and recorded to help future adaptors be written.

If you're going alone or taking the hack approach, use TypeScript to guide you and/or read the source starting here:

server.on("request", handler);

@benjie benjie removed this from V5.0.0 Nov 28, 2024
@benjie benjie added this to V5.X Nov 28, 2024
@github-project-automation github-project-automation bot moved this to 🌳 Triage in V5.X Nov 28, 2024
@benjie benjie changed the title Migrate from v4 to v5 Nest.js server support in grafserv? Nov 28, 2024
@github-project-automation github-project-automation bot moved this to 🌳 Triage in V5.0.0 Nov 28, 2024
@dourkk
Copy link
Author

dourkk commented Nov 29, 2024

Thanks for the answer @benjie 🙏

For context we wanted to do the migration, because we were getting this error recently in our logs

 Error: Cannot use GraphQLSchema "{ __validationErrors: [], description: undefined, extensions: {}, ast │
│                                                                                                        │
│ Ensure that there is only one instance of "graphql" in the node_modules                                │
│ directory. If different versions of "graphql" are the dependencies of other                            │
│ relied on modules, use "resolutions" to ensure only one version is installed.                          │
│                                                                                                        │
│ https://yarnpkg.com/en/docs/selective-version-resolutions                                              │
│                                                                                                        │
│ Duplicate "graphql" modules cannot be used at the same time since different                            │
│ versions may have different capabilities and behavior. The data from one                               │
│ version used in the function from another could produce confusing and                                  │
│ spurious results.                                                                                      │
│     at instanceOf (/usr/src/app/node_modules/postgraphile/node_modules/graphql/jsutils/instanceOf.js:3 │
│     at isSchema (/usr/src/app/node_modules/postgraphile/node_modules/graphql/type/schema.js:42:34)     │
│     at assertSchema (/usr/src/app/node_modules/postgraphile/node_modules/graphql/type/schema.js:46:8)  │
│     at validateSchema (/usr/src/app/node_modules/postgraphile/node_modules/graphql/type/validate.js:42 │
│     at assertValidSchema (/usr/src/app/node_modules/postgraphile/node_modules/graphql/type/validate.js │
│     at Object.validate (/usr/src/app/node_modules/postgraphile/node_modules/graphql/validation/validat │
│     at parseQuery (/usr/src/app/node_modules/postgraphile/build/postgraphile/http/createPostGraphileHt │
│     at /usr/src/app/node_modules/postgraphile/build/postgraphile/http/createPostGraphileHttpRequestHan │
│     at Array.map (<anonymous>)                                                                         │
│     at graphqlRouteHandler (/usr/src/app/node_modules/postgraphile/build/postgraphile/http/createPostG │
│ Stream canceled read tcp some_ip:60935->some_ip:443: use of closed network connection for  │

We tried to resolve the graphql dependency to 15.9.0, but still getting the same issue 🥲

IMG_0239

  "resolutions": {
    "graphql": "15.9.0"
  }

@benjie
Copy link
Member

benjie commented Nov 29, 2024

Try also adding an explicit dependency on [email protected], and consider downgrading msw so it uses [email protected] too.

@benjie benjie removed this from V5.0.0 Dec 23, 2024
@endurance-chorus
Copy link

@benjie I would love to pair program w/ you on getting this setup on NestJS. Let me know if you're still interested.

@benjie
Copy link
Member

benjie commented Jan 23, 2025

That'd be great! But for the next couple months I'm focussed on:

They're the two biggest issues we need to address before V5 can be released, and they're both big rewrites of core parts of the system. I'm taking time off of client work to get these done, so it's important I focus. Once these issues are closed, if you're still interested, please reach out and we'll arrange something! 🙌

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: 🌳 Triage
Development

No branches or pull requests

3 participants