mirror of
https://github.com/glittercowboy/get-shit-done
synced 2026-05-13 18:46:38 +02:00
* docs(adr): add ADR-0003 model catalog module * fix(#3229): add shared model catalog as source of truth for agent profiles and runtime tier defaults Research / design (ADR-0003): - Existing drift came from 4 independent model truths: 1. CJS model-profiles.cjs 2. SDK config-query.ts stale copy (18 agents) 3. settings-advanced.md runtime tier table 4. session-runner Claude-only profile map - New design: one machine-readable Model Catalog Module in sdk/shared/ that both packages ship and consume. Implementation: - sdk/shared/model-catalog.json — canonical source of truth for: - full 33-agent registry - per-agent golden (quality) alias + balanced/budget aliases - adaptive derivation from routingTier - agent→phaseType map - agent→dynamic-routing default tier map - runtime tier defaults for all supported runtimes - get-shit-done/bin/lib/model-catalog.cjs — CJS adapter over the catalog - sdk/src/model-catalog.ts — SDK adapter over the same catalog - CJS model-profiles.cjs now re-exports derived data from model-catalog.cjs - SDK config-query.ts now re-exports MODEL_PROFILES/VALID_PROFILES from model-catalog.ts instead of maintaining its own list - sdk/src/query/helpers.ts runtime list now comes from the catalog (fixes hermes drift) - sdk/src/session-runner.ts Claude profile→model-id mapping now resolves via catalog - docs/CONFIGURATION.md + settings-advanced.md runtime tables updated to match catalog Behavior changes: - resolve-model now covers every shipped agent file on disk (33 agents) - unknown-agent fallback is profile-semantic, not hardcoded sonnet: quality→opus, budget→haiku, balanced/adaptive→sonnet, inherit→inherit - Group B runtimes remain known runtimes but do not get built-in tier defaults Tests (RED→GREEN): - root tests: shipped agent files must equal MODEL_PROFILES keys - sdk tests: shipped agent files must equal MODEL_PROFILES keys - direct fix assertion: gsd-code-reviewer resolves to opus under quality with no unknown_agent - runtime defaults parity test: settings-advanced.md + CONFIGURATION.md tables must match catalog - helper tests: hermes included in SUPPORTED_RUNTIMES and getRuntimeConfigDir() Closes #3229 * chore(changeset): update #3229 changeset pr field to 3230 * fix(ci): update inherit fallback expectations and inventory parity for model catalog
123 lines
7.2 KiB
JSON
123 lines
7.2 KiB
JSON
{
|
|
"profiles": ["quality", "balanced", "budget", "adaptive", "inherit"],
|
|
"phaseTypes": ["planning", "discuss", "research", "execution", "verification", "completion"],
|
|
"adaptiveTierMap": {
|
|
"heavy": "opus",
|
|
"standard": "sonnet",
|
|
"light": "haiku"
|
|
},
|
|
"runtimeTierDefaults": {
|
|
"claude": {
|
|
"opus": { "model": "claude-opus-4-7" },
|
|
"sonnet": { "model": "claude-sonnet-4-6" },
|
|
"haiku": { "model": "claude-haiku-4-5" }
|
|
},
|
|
"codex": {
|
|
"opus": { "model": "gpt-5.4", "reasoning_effort": "xhigh" },
|
|
"sonnet": { "model": "gpt-5.3-codex", "reasoning_effort": "medium" },
|
|
"haiku": { "model": "gpt-5.4-mini", "reasoning_effort": "medium" }
|
|
},
|
|
"gemini": {
|
|
"opus": { "model": "gemini-3-pro" },
|
|
"sonnet": { "model": "gemini-3-flash" },
|
|
"haiku": { "model": "gemini-2.5-flash-lite" }
|
|
},
|
|
"qwen": {
|
|
"opus": { "model": "qwen3-max-2026-01-23" },
|
|
"sonnet": { "model": "qwen3-coder-plus" },
|
|
"haiku": { "model": "qwen3-coder-next" }
|
|
},
|
|
"opencode": {
|
|
"opus": { "model": "anthropic/claude-opus-4-7" },
|
|
"sonnet": { "model": "anthropic/claude-sonnet-4-6" },
|
|
"haiku": { "model": "anthropic/claude-haiku-4-5" }
|
|
},
|
|
"copilot": {
|
|
"opus": { "model": "claude-opus-4-7" },
|
|
"sonnet": { "model": "claude-sonnet-4-6" },
|
|
"haiku": { "model": "claude-haiku-4-5" }
|
|
},
|
|
"hermes": {
|
|
"opus": { "model": "anthropic/claude-opus-4-7" },
|
|
"sonnet": { "model": "anthropic/claude-sonnet-4-6" },
|
|
"haiku": { "model": "anthropic/claude-haiku-4-5" }
|
|
},
|
|
"kilo": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
},
|
|
"cline": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
},
|
|
"cursor": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
},
|
|
"windsurf": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
},
|
|
"augment": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
},
|
|
"trae": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
},
|
|
"codebuddy": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
},
|
|
"antigravity": {
|
|
"opus": null,
|
|
"sonnet": null,
|
|
"haiku": null
|
|
}
|
|
},
|
|
"agents": {
|
|
"gsd-planner": { "golden": "opus", "balanced": "opus", "budget": "sonnet", "phaseType": "planning", "routingTier": "heavy" },
|
|
"gsd-roadmapper": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "planning", "routingTier": "heavy" },
|
|
"gsd-executor": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "execution", "routingTier": "standard" },
|
|
"gsd-phase-researcher": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "standard" },
|
|
"gsd-project-researcher": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "standard" },
|
|
"gsd-research-synthesizer": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "light" },
|
|
"gsd-debugger": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "execution", "routingTier": "heavy" },
|
|
"gsd-codebase-mapper": { "golden": "sonnet", "balanced": "haiku", "budget": "haiku", "phaseType": "research", "routingTier": "light" },
|
|
"gsd-verifier": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "standard" },
|
|
"gsd-plan-checker": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "light" },
|
|
"gsd-integration-checker": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "light" },
|
|
"gsd-nyquist-auditor": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "light" },
|
|
"gsd-pattern-mapper": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "planning", "routingTier": "light" },
|
|
"gsd-ui-researcher": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "standard" },
|
|
"gsd-ui-checker": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "light" },
|
|
"gsd-ui-auditor": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "light" },
|
|
"gsd-doc-writer": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "execution", "routingTier": "standard" },
|
|
"gsd-doc-verifier": { "golden": "sonnet", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "light" },
|
|
|
|
"gsd-advisor-researcher": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "standard" },
|
|
"gsd-ai-researcher": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "standard" },
|
|
"gsd-assumptions-analyzer": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "discuss", "routingTier": "heavy" },
|
|
"gsd-code-fixer": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "execution", "routingTier": "standard" },
|
|
"gsd-code-reviewer": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "verification", "routingTier": "standard" },
|
|
"gsd-debug-session-manager": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "execution", "routingTier": "heavy" },
|
|
"gsd-doc-classifier": { "golden": "sonnet", "balanced": "haiku", "budget": "haiku", "phaseType": "research", "routingTier": "light" },
|
|
"gsd-doc-synthesizer": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "standard" },
|
|
"gsd-domain-researcher": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "standard" },
|
|
"gsd-eval-auditor": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "verification", "routingTier": "standard" },
|
|
"gsd-eval-planner": { "golden": "opus", "balanced": "opus", "budget": "sonnet", "phaseType": "planning", "routingTier": "heavy" },
|
|
"gsd-framework-selector": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "planning", "routingTier": "heavy" },
|
|
"gsd-intel-updater": { "golden": "opus", "balanced": "sonnet", "budget": "haiku", "phaseType": "research", "routingTier": "light" },
|
|
"gsd-security-auditor": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "verification", "routingTier": "heavy" },
|
|
"gsd-user-profiler": { "golden": "opus", "balanced": "sonnet", "budget": "sonnet", "phaseType": "research", "routingTier": "heavy" }
|
|
}
|
|
}
|