Group G — markdown tech-debt cleanup (post-audit 2026-05-02).
- 36 SKILL.md files: added "## When to use" section. Was missing across the
catalog; orchestrator routing by keyword could not auto-dispatch.
- 20 code-implementer agent .md files: added Output Footer block prescribing
RULE 0.16 STATUS-TRUTH MARKER schema in agent's final report. Previously only
code-implementer-rust.md had it; other 27 language/role variants were silent
about the marker, breaking RULE 0.16 §3 status-truth aggregation for non-Rust
batches.
- skills/site-create/: added phase-5-preview.md and phase-6-deploy.md skeleton
files. SKILL.md table-of-contents referenced 7 phases; only 5 existed on disk.
- skills/{ai-animation,rag-pipeline}/skill.md: added migration banner comment
noting they should be SKILL.md (canonical filename). Case-rename via git is a
separate orchestrator task (macOS APFS is case-insensitive; Linux deploy needs
explicit rename).
- 3 deprecated skills (site-builder, competitor-analysis, design-inspiration):
added concrete removed-after dates (was vague "before v2").
- docs/CONVERGENCE-PLAN.md:129: TBD on _blocks/evidence-grading.md duplicate
resolved (file exists, not duplicated).
- docs/DNA-INDEX.md: count edits made then overwritten by auto-encyclopedia-refresh
hook during agent run. The .kei-registry-ignore files in test fixtures (Group F)
are the structural fix; kei-registry walker implementation is the follow-up.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
6 KiB
| name | description | argument-hint |
|---|---|---|
| schema-design | Hub-and-spoke pipeline that converts "I need a database for app X" into a designed relational schema, a generated first migration, and optional seed/fixture data — via pure-click decisions across five phases. Emits SQL DDL, a kei-migrate-shaped migrations directory, and a library/ORM pick; never writes production secrets. | <one-line app description, e.g. "multi-tenant B2B SaaS, 6-8 entities, Postgres + Drizzle"> |
Schema-Design — Relational Schema & Migration Pipeline (index)
When to use
- Designing a relational database schema for a new or evolving app (Postgres, SQLite).
- Generating SQL DDL, migrations directory, and optional seed/fixture data from a click-driven design session.
- Choosing the right ORM, migration tool, and indexing strategy before writing any code.
See
_blocks/pipeline-5phase-template.mdfor the 5-phase wizard contract and_blocks/rule-pure-click-contract.mdfor the AskUserQuestion rule. Skill-specific phase tables are inline below.
You are converting "I need a database for app X" into a concrete, reviewable design: chosen DB + ORM, entity list + relations, SQL DDL with indexes and FKs, a scaffolded migrations directory with the first migration, and (if asked) seed data for tests and dev. Every decision is a click; the only typed inputs are the one-line app description in Phase 1 and the entity list in Phase 2.
This skill does NOT run migrations or touch production. It produces files
under db/schema.sql, migrations/<ts>_init.sql (+ .down.sql), and
optionally db/seed.sql. Applying them is a separate command (kei-migrate up), owned by the project's code-implementer.
The skill reads the five database blocks heavily — every phase references at least one of them:
_blocks/db-postgres.md— PG 17 patterns, indexing, pooling._blocks/db-sqlite.md— single-node / edge pragmas._blocks/db-sqlx.md— Rust query + migration flow._blocks/db-drizzle.md— TS schema-first ORM._blocks/db-migration-hygiene.md— universal up/down + checksum rules.
Primitive used for scaffolding: _primitives/_rust/kei-migrate (universal
Postgres / SQLite / MySQL migration runner — create + up + down + status).
Pipeline overview (5 phases, ≥5 AskUserQuestion calls)
| Phase | File | Purpose | AskUserQuestion |
|---|---|---|---|
| 1 | phase-1-intake.md | DB, ORM, scale, style, migration control | 5× (batched) |
| 2 | phase-2-entities.md | Entity list + relations matrix | 1× |
| 3 | phase-3-schema.md | Generate DDL + indexes + FKs + constraints; review/revise | 1× |
| 4 | phase-4-migrations.md | Scaffold migrations/ + first migration + kei-migrate wiring |
1× |
| 5 | phase-5-seed.md | Optional seed + test fixtures | 1× |
Minimum AskUserQuestion count across a full session: 9 (5 in Phase 1 + 1 each in Phases 2–5). Exceeds the ≥5 hub-and-spoke contract.
Variables the pipeline produces
| Name | Set in | Meaning |
|---|---|---|
INTAKE |
Phase 1 | one-paragraph app description (verbatim) |
DB |
Phase 1 | Postgres / SQLite / MySQL |
ORM |
Phase 1 | none (raw SQL) / Drizzle / SQLx / Prisma / SQLAlchemy |
SCALE |
Phase 1 | solo-prototype / team-dev / production-multi-replica |
STYLE |
Phase 1 | schema-first (SQL → types) / code-first (types → SQL) |
MIGCTL |
Phase 1 | manual / auto-on-deploy / hybrid (manual prod, auto dev) |
ENTITIES |
Phase 2 | list of entities + fields + relations matrix |
DDL |
Phase 3 | generated SQL (tables, indexes, FKs, constraints) |
MIGDIR |
Phase 4 | path of migrations dir + first migration filenames |
SEED |
Phase 5 | seed-data plan (or "skipped") |
Final report (emit after Phase 5)
=== SCHEMA-DESIGN REPORT ===
App: <first 80 chars of INTAKE>...
DB / ORM: <DB> + <ORM> (style: <STYLE>)
Scale: <SCALE> migration control: <MIGCTL>
Entities: <N> tables, <M> relations
Schema: db/schema.sql (<LOC> lines, <I> indexes, <F> FKs, <C> constraints)
Migrations: migrations/<ts>_init.sql (+ .down.sql) runner: kei-migrate
Seed: <SEED summary or "skipped">
Libraries: <ORM pick + driver crate/package, one line>
Next: run `kei-migrate up` against dev DB, then hand off to code-implementer
Rules (apply throughout)
- Pure-click contract. Only the Phase 1 intake paragraph and the Phase 2
entity list are typed. Every other decision is an
AskUserQuestioncall. - RULE 0.8 Secrets SSoT. The skill never emits a live
DATABASE_URLvalue, never writes tosecrets/*.env, never hard-codes credentials in DDL or seed. It emits ENV-VAR NAMES only; storage path is<repo>/secrets/db.envperdomain-has-secrets.md. - NO DOWNGRADE. If the chosen combination is unsafe (e.g.
auto-on-deploy+ multi-replica without leader-election) the skill returns 2–3 constructive alternatives, never "not supported". - Migration hygiene enforced. Every migration emitted is
timestamp-prefixed, has a
.down.sqlcounterpart, and usesIF NOT EXISTS/IF EXISTSwhere safe. Seedb-migration-hygiene.md. - Test-First. If Phase 5 is selected, seed includes at minimum a smoke-test fixture (one row per entity) to verify schema loads.
- Surgical scope. Reads the five db-* blocks; writes only to
db/schema.sql,migrations/<ts>_init.{sql,down.sql}, and optionallydb/seed.sql. Never touches application code.
References
_blocks/db-postgres.md,_blocks/db-sqlite.md,_blocks/db-sqlx.md,_blocks/db-drizzle.md,_blocks/db-migration-hygiene.md._primitives/_rust/kei-migrate— universal migration runner (autodetects Postgres / SQLite / MySQL fromDATABASE_URL)._blocks/domain-has-secrets.md— DB URL storage convention._blocks/rule-pre-dev-gate.md— check existing schema before inventing.- Evidence grade [E4] — pipeline mirrors standard relational-modelling practice (Codd 1NF-3NF, surrogate keys, FK-first indexing).