Back to list
aiskillstore

trpc-scaffolder

by aiskillstore

Security-audited skills for Claude, Codex & Claude Code. One-click install, quality verified.

102🍴 3📅 Jan 23, 2026

SKILL.md


name: trpc-scaffolder description: Scaffolds tRPC routers, procedures, and Zod schemas with full type safety following DevPrep AI patterns allowed-tools: [Read, Write, Edit, Bash, Glob, Grep]

tRPC Scaffolder

Automate creation of type-safe tRPC endpoints with Zod validation.

TL;DR: Run scripts to create routers/schemas, register in _app.ts, validate with scripts.


Auto-Triggers

Auto-triggered by keywords:

  • "new endpoint", "create endpoint", "tRPC procedure"
  • "new router", "API", "Zod schema"

Quick Standards

File Locations

lib/trpc/routers/
  _app.ts          # Register all routers here ⚠️
  {name}.ts        # Router files

lib/trpc/schemas/
  {entity}.schema.ts  # Zod schemas

Router Pattern

export const nameRouter = router({
  doThing: publicProcedure
    .input(inputSchema)
    .output(outputSchema)
    .mutation(async ({ input }) => { /* logic */ }),
});

Schema Pattern

export const inputSchema = z.object({
  field: z.string().min(1),
});

export type Input = z.infer<typeof inputSchema>;  // ⚠️ Required!

Registration (Required!)

// In _app.ts
export const appRouter = router({
  ai: aiRouter,
  name: nameRouter,  // ⬅️ Add new routers here
});

Run Scripts

Create Router

./.claude/skills/trpc-scaffolder/scripts/create-router.sh user
# Creates: lib/trpc/routers/user.ts
# ⚠️ Remember to register in _app.ts!

Add Procedure

./.claude/skills/trpc-scaffolder/scripts/add-procedure.sh ai getHints query
# Outputs code snippet to add to router

Create Schema

./.claude/skills/trpc-scaffolder/scripts/create-schema.sh hint
# Creates: lib/trpc/schemas/hint.schema.ts

Validate Setup

./.claude/skills/trpc-scaffolder/scripts/validate-trpc.sh
# Checks: router registration, type exports

Quick Reference

Query vs Mutation

TypeUse ForMethod
QueryFetch data (GET).query(async ({ input }) => ...)
MutationModify data (POST/PUT/DELETE).mutation(async ({ input }) => ...)

Common Zod Patterns

TypePatternExample
Stringz.string().min(1).max(100)Name validation
Numberz.number().int().min(0).max(10)Difficulty 0-10
Emailz.string().email()Email validation
Optionalz.string().optional()Optional field
Arrayz.array(z.string()).min(1)At least 1 item
Enumz.enum(["a", "b", "c"])Fixed choices
Objectz.object({ field: z.string() })Nested object

Naming Conventions

  • Routers: {domain}Router (e.g., aiRouter, userRouter)
  • Procedures: camelCase (e.g., generateQuestions, getHints)
  • Schemas: {action}{Entity}{Input\|Output}Schema
  • Files: {entity}.schema.ts, {domain}.ts

Error Codes

CodeWhenExample
NOT_FOUNDResource doesn't existUser not found
BAD_REQUESTInvalid inputValidation failed
UNAUTHORIZEDNot authenticatedLogin required
FORBIDDENNot authorizedAccess denied
INTERNAL_SERVER_ERRORServer errorAPI failure

Common Fixes

Router Not Registered

// ❌ Forgot this step
// ✅ Add to _app.ts:
import { userRouter } from "./user";
export const appRouter = router({ ai: aiRouter, user: userRouter });

Missing Type Exports

// ❌ Schema without types
export const userSchema = z.object({ name: z.string() });

// ✅ Always export inferred types
export type User = z.infer<typeof userSchema>;

Wrong Procedure Type

// ❌ Using mutation for fetching data
getData: publicProcedure.mutation(...)

// ✅ Use query for GET operations
getData: publicProcedure.query(...)

Schema Validation Error

// ❌ No validation
field: z.string()

// ✅ Add constraints
field: z.string().min(1, "Field is required")

When to Load Additional Docs

SKILL.md is self-sufficient for:

  • Creating routers and schemas
  • Running scripts
  • Fixing common errors

Load additional docs when needed:

NeedLoad
Step-by-step tutorialdocs/quick-start-guide.md
Advanced Zod patternsdocs/trpc-patterns.md (lines 1-80)
Error handling strategiesdocs/trpc-patterns.md (lines 150-220)
Testing proceduresdocs/trpc-patterns.md (lines 220-270)
Context & middlewaredocs/trpc-patterns.md (lines 80-150)

Code examples:

  • ✅ Perfect: examples/good-router.ts, examples/good-schema.ts

Full project docs: Docs/api-design.md, Docs/api-transition/trpc-migration.md


Version: 1.0.0 | Updated: October 2025 Pattern: Follows quality-reviewer structure (optimized)

Score

Total Score

60/100

Based on repository quality metrics

SKILL.md

SKILL.mdファイルが含まれている

+20
LICENSE

ライセンスが設定されている

0/10
説明文

100文字以上の説明がある

0/10
人気

GitHub Stars 100以上

+5
最近の活動

1ヶ月以内に更新

+10
フォーク

10回以上フォークされている

0/5
Issue管理

オープンIssueが50未満

+5
言語

プログラミング言語が設定されている

+5
タグ

1つ以上のタグが設定されている

+5

Reviews

💬

Reviews coming soon