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,467 @@
1
+ // @ts-nocheck
2
+ /**
3
+ * Session Routes Module
4
+ * Handles all Session/Task-related API endpoints
5
+ */
6
+ import type { IncomingMessage, ServerResponse } from 'http';
7
+ import { readFileSync, writeFileSync, existsSync, readdirSync } from 'fs';
8
+ import { join } from 'path';
9
+
10
+ export interface RouteContext {
11
+ pathname: string;
12
+ url: URL;
13
+ req: IncomingMessage;
14
+ res: ServerResponse;
15
+ initialPath: string;
16
+ handlePostRequest: (req: IncomingMessage, res: ServerResponse, handler: (body: unknown) => Promise<any>) => void;
17
+ broadcastToClients: (data: unknown) => void;
18
+ }
19
+
20
+ /**
21
+ * Get session detail data (context, summaries, impl-plan, review)
22
+ * @param {string} sessionPath - Path to session directory
23
+ * @param {string} dataType - Type of data to load ('all', 'context', 'tasks', 'summary', 'plan', 'explorations', 'conflict', 'impl-plan', 'review')
24
+ * @returns {Promise<Object>}
25
+ */
26
+ async function getSessionDetailData(sessionPath, dataType) {
27
+ const result = {};
28
+
29
+ // Normalize path
30
+ const normalizedPath = sessionPath.replace(/\\/g, '/');
31
+
32
+ try {
33
+ // Load context-package.json (in .process/ subfolder)
34
+ if (dataType === 'context' || dataType === 'all') {
35
+ // Try .process/context-package.json first (common location)
36
+ let contextFile = join(normalizedPath, '.process', 'context-package.json');
37
+ if (!existsSync(contextFile)) {
38
+ // Fallback to session root
39
+ contextFile = join(normalizedPath, 'context-package.json');
40
+ }
41
+ if (existsSync(contextFile)) {
42
+ try {
43
+ result.context = JSON.parse(readFileSync(contextFile, 'utf8'));
44
+ } catch (e) {
45
+ result.context = null;
46
+ }
47
+ }
48
+ }
49
+
50
+ // Load task JSONs from .task/ folder
51
+ if (dataType === 'tasks' || dataType === 'all') {
52
+ const taskDir = join(normalizedPath, '.task');
53
+ result.tasks = [];
54
+ if (existsSync(taskDir)) {
55
+ const files = readdirSync(taskDir).filter(f => f.endsWith('.json') && f.startsWith('IMPL-'));
56
+ for (const file of files) {
57
+ try {
58
+ const content = JSON.parse(readFileSync(join(taskDir, file), 'utf8'));
59
+ result.tasks.push({
60
+ filename: file,
61
+ task_id: file.replace('.json', ''),
62
+ ...content
63
+ });
64
+ } catch (e) {
65
+ // Skip unreadable files
66
+ }
67
+ }
68
+ // Sort by task ID
69
+ result.tasks.sort((a, b) => a.task_id.localeCompare(b.task_id));
70
+ }
71
+ }
72
+
73
+ // Load summaries from .summaries/
74
+ if (dataType === 'summary' || dataType === 'all') {
75
+ const summariesDir = join(normalizedPath, '.summaries');
76
+ result.summaries = [];
77
+ if (existsSync(summariesDir)) {
78
+ const files = readdirSync(summariesDir).filter(f => f.endsWith('.md'));
79
+ for (const file of files) {
80
+ try {
81
+ const content = readFileSync(join(summariesDir, file), 'utf8');
82
+ result.summaries.push({ name: file.replace('.md', ''), content });
83
+ } catch (e) {
84
+ // Skip unreadable files
85
+ }
86
+ }
87
+ }
88
+ }
89
+
90
+ // Load plan.json (for lite tasks)
91
+ if (dataType === 'plan' || dataType === 'all') {
92
+ const planFile = join(normalizedPath, 'plan.json');
93
+ if (existsSync(planFile)) {
94
+ try {
95
+ result.plan = JSON.parse(readFileSync(planFile, 'utf8'));
96
+ } catch (e) {
97
+ result.plan = null;
98
+ }
99
+ }
100
+ }
101
+
102
+ // Load explorations (exploration-*.json files) and diagnoses (diagnosis-*.json files) - check .process/ first, then session root
103
+ if (dataType === 'context' || dataType === 'explorations' || dataType === 'all') {
104
+ result.explorations = { manifest: null, data: {} };
105
+ result.diagnoses = { manifest: null, data: {} };
106
+
107
+ // Try .process/ first (standard workflow sessions), then session root (lite tasks)
108
+ const searchDirs = [
109
+ join(normalizedPath, '.process'),
110
+ normalizedPath
111
+ ];
112
+
113
+ for (const searchDir of searchDirs) {
114
+ if (!existsSync(searchDir)) continue;
115
+
116
+ // Look for explorations-manifest.json
117
+ const manifestFile = join(searchDir, 'explorations-manifest.json');
118
+ if (existsSync(manifestFile)) {
119
+ try {
120
+ result.explorations.manifest = JSON.parse(readFileSync(manifestFile, 'utf8'));
121
+
122
+ // Load each exploration file based on manifest
123
+ const explorations = result.explorations.manifest.explorations || [];
124
+ for (const exp of explorations) {
125
+ const expFile = join(searchDir, exp.file);
126
+ if (existsSync(expFile)) {
127
+ try {
128
+ result.explorations.data[exp.angle] = JSON.parse(readFileSync(expFile, 'utf8'));
129
+ } catch (e) {
130
+ // Skip unreadable exploration files
131
+ }
132
+ }
133
+ }
134
+ break; // Found manifest, stop searching
135
+ } catch (e) {
136
+ result.explorations.manifest = null;
137
+ }
138
+ }
139
+
140
+ // Look for diagnoses-manifest.json
141
+ const diagManifestFile = join(searchDir, 'diagnoses-manifest.json');
142
+ if (existsSync(diagManifestFile)) {
143
+ try {
144
+ result.diagnoses.manifest = JSON.parse(readFileSync(diagManifestFile, 'utf8'));
145
+
146
+ // Load each diagnosis file based on manifest
147
+ const diagnoses = result.diagnoses.manifest.diagnoses || [];
148
+ for (const diag of diagnoses) {
149
+ const diagFile = join(searchDir, diag.file);
150
+ if (existsSync(diagFile)) {
151
+ try {
152
+ result.diagnoses.data[diag.angle] = JSON.parse(readFileSync(diagFile, 'utf8'));
153
+ } catch (e) {
154
+ // Skip unreadable diagnosis files
155
+ }
156
+ }
157
+ }
158
+ break; // Found manifest, stop searching
159
+ } catch (e) {
160
+ result.diagnoses.manifest = null;
161
+ }
162
+ }
163
+
164
+ // Fallback: scan for exploration-*.json and diagnosis-*.json files directly
165
+ if (!result.explorations.manifest) {
166
+ try {
167
+ const expFiles = readdirSync(searchDir).filter(f => f.startsWith('exploration-') && f.endsWith('.json') && f !== 'explorations-manifest.json');
168
+ if (expFiles.length > 0) {
169
+ // Create synthetic manifest
170
+ result.explorations.manifest = {
171
+ exploration_count: expFiles.length,
172
+ explorations: expFiles.map((f, i) => ({
173
+ angle: f.replace('exploration-', '').replace('.json', ''),
174
+ file: f,
175
+ index: i + 1
176
+ }))
177
+ };
178
+
179
+ // Load each file
180
+ for (const file of expFiles) {
181
+ const angle = file.replace('exploration-', '').replace('.json', '');
182
+ try {
183
+ result.explorations.data[angle] = JSON.parse(readFileSync(join(searchDir, file), 'utf8'));
184
+ } catch (e) {
185
+ // Skip unreadable files
186
+ }
187
+ }
188
+ }
189
+ } catch (e) {
190
+ // Directory read failed
191
+ }
192
+ }
193
+
194
+ // Fallback: scan for diagnosis-*.json files directly
195
+ if (!result.diagnoses.manifest) {
196
+ try {
197
+ const diagFiles = readdirSync(searchDir).filter(f => f.startsWith('diagnosis-') && f.endsWith('.json') && f !== 'diagnoses-manifest.json');
198
+ if (diagFiles.length > 0) {
199
+ // Create synthetic manifest
200
+ result.diagnoses.manifest = {
201
+ diagnosis_count: diagFiles.length,
202
+ diagnoses: diagFiles.map((f, i) => ({
203
+ angle: f.replace('diagnosis-', '').replace('.json', ''),
204
+ file: f,
205
+ index: i + 1
206
+ }))
207
+ };
208
+
209
+ // Load each file
210
+ for (const file of diagFiles) {
211
+ const angle = file.replace('diagnosis-', '').replace('.json', '');
212
+ try {
213
+ result.diagnoses.data[angle] = JSON.parse(readFileSync(join(searchDir, file), 'utf8'));
214
+ } catch (e) {
215
+ // Skip unreadable files
216
+ }
217
+ }
218
+ }
219
+ } catch (e) {
220
+ // Directory read failed
221
+ }
222
+ }
223
+
224
+ // If we found either explorations or diagnoses, break out of the loop
225
+ if (result.explorations.manifest || result.diagnoses.manifest) {
226
+ break;
227
+ }
228
+ }
229
+ }
230
+
231
+ // Load conflict resolution decisions (conflict-resolution-decisions.json)
232
+ if (dataType === 'context' || dataType === 'conflict' || dataType === 'all') {
233
+ result.conflictResolution = null;
234
+
235
+ // Try .process/ first (standard workflow sessions)
236
+ const conflictFiles = [
237
+ join(normalizedPath, '.process', 'conflict-resolution-decisions.json'),
238
+ join(normalizedPath, 'conflict-resolution-decisions.json')
239
+ ];
240
+
241
+ for (const conflictFile of conflictFiles) {
242
+ if (existsSync(conflictFile)) {
243
+ try {
244
+ result.conflictResolution = JSON.parse(readFileSync(conflictFile, 'utf8'));
245
+ break; // Found file, stop searching
246
+ } catch (e) {
247
+ // Skip unreadable file
248
+ }
249
+ }
250
+ }
251
+ }
252
+
253
+ // Load IMPL_PLAN.md
254
+ if (dataType === 'impl-plan' || dataType === 'all') {
255
+ const implPlanFile = join(normalizedPath, 'IMPL_PLAN.md');
256
+ if (existsSync(implPlanFile)) {
257
+ try {
258
+ result.implPlan = readFileSync(implPlanFile, 'utf8');
259
+ } catch (e) {
260
+ result.implPlan = null;
261
+ }
262
+ }
263
+ }
264
+
265
+ // Load review data from .review/
266
+ if (dataType === 'review' || dataType === 'all') {
267
+ const reviewDir = join(normalizedPath, '.review');
268
+ result.review = {
269
+ state: null,
270
+ dimensions: [],
271
+ severityDistribution: null,
272
+ totalFindings: 0
273
+ };
274
+
275
+ if (existsSync(reviewDir)) {
276
+ // Load review-state.json
277
+ const stateFile = join(reviewDir, 'review-state.json');
278
+ if (existsSync(stateFile)) {
279
+ try {
280
+ const state = JSON.parse(readFileSync(stateFile, 'utf8'));
281
+ result.review.state = state;
282
+ result.review.severityDistribution = state.severity_distribution || {};
283
+ result.review.totalFindings = state.total_findings || 0;
284
+ result.review.phase = state.phase || 'unknown';
285
+ result.review.dimensionSummaries = state.dimension_summaries || {};
286
+ result.review.crossCuttingConcerns = state.cross_cutting_concerns || [];
287
+ result.review.criticalFiles = state.critical_files || [];
288
+ } catch (e) {
289
+ // Skip unreadable state
290
+ }
291
+ }
292
+
293
+ // Load dimension findings
294
+ const dimensionsDir = join(reviewDir, 'dimensions');
295
+ if (existsSync(dimensionsDir)) {
296
+ const files = readdirSync(dimensionsDir).filter(f => f.endsWith('.json'));
297
+ for (const file of files) {
298
+ try {
299
+ const dimName = file.replace('.json', '');
300
+ const data = JSON.parse(readFileSync(join(dimensionsDir, file), 'utf8'));
301
+
302
+ // Handle array structure: [ { findings: [...] } ]
303
+ let findings = [];
304
+ let summary = null;
305
+
306
+ if (Array.isArray(data) && data.length > 0) {
307
+ const dimData = data[0];
308
+ findings = dimData.findings || [];
309
+ summary = dimData.summary || null;
310
+ } else if (data.findings) {
311
+ findings = data.findings;
312
+ summary = data.summary || null;
313
+ }
314
+
315
+ result.review.dimensions.push({
316
+ name: dimName,
317
+ findings: findings,
318
+ summary: summary,
319
+ count: findings.length
320
+ });
321
+ } catch (e) {
322
+ // Skip unreadable files
323
+ }
324
+ }
325
+ }
326
+ }
327
+ }
328
+
329
+ } catch (error: unknown) {
330
+ console.error('Error loading session detail:', error);
331
+ result.error = (error as Error).message;
332
+ }
333
+
334
+ return result;
335
+ }
336
+
337
+ /**
338
+ * Update task status in a task JSON file
339
+ * @param {string} sessionPath - Path to session directory
340
+ * @param {string} taskId - Task ID (e.g., IMPL-001)
341
+ * @param {string} newStatus - New status (pending, in_progress, completed)
342
+ * @returns {Promise<Object>}
343
+ */
344
+ async function updateTaskStatus(sessionPath, taskId, newStatus) {
345
+ // Normalize path (handle both forward and back slashes)
346
+ let normalizedPath = sessionPath.replace(/\\/g, '/');
347
+
348
+ // Handle Windows drive letter format
349
+ if (normalizedPath.match(/^[a-zA-Z]:\//)) {
350
+ // Already in correct format
351
+ } else if (normalizedPath.match(/^\/[a-zA-Z]\//)) {
352
+ // Convert /D/path to D:/path
353
+ normalizedPath = normalizedPath.charAt(1).toUpperCase() + ':' + normalizedPath.slice(2);
354
+ }
355
+
356
+ const taskDir = join(normalizedPath, '.task');
357
+
358
+ // Check if task directory exists
359
+ if (!existsSync(taskDir)) {
360
+ throw new Error(`Task directory not found: ${taskDir}`);
361
+ }
362
+
363
+ // Try to find the task file
364
+ let taskFile = join(taskDir, `${taskId}.json`);
365
+
366
+ if (!existsSync(taskFile)) {
367
+ // Try without .json if taskId already has it
368
+ if (taskId.endsWith('.json')) {
369
+ taskFile = join(taskDir, taskId);
370
+ }
371
+ if (!existsSync(taskFile)) {
372
+ throw new Error(`Task file not found: ${taskId}.json in ${taskDir}`);
373
+ }
374
+ }
375
+
376
+ try {
377
+ const content = JSON.parse(readFileSync(taskFile, 'utf8'));
378
+ const oldStatus = content.status || 'pending';
379
+ content.status = newStatus;
380
+
381
+ // Add status change timestamp
382
+ if (!content.status_history) {
383
+ content.status_history = [];
384
+ }
385
+ content.status_history.push({
386
+ from: oldStatus,
387
+ to: newStatus,
388
+ changed_at: new Date().toISOString()
389
+ });
390
+
391
+ writeFileSync(taskFile, JSON.stringify(content, null, 2), 'utf8');
392
+
393
+ return {
394
+ success: true,
395
+ taskId,
396
+ oldStatus,
397
+ newStatus,
398
+ file: taskFile
399
+ };
400
+ } catch (error: unknown) {
401
+ throw new Error(`Failed to update task ${taskId}: ${(error as Error).message}`);
402
+ }
403
+ }
404
+
405
+ /**
406
+ * Handle Session routes
407
+ * @returns true if route was handled, false otherwise
408
+ */
409
+ export async function handleSessionRoutes(ctx: RouteContext): Promise<boolean> {
410
+ const { pathname, url, req, res, handlePostRequest } = ctx;
411
+
412
+ // API: Get session detail data (context, summaries, impl-plan, review)
413
+ if (pathname === '/api/session-detail') {
414
+ const sessionPath = url.searchParams.get('path');
415
+ const dataType = url.searchParams.get('type') || 'all';
416
+
417
+ if (!sessionPath) {
418
+ res.writeHead(400, { 'Content-Type': 'application/json' });
419
+ res.end(JSON.stringify({ error: 'Session path is required' }));
420
+ return true;
421
+ }
422
+
423
+ const detail = await getSessionDetailData(sessionPath, dataType);
424
+ res.writeHead(200, { 'Content-Type': 'application/json' });
425
+ res.end(JSON.stringify(detail));
426
+ return true;
427
+ }
428
+
429
+ // API: Update task status
430
+ if (pathname === '/api/update-task-status' && req.method === 'POST') {
431
+ handlePostRequest(req, res, async (body) => {
432
+ const { sessionPath, taskId, newStatus } = body;
433
+
434
+ if (!sessionPath || !taskId || !newStatus) {
435
+ return { error: 'sessionPath, taskId, and newStatus are required', status: 400 };
436
+ }
437
+
438
+ return await updateTaskStatus(sessionPath, taskId, newStatus);
439
+ });
440
+ return true;
441
+ }
442
+
443
+ // API: Bulk update task status
444
+ if (pathname === '/api/bulk-update-task-status' && req.method === 'POST') {
445
+ handlePostRequest(req, res, async (body) => {
446
+ const { sessionPath, taskIds, newStatus } = body;
447
+
448
+ if (!sessionPath || !taskIds || !newStatus) {
449
+ return { error: 'sessionPath, taskIds, and newStatus are required', status: 400 };
450
+ }
451
+
452
+ const results = [];
453
+ for (const taskId of taskIds) {
454
+ try {
455
+ const result = await updateTaskStatus(sessionPath, taskId, newStatus);
456
+ results.push(result);
457
+ } catch (err) {
458
+ results.push({ taskId, error: err.message });
459
+ }
460
+ }
461
+ return { success: true, results };
462
+ });
463
+ return true;
464
+ }
465
+
466
+ return false;
467
+ }