@jingyi0605/codingns 0.2.0 → 0.3.0

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 (328) hide show
  1. package/README.md +44 -0
  2. package/bin/codingns.mjs +918 -55
  3. package/dist/public/assets/{TerminalPage-BlbQuWi1.js → TerminalPage-Dfw1QUqW.js} +19 -19
  4. package/dist/public/assets/index-DR2rPNi7.css +1 -0
  5. package/dist/public/assets/index-DTOruahn.js +114 -0
  6. package/dist/public/index.html +2 -2
  7. package/dist/server/config/env.d.ts +3 -0
  8. package/dist/server/config/env.js +35 -3
  9. package/dist/server/config/env.js.map +1 -1
  10. package/dist/server/modules/assistant-capability/assistant-capability-controller.d.ts +89 -0
  11. package/dist/server/modules/assistant-capability/assistant-capability-controller.js +138 -0
  12. package/dist/server/modules/assistant-capability/assistant-capability-controller.js.map +1 -0
  13. package/dist/server/modules/assistant-capability/assistant-capability-service.d.ts +115 -0
  14. package/dist/server/modules/assistant-capability/assistant-capability-service.js +241 -0
  15. package/dist/server/modules/assistant-capability/assistant-capability-service.js.map +1 -0
  16. package/dist/server/modules/butler/butler-control-session-service.d.ts +3 -1
  17. package/dist/server/modules/butler/butler-control-session-service.js +96 -33
  18. package/dist/server/modules/butler/butler-control-session-service.js.map +1 -1
  19. package/dist/server/modules/butler/butler-follow-up-scheduler.d.ts +9 -0
  20. package/dist/server/modules/butler/butler-follow-up-scheduler.js +47 -11
  21. package/dist/server/modules/butler/butler-follow-up-scheduler.js.map +1 -1
  22. package/dist/server/modules/butler/butler-follow-up-service.d.ts +7 -1
  23. package/dist/server/modules/butler/butler-follow-up-service.js +10 -0
  24. package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -1
  25. package/dist/server/modules/butler/butler-session-service.d.ts +3 -1
  26. package/dist/server/modules/butler/butler-session-service.js +82 -16
  27. package/dist/server/modules/butler/butler-session-service.js.map +1 -1
  28. package/dist/server/modules/butler/butler-session-summary-service.d.ts +8 -1
  29. package/dist/server/modules/butler/butler-session-summary-service.js +34 -7
  30. package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -1
  31. package/dist/server/modules/butler/context-aggregator.js +44 -13
  32. package/dist/server/modules/butler/context-aggregator.js.map +1 -1
  33. package/dist/server/modules/butler/patrol-scheduler.d.ts +9 -0
  34. package/dist/server/modules/butler/patrol-scheduler.js +63 -9
  35. package/dist/server/modules/butler/patrol-scheduler.js.map +1 -1
  36. package/dist/server/modules/butler/session-summary-scheduler.d.ts +9 -0
  37. package/dist/server/modules/butler/session-summary-scheduler.js +47 -11
  38. package/dist/server/modules/butler/session-summary-scheduler.js.map +1 -1
  39. package/dist/server/modules/debug-target/debug-runtime-reconciliation-scheduler.d.ts +38 -0
  40. package/dist/server/modules/debug-target/debug-runtime-reconciliation-scheduler.js +99 -0
  41. package/dist/server/modules/debug-target/debug-runtime-reconciliation-scheduler.js.map +1 -0
  42. package/dist/server/modules/debug-target/debug-target-controller.d.ts +70 -0
  43. package/dist/server/modules/debug-target/debug-target-controller.js +113 -0
  44. package/dist/server/modules/debug-target/debug-target-controller.js.map +1 -0
  45. package/dist/server/modules/debug-target/debug-target-service.d.ts +105 -0
  46. package/dist/server/modules/debug-target/debug-target-service.js +1644 -0
  47. package/dist/server/modules/debug-target/debug-target-service.js.map +1 -0
  48. package/dist/server/modules/debug-target/framework-compatibility-matrix.d.ts +4 -0
  49. package/dist/server/modules/debug-target/framework-compatibility-matrix.js +45 -0
  50. package/dist/server/modules/debug-target/framework-compatibility-matrix.js.map +1 -0
  51. package/dist/server/modules/debug-target/launch-adapter-registry.d.ts +25 -0
  52. package/dist/server/modules/debug-target/launch-adapter-registry.js +445 -0
  53. package/dist/server/modules/debug-target/launch-adapter-registry.js.map +1 -0
  54. package/dist/server/modules/file/file-constants.d.ts +1 -0
  55. package/dist/server/modules/file/file-constants.js +1 -0
  56. package/dist/server/modules/file/file-constants.js.map +1 -1
  57. package/dist/server/modules/file/file-content-service.d.ts +2 -1
  58. package/dist/server/modules/file/file-content-service.js +53 -0
  59. package/dist/server/modules/file/file-content-service.js.map +1 -1
  60. package/dist/server/modules/file/file-controller.js +12 -3
  61. package/dist/server/modules/file/file-controller.js.map +1 -1
  62. package/dist/server/modules/file/file-preview-link-service.js +6 -37
  63. package/dist/server/modules/file/file-preview-link-service.js.map +1 -1
  64. package/dist/server/modules/file/file-preview-service.d.ts +6 -12
  65. package/dist/server/modules/file/file-preview-service.js +114 -28
  66. package/dist/server/modules/file/file-preview-service.js.map +1 -1
  67. package/dist/server/modules/file/file-preview-types.d.ts +37 -0
  68. package/dist/server/modules/file/file-preview-types.js +84 -0
  69. package/dist/server/modules/file/file-preview-types.js.map +1 -0
  70. package/dist/server/modules/git/commit-orchestrator.d.ts +4 -1
  71. package/dist/server/modules/git/commit-orchestrator.js +18 -1
  72. package/dist/server/modules/git/commit-orchestrator.js.map +1 -1
  73. package/dist/server/modules/git/git-auth.d.ts +25 -0
  74. package/dist/server/modules/git/git-auth.js +88 -0
  75. package/dist/server/modules/git/git-auth.js.map +1 -0
  76. package/dist/server/modules/git/git-controller.d.ts +12 -0
  77. package/dist/server/modules/git/git-controller.js +18 -1
  78. package/dist/server/modules/git/git-controller.js.map +1 -1
  79. package/dist/server/modules/git/git-read-service.d.ts +3 -1
  80. package/dist/server/modules/git/git-read-service.js +119 -2
  81. package/dist/server/modules/git/git-read-service.js.map +1 -1
  82. package/dist/server/modules/git/git-remote-credential-service.d.ts +9 -0
  83. package/dist/server/modules/git/git-remote-credential-service.js +76 -0
  84. package/dist/server/modules/git/git-remote-credential-service.js.map +1 -0
  85. package/dist/server/modules/git/git-write-service.d.ts +5 -2
  86. package/dist/server/modules/git/git-write-service.js +33 -17
  87. package/dist/server/modules/git/git-write-service.js.map +1 -1
  88. package/dist/server/modules/git/types.d.ts +26 -0
  89. package/dist/server/modules/git/workspace-repo-guard.js +3 -2
  90. package/dist/server/modules/git/workspace-repo-guard.js.map +1 -1
  91. package/dist/server/modules/provider/codex-model-options.d.ts +3 -1
  92. package/dist/server/modules/provider/codex-model-options.js +4 -1
  93. package/dist/server/modules/provider/codex-model-options.js.map +1 -1
  94. package/dist/server/modules/provider/opencode-model-options.d.ts +3 -1
  95. package/dist/server/modules/provider/opencode-model-options.js +5 -1
  96. package/dist/server/modules/provider/opencode-model-options.js.map +1 -1
  97. package/dist/server/modules/provider/provider-discovery-helper-client.d.ts +24 -0
  98. package/dist/server/modules/provider/provider-discovery-helper-client.js +14 -0
  99. package/dist/server/modules/provider/provider-discovery-helper-client.js.map +1 -1
  100. package/dist/server/modules/provider/provider-discovery-helper-process.js +54 -0
  101. package/dist/server/modules/provider/provider-discovery-helper-process.js.map +1 -1
  102. package/dist/server/modules/sessions/session-activity-authority-service.js +13 -1
  103. package/dist/server/modules/sessions/session-activity-authority-service.js.map +1 -1
  104. package/dist/server/modules/sessions/session-activity-inspector.js +21 -5
  105. package/dist/server/modules/sessions/session-activity-inspector.js.map +1 -1
  106. package/dist/server/modules/sessions/session-controller.d.ts +5 -0
  107. package/dist/server/modules/sessions/session-controller.js +16 -0
  108. package/dist/server/modules/sessions/session-controller.js.map +1 -1
  109. package/dist/server/modules/sessions/session-history-service.d.ts +27 -7
  110. package/dist/server/modules/sessions/session-history-service.js +439 -81
  111. package/dist/server/modules/sessions/session-history-service.js.map +1 -1
  112. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +2 -1
  113. package/dist/server/modules/sessions/session-live-runtime-service.js +12 -0
  114. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
  115. package/dist/server/modules/skills/skill-controller.d.ts +23 -0
  116. package/dist/server/modules/skills/skill-controller.js +35 -0
  117. package/dist/server/modules/skills/skill-controller.js.map +1 -0
  118. package/dist/server/modules/skills/skill-manager-service.d.ts +86 -0
  119. package/dist/server/modules/skills/skill-manager-service.js +557 -0
  120. package/dist/server/modules/skills/skill-manager-service.js.map +1 -0
  121. package/dist/server/modules/skills/skill-reconciler.d.ts +21 -0
  122. package/dist/server/modules/skills/skill-reconciler.js +99 -0
  123. package/dist/server/modules/skills/skill-reconciler.js.map +1 -0
  124. package/dist/server/modules/skills/skill-sync-planner.d.ts +8 -0
  125. package/dist/server/modules/skills/skill-sync-planner.js +20 -0
  126. package/dist/server/modules/skills/skill-sync-planner.js.map +1 -0
  127. package/dist/server/modules/skills/skill-target-adapter.d.ts +34 -0
  128. package/dist/server/modules/skills/skill-target-adapter.js +65 -0
  129. package/dist/server/modules/skills/skill-target-adapter.js.map +1 -0
  130. package/dist/server/modules/tailscale/tailscale-controller.d.ts +15 -0
  131. package/dist/server/modules/tailscale/tailscale-controller.js +33 -0
  132. package/dist/server/modules/tailscale/tailscale-controller.js.map +1 -0
  133. package/dist/server/modules/tailscale/tailscale-helper-client.d.ts +41 -0
  134. package/dist/server/modules/tailscale/tailscale-helper-client.js +135 -0
  135. package/dist/server/modules/tailscale/tailscale-helper-client.js.map +1 -0
  136. package/dist/server/modules/tailscale/tailscale-helper-process.d.ts +1 -0
  137. package/dist/server/modules/tailscale/tailscale-helper-process.js +327 -0
  138. package/dist/server/modules/tailscale/tailscale-helper-process.js.map +1 -0
  139. package/dist/server/modules/tailscale/tailscale-manager.d.ts +41 -0
  140. package/dist/server/modules/tailscale/tailscale-manager.js +259 -0
  141. package/dist/server/modules/tailscale/tailscale-manager.js.map +1 -0
  142. package/dist/server/modules/tailscale/tailscale-service.d.ts +43 -0
  143. package/dist/server/modules/tailscale/tailscale-service.js +201 -0
  144. package/dist/server/modules/tailscale/tailscale-service.js.map +1 -0
  145. package/dist/server/modules/tasks/event-loop-monitor.d.ts +21 -0
  146. package/dist/server/modules/tasks/event-loop-monitor.js +64 -0
  147. package/dist/server/modules/tasks/event-loop-monitor.js.map +1 -0
  148. package/dist/server/modules/tasks/observability-controller.d.ts +30 -0
  149. package/dist/server/modules/tasks/observability-controller.js +44 -0
  150. package/dist/server/modules/tasks/observability-controller.js.map +1 -0
  151. package/dist/server/modules/tasks/observability-service.d.ts +32 -0
  152. package/dist/server/modules/tasks/observability-service.js +104 -0
  153. package/dist/server/modules/tasks/observability-service.js.map +1 -0
  154. package/dist/server/modules/tasks/scheduler-metrics.d.ts +41 -0
  155. package/dist/server/modules/tasks/scheduler-metrics.js +92 -0
  156. package/dist/server/modules/tasks/scheduler-metrics.js.map +1 -0
  157. package/dist/server/modules/tasks/task-activity-log.d.ts +39 -0
  158. package/dist/server/modules/tasks/task-activity-log.js +43 -0
  159. package/dist/server/modules/tasks/task-activity-log.js.map +1 -0
  160. package/dist/server/modules/tasks/task-helper-client.d.ts +11 -0
  161. package/dist/server/modules/tasks/task-helper-client.js +132 -0
  162. package/dist/server/modules/tasks/task-helper-client.js.map +1 -0
  163. package/dist/server/modules/tasks/task-helper-process-handlers.d.ts +16 -0
  164. package/dist/server/modules/tasks/task-helper-process-handlers.js +14 -0
  165. package/dist/server/modules/tasks/task-helper-process-handlers.js.map +1 -0
  166. package/dist/server/modules/tasks/task-helper-process.d.ts +1 -0
  167. package/dist/server/modules/tasks/task-helper-process.js +49 -0
  168. package/dist/server/modules/tasks/task-helper-process.js.map +1 -0
  169. package/dist/server/modules/tasks/task-lane-executors.d.ts +2 -0
  170. package/dist/server/modules/tasks/task-lane-executors.js +15 -0
  171. package/dist/server/modules/tasks/task-lane-executors.js.map +1 -0
  172. package/dist/server/modules/tasks/task-manager.d.ts +15 -0
  173. package/dist/server/modules/tasks/task-manager.js +36 -0
  174. package/dist/server/modules/tasks/task-manager.js.map +1 -0
  175. package/dist/server/modules/tasks/task-metrics.d.ts +9 -0
  176. package/dist/server/modules/tasks/task-metrics.js +81 -0
  177. package/dist/server/modules/tasks/task-metrics.js.map +1 -0
  178. package/dist/server/modules/tasks/task-registry.d.ts +7 -0
  179. package/dist/server/modules/tasks/task-registry.js +21 -0
  180. package/dist/server/modules/tasks/task-registry.js.map +1 -0
  181. package/dist/server/modules/tasks/task-scheduler.d.ts +31 -0
  182. package/dist/server/modules/tasks/task-scheduler.js +473 -0
  183. package/dist/server/modules/tasks/task-scheduler.js.map +1 -0
  184. package/dist/server/modules/tasks/task-types.d.ts +106 -0
  185. package/dist/server/modules/tasks/task-types.js +23 -0
  186. package/dist/server/modules/tasks/task-types.js.map +1 -0
  187. package/dist/server/modules/terminal/command-template-service.d.ts +4 -0
  188. package/dist/server/modules/terminal/command-template-service.js +5 -3
  189. package/dist/server/modules/terminal/command-template-service.js.map +1 -1
  190. package/dist/server/modules/terminal/runtime/terminal-log-spooler.d.ts +7 -3
  191. package/dist/server/modules/terminal/runtime/terminal-log-spooler.js +95 -15
  192. package/dist/server/modules/terminal/runtime/terminal-log-spooler.js.map +1 -1
  193. package/dist/server/modules/terminal/runtime/terminal-log-writer-client.d.ts +21 -0
  194. package/dist/server/modules/terminal/runtime/terminal-log-writer-client.js +144 -0
  195. package/dist/server/modules/terminal/runtime/terminal-log-writer-client.js.map +1 -0
  196. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.d.ts +1 -0
  197. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js +187 -0
  198. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js.map +1 -0
  199. package/dist/server/modules/terminal/terminal-service.d.ts +12 -0
  200. package/dist/server/modules/terminal/terminal-service.js +34 -17
  201. package/dist/server/modules/terminal/terminal-service.js.map +1 -1
  202. package/dist/server/modules/workbench/workbench-service.d.ts +23 -2
  203. package/dist/server/modules/workbench/workbench-service.js +126 -15
  204. package/dist/server/modules/workbench/workbench-service.js.map +1 -1
  205. package/dist/server/modules/workbench/workspace-panel-snapshot-service.d.ts +5 -1
  206. package/dist/server/modules/workbench/workspace-panel-snapshot-service.js +88 -19
  207. package/dist/server/modules/workbench/workspace-panel-snapshot-service.js.map +1 -1
  208. package/dist/server/modules/workspace/workspace-code-composition.d.ts +2 -0
  209. package/dist/server/modules/workspace/workspace-code-composition.js +154 -0
  210. package/dist/server/modules/workspace/workspace-code-composition.js.map +1 -0
  211. package/dist/server/modules/workspace/workspace-controller.d.ts +14 -0
  212. package/dist/server/modules/workspace/workspace-controller.js +19 -0
  213. package/dist/server/modules/workspace/workspace-controller.js.map +1 -1
  214. package/dist/server/modules/workspace/workspace-service.d.ts +21 -14
  215. package/dist/server/modules/workspace/workspace-service.js +183 -234
  216. package/dist/server/modules/workspace/workspace-service.js.map +1 -1
  217. package/dist/server/modules/worktree/worktree-cleanup-service.d.ts +35 -0
  218. package/dist/server/modules/worktree/worktree-cleanup-service.js +210 -0
  219. package/dist/server/modules/worktree/worktree-cleanup-service.js.map +1 -0
  220. package/dist/server/modules/worktree/worktree-controller.d.ts +44 -0
  221. package/dist/server/modules/worktree/worktree-controller.js +40 -0
  222. package/dist/server/modules/worktree/worktree-controller.js.map +1 -0
  223. package/dist/server/modules/worktree/worktree-manager.d.ts +34 -0
  224. package/dist/server/modules/worktree/worktree-manager.js +292 -0
  225. package/dist/server/modules/worktree/worktree-manager.js.map +1 -0
  226. package/dist/server/modules/worktree/worktree-merge-service.d.ts +52 -0
  227. package/dist/server/modules/worktree/worktree-merge-service.js +293 -0
  228. package/dist/server/modules/worktree/worktree-merge-service.js.map +1 -0
  229. package/dist/server/modules/worktree/worktree-sync-service.d.ts +23 -0
  230. package/dist/server/modules/worktree/worktree-sync-service.js +166 -0
  231. package/dist/server/modules/worktree/worktree-sync-service.js.map +1 -0
  232. package/dist/server/routes/assistant.d.ts +3 -0
  233. package/dist/server/routes/assistant.js +15 -0
  234. package/dist/server/routes/assistant.js.map +1 -0
  235. package/dist/server/routes/debug-targets.d.ts +3 -0
  236. package/dist/server/routes/debug-targets.js +15 -0
  237. package/dist/server/routes/debug-targets.js.map +1 -0
  238. package/dist/server/routes/git.js +2 -0
  239. package/dist/server/routes/git.js.map +1 -1
  240. package/dist/server/routes/observability.d.ts +3 -0
  241. package/dist/server/routes/observability.js +7 -0
  242. package/dist/server/routes/observability.js.map +1 -0
  243. package/dist/server/routes/skills.d.ts +3 -0
  244. package/dist/server/routes/skills.js +7 -0
  245. package/dist/server/routes/skills.js.map +1 -0
  246. package/dist/server/routes/system.d.ts +3 -0
  247. package/dist/server/routes/system.js +9 -0
  248. package/dist/server/routes/system.js.map +1 -0
  249. package/dist/server/routes/workspaces.js +2 -0
  250. package/dist/server/routes/workspaces.js.map +1 -1
  251. package/dist/server/routes/worktrees.d.ts +3 -0
  252. package/dist/server/routes/worktrees.js +8 -0
  253. package/dist/server/routes/worktrees.js.map +1 -0
  254. package/dist/server/server/create-server.d.ts +46 -0
  255. package/dist/server/server/create-server.js +141 -12
  256. package/dist/server/server/create-server.js.map +1 -1
  257. package/dist/server/shared/utils/command-availability.d.ts +1 -0
  258. package/dist/server/shared/utils/command-availability.js +26 -3
  259. package/dist/server/shared/utils/command-availability.js.map +1 -1
  260. package/dist/server/shared/utils/secret-box.d.ts +2 -0
  261. package/dist/server/shared/utils/secret-box.js +29 -0
  262. package/dist/server/shared/utils/secret-box.js.map +1 -0
  263. package/dist/server/shared/utils/terminal-debug-log.js +5 -3
  264. package/dist/server/shared/utils/terminal-debug-log.js.map +1 -1
  265. package/dist/server/storage/repositories/ai-fallback-edit-repository.d.ts +11 -0
  266. package/dist/server/storage/repositories/ai-fallback-edit-repository.js +118 -0
  267. package/dist/server/storage/repositories/ai-fallback-edit-repository.js.map +1 -0
  268. package/dist/server/storage/repositories/debug-runtime-session-repository.d.ts +11 -0
  269. package/dist/server/storage/repositories/debug-runtime-session-repository.js +100 -0
  270. package/dist/server/storage/repositories/debug-runtime-session-repository.js.map +1 -0
  271. package/dist/server/storage/repositories/debug-service-repository.d.ts +9 -0
  272. package/dist/server/storage/repositories/debug-service-repository.js +99 -0
  273. package/dist/server/storage/repositories/debug-service-repository.js.map +1 -0
  274. package/dist/server/storage/repositories/debug-target-repository.d.ts +11 -0
  275. package/dist/server/storage/repositories/debug-target-repository.js +100 -0
  276. package/dist/server/storage/repositories/debug-target-repository.js.map +1 -0
  277. package/dist/server/storage/repositories/framework-analysis-result-repository.d.ts +9 -0
  278. package/dist/server/storage/repositories/framework-analysis-result-repository.js +98 -0
  279. package/dist/server/storage/repositories/framework-analysis-result-repository.js.map +1 -0
  280. package/dist/server/storage/repositories/git-remote-credential-repository.d.ts +9 -0
  281. package/dist/server/storage/repositories/git-remote-credential-repository.js +51 -0
  282. package/dist/server/storage/repositories/git-remote-credential-repository.js.map +1 -0
  283. package/dist/server/storage/repositories/instance-tailscale-repository.d.ts +10 -0
  284. package/dist/server/storage/repositories/instance-tailscale-repository.js +112 -0
  285. package/dist/server/storage/repositories/instance-tailscale-repository.js.map +1 -0
  286. package/dist/server/storage/repositories/managed-skill-repository.d.ts +11 -0
  287. package/dist/server/storage/repositories/managed-skill-repository.js +102 -0
  288. package/dist/server/storage/repositories/managed-skill-repository.js.map +1 -0
  289. package/dist/server/storage/repositories/port-lease-repository.d.ts +12 -0
  290. package/dist/server/storage/repositories/port-lease-repository.js +124 -0
  291. package/dist/server/storage/repositories/port-lease-repository.js.map +1 -0
  292. package/dist/server/storage/repositories/runtime-binding-repository.d.ts +10 -0
  293. package/dist/server/storage/repositories/runtime-binding-repository.js +89 -0
  294. package/dist/server/storage/repositories/runtime-binding-repository.js.map +1 -0
  295. package/dist/server/storage/repositories/skill-target-binding-repository.d.ts +10 -0
  296. package/dist/server/storage/repositories/skill-target-binding-repository.js +77 -0
  297. package/dist/server/storage/repositories/skill-target-binding-repository.js.map +1 -0
  298. package/dist/server/storage/repositories/terminal-command-template-repository.js +77 -4
  299. package/dist/server/storage/repositories/terminal-command-template-repository.js.map +1 -1
  300. package/dist/server/storage/repositories/terminal-instance-repository.js +89 -7
  301. package/dist/server/storage/repositories/terminal-instance-repository.js.map +1 -1
  302. package/dist/server/storage/repositories/workspace-navigation-state-repository.d.ts +9 -0
  303. package/dist/server/storage/repositories/workspace-navigation-state-repository.js +49 -0
  304. package/dist/server/storage/repositories/workspace-navigation-state-repository.js.map +1 -0
  305. package/dist/server/storage/repositories/workspace-repository.d.ts +7 -1
  306. package/dist/server/storage/repositories/workspace-repository.js +32 -8
  307. package/dist/server/storage/repositories/workspace-repository.js.map +1 -1
  308. package/dist/server/storage/repositories/workspace-worktree-repository.d.ts +13 -0
  309. package/dist/server/storage/repositories/workspace-worktree-repository.js +158 -0
  310. package/dist/server/storage/repositories/workspace-worktree-repository.js.map +1 -0
  311. package/dist/server/storage/sqlite/client.js +311 -0
  312. package/dist/server/storage/sqlite/client.js.map +1 -1
  313. package/dist/server/storage/sqlite/schema.sql +303 -0
  314. package/dist/server/types/domain.d.ts +303 -0
  315. package/dist/server/ws/workbench-ws-hub.js +33 -9
  316. package/dist/server/ws/workbench-ws-hub.js.map +1 -1
  317. package/dist/server/ws/ws-server.js +4 -4
  318. package/dist/server/ws/ws-server.js.map +1 -1
  319. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +18 -6
  320. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js.map +1 -1
  321. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +14 -2
  322. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
  323. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +25 -1
  324. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -1
  325. package/node_modules/@codingns/session-sync-core/dist/types.d.ts +6 -0
  326. package/package.json +1 -1
  327. package/dist/public/assets/index-1VIm8lVL.css +0 -1
  328. package/dist/public/assets/index-Dti93O2S.js +0 -109
@@ -0,0 +1,29 @@
1
+ import crypto from "node:crypto";
2
+ const SECRET_BOX_ALGORITHM = "aes-256-gcm";
3
+ const SECRET_BOX_IV_LENGTH = 12;
4
+ export function encryptSecret(secret, plaintext) {
5
+ const key = deriveSecretKey(secret);
6
+ const iv = crypto.randomBytes(SECRET_BOX_IV_LENGTH);
7
+ const cipher = crypto.createCipheriv(SECRET_BOX_ALGORITHM, key, iv);
8
+ const encrypted = Buffer.concat([cipher.update(plaintext, "utf8"), cipher.final()]);
9
+ const authTag = cipher.getAuthTag();
10
+ return `${iv.toString("base64url")}.${authTag.toString("base64url")}.${encrypted.toString("base64url")}`;
11
+ }
12
+ export function decryptSecret(secret, payload) {
13
+ const [ivText, authTagText, encryptedText] = payload.split(".");
14
+ if (!ivText || !authTagText || !encryptedText) {
15
+ throw new Error("SECRET_BOX_PAYLOAD_INVALID");
16
+ }
17
+ const key = deriveSecretKey(secret);
18
+ const decipher = crypto.createDecipheriv(SECRET_BOX_ALGORITHM, key, Buffer.from(ivText, "base64url"));
19
+ decipher.setAuthTag(Buffer.from(authTagText, "base64url"));
20
+ const decrypted = Buffer.concat([
21
+ decipher.update(Buffer.from(encryptedText, "base64url")),
22
+ decipher.final()
23
+ ]);
24
+ return decrypted.toString("utf8");
25
+ }
26
+ function deriveSecretKey(secret) {
27
+ return crypto.createHash("sha256").update(secret).digest();
28
+ }
29
+ //# sourceMappingURL=secret-box.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"secret-box.js","sourceRoot":"","sources":["../../../../src/shared/utils/secret-box.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,aAAa,CAAC;AAEjC,MAAM,oBAAoB,GAAG,aAAa,CAAC;AAC3C,MAAM,oBAAoB,GAAG,EAAE,CAAC;AAEhC,MAAM,UAAU,aAAa,CAAC,MAAc,EAAE,SAAiB;IAC7D,MAAM,GAAG,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;IACpC,MAAM,EAAE,GAAG,MAAM,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAC;IACpD,MAAM,MAAM,GAAG,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IACpE,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACpF,MAAM,OAAO,GAAG,MAAM,CAAC,UAAU,EAAE,CAAC;IAEpC,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;AAC3G,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,MAAc,EAAE,OAAe;IAC3D,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE,aAAa,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAEhE,IAAI,CAAC,MAAM,IAAI,CAAC,WAAW,IAAI,CAAC,aAAa,EAAE,CAAC;QAC9C,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;IAChD,CAAC;IAED,MAAM,GAAG,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;IACpC,MAAM,QAAQ,GAAG,MAAM,CAAC,gBAAgB,CACtC,oBAAoB,EACpB,GAAG,EACH,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,WAAW,CAAC,CACjC,CAAC;IAEF,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC;IAE3D,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC;QAC9B,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;QACxD,QAAQ,CAAC,KAAK,EAAE;KACjB,CAAC,CAAC;IAEH,OAAO,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AACpC,CAAC;AAED,SAAS,eAAe,CAAC,MAAc;IACrC,OAAO,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;AAC7D,CAAC"}
@@ -1,7 +1,5 @@
1
1
  import { performance } from "node:perf_hooks";
2
- // 调试日志已停用,保留工具函数便于后续需要时快速恢复。
3
- // const TERMINAL_DEBUG_ENABLED = process.env.CODINGNS_TERMINAL_DEBUG === "1";
4
- const TERMINAL_DEBUG_ENABLED = false;
2
+ const TERMINAL_DEBUG_ENABLED = readTerminalDebugFlag();
5
3
  const EVENT_LOOP_LAG_MONITOR_INTERVAL_MS = 100;
6
4
  const EVENT_LOOP_LAG_REPORT_THRESHOLD_MS = 50;
7
5
  export function isTerminalDebugEnabled() {
@@ -39,6 +37,10 @@ export function startTerminalDebugEventLoopLagMonitor() {
39
37
  clearInterval(timer);
40
38
  };
41
39
  }
40
+ function readTerminalDebugFlag() {
41
+ const rawValue = process.env.CODINGNS_TERMINAL_DEBUG?.trim().toLowerCase();
42
+ return rawValue === "1" || rawValue === "true" || rawValue === "yes" || rawValue === "on";
43
+ }
42
44
  function formatTerminalDebugDetail(detail) {
43
45
  const entries = Object.entries(detail).filter(([, value]) => value !== undefined);
44
46
  if (entries.length === 0) {
@@ -1 +1 @@
1
- {"version":3,"file":"terminal-debug-log.js","sourceRoot":"","sources":["../../../../src/shared/utils/terminal-debug-log.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"terminal-debug-log.js","sourceRoot":"","sources":["../../../../src/shared/utils/terminal-debug-log.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,MAAM,sBAAsB,GAAG,qBAAqB,EAAE,CAAC;AACvD,MAAM,kCAAkC,GAAG,GAAG,CAAC;AAC/C,MAAM,kCAAkC,GAAG,EAAE,CAAC;AAE9C,MAAM,UAAU,sBAAsB;IACpC,OAAO,sBAAsB,CAAC;AAChC,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,OAAO,WAAW,CAAC,GAAG,EAAE,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAa,EAAE,SAAkC,EAAE;IAClF,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC5B,OAAO;IACT,CAAC;IAED,MAAM,MAAM,GAAG,yBAAyB,CAAC,MAAM,CAAC,CAAC;IACjD,MAAM,OAAO,GAAG,0BAA0B,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IAC/E,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AACxB,CAAC;AAED,MAAM,UAAU,qCAAqC;IACnD,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC5B,OAAO,GAAG,EAAE,GAAE,CAAC,CAAC;IAClB,CAAC;IAED,IAAI,UAAU,GAAG,WAAW,CAAC,GAAG,EAAE,GAAG,kCAAkC,CAAC;IACxE,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,MAAM,GAAG,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC;QAC9B,MAAM,KAAK,GAAG,GAAG,GAAG,UAAU,CAAC;QAE/B,IAAI,KAAK,IAAI,kCAAkC,EAAE,CAAC;YAChD,gBAAgB,CAAC,gBAAgB,EAAE;gBACjC,KAAK;gBACL,UAAU,EAAE,kCAAkC;aAC/C,CAAC,CAAC;QACL,CAAC;QAED,UAAU,GAAG,GAAG,GAAG,kCAAkC,CAAC;IACxD,CAAC,EAAE,kCAAkC,CAAC,CAAC;IACvC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC;IAEhB,OAAO,GAAG,EAAE;QACV,aAAa,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC,CAAC;AACJ,CAAC;AAED,SAAS,qBAAqB;IAC5B,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,uBAAuB,EAAE,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC3E,OAAO,QAAQ,KAAK,GAAG,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,KAAK,IAAI,QAAQ,KAAK,IAAI,CAAC;AAC5F,CAAC;AAED,SAAS,yBAAyB,CAAC,MAA+B;IAChE,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC;IAElF,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO,OAAO;SACX,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,wBAAwB,CAAC,KAAK,CAAC,EAAE,CAAC;SAClE,IAAI,CAAC,GAAG,CAAC,CAAC;AACf,CAAC;AAED,SAAS,wBAAwB,CAAC,KAAc;IAC9C,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QACnB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACnE,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE,CAAC;QAC/B,OAAO,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;IAClC,CAAC;IAED,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;AACH,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { AiFallbackEditRecord } from "../../types/domain.js";
3
+ export declare class AiFallbackEditRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: AiFallbackEditRecord): AiFallbackEditRecord;
7
+ listByRuntimeId(runtimeId: string): AiFallbackEditRecord[];
8
+ listBlockingByWorkspaceId(workspaceId: string): AiFallbackEditRecord[];
9
+ update(record: AiFallbackEditRecord): AiFallbackEditRecord | null;
10
+ findById(id: string): AiFallbackEditRecord | null;
11
+ }
@@ -0,0 +1,118 @@
1
+ export class AiFallbackEditRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO ai_fallback_edits (
9
+ id,
10
+ runtime_id,
11
+ service_id,
12
+ reason,
13
+ allowed_files_json,
14
+ target_port,
15
+ patch_ref,
16
+ rollback_ref,
17
+ status,
18
+ created_at
19
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
20
+ .run(record.id, record.runtimeId, record.serviceId, record.reason, JSON.stringify(record.allowedFiles), record.targetPort, record.patchRef ?? null, record.rollbackRef ?? null, record.status, record.createdAt);
21
+ return record;
22
+ }
23
+ listByRuntimeId(runtimeId) {
24
+ return this.db
25
+ .prepare(`SELECT
26
+ id,
27
+ runtime_id,
28
+ service_id,
29
+ reason,
30
+ allowed_files_json,
31
+ target_port,
32
+ patch_ref,
33
+ rollback_ref,
34
+ status,
35
+ created_at
36
+ FROM ai_fallback_edits
37
+ WHERE runtime_id = ?
38
+ ORDER BY created_at DESC`)
39
+ .all(runtimeId)
40
+ .map((row) => mapAiFallbackEditRow(row));
41
+ }
42
+ listBlockingByWorkspaceId(workspaceId) {
43
+ return this.db
44
+ .prepare(`SELECT
45
+ edits.id,
46
+ edits.runtime_id,
47
+ edits.service_id,
48
+ edits.reason,
49
+ edits.allowed_files_json,
50
+ edits.target_port,
51
+ edits.patch_ref,
52
+ edits.rollback_ref,
53
+ edits.status,
54
+ edits.created_at
55
+ FROM ai_fallback_edits AS edits
56
+ INNER JOIN debug_runtime_sessions AS runtimes
57
+ ON runtimes.id = edits.runtime_id
58
+ INNER JOIN debug_targets AS targets
59
+ ON targets.id = runtimes.target_id
60
+ WHERE targets.workspace_id = ?
61
+ AND edits.status IN ('PENDING', 'APPLIED')
62
+ ORDER BY edits.created_at DESC`)
63
+ .all(workspaceId)
64
+ .map((row) => mapAiFallbackEditRow(row));
65
+ }
66
+ update(record) {
67
+ this.db
68
+ .prepare(`UPDATE ai_fallback_edits
69
+ SET patch_ref = ?,
70
+ rollback_ref = ?,
71
+ status = ?
72
+ WHERE id = ?`)
73
+ .run(record.patchRef ?? null, record.rollbackRef ?? null, record.status, record.id);
74
+ return this.findById(record.id);
75
+ }
76
+ findById(id) {
77
+ const row = this.db
78
+ .prepare(`SELECT
79
+ id,
80
+ runtime_id,
81
+ service_id,
82
+ reason,
83
+ allowed_files_json,
84
+ target_port,
85
+ patch_ref,
86
+ rollback_ref,
87
+ status,
88
+ created_at
89
+ FROM ai_fallback_edits
90
+ WHERE id = ?`)
91
+ .get(id);
92
+ return row ? mapAiFallbackEditRow(row) : null;
93
+ }
94
+ }
95
+ function mapAiFallbackEditRow(row) {
96
+ return {
97
+ id: row.id,
98
+ runtimeId: row.runtime_id,
99
+ serviceId: row.service_id,
100
+ reason: row.reason,
101
+ allowedFiles: parseJsonStringArray(row.allowed_files_json),
102
+ targetPort: row.target_port,
103
+ patchRef: row.patch_ref,
104
+ rollbackRef: row.rollback_ref,
105
+ status: row.status,
106
+ createdAt: row.created_at
107
+ };
108
+ }
109
+ function parseJsonStringArray(raw) {
110
+ try {
111
+ const parsed = JSON.parse(raw);
112
+ return Array.isArray(parsed) ? parsed.filter((item) => typeof item === "string") : [];
113
+ }
114
+ catch {
115
+ return [];
116
+ }
117
+ }
118
+ //# sourceMappingURL=ai-fallback-edit-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ai-fallback-edit-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/ai-fallback-edit-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { DebugRuntimeSession, DebugRuntimeSessionStatus } from "../../types/domain.js";
3
+ export declare class DebugRuntimeSessionRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: DebugRuntimeSession): DebugRuntimeSession;
7
+ findById(id: string): DebugRuntimeSession | null;
8
+ listByTargetId(targetId: string): DebugRuntimeSession[];
9
+ listByStatuses(statuses: DebugRuntimeSessionStatus[]): DebugRuntimeSession[];
10
+ update(record: DebugRuntimeSession): DebugRuntimeSession | null;
11
+ }
@@ -0,0 +1,100 @@
1
+ export class DebugRuntimeSessionRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO debug_runtime_sessions (
9
+ id,
10
+ target_id,
11
+ status,
12
+ failure_stage,
13
+ started_at,
14
+ stopped_at,
15
+ created_at,
16
+ updated_at
17
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?)`)
18
+ .run(record.id, record.targetId, record.status, record.failureStage ?? null, record.startedAt ?? null, record.stoppedAt ?? null, record.createdAt, record.updatedAt);
19
+ return record;
20
+ }
21
+ findById(id) {
22
+ const row = this.db
23
+ .prepare(`SELECT
24
+ id,
25
+ target_id,
26
+ status,
27
+ failure_stage,
28
+ started_at,
29
+ stopped_at,
30
+ created_at,
31
+ updated_at
32
+ FROM debug_runtime_sessions
33
+ WHERE id = ?`)
34
+ .get(id);
35
+ return row ? mapDebugRuntimeSessionRow(row) : null;
36
+ }
37
+ listByTargetId(targetId) {
38
+ return this.db
39
+ .prepare(`SELECT
40
+ id,
41
+ target_id,
42
+ status,
43
+ failure_stage,
44
+ started_at,
45
+ stopped_at,
46
+ created_at,
47
+ updated_at
48
+ FROM debug_runtime_sessions
49
+ WHERE target_id = ?
50
+ ORDER BY updated_at DESC, created_at DESC`)
51
+ .all(targetId)
52
+ .map((row) => mapDebugRuntimeSessionRow(row));
53
+ }
54
+ listByStatuses(statuses) {
55
+ if (statuses.length === 0) {
56
+ return [];
57
+ }
58
+ const placeholders = statuses.map(() => "?").join(", ");
59
+ return this.db
60
+ .prepare(`SELECT
61
+ id,
62
+ target_id,
63
+ status,
64
+ failure_stage,
65
+ started_at,
66
+ stopped_at,
67
+ created_at,
68
+ updated_at
69
+ FROM debug_runtime_sessions
70
+ WHERE status IN (${placeholders})
71
+ ORDER BY updated_at DESC, created_at DESC`)
72
+ .all(...statuses)
73
+ .map((row) => mapDebugRuntimeSessionRow(row));
74
+ }
75
+ update(record) {
76
+ this.db
77
+ .prepare(`UPDATE debug_runtime_sessions
78
+ SET status = ?,
79
+ failure_stage = ?,
80
+ started_at = ?,
81
+ stopped_at = ?,
82
+ updated_at = ?
83
+ WHERE id = ?`)
84
+ .run(record.status, record.failureStage ?? null, record.startedAt ?? null, record.stoppedAt ?? null, record.updatedAt, record.id);
85
+ return this.findById(record.id);
86
+ }
87
+ }
88
+ function mapDebugRuntimeSessionRow(row) {
89
+ return {
90
+ id: row.id,
91
+ targetId: row.target_id,
92
+ status: row.status,
93
+ failureStage: row.failure_stage,
94
+ startedAt: row.started_at,
95
+ stoppedAt: row.stopped_at,
96
+ createdAt: row.created_at,
97
+ updatedAt: row.updated_at
98
+ };
99
+ }
100
+ //# sourceMappingURL=debug-runtime-session-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug-runtime-session-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/debug-runtime-session-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,6BAA6B;IACX;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA2B;QAChC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;0CASkC,CACnC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,YAAY,IAAI,IAAI,EAC3B,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;qBAUa,CACd;aACA,GAAG,CAAC,EAAE,CAAuC,CAAC;QAEjD,OAAO,GAAG,CAAC,CAAC,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACrD,CAAC;IAED,cAAc,CAAC,QAAgB;QAC7B,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;kDAW0C,CAC3C;aACA,GAAG,CAAC,QAAQ,CAAC;aACb,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,yBAAyB,CAAC,GAA6B,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED,cAAc,CAAC,QAAqC;QAClD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,YAAY,GAAG,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExD,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;2BAUmB,YAAY;kDACW,CAC3C;aACA,GAAG,CAAC,GAAG,QAAQ,CAAC;aAChB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,yBAAyB,CAAC,GAA6B,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED,MAAM,CAAC,MAA2B;QAChC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;sBAMc,CACf;aACA,GAAG,CACF,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,YAAY,IAAI,IAAI,EAC3B,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,EAAE,CACV,CAAC;QAEJ,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC;CACF;AAaD,SAAS,yBAAyB,CAAC,GAA2B;IAC5D,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,YAAY,EAAE,GAAG,CAAC,aAAa;QAC/B,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { DebugServiceSpec } from "../../types/domain.js";
3
+ export declare class DebugServiceRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: DebugServiceSpec): DebugServiceSpec;
7
+ listByTargetId(targetId: string): DebugServiceSpec[];
8
+ deleteByTargetId(targetId: string): void;
9
+ }
@@ -0,0 +1,99 @@
1
+ export class DebugServiceRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO debug_services (
9
+ id,
10
+ target_id,
11
+ role,
12
+ name,
13
+ cwd,
14
+ command,
15
+ args_json,
16
+ env_json,
17
+ default_port_hint,
18
+ protocol,
19
+ health_path,
20
+ adapter_kind,
21
+ framework_analysis_id,
22
+ created_at,
23
+ updated_at
24
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
25
+ .run(record.id, record.targetId, record.role, record.name, record.cwd, record.command, JSON.stringify(record.args), JSON.stringify(record.env), record.defaultPortHint ?? null, record.protocol ?? null, record.healthPath ?? null, record.adapterKind ?? null, record.frameworkAnalysisId ?? null, record.createdAt, record.updatedAt);
26
+ return record;
27
+ }
28
+ listByTargetId(targetId) {
29
+ return this.db
30
+ .prepare(`SELECT
31
+ id,
32
+ target_id,
33
+ role,
34
+ name,
35
+ cwd,
36
+ command,
37
+ args_json,
38
+ env_json,
39
+ default_port_hint,
40
+ protocol,
41
+ health_path,
42
+ adapter_kind,
43
+ framework_analysis_id,
44
+ created_at,
45
+ updated_at
46
+ FROM debug_services
47
+ WHERE target_id = ?
48
+ ORDER BY updated_at DESC, created_at DESC`)
49
+ .all(targetId)
50
+ .map((row) => mapDebugServiceRow(row));
51
+ }
52
+ deleteByTargetId(targetId) {
53
+ this.db
54
+ .prepare(`DELETE FROM debug_services
55
+ WHERE target_id = ?`)
56
+ .run(targetId);
57
+ }
58
+ }
59
+ function mapDebugServiceRow(row) {
60
+ return {
61
+ id: row.id,
62
+ targetId: row.target_id,
63
+ role: row.role,
64
+ name: row.name,
65
+ cwd: row.cwd,
66
+ command: row.command,
67
+ args: parseJsonArray(row.args_json),
68
+ env: parseJsonObject(row.env_json),
69
+ defaultPortHint: row.default_port_hint,
70
+ protocol: row.protocol,
71
+ healthPath: row.health_path,
72
+ adapterKind: row.adapter_kind,
73
+ frameworkAnalysisId: row.framework_analysis_id,
74
+ createdAt: row.created_at,
75
+ updatedAt: row.updated_at
76
+ };
77
+ }
78
+ function parseJsonArray(raw) {
79
+ try {
80
+ const parsed = JSON.parse(raw);
81
+ return Array.isArray(parsed) ? parsed.filter((item) => typeof item === "string") : [];
82
+ }
83
+ catch {
84
+ return [];
85
+ }
86
+ }
87
+ function parseJsonObject(raw) {
88
+ try {
89
+ const parsed = JSON.parse(raw);
90
+ if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
91
+ return {};
92
+ }
93
+ return Object.fromEntries(Object.entries(parsed).filter((entry) => typeof entry[1] === "string"));
94
+ }
95
+ catch {
96
+ return {};
97
+ }
98
+ }
99
+ //# sourceMappingURL=debug-service-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug-service-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/debug-service-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { DebugTargetProfile } from "../../types/domain.js";
3
+ export declare class DebugTargetRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: DebugTargetProfile): DebugTargetProfile;
7
+ update(record: DebugTargetProfile): DebugTargetProfile | null;
8
+ findById(id: string): DebugTargetProfile | null;
9
+ findByWorkspaceAndRootPath(workspaceId: string, rootPath: string): DebugTargetProfile | null;
10
+ listByWorkspaceId(workspaceId: string): DebugTargetProfile[];
11
+ }
@@ -0,0 +1,100 @@
1
+ export class DebugTargetRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO debug_targets (
9
+ id,
10
+ workspace_id,
11
+ root_path,
12
+ display_name,
13
+ stack_hint,
14
+ source_type,
15
+ root_workspace_id,
16
+ created_at,
17
+ updated_at
18
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`)
19
+ .run(record.id, record.workspaceId, record.rootPath, record.displayName, record.stackHint ?? null, record.sourceType, record.rootWorkspaceId ?? null, record.createdAt, record.updatedAt);
20
+ return record;
21
+ }
22
+ update(record) {
23
+ this.db
24
+ .prepare(`UPDATE debug_targets
25
+ SET display_name = ?,
26
+ stack_hint = ?,
27
+ source_type = ?,
28
+ root_workspace_id = ?,
29
+ updated_at = ?
30
+ WHERE id = ?`)
31
+ .run(record.displayName, record.stackHint ?? null, record.sourceType, record.rootWorkspaceId ?? null, record.updatedAt, record.id);
32
+ return this.findById(record.id);
33
+ }
34
+ findById(id) {
35
+ const row = this.db
36
+ .prepare(`SELECT
37
+ id,
38
+ workspace_id,
39
+ root_path,
40
+ display_name,
41
+ stack_hint,
42
+ source_type,
43
+ root_workspace_id,
44
+ created_at,
45
+ updated_at
46
+ FROM debug_targets
47
+ WHERE id = ?`)
48
+ .get(id);
49
+ return row ? mapDebugTargetRow(row) : null;
50
+ }
51
+ findByWorkspaceAndRootPath(workspaceId, rootPath) {
52
+ const row = this.db
53
+ .prepare(`SELECT
54
+ id,
55
+ workspace_id,
56
+ root_path,
57
+ display_name,
58
+ stack_hint,
59
+ source_type,
60
+ root_workspace_id,
61
+ created_at,
62
+ updated_at
63
+ FROM debug_targets
64
+ WHERE workspace_id = ? AND root_path = ?`)
65
+ .get(workspaceId, rootPath);
66
+ return row ? mapDebugTargetRow(row) : null;
67
+ }
68
+ listByWorkspaceId(workspaceId) {
69
+ return this.db
70
+ .prepare(`SELECT
71
+ id,
72
+ workspace_id,
73
+ root_path,
74
+ display_name,
75
+ stack_hint,
76
+ source_type,
77
+ root_workspace_id,
78
+ created_at,
79
+ updated_at
80
+ FROM debug_targets
81
+ WHERE workspace_id = ?
82
+ ORDER BY updated_at DESC, created_at DESC`)
83
+ .all(workspaceId)
84
+ .map((row) => mapDebugTargetRow(row));
85
+ }
86
+ }
87
+ function mapDebugTargetRow(row) {
88
+ return {
89
+ id: row.id,
90
+ workspaceId: row.workspace_id,
91
+ rootPath: row.root_path,
92
+ displayName: row.display_name,
93
+ stackHint: row.stack_hint,
94
+ sourceType: row.source_type,
95
+ rootWorkspaceId: row.root_workspace_id,
96
+ createdAt: row.created_at,
97
+ updatedAt: row.updated_at
98
+ };
99
+ }
100
+ //# sourceMappingURL=debug-target-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug-target-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/debug-target-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,qBAAqB;IACH;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA0B;QAC/B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;6CAUqC,CACtC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,eAAe,IAAI,IAAI,EAC9B,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,MAAM,CAAC,MAA0B;QAC/B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;sBAMc,CACf;aACA,GAAG,CACF,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,eAAe,IAAI,IAAI,EAC9B,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,EAAE,CACV,CAAC;QAEJ,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;qBAWa,CACd;aACA,GAAG,CAAC,EAAE,CAA+B,CAAC;QAEzC,OAAO,GAAG,CAAC,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC7C,CAAC;IAED,0BAA0B,CAAC,WAAmB,EAAE,QAAgB;QAC9D,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;iDAWyC,CAC1C;aACA,GAAG,CAAC,WAAW,EAAE,QAAQ,CAA+B,CAAC;QAE5D,OAAO,GAAG,CAAC,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC7C,CAAC;IAED,iBAAiB,CAAC,WAAmB;QACnC,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;kDAY0C,CAC3C;aACA,GAAG,CAAC,WAAW,CAAC;aAChB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,iBAAiB,CAAC,GAAqB,CAAC,CAAC,CAAC;IAC5D,CAAC;CACF;AAcD,SAAS,iBAAiB,CAAC,GAAmB;IAC5C,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,eAAe,EAAE,GAAG,CAAC,iBAAiB;QACtC,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { FrameworkAnalysisResult } from "../../types/domain.js";
3
+ export declare class FrameworkAnalysisResultRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: FrameworkAnalysisResult): FrameworkAnalysisResult;
7
+ listByTargetId(targetId: string): FrameworkAnalysisResult[];
8
+ deleteByTargetId(targetId: string): void;
9
+ }
@@ -0,0 +1,98 @@
1
+ export class FrameworkAnalysisResultRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO framework_analysis_results (
9
+ id,
10
+ target_id,
11
+ service_id,
12
+ primary_framework,
13
+ confidence,
14
+ compatibility_level,
15
+ recommended_injection_mode,
16
+ requires_service_discovery_handling,
17
+ requires_hmr_handling,
18
+ requires_callback_handling,
19
+ ai_fallback_policy,
20
+ reasons_json,
21
+ detected_files_json,
22
+ raw_evidence_json,
23
+ created_at
24
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
25
+ .run(record.id, record.targetId, record.serviceId ?? null, record.primaryFramework ?? null, record.confidence, record.compatibilityLevel, record.recommendedInjectionMode ?? null, record.requiresServiceDiscoveryHandling ? 1 : 0, record.requiresHmrHandling ? 1 : 0, record.requiresCallbackHandling ? 1 : 0, record.aiFallbackPolicy, JSON.stringify(record.reasons), JSON.stringify(record.detectedFiles), JSON.stringify(record.rawEvidence ?? {}), record.createdAt);
26
+ return record;
27
+ }
28
+ listByTargetId(targetId) {
29
+ return this.db
30
+ .prepare(`SELECT
31
+ id,
32
+ target_id,
33
+ service_id,
34
+ primary_framework,
35
+ confidence,
36
+ compatibility_level,
37
+ recommended_injection_mode,
38
+ requires_service_discovery_handling,
39
+ requires_hmr_handling,
40
+ requires_callback_handling,
41
+ ai_fallback_policy,
42
+ reasons_json,
43
+ detected_files_json,
44
+ raw_evidence_json,
45
+ created_at
46
+ FROM framework_analysis_results
47
+ WHERE target_id = ?
48
+ ORDER BY created_at DESC`)
49
+ .all(targetId)
50
+ .map((row) => mapFrameworkAnalysisRow(row));
51
+ }
52
+ deleteByTargetId(targetId) {
53
+ this.db
54
+ .prepare(`DELETE FROM framework_analysis_results
55
+ WHERE target_id = ?`)
56
+ .run(targetId);
57
+ }
58
+ }
59
+ function mapFrameworkAnalysisRow(row) {
60
+ return {
61
+ id: row.id,
62
+ targetId: row.target_id,
63
+ serviceId: row.service_id,
64
+ primaryFramework: row.primary_framework,
65
+ confidence: row.confidence,
66
+ compatibilityLevel: row.compatibility_level,
67
+ recommendedInjectionMode: row.recommended_injection_mode,
68
+ requiresServiceDiscoveryHandling: row.requires_service_discovery_handling === 1,
69
+ requiresHmrHandling: row.requires_hmr_handling === 1,
70
+ requiresCallbackHandling: row.requires_callback_handling === 1,
71
+ aiFallbackPolicy: row.ai_fallback_policy,
72
+ reasons: parseJsonStringArray(row.reasons_json),
73
+ detectedFiles: parseJsonStringArray(row.detected_files_json),
74
+ rawEvidence: parseJsonObject(row.raw_evidence_json),
75
+ createdAt: row.created_at
76
+ };
77
+ }
78
+ function parseJsonStringArray(raw) {
79
+ try {
80
+ const parsed = JSON.parse(raw);
81
+ return Array.isArray(parsed) ? parsed.filter((item) => typeof item === "string") : [];
82
+ }
83
+ catch {
84
+ return [];
85
+ }
86
+ }
87
+ function parseJsonObject(raw) {
88
+ try {
89
+ const parsed = JSON.parse(raw);
90
+ return parsed && typeof parsed === "object" && !Array.isArray(parsed)
91
+ ? parsed
92
+ : {};
93
+ }
94
+ catch {
95
+ return {};
96
+ }
97
+ }
98
+ //# sourceMappingURL=framework-analysis-result-repository.js.map