NestJS-Prisma-GraphQL-Generator

NestJS-Prisma-GraphQL-Generator tool for generating GraphQL resolvers for your NestJS application based on the prisma schema of your project.

Prerequisites

Before you begin, ensure you have met the following requirements:

  • Your project uses the latest version of Prisma and NestJS

Installing NestJS-Prisma-GraphQL-Generator

To install NestJS-Prisma-GraphQL-Generator, follow these steps:

npm i nestjs-prisma-graphql-generator --save-dev

or

yarn add nestjs-prisma-graphql-generator --dev

Using NestJS-Prisma-GraphQL-Generator

To use NestJS-Prisma-GraphQL-Generator, follow these steps:

  1. configure the prisma generator
  2. add NestJS-Prisma-GraphQL-Generator as a subsequent generator to your prisma.schema
  3. optionally configure NestJS-Prisma-GraphQL-Generator as described in the Configuration section
  4. run prisma generate
  5. import generated types, enums and resolvers from path/to/prisma/schema/@generated/nestjs

Configuration

Create a new generator in your prisma schema and provide the import path of your prisma service:

generator nestjs {
  provider                = "nestjs-prisma-graphql"
  prismaServiceImportPath = "@your/prisma-service"
}

The following additional settings can be configured within the generator block of your prisma schema:

  • the input arguments name; default setting:
    inputArgumentsName = input
  • the named prisma service import; default setting:
    prismaServiceImport = PrismaService

To enable the Prisma Select integration, set includePrismaSelect to true:

generator nestjs {
  provider            = "nestjs-prisma-graphql"
  includePrismaSelect = true
}

Currently supported objects

  • Enums
  • Models
  • Input Types
  • Output Types
  • Resolvers

Usage

All supported objects can be used as the regular NestJS GraphQL object equivalents.

Resolvers can be imported on an individual base and used within the providers array of your modules

Upcoming features

  • support for adding custom decorators to the generated objects

Contributing to NestJS-Prisma-GraphQL-Generator

To contribute to NestJS-Prisma-GraphQL-Generator, follow these steps:

  1. Fork this repository.
  2. Create a branch: git checkout -b <branch_name>.
  3. Make your changes and commit them: git commit -m '<commit_message>'
  4. Push to the original branch: git push origin nestjs-prisma-graphql-generator/main
  5. Create the pull request.

Alternatively see the GitHub documentation on creating a pull request.

Contributors

Thanks to the following people who have contributed to this project:

License

This project uses the MIT license.