@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.
Files changed (413) hide show
  1. package/README.md +101 -67
  2. package/dist/cli/sync.d.ts +3 -0
  3. package/dist/cli/sync.d.ts.map +1 -0
  4. package/dist/cli/sync.js +59 -0
  5. package/dist/cli/sync.js.map +1 -0
  6. package/dist/generate/index.d.ts +3 -0
  7. package/dist/generate/index.d.ts.map +1 -0
  8. package/dist/generate/index.js +2 -0
  9. package/dist/generate/index.js.map +1 -0
  10. package/dist/generate/load-data.d.ts +8 -0
  11. package/dist/generate/load-data.d.ts.map +1 -0
  12. package/dist/generate/load-data.js +45 -0
  13. package/dist/generate/load-data.js.map +1 -0
  14. package/dist/generate/load-spec.d.ts +3 -0
  15. package/dist/generate/load-spec.d.ts.map +1 -0
  16. package/dist/generate/load-spec.js +48 -0
  17. package/dist/generate/load-spec.js.map +1 -0
  18. package/dist/generate/macros/expand.d.ts +3 -0
  19. package/dist/generate/macros/expand.d.ts.map +1 -0
  20. package/dist/generate/macros/expand.js +48 -0
  21. package/dist/generate/macros/expand.js.map +1 -0
  22. package/dist/generate/macros/parse.d.ts +4 -0
  23. package/dist/generate/macros/parse.d.ts.map +1 -0
  24. package/dist/generate/macros/parse.js +142 -0
  25. package/dist/generate/macros/parse.js.map +1 -0
  26. package/dist/generate/macros/validate.d.ts +3 -0
  27. package/dist/generate/macros/validate.d.ts.map +1 -0
  28. package/dist/generate/macros/validate.js +23 -0
  29. package/dist/generate/macros/validate.js.map +1 -0
  30. package/dist/generate/renderers/claude.d.ts +3 -0
  31. package/dist/generate/renderers/claude.d.ts.map +1 -0
  32. package/dist/generate/renderers/claude.js +48 -0
  33. package/dist/generate/renderers/claude.js.map +1 -0
  34. package/dist/generate/renderers/codex.d.ts +3 -0
  35. package/dist/generate/renderers/codex.d.ts.map +1 -0
  36. package/dist/generate/renderers/codex.js +79 -0
  37. package/dist/generate/renderers/codex.js.map +1 -0
  38. package/dist/generate/renderers/markdown.d.ts +2 -0
  39. package/dist/generate/renderers/markdown.d.ts.map +1 -0
  40. package/dist/generate/renderers/markdown.js +6 -0
  41. package/dist/generate/renderers/markdown.js.map +1 -0
  42. package/dist/generate/renderers/opencode.d.ts +3 -0
  43. package/dist/generate/renderers/opencode.d.ts.map +1 -0
  44. package/dist/generate/renderers/opencode.js +69 -0
  45. package/dist/generate/renderers/opencode.js.map +1 -0
  46. package/dist/generate/sync.d.ts +4 -0
  47. package/dist/generate/sync.d.ts.map +1 -0
  48. package/dist/generate/sync.js +60 -0
  49. package/dist/generate/sync.js.map +1 -0
  50. package/dist/generate/types.d.ts +74 -0
  51. package/dist/generate/types.d.ts.map +1 -0
  52. package/dist/generate/types.js +2 -0
  53. package/dist/generate/types.js.map +1 -0
  54. package/dist/index.d.ts +4 -0
  55. package/dist/index.d.ts.map +1 -0
  56. package/dist/index.js +2 -0
  57. package/dist/index.js.map +1 -0
  58. package/dist/mcp/definitions/artifact.d.ts +20 -0
  59. package/dist/mcp/definitions/artifact.d.ts.map +1 -0
  60. package/dist/mcp/definitions/artifact.js +14 -0
  61. package/dist/mcp/definitions/artifact.js.map +1 -0
  62. package/dist/mcp/definitions/history.d.ts +20 -0
  63. package/dist/mcp/definitions/history.d.ts.map +1 -0
  64. package/dist/mcp/definitions/history.js +18 -0
  65. package/dist/mcp/definitions/history.js.map +1 -0
  66. package/dist/mcp/definitions/index.d.ts +276 -0
  67. package/dist/mcp/definitions/index.d.ts.map +1 -0
  68. package/dist/mcp/definitions/index.js +16 -0
  69. package/dist/mcp/definitions/index.js.map +1 -0
  70. package/dist/mcp/definitions/plan.d.ts +111 -0
  71. package/dist/mcp/definitions/plan.d.ts.map +1 -0
  72. package/dist/mcp/definitions/plan.js +89 -0
  73. package/dist/mcp/definitions/plan.js.map +1 -0
  74. package/dist/mcp/definitions/task.d.ts +138 -0
  75. package/dist/mcp/definitions/task.d.ts.map +1 -0
  76. package/dist/mcp/definitions/task.js +78 -0
  77. package/dist/mcp/definitions/task.js.map +1 -0
  78. package/dist/mcp/handlers/artifact.d.ts.map +1 -0
  79. package/dist/mcp/handlers/artifact.js +42 -0
  80. package/dist/mcp/handlers/artifact.js.map +1 -0
  81. package/dist/mcp/handlers/history.d.ts.map +1 -0
  82. package/dist/mcp/handlers/history.js +35 -0
  83. package/dist/mcp/handlers/history.js.map +1 -0
  84. package/dist/mcp/handlers/plan.d.ts.map +1 -0
  85. package/dist/mcp/handlers/plan.js +324 -0
  86. package/dist/mcp/handlers/plan.js.map +1 -0
  87. package/dist/mcp/handlers/task.d.ts.map +1 -0
  88. package/dist/mcp/handlers/task.js +216 -0
  89. package/dist/mcp/handlers/task.js.map +1 -0
  90. package/dist/{src/mcp → mcp}/server.d.ts +1 -1
  91. package/dist/mcp/server.d.ts.map +1 -0
  92. package/dist/mcp/server.js +58 -0
  93. package/dist/mcp/server.js.map +1 -0
  94. package/dist/shared/json-store.d.ts.map +1 -0
  95. package/dist/{src/shared → shared}/json-store.js +5 -4
  96. package/dist/shared/json-store.js.map +1 -0
  97. package/dist/shared/mcp-utils.d.ts.map +1 -0
  98. package/dist/shared/mcp-utils.js.map +1 -0
  99. package/dist/{src/shared → shared}/paths.d.ts +0 -4
  100. package/dist/shared/paths.d.ts.map +1 -0
  101. package/dist/shared/paths.js +62 -0
  102. package/dist/shared/paths.js.map +1 -0
  103. package/dist/shared/register-tool.d.ts +20 -0
  104. package/dist/shared/register-tool.d.ts.map +1 -0
  105. package/dist/shared/register-tool.js +15 -0
  106. package/dist/shared/register-tool.js.map +1 -0
  107. package/dist/{src/types → types}/state.d.ts +65 -65
  108. package/dist/types/state.d.ts.map +1 -0
  109. package/dist/{src/types → types}/state.js +1 -1
  110. package/dist/types/state.js.map +1 -0
  111. package/harness/claude/agent-rules.yml +21 -0
  112. package/harness/claude/invocations.yml +11 -0
  113. package/harness/claude/layout.yml +3 -0
  114. package/harness/codex/agent-rules.yml +28 -0
  115. package/harness/codex/invocations.yml +13 -0
  116. package/harness/codex/layout.yml +3 -0
  117. package/harness/opencode/agent-rules.yml +18 -0
  118. package/harness/opencode/invocations.yml +12 -0
  119. package/harness/opencode/layout.yml +3 -0
  120. package/package.json +38 -43
  121. package/{assets → spec}/agents/architect/body.ko.md +92 -84
  122. package/spec/agents/architect/body.md +185 -0
  123. package/spec/agents/designer/body.ko.md +330 -0
  124. package/spec/agents/designer/body.md +330 -0
  125. package/spec/agents/engineer/body.ko.md +166 -0
  126. package/spec/agents/engineer/body.md +166 -0
  127. package/spec/agents/lead/body.ko.md +276 -0
  128. package/spec/agents/lead/body.md +276 -0
  129. package/{assets → spec}/agents/postdoc/body.ko.md +116 -46
  130. package/spec/agents/postdoc/body.md +192 -0
  131. package/{assets → spec}/agents/researcher/body.ko.md +131 -45
  132. package/spec/agents/researcher/body.md +223 -0
  133. package/spec/agents/reviewer/body.ko.md +219 -0
  134. package/spec/agents/reviewer/body.md +219 -0
  135. package/{assets → spec}/agents/strategist/body.ko.md +108 -35
  136. package/spec/agents/strategist/body.md +187 -0
  137. package/spec/agents/tester/body.ko.md +272 -0
  138. package/spec/agents/tester/body.md +272 -0
  139. package/{assets → spec}/agents/writer/body.ko.md +109 -33
  140. package/spec/agents/writer/body.md +198 -0
  141. package/spec/skills/nx-auto-plan/body.ko.md +150 -0
  142. package/spec/skills/nx-auto-plan/body.md +150 -0
  143. package/spec/skills/nx-plan/body.ko.md +159 -0
  144. package/spec/skills/nx-plan/body.md +159 -0
  145. package/spec/skills/nx-run/body.ko.md +132 -0
  146. package/spec/skills/nx-run/body.md +132 -0
  147. package/vocabulary/enums/task-register-state.yml +4 -0
  148. package/vocabulary/invocations.yml +43 -0
  149. package/assets/agents/architect/body.md +0 -177
  150. package/assets/agents/designer/body.ko.md +0 -125
  151. package/assets/agents/designer/body.md +0 -125
  152. package/assets/agents/engineer/body.ko.md +0 -106
  153. package/assets/agents/engineer/body.md +0 -106
  154. package/assets/agents/lead/body.ko.md +0 -70
  155. package/assets/agents/lead/body.md +0 -70
  156. package/assets/agents/postdoc/body.md +0 -122
  157. package/assets/agents/researcher/body.md +0 -137
  158. package/assets/agents/reviewer/body.ko.md +0 -138
  159. package/assets/agents/reviewer/body.md +0 -138
  160. package/assets/agents/strategist/body.md +0 -116
  161. package/assets/agents/tester/body.ko.md +0 -195
  162. package/assets/agents/tester/body.md +0 -195
  163. package/assets/agents/writer/body.md +0 -122
  164. package/assets/capability-matrix.yml +0 -198
  165. package/assets/hooks/agent-bootstrap/handler.test.ts +0 -368
  166. package/assets/hooks/agent-bootstrap/handler.ts +0 -119
  167. package/assets/hooks/agent-bootstrap/meta.yml +0 -10
  168. package/assets/hooks/agent-finalize/handler.test.ts +0 -368
  169. package/assets/hooks/agent-finalize/handler.ts +0 -76
  170. package/assets/hooks/agent-finalize/meta.yml +0 -10
  171. package/assets/hooks/capability-matrix.yml +0 -313
  172. package/assets/hooks/post-tool-telemetry/handler.test.ts +0 -302
  173. package/assets/hooks/post-tool-telemetry/handler.ts +0 -49
  174. package/assets/hooks/post-tool-telemetry/meta.yml +0 -11
  175. package/assets/hooks/prompt-router/handler.test.ts +0 -801
  176. package/assets/hooks/prompt-router/handler.ts +0 -272
  177. package/assets/hooks/prompt-router/meta.yml +0 -11
  178. package/assets/hooks/session-init/handler.test.ts +0 -274
  179. package/assets/hooks/session-init/handler.ts +0 -30
  180. package/assets/hooks/session-init/meta.yml +0 -9
  181. package/assets/lsp-servers.json +0 -55
  182. package/assets/schema/lsp-servers.schema.json +0 -67
  183. package/assets/skills/nx-init/body.ko.md +0 -197
  184. package/assets/skills/nx-init/body.md +0 -197
  185. package/assets/skills/nx-plan/body.ko.md +0 -361
  186. package/assets/skills/nx-plan/body.md +0 -361
  187. package/assets/skills/nx-run/body.ko.md +0 -161
  188. package/assets/skills/nx-run/body.md +0 -160
  189. package/assets/skills/nx-sync/body.ko.md +0 -92
  190. package/assets/skills/nx-sync/body.md +0 -92
  191. package/assets/tools/tool-name-map.yml +0 -353
  192. package/dist/assets/hooks/agent-bootstrap/handler.d.ts +0 -4
  193. package/dist/assets/hooks/agent-bootstrap/handler.d.ts.map +0 -1
  194. package/dist/assets/hooks/agent-bootstrap/handler.js +0 -100
  195. package/dist/assets/hooks/agent-bootstrap/handler.js.map +0 -1
  196. package/dist/assets/hooks/agent-finalize/handler.d.ts +0 -4
  197. package/dist/assets/hooks/agent-finalize/handler.d.ts.map +0 -1
  198. package/dist/assets/hooks/agent-finalize/handler.js +0 -63
  199. package/dist/assets/hooks/agent-finalize/handler.js.map +0 -1
  200. package/dist/assets/hooks/post-tool-telemetry/handler.d.ts +0 -4
  201. package/dist/assets/hooks/post-tool-telemetry/handler.d.ts.map +0 -1
  202. package/dist/assets/hooks/post-tool-telemetry/handler.js +0 -40
  203. package/dist/assets/hooks/post-tool-telemetry/handler.js.map +0 -1
  204. package/dist/assets/hooks/prompt-router/handler.d.ts +0 -4
  205. package/dist/assets/hooks/prompt-router/handler.d.ts.map +0 -1
  206. package/dist/assets/hooks/prompt-router/handler.js +0 -214
  207. package/dist/assets/hooks/prompt-router/handler.js.map +0 -1
  208. package/dist/assets/hooks/session-init/handler.d.ts +0 -4
  209. package/dist/assets/hooks/session-init/handler.d.ts.map +0 -1
  210. package/dist/assets/hooks/session-init/handler.js +0 -23
  211. package/dist/assets/hooks/session-init/handler.js.map +0 -1
  212. package/dist/claude/.claude-plugin/marketplace.json +0 -75
  213. package/dist/claude/.claude-plugin/plugin.json +0 -67
  214. package/dist/claude/agents/architect.md +0 -172
  215. package/dist/claude/agents/designer.md +0 -120
  216. package/dist/claude/agents/engineer.md +0 -98
  217. package/dist/claude/agents/lead.md +0 -59
  218. package/dist/claude/agents/postdoc.md +0 -117
  219. package/dist/claude/agents/researcher.md +0 -132
  220. package/dist/claude/agents/reviewer.md +0 -133
  221. package/dist/claude/agents/strategist.md +0 -111
  222. package/dist/claude/agents/tester.md +0 -190
  223. package/dist/claude/agents/writer.md +0 -114
  224. package/dist/claude/dist/hooks/agent-bootstrap.js +0 -121
  225. package/dist/claude/dist/hooks/agent-finalize.js +0 -180
  226. package/dist/claude/dist/hooks/prompt-router.js +0 -7336
  227. package/dist/claude/dist/hooks/session-init.js +0 -37
  228. package/dist/claude/hooks/hooks.json +0 -52
  229. package/dist/claude/settings.json +0 -3
  230. package/dist/claude/skills/nx-init/SKILL.md +0 -189
  231. package/dist/claude/skills/nx-plan/SKILL.md +0 -353
  232. package/dist/claude/skills/nx-run/SKILL.md +0 -154
  233. package/dist/claude/skills/nx-sync/SKILL.md +0 -87
  234. package/dist/codex/agents/architect.toml +0 -175
  235. package/dist/codex/agents/designer.toml +0 -123
  236. package/dist/codex/agents/engineer.toml +0 -105
  237. package/dist/codex/agents/lead.toml +0 -64
  238. package/dist/codex/agents/postdoc.toml +0 -120
  239. package/dist/codex/agents/researcher.toml +0 -136
  240. package/dist/codex/agents/reviewer.toml +0 -137
  241. package/dist/codex/agents/strategist.toml +0 -114
  242. package/dist/codex/agents/tester.toml +0 -194
  243. package/dist/codex/agents/writer.toml +0 -121
  244. package/dist/codex/dist/hooks/agent-bootstrap.js +0 -121
  245. package/dist/codex/dist/hooks/agent-finalize.js +0 -180
  246. package/dist/codex/dist/hooks/prompt-router.js +0 -7336
  247. package/dist/codex/dist/hooks/session-init.js +0 -37
  248. package/dist/codex/hooks/hooks.json +0 -28
  249. package/dist/codex/install/AGENTS.fragment.md +0 -60
  250. package/dist/codex/install/config.fragment.toml +0 -5
  251. package/dist/codex/install/install.sh +0 -60
  252. package/dist/codex/package.json +0 -20
  253. package/dist/codex/plugin/.codex-plugin/plugin.json +0 -57
  254. package/dist/codex/plugin/skills/nx-init/SKILL.md +0 -189
  255. package/dist/codex/plugin/skills/nx-plan/SKILL.md +0 -353
  256. package/dist/codex/plugin/skills/nx-run/SKILL.md +0 -154
  257. package/dist/codex/plugin/skills/nx-sync/SKILL.md +0 -87
  258. package/dist/codex/prompts/architect.md +0 -166
  259. package/dist/codex/prompts/designer.md +0 -114
  260. package/dist/codex/prompts/engineer.md +0 -97
  261. package/dist/codex/prompts/lead.md +0 -60
  262. package/dist/codex/prompts/postdoc.md +0 -111
  263. package/dist/codex/prompts/researcher.md +0 -127
  264. package/dist/codex/prompts/reviewer.md +0 -128
  265. package/dist/codex/prompts/strategist.md +0 -105
  266. package/dist/codex/prompts/tester.md +0 -185
  267. package/dist/codex/prompts/writer.md +0 -113
  268. package/dist/hooks/agent-bootstrap.js +0 -121
  269. package/dist/hooks/agent-finalize.js +0 -180
  270. package/dist/hooks/prompt-router.js +0 -7336
  271. package/dist/hooks/session-init.js +0 -37
  272. package/dist/manifests/claude-hooks.json +0 -52
  273. package/dist/manifests/codex-hooks.json +0 -28
  274. package/dist/manifests/opencode-manifest.json +0 -44
  275. package/dist/manifests/portability-report.json +0 -87
  276. package/dist/opencode/.opencode/skills/nx-init/SKILL.md +0 -189
  277. package/dist/opencode/.opencode/skills/nx-plan/SKILL.md +0 -353
  278. package/dist/opencode/.opencode/skills/nx-run/SKILL.md +0 -154
  279. package/dist/opencode/.opencode/skills/nx-sync/SKILL.md +0 -87
  280. package/dist/opencode/package.json +0 -23
  281. package/dist/opencode/src/agents/architect.ts +0 -176
  282. package/dist/opencode/src/agents/designer.ts +0 -124
  283. package/dist/opencode/src/agents/engineer.ts +0 -105
  284. package/dist/opencode/src/agents/lead.ts +0 -66
  285. package/dist/opencode/src/agents/postdoc.ts +0 -121
  286. package/dist/opencode/src/agents/researcher.ts +0 -136
  287. package/dist/opencode/src/agents/reviewer.ts +0 -137
  288. package/dist/opencode/src/agents/strategist.ts +0 -115
  289. package/dist/opencode/src/agents/tester.ts +0 -194
  290. package/dist/opencode/src/agents/writer.ts +0 -121
  291. package/dist/opencode/src/index.ts +0 -25
  292. package/dist/opencode/src/plugin.ts +0 -6
  293. package/dist/scripts/build-agents.d.ts +0 -164
  294. package/dist/scripts/build-agents.d.ts.map +0 -1
  295. package/dist/scripts/build-agents.js +0 -890
  296. package/dist/scripts/build-agents.js.map +0 -1
  297. package/dist/scripts/build-hooks.d.ts +0 -57
  298. package/dist/scripts/build-hooks.d.ts.map +0 -1
  299. package/dist/scripts/build-hooks.js +0 -555
  300. package/dist/scripts/build-hooks.js.map +0 -1
  301. package/dist/scripts/cli.d.ts +0 -54
  302. package/dist/scripts/cli.d.ts.map +0 -1
  303. package/dist/scripts/cli.js +0 -504
  304. package/dist/scripts/cli.js.map +0 -1
  305. package/dist/scripts/smoke/smoke-claude.d.ts +0 -2
  306. package/dist/scripts/smoke/smoke-claude.d.ts.map +0 -1
  307. package/dist/scripts/smoke/smoke-claude.js +0 -58
  308. package/dist/scripts/smoke/smoke-claude.js.map +0 -1
  309. package/dist/scripts/smoke/smoke-codex.d.ts +0 -2
  310. package/dist/scripts/smoke/smoke-codex.d.ts.map +0 -1
  311. package/dist/scripts/smoke/smoke-codex.js +0 -50
  312. package/dist/scripts/smoke/smoke-codex.js.map +0 -1
  313. package/dist/scripts/smoke/smoke-consumer.d.ts +0 -2
  314. package/dist/scripts/smoke/smoke-consumer.d.ts.map +0 -1
  315. package/dist/scripts/smoke/smoke-consumer.js +0 -80
  316. package/dist/scripts/smoke/smoke-consumer.js.map +0 -1
  317. package/dist/scripts/smoke/smoke-opencode.d.ts +0 -2
  318. package/dist/scripts/smoke/smoke-opencode.d.ts.map +0 -1
  319. package/dist/scripts/smoke/smoke-opencode.js +0 -99
  320. package/dist/scripts/smoke/smoke-opencode.js.map +0 -1
  321. package/dist/src/hooks/opencode-mount.d.ts +0 -35
  322. package/dist/src/hooks/opencode-mount.d.ts.map +0 -1
  323. package/dist/src/hooks/opencode-mount.js +0 -352
  324. package/dist/src/hooks/opencode-mount.js.map +0 -1
  325. package/dist/src/hooks/runtime.d.ts +0 -37
  326. package/dist/src/hooks/runtime.d.ts.map +0 -1
  327. package/dist/src/hooks/runtime.js +0 -274
  328. package/dist/src/hooks/runtime.js.map +0 -1
  329. package/dist/src/hooks/types.d.ts +0 -196
  330. package/dist/src/hooks/types.d.ts.map +0 -1
  331. package/dist/src/hooks/types.js +0 -85
  332. package/dist/src/hooks/types.js.map +0 -1
  333. package/dist/src/lsp/cache.d.ts +0 -9
  334. package/dist/src/lsp/cache.d.ts.map +0 -1
  335. package/dist/src/lsp/cache.js +0 -216
  336. package/dist/src/lsp/cache.js.map +0 -1
  337. package/dist/src/lsp/client.d.ts +0 -24
  338. package/dist/src/lsp/client.d.ts.map +0 -1
  339. package/dist/src/lsp/client.js +0 -166
  340. package/dist/src/lsp/client.js.map +0 -1
  341. package/dist/src/lsp/detect.d.ts +0 -77
  342. package/dist/src/lsp/detect.d.ts.map +0 -1
  343. package/dist/src/lsp/detect.js +0 -116
  344. package/dist/src/lsp/detect.js.map +0 -1
  345. package/dist/src/mcp/server.d.ts.map +0 -1
  346. package/dist/src/mcp/server.js +0 -34
  347. package/dist/src/mcp/server.js.map +0 -1
  348. package/dist/src/mcp/tools/artifact.d.ts.map +0 -1
  349. package/dist/src/mcp/tools/artifact.js +0 -36
  350. package/dist/src/mcp/tools/artifact.js.map +0 -1
  351. package/dist/src/mcp/tools/history.d.ts.map +0 -1
  352. package/dist/src/mcp/tools/history.js +0 -29
  353. package/dist/src/mcp/tools/history.js.map +0 -1
  354. package/dist/src/mcp/tools/lsp.d.ts +0 -13
  355. package/dist/src/mcp/tools/lsp.d.ts.map +0 -1
  356. package/dist/src/mcp/tools/lsp.js +0 -225
  357. package/dist/src/mcp/tools/lsp.js.map +0 -1
  358. package/dist/src/mcp/tools/plan.d.ts.map +0 -1
  359. package/dist/src/mcp/tools/plan.js +0 -317
  360. package/dist/src/mcp/tools/plan.js.map +0 -1
  361. package/dist/src/mcp/tools/task.d.ts.map +0 -1
  362. package/dist/src/mcp/tools/task.js +0 -252
  363. package/dist/src/mcp/tools/task.js.map +0 -1
  364. package/dist/src/shared/invocations.d.ts +0 -74
  365. package/dist/src/shared/invocations.d.ts.map +0 -1
  366. package/dist/src/shared/invocations.js +0 -247
  367. package/dist/src/shared/invocations.js.map +0 -1
  368. package/dist/src/shared/json-store.d.ts.map +0 -1
  369. package/dist/src/shared/json-store.js.map +0 -1
  370. package/dist/src/shared/mcp-utils.d.ts.map +0 -1
  371. package/dist/src/shared/mcp-utils.js.map +0 -1
  372. package/dist/src/shared/package-root.d.ts +0 -6
  373. package/dist/src/shared/package-root.d.ts.map +0 -1
  374. package/dist/src/shared/package-root.js +0 -19
  375. package/dist/src/shared/package-root.js.map +0 -1
  376. package/dist/src/shared/paths.d.ts.map +0 -1
  377. package/dist/src/shared/paths.js +0 -81
  378. package/dist/src/shared/paths.js.map +0 -1
  379. package/dist/src/shared/tool-log.d.ts +0 -8
  380. package/dist/src/shared/tool-log.d.ts.map +0 -1
  381. package/dist/src/shared/tool-log.js +0 -22
  382. package/dist/src/shared/tool-log.js.map +0 -1
  383. package/dist/src/types/agent-config.d.ts +0 -22
  384. package/dist/src/types/agent-config.d.ts.map +0 -1
  385. package/dist/src/types/agent-config.js +0 -2
  386. package/dist/src/types/agent-config.js.map +0 -1
  387. package/dist/src/types/index.d.ts +0 -2
  388. package/dist/src/types/index.d.ts.map +0 -1
  389. package/dist/src/types/index.js +0 -2
  390. package/dist/src/types/index.js.map +0 -1
  391. package/dist/src/types/state.d.ts.map +0 -1
  392. package/dist/src/types/state.js.map +0 -1
  393. package/docs/consuming/codex-lead-merge.md +0 -106
  394. package/docs/contract/harness-io.md +0 -333
  395. package/docs/plugin-guide.md +0 -355
  396. package/docs/plugin-template/claude/.github/workflows/build.yml +0 -60
  397. package/docs/plugin-template/claude/README.md +0 -110
  398. package/docs/plugin-template/claude/package.json +0 -16
  399. package/docs/plugin-template/codex/.github/workflows/build.yml +0 -51
  400. package/docs/plugin-template/codex/README.md +0 -147
  401. package/docs/plugin-template/codex/install/install.sh +0 -60
  402. package/docs/plugin-template/codex/package.json +0 -17
  403. package/docs/plugin-template/opencode/.github/workflows/build.yml +0 -61
  404. package/docs/plugin-template/opencode/README.md +0 -121
  405. package/docs/plugin-template/opencode/package.json +0 -25
  406. package/docs/plugin-template/opencode/src/plugin.ts +0 -6
  407. /package/dist/{src/mcp/tools → mcp/handlers}/artifact.d.ts +0 -0
  408. /package/dist/{src/mcp/tools → mcp/handlers}/history.d.ts +0 -0
  409. /package/dist/{src/mcp/tools → mcp/handlers}/plan.d.ts +0 -0
  410. /package/dist/{src/mcp/tools → mcp/handlers}/task.d.ts +0 -0
  411. /package/dist/{src/shared → shared}/json-store.d.ts +0 -0
  412. /package/dist/{src/shared → shared}/mcp-utils.d.ts +0 -0
  413. /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