claude-code-workflow 6.1.4 → 6.2.1

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 (879) hide show
  1. package/README.md +145 -274
  2. package/bin/ccw-mcp.js +7 -0
  3. package/bin/ccw.js +10 -0
  4. package/dist/cli.d.ts +2 -0
  5. package/dist/cli.d.ts.map +1 -0
  6. package/dist/cli.js +219 -0
  7. package/dist/cli.js.map +1 -0
  8. package/dist/commands/cli.d.ts +32 -0
  9. package/dist/commands/cli.d.ts.map +1 -0
  10. package/dist/commands/cli.js +619 -0
  11. package/dist/commands/cli.js.map +1 -0
  12. package/dist/commands/core-memory.d.ts +32 -0
  13. package/dist/commands/core-memory.d.ts.map +1 -0
  14. package/dist/commands/core-memory.js +640 -0
  15. package/dist/commands/core-memory.js.map +1 -0
  16. package/dist/commands/hook.d.ts +16 -0
  17. package/dist/commands/hook.d.ts.map +1 -0
  18. package/dist/commands/hook.js +276 -0
  19. package/dist/commands/hook.js.map +1 -0
  20. package/dist/commands/install.d.ts +12 -0
  21. package/dist/commands/install.d.ts.map +1 -0
  22. package/dist/commands/install.js +443 -0
  23. package/dist/commands/install.js.map +1 -0
  24. package/dist/commands/list.d.ts +5 -0
  25. package/dist/commands/list.d.ts.map +1 -0
  26. package/dist/commands/list.js +32 -0
  27. package/dist/commands/list.js.map +1 -0
  28. package/dist/commands/memory.d.ts +57 -0
  29. package/dist/commands/memory.d.ts.map +1 -0
  30. package/dist/commands/memory.js +890 -0
  31. package/dist/commands/memory.js.map +1 -0
  32. package/dist/commands/serve.d.ts +12 -0
  33. package/dist/commands/serve.d.ts.map +1 -0
  34. package/dist/commands/serve.js +63 -0
  35. package/dist/commands/serve.js.map +1 -0
  36. package/dist/commands/session-path-resolver.d.ts +45 -0
  37. package/dist/commands/session-path-resolver.d.ts.map +1 -0
  38. package/dist/commands/session-path-resolver.js +302 -0
  39. package/dist/commands/session-path-resolver.js.map +1 -0
  40. package/dist/commands/session.d.ts +12 -0
  41. package/dist/commands/session.d.ts.map +1 -0
  42. package/dist/commands/session.js +954 -0
  43. package/dist/commands/session.js.map +1 -0
  44. package/dist/commands/stop.d.ts +11 -0
  45. package/dist/commands/stop.d.ts.map +1 -0
  46. package/dist/commands/stop.js +96 -0
  47. package/dist/commands/stop.js.map +1 -0
  48. package/dist/commands/tool.d.ts +29 -0
  49. package/dist/commands/tool.d.ts.map +1 -0
  50. package/dist/commands/tool.js +173 -0
  51. package/dist/commands/tool.js.map +1 -0
  52. package/dist/commands/uninstall.d.ts +9 -0
  53. package/dist/commands/uninstall.d.ts.map +1 -0
  54. package/dist/commands/uninstall.js +239 -0
  55. package/dist/commands/uninstall.js.map +1 -0
  56. package/dist/commands/upgrade.d.ts +10 -0
  57. package/dist/commands/upgrade.d.ts.map +1 -0
  58. package/dist/commands/upgrade.js +288 -0
  59. package/dist/commands/upgrade.js.map +1 -0
  60. package/dist/commands/view.d.ts +14 -0
  61. package/dist/commands/view.d.ts.map +1 -0
  62. package/dist/commands/view.js +100 -0
  63. package/dist/commands/view.js.map +1 -0
  64. package/dist/config/storage-paths.d.ts +184 -0
  65. package/dist/config/storage-paths.d.ts.map +1 -0
  66. package/dist/config/storage-paths.js +536 -0
  67. package/dist/config/storage-paths.js.map +1 -0
  68. package/dist/core/cache-manager.d.ts +80 -0
  69. package/dist/core/cache-manager.d.ts.map +1 -0
  70. package/dist/core/cache-manager.js +260 -0
  71. package/dist/core/cache-manager.js.map +1 -0
  72. package/dist/core/claude-freshness.d.ts +53 -0
  73. package/dist/core/claude-freshness.d.ts.map +1 -0
  74. package/dist/core/claude-freshness.js +232 -0
  75. package/dist/core/claude-freshness.js.map +1 -0
  76. package/dist/core/core-memory-store.d.ts +320 -0
  77. package/dist/core/core-memory-store.d.ts.map +1 -0
  78. package/dist/core/core-memory-store.js +1177 -0
  79. package/dist/core/core-memory-store.js.map +1 -0
  80. package/dist/core/dashboard-generator-patch.d.ts +2 -0
  81. package/dist/core/dashboard-generator-patch.d.ts.map +1 -0
  82. package/dist/core/dashboard-generator-patch.js +48 -0
  83. package/dist/core/dashboard-generator-patch.js.map +1 -0
  84. package/dist/core/dashboard-generator.d.ts +8 -0
  85. package/dist/core/dashboard-generator.d.ts.map +1 -0
  86. package/dist/core/dashboard-generator.js +695 -0
  87. package/dist/core/dashboard-generator.js.map +1 -0
  88. package/dist/core/data-aggregator.d.ts +145 -0
  89. package/dist/core/data-aggregator.d.ts.map +1 -0
  90. package/dist/core/data-aggregator.js +416 -0
  91. package/dist/core/data-aggregator.js.map +1 -0
  92. package/dist/core/history-importer.d.ts +102 -0
  93. package/dist/core/history-importer.d.ts.map +1 -0
  94. package/dist/core/history-importer.js +493 -0
  95. package/dist/core/history-importer.js.map +1 -0
  96. package/dist/core/lite-scanner-complete.d.ts +81 -0
  97. package/dist/core/lite-scanner-complete.d.ts.map +1 -0
  98. package/dist/core/lite-scanner-complete.js +368 -0
  99. package/dist/core/lite-scanner-complete.js.map +1 -0
  100. package/dist/core/lite-scanner.d.ts +81 -0
  101. package/dist/core/lite-scanner.d.ts.map +1 -0
  102. package/dist/core/lite-scanner.js +368 -0
  103. package/dist/core/lite-scanner.js.map +1 -0
  104. package/dist/core/manifest.d.ts +88 -0
  105. package/dist/core/manifest.d.ts.map +1 -0
  106. package/dist/core/manifest.js +214 -0
  107. package/dist/core/manifest.js.map +1 -0
  108. package/dist/core/memory-embedder-bridge.d.ts +83 -0
  109. package/dist/core/memory-embedder-bridge.d.ts.map +1 -0
  110. package/dist/core/memory-embedder-bridge.js +181 -0
  111. package/dist/core/memory-embedder-bridge.js.map +1 -0
  112. package/dist/core/memory-store.d.ts +249 -0
  113. package/dist/core/memory-store.d.ts.map +1 -0
  114. package/dist/core/memory-store.js +781 -0
  115. package/dist/core/memory-store.js.map +1 -0
  116. package/dist/core/routes/ccw-routes.d.ts +20 -0
  117. package/dist/core/routes/ccw-routes.d.ts.map +1 -0
  118. package/dist/core/routes/ccw-routes.js +70 -0
  119. package/dist/core/routes/ccw-routes.js.map +1 -0
  120. package/dist/core/routes/claude-routes.d.ts +19 -0
  121. package/dist/core/routes/claude-routes.d.ts.map +1 -0
  122. package/dist/core/routes/claude-routes.js +1017 -0
  123. package/dist/core/routes/claude-routes.js.map +1 -0
  124. package/dist/core/routes/cli-routes.d.ts +20 -0
  125. package/dist/core/routes/cli-routes.d.ts.map +1 -0
  126. package/dist/core/routes/cli-routes.js +468 -0
  127. package/dist/core/routes/cli-routes.js.map +1 -0
  128. package/dist/core/routes/codexlens-routes.d.ts +20 -0
  129. package/dist/core/routes/codexlens-routes.d.ts.map +1 -0
  130. package/dist/core/routes/codexlens-routes.js +754 -0
  131. package/dist/core/routes/codexlens-routes.js.map +1 -0
  132. package/dist/core/routes/core-memory-routes.d.ts +21 -0
  133. package/dist/core/routes/core-memory-routes.d.ts.map +1 -0
  134. package/dist/core/routes/core-memory-routes.js +520 -0
  135. package/dist/core/routes/core-memory-routes.js.map +1 -0
  136. package/dist/core/routes/files-routes.d.ts +20 -0
  137. package/dist/core/routes/files-routes.d.ts.map +1 -0
  138. package/dist/core/routes/files-routes.js +374 -0
  139. package/dist/core/routes/files-routes.js.map +1 -0
  140. package/dist/core/routes/graph-routes.d.ts +20 -0
  141. package/dist/core/routes/graph-routes.d.ts.map +1 -0
  142. package/dist/core/routes/graph-routes.js +517 -0
  143. package/dist/core/routes/graph-routes.js.map +1 -0
  144. package/dist/core/routes/help-routes.d.ts +20 -0
  145. package/dist/core/routes/help-routes.d.ts.map +1 -0
  146. package/dist/core/routes/help-routes.js +250 -0
  147. package/dist/core/routes/help-routes.js.map +1 -0
  148. package/dist/core/routes/hooks-routes.d.ts +21 -0
  149. package/dist/core/routes/hooks-routes.d.ts.map +1 -0
  150. package/dist/core/routes/hooks-routes.js +346 -0
  151. package/dist/core/routes/hooks-routes.js.map +1 -0
  152. package/dist/core/routes/mcp-routes.d.ts +20 -0
  153. package/dist/core/routes/mcp-routes.d.ts.map +1 -0
  154. package/dist/core/routes/mcp-routes.js +1129 -0
  155. package/dist/core/routes/mcp-routes.js.map +1 -0
  156. package/dist/core/routes/mcp-templates-db.d.ts +54 -0
  157. package/dist/core/routes/mcp-templates-db.d.ts.map +1 -0
  158. package/dist/core/routes/mcp-templates-db.js +226 -0
  159. package/dist/core/routes/mcp-templates-db.js.map +1 -0
  160. package/dist/core/routes/memory-routes.d.ts +21 -0
  161. package/dist/core/routes/memory-routes.d.ts.map +1 -0
  162. package/dist/core/routes/memory-routes.js +1095 -0
  163. package/dist/core/routes/memory-routes.js.map +1 -0
  164. package/dist/core/routes/rules-routes.d.ts +20 -0
  165. package/dist/core/routes/rules-routes.d.ts.map +1 -0
  166. package/dist/core/routes/rules-routes.js +442 -0
  167. package/dist/core/routes/rules-routes.js.map +1 -0
  168. package/dist/core/routes/session-routes.d.ts +20 -0
  169. package/dist/core/routes/session-routes.d.ts.map +1 -0
  170. package/dist/core/routes/session-routes.js +423 -0
  171. package/dist/core/routes/session-routes.js.map +1 -0
  172. package/dist/core/routes/skills-routes.d.ts +20 -0
  173. package/dist/core/routes/skills-routes.d.ts.map +1 -0
  174. package/dist/core/routes/skills-routes.js +533 -0
  175. package/dist/core/routes/skills-routes.js.map +1 -0
  176. package/dist/core/routes/status-routes.d.ts +20 -0
  177. package/dist/core/routes/status-routes.d.ts.map +1 -0
  178. package/dist/core/routes/status-routes.js +38 -0
  179. package/dist/core/routes/status-routes.js.map +1 -0
  180. package/dist/core/routes/system-routes.d.ts +22 -0
  181. package/dist/core/routes/system-routes.d.ts.map +1 -0
  182. package/dist/core/routes/system-routes.js +354 -0
  183. package/dist/core/routes/system-routes.js.map +1 -0
  184. package/dist/core/server.d.ts +17 -0
  185. package/dist/core/server.d.ts.map +1 -0
  186. package/dist/core/server.js +386 -0
  187. package/dist/core/server.js.map +1 -0
  188. package/dist/core/session-clustering-service.d.ts +153 -0
  189. package/dist/core/session-clustering-service.d.ts.map +1 -0
  190. package/dist/core/session-clustering-service.js +1065 -0
  191. package/dist/core/session-clustering-service.js.map +1 -0
  192. package/dist/core/session-scanner.d.ts +32 -0
  193. package/dist/core/session-scanner.d.ts.map +1 -0
  194. package/dist/core/session-scanner.js +253 -0
  195. package/dist/core/session-scanner.js.map +1 -0
  196. package/dist/core/websocket.d.ts +23 -0
  197. package/dist/core/websocket.d.ts.map +1 -0
  198. package/dist/core/websocket.js +168 -0
  199. package/dist/core/websocket.js.map +1 -0
  200. package/dist/index.d.ts +10 -0
  201. package/dist/index.d.ts.map +1 -0
  202. package/dist/index.js +10 -0
  203. package/dist/index.js.map +1 -0
  204. package/dist/mcp-server/index.d.ts +7 -0
  205. package/dist/mcp-server/index.d.ts.map +1 -0
  206. package/dist/mcp-server/index.js +157 -0
  207. package/dist/mcp-server/index.js.map +1 -0
  208. package/dist/tools/classify-folders.d.ts +26 -0
  209. package/dist/tools/classify-folders.d.ts.map +1 -0
  210. package/dist/tools/classify-folders.js +201 -0
  211. package/dist/tools/classify-folders.js.map +1 -0
  212. package/dist/tools/cli-config-manager.d.ts +62 -0
  213. package/dist/tools/cli-config-manager.d.ts.map +1 -0
  214. package/dist/tools/cli-config-manager.js +221 -0
  215. package/dist/tools/cli-config-manager.js.map +1 -0
  216. package/dist/tools/cli-executor.d.ts +373 -0
  217. package/dist/tools/cli-executor.d.ts.map +1 -0
  218. package/dist/tools/cli-executor.js +1625 -0
  219. package/dist/tools/cli-executor.js.map +1 -0
  220. package/dist/tools/cli-history-store.d.ts +330 -0
  221. package/dist/tools/cli-history-store.d.ts.map +1 -0
  222. package/dist/tools/cli-history-store.js +916 -0
  223. package/dist/tools/cli-history-store.js.map +1 -0
  224. package/dist/tools/codex-lens.d.ts +118 -0
  225. package/dist/tools/codex-lens.d.ts.map +1 -0
  226. package/dist/tools/codex-lens.js +962 -0
  227. package/dist/tools/codex-lens.js.map +1 -0
  228. package/dist/tools/convert-tokens-to-css.d.ts +14 -0
  229. package/dist/tools/convert-tokens-to-css.d.ts.map +1 -0
  230. package/dist/tools/convert-tokens-to-css.js +244 -0
  231. package/dist/tools/convert-tokens-to-css.js.map +1 -0
  232. package/dist/tools/core-memory.d.ts +66 -0
  233. package/dist/tools/core-memory.d.ts.map +1 -0
  234. package/dist/tools/core-memory.js +324 -0
  235. package/dist/tools/core-memory.js.map +1 -0
  236. package/dist/tools/detect-changed-modules.d.ts +24 -0
  237. package/dist/tools/detect-changed-modules.d.ts.map +1 -0
  238. package/dist/tools/detect-changed-modules.js +277 -0
  239. package/dist/tools/detect-changed-modules.js.map +1 -0
  240. package/dist/tools/discover-design-files.d.ts +36 -0
  241. package/dist/tools/discover-design-files.d.ts.map +1 -0
  242. package/dist/tools/discover-design-files.js +147 -0
  243. package/dist/tools/discover-design-files.js.map +1 -0
  244. package/dist/tools/edit-file.d.ts +28 -0
  245. package/dist/tools/edit-file.d.ts.map +1 -0
  246. package/dist/tools/edit-file.js +479 -0
  247. package/dist/tools/edit-file.js.map +1 -0
  248. package/dist/tools/generate-module-docs.d.ts +22 -0
  249. package/dist/tools/generate-module-docs.d.ts.map +1 -0
  250. package/dist/tools/generate-module-docs.js +379 -0
  251. package/dist/tools/generate-module-docs.js.map +1 -0
  252. package/dist/tools/get-modules-by-depth.d.ts +15 -0
  253. package/dist/tools/get-modules-by-depth.d.ts.map +1 -0
  254. package/dist/tools/get-modules-by-depth.js +296 -0
  255. package/dist/tools/get-modules-by-depth.js.map +1 -0
  256. package/dist/tools/index.d.ts +55 -0
  257. package/dist/tools/index.d.ts.map +1 -0
  258. package/dist/tools/index.js +304 -0
  259. package/dist/tools/index.js.map +1 -0
  260. package/dist/tools/native-session-discovery.d.ts +97 -0
  261. package/dist/tools/native-session-discovery.d.ts.map +1 -0
  262. package/dist/tools/native-session-discovery.js +700 -0
  263. package/dist/tools/native-session-discovery.js.map +1 -0
  264. package/dist/tools/notifier.d.ts +50 -0
  265. package/dist/tools/notifier.d.ts.map +1 -0
  266. package/dist/tools/notifier.js +90 -0
  267. package/dist/tools/notifier.js.map +1 -0
  268. package/dist/tools/read-file.d.ts +32 -0
  269. package/dist/tools/read-file.d.ts.map +1 -0
  270. package/dist/tools/read-file.js +329 -0
  271. package/dist/tools/read-file.js.map +1 -0
  272. package/dist/tools/resume-strategy.d.ts +48 -0
  273. package/dist/tools/resume-strategy.d.ts.map +1 -0
  274. package/dist/tools/resume-strategy.js +248 -0
  275. package/dist/tools/resume-strategy.js.map +1 -0
  276. package/dist/tools/session-content-parser.d.ts +58 -0
  277. package/dist/tools/session-content-parser.d.ts.map +1 -0
  278. package/dist/tools/session-content-parser.js +420 -0
  279. package/dist/tools/session-content-parser.js.map +1 -0
  280. package/dist/tools/session-manager.d.ts +9 -0
  281. package/dist/tools/session-manager.d.ts.map +1 -0
  282. package/dist/tools/session-manager.js +834 -0
  283. package/dist/tools/session-manager.js.map +1 -0
  284. package/dist/tools/smart-context.d.ts +35 -0
  285. package/dist/tools/smart-context.d.ts.map +1 -0
  286. package/dist/tools/smart-context.js +182 -0
  287. package/dist/tools/smart-context.js.map +1 -0
  288. package/dist/tools/smart-search.d.ts +105 -0
  289. package/dist/tools/smart-search.d.ts.map +1 -0
  290. package/dist/tools/smart-search.js +1753 -0
  291. package/dist/tools/smart-search.js.map +1 -0
  292. package/dist/tools/storage-manager.d.ts +114 -0
  293. package/dist/tools/storage-manager.d.ts.map +1 -0
  294. package/dist/tools/storage-manager.js +392 -0
  295. package/dist/tools/storage-manager.js.map +1 -0
  296. package/dist/tools/ui-generate-preview.d.ts +39 -0
  297. package/dist/tools/ui-generate-preview.d.ts.map +1 -0
  298. package/dist/tools/ui-generate-preview.js +300 -0
  299. package/dist/tools/ui-generate-preview.js.map +1 -0
  300. package/dist/tools/ui-instantiate-prototypes.d.ts +75 -0
  301. package/dist/tools/ui-instantiate-prototypes.d.ts.map +1 -0
  302. package/dist/tools/ui-instantiate-prototypes.js +256 -0
  303. package/dist/tools/ui-instantiate-prototypes.js.map +1 -0
  304. package/dist/tools/update-module-claude.d.ts +80 -0
  305. package/dist/tools/update-module-claude.d.ts.map +1 -0
  306. package/dist/tools/update-module-claude.js +351 -0
  307. package/dist/tools/update-module-claude.js.map +1 -0
  308. package/dist/tools/write-file.d.ts +19 -0
  309. package/dist/tools/write-file.d.ts.map +1 -0
  310. package/dist/tools/write-file.js +193 -0
  311. package/dist/tools/write-file.js.map +1 -0
  312. package/dist/types/config.d.ts +11 -0
  313. package/dist/types/config.d.ts.map +1 -0
  314. package/dist/types/config.js +2 -0
  315. package/dist/types/config.js.map +1 -0
  316. package/dist/types/index.d.ts +4 -0
  317. package/dist/types/index.d.ts.map +1 -0
  318. package/dist/types/index.js +4 -0
  319. package/dist/types/index.js.map +1 -0
  320. package/dist/types/session.d.ts +20 -0
  321. package/dist/types/session.d.ts.map +1 -0
  322. package/dist/types/session.js +2 -0
  323. package/dist/types/session.js.map +1 -0
  324. package/dist/types/tool.d.ts +36 -0
  325. package/dist/types/tool.d.ts.map +1 -0
  326. package/dist/types/tool.js +11 -0
  327. package/dist/types/tool.js.map +1 -0
  328. package/dist/utils/browser-launcher.d.ts +13 -0
  329. package/dist/utils/browser-launcher.d.ts.map +1 -0
  330. package/dist/utils/browser-launcher.js +60 -0
  331. package/dist/utils/browser-launcher.js.map +1 -0
  332. package/dist/utils/file-utils.d.ts +25 -0
  333. package/dist/utils/file-utils.d.ts.map +1 -0
  334. package/dist/utils/file-utils.js +48 -0
  335. package/dist/utils/file-utils.js.map +1 -0
  336. package/dist/utils/path-resolver.d.ts +80 -0
  337. package/dist/utils/path-resolver.d.ts.map +1 -0
  338. package/dist/utils/path-resolver.js +260 -0
  339. package/dist/utils/path-resolver.js.map +1 -0
  340. package/dist/utils/path-validator.d.ts +49 -0
  341. package/dist/utils/path-validator.d.ts.map +1 -0
  342. package/dist/utils/path-validator.js +123 -0
  343. package/dist/utils/path-validator.js.map +1 -0
  344. package/dist/utils/ui.d.ts +62 -0
  345. package/dist/utils/ui.d.ts.map +1 -0
  346. package/dist/utils/ui.js +129 -0
  347. package/dist/utils/ui.js.map +1 -0
  348. package/package.json +32 -34
  349. package/src/.workflow/.cli-history/history.db +0 -0
  350. package/src/.workflow/.cli-history/history.db-shm +0 -0
  351. package/src/.workflow/.cli-history/history.db-wal +0 -0
  352. package/src/cli.ts +244 -0
  353. package/src/commands/cli.ts +740 -0
  354. package/src/commands/core-memory.ts +770 -0
  355. package/src/commands/hook.ts +315 -0
  356. package/src/commands/install.ts +519 -0
  357. package/src/commands/list.ts +37 -0
  358. package/src/commands/memory.ts +1090 -0
  359. package/src/commands/serve.ts +76 -0
  360. package/src/commands/session-path-resolver.ts +372 -0
  361. package/src/commands/session.ts +1141 -0
  362. package/src/commands/stop.ts +111 -0
  363. package/src/commands/tool.ts +201 -0
  364. package/src/commands/uninstall.ts +287 -0
  365. package/src/commands/upgrade.ts +352 -0
  366. package/src/commands/view.ts +119 -0
  367. package/src/config/storage-paths.ts +670 -0
  368. package/src/core/cache-manager.ts +294 -0
  369. package/src/core/claude-freshness.ts +319 -0
  370. package/src/core/core-memory-store.ts +1528 -0
  371. package/src/core/dashboard-generator-patch.ts +47 -0
  372. package/src/core/dashboard-generator.ts +739 -0
  373. package/src/core/data-aggregator.ts +584 -0
  374. package/src/core/history-importer.ts +625 -0
  375. package/src/core/lite-scanner-complete.ts +469 -0
  376. package/src/core/lite-scanner.ts +469 -0
  377. package/src/core/manifest.ts +271 -0
  378. package/src/core/memory-embedder-bridge.ts +262 -0
  379. package/src/core/memory-store.ts +978 -0
  380. package/src/core/routes/ccw-routes.ts +96 -0
  381. package/src/core/routes/claude-routes.ts +1183 -0
  382. package/src/core/routes/cli-routes.ts +561 -0
  383. package/src/core/routes/codexlens-routes.ts +806 -0
  384. package/src/core/routes/core-memory-routes.ts +605 -0
  385. package/src/core/routes/files-routes.ts +428 -0
  386. package/src/core/routes/graph-routes.md +164 -0
  387. package/src/core/routes/graph-routes.ts +626 -0
  388. package/src/core/routes/help-routes.ts +308 -0
  389. package/src/core/routes/hooks-routes.ts +405 -0
  390. package/src/core/routes/mcp-routes.ts +1271 -0
  391. package/src/core/routes/mcp-routes.ts.backup +550 -0
  392. package/src/core/routes/mcp-templates-db.ts +268 -0
  393. package/src/core/routes/memory-routes.ts +1206 -0
  394. package/src/core/routes/rules-routes.ts +526 -0
  395. package/src/core/routes/session-routes.ts +467 -0
  396. package/src/core/routes/skills-routes.ts +599 -0
  397. package/src/core/routes/status-routes.ts +57 -0
  398. package/src/core/routes/system-routes.ts +427 -0
  399. package/src/core/server.ts +431 -0
  400. package/src/core/session-clustering-service.ts +1258 -0
  401. package/src/core/session-scanner.ts +283 -0
  402. package/src/core/websocket.ts +190 -0
  403. package/src/index.ts +10 -0
  404. package/src/mcp-server/index.ts +186 -0
  405. package/src/templates/assets/css/github-dark.min.css +10 -0
  406. package/src/templates/assets/css/github.min.css +10 -0
  407. package/src/templates/assets/js/cytoscape.min.js +32 -0
  408. package/src/templates/assets/js/d3.min.js +2 -0
  409. package/src/templates/assets/js/highlight.min.js +1244 -0
  410. package/src/templates/assets/js/lucide.min.js +12 -0
  411. package/src/templates/assets/js/marked.min.js +69 -0
  412. package/src/templates/assets/js/tailwind.js +83 -0
  413. package/src/templates/dashboard-css/01-base.css +302 -0
  414. package/src/templates/dashboard-css/02-session.css +748 -0
  415. package/src/templates/dashboard-css/04-lite-tasks.css +1181 -0
  416. package/src/templates/dashboard-css/06-cards.css +1576 -0
  417. package/src/templates/dashboard-css/07-managers.css +2107 -0
  418. package/src/templates/dashboard-css/09-explorer.css +1408 -0
  419. package/src/templates/dashboard-css/10-cli-status.css +337 -0
  420. package/src/templates/dashboard-css/11-cli-history.css +271 -0
  421. package/src/templates/dashboard-css/12-cli-legacy.css +796 -0
  422. package/src/templates/dashboard-css/13-cli-ccw.css +199 -0
  423. package/src/templates/dashboard-css/14-cli-modals.css +258 -0
  424. package/src/templates/dashboard-css/15-cli-endpoints.css +305 -0
  425. package/src/templates/dashboard-css/16-cli-session.css +241 -0
  426. package/src/templates/dashboard-css/17-cli-conversation.css +283 -0
  427. package/src/templates/dashboard-css/18-cli-settings.css +160 -0
  428. package/src/templates/dashboard-css/19-cli-native-session.css +496 -0
  429. package/src/templates/dashboard-css/20-cli-taskqueue.css +188 -0
  430. package/src/templates/dashboard-css/21-cli-toolmgmt.css +310 -0
  431. package/src/templates/dashboard-css/22-cli-semantic.css +240 -0
  432. package/src/templates/dashboard-css/23-memory.css +2390 -0
  433. package/src/templates/dashboard-css/24-prompt-history.css +1089 -0
  434. package/src/templates/dashboard-css/25-skills-rules.css +326 -0
  435. package/src/templates/dashboard-css/26-claude-manager.css +908 -0
  436. package/src/templates/dashboard-css/27-graph-explorer.css +1678 -0
  437. package/src/templates/dashboard-css/28-mcp-manager.css +748 -0
  438. package/src/templates/dashboard-css/29-help.css +264 -0
  439. package/src/templates/dashboard-css/30-core-memory.css +1700 -0
  440. package/src/templates/dashboard-js/api.js +220 -0
  441. package/src/templates/dashboard-js/components/carousel.js +398 -0
  442. package/src/templates/dashboard-js/components/cli-history.js +876 -0
  443. package/src/templates/dashboard-js/components/cli-status.js +978 -0
  444. package/src/templates/dashboard-js/components/global-notifications.js +508 -0
  445. package/src/templates/dashboard-js/components/hook-manager.js +1278 -0
  446. package/src/templates/dashboard-js/components/index-manager.js +302 -0
  447. package/src/templates/dashboard-js/components/mcp-manager.js +1219 -0
  448. package/src/templates/dashboard-js/components/modals.js +326 -0
  449. package/src/templates/dashboard-js/components/navigation.js +313 -0
  450. package/src/templates/dashboard-js/components/notifications.js +758 -0
  451. package/src/templates/dashboard-js/components/storage-manager.js +478 -0
  452. package/src/templates/dashboard-js/components/tabs-other.js +424 -0
  453. package/src/templates/dashboard-js/components/task-queue-sidebar.js +716 -0
  454. package/src/templates/dashboard-js/help-i18n.js +272 -0
  455. package/src/templates/dashboard-js/i18n.js +2807 -0
  456. package/src/templates/dashboard-js/main.js +87 -0
  457. package/src/templates/dashboard-js/state.js +243 -0
  458. package/src/templates/dashboard-js/utils.js +199 -0
  459. package/src/templates/dashboard-js/views/claude-manager.js +912 -0
  460. package/src/templates/dashboard-js/views/cli-manager.js +2272 -0
  461. package/src/templates/dashboard-js/views/codexlens-manager.js +964 -0
  462. package/src/templates/dashboard-js/views/core-memory-clusters.js +503 -0
  463. package/src/templates/dashboard-js/views/core-memory.js +782 -0
  464. package/src/templates/dashboard-js/views/explorer.js +888 -0
  465. package/src/templates/dashboard-js/views/graph-explorer.js +1157 -0
  466. package/src/templates/dashboard-js/views/help.js +856 -0
  467. package/src/templates/dashboard-js/views/history.js +337 -0
  468. package/src/templates/dashboard-js/views/home.js +243 -0
  469. package/src/templates/dashboard-js/views/hook-manager.js +660 -0
  470. package/src/templates/dashboard-js/views/lite-tasks.js +861 -0
  471. package/src/templates/dashboard-js/views/mcp-manager.js +2187 -0
  472. package/src/templates/dashboard-js/views/mcp-manager.js.backup +1729 -0
  473. package/src/templates/dashboard-js/views/mcp-manager.js.new +928 -0
  474. package/src/templates/dashboard-js/views/memory.js +1221 -0
  475. package/src/templates/dashboard-js/views/prompt-history.js +713 -0
  476. package/src/templates/dashboard-js/views/rules-manager.js +828 -0
  477. package/src/templates/dashboard-js/views/session-detail.js +781 -0
  478. package/src/templates/dashboard-js/views/skills-manager.js +819 -0
  479. package/src/templates/dashboard.html +831 -0
  480. package/src/templates/hooks-config-example.json +60 -0
  481. package/src/tools/classify-folders.ts +245 -0
  482. package/src/tools/cli-config-manager.ts +268 -0
  483. package/src/tools/cli-executor.ts +2014 -0
  484. package/src/tools/cli-history-store.ts +1195 -0
  485. package/src/tools/codex-lens.ts +1141 -0
  486. package/src/tools/convert-tokens-to-css.ts +300 -0
  487. package/src/tools/core-memory.ts +444 -0
  488. package/src/tools/detect-changed-modules.ts +325 -0
  489. package/src/tools/discover-design-files.ts +184 -0
  490. package/src/tools/edit-file.ts +568 -0
  491. package/src/tools/generate-module-docs.ts +438 -0
  492. package/src/tools/get-modules-by-depth.ts +349 -0
  493. package/src/tools/index.ts +370 -0
  494. package/src/tools/native-session-discovery.ts +795 -0
  495. package/src/tools/notifier.ts +129 -0
  496. package/src/tools/read-file.ts +410 -0
  497. package/src/tools/resume-strategy.ts +345 -0
  498. package/src/tools/session-content-parser.ts +619 -0
  499. package/src/tools/session-manager.ts +1026 -0
  500. package/src/tools/smart-context.ts +228 -0
  501. package/src/tools/smart-search.ts +2065 -0
  502. package/src/tools/smart-search.ts.backup +1233 -0
  503. package/src/tools/storage-manager.ts +455 -0
  504. package/src/tools/write-file.ts +222 -0
  505. package/src/types/config.ts +11 -0
  506. package/src/types/index.ts +3 -0
  507. package/src/types/session.ts +25 -0
  508. package/src/types/tool.ts +41 -0
  509. package/src/utils/browser-launcher.ts +62 -0
  510. package/src/utils/file-utils.ts +48 -0
  511. package/src/utils/path-resolver.ts +315 -0
  512. package/src/utils/path-validator.ts +153 -0
  513. package/src/utils/ui.ts +155 -0
  514. package/.claude/agents/action-planning-agent.md +0 -778
  515. package/.claude/agents/cli-execution-agent.md +0 -270
  516. package/.claude/agents/cli-explore-agent.md +0 -182
  517. package/.claude/agents/cli-lite-planning-agent.md +0 -396
  518. package/.claude/agents/cli-planning-agent.md +0 -558
  519. package/.claude/agents/code-developer.md +0 -310
  520. package/.claude/agents/conceptual-planning-agent.md +0 -308
  521. package/.claude/agents/context-search-agent.md +0 -582
  522. package/.claude/agents/doc-generator.md +0 -330
  523. package/.claude/agents/memory-bridge.md +0 -94
  524. package/.claude/agents/test-context-search-agent.md +0 -399
  525. package/.claude/agents/test-fix-agent.md +0 -343
  526. package/.claude/agents/ui-design-agent.md +0 -593
  527. package/.claude/agents/universal-executor.md +0 -131
  528. package/.claude/commands/cli/cli-init.md +0 -440
  529. package/.claude/commands/enhance-prompt.md +0 -93
  530. package/.claude/commands/memory/code-map-memory.md +0 -687
  531. package/.claude/commands/memory/docs-full-cli.md +0 -471
  532. package/.claude/commands/memory/docs-related-cli.md +0 -386
  533. package/.claude/commands/memory/docs.md +0 -615
  534. package/.claude/commands/memory/load-skill-memory.md +0 -182
  535. package/.claude/commands/memory/load.md +0 -240
  536. package/.claude/commands/memory/skill-memory.md +0 -525
  537. package/.claude/commands/memory/style-skill-memory.md +0 -396
  538. package/.claude/commands/memory/tech-research.md +0 -477
  539. package/.claude/commands/memory/update-full.md +0 -332
  540. package/.claude/commands/memory/update-related.md +0 -332
  541. package/.claude/commands/memory/workflow-skill-memory.md +0 -517
  542. package/.claude/commands/task/breakdown.md +0 -204
  543. package/.claude/commands/task/create.md +0 -152
  544. package/.claude/commands/task/execute.md +0 -270
  545. package/.claude/commands/task/replan.md +0 -437
  546. package/.claude/commands/version.md +0 -254
  547. package/.claude/commands/workflow/action-plan-verify.md +0 -447
  548. package/.claude/commands/workflow/brainstorm/api-designer.md +0 -585
  549. package/.claude/commands/workflow/brainstorm/artifacts.md +0 -452
  550. package/.claude/commands/workflow/brainstorm/auto-parallel.md +0 -443
  551. package/.claude/commands/workflow/brainstorm/data-architect.md +0 -220
  552. package/.claude/commands/workflow/brainstorm/product-manager.md +0 -200
  553. package/.claude/commands/workflow/brainstorm/product-owner.md +0 -200
  554. package/.claude/commands/workflow/brainstorm/scrum-master.md +0 -200
  555. package/.claude/commands/workflow/brainstorm/subject-matter-expert.md +0 -200
  556. package/.claude/commands/workflow/brainstorm/synthesis.md +0 -398
  557. package/.claude/commands/workflow/brainstorm/system-architect.md +0 -387
  558. package/.claude/commands/workflow/brainstorm/ui-designer.md +0 -221
  559. package/.claude/commands/workflow/brainstorm/ux-expert.md +0 -221
  560. package/.claude/commands/workflow/execute.md +0 -462
  561. package/.claude/commands/workflow/init.md +0 -164
  562. package/.claude/commands/workflow/lite-execute.md +0 -686
  563. package/.claude/commands/workflow/lite-fix.md +0 -621
  564. package/.claude/commands/workflow/lite-plan.md +0 -592
  565. package/.claude/commands/workflow/plan.md +0 -551
  566. package/.claude/commands/workflow/replan.md +0 -515
  567. package/.claude/commands/workflow/review-fix.md +0 -606
  568. package/.claude/commands/workflow/review-module-cycle.md +0 -765
  569. package/.claude/commands/workflow/review-session-cycle.md +0 -776
  570. package/.claude/commands/workflow/review.md +0 -291
  571. package/.claude/commands/workflow/session/complete.md +0 -500
  572. package/.claude/commands/workflow/session/list.md +0 -96
  573. package/.claude/commands/workflow/session/resume.md +0 -61
  574. package/.claude/commands/workflow/session/start.md +0 -200
  575. package/.claude/commands/workflow/tdd-plan.md +0 -460
  576. package/.claude/commands/workflow/tdd-verify.md +0 -386
  577. package/.claude/commands/workflow/test-cycle-execute.md +0 -498
  578. package/.claude/commands/workflow/test-fix-gen.md +0 -699
  579. package/.claude/commands/workflow/test-gen.md +0 -529
  580. package/.claude/commands/workflow/tools/conflict-resolution.md +0 -680
  581. package/.claude/commands/workflow/tools/context-gather.md +0 -434
  582. package/.claude/commands/workflow/tools/task-generate-agent.md +0 -291
  583. package/.claude/commands/workflow/tools/task-generate-tdd.md +0 -518
  584. package/.claude/commands/workflow/tools/tdd-coverage-analysis.md +0 -309
  585. package/.claude/commands/workflow/tools/test-concept-enhanced.md +0 -163
  586. package/.claude/commands/workflow/tools/test-context-gather.md +0 -235
  587. package/.claude/commands/workflow/tools/test-task-generate.md +0 -256
  588. package/.claude/commands/workflow/ui-design/animation-extract.md +0 -1150
  589. package/.claude/commands/workflow/ui-design/codify-style.md +0 -652
  590. package/.claude/commands/workflow/ui-design/design-sync.md +0 -454
  591. package/.claude/commands/workflow/ui-design/explore-auto.md +0 -678
  592. package/.claude/commands/workflow/ui-design/generate.md +0 -504
  593. package/.claude/commands/workflow/ui-design/imitate-auto.md +0 -745
  594. package/.claude/commands/workflow/ui-design/import-from-code.md +0 -537
  595. package/.claude/commands/workflow/ui-design/layout-extract.md +0 -788
  596. package/.claude/commands/workflow/ui-design/reference-page-generator.md +0 -356
  597. package/.claude/commands/workflow/ui-design/style-extract.md +0 -773
  598. package/.claude/scripts/classify-folders.sh +0 -39
  599. package/.claude/scripts/convert_tokens_to_css.sh +0 -229
  600. package/.claude/scripts/detect_changed_modules.sh +0 -161
  601. package/.claude/scripts/discover-design-files.sh +0 -87
  602. package/.claude/scripts/extract-animations.js +0 -243
  603. package/.claude/scripts/extract-computed-styles.js +0 -118
  604. package/.claude/scripts/extract-layout-structure.js +0 -411
  605. package/.claude/scripts/generate_module_docs.sh +0 -717
  606. package/.claude/scripts/get_modules_by_depth.sh +0 -170
  607. package/.claude/scripts/ui-generate-preview.sh +0 -395
  608. package/.claude/scripts/ui-instantiate-prototypes.sh +0 -815
  609. package/.claude/scripts/update_module_claude.sh +0 -337
  610. package/.claude/skills/command-guide/SKILL.md +0 -388
  611. package/.claude/skills/command-guide/UPDATE-GUIDELINE.md +0 -592
  612. package/.claude/skills/command-guide/guides/cli-tools-guide.md +0 -410
  613. package/.claude/skills/command-guide/guides/examples.md +0 -537
  614. package/.claude/skills/command-guide/guides/getting-started.md +0 -242
  615. package/.claude/skills/command-guide/guides/implementation-details.md +0 -1010
  616. package/.claude/skills/command-guide/guides/index-structure.md +0 -326
  617. package/.claude/skills/command-guide/guides/troubleshooting.md +0 -92
  618. package/.claude/skills/command-guide/guides/ui-design-workflow-guide.md +0 -316
  619. package/.claude/skills/command-guide/guides/workflow-patterns.md +0 -662
  620. package/.claude/skills/command-guide/index/all-commands.json +0 -772
  621. package/.claude/skills/command-guide/index/by-category.json +0 -800
  622. package/.claude/skills/command-guide/index/by-use-case.json +0 -786
  623. package/.claude/skills/command-guide/index/command-relationships.json +0 -307
  624. package/.claude/skills/command-guide/index/essential-commands.json +0 -112
  625. package/.claude/skills/command-guide/reference/agents/action-planning-agent.md +0 -778
  626. package/.claude/skills/command-guide/reference/agents/cli-execution-agent.md +0 -270
  627. package/.claude/skills/command-guide/reference/agents/cli-explore-agent.md +0 -182
  628. package/.claude/skills/command-guide/reference/agents/cli-lite-planning-agent.md +0 -396
  629. package/.claude/skills/command-guide/reference/agents/cli-planning-agent.md +0 -558
  630. package/.claude/skills/command-guide/reference/agents/code-developer.md +0 -310
  631. package/.claude/skills/command-guide/reference/agents/conceptual-planning-agent.md +0 -308
  632. package/.claude/skills/command-guide/reference/agents/context-search-agent.md +0 -582
  633. package/.claude/skills/command-guide/reference/agents/doc-generator.md +0 -330
  634. package/.claude/skills/command-guide/reference/agents/memory-bridge.md +0 -94
  635. package/.claude/skills/command-guide/reference/agents/test-context-search-agent.md +0 -399
  636. package/.claude/skills/command-guide/reference/agents/test-fix-agent.md +0 -343
  637. package/.claude/skills/command-guide/reference/agents/ui-design-agent.md +0 -593
  638. package/.claude/skills/command-guide/reference/agents/universal-executor.md +0 -131
  639. package/.claude/skills/command-guide/reference/commands/cli/cli-init.md +0 -440
  640. package/.claude/skills/command-guide/reference/commands/enhance-prompt.md +0 -93
  641. package/.claude/skills/command-guide/reference/commands/memory/code-map-memory.md +0 -687
  642. package/.claude/skills/command-guide/reference/commands/memory/docs-full-cli.md +0 -471
  643. package/.claude/skills/command-guide/reference/commands/memory/docs-related-cli.md +0 -386
  644. package/.claude/skills/command-guide/reference/commands/memory/docs.md +0 -615
  645. package/.claude/skills/command-guide/reference/commands/memory/load-skill-memory.md +0 -182
  646. package/.claude/skills/command-guide/reference/commands/memory/load.md +0 -240
  647. package/.claude/skills/command-guide/reference/commands/memory/skill-memory.md +0 -525
  648. package/.claude/skills/command-guide/reference/commands/memory/style-skill-memory.md +0 -396
  649. package/.claude/skills/command-guide/reference/commands/memory/tech-research.md +0 -477
  650. package/.claude/skills/command-guide/reference/commands/memory/update-full.md +0 -332
  651. package/.claude/skills/command-guide/reference/commands/memory/update-related.md +0 -332
  652. package/.claude/skills/command-guide/reference/commands/memory/workflow-skill-memory.md +0 -517
  653. package/.claude/skills/command-guide/reference/commands/task/breakdown.md +0 -204
  654. package/.claude/skills/command-guide/reference/commands/task/create.md +0 -152
  655. package/.claude/skills/command-guide/reference/commands/task/execute.md +0 -270
  656. package/.claude/skills/command-guide/reference/commands/task/replan.md +0 -437
  657. package/.claude/skills/command-guide/reference/commands/version.md +0 -254
  658. package/.claude/skills/command-guide/reference/commands/workflow/action-plan-verify.md +0 -447
  659. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/api-designer.md +0 -585
  660. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/artifacts.md +0 -452
  661. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/auto-parallel.md +0 -443
  662. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/data-architect.md +0 -220
  663. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-manager.md +0 -200
  664. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/product-owner.md +0 -200
  665. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/scrum-master.md +0 -200
  666. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/subject-matter-expert.md +0 -200
  667. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/synthesis.md +0 -398
  668. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/system-architect.md +0 -387
  669. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ui-designer.md +0 -221
  670. package/.claude/skills/command-guide/reference/commands/workflow/brainstorm/ux-expert.md +0 -221
  671. package/.claude/skills/command-guide/reference/commands/workflow/execute.md +0 -460
  672. package/.claude/skills/command-guide/reference/commands/workflow/init.md +0 -164
  673. package/.claude/skills/command-guide/reference/commands/workflow/lite-execute.md +0 -686
  674. package/.claude/skills/command-guide/reference/commands/workflow/lite-fix.md +0 -621
  675. package/.claude/skills/command-guide/reference/commands/workflow/lite-plan.md +0 -592
  676. package/.claude/skills/command-guide/reference/commands/workflow/plan.md +0 -551
  677. package/.claude/skills/command-guide/reference/commands/workflow/replan.md +0 -515
  678. package/.claude/skills/command-guide/reference/commands/workflow/review-fix.md +0 -606
  679. package/.claude/skills/command-guide/reference/commands/workflow/review-module-cycle.md +0 -765
  680. package/.claude/skills/command-guide/reference/commands/workflow/review-session-cycle.md +0 -776
  681. package/.claude/skills/command-guide/reference/commands/workflow/review.md +0 -291
  682. package/.claude/skills/command-guide/reference/commands/workflow/session/complete.md +0 -500
  683. package/.claude/skills/command-guide/reference/commands/workflow/session/list.md +0 -96
  684. package/.claude/skills/command-guide/reference/commands/workflow/session/resume.md +0 -61
  685. package/.claude/skills/command-guide/reference/commands/workflow/session/start.md +0 -200
  686. package/.claude/skills/command-guide/reference/commands/workflow/tdd-plan.md +0 -460
  687. package/.claude/skills/command-guide/reference/commands/workflow/tdd-verify.md +0 -386
  688. package/.claude/skills/command-guide/reference/commands/workflow/test-cycle-execute.md +0 -498
  689. package/.claude/skills/command-guide/reference/commands/workflow/test-fix-gen.md +0 -699
  690. package/.claude/skills/command-guide/reference/commands/workflow/test-gen.md +0 -529
  691. package/.claude/skills/command-guide/reference/commands/workflow/tools/conflict-resolution.md +0 -680
  692. package/.claude/skills/command-guide/reference/commands/workflow/tools/context-gather.md +0 -434
  693. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-agent.md +0 -291
  694. package/.claude/skills/command-guide/reference/commands/workflow/tools/task-generate-tdd.md +0 -518
  695. package/.claude/skills/command-guide/reference/commands/workflow/tools/tdd-coverage-analysis.md +0 -309
  696. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-concept-enhanced.md +0 -163
  697. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-context-gather.md +0 -235
  698. package/.claude/skills/command-guide/reference/commands/workflow/tools/test-task-generate.md +0 -256
  699. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/animation-extract.md +0 -1150
  700. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/codify-style.md +0 -652
  701. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/design-sync.md +0 -454
  702. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/explore-auto.md +0 -678
  703. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/generate.md +0 -504
  704. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/imitate-auto.md +0 -745
  705. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/import-from-code.md +0 -537
  706. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/layout-extract.md +0 -788
  707. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/reference-page-generator.md +0 -356
  708. package/.claude/skills/command-guide/reference/commands/workflow/ui-design/style-extract.md +0 -773
  709. package/.claude/skills/command-guide/scripts/analyze_commands.py +0 -502
  710. package/.claude/skills/command-guide/scripts/update-index.sh +0 -130
  711. package/.claude/skills/command-guide/templates/issue-bug.md +0 -104
  712. package/.claude/skills/command-guide/templates/issue-diagnosis.md +0 -275
  713. package/.claude/skills/command-guide/templates/issue-feature.md +0 -97
  714. package/.claude/skills/command-guide/templates/issue-question.md +0 -141
  715. package/.claude/skills/prompt-enhancer/SKILL.md +0 -124
  716. package/.claude/workflows/_template-compare-matrix.html +0 -692
  717. package/.claude/workflows/cli-templates/fix-plan-template.json +0 -75
  718. package/.claude/workflows/cli-templates/fix-progress-template.json +0 -48
  719. package/.claude/workflows/cli-templates/memory/style-skill-memory/skill-md-template.md +0 -299
  720. package/.claude/workflows/cli-templates/planning-roles/data-architect.md +0 -120
  721. package/.claude/workflows/cli-templates/planning-roles/product-manager.md +0 -119
  722. package/.claude/workflows/cli-templates/planning-roles/product-owner.md +0 -261
  723. package/.claude/workflows/cli-templates/planning-roles/scrum-master.md +0 -186
  724. package/.claude/workflows/cli-templates/planning-roles/subject-matter-expert.md +0 -281
  725. package/.claude/workflows/cli-templates/planning-roles/synthesis-role.md +0 -414
  726. package/.claude/workflows/cli-templates/planning-roles/system-architect.md +0 -106
  727. package/.claude/workflows/cli-templates/planning-roles/test-strategist.md +0 -124
  728. package/.claude/workflows/cli-templates/planning-roles/ui-designer.md +0 -379
  729. package/.claude/workflows/cli-templates/planning-roles/ux-expert.md +0 -240
  730. package/.claude/workflows/cli-templates/prompts/analysis/01-diagnose-bug-root-cause.txt +0 -127
  731. package/.claude/workflows/cli-templates/prompts/analysis/01-trace-code-execution.txt +0 -115
  732. package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-code-patterns.txt +0 -37
  733. package/.claude/workflows/cli-templates/prompts/analysis/02-analyze-technical-document.txt +0 -33
  734. package/.claude/workflows/cli-templates/prompts/analysis/02-review-architecture.txt +0 -29
  735. package/.claude/workflows/cli-templates/prompts/analysis/02-review-code-quality.txt +0 -28
  736. package/.claude/workflows/cli-templates/prompts/analysis/03-analyze-performance.txt +0 -29
  737. package/.claude/workflows/cli-templates/prompts/analysis/03-assess-security-risks.txt +0 -29
  738. package/.claude/workflows/cli-templates/prompts/analysis/03-review-quality-standards.txt +0 -29
  739. package/.claude/workflows/cli-templates/prompts/development/02-generate-tests.txt +0 -70
  740. package/.claude/workflows/cli-templates/prompts/development/02-implement-component-ui.txt +0 -55
  741. package/.claude/workflows/cli-templates/prompts/development/02-implement-feature.txt +0 -58
  742. package/.claude/workflows/cli-templates/prompts/development/02-refactor-codebase.txt +0 -55
  743. package/.claude/workflows/cli-templates/prompts/development/03-debug-runtime-issues.txt +0 -55
  744. package/.claude/workflows/cli-templates/prompts/documentation/api.txt +0 -15
  745. package/.claude/workflows/cli-templates/prompts/documentation/folder-navigation.txt +0 -27
  746. package/.claude/workflows/cli-templates/prompts/documentation/module-readme.txt +0 -49
  747. package/.claude/workflows/cli-templates/prompts/documentation/project-architecture.txt +0 -41
  748. package/.claude/workflows/cli-templates/prompts/documentation/project-examples.txt +0 -35
  749. package/.claude/workflows/cli-templates/prompts/documentation/project-readme.txt +0 -35
  750. package/.claude/workflows/cli-templates/prompts/memory/02-document-module-structure.txt +0 -165
  751. package/.claude/workflows/cli-templates/prompts/planning/01-plan-architecture-design.txt +0 -109
  752. package/.claude/workflows/cli-templates/prompts/planning/02-breakdown-task-steps.txt +0 -30
  753. package/.claude/workflows/cli-templates/prompts/planning/02-design-component-spec.txt +0 -28
  754. package/.claude/workflows/cli-templates/prompts/planning/03-evaluate-concept-feasibility.txt +0 -127
  755. package/.claude/workflows/cli-templates/prompts/planning/03-plan-migration-strategy.txt +0 -30
  756. package/.claude/workflows/cli-templates/prompts/tech/tech-module-format.txt +0 -359
  757. package/.claude/workflows/cli-templates/prompts/tech/tech-skill-index.txt +0 -185
  758. package/.claude/workflows/cli-templates/prompts/test/test-concept-analysis.txt +0 -179
  759. package/.claude/workflows/cli-templates/prompts/universal/00-universal-creative-style.txt +0 -95
  760. package/.claude/workflows/cli-templates/prompts/universal/00-universal-rigorous-style.txt +0 -92
  761. package/.claude/workflows/cli-templates/prompts/verification/codex-technical.txt +0 -28
  762. package/.claude/workflows/cli-templates/prompts/verification/cross-validation.txt +0 -28
  763. package/.claude/workflows/cli-templates/prompts/verification/gemini-strategic.txt +0 -27
  764. package/.claude/workflows/cli-templates/prompts/workflow/analysis-results-structure.txt +0 -224
  765. package/.claude/workflows/cli-templates/prompts/workflow/codex-feasibility-validation.txt +0 -176
  766. package/.claude/workflows/cli-templates/prompts/workflow/gemini-solution-design.txt +0 -131
  767. package/.claude/workflows/cli-templates/prompts/workflow/impl-plan-template.txt +0 -286
  768. package/.claude/workflows/cli-templates/prompts/workflow/skill-aggregation.txt +0 -172
  769. package/.claude/workflows/cli-templates/prompts/workflow/skill-conflict-patterns.txt +0 -98
  770. package/.claude/workflows/cli-templates/prompts/workflow/skill-index.txt +0 -224
  771. package/.claude/workflows/cli-templates/prompts/workflow/skill-lessons-learned.txt +0 -98
  772. package/.claude/workflows/cli-templates/prompts/workflow/skill-sessions-timeline.txt +0 -53
  773. package/.claude/workflows/cli-templates/prompts/workflow/task-json-agent-mode.txt +0 -123
  774. package/.claude/workflows/cli-templates/prompts/workflow/task-json-cli-mode.txt +0 -182
  775. package/.claude/workflows/cli-templates/schemas/diagnosis-json-schema.json +0 -234
  776. package/.claude/workflows/cli-templates/schemas/explore-json-schema.json +0 -124
  777. package/.claude/workflows/cli-templates/schemas/fix-plan-json-schema.json +0 -273
  778. package/.claude/workflows/cli-templates/schemas/plan-json-schema.json +0 -219
  779. package/.claude/workflows/cli-templates/schemas/project-json-schema.json +0 -221
  780. package/.claude/workflows/cli-templates/schemas/review-deep-dive-results-schema.json +0 -82
  781. package/.claude/workflows/cli-templates/schemas/review-dimension-results-schema.json +0 -51
  782. package/.claude/workflows/cli-templates/tech-stacks/go-dev.md +0 -91
  783. package/.claude/workflows/cli-templates/tech-stacks/java-dev.md +0 -107
  784. package/.claude/workflows/cli-templates/tech-stacks/javascript-dev.md +0 -58
  785. package/.claude/workflows/cli-templates/tech-stacks/python-dev.md +0 -79
  786. package/.claude/workflows/cli-templates/tech-stacks/react-dev.md +0 -103
  787. package/.claude/workflows/cli-templates/tech-stacks/typescript-dev.md +0 -83
  788. package/.claude/workflows/cli-templates/ui-design/systems/animation-tokens.json +0 -247
  789. package/.claude/workflows/cli-templates/ui-design/systems/design-tokens.json +0 -342
  790. package/.claude/workflows/cli-templates/ui-design/systems/layout-templates.json +0 -145
  791. package/.claude/workflows/context-search-strategy.md +0 -77
  792. package/.claude/workflows/intelligent-tools-strategy.md +0 -662
  793. package/.claude/workflows/review-directory-specification.md +0 -336
  794. package/.claude/workflows/task-core.md +0 -214
  795. package/.claude/workflows/tool-strategy.md +0 -79
  796. package/.claude/workflows/workflow-architecture.md +0 -942
  797. package/.codex/AGENTS.md +0 -330
  798. package/.gemini/GEMINI.md +0 -164
  799. package/.qwen/QWEN.md +0 -164
  800. package/CLAUDE.md +0 -91
  801. package/LICENSE +0 -21
  802. package/ccw/README.md +0 -121
  803. package/ccw/bin/ccw.js +0 -10
  804. package/ccw/package.json +0 -47
  805. package/ccw/src/cli.js +0 -119
  806. package/ccw/src/commands/install.js +0 -324
  807. package/ccw/src/commands/list.js +0 -37
  808. package/ccw/src/commands/serve.js +0 -67
  809. package/ccw/src/commands/stop.js +0 -101
  810. package/ccw/src/commands/tool.js +0 -138
  811. package/ccw/src/commands/uninstall.js +0 -238
  812. package/ccw/src/commands/upgrade.js +0 -307
  813. package/ccw/src/commands/view.js +0 -105
  814. package/ccw/src/core/dashboard-generator-patch.js +0 -29
  815. package/ccw/src/core/dashboard-generator.js +0 -682
  816. package/ccw/src/core/data-aggregator.js +0 -409
  817. package/ccw/src/core/lite-scanner.js +0 -373
  818. package/ccw/src/core/manifest.js +0 -201
  819. package/ccw/src/core/server.js +0 -2063
  820. package/ccw/src/core/session-scanner.js +0 -235
  821. package/ccw/src/index.js +0 -9
  822. package/ccw/src/templates/dashboard-css/01-base.css +0 -291
  823. package/ccw/src/templates/dashboard-css/02-session.css +0 -726
  824. package/ccw/src/templates/dashboard-css/04-lite-tasks.css +0 -1171
  825. package/ccw/src/templates/dashboard-css/06-cards.css +0 -1570
  826. package/ccw/src/templates/dashboard-css/07-managers.css +0 -936
  827. package/ccw/src/templates/dashboard-css/09-explorer.css +0 -1397
  828. package/ccw/src/templates/dashboard-js/api.js +0 -200
  829. package/ccw/src/templates/dashboard-js/components/carousel.js +0 -398
  830. package/ccw/src/templates/dashboard-js/components/global-notifications.js +0 -219
  831. package/ccw/src/templates/dashboard-js/components/hook-manager.js +0 -283
  832. package/ccw/src/templates/dashboard-js/components/mcp-manager.js +0 -528
  833. package/ccw/src/templates/dashboard-js/components/modals.js +0 -260
  834. package/ccw/src/templates/dashboard-js/components/navigation.js +0 -245
  835. package/ccw/src/templates/dashboard-js/components/notifications.js +0 -194
  836. package/ccw/src/templates/dashboard-js/components/tabs-other.js +0 -273
  837. package/ccw/src/templates/dashboard-js/main.js +0 -72
  838. package/ccw/src/templates/dashboard-js/state.js +0 -42
  839. package/ccw/src/templates/dashboard-js/utils.js +0 -153
  840. package/ccw/src/templates/dashboard-js/views/explorer.js +0 -852
  841. package/ccw/src/templates/dashboard-js/views/home.js +0 -197
  842. package/ccw/src/templates/dashboard-js/views/hook-manager.js +0 -392
  843. package/ccw/src/templates/dashboard-js/views/lite-tasks.js +0 -685
  844. package/ccw/src/templates/dashboard-js/views/mcp-manager.js +0 -411
  845. package/ccw/src/templates/dashboard-js/views/session-detail.js +0 -780
  846. package/ccw/src/templates/dashboard.html +0 -731
  847. package/ccw/src/tools/classify-folders.js +0 -204
  848. package/ccw/src/tools/convert-tokens-to-css.js +0 -250
  849. package/ccw/src/tools/detect-changed-modules.js +0 -288
  850. package/ccw/src/tools/discover-design-files.js +0 -134
  851. package/ccw/src/tools/edit-file.js +0 -266
  852. package/ccw/src/tools/generate-module-docs.js +0 -416
  853. package/ccw/src/tools/get-modules-by-depth.js +0 -308
  854. package/ccw/src/tools/index.js +0 -176
  855. package/ccw/src/utils/browser-launcher.js +0 -60
  856. package/ccw/src/utils/file-utils.js +0 -48
  857. package/ccw/src/utils/path-resolver.js +0 -279
  858. package/ccw/src/utils/ui.js +0 -148
  859. /package/{ccw/src → src}/templates/dashboard-css/03-tasks.css +0 -0
  860. /package/{ccw/src → src}/templates/dashboard-css/05-context.css +0 -0
  861. /package/{ccw/src → src}/templates/dashboard-css/08-review.css +0 -0
  862. /package/{ccw/src → src}/templates/dashboard-js/components/_conflict_tab.js +0 -0
  863. /package/{ccw/src → src}/templates/dashboard-js/components/_exp_helpers.js +0 -0
  864. /package/{ccw/src → src}/templates/dashboard-js/components/_review_tab.js +0 -0
  865. /package/{ccw/src → src}/templates/dashboard-js/components/flowchart.js +0 -0
  866. /package/{ccw/src → src}/templates/dashboard-js/components/sidebar.js +0 -0
  867. /package/{ccw/src → src}/templates/dashboard-js/components/tabs-context.js +0 -0
  868. /package/{ccw/src → src}/templates/dashboard-js/components/task-drawer-core.js +0 -0
  869. /package/{ccw/src → src}/templates/dashboard-js/components/task-drawer-renderers.js +0 -0
  870. /package/{ccw/src → src}/templates/dashboard-js/components/theme.js +0 -0
  871. /package/{ccw/src → src}/templates/dashboard-js/components/version-check.js +0 -0
  872. /package/{ccw/src → src}/templates/dashboard-js/views/fix-session.js +0 -0
  873. /package/{ccw/src → src}/templates/dashboard-js/views/project-overview.js +0 -0
  874. /package/{ccw/src → src}/templates/dashboard-js/views/review-session.js +0 -0
  875. /package/{ccw/src → src}/templates/review-cycle-dashboard.html +0 -0
  876. /package/{ccw/src → src}/templates/workflow-dashboard.html +0 -0
  877. /package/{ccw/src → src}/tools/ui-generate-preview.js +0 -0
  878. /package/{ccw/src → src}/tools/ui-instantiate-prototypes.js +0 -0
  879. /package/{ccw/src → src}/tools/update-module-claude.js +0 -0
@@ -0,0 +1,1206 @@
1
+ import http from 'http';
2
+ import { URL } from 'url';
3
+ import { readFileSync, writeFileSync, existsSync, mkdirSync, statSync, unlinkSync } from 'fs';
4
+ import { join, isAbsolute, extname } from 'path';
5
+ import { homedir } from 'os';
6
+ import { getMemoryStore } from '../memory-store.js';
7
+ import { executeCliTool } from '../../tools/cli-executor.js';
8
+
9
+ /**
10
+ * Route context interface
11
+ */
12
+ interface RouteContext {
13
+ pathname: string;
14
+ url: URL;
15
+ req: http.IncomingMessage;
16
+ res: http.ServerResponse;
17
+ initialPath: string;
18
+ handlePostRequest: (req: http.IncomingMessage, res: http.ServerResponse, handler: (body: any) => Promise<any>) => void;
19
+ broadcastToClients: (data: any) => void;
20
+ }
21
+
22
+ /**
23
+ * Derive prompt intent from text
24
+ */
25
+ function derivePromptIntent(text: string): string {
26
+ const lower = text.toLowerCase();
27
+
28
+ // Implementation/coding patterns
29
+ if (/实现|implement|create|add|build|write|develop|make/.test(lower)) return 'implement';
30
+ if (/修复|fix|bug|error|issue|problem|解决/.test(lower)) return 'fix';
31
+ if (/重构|refactor|optimize|improve|clean/.test(lower)) return 'refactor';
32
+ if (/测试|test|spec|coverage/.test(lower)) return 'test';
33
+
34
+ // Analysis patterns
35
+ if (/分析|analyze|review|check|examine|audit/.test(lower)) return 'analyze';
36
+ if (/解释|explain|what|how|why|understand/.test(lower)) return 'explain';
37
+ if (/搜索|search|find|look|where|locate/.test(lower)) return 'search';
38
+
39
+ // Documentation patterns
40
+ if (/文档|document|readme|comment|注释/.test(lower)) return 'document';
41
+
42
+ // Planning patterns
43
+ if (/计划|plan|design|architect|strategy/.test(lower)) return 'plan';
44
+
45
+ // Configuration patterns
46
+ if (/配置|config|setup|install|设置/.test(lower)) return 'configure';
47
+
48
+ // Default
49
+ return 'general';
50
+ }
51
+
52
+ /**
53
+ * Calculate prompt quality score (0-100)
54
+ */
55
+ function calculateQualityScore(text: string): number {
56
+ let score = 50; // Base score
57
+
58
+ // Length factors
59
+ const length = text.length;
60
+ if (length > 50 && length < 500) score += 15;
61
+ else if (length >= 500 && length < 1000) score += 10;
62
+ else if (length < 20) score -= 20;
63
+
64
+ // Specificity indicators
65
+ if (/file|path|function|class|method|variable/i.test(text)) score += 10;
66
+ if (/src\/|\.ts|\.js|\.py|\.go/i.test(text)) score += 10;
67
+
68
+ // Context indicators
69
+ if (/when|after|before|because|since/i.test(text)) score += 5;
70
+
71
+ // Action clarity
72
+ if (/please|要|请|帮|help/i.test(text)) score += 5;
73
+
74
+ // Structure indicators
75
+ if (/\d+\.|•|-\s/.test(text)) score += 10; // Lists
76
+
77
+ // Cap at 100
78
+ return Math.min(100, Math.max(0, score));
79
+ }
80
+
81
+ /**
82
+ * Handle Memory API routes
83
+ * @returns true if route was handled, false otherwise
84
+ */
85
+ export async function handleMemoryRoutes(ctx: RouteContext): Promise<boolean> {
86
+ const { pathname, url, req, res, initialPath, handlePostRequest, broadcastToClients } = ctx;
87
+
88
+ // API: Memory Module - Track entity access
89
+ if (pathname === '/api/memory/track' && req.method === 'POST') {
90
+ handlePostRequest(req, res, async (body) => {
91
+ const { type, action, value, sessionId, metadata, path: projectPath } = body;
92
+
93
+ if (!type || !action || !value) {
94
+ return { error: 'type, action, and value are required', status: 400 };
95
+ }
96
+
97
+ const basePath = projectPath || initialPath;
98
+
99
+ try {
100
+ const memoryStore = getMemoryStore(basePath);
101
+ const now = new Date().toISOString();
102
+
103
+ // Normalize the value
104
+ const normalizedValue = value.toLowerCase().trim();
105
+
106
+ // Upsert entity
107
+ const entityId = memoryStore.upsertEntity({
108
+ type,
109
+ value,
110
+ normalized_value: normalizedValue,
111
+ first_seen_at: now,
112
+ last_seen_at: now,
113
+ metadata: metadata ? JSON.stringify(metadata) : undefined
114
+ });
115
+
116
+ // Log access
117
+ memoryStore.logAccess({
118
+ entity_id: entityId,
119
+ action,
120
+ session_id: sessionId,
121
+ timestamp: now,
122
+ context_summary: metadata?.context
123
+ });
124
+
125
+ // Update stats
126
+ memoryStore.updateStats(entityId, action);
127
+
128
+ // Calculate new heat score
129
+ const heatScore = memoryStore.calculateHeatScore(entityId);
130
+ const stats = memoryStore.getStats(entityId);
131
+
132
+ // Broadcast MEMORY_UPDATED event via WebSocket
133
+ broadcastToClients({
134
+ type: 'MEMORY_UPDATED',
135
+ payload: {
136
+ entity: { id: entityId, type, value },
137
+ stats: {
138
+ read_count: stats?.read_count || 0,
139
+ write_count: stats?.write_count || 0,
140
+ mention_count: stats?.mention_count || 0,
141
+ heat_score: heatScore
142
+ },
143
+ timestamp: now
144
+ }
145
+ });
146
+
147
+ return {
148
+ success: true,
149
+ entity_id: entityId,
150
+ heat_score: heatScore
151
+ };
152
+ } catch (error: unknown) {
153
+ return { error: (error as Error).message, status: 500 };
154
+ }
155
+ });
156
+ return true;
157
+ }
158
+
159
+ // API: Memory Module - Get native Claude history from ~/.claude/history.jsonl
160
+ if (pathname === '/api/memory/native-history') {
161
+ const projectPath = url.searchParams.get('path') || initialPath;
162
+ const limit = parseInt(url.searchParams.get('limit') || '100', 10);
163
+ const historyFile = join(homedir(), '.claude', 'history.jsonl');
164
+
165
+ try {
166
+ if (!existsSync(historyFile)) {
167
+ res.writeHead(200, { 'Content-Type': 'application/json' });
168
+ res.end(JSON.stringify({ prompts: [], total: 0, message: 'No history file found' }));
169
+ return true;
170
+ }
171
+
172
+ const content = readFileSync(historyFile, 'utf8');
173
+ const lines = content.trim().split('\n').filter(line => line.trim());
174
+ const allPrompts = [];
175
+
176
+ for (const line of lines) {
177
+ try {
178
+ const entry = JSON.parse(line);
179
+ // Filter by project if specified
180
+ if (projectPath && entry.project) {
181
+ const normalizedProject = entry.project.replace(/\\/g, '/').toLowerCase();
182
+ const normalizedPath = projectPath.replace(/\\/g, '/').toLowerCase();
183
+ if (!normalizedProject.includes(normalizedPath) && !normalizedPath.includes(normalizedProject)) {
184
+ continue;
185
+ }
186
+ }
187
+
188
+ allPrompts.push({
189
+ id: `${entry.sessionId}-${entry.timestamp}`,
190
+ text: entry.display || '',
191
+ timestamp: new Date(entry.timestamp).toISOString(),
192
+ project: entry.project || '',
193
+ session_id: entry.sessionId || '',
194
+ pasted_contents: entry.pastedContents || {},
195
+ // Derive intent from content keywords
196
+ intent: derivePromptIntent(entry.display || ''),
197
+ quality_score: calculateQualityScore(entry.display || '')
198
+ });
199
+ } catch (parseError) {
200
+ // Skip malformed lines
201
+ }
202
+ }
203
+
204
+ // Sort by timestamp descending
205
+ allPrompts.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime());
206
+
207
+ // Apply limit
208
+ const prompts = allPrompts.slice(0, limit);
209
+
210
+ res.writeHead(200, { 'Content-Type': 'application/json' });
211
+ res.end(JSON.stringify({ prompts, total: allPrompts.length }));
212
+ } catch (error: unknown) {
213
+ res.writeHead(500, { 'Content-Type': 'application/json' });
214
+ res.end(JSON.stringify({ error: (error as Error).message }));
215
+ }
216
+ return true;
217
+ }
218
+
219
+ // API: Memory Module - Get prompt history
220
+ if (pathname === '/api/memory/prompts') {
221
+ const projectPath = url.searchParams.get('path') || initialPath;
222
+ const limit = parseInt(url.searchParams.get('limit') || '50', 10);
223
+ const search = url.searchParams.get('search') || null;
224
+ const recursive = url.searchParams.get('recursive') !== 'false';
225
+
226
+ try {
227
+ let prompts;
228
+
229
+ // Recursive mode: aggregate prompts from parent and child projects
230
+ if (recursive && !search) {
231
+ const { getAggregatedPrompts } = await import('../memory-store.js');
232
+ prompts = await getAggregatedPrompts(projectPath, limit);
233
+ } else {
234
+ // Non-recursive mode or search mode: query only current project
235
+ const memoryStore = getMemoryStore(projectPath);
236
+
237
+ if (search) {
238
+ prompts = memoryStore.searchPrompts(search, limit);
239
+ } else {
240
+ // Get all recent prompts (we'll need to add this method to MemoryStore)
241
+ const stmt = memoryStore['db'].prepare(`
242
+ SELECT * FROM prompt_history
243
+ ORDER BY timestamp DESC
244
+ LIMIT ?
245
+ `);
246
+ prompts = stmt.all(limit);
247
+ }
248
+ }
249
+
250
+ res.writeHead(200, { 'Content-Type': 'application/json' });
251
+ res.end(JSON.stringify({ prompts }));
252
+ } catch (error: unknown) {
253
+ res.writeHead(500, { 'Content-Type': 'application/json' });
254
+ res.end(JSON.stringify({ error: (error as Error).message }));
255
+ }
256
+ return true;
257
+ }
258
+
259
+ // API: Memory Module - Get insights (from prompt_patterns)
260
+ if (pathname === '/api/memory/insights' && req.method === 'GET') {
261
+ const projectPath = url.searchParams.get('path') || initialPath;
262
+ const limitParam = url.searchParams.get('limit');
263
+ const tool = url.searchParams.get('tool') || undefined;
264
+
265
+ // Check if this is a request for insights history (has limit or tool param)
266
+ if (limitParam || tool) {
267
+ const limit = parseInt(limitParam || '20', 10);
268
+ try {
269
+ const storeModule = await import('../../tools/cli-history-store.js');
270
+ const store = storeModule.getHistoryStore(projectPath);
271
+ const insights = store.getInsights({ limit, tool });
272
+
273
+ res.writeHead(200, { 'Content-Type': 'application/json' });
274
+ res.end(JSON.stringify({ success: true, insights }));
275
+ } catch (error: unknown) {
276
+ res.writeHead(500, { 'Content-Type': 'application/json' });
277
+ res.end(JSON.stringify({ error: (error as Error).message }));
278
+ }
279
+ return true;
280
+ }
281
+
282
+ // Default: Get prompt pattern insights
283
+ try {
284
+ const memoryStore = getMemoryStore(projectPath);
285
+
286
+ // Get total prompt count
287
+ const countStmt = memoryStore['db'].prepare(`SELECT COUNT(*) as count FROM prompt_history`);
288
+ const { count: totalPrompts } = countStmt.get() as { count: number };
289
+
290
+ // Get top intent
291
+ const topIntentStmt = memoryStore['db'].prepare(`
292
+ SELECT intent_label, COUNT(*) as count
293
+ FROM prompt_history
294
+ WHERE intent_label IS NOT NULL
295
+ GROUP BY intent_label
296
+ ORDER BY count DESC
297
+ LIMIT 1
298
+ `);
299
+ const topIntentRow = topIntentStmt.get() as { intent_label: string; count: number } | undefined;
300
+
301
+ // Get average prompt length
302
+ const avgLengthStmt = memoryStore['db'].prepare(`
303
+ SELECT AVG(LENGTH(prompt_text)) as avg_length
304
+ FROM prompt_history
305
+ WHERE prompt_text IS NOT NULL
306
+ `);
307
+ const { avg_length: avgLength } = avgLengthStmt.get() as { avg_length: number };
308
+
309
+ // Get prompt patterns
310
+ const patternsStmt = memoryStore['db'].prepare(`
311
+ SELECT * FROM prompt_patterns
312
+ ORDER BY frequency DESC
313
+ LIMIT 10
314
+ `);
315
+ const patterns = patternsStmt.all();
316
+
317
+ res.writeHead(200, { 'Content-Type': 'application/json' });
318
+ res.end(JSON.stringify({
319
+ stats: {
320
+ totalPrompts,
321
+ topIntent: topIntentRow?.intent_label || 'unknown',
322
+ avgLength: Math.round(avgLength || 0)
323
+ },
324
+ patterns: patterns.map((p: any) => ({
325
+ type: p.pattern_type,
326
+ description: `Pattern detected in prompts`,
327
+ occurrences: p.frequency,
328
+ suggestion: `Consider using more specific prompts for ${p.pattern_type}`
329
+ }))
330
+ }));
331
+ } catch (error: unknown) {
332
+ res.writeHead(500, { 'Content-Type': 'application/json' });
333
+ res.end(JSON.stringify({ error: (error as Error).message }));
334
+ }
335
+ return true;
336
+ }
337
+
338
+ // API: Memory Module - Trigger async CLI-based insights analysis
339
+ if (pathname === '/api/memory/insights/analyze' && req.method === 'POST') {
340
+ handlePostRequest(req, res, async (body: any) => {
341
+ const projectPath = body.path || initialPath;
342
+ const tool = body.tool || 'gemini'; // gemini, qwen, codex, claude
343
+ const prompts = body.prompts || [];
344
+ const lang = body.lang || 'en'; // Language preference
345
+
346
+ if (prompts.length === 0) {
347
+ return { error: 'No prompts provided for analysis', status: 400 };
348
+ }
349
+
350
+ // Prepare prompt summary for CLI analysis
351
+ const promptSummary = prompts.slice(0, 20).map((p: any, i: number) => {
352
+ return `${i + 1}. [${p.intent || 'unknown'}] ${(p.text || '').substring(0, 100)}...`;
353
+ }).join('\n');
354
+
355
+ const langInstruction = lang === 'zh'
356
+ ? '请用中文回复。所有 description、suggestion、title 字段必须使用中文。'
357
+ : 'Respond in English. All description, suggestion, title fields must be in English.';
358
+
359
+ const analysisPrompt = `
360
+ PURPOSE: Analyze prompt patterns and provide optimization suggestions
361
+ TASK:
362
+ • Review the following prompt history summary
363
+ • Identify common patterns (vague requests, repetitive queries, incomplete context)
364
+ • Suggest specific improvements for prompt quality
365
+ • Detect areas where prompts could be more effective
366
+ MODE: analysis
367
+ CONTEXT: ${prompts.length} prompts from project: ${projectPath}
368
+ EXPECTED: JSON with patterns array and suggestions array
369
+ LANGUAGE: ${langInstruction}
370
+
371
+ PROMPT HISTORY:
372
+ ${promptSummary}
373
+
374
+ Return ONLY valid JSON in this exact format (no markdown, no code blocks, just pure JSON):
375
+ {
376
+ "patterns": [
377
+ {"type": "pattern_type", "description": "description", "occurrences": count, "severity": "low|medium|high", "suggestion": "how to improve"}
378
+ ],
379
+ "suggestions": [
380
+ {"title": "title", "description": "description", "example": "example prompt"}
381
+ ]
382
+ }`;
383
+
384
+ try {
385
+ // Queue CLI execution
386
+ const result = await executeCliTool({
387
+ tool,
388
+ prompt: analysisPrompt,
389
+ mode: 'analysis',
390
+ timeout: 120000,
391
+ cd: projectPath,
392
+ category: 'insight'
393
+ });
394
+
395
+ // Try to parse JSON from response
396
+ let insights: { patterns: any[]; suggestions: any[] } = { patterns: [], suggestions: [] };
397
+ if (result.stdout) {
398
+ let outputText = result.stdout;
399
+
400
+ // Strip markdown code blocks if present
401
+ const codeBlockMatch = outputText.match(/```(?:json)?\s*([\s\S]*?)```/);
402
+ if (codeBlockMatch) {
403
+ outputText = codeBlockMatch[1].trim();
404
+ }
405
+
406
+ // Find JSON object in the response
407
+ const jsonMatch = outputText.match(/\{[\s\S]*\}/);
408
+ if (jsonMatch) {
409
+ try {
410
+ insights = JSON.parse(jsonMatch[0]);
411
+ // Ensure arrays exist
412
+ if (!Array.isArray(insights.patterns)) insights.patterns = [];
413
+ if (!Array.isArray(insights.suggestions)) insights.suggestions = [];
414
+ } catch (e) {
415
+ console.error('[insights/analyze] JSON parse error:', e);
416
+ // Return raw output if JSON parse fails
417
+ insights = {
418
+ patterns: [{ type: 'raw_analysis', description: result.stdout.substring(0, 500), occurrences: 1, severity: 'low', suggestion: '' }],
419
+ suggestions: []
420
+ };
421
+ }
422
+ } else {
423
+ // No JSON found, wrap raw output
424
+ insights = {
425
+ patterns: [{ type: 'raw_analysis', description: result.stdout.substring(0, 500), occurrences: 1, severity: 'low', suggestion: '' }],
426
+ suggestions: []
427
+ };
428
+ }
429
+ }
430
+
431
+ // Save insight to database
432
+ try {
433
+ const storeModule = await import('../../tools/cli-history-store.js');
434
+ const store = storeModule.getHistoryStore(projectPath);
435
+ const insightId = `insight-${Date.now()}`;
436
+ store.saveInsight({
437
+ id: insightId,
438
+ tool,
439
+ promptCount: prompts.length,
440
+ patterns: insights.patterns,
441
+ suggestions: insights.suggestions,
442
+ rawOutput: result.stdout || '',
443
+ executionId: result.execution?.id,
444
+ lang
445
+ });
446
+ console.log('[Insights] Saved insight:', insightId);
447
+ } catch (saveErr) {
448
+ console.warn('[Insights] Failed to save insight:', (saveErr as Error).message);
449
+ }
450
+
451
+ return {
452
+ success: true,
453
+ insights,
454
+ tool,
455
+ executionId: result.execution.id
456
+ };
457
+ } catch (error: unknown) {
458
+ return { error: (error as Error).message, status: 500 };
459
+ }
460
+ });
461
+ return true;
462
+ }
463
+
464
+ // API: Get single insight detail
465
+ if (pathname.startsWith('/api/memory/insights/') && req.method === 'GET') {
466
+ const insightId = pathname.replace('/api/memory/insights/', '');
467
+ const projectPath = url.searchParams.get('path') || initialPath;
468
+
469
+ if (!insightId || insightId === 'analyze') {
470
+ // Skip - handled by other routes
471
+ return false;
472
+ }
473
+
474
+ try {
475
+ const storeModule = await import('../../tools/cli-history-store.js');
476
+ const store = storeModule.getHistoryStore(projectPath);
477
+ const insight = store.getInsight(insightId);
478
+
479
+ if (insight) {
480
+ res.writeHead(200, { 'Content-Type': 'application/json' });
481
+ res.end(JSON.stringify({ success: true, insight }));
482
+ } else {
483
+ res.writeHead(404, { 'Content-Type': 'application/json' });
484
+ res.end(JSON.stringify({ error: 'Insight not found' }));
485
+ }
486
+ } catch (error: unknown) {
487
+ res.writeHead(500, { 'Content-Type': 'application/json' });
488
+ res.end(JSON.stringify({ error: (error as Error).message }));
489
+ }
490
+ return true;
491
+ }
492
+
493
+ // API: Delete insight
494
+ if (pathname.startsWith('/api/memory/insights/') && req.method === 'DELETE') {
495
+ const insightId = pathname.replace('/api/memory/insights/', '');
496
+ const projectPath = url.searchParams.get('path') || initialPath;
497
+
498
+ try {
499
+ const storeModule = await import('../../tools/cli-history-store.js');
500
+ const store = storeModule.getHistoryStore(projectPath);
501
+ const deleted = store.deleteInsight(insightId);
502
+
503
+ res.writeHead(200, { 'Content-Type': 'application/json' });
504
+ res.end(JSON.stringify({ success: deleted }));
505
+ } catch (error: unknown) {
506
+ res.writeHead(500, { 'Content-Type': 'application/json' });
507
+ res.end(JSON.stringify({ error: (error as Error).message }));
508
+ }
509
+ return true;
510
+ }
511
+
512
+ // API: Memory Module - Get hotspot statistics
513
+ if (pathname === '/api/memory/stats') {
514
+ const projectPath = url.searchParams.get('path') || initialPath;
515
+ const filter = url.searchParams.get('filter') || 'all'; // today, week, all
516
+ const limit = parseInt(url.searchParams.get('limit') || '10', 10);
517
+ const recursive = url.searchParams.get('recursive') !== 'false';
518
+
519
+ try {
520
+ // If requesting aggregated stats, use the aggregated function
521
+ if (url.searchParams.has('aggregated') || recursive) {
522
+ const { getAggregatedStats } = await import('../memory-store.js');
523
+ const aggregatedStats = await getAggregatedStats(projectPath);
524
+
525
+ res.writeHead(200, { 'Content-Type': 'application/json' });
526
+ res.end(JSON.stringify({
527
+ stats: aggregatedStats,
528
+ aggregated: true
529
+ }));
530
+ return true;
531
+ }
532
+
533
+ // Original hotspot statistics (non-recursive)
534
+ const memoryStore = getMemoryStore(projectPath);
535
+ const hotEntities = memoryStore.getHotEntities(limit * 4);
536
+
537
+ // Filter by time if needed
538
+ let filtered = hotEntities;
539
+ if (filter === 'today') {
540
+ const today = new Date();
541
+ today.setHours(0, 0, 0, 0);
542
+ filtered = hotEntities.filter((e: any) => new Date(e.last_seen_at) >= today);
543
+ } else if (filter === 'week') {
544
+ const weekAgo = new Date();
545
+ weekAgo.setDate(weekAgo.getDate() - 7);
546
+ filtered = hotEntities.filter((e: any) => new Date(e.last_seen_at) >= weekAgo);
547
+ }
548
+
549
+ // Separate into mostRead, mostEdited, and mostMentioned
550
+ const fileEntities = filtered.filter((e: any) => e.type === 'file');
551
+ const topicEntities = filtered.filter((e: any) => e.type === 'topic');
552
+
553
+ const mostRead = fileEntities
554
+ .filter((e: any) => e.stats.read_count > 0)
555
+ .sort((a: any, b: any) => b.stats.read_count - a.stats.read_count)
556
+ .slice(0, limit)
557
+ .map((e: any) => ({
558
+ path: e.value,
559
+ file: e.value.split(/[/\\]/).pop(),
560
+ heat: e.stats.read_count,
561
+ count: e.stats.read_count,
562
+ lastSeen: e.last_seen_at
563
+ }));
564
+
565
+ const mostEdited = fileEntities
566
+ .filter((e: any) => e.stats.write_count > 0)
567
+ .sort((a: any, b: any) => b.stats.write_count - a.stats.write_count)
568
+ .slice(0, limit)
569
+ .map((e: any) => ({
570
+ path: e.value,
571
+ file: e.value.split(/[/\\]/).pop(),
572
+ heat: e.stats.write_count,
573
+ count: e.stats.write_count,
574
+ lastSeen: e.last_seen_at
575
+ }));
576
+
577
+ const mostMentioned = topicEntities
578
+ .filter((e: any) => e.stats.mention_count > 0)
579
+ .sort((a: any, b: any) => b.stats.mention_count - a.stats.mention_count)
580
+ .slice(0, limit)
581
+ .map((e: any) => ({
582
+ topic: e.value,
583
+ preview: e.value.substring(0, 100) + (e.value.length > 100 ? '...' : ''),
584
+ heat: e.stats.mention_count,
585
+ count: e.stats.mention_count,
586
+ lastSeen: e.last_seen_at
587
+ }));
588
+
589
+ res.writeHead(200, { 'Content-Type': 'application/json' });
590
+ res.end(JSON.stringify({ stats: { mostRead, mostEdited, mostMentioned } }));
591
+ } catch (error: unknown) {
592
+ res.writeHead(200, { 'Content-Type': 'application/json' });
593
+ res.end(JSON.stringify({ stats: { mostRead: [], mostEdited: [], mostMentioned: [] } }));
594
+ }
595
+ return true;
596
+ }
597
+
598
+ // API: Memory Module - Get memory graph (file associations with modules and components)
599
+ if (pathname === '/api/memory/graph') {
600
+ const projectPath = url.searchParams.get('path') || initialPath;
601
+
602
+ try {
603
+ const memoryStore = getMemoryStore(projectPath);
604
+ const hotEntities = memoryStore.getHotEntities(100);
605
+
606
+ // Build file nodes from entities
607
+ const fileEntities = hotEntities.filter((e: any) => e.type === 'file');
608
+ const fileNodes = fileEntities.map((e: any) => {
609
+ const fileName = e.value.split(/[/\\]/).pop() || '';
610
+ // Detect component type based on file name patterns
611
+ const isComponent = /\.(tsx|jsx|vue|svelte)$/.test(fileName) ||
612
+ /^[A-Z][a-zA-Z]+\.(ts|js)$/.test(fileName) ||
613
+ fileName.includes('.component.') ||
614
+ fileName.includes('.controller.');
615
+
616
+ return {
617
+ id: e.value,
618
+ name: fileName,
619
+ path: e.value,
620
+ type: isComponent ? 'component' : 'file',
621
+ heat: Math.min(25, 8 + e.stats.heat_score / 10)
622
+ };
623
+ });
624
+
625
+ // Extract unique modules (directories) from file paths
626
+ const moduleMap = new Map<string, { heat: number; files: string[] }>();
627
+ for (const file of fileEntities) {
628
+ const parts = file.value.split(/[/\\]/);
629
+ // Get parent directory as module (skip if root level)
630
+ if (parts.length > 1) {
631
+ const modulePath = parts.slice(0, -1).join('/');
632
+ const moduleName = parts[parts.length - 2] || modulePath;
633
+ // Skip common non-module directories
634
+ if (['node_modules', '.git', 'dist', 'build', '.next', '.nuxt'].includes(moduleName)) continue;
635
+
636
+ if (!moduleMap.has(modulePath)) {
637
+ moduleMap.set(modulePath, { heat: 0, files: [] });
638
+ }
639
+ const mod = moduleMap.get(modulePath)!;
640
+ mod.heat += file.stats.heat_score / 20;
641
+ mod.files.push(file.value);
642
+ }
643
+ }
644
+
645
+ // Create module nodes (limit to top modules by heat)
646
+ const moduleNodes = Array.from(moduleMap.entries())
647
+ .sort((a, b) => b[1].heat - a[1].heat)
648
+ .slice(0, 15)
649
+ .map(([modulePath, data]) => ({
650
+ id: modulePath,
651
+ name: modulePath.split(/[/\\]/).pop() || modulePath,
652
+ path: modulePath,
653
+ type: 'module',
654
+ heat: Math.min(20, 12 + data.heat / 5),
655
+ fileCount: data.files.length
656
+ }));
657
+
658
+ // Combine all nodes
659
+ const nodes = [...fileNodes, ...moduleNodes];
660
+ const nodeIds = new Set(nodes.map(n => n.id));
661
+
662
+ // Build edges from associations
663
+ const edges: any[] = [];
664
+ const edgeSet = new Set<string>(); // Prevent duplicate edges
665
+
666
+ // Add file-to-file associations
667
+ for (const entity of hotEntities) {
668
+ if (!entity.id || entity.type !== 'file') continue;
669
+ const associations = memoryStore.getAssociations(entity.id, 10);
670
+ for (const assoc of associations) {
671
+ if (assoc.target && nodeIds.has(assoc.target.value)) {
672
+ const edgeKey = [entity.value, assoc.target.value].sort().join('|');
673
+ if (!edgeSet.has(edgeKey)) {
674
+ edgeSet.add(edgeKey);
675
+ edges.push({
676
+ source: entity.value,
677
+ target: assoc.target.value,
678
+ weight: assoc.weight
679
+ });
680
+ }
681
+ }
682
+ }
683
+ }
684
+
685
+ // Add file-to-module edges (files belong to their parent modules)
686
+ for (const [modulePath, data] of moduleMap.entries()) {
687
+ if (!nodeIds.has(modulePath)) continue;
688
+ for (const filePath of data.files) {
689
+ if (nodeIds.has(filePath)) {
690
+ const edgeKey = [modulePath, filePath].sort().join('|');
691
+ if (!edgeSet.has(edgeKey)) {
692
+ edgeSet.add(edgeKey);
693
+ edges.push({
694
+ source: modulePath,
695
+ target: filePath,
696
+ weight: 2 // Lower weight for structural relationships
697
+ });
698
+ }
699
+ }
700
+ }
701
+ }
702
+
703
+ res.writeHead(200, { 'Content-Type': 'application/json' });
704
+ res.end(JSON.stringify({ graph: { nodes, edges } }));
705
+ } catch (error: unknown) {
706
+ res.writeHead(200, { 'Content-Type': 'application/json' });
707
+ res.end(JSON.stringify({ graph: { nodes: [], edges: [] } }));
708
+ }
709
+ return true;
710
+ }
711
+
712
+ // API: Memory Module - Get recent context activities
713
+ if (pathname === '/api/memory/recent') {
714
+ const projectPath = url.searchParams.get('path') || initialPath;
715
+ const limit = parseInt(url.searchParams.get('limit') || '20', 10);
716
+
717
+ try {
718
+ const memoryStore = getMemoryStore(projectPath);
719
+
720
+ // Get recent access logs with entity info - filter to file type only
721
+ const db = (memoryStore as any).db;
722
+ const recentLogs = db.prepare(`
723
+ SELECT a.*, e.type, e.value
724
+ FROM access_logs a
725
+ JOIN entities e ON a.entity_id = e.id
726
+ WHERE e.type = 'file'
727
+ ORDER BY a.timestamp DESC
728
+ LIMIT ?
729
+ `).all(limit * 2) as any[]; // Fetch more to account for filtering
730
+
731
+ // Filter out invalid entries (JSON strings, error messages, etc.)
732
+ const validLogs = recentLogs.filter((log: any) => {
733
+ const value = log.value || '';
734
+ // Skip if value looks like JSON or contains error-like patterns
735
+ if (value.includes('"status"') || value.includes('"content"') ||
736
+ value.includes('"activeForm"') || value.startsWith('{') ||
737
+ value.startsWith('[') || value.includes('graph 400')) {
738
+ return false;
739
+ }
740
+ // Must have a file extension or look like a valid path
741
+ const hasExtension = /\.[a-zA-Z0-9]{1,10}$/.test(value);
742
+ const looksLikePath = value.includes('/') || value.includes('\\');
743
+ return hasExtension || looksLikePath;
744
+ }).slice(0, limit);
745
+
746
+ const recent = validLogs.map((log: any) => ({
747
+ type: log.action, // read, write, mention
748
+ timestamp: log.timestamp,
749
+ prompt: log.context_summary || '',
750
+ files: [log.value],
751
+ description: `${log.action}: ${log.value.split(/[/\\]/).pop()}`
752
+ }));
753
+
754
+ res.writeHead(200, { 'Content-Type': 'application/json' });
755
+ res.end(JSON.stringify({ recent }));
756
+ } catch (error: unknown) {
757
+ res.writeHead(200, { 'Content-Type': 'application/json' });
758
+ res.end(JSON.stringify({ recent: [] }));
759
+ }
760
+ return true;
761
+ }
762
+
763
+ // API: Active Memory - Get status
764
+ if (pathname === '/api/memory/active/status') {
765
+ const projectPath = url.searchParams.get('path') || initialPath;
766
+
767
+ if (!projectPath) {
768
+ res.writeHead(200, { 'Content-Type': 'application/json' });
769
+ res.end(JSON.stringify({ enabled: false, status: null, config: { interval: 'manual', tool: 'gemini' } }));
770
+ return true;
771
+ }
772
+
773
+ try {
774
+ const rulesDir = join(projectPath, '.claude', 'rules');
775
+ const configPath = join(rulesDir, 'active_memory.md');
776
+ const configJsonPath = join(projectPath, '.claude', 'active_memory_config.json');
777
+ const enabled = existsSync(configPath);
778
+ let lastSync: string | null = null;
779
+ let fileCount = 0;
780
+ let config = { interval: 'manual', tool: 'gemini' };
781
+
782
+ if (enabled) {
783
+ const stats = statSync(configPath);
784
+ lastSync = stats.mtime.toISOString();
785
+ const content = readFileSync(configPath, 'utf-8');
786
+ // Count file sections
787
+ fileCount = (content.match(/^## /gm) || []).length;
788
+ }
789
+
790
+ // Load config if exists
791
+ if (existsSync(configJsonPath)) {
792
+ try {
793
+ config = JSON.parse(readFileSync(configJsonPath, 'utf-8'));
794
+ } catch (e) { /* ignore parse errors */ }
795
+ }
796
+
797
+ res.writeHead(200, { 'Content-Type': 'application/json' });
798
+ res.end(JSON.stringify({
799
+ enabled,
800
+ status: enabled ? { lastSync, fileCount } : null,
801
+ config
802
+ }));
803
+ } catch (error: unknown) {
804
+ console.error('Active Memory status error:', error);
805
+ res.writeHead(200, { 'Content-Type': 'application/json' });
806
+ res.end(JSON.stringify({ enabled: false, status: null, config: { interval: 'manual', tool: 'gemini' } }));
807
+ }
808
+ return true;
809
+ }
810
+
811
+ // API: Active Memory - Toggle
812
+ if (pathname === '/api/memory/active/toggle' && req.method === 'POST') {
813
+ let body = '';
814
+ req.on('data', (chunk: Buffer) => { body += chunk.toString(); });
815
+ req.on('end', async () => {
816
+ try {
817
+ const { enabled, config } = JSON.parse(body || '{}');
818
+ const projectPath = initialPath;
819
+
820
+ if (!projectPath) {
821
+ res.writeHead(400, { 'Content-Type': 'application/json' });
822
+ res.end(JSON.stringify({ error: 'No project path configured' }));
823
+ return;
824
+ }
825
+
826
+ const claudeDir = join(projectPath, '.claude');
827
+ const rulesDir = join(claudeDir, 'rules');
828
+ const configPath = join(rulesDir, 'active_memory.md');
829
+ const configJsonPath = join(claudeDir, 'active_memory_config.json');
830
+
831
+ if (enabled) {
832
+ // Enable: Create directories and initial file
833
+ if (!existsSync(claudeDir)) {
834
+ mkdirSync(claudeDir, { recursive: true });
835
+ }
836
+ if (!existsSync(rulesDir)) {
837
+ mkdirSync(rulesDir, { recursive: true });
838
+ }
839
+
840
+ // Save config
841
+ if (config) {
842
+ writeFileSync(configJsonPath, JSON.stringify(config, null, 2), 'utf-8');
843
+ }
844
+
845
+ // Create initial active_memory.md with header
846
+ const initialContent = `# Active Memory - Project Context
847
+
848
+ > Auto-generated understanding of frequently accessed files.
849
+ > Last updated: ${new Date().toISOString()}
850
+
851
+ ---
852
+
853
+ *No files analyzed yet. Click "Sync Now" to analyze hot files.*
854
+ `;
855
+ writeFileSync(configPath, initialContent, 'utf-8');
856
+
857
+ res.writeHead(200, { 'Content-Type': 'application/json' });
858
+ res.end(JSON.stringify({ enabled: true, message: 'Active Memory enabled' }));
859
+ } else {
860
+ // Disable: Remove the files
861
+ if (existsSync(configPath)) {
862
+ unlinkSync(configPath);
863
+ }
864
+ if (existsSync(configJsonPath)) {
865
+ unlinkSync(configJsonPath);
866
+ }
867
+
868
+ res.writeHead(200, { 'Content-Type': 'application/json' });
869
+ res.end(JSON.stringify({ enabled: false, message: 'Active Memory disabled' }));
870
+ }
871
+ } catch (error: unknown) {
872
+ console.error('Active Memory toggle error:', error);
873
+ if (!res.headersSent) {
874
+ res.writeHead(500, { 'Content-Type': 'application/json' });
875
+ res.end(JSON.stringify({ error: (error as Error).message }));
876
+ }
877
+ }
878
+ });
879
+ return true;
880
+ }
881
+
882
+ // API: Active Memory - Update Config
883
+ if (pathname === '/api/memory/active/config' && req.method === 'POST') {
884
+ let body = '';
885
+ req.on('data', (chunk: Buffer) => { body += chunk.toString(); });
886
+ req.on('end', async () => {
887
+ try {
888
+ const { config } = JSON.parse(body || '{}');
889
+ const projectPath = initialPath;
890
+ const claudeDir = join(projectPath, '.claude');
891
+ const configJsonPath = join(claudeDir, 'active_memory_config.json');
892
+
893
+ if (!existsSync(claudeDir)) {
894
+ mkdirSync(claudeDir, { recursive: true });
895
+ }
896
+
897
+ writeFileSync(configJsonPath, JSON.stringify(config, null, 2), 'utf-8');
898
+
899
+ res.writeHead(200, { 'Content-Type': 'application/json' });
900
+ res.end(JSON.stringify({ success: true, config }));
901
+ } catch (error: unknown) {
902
+ res.writeHead(500, { 'Content-Type': 'application/json' });
903
+ res.end(JSON.stringify({ error: (error as Error).message }));
904
+ }
905
+ });
906
+ return true;
907
+ }
908
+
909
+ // API: Active Memory - Sync (analyze hot files using CLI and update active_memory.md)
910
+ if (pathname === '/api/memory/active/sync' && req.method === 'POST') {
911
+ let body = '';
912
+ req.on('data', (chunk: Buffer) => { body += chunk.toString(); });
913
+ req.on('end', async () => {
914
+ try {
915
+ const { tool = 'gemini' } = JSON.parse(body || '{}');
916
+ const projectPath = initialPath;
917
+
918
+ if (!projectPath) {
919
+ res.writeHead(400, { 'Content-Type': 'application/json' });
920
+ res.end(JSON.stringify({ error: 'No project path configured' }));
921
+ return;
922
+ }
923
+
924
+ const claudeDir = join(projectPath, '.claude');
925
+ const rulesDir = join(claudeDir, 'rules');
926
+ const configPath = join(rulesDir, 'active_memory.md');
927
+
928
+ // Get hot files from memory store - with fallback
929
+ let hotFiles: any[] = [];
930
+ try {
931
+ const memoryStore = getMemoryStore(projectPath);
932
+ const hotEntities = memoryStore.getHotEntities(20);
933
+ hotFiles = hotEntities
934
+ .filter((e: any) => e.type === 'file')
935
+ .slice(0, 10);
936
+ } catch (memErr) {
937
+ console.warn('[Active Memory] Memory store error, using empty list:', (memErr as Error).message);
938
+ }
939
+
940
+ // Build file list for CLI analysis
941
+ const filePaths = hotFiles.map((f: any) => {
942
+ const filePath = f.value;
943
+ return isAbsolute(filePath) ? filePath : join(projectPath, filePath);
944
+ }).filter((p: string) => existsSync(p));
945
+
946
+ // Build the active_memory.md content header
947
+ let content = `# Active Memory - Project Context
948
+
949
+ > Auto-generated understanding of frequently accessed files using ${tool.toUpperCase()}.
950
+ > Last updated: ${new Date().toISOString()}
951
+ > Files analyzed: ${hotFiles.length}
952
+ > CLI Tool: ${tool}
953
+
954
+ ---
955
+
956
+ `;
957
+
958
+ // Use CCW CLI tool to analyze files
959
+ let cliOutput = '';
960
+
961
+ // Build CLI prompt
962
+ const cliPrompt = `PURPOSE: Analyze the following hot files and provide a concise understanding of each.
963
+ TASK: For each file, describe its purpose, key exports, dependencies, and how it relates to other files.
964
+ MODE: analysis
965
+ CONTEXT: ${filePaths.map((p: string) => '@' + p).join(' ')}
966
+ EXPECTED: Markdown format with ## headings for each file, bullet points for key information.
967
+ RULES: Be concise. Focus on practical understanding. Include function signatures for key exports.`;
968
+
969
+ // Try to execute CLI using CCW's built-in executor
970
+ try {
971
+ const syncId = `active-memory-${Date.now()}`;
972
+ const result = await executeCliTool({
973
+ tool: tool === 'qwen' ? 'qwen' : 'gemini',
974
+ prompt: cliPrompt,
975
+ mode: 'analysis',
976
+ format: 'plain',
977
+ cd: projectPath,
978
+ timeout: 120000,
979
+ stream: false,
980
+ category: 'internal',
981
+ id: syncId
982
+ });
983
+
984
+ if (result.success && result.execution?.output) {
985
+ // Extract stdout from output object with proper serialization
986
+ const output = result.execution.output;
987
+ if (typeof output === 'string') {
988
+ cliOutput = output;
989
+ } else if (output && typeof output === 'object') {
990
+ // Handle object output - extract stdout or serialize the object
991
+ if (output.stdout && typeof output.stdout === 'string') {
992
+ cliOutput = output.stdout;
993
+ } else if (output.stderr && typeof output.stderr === 'string') {
994
+ cliOutput = output.stderr;
995
+ } else {
996
+ // Last resort: serialize the entire object as JSON
997
+ cliOutput = JSON.stringify(output, null, 2);
998
+ }
999
+ } else {
1000
+ cliOutput = '';
1001
+ }
1002
+ }
1003
+
1004
+ // Add CLI output to content (only if not empty)
1005
+ if (cliOutput && cliOutput.trim()) {
1006
+ content += cliOutput + '\n\n---\n\n';
1007
+ }
1008
+
1009
+ } catch (cliErr) {
1010
+ // Fallback to basic analysis if CLI fails
1011
+ console.warn('[Active Memory] CLI analysis failed, using basic analysis:', (cliErr as Error).message);
1012
+
1013
+ // Basic analysis fallback
1014
+ for (const file of hotFiles) {
1015
+ const fileName = file.value.split(/[/\\]/).pop() || file.value;
1016
+ const filePath = file.value;
1017
+ const heat = file.stats?.heat_score || 0;
1018
+ const readCount = file.stats?.read_count || 0;
1019
+ const writeCount = file.stats?.write_count || 0;
1020
+
1021
+ content += `## ${fileName}
1022
+
1023
+ - **Path**: \`${filePath}\`
1024
+ - **Heat Score**: ${heat}
1025
+ - **Access**: ${readCount} reads, ${writeCount} writes
1026
+ - **Last Seen**: ${file.last_seen_at || 'Unknown'}
1027
+
1028
+ `;
1029
+
1030
+ // Try to read file and generate summary
1031
+ try {
1032
+ const fullPath = isAbsolute(filePath) ? filePath : join(projectPath, filePath);
1033
+
1034
+ if (existsSync(fullPath)) {
1035
+ const stat = statSync(fullPath);
1036
+ const ext = extname(fullPath).toLowerCase();
1037
+
1038
+ content += `- **Size**: ${(stat.size / 1024).toFixed(1)} KB\n`;
1039
+ content += `- **Type**: ${ext || 'unknown'}\n`;
1040
+
1041
+ const textExts = ['.ts', '.js', '.tsx', '.jsx', '.md', '.json', '.css', '.html', '.vue', '.svelte', '.py', '.go', '.rs'];
1042
+ if (textExts.includes(ext) && stat.size < 100000) {
1043
+ const fileContent = readFileSync(fullPath, 'utf-8');
1044
+ const lines = fileContent.split('\n').slice(0, 30);
1045
+
1046
+ const exports = lines.filter(l =>
1047
+ l.includes('export ') || l.includes('function ') ||
1048
+ l.includes('class ') || l.includes('interface ')
1049
+ ).slice(0, 8);
1050
+
1051
+ if (exports.length > 0) {
1052
+ content += `\n**Key Exports**:\n\`\`\`\n${exports.join('\n')}\n\`\`\`\n`;
1053
+ }
1054
+ }
1055
+ }
1056
+ } catch (fileErr) {
1057
+ // Skip file analysis errors
1058
+ }
1059
+
1060
+ content += '\n---\n\n';
1061
+ }
1062
+ }
1063
+
1064
+ // Ensure directories exist
1065
+ if (!existsSync(claudeDir)) {
1066
+ mkdirSync(claudeDir, { recursive: true });
1067
+ }
1068
+ if (!existsSync(rulesDir)) {
1069
+ mkdirSync(rulesDir, { recursive: true });
1070
+ }
1071
+
1072
+ // Write the file
1073
+ writeFileSync(configPath, content, 'utf-8');
1074
+
1075
+ // Broadcast Active Memory sync completion event
1076
+ broadcastToClients({
1077
+ type: 'ACTIVE_MEMORY_SYNCED',
1078
+ payload: {
1079
+ filesAnalyzed: hotFiles.length,
1080
+ path: configPath,
1081
+ tool,
1082
+ usedCli: cliOutput.length > 0,
1083
+ timestamp: new Date().toISOString()
1084
+ }
1085
+ });
1086
+
1087
+ res.writeHead(200, { 'Content-Type': 'application/json' });
1088
+ res.end(JSON.stringify({
1089
+ success: true,
1090
+ filesAnalyzed: hotFiles.length,
1091
+ path: configPath,
1092
+ usedCli: cliOutput.length > 0
1093
+ }));
1094
+ } catch (error: unknown) {
1095
+ console.error('[Active Memory] Sync error:', error);
1096
+ if (!res.headersSent) {
1097
+ res.writeHead(500, { 'Content-Type': 'application/json' });
1098
+ res.end(JSON.stringify({ error: (error as Error).message }));
1099
+ }
1100
+ }
1101
+ });
1102
+ return true;
1103
+ }
1104
+
1105
+ // API: Memory Module - Get conversations index
1106
+ if (pathname === '/api/memory/conversations') {
1107
+ const projectPath = url.searchParams.get('path') || initialPath;
1108
+ const project = url.searchParams.get('project') || null;
1109
+ const limit = parseInt(url.searchParams.get('limit') || '20', 10);
1110
+
1111
+ try {
1112
+ const memoryStore = getMemoryStore(projectPath);
1113
+
1114
+ let conversations;
1115
+ if (project) {
1116
+ const stmt = memoryStore['db'].prepare(`
1117
+ SELECT * FROM conversations
1118
+ WHERE project_name = ?
1119
+ ORDER BY updated_at DESC
1120
+ LIMIT ?
1121
+ `);
1122
+ conversations = stmt.all(project, limit);
1123
+ } else {
1124
+ conversations = memoryStore.getConversations(limit);
1125
+ }
1126
+
1127
+ res.writeHead(200, { 'Content-Type': 'application/json' });
1128
+ res.end(JSON.stringify({ conversations }));
1129
+ } catch (error: unknown) {
1130
+ res.writeHead(500, { 'Content-Type': 'application/json' });
1131
+ res.end(JSON.stringify({ error: (error as Error).message }));
1132
+ }
1133
+ return true;
1134
+ }
1135
+
1136
+ // API: Memory Module - Replay conversation
1137
+ if (pathname.startsWith('/api/memory/replay/')) {
1138
+ const conversationId = pathname.replace('/api/memory/replay/', '');
1139
+ const projectPath = url.searchParams.get('path') || initialPath;
1140
+
1141
+ if (!conversationId) {
1142
+ res.writeHead(400, { 'Content-Type': 'application/json' });
1143
+ res.end(JSON.stringify({ error: 'Conversation ID is required' }));
1144
+ return true;
1145
+ }
1146
+
1147
+ try {
1148
+ const memoryStore = getMemoryStore(projectPath);
1149
+ const conversation = memoryStore.getConversation(conversationId);
1150
+
1151
+ if (!conversation) {
1152
+ res.writeHead(404, { 'Content-Type': 'application/json' });
1153
+ res.end(JSON.stringify({ error: 'Conversation not found' }));
1154
+ return true;
1155
+ }
1156
+
1157
+ const messages = memoryStore.getMessages(conversationId);
1158
+
1159
+ // Enhance messages with tool calls
1160
+ const messagesWithTools = [];
1161
+ for (const message of messages) {
1162
+ const toolCalls = message.id ? memoryStore.getToolCalls(message.id) : [];
1163
+ messagesWithTools.push({
1164
+ ...message,
1165
+ tool_calls: toolCalls
1166
+ });
1167
+ }
1168
+
1169
+ res.writeHead(200, { 'Content-Type': 'application/json' });
1170
+ res.end(JSON.stringify({
1171
+ conversation,
1172
+ messages: messagesWithTools
1173
+ }));
1174
+ } catch (error: unknown) {
1175
+ res.writeHead(500, { 'Content-Type': 'application/json' });
1176
+ res.end(JSON.stringify({ error: (error as Error).message }));
1177
+ }
1178
+ return true;
1179
+ }
1180
+
1181
+ // API: Memory Module - Import history (async task)
1182
+ if (pathname === '/api/memory/import' && req.method === 'POST') {
1183
+ handlePostRequest(req, res, async (body) => {
1184
+ const { source = 'all', project, path: projectPath } = body;
1185
+ const basePath = projectPath || initialPath;
1186
+
1187
+ // Generate task ID for async operation
1188
+ const taskId = `import-${Date.now()}`;
1189
+
1190
+ // TODO: Implement actual history import using HistoryImporter
1191
+ // For now, return a placeholder response
1192
+ console.log(`[Memory] Import task ${taskId} started: source=${source}, project=${project}`);
1193
+
1194
+ return {
1195
+ success: true,
1196
+ taskId,
1197
+ message: 'Import task started (not yet implemented)',
1198
+ source,
1199
+ project
1200
+ };
1201
+ });
1202
+ return true;
1203
+ }
1204
+
1205
+ return false;
1206
+ }