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,605 @@
1
+ import * as http from 'http';
2
+ import { URL } from 'url';
3
+ import { getCoreMemoryStore } from '../core-memory-store.js';
4
+ import type { CoreMemory, SessionCluster, ClusterMember, ClusterRelation } from '../core-memory-store.js';
5
+ import { getEmbeddingStatus, generateEmbeddings } from '../memory-embedder-bridge.js';
6
+ import { checkSemanticStatus } from '../../tools/codex-lens.js';
7
+ import { StoragePaths } from '../../config/storage-paths.js';
8
+ import { join } from 'path';
9
+
10
+ /**
11
+ * Route context interface
12
+ */
13
+ interface RouteContext {
14
+ pathname: string;
15
+ url: URL;
16
+ req: http.IncomingMessage;
17
+ res: http.ServerResponse;
18
+ initialPath: string;
19
+ handlePostRequest: (req: http.IncomingMessage, res: http.ServerResponse, handler: (body: any) => Promise<any>) => void;
20
+ broadcastToClients: (data: any) => void;
21
+ }
22
+
23
+ /**
24
+ * Handle Core Memory API routes
25
+ * @returns true if route was handled, false otherwise
26
+ */
27
+ export async function handleCoreMemoryRoutes(ctx: RouteContext): Promise<boolean> {
28
+ const { pathname, url, req, res, initialPath, handlePostRequest, broadcastToClients } = ctx;
29
+
30
+ // API: Core Memory - Get all memories
31
+ if (pathname === '/api/core-memory/memories' && req.method === 'GET') {
32
+ const projectPath = url.searchParams.get('path') || initialPath;
33
+ const archived = url.searchParams.get('archived') === 'true';
34
+ const limit = parseInt(url.searchParams.get('limit') || '50', 10);
35
+ const offset = parseInt(url.searchParams.get('offset') || '0', 10);
36
+
37
+ try {
38
+ const store = getCoreMemoryStore(projectPath);
39
+ const memories = store.getMemories({ archived, limit, offset });
40
+
41
+ res.writeHead(200, { 'Content-Type': 'application/json' });
42
+ res.end(JSON.stringify({ success: true, memories }));
43
+ } catch (error: unknown) {
44
+ res.writeHead(500, { 'Content-Type': 'application/json' });
45
+ res.end(JSON.stringify({ error: (error as Error).message }));
46
+ }
47
+ return true;
48
+ }
49
+
50
+ // API: Core Memory - Get single memory
51
+ if (pathname.startsWith('/api/core-memory/memories/') && req.method === 'GET') {
52
+ const memoryId = pathname.replace('/api/core-memory/memories/', '');
53
+ const projectPath = url.searchParams.get('path') || initialPath;
54
+
55
+ try {
56
+ const store = getCoreMemoryStore(projectPath);
57
+ const memory = store.getMemory(memoryId);
58
+
59
+ if (memory) {
60
+ res.writeHead(200, { 'Content-Type': 'application/json' });
61
+ res.end(JSON.stringify({ success: true, memory }));
62
+ } else {
63
+ res.writeHead(404, { 'Content-Type': 'application/json' });
64
+ res.end(JSON.stringify({ error: 'Memory not found' }));
65
+ }
66
+ } catch (error: unknown) {
67
+ res.writeHead(500, { 'Content-Type': 'application/json' });
68
+ res.end(JSON.stringify({ error: (error as Error).message }));
69
+ }
70
+ return true;
71
+ }
72
+
73
+ // API: Core Memory - Create or update memory
74
+ if (pathname === '/api/core-memory/memories' && req.method === 'POST') {
75
+ handlePostRequest(req, res, async (body) => {
76
+ const { content, summary, raw_output, id, archived, metadata, path: projectPath } = body;
77
+
78
+ if (!content) {
79
+ return { error: 'content is required', status: 400 };
80
+ }
81
+
82
+ const basePath = projectPath || initialPath;
83
+
84
+ try {
85
+ const store = getCoreMemoryStore(basePath);
86
+ const memory = store.upsertMemory({
87
+ id,
88
+ content,
89
+ summary,
90
+ raw_output,
91
+ archived,
92
+ metadata: metadata ? JSON.stringify(metadata) : undefined
93
+ });
94
+
95
+ // Broadcast update event
96
+ broadcastToClients({
97
+ type: 'CORE_MEMORY_UPDATED',
98
+ payload: {
99
+ memory,
100
+ timestamp: new Date().toISOString()
101
+ }
102
+ });
103
+
104
+ return {
105
+ success: true,
106
+ memory
107
+ };
108
+ } catch (error: unknown) {
109
+ return { error: (error as Error).message, status: 500 };
110
+ }
111
+ });
112
+ return true;
113
+ }
114
+
115
+ // API: Core Memory - Archive memory
116
+ if (pathname.startsWith('/api/core-memory/memories/') && pathname.endsWith('/archive') && req.method === 'POST') {
117
+ const memoryId = pathname.replace('/api/core-memory/memories/', '').replace('/archive', '');
118
+ const projectPath = url.searchParams.get('path') || initialPath;
119
+
120
+ try {
121
+ const store = getCoreMemoryStore(projectPath);
122
+ store.archiveMemory(memoryId);
123
+
124
+ // Broadcast update event
125
+ broadcastToClients({
126
+ type: 'CORE_MEMORY_UPDATED',
127
+ payload: {
128
+ memoryId,
129
+ archived: true,
130
+ timestamp: new Date().toISOString()
131
+ }
132
+ });
133
+
134
+ res.writeHead(200, { 'Content-Type': 'application/json' });
135
+ res.end(JSON.stringify({ success: true }));
136
+ } catch (error: unknown) {
137
+ res.writeHead(500, { 'Content-Type': 'application/json' });
138
+ res.end(JSON.stringify({ error: (error as Error).message }));
139
+ }
140
+ return true;
141
+ }
142
+
143
+ // API: Core Memory - Delete memory
144
+ if (pathname.startsWith('/api/core-memory/memories/') && req.method === 'DELETE') {
145
+ const memoryId = pathname.replace('/api/core-memory/memories/', '');
146
+ const projectPath = url.searchParams.get('path') || initialPath;
147
+
148
+ try {
149
+ const store = getCoreMemoryStore(projectPath);
150
+ store.deleteMemory(memoryId);
151
+
152
+ // Broadcast update event
153
+ broadcastToClients({
154
+ type: 'CORE_MEMORY_UPDATED',
155
+ payload: {
156
+ memoryId,
157
+ deleted: true,
158
+ timestamp: new Date().toISOString()
159
+ }
160
+ });
161
+
162
+ res.writeHead(204, { 'Content-Type': 'application/json' });
163
+ res.end();
164
+ } catch (error: unknown) {
165
+ res.writeHead(500, { 'Content-Type': 'application/json' });
166
+ res.end(JSON.stringify({ error: (error as Error).message }));
167
+ }
168
+ return true;
169
+ }
170
+
171
+ // API: Core Memory - Generate summary
172
+ if (pathname.startsWith('/api/core-memory/memories/') && pathname.endsWith('/summary') && req.method === 'POST') {
173
+ const memoryId = pathname.replace('/api/core-memory/memories/', '').replace('/summary', '');
174
+
175
+ handlePostRequest(req, res, async (body) => {
176
+ const { tool = 'gemini', path: projectPath } = body;
177
+ const basePath = projectPath || initialPath;
178
+
179
+ try {
180
+ const store = getCoreMemoryStore(basePath);
181
+ const summary = await store.generateSummary(memoryId, tool);
182
+
183
+ // Broadcast update event
184
+ broadcastToClients({
185
+ type: 'CORE_MEMORY_UPDATED',
186
+ payload: {
187
+ memoryId,
188
+ summary,
189
+ timestamp: new Date().toISOString()
190
+ }
191
+ });
192
+
193
+ return {
194
+ success: true,
195
+ summary
196
+ };
197
+ } catch (error: unknown) {
198
+ return { error: (error as Error).message, status: 500 };
199
+ }
200
+ });
201
+ return true;
202
+ }
203
+
204
+ // ============================================================
205
+ // Session Clustering API Endpoints
206
+ // ============================================================
207
+
208
+ // API: Get all clusters
209
+ if (pathname === '/api/core-memory/clusters' && req.method === 'GET') {
210
+ const projectPath = url.searchParams.get('path') || initialPath;
211
+ const status = url.searchParams.get('status') || undefined;
212
+
213
+ try {
214
+ const store = getCoreMemoryStore(projectPath);
215
+ const clusters = store.listClusters(status);
216
+
217
+ // Add member count to each cluster
218
+ const clustersWithCount = clusters.map(c => ({
219
+ ...c,
220
+ memberCount: store.getClusterMembers(c.id).length
221
+ }));
222
+
223
+ res.writeHead(200, { 'Content-Type': 'application/json' });
224
+ res.end(JSON.stringify({ success: true, clusters: clustersWithCount }));
225
+ } catch (error: unknown) {
226
+ res.writeHead(500, { 'Content-Type': 'application/json' });
227
+ res.end(JSON.stringify({ error: (error as Error).message }));
228
+ }
229
+ return true;
230
+ }
231
+
232
+ // API: Get cluster detail with members
233
+ if (pathname.match(/^\/api\/core-memory\/clusters\/[^\/]+$/) && req.method === 'GET') {
234
+ const clusterId = pathname.split('/').pop()!;
235
+ const projectPath = url.searchParams.get('path') || initialPath;
236
+
237
+ try {
238
+ const store = getCoreMemoryStore(projectPath);
239
+ const cluster = store.getCluster(clusterId);
240
+
241
+ if (!cluster) {
242
+ res.writeHead(404, { 'Content-Type': 'application/json' });
243
+ res.end(JSON.stringify({ error: 'Cluster not found' }));
244
+ return true;
245
+ }
246
+
247
+ const members = store.getClusterMembers(clusterId);
248
+ const relations = store.getClusterRelations(clusterId);
249
+
250
+ // Get metadata for each member
251
+ const membersWithMetadata = members.map(m => ({
252
+ ...m,
253
+ metadata: store.getSessionMetadata(m.session_id)
254
+ }));
255
+
256
+ res.writeHead(200, { 'Content-Type': 'application/json' });
257
+ res.end(JSON.stringify({
258
+ success: true,
259
+ cluster,
260
+ members: membersWithMetadata,
261
+ relations
262
+ }));
263
+ } catch (error: unknown) {
264
+ res.writeHead(500, { 'Content-Type': 'application/json' });
265
+ res.end(JSON.stringify({ error: (error as Error).message }));
266
+ }
267
+ return true;
268
+ }
269
+
270
+ // API: Auto-cluster sessions
271
+ if (pathname === '/api/core-memory/clusters/auto' && req.method === 'POST') {
272
+ handlePostRequest(req, res, async (body) => {
273
+ const { scope = 'recent', minClusterSize = 2, path: projectPath } = body;
274
+ const basePath = projectPath || initialPath;
275
+
276
+ try {
277
+ const { SessionClusteringService } = await import('../session-clustering-service.js');
278
+ const service = new SessionClusteringService(basePath);
279
+
280
+ const validScope: 'all' | 'recent' | 'unclustered' =
281
+ scope === 'all' || scope === 'recent' || scope === 'unclustered' ? scope : 'recent';
282
+
283
+ const result = await service.autocluster({
284
+ scope: validScope,
285
+ minClusterSize
286
+ });
287
+
288
+ // Broadcast update event
289
+ broadcastToClients({
290
+ type: 'CLUSTERS_UPDATED',
291
+ payload: {
292
+ ...result,
293
+ timestamp: new Date().toISOString()
294
+ }
295
+ });
296
+
297
+ return {
298
+ success: true,
299
+ ...result
300
+ };
301
+ } catch (error: unknown) {
302
+ return { error: (error as Error).message, status: 500 };
303
+ }
304
+ });
305
+ return true;
306
+ }
307
+
308
+ // API: Get embedding status
309
+ if (pathname === '/api/core-memory/embed-status' && req.method === 'GET') {
310
+ const projectPath = url.searchParams.get('path') || initialPath;
311
+
312
+ try {
313
+ // Check semantic status using CodexLens's check (same as status page)
314
+ const semanticStatus = await checkSemanticStatus();
315
+
316
+ if (!semanticStatus.available) {
317
+ res.writeHead(200, { 'Content-Type': 'application/json' });
318
+ res.end(JSON.stringify({
319
+ available: false,
320
+ total_chunks: 0,
321
+ embedded_chunks: 0,
322
+ pending_chunks: 0,
323
+ by_type: {},
324
+ error: semanticStatus.error
325
+ }));
326
+ return true;
327
+ }
328
+
329
+ const paths = StoragePaths.project(projectPath);
330
+ const dbPath = join(paths.root, 'core-memory', 'core_memory.db');
331
+ const status = await getEmbeddingStatus(dbPath);
332
+
333
+ res.writeHead(200, { 'Content-Type': 'application/json' });
334
+ res.end(JSON.stringify({ ...status, available: true }));
335
+ } catch (error: unknown) {
336
+ // Return status with available=true even on error (embedder exists but query failed)
337
+ res.writeHead(200, { 'Content-Type': 'application/json' });
338
+ res.end(JSON.stringify({
339
+ available: true,
340
+ total_chunks: 0,
341
+ embedded_chunks: 0,
342
+ pending_chunks: 0,
343
+ by_type: {},
344
+ error: (error as Error).message
345
+ }));
346
+ }
347
+ return true;
348
+ }
349
+
350
+ // API: Generate embeddings
351
+ if (pathname === '/api/core-memory/embed' && req.method === 'POST') {
352
+ handlePostRequest(req, res, async (body) => {
353
+ const { sourceId, force, batchSize, path: projectPath } = body;
354
+ const basePath = projectPath || initialPath;
355
+
356
+ try {
357
+ // Check semantic status using CodexLens's check
358
+ const semanticStatus = await checkSemanticStatus();
359
+ if (!semanticStatus.available) {
360
+ return { error: semanticStatus.error || 'Semantic search not available. Install it from CLI > CodexLens > Semantic page.', status: 503 };
361
+ }
362
+
363
+ const paths = StoragePaths.project(basePath);
364
+ const dbPath = join(paths.root, 'core-memory', 'core_memory.db');
365
+
366
+ const result = await generateEmbeddings(dbPath, {
367
+ sourceId,
368
+ force: force || false,
369
+ batchSize: batchSize || 8
370
+ });
371
+
372
+ return {
373
+ success: result.success,
374
+ chunks_processed: result.chunks_processed,
375
+ elapsed_time: result.elapsed_time
376
+ };
377
+ } catch (error: unknown) {
378
+ return { error: (error as Error).message, status: 500 };
379
+ }
380
+ });
381
+ return true;
382
+ }
383
+
384
+ // API: Create new cluster
385
+ if (pathname === '/api/core-memory/clusters' && req.method === 'POST') {
386
+ handlePostRequest(req, res, async (body) => {
387
+ const { name, description, intent, metadata, path: projectPath } = body;
388
+
389
+ if (!name) {
390
+ return { error: 'name is required', status: 400 };
391
+ }
392
+
393
+ const basePath = projectPath || initialPath;
394
+
395
+ try {
396
+ const store = getCoreMemoryStore(basePath);
397
+ const cluster = store.createCluster({
398
+ name,
399
+ description,
400
+ intent,
401
+ metadata: metadata ? JSON.stringify(metadata) : undefined
402
+ });
403
+
404
+ // Broadcast update event
405
+ broadcastToClients({
406
+ type: 'CLUSTER_UPDATED',
407
+ payload: {
408
+ cluster,
409
+ timestamp: new Date().toISOString()
410
+ }
411
+ });
412
+
413
+ return {
414
+ success: true,
415
+ cluster
416
+ };
417
+ } catch (error: unknown) {
418
+ return { error: (error as Error).message, status: 500 };
419
+ }
420
+ });
421
+ return true;
422
+ }
423
+
424
+ // API: Update cluster (supports both PUT and PATCH)
425
+ if (pathname.match(/^\/api\/core-memory\/clusters\/[^\/]+$/) && (req.method === 'PUT' || req.method === 'PATCH')) {
426
+ const clusterId = pathname.split('/').pop()!;
427
+
428
+ handlePostRequest(req, res, async (body) => {
429
+ const { name, description, intent, status, metadata, path: projectPath } = body;
430
+ const basePath = projectPath || initialPath;
431
+
432
+ try {
433
+ const store = getCoreMemoryStore(basePath);
434
+ const cluster = store.updateCluster(clusterId, {
435
+ name,
436
+ description,
437
+ intent,
438
+ status,
439
+ metadata: metadata ? JSON.stringify(metadata) : undefined
440
+ });
441
+
442
+ if (!cluster) {
443
+ return { error: 'Cluster not found', status: 404 };
444
+ }
445
+
446
+ // Broadcast update event
447
+ broadcastToClients({
448
+ type: 'CLUSTER_UPDATED',
449
+ payload: {
450
+ cluster,
451
+ timestamp: new Date().toISOString()
452
+ }
453
+ });
454
+
455
+ return {
456
+ success: true,
457
+ cluster
458
+ };
459
+ } catch (error: unknown) {
460
+ return { error: (error as Error).message, status: 500 };
461
+ }
462
+ });
463
+ return true;
464
+ }
465
+
466
+ // API: Delete cluster
467
+ if (pathname.match(/^\/api\/core-memory\/clusters\/[^\/]+$/) && req.method === 'DELETE') {
468
+ const clusterId = pathname.split('/').pop()!;
469
+ const projectPath = url.searchParams.get('path') || initialPath;
470
+
471
+ try {
472
+ const store = getCoreMemoryStore(projectPath);
473
+ const deleted = store.deleteCluster(clusterId);
474
+
475
+ if (!deleted) {
476
+ res.writeHead(404, { 'Content-Type': 'application/json' });
477
+ res.end(JSON.stringify({ error: 'Cluster not found' }));
478
+ return true;
479
+ }
480
+
481
+ // Broadcast update event
482
+ broadcastToClients({
483
+ type: 'CLUSTER_UPDATED',
484
+ payload: {
485
+ clusterId,
486
+ deleted: true,
487
+ timestamp: new Date().toISOString()
488
+ }
489
+ });
490
+
491
+ res.writeHead(204, { 'Content-Type': 'application/json' });
492
+ res.end();
493
+ } catch (error: unknown) {
494
+ res.writeHead(500, { 'Content-Type': 'application/json' });
495
+ res.end(JSON.stringify({ error: (error as Error).message }));
496
+ }
497
+ return true;
498
+ }
499
+
500
+ // API: Add member to cluster
501
+ if (pathname.match(/^\/api\/core-memory\/clusters\/[^\/]+\/members$/) && req.method === 'POST') {
502
+ const clusterId = pathname.split('/')[4];
503
+
504
+ handlePostRequest(req, res, async (body) => {
505
+ const { session_id, session_type, sequence_order, relevance_score, path: projectPath } = body;
506
+
507
+ if (!session_id || !session_type) {
508
+ return { error: 'session_id and session_type are required', status: 400 };
509
+ }
510
+
511
+ const basePath = projectPath || initialPath;
512
+
513
+ try {
514
+ const store = getCoreMemoryStore(basePath);
515
+ const member = store.addClusterMember({
516
+ cluster_id: clusterId,
517
+ session_id,
518
+ session_type,
519
+ sequence_order: sequence_order ?? 0,
520
+ relevance_score: relevance_score ?? 1.0
521
+ });
522
+
523
+ // Broadcast update event
524
+ broadcastToClients({
525
+ type: 'CLUSTER_UPDATED',
526
+ payload: {
527
+ clusterId,
528
+ member,
529
+ timestamp: new Date().toISOString()
530
+ }
531
+ });
532
+
533
+ return {
534
+ success: true,
535
+ member
536
+ };
537
+ } catch (error: unknown) {
538
+ return { error: (error as Error).message, status: 500 };
539
+ }
540
+ });
541
+ return true;
542
+ }
543
+
544
+ // API: Remove member from cluster
545
+ if (pathname.match(/^\/api\/core-memory\/clusters\/[^\/]+\/members\/[^\/]+$/) && req.method === 'DELETE') {
546
+ const parts = pathname.split('/');
547
+ const clusterId = parts[4];
548
+ const sessionId = parts[6];
549
+ const projectPath = url.searchParams.get('path') || initialPath;
550
+
551
+ try {
552
+ const store = getCoreMemoryStore(projectPath);
553
+ const removed = store.removeClusterMember(clusterId, sessionId);
554
+
555
+ if (!removed) {
556
+ res.writeHead(404, { 'Content-Type': 'application/json' });
557
+ res.end(JSON.stringify({ error: 'Member not found' }));
558
+ return true;
559
+ }
560
+
561
+ // Broadcast update event
562
+ broadcastToClients({
563
+ type: 'CLUSTER_UPDATED',
564
+ payload: {
565
+ clusterId,
566
+ removedSessionId: sessionId,
567
+ timestamp: new Date().toISOString()
568
+ }
569
+ });
570
+
571
+ res.writeHead(204, { 'Content-Type': 'application/json' });
572
+ res.end();
573
+ } catch (error: unknown) {
574
+ res.writeHead(500, { 'Content-Type': 'application/json' });
575
+ res.end(JSON.stringify({ error: (error as Error).message }));
576
+ }
577
+ return true;
578
+ }
579
+
580
+ // API: Search sessions by keyword
581
+ if (pathname === '/api/core-memory/sessions/search' && req.method === 'GET') {
582
+ const keyword = url.searchParams.get('q') || '';
583
+ const projectPath = url.searchParams.get('path') || initialPath;
584
+
585
+ if (!keyword) {
586
+ res.writeHead(400, { 'Content-Type': 'application/json' });
587
+ res.end(JSON.stringify({ error: 'Query parameter q is required' }));
588
+ return true;
589
+ }
590
+
591
+ try {
592
+ const store = getCoreMemoryStore(projectPath);
593
+ const results = store.searchSessionsByKeyword(keyword);
594
+
595
+ res.writeHead(200, { 'Content-Type': 'application/json' });
596
+ res.end(JSON.stringify({ success: true, results }));
597
+ } catch (error: unknown) {
598
+ res.writeHead(500, { 'Content-Type': 'application/json' });
599
+ res.end(JSON.stringify({ error: (error as Error).message }));
600
+ }
601
+ return true;
602
+ }
603
+
604
+ return false;
605
+ }