zodipus

Prisma-to-Zod schema generator with composable Query Engine. Use when user mentions zodipus, prisma zod schemas, prisma validation, zod from prisma, query builders with zod, runtime database validation, or type-safe prisma queries.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "zodipus" with this command: npx skills add bratsos/zodipus/bratsos-zodipus-zodipus

Zodipus

Type-safe Zod schema generator for Prisma with composable Query Engine.

When to Apply

  • User mentions "zodipus" anywhere in conversation
  • User wants Zod schemas generated from Prisma
  • User needs runtime validation for Prisma queries
  • User asks about type-safe query builders
  • User has Prisma + Zod integration questions
  • User mentions "prisma-zod" or similar terms

Quick Routing

User IntentSkill
Install, setup, configure generatorzodipus-setup
Query engine, createRegistry, type-safe querieszodipus-query-engine
JSON fields, @zodSchema, custom schemaszodipus-custom-schemas
Errors, validation failed, not workingzodipus-troubleshooting
Migrate from other generatorszodipus-migration

Core Concepts

1. Generator

Zodipus is a Prisma generator that outputs Zod schemas:

generator zodipus {
  provider = "zodipus"
  output   = "./generated"
}

2. Clean Schemas

Generated schemas contain scalar fields only (no relations). This keeps validation fast and focused:

// Generated UserSchema validates: id, email, name, role, createdAt, updatedAt
// Does NOT include: posts, comments, profile (relations)
const user = UserSchema.parse(data);

3. Query Engine

Build composable queries with automatic validation:

import { createRegistry } from 'zodipus/queryEngine';
import { models, modelRelations } from './generated/generated-index';

const registry = createRegistry({ models, relations: modelRelations });
const userQuery = registry.createQuery('user');

const query = userQuery({
  select: { id: true, email: true },
  posts: { select: { title: true } }
});

const result = query.parse(await prisma.user.findFirst(query.query));
// Fully typed: { id: string; email: string; posts: { title: string }[] }

4. Custom JSON Schemas

Type Prisma JSON fields with @zodSchema:

model Post {
  /// @zodSchema PostMetadataSchema
  metadata Json?
}

Minimal Working Example

Step 1: Install

npm install zodipus zod

Step 2: Configure

generator client {
  provider = "prisma-client-js"
}

generator zodipus {
  provider = "zodipus"
  output   = "./generated"
}

model User {
  id    String @id @default(cuid())
  email String @unique
  name  String?
  posts Post[]
}

model Post {
  id       String  @id @default(cuid())
  title    String
  author   User    @relation(fields: [authorId], references: [id])
  authorId String
}

Step 3: Generate

npx prisma generate

Step 4: Use

import { UserSchema, PostSchema } from './generated';
import { createRegistry } from 'zodipus/queryEngine';
import { models, modelRelations } from './generated/generated-index';

// Direct validation
const user = UserSchema.parse(userData);

// Query with validation
const registry = createRegistry({ models, relations: modelRelations });
const query = registry.createQuery('user')({
  select: { id: true, email: true, name: true }
});

const users = await prisma.user.findMany(query.query);
const validated = query.array().parse(users);

Generated Files

After running prisma generate, Zodipus creates:

FileContents
enums.tsPrisma enums as Zod schemas
models.tsClean model schemas (no relations)
custom-schemas.tsPlaceholder for @zodSchema definitions
generated-relations.tsRelation metadata for Query Engine
generated-index.tsRe-exports and convenience exports

Priority Reference

PriorityFeatureWhen to Use
CriticalUserSchema.parse()Validate any model data
CriticalcreateRegistry()Set up Query Engine
Highquery.array().parse()Validate findMany results
Highquery.safeParse()Handle errors without throwing
Medium@zodSchema annotationType JSON fields
MediumrelationDepth configDeep nested queries
LowCLI inspect commandDebug schema issues

Quick Reference

See references/QUICK-REFERENCE.md for a complete cheat sheet.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

zodipus-query-engine

No summary provided by upstream source.

Repository SourceNeeds Review
General

zodipus-migration

No summary provided by upstream source.

Repository SourceNeeds Review
General

zodipus-setup

No summary provided by upstream source.

Repository SourceNeeds Review
General

zodipus-troubleshooting

No summary provided by upstream source.

Repository SourceNeeds Review
zodipus | V50.AI