Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/CarterGrimmeisen/zod-prisma
A custom prisma generator that creates Zod schemas from your Prisma model.
https://github.com/CarterGrimmeisen/zod-prisma
prisma typescript zod
Last synced: about 2 months ago
JSON representation
A custom prisma generator that creates Zod schemas from your Prisma model.
- Host: GitHub
- URL: https://github.com/CarterGrimmeisen/zod-prisma
- Owner: CarterGrimmeisen
- License: mit
- Created: 2021-06-01T17:03:24.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-13T22:08:35.000Z (9 months ago)
- Last Synced: 2024-11-02T07:06:04.936Z (2 months ago)
- Topics: prisma, typescript, zod
- Language: TypeScript
- Homepage:
- Size: 16.3 MB
- Stars: 824
- Watchers: 7
- Forks: 86
- Open Issues: 52
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-zod - `zod-prisma` - Generate Zod schemas from your Prisma schema. (Convertors and Generators)
README
[![NPM][npm-shield]][npm-url]
[![Contributors][contributors-shield]][contributors-url]
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
[![MIT License][license-shield]][license-url]
Zod Prisma
A custom prisma generator that creates Zod schemas from your Prisma model.
Explore the docs »
View Demo
·
Report Bug
·
Request Feature
Table of Contents
## About The Project
I got tired of having to manually create Zod schemas for my Prisma models and of updating them everytime I made schema changes.
This provides a way of automatically generating them with your prisma### Built With
- [dts-cli](https://github.com/weiran-zsd/dts-cli)
- [Zod](https://github.com/colinhacks/zod)
- [Based on this gist](https://gist.github.com/deckchairlabs/8a11c33311c01273deec7e739417dbc9)## Getting Started
To get a local copy up and running follow these simple steps.
### Prerequisites
This project utilizes yarn and if you plan on contributing, you should too.
```sh
npm install -g yarn
```### Installation
0. **Ensure your tsconfig.json enables the compiler's strict mode.**
**Zod requires it and so do we, you will experience TS errors without strict mode enabled**1. Add zod-prisma as a dev dependency
```sh
yarn add -D zod-prisma
```2. Add the zod-prisma generator to your schema.prisma
```prisma
generator zod {
provider = "zod-prisma"
output = "./zod" // (default) the directory where generated zod schemas will be savedrelationModel = true // (default) Create and export both plain and related models.
// relationModel = "default" // Do not export model without relations.
// relationModel = false // Do not generate related modelmodelCase = "PascalCase" // (default) Output models using pascal case (ex. UserModel, PostModel)
// modelCase = "camelCase" // Output models using camel case (ex. userModel, postModel)modelSuffix = "Model" // (default) Suffix to apply to your prisma models when naming Zod schemas
// useDecimalJs = false // (default) represent the prisma Decimal type using as a JS number
useDecimalJs = true // represent the prisma Decimal type using Decimal.js (as Prisma does)imports = null // (default) will import the referenced file in generated schemas to be used via imports.someExportedVariable
// https://www.prisma.io/docs/concepts/components/prisma-client/working-with-fields/working-with-json-fields#filtering-by-null-values
prismaJsonNullability = true // (default) uses prisma's scheme for JSON field nullability
// prismaJsonNullability = false // allows null assignment to optional JSON fields
}
```3. Run `npx prisma generate` or `yarn prisma generate` to generate your zod schemas
4. Import the generated schemas form your selected output location## Usage
### JSDoc Generation
[Rich-comments](https://www.prisma.io/docs/concepts/components/prisma-schema#comments)
in the Prisma schema will be transformed into JSDoc for the associated fields:> _Note: make sure to use a triple-slash. Double-slash comments won't be processed._
```prisma
model Post {
/// The unique identifier for the post
/// @default {Generated by database}
id String @id @default(uuid())/// A brief title that describes the contents of the post
title String/// The actual contents of the post.
contents String
}
```Generated code:
```ts
export const PostModel = z.object({
/**
* The unique identifier for the post
* @default {Generated by database}
*/
id: z.string().uuid(),
/**
* A brief title that describes the contents of the post
*/
title: z.string(),
/**
* The actual contents of the post.
*/
contents: z.string(),
})
```### Extending Zod Fields
You can also use the `@zod` keyword in rich-comments in the Prisma schema
to extend your Zod schema fields:```prisma
model Post {
id String @id @default(uuid()) /// @zod.uuid()/// @zod.max(255, { message: "The title must be shorter than 256 characters" })
title Stringcontents String /// @zod.max(10240)
}
```Generated code:
```ts
export const PostModel = z.object({
id: z.string().uuid(),
title: z.string().max(255, { message: 'The title must be shorter than 256 characters' }),
contents: z.string().max(10240),
})
```### Importing Helpers
Sometimes its useful to define a custom Zod preprocessor or transformer for your data.
zod-prisma enables you to reuse these by importing them via a config options. For example:```prisma
generator zod {
provider = "zod-prisma"
output = "./zod"
imports = "../src/zod-schemas"
}model User {
username String /// @zod.refine(imports.isValidUsername)
}
```The referenced file can then be used by simply referring to exported members via `imports.whateverExport`.
The generated zod schema files will now include a namespaced import like the following.```typescript
import * as imports from '../../src/zod-schemas'
```#### Custom Zod Schema
In conjunction with this import option, you may want to utilize an entirely custom zod schema for a field.
This can be accomplished by using the special comment directive `@zod.custom()`.
By specifying the custom schema within the parentheses you can replace the autogenerated type that would normally be assigned to the field.> For instance if you wanted to use `z.preprocess`
### JSON Fields
JSON fields in Prisma disallow null values. This is to disambiguate between setting a field's value to NULL in the database and having
a value of null stored in the JSON. In accordance with this zod-prisma will default to disallowing null values, even if your JSON field is optional.If you would like to revert this behavior and allow null assignment to JSON fields,
you can set `prismaJsonNullability` to `false` in the generator options.## Examples
_For examples, please refer to the [Examples Directory](https://github.com/CarterGrimmeisen/zod-prisma/blob/main/examples) or the [Functional Tests](https://github.com/CarterGrimmeisen/zod-prisma/blob/main/src/test/functional)_
## Roadmap
See the [open issues](https://github.com/CarterGrimmeisen/zod-prisma/issues) for a list of proposed features (and known issues).
## Contributing
Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are **greatly appreciated**.
1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request## License
Distributed under the MIT License. See `LICENSE` for more information.
## Contact
Carter Grimmeisen - [email protected]
Project Link: [https://github.com/CarterGrimmeisen/zod-prisma](https://github.com/CarterGrimmeisen/zod-prisma)
[npm-shield]: https://img.shields.io/npm/v/zod-prisma?style=for-the-badge
[npm-url]: https://www.npmjs.com/package/zod-prisma
[contributors-shield]: https://img.shields.io/github/contributors/CarterGrimmeisen/zod-prisma.svg?style=for-the-badge
[contributors-url]: https://github.com/CarterGrimmeisen/zod-prisma/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/CarterGrimmeisen/zod-prisma.svg?style=for-the-badge
[forks-url]: https://github.com/CarterGrimmeisen/zod-prisma/network/members
[stars-shield]: https://img.shields.io/github/stars/CarterGrimmeisen/zod-prisma.svg?style=for-the-badge
[stars-url]: https://github.com/CarterGrimmeisen/zod-prisma/stargazers
[issues-shield]: https://img.shields.io/github/issues/CarterGrimmeisen/zod-prisma.svg?style=for-the-badge
[issues-url]: https://github.com/CarterGrimmeisen/zod-prisma/issues
[license-shield]: https://img.shields.io/github/license/CarterGrimmeisen/zod-prisma.svg?style=for-the-badge
[license-url]: https://github.com/CarterGrimmeisen/zod-prisma/blob/main/LICENSE