claude-code-workflow 6.1.4 → 6.2.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 (437) hide show
  1. package/.claude/CLAUDE.md +10 -0
  2. package/.claude/agents/action-planning-agent.md +857 -778
  3. package/.claude/agents/cli-execution-agent.md +266 -269
  4. package/.claude/agents/cli-explore-agent.md +2 -2
  5. package/.claude/agents/cli-lite-planning-agent.md +142 -92
  6. package/.claude/agents/cli-planning-agent.md +4 -4
  7. package/.claude/agents/code-developer.md +7 -6
  8. package/.claude/agents/conceptual-planning-agent.md +2 -2
  9. package/.claude/agents/context-search-agent.md +31 -32
  10. package/.claude/agents/doc-generator.md +4 -4
  11. package/.claude/agents/memory-bridge.md +93 -93
  12. package/.claude/agents/test-context-search-agent.md +8 -7
  13. package/.claude/agents/test-fix-agent.md +7 -6
  14. package/.claude/commands/clean.md +516 -0
  15. package/.claude/commands/memory/compact.md +383 -0
  16. package/.claude/commands/memory/docs-full-cli.md +471 -471
  17. package/.claude/commands/memory/docs-related-cli.md +386 -386
  18. package/.claude/commands/memory/docs.md +615 -615
  19. package/.claude/commands/memory/load.md +5 -5
  20. package/.claude/commands/memory/tech-research-rules.md +310 -0
  21. package/.claude/commands/memory/update-full.md +332 -332
  22. package/.claude/commands/memory/workflow-skill-memory.md +4 -4
  23. package/.claude/commands/task/create.md +151 -151
  24. package/.claude/commands/version.md +254 -254
  25. package/.claude/commands/workflow/brainstorm/api-designer.md +587 -585
  26. package/.claude/commands/workflow/brainstorm/artifacts.md +1 -0
  27. package/.claude/commands/workflow/brainstorm/auto-parallel.md +443 -443
  28. package/.claude/commands/workflow/brainstorm/data-architect.md +220 -220
  29. package/.claude/commands/workflow/brainstorm/product-manager.md +200 -200
  30. package/.claude/commands/workflow/brainstorm/product-owner.md +200 -200
  31. package/.claude/commands/workflow/brainstorm/scrum-master.md +200 -200
  32. package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  33. package/.claude/commands/workflow/brainstorm/system-architect.md +389 -387
  34. package/.claude/commands/workflow/brainstorm/ui-designer.md +221 -221
  35. package/.claude/commands/workflow/brainstorm/ux-expert.md +221 -221
  36. package/.claude/commands/workflow/debug.md +321 -0
  37. package/.claude/commands/workflow/execute.md +13 -0
  38. package/.claude/commands/workflow/init.md +165 -164
  39. package/.claude/commands/workflow/lite-execute.md +119 -13
  40. package/.claude/commands/workflow/lite-fix.md +623 -621
  41. package/.claude/commands/workflow/lite-plan.md +610 -592
  42. package/.claude/commands/workflow/plan.md +5 -5
  43. package/.claude/commands/workflow/review-module-cycle.md +2 -0
  44. package/.claude/commands/workflow/review-session-cycle.md +2 -0
  45. package/.claude/commands/workflow/review.md +297 -291
  46. package/.claude/commands/workflow/session/complete.md +153 -500
  47. package/.claude/commands/workflow/session/list.md +95 -95
  48. package/.claude/commands/workflow/session/resume.md +60 -60
  49. package/.claude/commands/workflow/session/start.md +199 -199
  50. package/.claude/commands/workflow/tdd-plan.md +3 -3
  51. package/.claude/commands/workflow/tdd-verify.md +23 -9
  52. package/.claude/commands/workflow/test-cycle-execute.md +2 -0
  53. package/.claude/commands/workflow/test-fix-gen.md +699 -699
  54. package/.claude/commands/workflow/tools/conflict-resolution.md +104 -18
  55. package/.claude/commands/workflow/tools/context-gather.md +436 -434
  56. package/.claude/commands/workflow/tools/task-generate-agent.md +490 -291
  57. package/.claude/commands/workflow/tools/task-generate-tdd.md +18 -10
  58. package/.claude/commands/workflow/tools/test-concept-enhanced.md +2 -1
  59. package/.claude/commands/workflow/tools/test-context-gather.md +1 -0
  60. package/.claude/commands/workflow/tools/test-task-generate.md +1 -0
  61. package/.claude/commands/workflow/ui-design/import-from-code.md +9 -6
  62. package/.claude/skills/command-guide/SKILL.md +5 -5
  63. package/.claude/skills/command-guide/index/all-commands.json +1 -1
  64. package/.claude/skills/command-guide/index/by-category.json +1 -1
  65. package/.claude/skills/command-guide/index/by-use-case.json +1 -1
  66. package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +857 -778
  67. package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +266 -269
  68. package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +2 -2
  69. package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +142 -92
  70. package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +4 -4
  71. package/.claude/skills/command-guide/reference/agents/code-developer.md +7 -6
  72. package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +2 -2
  73. package/.claude/skills/command-guide/reference/agents/context-search-agent.md +31 -32
  74. package/.claude/skills/command-guide/reference/agents/doc-generator.md +4 -4
  75. package/.claude/skills/command-guide/reference/agents/memory-bridge.md +93 -93
  76. package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +8 -7
  77. package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +7 -6
  78. package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +471 -471
  79. package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +386 -386
  80. package/.claude/skills/command-guide/reference/commands/memory/docs.md +17 -16
  81. package/.claude/skills/command-guide/reference/commands/memory/load.md +5 -5
  82. package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +194 -357
  83. package/.claude/skills/command-guide/reference/commands/memory/update-full.md +332 -332
  84. package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +4 -4
  85. package/.claude/skills/command-guide/reference/commands/task/create.md +151 -151
  86. package/.claude/skills/command-guide/reference/commands/version.md +254 -254
  87. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +585 -585
  88. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +443 -443
  89. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +220 -220
  90. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +200 -200
  91. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +200 -200
  92. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +200 -200
  93. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +200 -200
  94. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +387 -387
  95. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +221 -221
  96. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +221 -221
  97. package/.claude/skills/command-guide/reference/commands/workflow/execute.md +25 -20
  98. package/.claude/skills/command-guide/reference/commands/workflow/init.md +164 -164
  99. package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +748 -686
  100. package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +664 -621
  101. package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +645 -592
  102. package/.claude/skills/command-guide/reference/commands/workflow/plan.md +5 -5
  103. package/.claude/skills/command-guide/reference/commands/workflow/review.md +25 -18
  104. package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +547 -500
  105. package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +45 -27
  106. package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +35 -19
  107. package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +90 -33
  108. package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +3 -3
  109. package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +23 -9
  110. package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +699 -699
  111. package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +103 -17
  112. package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +434 -434
  113. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +487 -291
  114. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +17 -10
  115. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +1 -1
  116. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +6 -6
  117. package/.claude/workflows/chinese-response.md +38 -0
  118. package/.claude/workflows/cli-templates/prompts/rules/rule-api.txt +122 -0
  119. package/.claude/workflows/cli-templates/prompts/rules/rule-components.txt +122 -0
  120. package/.claude/workflows/cli-templates/prompts/rules/rule-config.txt +89 -0
  121. package/.claude/workflows/cli-templates/prompts/rules/rule-core.txt +60 -0
  122. package/.claude/workflows/cli-templates/prompts/rules/rule-patterns.txt +70 -0
  123. package/.claude/workflows/cli-templates/prompts/rules/rule-testing.txt +81 -0
  124. package/.claude/workflows/cli-templates/prompts/rules/tech-rules-agent-prompt.txt +89 -0
  125. package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +131 -131
  126. package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +5 -9
  127. package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +5 -9
  128. package/.claude/workflows/cli-templates/protocols/analysis-protocol.md +112 -0
  129. package/.claude/workflows/cli-templates/protocols/write-protocol.md +201 -0
  130. package/.claude/workflows/cli-templates/schemas/conflict-resolution-schema.json +137 -0
  131. package/.claude/workflows/cli-templates/schemas/debug-log-json-schema.json +127 -0
  132. package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +25 -0
  133. package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +25 -0
  134. package/.claude/workflows/cli-tools-usage.md +526 -0
  135. package/{CLAUDE.md → .claude/workflows/coding-philosophy.md} +24 -45
  136. package/.claude/workflows/context-tools.md +84 -0
  137. package/.claude/workflows/file-modification.md +64 -0
  138. package/.claude/workflows/tool-strategy.md +216 -79
  139. package/.claude/workflows/windows-platform.md +16 -0
  140. package/.claude/workflows/workflow-architecture.md +942 -942
  141. package/.codex/AGENTS.md +63 -330
  142. package/.codex/prompts/debug.md +318 -0
  143. package/.codex/prompts/execute.md +273 -0
  144. package/.codex/prompts/lite-execute.md +164 -0
  145. package/.codex/prompts/lite-plan.md +469 -0
  146. package/.codex/prompts.zip +0 -0
  147. package/.gemini/GEMINI.md +25 -164
  148. package/.qwen/QWEN.md +0 -139
  149. package/README.md +29 -9
  150. package/ccw/README.md +30 -6
  151. package/ccw/bin/ccw-mcp.js +7 -0
  152. package/ccw/bin/ccw.js +9 -9
  153. package/ccw/package.json +65 -47
  154. package/ccw/src/.workflow/.cli-history/history.db +0 -0
  155. package/ccw/src/.workflow/.cli-history/history.db-shm +0 -0
  156. package/ccw/src/.workflow/.cli-history/history.db-wal +0 -0
  157. package/ccw/src/cli.ts +244 -0
  158. package/ccw/src/commands/cli.ts +740 -0
  159. package/ccw/src/commands/core-memory.ts +770 -0
  160. package/ccw/src/commands/hook.ts +315 -0
  161. package/ccw/src/commands/install.ts +519 -0
  162. package/ccw/src/commands/{list.js → list.ts} +1 -1
  163. package/ccw/src/commands/memory.ts +1090 -0
  164. package/ccw/src/commands/{serve.js → serve.ts} +14 -5
  165. package/ccw/src/commands/session-path-resolver.ts +372 -0
  166. package/ccw/src/commands/session.ts +1141 -0
  167. package/ccw/src/commands/{stop.js → stop.ts} +16 -6
  168. package/ccw/src/commands/tool.ts +201 -0
  169. package/ccw/src/commands/{uninstall.js → uninstall.ts} +89 -40
  170. package/ccw/src/commands/{upgrade.js → upgrade.ts} +68 -23
  171. package/ccw/src/commands/{view.js → view.ts} +22 -8
  172. package/ccw/src/config/storage-paths.ts +670 -0
  173. package/ccw/src/core/cache-manager.ts +294 -0
  174. package/ccw/src/core/claude-freshness.ts +319 -0
  175. package/ccw/src/core/core-memory-store.ts +1528 -0
  176. package/ccw/src/core/{dashboard-generator-patch.js → dashboard-generator-patch.ts} +18 -0
  177. package/ccw/src/core/{dashboard-generator.js → dashboard-generator.ts} +69 -12
  178. package/ccw/src/core/data-aggregator.ts +584 -0
  179. package/ccw/src/core/history-importer.ts +625 -0
  180. package/ccw/src/core/{lite-scanner.js → lite-scanner-complete.ts} +162 -66
  181. package/ccw/src/core/lite-scanner.ts +469 -0
  182. package/ccw/src/core/{manifest.js → manifest.ts} +104 -34
  183. package/ccw/src/core/memory-embedder-bridge.ts +262 -0
  184. package/ccw/src/core/memory-store.ts +978 -0
  185. package/ccw/src/core/routes/ccw-routes.ts +96 -0
  186. package/ccw/src/core/routes/claude-routes.ts +1183 -0
  187. package/ccw/src/core/routes/cli-routes.ts +561 -0
  188. package/ccw/src/core/routes/codexlens-routes.ts +806 -0
  189. package/ccw/src/core/routes/core-memory-routes.ts +605 -0
  190. package/ccw/src/core/routes/files-routes.ts +428 -0
  191. package/ccw/src/core/routes/graph-routes.md +164 -0
  192. package/ccw/src/core/routes/graph-routes.ts +626 -0
  193. package/ccw/src/core/routes/help-routes.ts +308 -0
  194. package/ccw/src/core/routes/hooks-routes.ts +405 -0
  195. package/ccw/src/core/routes/mcp-routes.ts +1271 -0
  196. package/ccw/src/core/routes/mcp-routes.ts.backup +550 -0
  197. package/ccw/src/core/routes/mcp-templates-db.ts +268 -0
  198. package/ccw/src/core/routes/memory-routes.ts +1206 -0
  199. package/ccw/src/core/routes/rules-routes.ts +526 -0
  200. package/ccw/src/core/routes/session-routes.ts +467 -0
  201. package/ccw/src/core/routes/skills-routes.ts +599 -0
  202. package/ccw/src/core/routes/status-routes.ts +57 -0
  203. package/ccw/src/core/routes/system-routes.ts +427 -0
  204. package/ccw/src/core/server.ts +431 -0
  205. package/ccw/src/core/session-clustering-service.ts +1258 -0
  206. package/ccw/src/core/session-scanner.ts +283 -0
  207. package/ccw/src/core/websocket.ts +190 -0
  208. package/ccw/src/{index.js → index.ts} +1 -0
  209. package/ccw/src/mcp-server/index.ts +186 -0
  210. package/ccw/src/templates/assets/css/github-dark.min.css +10 -0
  211. package/ccw/src/templates/assets/css/github.min.css +10 -0
  212. package/ccw/src/templates/assets/js/cytoscape.min.js +32 -0
  213. package/ccw/src/templates/assets/js/d3.min.js +2 -0
  214. package/ccw/src/templates/assets/js/highlight.min.js +1244 -0
  215. package/ccw/src/templates/assets/js/lucide.min.js +12 -0
  216. package/ccw/src/templates/assets/js/marked.min.js +69 -0
  217. package/ccw/src/templates/assets/js/tailwind.js +83 -0
  218. package/ccw/src/templates/dashboard-css/01-base.css +11 -0
  219. package/ccw/src/templates/dashboard-css/02-session.css +22 -0
  220. package/ccw/src/templates/dashboard-css/04-lite-tasks.css +10 -0
  221. package/ccw/src/templates/dashboard-css/06-cards.css +10 -4
  222. package/ccw/src/templates/dashboard-css/07-managers.css +1178 -7
  223. package/ccw/src/templates/dashboard-css/09-explorer.css +23 -12
  224. package/ccw/src/templates/dashboard-css/10-cli-status.css +337 -0
  225. package/ccw/src/templates/dashboard-css/11-cli-history.css +271 -0
  226. package/ccw/src/templates/dashboard-css/12-cli-legacy.css +796 -0
  227. package/ccw/src/templates/dashboard-css/13-cli-ccw.css +199 -0
  228. package/ccw/src/templates/dashboard-css/14-cli-modals.css +258 -0
  229. package/ccw/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
  230. package/ccw/src/templates/dashboard-css/16-cli-session.css +241 -0
  231. package/ccw/src/templates/dashboard-css/17-cli-conversation.css +283 -0
  232. package/ccw/src/templates/dashboard-css/18-cli-settings.css +160 -0
  233. package/ccw/src/templates/dashboard-css/19-cli-native-session.css +496 -0
  234. package/ccw/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
  235. package/ccw/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
  236. package/ccw/src/templates/dashboard-css/22-cli-semantic.css +240 -0
  237. package/ccw/src/templates/dashboard-css/23-memory.css +2390 -0
  238. package/ccw/src/templates/dashboard-css/24-prompt-history.css +1089 -0
  239. package/ccw/src/templates/dashboard-css/25-skills-rules.css +326 -0
  240. package/ccw/src/templates/dashboard-css/26-claude-manager.css +908 -0
  241. package/ccw/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
  242. package/ccw/src/templates/dashboard-css/28-mcp-manager.css +748 -0
  243. package/ccw/src/templates/dashboard-css/29-help.css +264 -0
  244. package/ccw/src/templates/dashboard-css/30-core-memory.css +1700 -0
  245. package/ccw/src/templates/dashboard-js/api.js +162 -142
  246. package/ccw/src/templates/dashboard-js/components/carousel.js +4 -4
  247. package/ccw/src/templates/dashboard-js/components/cli-history.js +876 -0
  248. package/ccw/src/templates/dashboard-js/components/cli-status.js +978 -0
  249. package/ccw/src/templates/dashboard-js/components/global-notifications.js +508 -219
  250. package/ccw/src/templates/dashboard-js/components/hook-manager.js +1277 -282
  251. package/ccw/src/templates/dashboard-js/components/index-manager.js +302 -0
  252. package/ccw/src/templates/dashboard-js/components/mcp-manager.js +718 -27
  253. package/ccw/src/templates/dashboard-js/components/modals.js +66 -0
  254. package/ccw/src/templates/dashboard-js/components/navigation.js +80 -12
  255. package/ccw/src/templates/dashboard-js/components/notifications.js +758 -194
  256. package/ccw/src/templates/dashboard-js/components/storage-manager.js +478 -0
  257. package/ccw/src/templates/dashboard-js/components/tabs-other.js +157 -6
  258. package/ccw/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
  259. package/ccw/src/templates/dashboard-js/help-i18n.js +272 -0
  260. package/ccw/src/templates/dashboard-js/i18n.js +2807 -0
  261. package/ccw/src/templates/dashboard-js/main.js +15 -0
  262. package/ccw/src/templates/dashboard-js/state.js +243 -42
  263. package/ccw/src/templates/dashboard-js/utils.js +47 -1
  264. package/ccw/src/templates/dashboard-js/views/claude-manager.js +912 -0
  265. package/ccw/src/templates/dashboard-js/views/cli-manager.js +2272 -0
  266. package/ccw/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
  267. package/ccw/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
  268. package/ccw/src/templates/dashboard-js/views/core-memory.js +782 -0
  269. package/ccw/src/templates/dashboard-js/views/explorer.js +888 -852
  270. package/ccw/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
  271. package/ccw/src/templates/dashboard-js/views/help.js +856 -0
  272. package/ccw/src/templates/dashboard-js/views/history.js +337 -0
  273. package/ccw/src/templates/dashboard-js/views/home.js +61 -15
  274. package/ccw/src/templates/dashboard-js/views/hook-manager.js +311 -43
  275. package/ccw/src/templates/dashboard-js/views/lite-tasks.js +204 -28
  276. package/ccw/src/templates/dashboard-js/views/mcp-manager.js +2187 -411
  277. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
  278. package/ccw/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
  279. package/ccw/src/templates/dashboard-js/views/memory.js +1221 -0
  280. package/ccw/src/templates/dashboard-js/views/prompt-history.js +713 -0
  281. package/ccw/src/templates/dashboard-js/views/rules-manager.js +828 -0
  282. package/ccw/src/templates/dashboard-js/views/session-detail.js +54 -53
  283. package/ccw/src/templates/dashboard-js/views/skills-manager.js +819 -0
  284. package/ccw/src/templates/dashboard.html +185 -85
  285. package/ccw/src/templates/hooks-config-example.json +60 -0
  286. package/ccw/src/tools/classify-folders.ts +245 -0
  287. package/ccw/src/tools/cli-config-manager.ts +268 -0
  288. package/ccw/src/tools/cli-executor.ts +2014 -0
  289. package/ccw/src/tools/cli-history-store.ts +1195 -0
  290. package/ccw/src/tools/codex-lens.ts +1141 -0
  291. package/ccw/src/tools/{convert-tokens-to-css.js → convert-tokens-to-css.ts} +73 -23
  292. package/ccw/src/tools/core-memory.ts +444 -0
  293. package/ccw/src/tools/detect-changed-modules.ts +325 -0
  294. package/ccw/src/tools/{discover-design-files.js → discover-design-files.ts} +74 -24
  295. package/ccw/src/tools/edit-file.ts +568 -0
  296. package/ccw/src/tools/{generate-module-docs.js → generate-module-docs.ts} +207 -185
  297. package/ccw/src/tools/{get-modules-by-depth.js → get-modules-by-depth.ts} +120 -79
  298. package/ccw/src/tools/index.ts +370 -0
  299. package/ccw/src/tools/native-session-discovery.ts +795 -0
  300. package/ccw/src/tools/notifier.ts +129 -0
  301. package/ccw/src/tools/read-file.ts +410 -0
  302. package/ccw/src/tools/resume-strategy.ts +345 -0
  303. package/ccw/src/tools/session-content-parser.ts +619 -0
  304. package/ccw/src/tools/session-manager.ts +1026 -0
  305. package/ccw/src/tools/smart-context.ts +228 -0
  306. package/ccw/src/tools/smart-search.ts +2065 -0
  307. package/ccw/src/tools/smart-search.ts.backup +1233 -0
  308. package/ccw/src/tools/storage-manager.ts +455 -0
  309. package/ccw/src/tools/write-file.ts +222 -0
  310. package/ccw/src/types/config.ts +11 -0
  311. package/ccw/src/types/index.ts +3 -0
  312. package/ccw/src/types/session.ts +25 -0
  313. package/ccw/src/types/tool.ts +41 -0
  314. package/ccw/src/utils/{browser-launcher.js → browser-launcher.ts} +10 -8
  315. package/ccw/src/utils/file-utils.ts +48 -0
  316. package/ccw/src/utils/{path-resolver.js → path-resolver.ts} +114 -78
  317. package/ccw/src/utils/path-validator.ts +153 -0
  318. package/ccw/src/utils/{ui.js → ui.ts} +32 -25
  319. package/codex-lens/pyproject.toml +48 -0
  320. package/codex-lens/src/codexlens/.workflow/.cli-history/history.db +0 -0
  321. package/codex-lens/src/codexlens/__init__.py +28 -0
  322. package/codex-lens/src/codexlens/__main__.py +14 -0
  323. package/codex-lens/src/codexlens/__pycache__/__init__.cpython-313.pyc +0 -0
  324. package/codex-lens/src/codexlens/__pycache__/__main__.cpython-313.pyc +0 -0
  325. package/codex-lens/src/codexlens/__pycache__/config.cpython-313.pyc +0 -0
  326. package/codex-lens/src/codexlens/__pycache__/entities.cpython-313.pyc +0 -0
  327. package/codex-lens/src/codexlens/__pycache__/errors.cpython-313.pyc +0 -0
  328. package/codex-lens/src/codexlens/cli/__init__.py +27 -0
  329. package/codex-lens/src/codexlens/cli/__pycache__/__init__.cpython-313.pyc +0 -0
  330. package/codex-lens/src/codexlens/cli/__pycache__/commands.cpython-313.pyc +0 -0
  331. package/codex-lens/src/codexlens/cli/__pycache__/embedding_manager.cpython-313.pyc +0 -0
  332. package/codex-lens/src/codexlens/cli/__pycache__/model_manager.cpython-313.pyc +0 -0
  333. package/codex-lens/src/codexlens/cli/__pycache__/output.cpython-313.pyc +0 -0
  334. package/codex-lens/src/codexlens/cli/commands.py +1931 -0
  335. package/codex-lens/src/codexlens/cli/embedding_manager.py +620 -0
  336. package/codex-lens/src/codexlens/cli/model_manager.py +289 -0
  337. package/codex-lens/src/codexlens/cli/output.py +124 -0
  338. package/codex-lens/src/codexlens/config.py +201 -0
  339. package/codex-lens/src/codexlens/entities.py +121 -0
  340. package/codex-lens/src/codexlens/errors.py +55 -0
  341. package/codex-lens/src/codexlens/indexing/README.md +77 -0
  342. package/codex-lens/src/codexlens/indexing/__init__.py +4 -0
  343. package/codex-lens/src/codexlens/indexing/__pycache__/__init__.cpython-313.pyc +0 -0
  344. package/codex-lens/src/codexlens/indexing/__pycache__/symbol_extractor.cpython-313.pyc +0 -0
  345. package/codex-lens/src/codexlens/indexing/symbol_extractor.py +243 -0
  346. package/codex-lens/src/codexlens/parsers/__init__.py +8 -0
  347. package/codex-lens/src/codexlens/parsers/__pycache__/__init__.cpython-313.pyc +0 -0
  348. package/codex-lens/src/codexlens/parsers/__pycache__/encoding.cpython-313.pyc +0 -0
  349. package/codex-lens/src/codexlens/parsers/__pycache__/factory.cpython-313.pyc +0 -0
  350. package/codex-lens/src/codexlens/parsers/__pycache__/tokenizer.cpython-313.pyc +0 -0
  351. package/codex-lens/src/codexlens/parsers/__pycache__/treesitter_parser.cpython-313.pyc +0 -0
  352. package/codex-lens/src/codexlens/parsers/encoding.py +202 -0
  353. package/codex-lens/src/codexlens/parsers/factory.py +256 -0
  354. package/codex-lens/src/codexlens/parsers/tokenizer.py +98 -0
  355. package/codex-lens/src/codexlens/parsers/treesitter_parser.py +335 -0
  356. package/codex-lens/src/codexlens/search/__init__.py +15 -0
  357. package/codex-lens/src/codexlens/search/__pycache__/__init__.cpython-313.pyc +0 -0
  358. package/codex-lens/src/codexlens/search/__pycache__/chain_search.cpython-313.pyc +0 -0
  359. package/codex-lens/src/codexlens/search/__pycache__/enrichment.cpython-313.pyc +0 -0
  360. package/codex-lens/src/codexlens/search/__pycache__/hybrid_search.cpython-313.pyc +0 -0
  361. package/codex-lens/src/codexlens/search/__pycache__/query_parser.cpython-313.pyc +0 -0
  362. package/codex-lens/src/codexlens/search/__pycache__/ranking.cpython-313.pyc +0 -0
  363. package/codex-lens/src/codexlens/search/chain_search.py +647 -0
  364. package/codex-lens/src/codexlens/search/enrichment.py +150 -0
  365. package/codex-lens/src/codexlens/search/hybrid_search.py +313 -0
  366. package/codex-lens/src/codexlens/search/query_parser.py +242 -0
  367. package/codex-lens/src/codexlens/search/ranking.py +274 -0
  368. package/codex-lens/src/codexlens/semantic/__init__.py +39 -0
  369. package/codex-lens/src/codexlens/semantic/__pycache__/__init__.cpython-313.pyc +0 -0
  370. package/codex-lens/src/codexlens/semantic/__pycache__/ann_index.cpython-313.pyc +0 -0
  371. package/codex-lens/src/codexlens/semantic/__pycache__/chunker.cpython-313.pyc +0 -0
  372. package/codex-lens/src/codexlens/semantic/__pycache__/code_extractor.cpython-313.pyc +0 -0
  373. package/codex-lens/src/codexlens/semantic/__pycache__/embedder.cpython-313.pyc +0 -0
  374. package/codex-lens/src/codexlens/semantic/__pycache__/graph_analyzer.cpython-313.pyc +0 -0
  375. package/codex-lens/src/codexlens/semantic/__pycache__/llm_enhancer.cpython-313.pyc +0 -0
  376. package/codex-lens/src/codexlens/semantic/__pycache__/vector_store.cpython-313.pyc +0 -0
  377. package/codex-lens/src/codexlens/semantic/ann_index.py +414 -0
  378. package/codex-lens/src/codexlens/semantic/chunker.py +448 -0
  379. package/codex-lens/src/codexlens/semantic/code_extractor.py +274 -0
  380. package/codex-lens/src/codexlens/semantic/embedder.py +185 -0
  381. package/codex-lens/src/codexlens/semantic/vector_store.py +955 -0
  382. package/codex-lens/src/codexlens/storage/__init__.py +29 -0
  383. package/codex-lens/src/codexlens/storage/__pycache__/__init__.cpython-313.pyc +0 -0
  384. package/codex-lens/src/codexlens/storage/__pycache__/dir_index.cpython-313.pyc +0 -0
  385. package/codex-lens/src/codexlens/storage/__pycache__/file_cache.cpython-313.pyc +0 -0
  386. package/codex-lens/src/codexlens/storage/__pycache__/index_tree.cpython-313.pyc +0 -0
  387. package/codex-lens/src/codexlens/storage/__pycache__/migration_manager.cpython-313.pyc +0 -0
  388. package/codex-lens/src/codexlens/storage/__pycache__/path_mapper.cpython-313.pyc +0 -0
  389. package/codex-lens/src/codexlens/storage/__pycache__/registry.cpython-313.pyc +0 -0
  390. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_store.cpython-313.pyc +0 -0
  391. package/codex-lens/src/codexlens/storage/__pycache__/sqlite_utils.cpython-313.pyc +0 -0
  392. package/codex-lens/src/codexlens/storage/dir_index.py +1850 -0
  393. package/codex-lens/src/codexlens/storage/file_cache.py +32 -0
  394. package/codex-lens/src/codexlens/storage/index_tree.py +776 -0
  395. package/codex-lens/src/codexlens/storage/migration_manager.py +154 -0
  396. package/codex-lens/src/codexlens/storage/migrations/__init__.py +1 -0
  397. package/codex-lens/src/codexlens/storage/migrations/__pycache__/__init__.cpython-313.pyc +0 -0
  398. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_001_normalize_keywords.cpython-313.pyc +0 -0
  399. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_002_add_token_metadata.cpython-313.pyc +0 -0
  400. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_003_code_relationships.cpython-313.pyc +0 -0
  401. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_004_dual_fts.cpython-313.pyc +0 -0
  402. package/codex-lens/src/codexlens/storage/migrations/__pycache__/migration_005_cleanup_unused_fields.cpython-313.pyc +0 -0
  403. package/codex-lens/src/codexlens/storage/migrations/migration_001_normalize_keywords.py +123 -0
  404. package/codex-lens/src/codexlens/storage/migrations/migration_002_add_token_metadata.py +48 -0
  405. package/codex-lens/src/codexlens/storage/migrations/migration_004_dual_fts.py +232 -0
  406. package/codex-lens/src/codexlens/storage/migrations/migration_005_cleanup_unused_fields.py +196 -0
  407. package/codex-lens/src/codexlens/storage/path_mapper.py +274 -0
  408. package/codex-lens/src/codexlens/storage/registry.py +670 -0
  409. package/codex-lens/src/codexlens/storage/sqlite_store.py +576 -0
  410. package/codex-lens/src/codexlens/storage/sqlite_utils.py +64 -0
  411. package/package.json +4 -1
  412. package/.claude/commands/memory/tech-research.md +0 -477
  413. package/.claude/scripts/classify-folders.sh +0 -39
  414. package/.claude/scripts/convert_tokens_to_css.sh +0 -229
  415. package/.claude/scripts/detect_changed_modules.sh +0 -161
  416. package/.claude/scripts/discover-design-files.sh +0 -87
  417. package/.claude/scripts/extract-animations.js +0 -243
  418. package/.claude/scripts/extract-computed-styles.js +0 -118
  419. package/.claude/scripts/extract-layout-structure.js +0 -411
  420. package/.claude/scripts/generate_module_docs.sh +0 -717
  421. package/.claude/scripts/get_modules_by_depth.sh +0 -170
  422. package/.claude/scripts/ui-generate-preview.sh +0 -395
  423. package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
  424. package/.claude/scripts/update_module_claude.sh +0 -337
  425. package/.claude/workflows/context-search-strategy.md +0 -77
  426. package/.claude/workflows/intelligent-tools-strategy.md +0 -662
  427. package/ccw/src/cli.js +0 -119
  428. package/ccw/src/commands/install.js +0 -324
  429. package/ccw/src/commands/tool.js +0 -138
  430. package/ccw/src/core/data-aggregator.js +0 -409
  431. package/ccw/src/core/server.js +0 -2063
  432. package/ccw/src/core/session-scanner.js +0 -235
  433. package/ccw/src/tools/classify-folders.js +0 -204
  434. package/ccw/src/tools/detect-changed-modules.js +0 -288
  435. package/ccw/src/tools/edit-file.js +0 -266
  436. package/ccw/src/tools/index.js +0 -176
  437. package/ccw/src/utils/file-utils.js +0 -48
@@ -0,0 +1,561 @@
1
+ // @ts-nocheck
2
+ /**
3
+ * CLI Routes Module
4
+ * Handles all CLI-related API endpoints
5
+ */
6
+ import type { IncomingMessage, ServerResponse } from 'http';
7
+ import {
8
+ getCliToolsStatus,
9
+ getCliToolsFullStatus,
10
+ installCliTool,
11
+ uninstallCliTool,
12
+ enableCliTool,
13
+ disableCliTool,
14
+ getExecutionHistory,
15
+ getExecutionHistoryAsync,
16
+ getExecutionDetail,
17
+ getConversationDetail,
18
+ getConversationDetailWithNativeInfo,
19
+ deleteExecution,
20
+ deleteExecutionAsync,
21
+ batchDeleteExecutionsAsync,
22
+ executeCliTool,
23
+ getNativeSessionContent,
24
+ getFormattedNativeConversation,
25
+ getEnrichedConversation,
26
+ getHistoryWithNativeInfo
27
+ } from '../../tools/cli-executor.js';
28
+ import { generateSmartContext, formatSmartContext } from '../../tools/smart-context.js';
29
+ import {
30
+ loadCliConfig,
31
+ getToolConfig,
32
+ updateToolConfig,
33
+ getFullConfigResponse,
34
+ PREDEFINED_MODELS
35
+ } from '../../tools/cli-config-manager.js';
36
+
37
+ export interface RouteContext {
38
+ pathname: string;
39
+ url: URL;
40
+ req: IncomingMessage;
41
+ res: ServerResponse;
42
+ initialPath: string;
43
+ handlePostRequest: (req: IncomingMessage, res: ServerResponse, handler: (body: unknown) => Promise<any>) => void;
44
+ broadcastToClients: (data: unknown) => void;
45
+ }
46
+
47
+ /**
48
+ * Handle CLI routes
49
+ * @returns true if route was handled, false otherwise
50
+ */
51
+ export async function handleCliRoutes(ctx: RouteContext): Promise<boolean> {
52
+ const { pathname, url, req, res, initialPath, handlePostRequest, broadcastToClients } = ctx;
53
+
54
+ // API: CLI Tools Status
55
+ if (pathname === '/api/cli/status') {
56
+ const status = await getCliToolsStatus();
57
+ res.writeHead(200, { 'Content-Type': 'application/json' });
58
+ res.end(JSON.stringify(status));
59
+ return true;
60
+ }
61
+
62
+ // API: CLI Tools Full Status (with enabled state)
63
+ if (pathname === '/api/cli/full-status') {
64
+ const status = await getCliToolsFullStatus();
65
+ res.writeHead(200, { 'Content-Type': 'application/json' });
66
+ res.end(JSON.stringify(status));
67
+ return true;
68
+ }
69
+
70
+ // API: Install CLI Tool
71
+ if (pathname === '/api/cli/install' && req.method === 'POST') {
72
+ handlePostRequest(req, res, async (body: unknown) => {
73
+ const { tool } = body as { tool: string };
74
+ if (!tool) {
75
+ return { error: 'Tool name is required', status: 400 };
76
+ }
77
+
78
+ const result = await installCliTool(tool);
79
+ if (result.success) {
80
+ // Broadcast tool installed event
81
+ broadcastToClients({
82
+ type: 'CLI_TOOL_INSTALLED',
83
+ payload: { tool, timestamp: new Date().toISOString() }
84
+ });
85
+ return { success: true, message: `${tool} installed successfully` };
86
+ } else {
87
+ return { success: false, error: result.error, status: 500 };
88
+ }
89
+ });
90
+ return true;
91
+ }
92
+
93
+ // API: Uninstall CLI Tool
94
+ if (pathname === '/api/cli/uninstall' && req.method === 'POST') {
95
+ handlePostRequest(req, res, async (body: unknown) => {
96
+ const { tool } = body as { tool: string };
97
+ if (!tool) {
98
+ return { error: 'Tool name is required', status: 400 };
99
+ }
100
+
101
+ const result = await uninstallCliTool(tool);
102
+ if (result.success) {
103
+ // Broadcast tool uninstalled event
104
+ broadcastToClients({
105
+ type: 'CLI_TOOL_UNINSTALLED',
106
+ payload: { tool, timestamp: new Date().toISOString() }
107
+ });
108
+ return { success: true, message: `${tool} uninstalled successfully` };
109
+ } else {
110
+ return { success: false, error: result.error, status: 500 };
111
+ }
112
+ });
113
+ return true;
114
+ }
115
+
116
+ // API: Enable CLI Tool
117
+ if (pathname === '/api/cli/enable' && req.method === 'POST') {
118
+ handlePostRequest(req, res, async (body: unknown) => {
119
+ const { tool } = body as { tool: string };
120
+ if (!tool) {
121
+ return { error: 'Tool name is required', status: 400 };
122
+ }
123
+
124
+ const result = enableCliTool(tool);
125
+ // Broadcast tool enabled event
126
+ broadcastToClients({
127
+ type: 'CLI_TOOL_ENABLED',
128
+ payload: { tool, timestamp: new Date().toISOString() }
129
+ });
130
+ return { success: true, message: `${tool} enabled` };
131
+ });
132
+ return true;
133
+ }
134
+
135
+ // API: Disable CLI Tool
136
+ if (pathname === '/api/cli/disable' && req.method === 'POST') {
137
+ handlePostRequest(req, res, async (body: unknown) => {
138
+ const { tool } = body as { tool: string };
139
+ if (!tool) {
140
+ return { error: 'Tool name is required', status: 400 };
141
+ }
142
+
143
+ const result = disableCliTool(tool);
144
+ // Broadcast tool disabled event
145
+ broadcastToClients({
146
+ type: 'CLI_TOOL_DISABLED',
147
+ payload: { tool, timestamp: new Date().toISOString() }
148
+ });
149
+ return { success: true, message: `${tool} disabled` };
150
+ });
151
+ return true;
152
+ }
153
+
154
+ // API: Get Full CLI Config (with predefined models)
155
+ if (pathname === '/api/cli/config' && req.method === 'GET') {
156
+ try {
157
+ const response = getFullConfigResponse(initialPath);
158
+ res.writeHead(200, { 'Content-Type': 'application/json' });
159
+ res.end(JSON.stringify(response));
160
+ } catch (err) {
161
+ res.writeHead(500, { 'Content-Type': 'application/json' });
162
+ res.end(JSON.stringify({ error: (err as Error).message }));
163
+ }
164
+ return true;
165
+ }
166
+
167
+ // API: Get/Update Tool Config
168
+ const configMatch = pathname.match(/^\/api\/cli\/config\/(gemini|qwen|codex)$/);
169
+ if (configMatch) {
170
+ const tool = configMatch[1];
171
+
172
+ // GET: Get single tool config
173
+ if (req.method === 'GET') {
174
+ try {
175
+ const toolConfig = getToolConfig(initialPath, tool);
176
+ res.writeHead(200, { 'Content-Type': 'application/json' });
177
+ res.end(JSON.stringify(toolConfig));
178
+ } catch (err) {
179
+ res.writeHead(500, { 'Content-Type': 'application/json' });
180
+ res.end(JSON.stringify({ error: (err as Error).message }));
181
+ }
182
+ return true;
183
+ }
184
+
185
+ // PUT: Update tool config
186
+ if (req.method === 'PUT') {
187
+ handlePostRequest(req, res, async (body: unknown) => {
188
+ try {
189
+ const updates = body as { enabled?: boolean; primaryModel?: string; secondaryModel?: string };
190
+ const updated = updateToolConfig(initialPath, tool, updates);
191
+
192
+ // Broadcast config updated event
193
+ broadcastToClients({
194
+ type: 'CLI_CONFIG_UPDATED',
195
+ payload: { tool, config: updated, timestamp: new Date().toISOString() }
196
+ });
197
+
198
+ return { success: true, config: updated };
199
+ } catch (err) {
200
+ return { error: (err as Error).message, status: 500 };
201
+ }
202
+ });
203
+ return true;
204
+ }
205
+ }
206
+
207
+ // API: CLI Execution History
208
+ if (pathname === '/api/cli/history') {
209
+ const projectPath = url.searchParams.get('path') || initialPath;
210
+ const limit = parseInt(url.searchParams.get('limit') || '50', 10);
211
+ const tool = url.searchParams.get('tool') || null;
212
+ const status = url.searchParams.get('status') || null;
213
+ const category = url.searchParams.get('category') as 'user' | 'internal' | 'insight' | null;
214
+ const search = url.searchParams.get('search') || null;
215
+ const recursive = url.searchParams.get('recursive') !== 'false';
216
+
217
+ getExecutionHistoryAsync(projectPath, { limit, tool, status, category, search, recursive })
218
+ .then(history => {
219
+ res.writeHead(200, { 'Content-Type': 'application/json' });
220
+ res.end(JSON.stringify(history));
221
+ })
222
+ .catch(err => {
223
+ res.writeHead(500, { 'Content-Type': 'application/json' });
224
+ res.end(JSON.stringify({ error: err.message }));
225
+ });
226
+ return true;
227
+ }
228
+
229
+ // API: CLI Execution Detail (GET) or Delete (DELETE)
230
+ if (pathname === '/api/cli/execution') {
231
+ const projectPath = url.searchParams.get('path') || initialPath;
232
+ const executionId = url.searchParams.get('id');
233
+
234
+ if (!executionId) {
235
+ res.writeHead(400, { 'Content-Type': 'application/json' });
236
+ res.end(JSON.stringify({ error: 'Execution ID is required' }));
237
+ return true;
238
+ }
239
+
240
+ // Handle DELETE request
241
+ if (req.method === 'DELETE') {
242
+ deleteExecutionAsync(projectPath, executionId)
243
+ .then(result => {
244
+ if (result.success) {
245
+ res.writeHead(200, { 'Content-Type': 'application/json' });
246
+ res.end(JSON.stringify({ success: true, message: 'Execution deleted' }));
247
+ } else {
248
+ res.writeHead(500, { 'Content-Type': 'application/json' });
249
+ res.end(JSON.stringify({ error: result.error || 'Delete failed' }));
250
+ }
251
+ })
252
+ .catch(err => {
253
+ res.writeHead(500, { 'Content-Type': 'application/json' });
254
+ res.end(JSON.stringify({ error: err.message }));
255
+ });
256
+ return true;
257
+ }
258
+
259
+ // Handle GET request - return conversation with native session info
260
+ const conversation = getConversationDetailWithNativeInfo(projectPath, executionId);
261
+ if (!conversation) {
262
+ res.writeHead(404, { 'Content-Type': 'application/json' });
263
+ res.end(JSON.stringify({ error: 'Conversation not found' }));
264
+ return true;
265
+ }
266
+
267
+ res.writeHead(200, { 'Content-Type': 'application/json' });
268
+ res.end(JSON.stringify(conversation));
269
+ return true;
270
+ }
271
+
272
+ // API: Batch Delete CLI Executions
273
+ if (pathname === '/api/cli/batch-delete' && req.method === 'POST') {
274
+ handlePostRequest(req, res, async (body) => {
275
+ const { path: projectPath, ids } = body as { path?: string; ids: string[] };
276
+
277
+ if (!ids || !Array.isArray(ids) || ids.length === 0) {
278
+ return { error: 'ids array is required', status: 400 };
279
+ }
280
+
281
+ const basePath = projectPath || initialPath;
282
+ return await batchDeleteExecutionsAsync(basePath, ids);
283
+ });
284
+ return true;
285
+ }
286
+
287
+ // API: Get Native Session Content
288
+ if (pathname === '/api/cli/native-session') {
289
+ const projectPath = url.searchParams.get('path') || initialPath;
290
+ const executionId = url.searchParams.get('id');
291
+ const format = url.searchParams.get('format') || 'json';
292
+
293
+ if (!executionId) {
294
+ res.writeHead(400, { 'Content-Type': 'application/json' });
295
+ res.end(JSON.stringify({ error: 'Execution ID is required' }));
296
+ return true;
297
+ }
298
+
299
+ try {
300
+ let result;
301
+ if (format === 'text') {
302
+ result = await getFormattedNativeConversation(projectPath, executionId, {
303
+ includeThoughts: url.searchParams.get('thoughts') === 'true',
304
+ includeToolCalls: url.searchParams.get('tools') === 'true',
305
+ includeTokens: url.searchParams.get('tokens') === 'true'
306
+ });
307
+ } else if (format === 'pairs') {
308
+ const enriched = await getEnrichedConversation(projectPath, executionId);
309
+ result = enriched?.merged || null;
310
+ } else {
311
+ result = await getNativeSessionContent(projectPath, executionId);
312
+ }
313
+
314
+ if (!result) {
315
+ res.writeHead(404, { 'Content-Type': 'application/json' });
316
+ res.end(JSON.stringify({ error: 'Native session not found' }));
317
+ return true;
318
+ }
319
+
320
+ res.writeHead(200, { 'Content-Type': format === 'text' ? 'text/plain' : 'application/json' });
321
+ res.end(format === 'text' ? result : JSON.stringify(result));
322
+ } catch (err) {
323
+ res.writeHead(500, { 'Content-Type': 'application/json' });
324
+ res.end(JSON.stringify({ error: (err as Error).message }));
325
+ }
326
+ return true;
327
+ }
328
+
329
+ // API: Get Enriched Conversation
330
+ if (pathname === '/api/cli/enriched') {
331
+ const projectPath = url.searchParams.get('path') || initialPath;
332
+ const executionId = url.searchParams.get('id');
333
+
334
+ if (!executionId) {
335
+ res.writeHead(400, { 'Content-Type': 'application/json' });
336
+ res.end(JSON.stringify({ error: 'Execution ID is required' }));
337
+ return true;
338
+ }
339
+
340
+ getEnrichedConversation(projectPath, executionId)
341
+ .then(result => {
342
+ if (!result) {
343
+ res.writeHead(404, { 'Content-Type': 'application/json' });
344
+ res.end(JSON.stringify({ error: 'Conversation not found' }));
345
+ return;
346
+ }
347
+ res.writeHead(200, { 'Content-Type': 'application/json' });
348
+ res.end(JSON.stringify(result));
349
+ })
350
+ .catch(err => {
351
+ res.writeHead(500, { 'Content-Type': 'application/json' });
352
+ res.end(JSON.stringify({ error: (err as Error).message }));
353
+ });
354
+ return true;
355
+ }
356
+
357
+ // API: Get History with Native Session Info
358
+ if (pathname === '/api/cli/history-native') {
359
+ const projectPath = url.searchParams.get('path') || initialPath;
360
+ const limit = parseInt(url.searchParams.get('limit') || '50', 10);
361
+ const tool = url.searchParams.get('tool') || null;
362
+ const status = url.searchParams.get('status') || null;
363
+ const category = url.searchParams.get('category') as 'user' | 'internal' | 'insight' | null;
364
+ const search = url.searchParams.get('search') || null;
365
+
366
+ getHistoryWithNativeInfo(projectPath, { limit, tool, status, category, search })
367
+ .then(history => {
368
+ res.writeHead(200, { 'Content-Type': 'application/json' });
369
+ res.end(JSON.stringify(history));
370
+ })
371
+ .catch(err => {
372
+ res.writeHead(500, { 'Content-Type': 'application/json' });
373
+ res.end(JSON.stringify({ error: (err as Error).message }));
374
+ });
375
+ return true;
376
+ }
377
+
378
+ // API: Execute CLI Tool
379
+ if (pathname === '/api/cli/execute' && req.method === 'POST') {
380
+ handlePostRequest(req, res, async (body) => {
381
+ const { tool, prompt, mode, format, model, dir, includeDirs, timeout, smartContext, parentExecutionId, category } = body as any;
382
+
383
+ if (!tool || !prompt) {
384
+ return { error: 'tool and prompt are required', status: 400 };
385
+ }
386
+
387
+ // Generate smart context if enabled
388
+ let finalPrompt = prompt;
389
+ if (smartContext?.enabled) {
390
+ try {
391
+ const contextResult = await generateSmartContext(prompt, {
392
+ enabled: true,
393
+ maxFiles: smartContext.maxFiles || 10,
394
+ searchMode: 'text'
395
+ }, dir || initialPath);
396
+
397
+ const contextAppendage = formatSmartContext(contextResult);
398
+ if (contextAppendage) {
399
+ finalPrompt = prompt + contextAppendage;
400
+ }
401
+ } catch (err) {
402
+ console.warn('[Smart Context] Failed to generate:', err);
403
+ }
404
+ }
405
+
406
+ const executionId = `${Date.now()}-${tool}`;
407
+
408
+ // Broadcast execution started
409
+ broadcastToClients({
410
+ type: 'CLI_EXECUTION_STARTED',
411
+ payload: {
412
+ executionId,
413
+ tool,
414
+ mode: mode || 'analysis',
415
+ parentExecutionId,
416
+ timestamp: new Date().toISOString()
417
+ }
418
+ });
419
+
420
+ try {
421
+ const result = await executeCliTool({
422
+ tool,
423
+ prompt: finalPrompt,
424
+ mode: mode || 'analysis',
425
+ format: format || 'plain',
426
+ model,
427
+ cd: dir || initialPath,
428
+ includeDirs,
429
+ timeout: timeout || 300000,
430
+ category: category || 'user',
431
+ parentExecutionId,
432
+ stream: true
433
+ }, (chunk) => {
434
+ broadcastToClients({
435
+ type: 'CLI_OUTPUT',
436
+ payload: {
437
+ executionId,
438
+ chunkType: chunk.type,
439
+ data: chunk.data
440
+ }
441
+ });
442
+ });
443
+
444
+ // Broadcast completion
445
+ broadcastToClients({
446
+ type: 'CLI_EXECUTION_COMPLETED',
447
+ payload: {
448
+ executionId,
449
+ success: result.success,
450
+ status: result.execution.status,
451
+ duration_ms: result.execution.duration_ms
452
+ }
453
+ });
454
+
455
+ return {
456
+ success: result.success,
457
+ execution: result.execution
458
+ };
459
+
460
+ } catch (error: unknown) {
461
+ broadcastToClients({
462
+ type: 'CLI_EXECUTION_ERROR',
463
+ payload: {
464
+ executionId,
465
+ error: (error as Error).message
466
+ }
467
+ });
468
+
469
+ return { error: (error as Error).message, status: 500 };
470
+ }
471
+ });
472
+ return true;
473
+ }
474
+
475
+ // API: CLI Review - Submit review for an execution
476
+ if (pathname.startsWith('/api/cli/review/') && req.method === 'POST') {
477
+ const executionId = pathname.replace('/api/cli/review/', '');
478
+ handlePostRequest(req, res, async (body) => {
479
+ const { status, rating, comments, reviewer } = body as {
480
+ status: 'pending' | 'approved' | 'rejected' | 'changes_requested';
481
+ rating?: number;
482
+ comments?: string;
483
+ reviewer?: string;
484
+ };
485
+
486
+ if (!status) {
487
+ return { error: 'status is required', status: 400 };
488
+ }
489
+
490
+ try {
491
+ const historyStore = await import('../../tools/cli-history-store.js').then(m => m.getHistoryStore(initialPath));
492
+
493
+ const execution = historyStore.getConversation(executionId);
494
+ if (!execution) {
495
+ return { error: 'Execution not found', status: 404 };
496
+ }
497
+
498
+ const review = historyStore.saveReview({
499
+ execution_id: executionId,
500
+ status,
501
+ rating,
502
+ comments,
503
+ reviewer
504
+ });
505
+
506
+ broadcastToClients({
507
+ type: 'CLI_REVIEW_UPDATED',
508
+ payload: {
509
+ executionId,
510
+ review,
511
+ timestamp: new Date().toISOString()
512
+ }
513
+ });
514
+
515
+ return { success: true, review };
516
+ } catch (error: unknown) {
517
+ return { error: (error as Error).message, status: 500 };
518
+ }
519
+ });
520
+ return true;
521
+ }
522
+
523
+ // API: CLI Review - Get review for an execution
524
+ if (pathname.startsWith('/api/cli/review/') && req.method === 'GET') {
525
+ const executionId = pathname.replace('/api/cli/review/', '');
526
+ try {
527
+ const historyStore = await import('../../tools/cli-history-store.js').then(m => m.getHistoryStore(initialPath));
528
+ const review = historyStore.getReview(executionId);
529
+
530
+ res.writeHead(200, { 'Content-Type': 'application/json' });
531
+ res.end(JSON.stringify({ review }));
532
+ } catch (error: unknown) {
533
+ res.writeHead(500, { 'Content-Type': 'application/json' });
534
+ res.end(JSON.stringify({ error: (error as Error).message }));
535
+ }
536
+ return true;
537
+ }
538
+
539
+ // API: CLI Reviews - List all reviews
540
+ if (pathname === '/api/cli/reviews' && req.method === 'GET') {
541
+ try {
542
+ const historyStore = await import('../../tools/cli-history-store.js').then(m => m.getHistoryStore(initialPath));
543
+ const statusFilter = url.searchParams.get('status') as 'pending' | 'approved' | 'rejected' | 'changes_requested' | null;
544
+ const limit = parseInt(url.searchParams.get('limit') || '50', 10);
545
+
546
+ const reviews = historyStore.getReviews({
547
+ status: statusFilter || undefined,
548
+ limit
549
+ });
550
+
551
+ res.writeHead(200, { 'Content-Type': 'application/json' });
552
+ res.end(JSON.stringify({ reviews, count: reviews.length }));
553
+ } catch (error: unknown) {
554
+ res.writeHead(500, { 'Content-Type': 'application/json' });
555
+ res.end(JSON.stringify({ error: (error as Error).message }));
556
+ }
557
+ return true;
558
+ }
559
+
560
+ return false;
561
+ }