install
source · Clone the upstream repo
git clone https://github.com/wrtnlabs/autobe
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/wrtnlabs/autobe "$T" && mkdir -p ~/.claude/skills && cp -r "$T/internals/template/realize/.claude/skills/fix-interface" ~/.claude/skills/wrtnlabs-autobe-fix-interface && rm -rf "$T"
manifest:
internals/template/realize/.claude/skills/fix-interface/SKILL.mdsource content
Fix Interface Errors
Fix interface and controller compilation errors according to code conventions.
FORBIDDEN
NEVER use:
keyword (type assertion)as
typeany
Fix type issues by properly defining interfaces.
DO NOT MODIFY
Leave as-is:
in Controller catch blocksconsole.log
in Controller catch blocksconsole.error
These are intentional and should not be changed to NestJS Logger.
Purpose
Fix compilation errors in interface and controller files to ensure
npm run build:main passes.
Workflow
┌─────────────────────────────────────┐ │ Step 1: Run Build │ │ npm run build:main │ └───────────────┬─────────────────────┘ │ ▼ ┌─────────────────────────────────────┐ │ Step 2: Parse Interface Errors │ │ - Empty interfaces {} │ │ - Type mismatches │ │ - Missing properties │ └───────────────┬─────────────────────┘ │ ▼ ┌─────────────────────────────────────┐ │ Step 3: Fix by Convention │ │ - Fill empty interfaces │ │ - Add typia tags │ │ - Fix nullable types │ └───────────────┬─────────────────────┘ │ ▼ ┌─────────────────────────────────────┐ │ Step 4: Re-run Build │ │ Loop until 0 errors │ └─────────────────────────────────────┘
Step 1: Run Build
npm run build:main 2>&1 | head -100
Capture interface-related errors.
Step 2: Parse Errors
Common error patterns:
→ Empty interfaceType '{}' is not assignable
→ Empty interfaceProperty 'X' does not exist on type '{}'
→ Missing typia tagType 'string' is not assignable to type 'string & Format<"uuid">'
Step 3: Fix by Convention
Empty Interface Fix
Read Prisma schema and fill interface:
// Before export type IEntity = {}; // After import { tags } from "typia"; export type IEntity = { id: string & tags.Format<"uuid">; name: string; status: "active" | "inactive"; created_at: string & tags.Format<"date-time">; updated_at: string & tags.Format<"date-time">; deleted_at: (string & tags.Format<"date-time">) | null; };
ICreate Convention
export namespace IEntity { export type ICreate = { name: string; status?: "active" | "inactive"; // optional with default }; }
IUpdate Convention
export namespace IEntity { export type IUpdate = { name?: string; status?: "active" | "inactive"; }; }
ISummary Convention
export namespace IEntity { export type ISummary = { id: string & tags.Format<"uuid">; name: string; status: "active" | "inactive"; created_at: string & tags.Format<"date-time">; }; }
IRequest Convention
export namespace IEntity { export type IRequest = { page?: number & tags.Minimum<1>; limit?: number & tags.Minimum<1> & tags.Maximum<100>; search?: string; status?: "active" | "inactive"; }; }
Typia Tags
// UUID id: string & tags.Format<"uuid">; // Email email: string & tags.Format<"email">; // URL url: string & tags.Format<"uri">; // DateTime created_at: string & tags.Format<"date-time">; // Numeric constraints page: number & tags.Minimum<1>; limit: number & tags.Minimum<1> & tags.Maximum<100>;
Nullable Types
// Nullable field deleted_at: (string & tags.Format<"date-time">) | null; // Optional nullable field description?: string | null;
Path Naming Fix
Fix redundant path segments where the same word repeats:
// Before - redundant word in path: /{word}/{word}s @Controller("{prefix}/{word}/{word}s") export class {Word}{Word}sController { ... } // After - remove redundant segment @Controller("{prefix}/{word}s") export class {Word}sController { ... }
Pattern to fix:
→/{word}/{word}s/{word}s
→/{word}/{word}-*
or/{word}-*/{word}/*
When fixing paths, also update:
- Controller
decorator@Controller() - Controller class name
- Controller file name and directory
- Related provider function names
- Test file paths and API calls
Step 4: Verify
npm run build:main
Repeat Steps 2-4 until no interface errors.
Common Fixes
| Error Pattern | Fix |
|---|---|
Empty interface | Read Prisma schema, define all fields |
| Missing typia tag | Add appropriate |
| Nullable mismatch | Add for nullable fields |
| Missing namespace | Add namespace with ICreate, IUpdate, etc. |
Redundant path | Remove duplication: |
Exit Condition
completes with no interface errorsnpm run build:main- All interfaces properly defined
- All typia tags applied
- No redundant path segments (
pattern)/{word}/{word}s