@moreih29/nexus-core 0.16.2 → 0.18.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +101 -67
- package/dist/cli/sync.d.ts +3 -0
- package/dist/cli/sync.d.ts.map +1 -0
- package/dist/cli/sync.js +59 -0
- package/dist/cli/sync.js.map +1 -0
- package/dist/generate/index.d.ts +3 -0
- package/dist/generate/index.d.ts.map +1 -0
- package/dist/generate/index.js +2 -0
- package/dist/generate/index.js.map +1 -0
- package/dist/generate/load-data.d.ts +8 -0
- package/dist/generate/load-data.d.ts.map +1 -0
- package/dist/generate/load-data.js +45 -0
- package/dist/generate/load-data.js.map +1 -0
- package/dist/generate/load-spec.d.ts +3 -0
- package/dist/generate/load-spec.d.ts.map +1 -0
- package/dist/generate/load-spec.js +48 -0
- package/dist/generate/load-spec.js.map +1 -0
- package/dist/generate/macros/expand.d.ts +3 -0
- package/dist/generate/macros/expand.d.ts.map +1 -0
- package/dist/generate/macros/expand.js +48 -0
- package/dist/generate/macros/expand.js.map +1 -0
- package/dist/generate/macros/parse.d.ts +4 -0
- package/dist/generate/macros/parse.d.ts.map +1 -0
- package/dist/generate/macros/parse.js +142 -0
- package/dist/generate/macros/parse.js.map +1 -0
- package/dist/generate/macros/validate.d.ts +3 -0
- package/dist/generate/macros/validate.d.ts.map +1 -0
- package/dist/generate/macros/validate.js +23 -0
- package/dist/generate/macros/validate.js.map +1 -0
- package/dist/generate/renderers/claude.d.ts +3 -0
- package/dist/generate/renderers/claude.d.ts.map +1 -0
- package/dist/generate/renderers/claude.js +48 -0
- package/dist/generate/renderers/claude.js.map +1 -0
- package/dist/generate/renderers/codex.d.ts +3 -0
- package/dist/generate/renderers/codex.d.ts.map +1 -0
- package/dist/generate/renderers/codex.js +79 -0
- package/dist/generate/renderers/codex.js.map +1 -0
- package/dist/generate/renderers/markdown.d.ts +2 -0
- package/dist/generate/renderers/markdown.d.ts.map +1 -0
- package/dist/generate/renderers/markdown.js +6 -0
- package/dist/generate/renderers/markdown.js.map +1 -0
- package/dist/generate/renderers/opencode.d.ts +3 -0
- package/dist/generate/renderers/opencode.d.ts.map +1 -0
- package/dist/generate/renderers/opencode.js +69 -0
- package/dist/generate/renderers/opencode.js.map +1 -0
- package/dist/generate/sync.d.ts +4 -0
- package/dist/generate/sync.d.ts.map +1 -0
- package/dist/generate/sync.js +60 -0
- package/dist/generate/sync.js.map +1 -0
- package/dist/generate/types.d.ts +74 -0
- package/dist/generate/types.d.ts.map +1 -0
- package/dist/generate/types.js +2 -0
- package/dist/generate/types.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/definitions/artifact.d.ts +20 -0
- package/dist/mcp/definitions/artifact.d.ts.map +1 -0
- package/dist/mcp/definitions/artifact.js +14 -0
- package/dist/mcp/definitions/artifact.js.map +1 -0
- package/dist/mcp/definitions/history.d.ts +20 -0
- package/dist/mcp/definitions/history.d.ts.map +1 -0
- package/dist/mcp/definitions/history.js +18 -0
- package/dist/mcp/definitions/history.js.map +1 -0
- package/dist/mcp/definitions/index.d.ts +276 -0
- package/dist/mcp/definitions/index.d.ts.map +1 -0
- package/dist/mcp/definitions/index.js +16 -0
- package/dist/mcp/definitions/index.js.map +1 -0
- package/dist/mcp/definitions/plan.d.ts +111 -0
- package/dist/mcp/definitions/plan.d.ts.map +1 -0
- package/dist/mcp/definitions/plan.js +89 -0
- package/dist/mcp/definitions/plan.js.map +1 -0
- package/dist/mcp/definitions/task.d.ts +138 -0
- package/dist/mcp/definitions/task.d.ts.map +1 -0
- package/dist/mcp/definitions/task.js +78 -0
- package/dist/mcp/definitions/task.js.map +1 -0
- package/dist/mcp/handlers/artifact.d.ts.map +1 -0
- package/dist/mcp/handlers/artifact.js +42 -0
- package/dist/mcp/handlers/artifact.js.map +1 -0
- package/dist/mcp/handlers/history.d.ts.map +1 -0
- package/dist/mcp/handlers/history.js +35 -0
- package/dist/mcp/handlers/history.js.map +1 -0
- package/dist/mcp/handlers/plan.d.ts.map +1 -0
- package/dist/mcp/handlers/plan.js +324 -0
- package/dist/mcp/handlers/plan.js.map +1 -0
- package/dist/mcp/handlers/task.d.ts.map +1 -0
- package/dist/mcp/handlers/task.js +216 -0
- package/dist/mcp/handlers/task.js.map +1 -0
- package/dist/{src/mcp → mcp}/server.d.ts +1 -1
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +58 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/shared/json-store.d.ts.map +1 -0
- package/dist/{src/shared → shared}/json-store.js +5 -4
- package/dist/shared/json-store.js.map +1 -0
- package/dist/shared/mcp-utils.d.ts.map +1 -0
- package/dist/shared/mcp-utils.js.map +1 -0
- package/dist/{src/shared → shared}/paths.d.ts +0 -4
- package/dist/shared/paths.d.ts.map +1 -0
- package/dist/shared/paths.js +62 -0
- package/dist/shared/paths.js.map +1 -0
- package/dist/shared/register-tool.d.ts +20 -0
- package/dist/shared/register-tool.d.ts.map +1 -0
- package/dist/shared/register-tool.js +15 -0
- package/dist/shared/register-tool.js.map +1 -0
- package/dist/{src/types → types}/state.d.ts +65 -65
- package/dist/types/state.d.ts.map +1 -0
- package/dist/{src/types → types}/state.js +1 -1
- package/dist/types/state.js.map +1 -0
- package/harness/claude/agent-rules.yml +21 -0
- package/harness/claude/invocations.yml +11 -0
- package/harness/claude/layout.yml +3 -0
- package/harness/codex/agent-rules.yml +28 -0
- package/harness/codex/invocations.yml +13 -0
- package/harness/codex/layout.yml +3 -0
- package/harness/opencode/agent-rules.yml +18 -0
- package/harness/opencode/invocations.yml +12 -0
- package/harness/opencode/layout.yml +3 -0
- package/package.json +38 -43
- package/{assets → spec}/agents/architect/body.ko.md +92 -84
- package/spec/agents/architect/body.md +185 -0
- package/spec/agents/designer/body.ko.md +330 -0
- package/spec/agents/designer/body.md +330 -0
- package/spec/agents/engineer/body.ko.md +166 -0
- package/spec/agents/engineer/body.md +166 -0
- package/spec/agents/lead/body.ko.md +276 -0
- package/spec/agents/lead/body.md +276 -0
- package/{assets → spec}/agents/postdoc/body.ko.md +116 -46
- package/spec/agents/postdoc/body.md +192 -0
- package/{assets → spec}/agents/researcher/body.ko.md +131 -45
- package/spec/agents/researcher/body.md +223 -0
- package/spec/agents/reviewer/body.ko.md +219 -0
- package/spec/agents/reviewer/body.md +219 -0
- package/{assets → spec}/agents/strategist/body.ko.md +108 -35
- package/spec/agents/strategist/body.md +187 -0
- package/spec/agents/tester/body.ko.md +272 -0
- package/spec/agents/tester/body.md +272 -0
- package/{assets → spec}/agents/writer/body.ko.md +109 -33
- package/spec/agents/writer/body.md +198 -0
- package/spec/skills/nx-auto-plan/body.ko.md +150 -0
- package/spec/skills/nx-auto-plan/body.md +150 -0
- package/spec/skills/nx-plan/body.ko.md +159 -0
- package/spec/skills/nx-plan/body.md +159 -0
- package/spec/skills/nx-run/body.ko.md +132 -0
- package/spec/skills/nx-run/body.md +132 -0
- package/vocabulary/enums/task-register-state.yml +4 -0
- package/vocabulary/invocations.yml +43 -0
- package/assets/agents/architect/body.md +0 -177
- package/assets/agents/designer/body.ko.md +0 -125
- package/assets/agents/designer/body.md +0 -125
- package/assets/agents/engineer/body.ko.md +0 -106
- package/assets/agents/engineer/body.md +0 -106
- package/assets/agents/lead/body.ko.md +0 -70
- package/assets/agents/lead/body.md +0 -70
- package/assets/agents/postdoc/body.md +0 -122
- package/assets/agents/researcher/body.md +0 -137
- package/assets/agents/reviewer/body.ko.md +0 -138
- package/assets/agents/reviewer/body.md +0 -138
- package/assets/agents/strategist/body.md +0 -116
- package/assets/agents/tester/body.ko.md +0 -195
- package/assets/agents/tester/body.md +0 -195
- package/assets/agents/writer/body.md +0 -122
- package/assets/capability-matrix.yml +0 -198
- package/assets/hooks/agent-bootstrap/handler.test.ts +0 -368
- package/assets/hooks/agent-bootstrap/handler.ts +0 -119
- package/assets/hooks/agent-bootstrap/meta.yml +0 -10
- package/assets/hooks/agent-finalize/handler.test.ts +0 -368
- package/assets/hooks/agent-finalize/handler.ts +0 -76
- package/assets/hooks/agent-finalize/meta.yml +0 -10
- package/assets/hooks/capability-matrix.yml +0 -313
- package/assets/hooks/post-tool-telemetry/handler.test.ts +0 -302
- package/assets/hooks/post-tool-telemetry/handler.ts +0 -49
- package/assets/hooks/post-tool-telemetry/meta.yml +0 -11
- package/assets/hooks/prompt-router/handler.test.ts +0 -801
- package/assets/hooks/prompt-router/handler.ts +0 -272
- package/assets/hooks/prompt-router/meta.yml +0 -11
- package/assets/hooks/session-init/handler.test.ts +0 -274
- package/assets/hooks/session-init/handler.ts +0 -30
- package/assets/hooks/session-init/meta.yml +0 -9
- package/assets/lsp-servers.json +0 -55
- package/assets/schema/lsp-servers.schema.json +0 -67
- package/assets/skills/nx-init/body.ko.md +0 -197
- package/assets/skills/nx-init/body.md +0 -197
- package/assets/skills/nx-plan/body.ko.md +0 -361
- package/assets/skills/nx-plan/body.md +0 -361
- package/assets/skills/nx-run/body.ko.md +0 -161
- package/assets/skills/nx-run/body.md +0 -160
- package/assets/skills/nx-sync/body.ko.md +0 -92
- package/assets/skills/nx-sync/body.md +0 -92
- package/assets/tools/tool-name-map.yml +0 -353
- package/dist/assets/hooks/agent-bootstrap/handler.d.ts +0 -4
- package/dist/assets/hooks/agent-bootstrap/handler.d.ts.map +0 -1
- package/dist/assets/hooks/agent-bootstrap/handler.js +0 -100
- package/dist/assets/hooks/agent-bootstrap/handler.js.map +0 -1
- package/dist/assets/hooks/agent-finalize/handler.d.ts +0 -4
- package/dist/assets/hooks/agent-finalize/handler.d.ts.map +0 -1
- package/dist/assets/hooks/agent-finalize/handler.js +0 -63
- package/dist/assets/hooks/agent-finalize/handler.js.map +0 -1
- package/dist/assets/hooks/post-tool-telemetry/handler.d.ts +0 -4
- package/dist/assets/hooks/post-tool-telemetry/handler.d.ts.map +0 -1
- package/dist/assets/hooks/post-tool-telemetry/handler.js +0 -40
- package/dist/assets/hooks/post-tool-telemetry/handler.js.map +0 -1
- package/dist/assets/hooks/prompt-router/handler.d.ts +0 -4
- package/dist/assets/hooks/prompt-router/handler.d.ts.map +0 -1
- package/dist/assets/hooks/prompt-router/handler.js +0 -214
- package/dist/assets/hooks/prompt-router/handler.js.map +0 -1
- package/dist/assets/hooks/session-init/handler.d.ts +0 -4
- package/dist/assets/hooks/session-init/handler.d.ts.map +0 -1
- package/dist/assets/hooks/session-init/handler.js +0 -23
- package/dist/assets/hooks/session-init/handler.js.map +0 -1
- package/dist/claude/.claude-plugin/marketplace.json +0 -75
- package/dist/claude/.claude-plugin/plugin.json +0 -67
- package/dist/claude/agents/architect.md +0 -172
- package/dist/claude/agents/designer.md +0 -120
- package/dist/claude/agents/engineer.md +0 -98
- package/dist/claude/agents/lead.md +0 -59
- package/dist/claude/agents/postdoc.md +0 -117
- package/dist/claude/agents/researcher.md +0 -132
- package/dist/claude/agents/reviewer.md +0 -133
- package/dist/claude/agents/strategist.md +0 -111
- package/dist/claude/agents/tester.md +0 -190
- package/dist/claude/agents/writer.md +0 -114
- package/dist/claude/dist/hooks/agent-bootstrap.js +0 -121
- package/dist/claude/dist/hooks/agent-finalize.js +0 -180
- package/dist/claude/dist/hooks/prompt-router.js +0 -7336
- package/dist/claude/dist/hooks/session-init.js +0 -37
- package/dist/claude/hooks/hooks.json +0 -52
- package/dist/claude/settings.json +0 -3
- package/dist/claude/skills/nx-init/SKILL.md +0 -189
- package/dist/claude/skills/nx-plan/SKILL.md +0 -353
- package/dist/claude/skills/nx-run/SKILL.md +0 -154
- package/dist/claude/skills/nx-sync/SKILL.md +0 -87
- package/dist/codex/agents/architect.toml +0 -175
- package/dist/codex/agents/designer.toml +0 -123
- package/dist/codex/agents/engineer.toml +0 -105
- package/dist/codex/agents/lead.toml +0 -64
- package/dist/codex/agents/postdoc.toml +0 -120
- package/dist/codex/agents/researcher.toml +0 -136
- package/dist/codex/agents/reviewer.toml +0 -137
- package/dist/codex/agents/strategist.toml +0 -114
- package/dist/codex/agents/tester.toml +0 -194
- package/dist/codex/agents/writer.toml +0 -121
- package/dist/codex/dist/hooks/agent-bootstrap.js +0 -121
- package/dist/codex/dist/hooks/agent-finalize.js +0 -180
- package/dist/codex/dist/hooks/prompt-router.js +0 -7336
- package/dist/codex/dist/hooks/session-init.js +0 -37
- package/dist/codex/hooks/hooks.json +0 -28
- package/dist/codex/install/AGENTS.fragment.md +0 -60
- package/dist/codex/install/config.fragment.toml +0 -5
- package/dist/codex/install/install.sh +0 -60
- package/dist/codex/package.json +0 -20
- package/dist/codex/plugin/.codex-plugin/plugin.json +0 -57
- package/dist/codex/plugin/skills/nx-init/SKILL.md +0 -189
- package/dist/codex/plugin/skills/nx-plan/SKILL.md +0 -353
- package/dist/codex/plugin/skills/nx-run/SKILL.md +0 -154
- package/dist/codex/plugin/skills/nx-sync/SKILL.md +0 -87
- package/dist/codex/prompts/architect.md +0 -166
- package/dist/codex/prompts/designer.md +0 -114
- package/dist/codex/prompts/engineer.md +0 -97
- package/dist/codex/prompts/lead.md +0 -60
- package/dist/codex/prompts/postdoc.md +0 -111
- package/dist/codex/prompts/researcher.md +0 -127
- package/dist/codex/prompts/reviewer.md +0 -128
- package/dist/codex/prompts/strategist.md +0 -105
- package/dist/codex/prompts/tester.md +0 -185
- package/dist/codex/prompts/writer.md +0 -113
- package/dist/hooks/agent-bootstrap.js +0 -121
- package/dist/hooks/agent-finalize.js +0 -180
- package/dist/hooks/prompt-router.js +0 -7336
- package/dist/hooks/session-init.js +0 -37
- package/dist/manifests/claude-hooks.json +0 -52
- package/dist/manifests/codex-hooks.json +0 -28
- package/dist/manifests/opencode-manifest.json +0 -44
- package/dist/manifests/portability-report.json +0 -87
- package/dist/opencode/.opencode/skills/nx-init/SKILL.md +0 -189
- package/dist/opencode/.opencode/skills/nx-plan/SKILL.md +0 -353
- package/dist/opencode/.opencode/skills/nx-run/SKILL.md +0 -154
- package/dist/opencode/.opencode/skills/nx-sync/SKILL.md +0 -87
- package/dist/opencode/package.json +0 -23
- package/dist/opencode/src/agents/architect.ts +0 -176
- package/dist/opencode/src/agents/designer.ts +0 -124
- package/dist/opencode/src/agents/engineer.ts +0 -105
- package/dist/opencode/src/agents/lead.ts +0 -66
- package/dist/opencode/src/agents/postdoc.ts +0 -121
- package/dist/opencode/src/agents/researcher.ts +0 -136
- package/dist/opencode/src/agents/reviewer.ts +0 -137
- package/dist/opencode/src/agents/strategist.ts +0 -115
- package/dist/opencode/src/agents/tester.ts +0 -194
- package/dist/opencode/src/agents/writer.ts +0 -121
- package/dist/opencode/src/index.ts +0 -25
- package/dist/opencode/src/plugin.ts +0 -6
- package/dist/scripts/build-agents.d.ts +0 -164
- package/dist/scripts/build-agents.d.ts.map +0 -1
- package/dist/scripts/build-agents.js +0 -890
- package/dist/scripts/build-agents.js.map +0 -1
- package/dist/scripts/build-hooks.d.ts +0 -57
- package/dist/scripts/build-hooks.d.ts.map +0 -1
- package/dist/scripts/build-hooks.js +0 -555
- package/dist/scripts/build-hooks.js.map +0 -1
- package/dist/scripts/cli.d.ts +0 -54
- package/dist/scripts/cli.d.ts.map +0 -1
- package/dist/scripts/cli.js +0 -504
- package/dist/scripts/cli.js.map +0 -1
- package/dist/scripts/smoke/smoke-claude.d.ts +0 -2
- package/dist/scripts/smoke/smoke-claude.d.ts.map +0 -1
- package/dist/scripts/smoke/smoke-claude.js +0 -58
- package/dist/scripts/smoke/smoke-claude.js.map +0 -1
- package/dist/scripts/smoke/smoke-codex.d.ts +0 -2
- package/dist/scripts/smoke/smoke-codex.d.ts.map +0 -1
- package/dist/scripts/smoke/smoke-codex.js +0 -50
- package/dist/scripts/smoke/smoke-codex.js.map +0 -1
- package/dist/scripts/smoke/smoke-consumer.d.ts +0 -2
- package/dist/scripts/smoke/smoke-consumer.d.ts.map +0 -1
- package/dist/scripts/smoke/smoke-consumer.js +0 -80
- package/dist/scripts/smoke/smoke-consumer.js.map +0 -1
- package/dist/scripts/smoke/smoke-opencode.d.ts +0 -2
- package/dist/scripts/smoke/smoke-opencode.d.ts.map +0 -1
- package/dist/scripts/smoke/smoke-opencode.js +0 -99
- package/dist/scripts/smoke/smoke-opencode.js.map +0 -1
- package/dist/src/hooks/opencode-mount.d.ts +0 -35
- package/dist/src/hooks/opencode-mount.d.ts.map +0 -1
- package/dist/src/hooks/opencode-mount.js +0 -352
- package/dist/src/hooks/opencode-mount.js.map +0 -1
- package/dist/src/hooks/runtime.d.ts +0 -37
- package/dist/src/hooks/runtime.d.ts.map +0 -1
- package/dist/src/hooks/runtime.js +0 -274
- package/dist/src/hooks/runtime.js.map +0 -1
- package/dist/src/hooks/types.d.ts +0 -196
- package/dist/src/hooks/types.d.ts.map +0 -1
- package/dist/src/hooks/types.js +0 -85
- package/dist/src/hooks/types.js.map +0 -1
- package/dist/src/lsp/cache.d.ts +0 -9
- package/dist/src/lsp/cache.d.ts.map +0 -1
- package/dist/src/lsp/cache.js +0 -216
- package/dist/src/lsp/cache.js.map +0 -1
- package/dist/src/lsp/client.d.ts +0 -24
- package/dist/src/lsp/client.d.ts.map +0 -1
- package/dist/src/lsp/client.js +0 -166
- package/dist/src/lsp/client.js.map +0 -1
- package/dist/src/lsp/detect.d.ts +0 -77
- package/dist/src/lsp/detect.d.ts.map +0 -1
- package/dist/src/lsp/detect.js +0 -116
- package/dist/src/lsp/detect.js.map +0 -1
- package/dist/src/mcp/server.d.ts.map +0 -1
- package/dist/src/mcp/server.js +0 -34
- package/dist/src/mcp/server.js.map +0 -1
- package/dist/src/mcp/tools/artifact.d.ts.map +0 -1
- package/dist/src/mcp/tools/artifact.js +0 -36
- package/dist/src/mcp/tools/artifact.js.map +0 -1
- package/dist/src/mcp/tools/history.d.ts.map +0 -1
- package/dist/src/mcp/tools/history.js +0 -29
- package/dist/src/mcp/tools/history.js.map +0 -1
- package/dist/src/mcp/tools/lsp.d.ts +0 -13
- package/dist/src/mcp/tools/lsp.d.ts.map +0 -1
- package/dist/src/mcp/tools/lsp.js +0 -225
- package/dist/src/mcp/tools/lsp.js.map +0 -1
- package/dist/src/mcp/tools/plan.d.ts.map +0 -1
- package/dist/src/mcp/tools/plan.js +0 -317
- package/dist/src/mcp/tools/plan.js.map +0 -1
- package/dist/src/mcp/tools/task.d.ts.map +0 -1
- package/dist/src/mcp/tools/task.js +0 -252
- package/dist/src/mcp/tools/task.js.map +0 -1
- package/dist/src/shared/invocations.d.ts +0 -74
- package/dist/src/shared/invocations.d.ts.map +0 -1
- package/dist/src/shared/invocations.js +0 -247
- package/dist/src/shared/invocations.js.map +0 -1
- package/dist/src/shared/json-store.d.ts.map +0 -1
- package/dist/src/shared/json-store.js.map +0 -1
- package/dist/src/shared/mcp-utils.d.ts.map +0 -1
- package/dist/src/shared/mcp-utils.js.map +0 -1
- package/dist/src/shared/package-root.d.ts +0 -6
- package/dist/src/shared/package-root.d.ts.map +0 -1
- package/dist/src/shared/package-root.js +0 -19
- package/dist/src/shared/package-root.js.map +0 -1
- package/dist/src/shared/paths.d.ts.map +0 -1
- package/dist/src/shared/paths.js +0 -81
- package/dist/src/shared/paths.js.map +0 -1
- package/dist/src/shared/tool-log.d.ts +0 -8
- package/dist/src/shared/tool-log.d.ts.map +0 -1
- package/dist/src/shared/tool-log.js +0 -22
- package/dist/src/shared/tool-log.js.map +0 -1
- package/dist/src/types/agent-config.d.ts +0 -22
- package/dist/src/types/agent-config.d.ts.map +0 -1
- package/dist/src/types/agent-config.js +0 -2
- package/dist/src/types/agent-config.js.map +0 -1
- package/dist/src/types/index.d.ts +0 -2
- package/dist/src/types/index.d.ts.map +0 -1
- package/dist/src/types/index.js +0 -2
- package/dist/src/types/index.js.map +0 -1
- package/dist/src/types/state.d.ts.map +0 -1
- package/dist/src/types/state.js.map +0 -1
- package/docs/consuming/codex-lead-merge.md +0 -106
- package/docs/contract/harness-io.md +0 -333
- package/docs/plugin-guide.md +0 -355
- package/docs/plugin-template/claude/.github/workflows/build.yml +0 -60
- package/docs/plugin-template/claude/README.md +0 -110
- package/docs/plugin-template/claude/package.json +0 -16
- package/docs/plugin-template/codex/.github/workflows/build.yml +0 -51
- package/docs/plugin-template/codex/README.md +0 -147
- package/docs/plugin-template/codex/install/install.sh +0 -60
- package/docs/plugin-template/codex/package.json +0 -17
- package/docs/plugin-template/opencode/.github/workflows/build.yml +0 -61
- package/docs/plugin-template/opencode/README.md +0 -121
- package/docs/plugin-template/opencode/package.json +0 -25
- package/docs/plugin-template/opencode/src/plugin.ts +0 -6
- /package/dist/{src/mcp/tools → mcp/handlers}/artifact.d.ts +0 -0
- /package/dist/{src/mcp/tools → mcp/handlers}/history.d.ts +0 -0
- /package/dist/{src/mcp/tools → mcp/handlers}/plan.d.ts +0 -0
- /package/dist/{src/mcp/tools → mcp/handlers}/task.d.ts +0 -0
- /package/dist/{src/shared → shared}/json-store.d.ts +0 -0
- /package/dist/{src/shared → shared}/mcp-utils.d.ts +0 -0
- /package/dist/{src/shared → shared}/mcp-utils.js +0 -0
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import * as z from "zod/v3";
|
|
2
|
+
export declare const taskAddTool: {
|
|
3
|
+
group: string;
|
|
4
|
+
name: string;
|
|
5
|
+
description: string;
|
|
6
|
+
inputSchema: {
|
|
7
|
+
title: z.ZodString;
|
|
8
|
+
context: z.ZodString;
|
|
9
|
+
acceptance: z.ZodString;
|
|
10
|
+
approach: z.ZodOptional<z.ZodString>;
|
|
11
|
+
risk: z.ZodOptional<z.ZodString>;
|
|
12
|
+
plan_issue: z.ZodOptional<z.ZodNumber>;
|
|
13
|
+
deps: z.ZodOptional<z.ZodArray<z.ZodNumber, "many">>;
|
|
14
|
+
owner: z.ZodObject<{
|
|
15
|
+
role: z.ZodString;
|
|
16
|
+
agent_id: z.ZodOptional<z.ZodString>;
|
|
17
|
+
resume_tier: z.ZodOptional<z.ZodEnum<["persistent", "bounded", "ephemeral"]>>;
|
|
18
|
+
}, "strip", z.ZodTypeAny, {
|
|
19
|
+
role: string;
|
|
20
|
+
agent_id?: string | undefined;
|
|
21
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | undefined;
|
|
22
|
+
}, {
|
|
23
|
+
role: string;
|
|
24
|
+
agent_id?: string | undefined;
|
|
25
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | undefined;
|
|
26
|
+
}>;
|
|
27
|
+
goal: z.ZodOptional<z.ZodString>;
|
|
28
|
+
decisions: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
export declare const taskListTool: {
|
|
32
|
+
group: string;
|
|
33
|
+
name: string;
|
|
34
|
+
description: string;
|
|
35
|
+
inputSchema: {
|
|
36
|
+
include_completed: z.ZodOptional<z.ZodBoolean>;
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
export declare const taskUpdateTool: {
|
|
40
|
+
group: string;
|
|
41
|
+
name: string;
|
|
42
|
+
description: string;
|
|
43
|
+
inputSchema: {
|
|
44
|
+
id: z.ZodNumber;
|
|
45
|
+
status: z.ZodOptional<z.ZodEnum<["pending", "in_progress", "completed"]>>;
|
|
46
|
+
owner: z.ZodOptional<z.ZodObject<{
|
|
47
|
+
agent_id: z.ZodOptional<z.ZodNullable<z.ZodString>>;
|
|
48
|
+
resume_tier: z.ZodOptional<z.ZodNullable<z.ZodEnum<["persistent", "bounded", "ephemeral"]>>>;
|
|
49
|
+
}, "strip", z.ZodTypeAny, {
|
|
50
|
+
agent_id?: string | null | undefined;
|
|
51
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | null | undefined;
|
|
52
|
+
}, {
|
|
53
|
+
agent_id?: string | null | undefined;
|
|
54
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | null | undefined;
|
|
55
|
+
}>>;
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
export declare const taskCloseTool: {
|
|
59
|
+
group: string;
|
|
60
|
+
name: string;
|
|
61
|
+
description: string;
|
|
62
|
+
inputSchema: {};
|
|
63
|
+
};
|
|
64
|
+
export declare const taskResumeTool: {
|
|
65
|
+
group: string;
|
|
66
|
+
name: string;
|
|
67
|
+
description: string;
|
|
68
|
+
inputSchema: {
|
|
69
|
+
id: z.ZodNumber;
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
export declare const taskToolDefinitions: readonly [{
|
|
73
|
+
group: string;
|
|
74
|
+
name: string;
|
|
75
|
+
description: string;
|
|
76
|
+
inputSchema: {
|
|
77
|
+
title: z.ZodString;
|
|
78
|
+
context: z.ZodString;
|
|
79
|
+
acceptance: z.ZodString;
|
|
80
|
+
approach: z.ZodOptional<z.ZodString>;
|
|
81
|
+
risk: z.ZodOptional<z.ZodString>;
|
|
82
|
+
plan_issue: z.ZodOptional<z.ZodNumber>;
|
|
83
|
+
deps: z.ZodOptional<z.ZodArray<z.ZodNumber, "many">>;
|
|
84
|
+
owner: z.ZodObject<{
|
|
85
|
+
role: z.ZodString;
|
|
86
|
+
agent_id: z.ZodOptional<z.ZodString>;
|
|
87
|
+
resume_tier: z.ZodOptional<z.ZodEnum<["persistent", "bounded", "ephemeral"]>>;
|
|
88
|
+
}, "strip", z.ZodTypeAny, {
|
|
89
|
+
role: string;
|
|
90
|
+
agent_id?: string | undefined;
|
|
91
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | undefined;
|
|
92
|
+
}, {
|
|
93
|
+
role: string;
|
|
94
|
+
agent_id?: string | undefined;
|
|
95
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | undefined;
|
|
96
|
+
}>;
|
|
97
|
+
goal: z.ZodOptional<z.ZodString>;
|
|
98
|
+
decisions: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
|
|
99
|
+
};
|
|
100
|
+
}, {
|
|
101
|
+
group: string;
|
|
102
|
+
name: string;
|
|
103
|
+
description: string;
|
|
104
|
+
inputSchema: {
|
|
105
|
+
include_completed: z.ZodOptional<z.ZodBoolean>;
|
|
106
|
+
};
|
|
107
|
+
}, {
|
|
108
|
+
group: string;
|
|
109
|
+
name: string;
|
|
110
|
+
description: string;
|
|
111
|
+
inputSchema: {
|
|
112
|
+
id: z.ZodNumber;
|
|
113
|
+
status: z.ZodOptional<z.ZodEnum<["pending", "in_progress", "completed"]>>;
|
|
114
|
+
owner: z.ZodOptional<z.ZodObject<{
|
|
115
|
+
agent_id: z.ZodOptional<z.ZodNullable<z.ZodString>>;
|
|
116
|
+
resume_tier: z.ZodOptional<z.ZodNullable<z.ZodEnum<["persistent", "bounded", "ephemeral"]>>>;
|
|
117
|
+
}, "strip", z.ZodTypeAny, {
|
|
118
|
+
agent_id?: string | null | undefined;
|
|
119
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | null | undefined;
|
|
120
|
+
}, {
|
|
121
|
+
agent_id?: string | null | undefined;
|
|
122
|
+
resume_tier?: "persistent" | "bounded" | "ephemeral" | null | undefined;
|
|
123
|
+
}>>;
|
|
124
|
+
};
|
|
125
|
+
}, {
|
|
126
|
+
group: string;
|
|
127
|
+
name: string;
|
|
128
|
+
description: string;
|
|
129
|
+
inputSchema: {};
|
|
130
|
+
}, {
|
|
131
|
+
group: string;
|
|
132
|
+
name: string;
|
|
133
|
+
description: string;
|
|
134
|
+
inputSchema: {
|
|
135
|
+
id: z.ZodNumber;
|
|
136
|
+
};
|
|
137
|
+
}];
|
|
138
|
+
//# sourceMappingURL=task.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task.d.ts","sourceRoot":"","sources":["../../../src/mcp/definitions/task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAS5B,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyBI,CAAC;AAE7B,eAAO,MAAM,YAAY;;;;;;;CAUG,CAAC;AAE7B,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;CAcC,CAAC;AAE7B,eAAO,MAAM,aAAa;;;;;CAME,CAAC;AAE7B,eAAO,MAAM,cAAc;;;;;;;CAOC,CAAC;AAE7B,eAAO,MAAM,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAMtB,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import * as z from "zod/v3";
|
|
2
|
+
import { ResumeTierSchema, TaskOwnerSchema } from "../../types/state.js";
|
|
3
|
+
const TaskOwnerUpdateSchema = z.object({
|
|
4
|
+
agent_id: z.string().nullable().optional(),
|
|
5
|
+
resume_tier: ResumeTierSchema.nullable().optional(),
|
|
6
|
+
});
|
|
7
|
+
export const taskAddTool = {
|
|
8
|
+
group: "task",
|
|
9
|
+
name: "nx_task_add",
|
|
10
|
+
description: "Add a new task to tasks.json",
|
|
11
|
+
inputSchema: {
|
|
12
|
+
title: z.string().describe("Task title"),
|
|
13
|
+
context: z.string().describe("Task context"),
|
|
14
|
+
acceptance: z.string().describe("Definition of done. Required"),
|
|
15
|
+
approach: z.string().optional().describe("Implementation approach"),
|
|
16
|
+
risk: z.string().optional().describe("Known risk"),
|
|
17
|
+
plan_issue: z.number().optional().describe("Related plan issue ID"),
|
|
18
|
+
deps: z
|
|
19
|
+
.array(z.number())
|
|
20
|
+
.optional()
|
|
21
|
+
.describe("List of dependency task IDs"),
|
|
22
|
+
owner: TaskOwnerSchema.describe("Owner metadata. role is required"),
|
|
23
|
+
goal: z
|
|
24
|
+
.string()
|
|
25
|
+
.optional()
|
|
26
|
+
.describe("Replace the top-level goal in tasks.json"),
|
|
27
|
+
decisions: z
|
|
28
|
+
.array(z.string())
|
|
29
|
+
.optional()
|
|
30
|
+
.describe("Append entries to the top-level decisions list in tasks.json"),
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
export const taskListTool = {
|
|
34
|
+
group: "task",
|
|
35
|
+
name: "nx_task_list",
|
|
36
|
+
description: "Read tasks.json and return the task list with a summary",
|
|
37
|
+
inputSchema: {
|
|
38
|
+
include_completed: z
|
|
39
|
+
.boolean()
|
|
40
|
+
.optional()
|
|
41
|
+
.describe("Whether to include completed tasks. Defaults to true"),
|
|
42
|
+
},
|
|
43
|
+
};
|
|
44
|
+
export const taskUpdateTool = {
|
|
45
|
+
group: "task",
|
|
46
|
+
name: "nx_task_update",
|
|
47
|
+
description: "Partially update task status or owner metadata",
|
|
48
|
+
inputSchema: {
|
|
49
|
+
id: z.number().describe("Task ID to update"),
|
|
50
|
+
status: z
|
|
51
|
+
.enum(["pending", "in_progress", "completed"])
|
|
52
|
+
.optional()
|
|
53
|
+
.describe("New status"),
|
|
54
|
+
owner: TaskOwnerUpdateSchema.optional().describe("Partial owner update. Only agent_id and resume_tier are allowed; role cannot be changed"),
|
|
55
|
+
},
|
|
56
|
+
};
|
|
57
|
+
export const taskCloseTool = {
|
|
58
|
+
group: "task",
|
|
59
|
+
name: "nx_task_close",
|
|
60
|
+
description: "Close the current cycle, archive it to history.json, and remove plan.json and tasks.json",
|
|
61
|
+
inputSchema: {},
|
|
62
|
+
};
|
|
63
|
+
export const taskResumeTool = {
|
|
64
|
+
group: "task",
|
|
65
|
+
name: "nx_task_resume",
|
|
66
|
+
description: "Get task resume routing information based on owner.resume_tier",
|
|
67
|
+
inputSchema: {
|
|
68
|
+
id: z.number().describe("Task ID to look up"),
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
export const taskToolDefinitions = [
|
|
72
|
+
taskAddTool,
|
|
73
|
+
taskListTool,
|
|
74
|
+
taskUpdateTool,
|
|
75
|
+
taskCloseTool,
|
|
76
|
+
taskResumeTool,
|
|
77
|
+
];
|
|
78
|
+
//# sourceMappingURL=task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task.js","sourceRoot":"","sources":["../../../src/mcp/definitions/task.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"artifact.d.ts","sourceRoot":"","sources":["../../../src/mcp/handlers/artifact.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAczE,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CASlD;AA2BD,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAE7D"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { mkdir, realpath, writeFile } from "node:fs/promises";
|
|
2
|
+
import { dirname, join, relative } from "node:path";
|
|
3
|
+
import { textResult } from "../../shared/mcp-utils.js";
|
|
4
|
+
import { findProjectRoot, getStateRoot } from "../../shared/paths.js";
|
|
5
|
+
import { registerNxTools, } from "../../shared/register-tool.js";
|
|
6
|
+
import { artifactWriteTool } from "../definitions/artifact.js";
|
|
7
|
+
export function sanitizeName(input) {
|
|
8
|
+
const normalized = input.replace(/\\/g, "/");
|
|
9
|
+
const segments = normalized
|
|
10
|
+
.split("/")
|
|
11
|
+
.filter((s) => s && s !== "." && s !== "..");
|
|
12
|
+
if (segments.length === 0) {
|
|
13
|
+
throw new Error("Invalid filename: empty after sanitize");
|
|
14
|
+
}
|
|
15
|
+
return segments.join("/");
|
|
16
|
+
}
|
|
17
|
+
const artifactToolBindings = [
|
|
18
|
+
{
|
|
19
|
+
definition: artifactWriteTool,
|
|
20
|
+
handler: async ({ filename, content }) => {
|
|
21
|
+
const safeName = sanitizeName(filename);
|
|
22
|
+
const artifactsDir = join(getStateRoot(), "artifacts");
|
|
23
|
+
const outputPath = join(artifactsDir, safeName);
|
|
24
|
+
const outputDir = dirname(outputPath);
|
|
25
|
+
await mkdir(outputDir, { recursive: true });
|
|
26
|
+
const realOutputDir = await realpath(outputDir);
|
|
27
|
+
const realArtifactsDir = await realpath(artifactsDir);
|
|
28
|
+
if (!realOutputDir.startsWith(`${realArtifactsDir}/`) &&
|
|
29
|
+
realOutputDir !== realArtifactsDir) {
|
|
30
|
+
throw new Error("Security: resolved path escapes artifactsDir");
|
|
31
|
+
}
|
|
32
|
+
await writeFile(outputPath, content, "utf-8");
|
|
33
|
+
const projectRoot = findProjectRoot();
|
|
34
|
+
const relPath = relative(projectRoot, outputPath);
|
|
35
|
+
return textResult({ success: true, path: relPath });
|
|
36
|
+
},
|
|
37
|
+
},
|
|
38
|
+
];
|
|
39
|
+
export function registerArtifactTools(server) {
|
|
40
|
+
registerNxTools(server, artifactToolBindings);
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=artifact.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"artifact.js","sourceRoot":"","sources":["../../../src/mcp/handlers/artifact.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC9D,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAEpD,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAEL,eAAe,GAChB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAO/D,MAAM,UAAU,YAAY,CAAC,KAAa;IACxC,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC7C,MAAM,QAAQ,GAAG,UAAU;SACxB,KAAK,CAAC,GAAG,CAAC;SACV,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC;IAC/C,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;IAC5D,CAAC;IACD,OAAO,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC5B,CAAC;AAED,MAAM,oBAAoB,GAAiC;IACzD;QACE,UAAU,EAAE,iBAAiB;QAC7B,OAAO,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAqB,EAAE,EAAE;YAC1D,MAAM,QAAQ,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;YACxC,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE,WAAW,CAAC,CAAC;YACvD,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YAChD,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;YACtC,MAAM,KAAK,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YAC5C,MAAM,aAAa,GAAG,MAAM,QAAQ,CAAC,SAAS,CAAC,CAAC;YAChD,MAAM,gBAAgB,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,CAAC;YACtD,IACE,CAAC,aAAa,CAAC,UAAU,CAAC,GAAG,gBAAgB,GAAG,CAAC;gBACjD,aAAa,KAAK,gBAAgB,EAClC,CAAC;gBACD,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;YAClE,CAAC;YACD,MAAM,SAAS,CAAC,UAAU,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;YAC9C,MAAM,WAAW,GAAG,eAAe,EAAE,CAAC;YACtC,MAAM,OAAO,GAAG,QAAQ,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;YAClD,OAAO,UAAU,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;QACtD,CAAC;KACF;CACF,CAAC;AAEF,MAAM,UAAU,qBAAqB,CAAC,MAAiB;IACrD,eAAe,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAC;AAChD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"history.d.ts","sourceRoot":"","sources":["../../../src/mcp/handlers/history.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AA+CzE,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAE5D"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { join } from "node:path";
|
|
2
|
+
import { readJsonFile } from "../../shared/json-store.js";
|
|
3
|
+
import { textResult } from "../../shared/mcp-utils.js";
|
|
4
|
+
import { getNexusRoot } from "../../shared/paths.js";
|
|
5
|
+
import { registerNxTools, } from "../../shared/register-tool.js";
|
|
6
|
+
import { historySearchTool } from "../definitions/history.js";
|
|
7
|
+
const historyToolBindings = [
|
|
8
|
+
{
|
|
9
|
+
definition: historySearchTool,
|
|
10
|
+
handler: async ({ query, last_n }) => {
|
|
11
|
+
const historyPath = join(getNexusRoot(), "history.json");
|
|
12
|
+
const history = await readJsonFile(historyPath, {
|
|
13
|
+
cycles: [],
|
|
14
|
+
});
|
|
15
|
+
let cycles = Array.isArray(history.cycles) ? history.cycles : [];
|
|
16
|
+
if (query && query.length > 0) {
|
|
17
|
+
const q = query.toLowerCase();
|
|
18
|
+
cycles = cycles.filter((c) => JSON.stringify(c).toLowerCase().includes(q));
|
|
19
|
+
}
|
|
20
|
+
const total = cycles.length;
|
|
21
|
+
const reversed = [...cycles].reverse();
|
|
22
|
+
const limit = last_n ?? 10;
|
|
23
|
+
const showing = reversed.slice(0, limit);
|
|
24
|
+
return textResult({
|
|
25
|
+
total,
|
|
26
|
+
showing: showing.length,
|
|
27
|
+
cycles: showing,
|
|
28
|
+
});
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
];
|
|
32
|
+
export function registerHistoryTools(server) {
|
|
33
|
+
registerNxTools(server, historyToolBindings);
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=history.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"history.js","sourceRoot":"","sources":["../../../src/mcp/handlers/history.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAEL,eAAe,GAChB,MAAM,+BAA+B,CAAC;AAEvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAO9D,MAAM,mBAAmB,GAAiC;IACxD;QACE,UAAU,EAAE,iBAAiB;QAC7B,OAAO,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAqB,EAAE,EAAE;YACtD,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE,cAAc,CAAC,CAAC;YACzD,MAAM,OAAO,GAAG,MAAM,YAAY,CAAc,WAAW,EAAE;gBAC3D,MAAM,EAAE,EAAE;aACX,CAAC,CAAC;YACH,IAAI,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;YAEjE,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC9B,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;gBAC9B,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAC3B,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAC5C,CAAC;YACJ,CAAC;YAED,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC;YAC5B,MAAM,QAAQ,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,OAAO,EAAE,CAAC;YACvC,MAAM,KAAK,GAAG,MAAM,IAAI,EAAE,CAAC;YAC3B,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;YAEzC,OAAO,UAAU,CAAC;gBAChB,KAAK;gBACL,OAAO,EAAE,OAAO,CAAC,MAAM;gBACvB,MAAM,EAAE,OAAO;aAChB,CAAC,CAAC;QACL,CAAC;KACF;CACF,CAAC;AAEF,MAAM,UAAU,oBAAoB,CAAC,MAAiB;IACpD,eAAe,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;AAC/C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plan.d.ts","sourceRoot":"","sources":["../../../src/mcp/handlers/plan.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AA2bzE,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAEzD"}
|
|
@@ -0,0 +1,324 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { readJsonFile, updateJsonFileLocked, writeJsonFile, } from "../../shared/json-store.js";
|
|
4
|
+
import { textResult } from "../../shared/mcp-utils.js";
|
|
5
|
+
import { ensureDir, getCurrentBranch, getNexusRoot, getStateRoot, } from "../../shared/paths.js";
|
|
6
|
+
import { registerNxTools, } from "../../shared/register-tool.js";
|
|
7
|
+
import { planAnalysisAddTool, planDecideTool, planResumeTool, planStartTool, planStatusTool, planUpdateTool, } from "../definitions/plan.js";
|
|
8
|
+
function planPath() {
|
|
9
|
+
return join(getStateRoot(), "plan.json");
|
|
10
|
+
}
|
|
11
|
+
function historyPath() {
|
|
12
|
+
return join(getNexusRoot(), "history.json");
|
|
13
|
+
}
|
|
14
|
+
async function nextPlanId() {
|
|
15
|
+
const history = await readJsonFile(historyPath(), {
|
|
16
|
+
cycles: [],
|
|
17
|
+
});
|
|
18
|
+
let maxId = 0;
|
|
19
|
+
for (const cycle of history.cycles) {
|
|
20
|
+
if (cycle.plan && typeof cycle.plan.id === "number") {
|
|
21
|
+
maxId = Math.max(maxId, cycle.plan.id);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
return maxId + 1;
|
|
25
|
+
}
|
|
26
|
+
const planToolBindings = [
|
|
27
|
+
{
|
|
28
|
+
definition: planStartTool,
|
|
29
|
+
handler: async ({ topic, issues, research_summary }) => {
|
|
30
|
+
if (!research_summary || research_summary.trim() === "") {
|
|
31
|
+
throw new Error("research_summary is required — complete research before starting a plan");
|
|
32
|
+
}
|
|
33
|
+
const hPath = historyPath();
|
|
34
|
+
const pPath = planPath();
|
|
35
|
+
const existingRaw = await readJsonFile(pPath, null);
|
|
36
|
+
let previousArchived = false;
|
|
37
|
+
if (existingRaw) {
|
|
38
|
+
try {
|
|
39
|
+
ensureDir(getNexusRoot());
|
|
40
|
+
await updateJsonFileLocked(hPath, { cycles: [] }, (history) => ({
|
|
41
|
+
...history,
|
|
42
|
+
cycles: [
|
|
43
|
+
...(Array.isArray(history.cycles) ? history.cycles : []),
|
|
44
|
+
{
|
|
45
|
+
completed_at: new Date().toISOString(),
|
|
46
|
+
branch: getCurrentBranch(),
|
|
47
|
+
plan: existingRaw,
|
|
48
|
+
tasks: [],
|
|
49
|
+
},
|
|
50
|
+
],
|
|
51
|
+
}));
|
|
52
|
+
}
|
|
53
|
+
catch { }
|
|
54
|
+
try {
|
|
55
|
+
fs.unlinkSync(pPath);
|
|
56
|
+
}
|
|
57
|
+
catch { }
|
|
58
|
+
previousArchived = true;
|
|
59
|
+
}
|
|
60
|
+
const planId = await nextPlanId();
|
|
61
|
+
const now = new Date().toISOString();
|
|
62
|
+
const newPlan = {
|
|
63
|
+
id: planId,
|
|
64
|
+
topic,
|
|
65
|
+
issues: issues.map((title, index) => ({
|
|
66
|
+
id: index + 1,
|
|
67
|
+
title,
|
|
68
|
+
status: "pending",
|
|
69
|
+
})),
|
|
70
|
+
research_summary,
|
|
71
|
+
created_at: now,
|
|
72
|
+
};
|
|
73
|
+
ensureDir(getStateRoot());
|
|
74
|
+
await writeJsonFile(pPath, newPlan);
|
|
75
|
+
return textResult({
|
|
76
|
+
created: true,
|
|
77
|
+
plan_id: planId,
|
|
78
|
+
topic,
|
|
79
|
+
issueCount: issues.length,
|
|
80
|
+
previousArchived,
|
|
81
|
+
});
|
|
82
|
+
},
|
|
83
|
+
},
|
|
84
|
+
{
|
|
85
|
+
definition: planStatusTool,
|
|
86
|
+
handler: async () => {
|
|
87
|
+
const plan = await readJsonFile(planPath(), null);
|
|
88
|
+
if (!plan) {
|
|
89
|
+
return textResult({ exists: false });
|
|
90
|
+
}
|
|
91
|
+
const total = plan.issues.length;
|
|
92
|
+
const pending = plan.issues.filter((issue) => issue.status === "pending").length;
|
|
93
|
+
const decided = plan.issues.filter((issue) => issue.status === "decided").length;
|
|
94
|
+
return textResult({
|
|
95
|
+
exists: true,
|
|
96
|
+
id: plan.id,
|
|
97
|
+
topic: plan.topic,
|
|
98
|
+
summary: { total, pending, decided },
|
|
99
|
+
issues: plan.issues.map((issue) => ({
|
|
100
|
+
id: issue.id,
|
|
101
|
+
title: issue.title,
|
|
102
|
+
status: issue.status,
|
|
103
|
+
...(issue.decision !== undefined ? { decision: issue.decision } : {}),
|
|
104
|
+
})),
|
|
105
|
+
});
|
|
106
|
+
},
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
definition: planUpdateTool,
|
|
110
|
+
handler: async ({ action, issue_id, title }) => {
|
|
111
|
+
const pPath = planPath();
|
|
112
|
+
let result = {};
|
|
113
|
+
await updateJsonFileLocked(pPath, null, (raw) => {
|
|
114
|
+
if (!raw) {
|
|
115
|
+
throw new Error("No active plan");
|
|
116
|
+
}
|
|
117
|
+
if (action === "add") {
|
|
118
|
+
if (!title) {
|
|
119
|
+
throw new Error("title is required for add");
|
|
120
|
+
}
|
|
121
|
+
const maxId = raw.issues.reduce((m, issue) => Math.max(m, issue.id), 0);
|
|
122
|
+
const newIssue = {
|
|
123
|
+
id: maxId + 1,
|
|
124
|
+
title,
|
|
125
|
+
status: "pending",
|
|
126
|
+
};
|
|
127
|
+
raw.issues.push(newIssue);
|
|
128
|
+
result = {
|
|
129
|
+
updated: true,
|
|
130
|
+
action,
|
|
131
|
+
issue_id: newIssue.id,
|
|
132
|
+
issue: newIssue,
|
|
133
|
+
};
|
|
134
|
+
return raw;
|
|
135
|
+
}
|
|
136
|
+
if (action === "remove") {
|
|
137
|
+
if (issue_id === undefined) {
|
|
138
|
+
throw new Error("issue_id is required for remove");
|
|
139
|
+
}
|
|
140
|
+
const index = raw.issues.findIndex((issue) => issue.id === issue_id);
|
|
141
|
+
if (index === -1) {
|
|
142
|
+
throw new Error(`Issue ${issue_id} not found`);
|
|
143
|
+
}
|
|
144
|
+
const [removed] = raw.issues.splice(index, 1);
|
|
145
|
+
result = { updated: true, action, issue_id: removed.id };
|
|
146
|
+
return raw;
|
|
147
|
+
}
|
|
148
|
+
if (action === "modify") {
|
|
149
|
+
if (issue_id === undefined || !title) {
|
|
150
|
+
throw new Error("issue_id and title are required for modify");
|
|
151
|
+
}
|
|
152
|
+
const issue = raw.issues.find((candidate) => candidate.id === issue_id);
|
|
153
|
+
if (!issue) {
|
|
154
|
+
throw new Error(`Issue ${issue_id} not found`);
|
|
155
|
+
}
|
|
156
|
+
issue.title = title;
|
|
157
|
+
result = {
|
|
158
|
+
updated: true,
|
|
159
|
+
action,
|
|
160
|
+
issue_id: issue.id,
|
|
161
|
+
title: issue.title,
|
|
162
|
+
};
|
|
163
|
+
return raw;
|
|
164
|
+
}
|
|
165
|
+
if (issue_id === undefined) {
|
|
166
|
+
throw new Error("issue_id is required for reopen");
|
|
167
|
+
}
|
|
168
|
+
const issue = raw.issues.find((candidate) => candidate.id === issue_id);
|
|
169
|
+
if (!issue) {
|
|
170
|
+
throw new Error(`Issue ${issue_id} not found`);
|
|
171
|
+
}
|
|
172
|
+
issue.status = "pending";
|
|
173
|
+
delete issue.decision;
|
|
174
|
+
result = {
|
|
175
|
+
updated: true,
|
|
176
|
+
action,
|
|
177
|
+
issue_id: issue.id,
|
|
178
|
+
status: issue.status,
|
|
179
|
+
};
|
|
180
|
+
return raw;
|
|
181
|
+
});
|
|
182
|
+
return textResult(result);
|
|
183
|
+
},
|
|
184
|
+
},
|
|
185
|
+
{
|
|
186
|
+
definition: planDecideTool,
|
|
187
|
+
handler: async ({ issue_id, decision, how_agents, how_summary, how_agent_ids, }) => {
|
|
188
|
+
const pPath = planPath();
|
|
189
|
+
let responsePayload = {};
|
|
190
|
+
await updateJsonFileLocked(pPath, null, (raw) => {
|
|
191
|
+
if (!raw) {
|
|
192
|
+
throw new Error("No active plan");
|
|
193
|
+
}
|
|
194
|
+
const issue = raw.issues.find((candidate) => candidate.id === issue_id);
|
|
195
|
+
if (!issue) {
|
|
196
|
+
throw new Error(`Issue ${issue_id} not found`);
|
|
197
|
+
}
|
|
198
|
+
if (issue.status === "decided") {
|
|
199
|
+
throw new Error("이미 결정된 issue입니다. 재결정은 reopen 후 진행하세요.");
|
|
200
|
+
}
|
|
201
|
+
issue.status = "decided";
|
|
202
|
+
issue.decision = decision;
|
|
203
|
+
if (how_agents && how_agents.length > 0) {
|
|
204
|
+
const now = new Date().toISOString();
|
|
205
|
+
if (!issue.analysis) {
|
|
206
|
+
issue.analysis = [];
|
|
207
|
+
}
|
|
208
|
+
for (const agentName of how_agents) {
|
|
209
|
+
const entry = {
|
|
210
|
+
role: agentName,
|
|
211
|
+
summary: how_summary?.[agentName] ?? "",
|
|
212
|
+
recorded_at: now,
|
|
213
|
+
};
|
|
214
|
+
if (how_agent_ids?.[agentName]) {
|
|
215
|
+
entry.agent_id = how_agent_ids[agentName];
|
|
216
|
+
}
|
|
217
|
+
issue.analysis.push(entry);
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
const allComplete = raw.issues.every((candidate) => candidate.status === "decided");
|
|
221
|
+
const remaining = raw.issues.filter((candidate) => candidate.status !== "decided");
|
|
222
|
+
responsePayload = {
|
|
223
|
+
decided: true,
|
|
224
|
+
issue: {
|
|
225
|
+
id: issue.id,
|
|
226
|
+
title: issue.title,
|
|
227
|
+
status: issue.status,
|
|
228
|
+
decision: issue.decision,
|
|
229
|
+
},
|
|
230
|
+
allComplete,
|
|
231
|
+
remaining: remaining.map((candidate) => ({
|
|
232
|
+
id: candidate.id,
|
|
233
|
+
title: candidate.title,
|
|
234
|
+
status: candidate.status,
|
|
235
|
+
})),
|
|
236
|
+
...(allComplete
|
|
237
|
+
? {
|
|
238
|
+
message: "모든 안건이 결정되었습니다. tasks.json으로 태스크를 생성하세요.",
|
|
239
|
+
}
|
|
240
|
+
: {}),
|
|
241
|
+
};
|
|
242
|
+
return raw;
|
|
243
|
+
});
|
|
244
|
+
return textResult(responsePayload);
|
|
245
|
+
},
|
|
246
|
+
},
|
|
247
|
+
{
|
|
248
|
+
definition: planResumeTool,
|
|
249
|
+
handler: async ({ role }) => {
|
|
250
|
+
const plan = await readJsonFile(planPath(), null);
|
|
251
|
+
if (!plan) {
|
|
252
|
+
return textResult({
|
|
253
|
+
role,
|
|
254
|
+
resumable: false,
|
|
255
|
+
agent_id: null,
|
|
256
|
+
resume_tier: null,
|
|
257
|
+
issue_id: null,
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
let latestEntry = null;
|
|
261
|
+
let latestIssueId = null;
|
|
262
|
+
let latestTime = "";
|
|
263
|
+
for (const issue of plan.issues) {
|
|
264
|
+
if (!issue.analysis) {
|
|
265
|
+
continue;
|
|
266
|
+
}
|
|
267
|
+
for (const entry of issue.analysis) {
|
|
268
|
+
if (entry.role === role && entry.recorded_at > latestTime) {
|
|
269
|
+
latestTime = entry.recorded_at;
|
|
270
|
+
latestEntry = entry;
|
|
271
|
+
latestIssueId = issue.id;
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
return textResult({
|
|
276
|
+
role,
|
|
277
|
+
resumable: latestEntry !== null,
|
|
278
|
+
agent_id: latestEntry?.agent_id ?? null,
|
|
279
|
+
resume_tier: null,
|
|
280
|
+
issue_id: latestIssueId,
|
|
281
|
+
});
|
|
282
|
+
},
|
|
283
|
+
},
|
|
284
|
+
{
|
|
285
|
+
definition: planAnalysisAddTool,
|
|
286
|
+
handler: async ({ issue_id, role, agent_id, summary, }) => {
|
|
287
|
+
const pPath = planPath();
|
|
288
|
+
let responsePayload = {};
|
|
289
|
+
await updateJsonFileLocked(pPath, null, (raw) => {
|
|
290
|
+
if (!raw) {
|
|
291
|
+
throw new Error("No active plan");
|
|
292
|
+
}
|
|
293
|
+
const issue = raw.issues.find((candidate) => candidate.id === issue_id);
|
|
294
|
+
if (!issue) {
|
|
295
|
+
throw new Error(`Issue ${issue_id} not found`);
|
|
296
|
+
}
|
|
297
|
+
if (!issue.analysis) {
|
|
298
|
+
issue.analysis = [];
|
|
299
|
+
}
|
|
300
|
+
const recorded_at = new Date().toISOString();
|
|
301
|
+
const entry = {
|
|
302
|
+
role,
|
|
303
|
+
summary,
|
|
304
|
+
recorded_at,
|
|
305
|
+
...(agent_id !== undefined ? { agent_id } : {}),
|
|
306
|
+
};
|
|
307
|
+
issue.analysis.push(entry);
|
|
308
|
+
responsePayload = {
|
|
309
|
+
added: true,
|
|
310
|
+
issue_id,
|
|
311
|
+
role,
|
|
312
|
+
recorded_at,
|
|
313
|
+
total_entries: issue.analysis.length,
|
|
314
|
+
};
|
|
315
|
+
return raw;
|
|
316
|
+
});
|
|
317
|
+
return textResult(responsePayload);
|
|
318
|
+
},
|
|
319
|
+
},
|
|
320
|
+
];
|
|
321
|
+
export function registerPlanTools(server) {
|
|
322
|
+
registerNxTools(server, planToolBindings);
|
|
323
|
+
}
|
|
324
|
+
//# sourceMappingURL=plan.js.map
|