@jingyi0605/codingns 0.1.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 (405) hide show
  1. package/README.md +24 -0
  2. package/bin/codingns.mjs +173 -0
  3. package/dist/public/assets/TerminalPage-6GBZ9nXN.css +32 -0
  4. package/dist/public/assets/TerminalPage-Dj_VDew3.js +54 -0
  5. package/dist/public/assets/index-C1GZV2wq.js +106 -0
  6. package/dist/public/assets/index-DU7f8NaZ.css +1 -0
  7. package/dist/public/index.html +13 -0
  8. package/dist/public/logo.png +0 -0
  9. package/dist/public/logo.svg +162 -0
  10. package/dist/server/config/env.d.ts +24 -0
  11. package/dist/server/config/env.js +152 -0
  12. package/dist/server/config/env.js.map +1 -0
  13. package/dist/server/config/opencode-base-url-resolver.d.ts +37 -0
  14. package/dist/server/config/opencode-base-url-resolver.js +422 -0
  15. package/dist/server/config/opencode-base-url-resolver.js.map +1 -0
  16. package/dist/server/main.d.ts +1 -0
  17. package/dist/server/main.js +3 -0
  18. package/dist/server/main.js.map +1 -0
  19. package/dist/server/middlewares/auth-guard.d.ts +4 -0
  20. package/dist/server/middlewares/auth-guard.js +35 -0
  21. package/dist/server/middlewares/auth-guard.js.map +1 -0
  22. package/dist/server/modules/auth/auth-controller.d.ts +15 -0
  23. package/dist/server/modules/auth/auth-controller.js +20 -0
  24. package/dist/server/modules/auth/auth-controller.js.map +1 -0
  25. package/dist/server/modules/auth/auth-service.d.ts +44 -0
  26. package/dist/server/modules/auth/auth-service.js +151 -0
  27. package/dist/server/modules/auth/auth-service.js.map +1 -0
  28. package/dist/server/modules/bootstrap/bootstrap-controller.d.ts +10 -0
  29. package/dist/server/modules/bootstrap/bootstrap-controller.js +13 -0
  30. package/dist/server/modules/bootstrap/bootstrap-controller.js.map +1 -0
  31. package/dist/server/modules/bootstrap/bootstrap-service.d.ts +20 -0
  32. package/dist/server/modules/bootstrap/bootstrap-service.js +71 -0
  33. package/dist/server/modules/bootstrap/bootstrap-service.js.map +1 -0
  34. package/dist/server/modules/client/client-controller.d.ts +9 -0
  35. package/dist/server/modules/client/client-controller.js +65 -0
  36. package/dist/server/modules/client/client-controller.js.map +1 -0
  37. package/dist/server/modules/client/client-service.d.ts +37 -0
  38. package/dist/server/modules/client/client-service.js +186 -0
  39. package/dist/server/modules/client/client-service.js.map +1 -0
  40. package/dist/server/modules/file/file-access-guard.d.ts +27 -0
  41. package/dist/server/modules/file/file-access-guard.js +99 -0
  42. package/dist/server/modules/file/file-access-guard.js.map +1 -0
  43. package/dist/server/modules/file/file-constants.d.ts +6 -0
  44. package/dist/server/modules/file/file-constants.js +7 -0
  45. package/dist/server/modules/file/file-constants.js.map +1 -0
  46. package/dist/server/modules/file/file-content-service.d.ts +65 -0
  47. package/dist/server/modules/file/file-content-service.js +239 -0
  48. package/dist/server/modules/file/file-content-service.js.map +1 -0
  49. package/dist/server/modules/file/file-context-controller.d.ts +29 -0
  50. package/dist/server/modules/file/file-context-controller.js +52 -0
  51. package/dist/server/modules/file/file-context-controller.js.map +1 -0
  52. package/dist/server/modules/file/file-context-service.d.ts +22 -0
  53. package/dist/server/modules/file/file-context-service.js +90 -0
  54. package/dist/server/modules/file/file-context-service.js.map +1 -0
  55. package/dist/server/modules/file/file-controller.d.ts +68 -0
  56. package/dist/server/modules/file/file-controller.js +111 -0
  57. package/dist/server/modules/file/file-controller.js.map +1 -0
  58. package/dist/server/modules/file/file-preview-service.d.ts +19 -0
  59. package/dist/server/modules/file/file-preview-service.js +60 -0
  60. package/dist/server/modules/file/file-preview-service.js.map +1 -0
  61. package/dist/server/modules/file/file-search-service.d.ts +13 -0
  62. package/dist/server/modules/file/file-search-service.js +62 -0
  63. package/dist/server/modules/file/file-search-service.js.map +1 -0
  64. package/dist/server/modules/file/file-tree-service.d.ts +7 -0
  65. package/dist/server/modules/file/file-tree-service.js +43 -0
  66. package/dist/server/modules/file/file-tree-service.js.map +1 -0
  67. package/dist/server/modules/file/file-version-checker.d.ts +10 -0
  68. package/dist/server/modules/file/file-version-checker.js +30 -0
  69. package/dist/server/modules/file/file-version-checker.js.map +1 -0
  70. package/dist/server/modules/file/path-normalizer.d.ts +2 -0
  71. package/dist/server/modules/file/path-normalizer.js +80 -0
  72. package/dist/server/modules/file/path-normalizer.js.map +1 -0
  73. package/dist/server/modules/file/recent-file-service.d.ts +10 -0
  74. package/dist/server/modules/file/recent-file-service.js +28 -0
  75. package/dist/server/modules/file/recent-file-service.js.map +1 -0
  76. package/dist/server/modules/git/commit-draft-service.d.ts +7 -0
  77. package/dist/server/modules/git/commit-draft-service.js +76 -0
  78. package/dist/server/modules/git/commit-draft-service.js.map +1 -0
  79. package/dist/server/modules/git/commit-orchestrator.d.ts +28 -0
  80. package/dist/server/modules/git/commit-orchestrator.js +47 -0
  81. package/dist/server/modules/git/commit-orchestrator.js.map +1 -0
  82. package/dist/server/modules/git/commit-rule-engine.d.ts +5 -0
  83. package/dist/server/modules/git/commit-rule-engine.js +22 -0
  84. package/dist/server/modules/git/commit-rule-engine.js.map +1 -0
  85. package/dist/server/modules/git/git-command-runner.d.ts +16 -0
  86. package/dist/server/modules/git/git-command-runner.js +102 -0
  87. package/dist/server/modules/git/git-command-runner.js.map +1 -0
  88. package/dist/server/modules/git/git-controller.d.ts +104 -0
  89. package/dist/server/modules/git/git-controller.js +140 -0
  90. package/dist/server/modules/git/git-controller.js.map +1 -0
  91. package/dist/server/modules/git/git-read-service.d.ts +15 -0
  92. package/dist/server/modules/git/git-read-service.js +393 -0
  93. package/dist/server/modules/git/git-read-service.js.map +1 -0
  94. package/dist/server/modules/git/git-rule-repository.d.ts +9 -0
  95. package/dist/server/modules/git/git-rule-repository.js +43 -0
  96. package/dist/server/modules/git/git-rule-repository.js.map +1 -0
  97. package/dist/server/modules/git/git-write-service.d.ts +28 -0
  98. package/dist/server/modules/git/git-write-service.js +330 -0
  99. package/dist/server/modules/git/git-write-service.js.map +1 -0
  100. package/dist/server/modules/git/types.d.ts +99 -0
  101. package/dist/server/modules/git/types.js +2 -0
  102. package/dist/server/modules/git/types.js.map +1 -0
  103. package/dist/server/modules/git/workspace-repo-guard.d.ts +17 -0
  104. package/dist/server/modules/git/workspace-repo-guard.js +124 -0
  105. package/dist/server/modules/git/workspace-repo-guard.js.map +1 -0
  106. package/dist/server/modules/preferences/quick-phrase-controller.d.ts +17 -0
  107. package/dist/server/modules/preferences/quick-phrase-controller.js +37 -0
  108. package/dist/server/modules/preferences/quick-phrase-controller.js.map +1 -0
  109. package/dist/server/modules/preferences/quick-phrase-service.d.ts +13 -0
  110. package/dist/server/modules/preferences/quick-phrase-service.js +67 -0
  111. package/dist/server/modules/preferences/quick-phrase-service.js.map +1 -0
  112. package/dist/server/modules/provider/claude-model-options.d.ts +5 -0
  113. package/dist/server/modules/provider/claude-model-options.js +116 -0
  114. package/dist/server/modules/provider/claude-model-options.js.map +1 -0
  115. package/dist/server/modules/provider/codex-model-options.d.ts +23 -0
  116. package/dist/server/modules/provider/codex-model-options.js +308 -0
  117. package/dist/server/modules/provider/codex-model-options.js.map +1 -0
  118. package/dist/server/modules/provider/opencode-model-options.d.ts +30 -0
  119. package/dist/server/modules/provider/opencode-model-options.js +362 -0
  120. package/dist/server/modules/provider/opencode-model-options.js.map +1 -0
  121. package/dist/server/modules/provider/provider-controller.d.ts +33 -0
  122. package/dist/server/modules/provider/provider-controller.js +50 -0
  123. package/dist/server/modules/provider/provider-controller.js.map +1 -0
  124. package/dist/server/modules/sessions/session-activity-inspector.d.ts +10 -0
  125. package/dist/server/modules/sessions/session-activity-inspector.js +271 -0
  126. package/dist/server/modules/sessions/session-activity-inspector.js.map +1 -0
  127. package/dist/server/modules/sessions/session-changed-file-service.d.ts +14 -0
  128. package/dist/server/modules/sessions/session-changed-file-service.js +175 -0
  129. package/dist/server/modules/sessions/session-changed-file-service.js.map +1 -0
  130. package/dist/server/modules/sessions/session-controller.d.ts +134 -0
  131. package/dist/server/modules/sessions/session-controller.js +253 -0
  132. package/dist/server/modules/sessions/session-controller.js.map +1 -0
  133. package/dist/server/modules/sessions/session-history-service.d.ts +128 -0
  134. package/dist/server/modules/sessions/session-history-service.js +1558 -0
  135. package/dist/server/modules/sessions/session-history-service.js.map +1 -0
  136. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +191 -0
  137. package/dist/server/modules/sessions/session-live-runtime-service.js +1303 -0
  138. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -0
  139. package/dist/server/modules/sessions/session-message-attachment-service.d.ts +42 -0
  140. package/dist/server/modules/sessions/session-message-attachment-service.js +244 -0
  141. package/dist/server/modules/sessions/session-message-attachment-service.js.map +1 -0
  142. package/dist/server/modules/sessions/session-provider-error-mapper.d.ts +2 -0
  143. package/dist/server/modules/sessions/session-provider-error-mapper.js +101 -0
  144. package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -0
  145. package/dist/server/modules/terminal/command-template-service.d.ts +48 -0
  146. package/dist/server/modules/terminal/command-template-service.js +273 -0
  147. package/dist/server/modules/terminal/command-template-service.js.map +1 -0
  148. package/dist/server/modules/terminal/runtime/adapters/embedded-pty-runtime-adapter.d.ts +22 -0
  149. package/dist/server/modules/terminal/runtime/adapters/embedded-pty-runtime-adapter.js +30 -0
  150. package/dist/server/modules/terminal/runtime/adapters/embedded-pty-runtime-adapter.js.map +1 -0
  151. package/dist/server/modules/terminal/runtime/adapters/tmux-runtime-adapter.d.ts +31 -0
  152. package/dist/server/modules/terminal/runtime/adapters/tmux-runtime-adapter.js +199 -0
  153. package/dist/server/modules/terminal/runtime/adapters/tmux-runtime-adapter.js.map +1 -0
  154. package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.d.ts +36 -0
  155. package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.js +141 -0
  156. package/dist/server/modules/terminal/runtime/pty-host-attachment-manager.js.map +1 -0
  157. package/dist/server/modules/terminal/runtime/pty-runtime-manager.d.ts +29 -0
  158. package/dist/server/modules/terminal/runtime/pty-runtime-manager.js +138 -0
  159. package/dist/server/modules/terminal/runtime/pty-runtime-manager.js.map +1 -0
  160. package/dist/server/modules/terminal/runtime/terminal-log-file-store.d.ts +14 -0
  161. package/dist/server/modules/terminal/runtime/terminal-log-file-store.js +47 -0
  162. package/dist/server/modules/terminal/runtime/terminal-log-file-store.js.map +1 -0
  163. package/dist/server/modules/terminal/runtime/terminal-log-spooler.d.ts +28 -0
  164. package/dist/server/modules/terminal/runtime/terminal-log-spooler.js +162 -0
  165. package/dist/server/modules/terminal/runtime/terminal-log-spooler.js.map +1 -0
  166. package/dist/server/modules/terminal/runtime/terminal-output-buffer.d.ts +18 -0
  167. package/dist/server/modules/terminal/runtime/terminal-output-buffer.js +109 -0
  168. package/dist/server/modules/terminal/runtime/terminal-output-buffer.js.map +1 -0
  169. package/dist/server/modules/terminal/runtime/terminal-runtime-adapter.d.ts +34 -0
  170. package/dist/server/modules/terminal/runtime/terminal-runtime-adapter.js +2 -0
  171. package/dist/server/modules/terminal/runtime/terminal-runtime-adapter.js.map +1 -0
  172. package/dist/server/modules/terminal/runtime/terminal-runtime-manager.d.ts +41 -0
  173. package/dist/server/modules/terminal/runtime/terminal-runtime-manager.js +138 -0
  174. package/dist/server/modules/terminal/runtime/terminal-runtime-manager.js.map +1 -0
  175. package/dist/server/modules/terminal/template-port-runtime.d.ts +6 -0
  176. package/dist/server/modules/terminal/template-port-runtime.js +199 -0
  177. package/dist/server/modules/terminal/template-port-runtime.js.map +1 -0
  178. package/dist/server/modules/terminal/terminal-controller.d.ts +94 -0
  179. package/dist/server/modules/terminal/terminal-controller.js +236 -0
  180. package/dist/server/modules/terminal/terminal-controller.js.map +1 -0
  181. package/dist/server/modules/terminal/terminal-history.d.ts +18 -0
  182. package/dist/server/modules/terminal/terminal-history.js +2 -0
  183. package/dist/server/modules/terminal/terminal-history.js.map +1 -0
  184. package/dist/server/modules/terminal/terminal-paths.d.ts +1 -0
  185. package/dist/server/modules/terminal/terminal-paths.js +27 -0
  186. package/dist/server/modules/terminal/terminal-paths.js.map +1 -0
  187. package/dist/server/modules/terminal/terminal-service.d.ts +112 -0
  188. package/dist/server/modules/terminal/terminal-service.js +794 -0
  189. package/dist/server/modules/terminal/terminal-service.js.map +1 -0
  190. package/dist/server/modules/terminal/terminal-shell.d.ts +13 -0
  191. package/dist/server/modules/terminal/terminal-shell.js +293 -0
  192. package/dist/server/modules/terminal/terminal-shell.js.map +1 -0
  193. package/dist/server/modules/workbench/workbench-controller.d.ts +7 -0
  194. package/dist/server/modules/workbench/workbench-controller.js +22 -0
  195. package/dist/server/modules/workbench/workbench-controller.js.map +1 -0
  196. package/dist/server/modules/workbench/workbench-service.d.ts +19 -0
  197. package/dist/server/modules/workbench/workbench-service.js +46 -0
  198. package/dist/server/modules/workbench/workbench-service.js.map +1 -0
  199. package/dist/server/modules/workbench/workspace-panel-snapshot-service.d.ts +65 -0
  200. package/dist/server/modules/workbench/workspace-panel-snapshot-service.js +176 -0
  201. package/dist/server/modules/workbench/workspace-panel-snapshot-service.js.map +1 -0
  202. package/dist/server/modules/workspace/workspace-controller.d.ts +57 -0
  203. package/dist/server/modules/workspace/workspace-controller.js +38 -0
  204. package/dist/server/modules/workspace/workspace-controller.js.map +1 -0
  205. package/dist/server/modules/workspace/workspace-service.d.ts +81 -0
  206. package/dist/server/modules/workspace/workspace-service.js +659 -0
  207. package/dist/server/modules/workspace/workspace-service.js.map +1 -0
  208. package/dist/server/routes/auth.d.ts +3 -0
  209. package/dist/server/routes/auth.js +6 -0
  210. package/dist/server/routes/auth.js.map +1 -0
  211. package/dist/server/routes/client.d.ts +3 -0
  212. package/dist/server/routes/client.js +6 -0
  213. package/dist/server/routes/client.js.map +1 -0
  214. package/dist/server/routes/files.d.ts +3 -0
  215. package/dist/server/routes/files.js +15 -0
  216. package/dist/server/routes/files.js.map +1 -0
  217. package/dist/server/routes/git.d.ts +3 -0
  218. package/dist/server/routes/git.js +18 -0
  219. package/dist/server/routes/git.js.map +1 -0
  220. package/dist/server/routes/preferences.d.ts +3 -0
  221. package/dist/server/routes/preferences.js +5 -0
  222. package/dist/server/routes/preferences.js.map +1 -0
  223. package/dist/server/routes/providers.d.ts +3 -0
  224. package/dist/server/routes/providers.js +6 -0
  225. package/dist/server/routes/providers.js.map +1 -0
  226. package/dist/server/routes/public.d.ts +3 -0
  227. package/dist/server/routes/public.js +5 -0
  228. package/dist/server/routes/public.js.map +1 -0
  229. package/dist/server/routes/session-contexts.d.ts +3 -0
  230. package/dist/server/routes/session-contexts.js +6 -0
  231. package/dist/server/routes/session-contexts.js.map +1 -0
  232. package/dist/server/routes/sessions.d.ts +3 -0
  233. package/dist/server/routes/sessions.js +24 -0
  234. package/dist/server/routes/sessions.js.map +1 -0
  235. package/dist/server/routes/terminals.d.ts +3 -0
  236. package/dist/server/routes/terminals.js +17 -0
  237. package/dist/server/routes/terminals.js.map +1 -0
  238. package/dist/server/routes/workbench.d.ts +3 -0
  239. package/dist/server/routes/workbench.js +4 -0
  240. package/dist/server/routes/workbench.js.map +1 -0
  241. package/dist/server/routes/workspaces.d.ts +3 -0
  242. package/dist/server/routes/workspaces.js +10 -0
  243. package/dist/server/routes/workspaces.js.map +1 -0
  244. package/dist/server/server/create-server.d.ts +103 -0
  245. package/dist/server/server/create-server.js +259 -0
  246. package/dist/server/server/create-server.js.map +1 -0
  247. package/dist/server/server/start-host.d.ts +8 -0
  248. package/dist/server/server/start-host.js +40 -0
  249. package/dist/server/server/start-host.js.map +1 -0
  250. package/dist/server/server/static-web.d.ts +2 -0
  251. package/dist/server/server/static-web.js +75 -0
  252. package/dist/server/server/static-web.js.map +1 -0
  253. package/dist/server/shared/errors/app-error.d.ts +13 -0
  254. package/dist/server/shared/errors/app-error.js +16 -0
  255. package/dist/server/shared/errors/app-error.js.map +1 -0
  256. package/dist/server/shared/http/error-handler.d.ts +9 -0
  257. package/dist/server/shared/http/error-handler.js +25 -0
  258. package/dist/server/shared/http/error-handler.js.map +1 -0
  259. package/dist/server/shared/utils/hash.d.ts +4 -0
  260. package/dist/server/shared/utils/hash.js +27 -0
  261. package/dist/server/shared/utils/hash.js.map +1 -0
  262. package/dist/server/shared/utils/id.d.ts +1 -0
  263. package/dist/server/shared/utils/id.js +5 -0
  264. package/dist/server/shared/utils/id.js.map +1 -0
  265. package/dist/server/shared/utils/perf-log.d.ts +6 -0
  266. package/dist/server/shared/utils/perf-log.js +40 -0
  267. package/dist/server/shared/utils/perf-log.js.map +1 -0
  268. package/dist/server/shared/utils/time.d.ts +2 -0
  269. package/dist/server/shared/utils/time.js +7 -0
  270. package/dist/server/shared/utils/time.js.map +1 -0
  271. package/dist/server/shared/utils/tokens.d.ts +1 -0
  272. package/dist/server/shared/utils/tokens.js +5 -0
  273. package/dist/server/shared/utils/tokens.js.map +1 -0
  274. package/dist/server/storage/repositories/auth-token-repository.d.ts +9 -0
  275. package/dist/server/storage/repositories/auth-token-repository.js +45 -0
  276. package/dist/server/storage/repositories/auth-token-repository.js.map +1 -0
  277. package/dist/server/storage/repositories/auth-user-repository.d.ts +11 -0
  278. package/dist/server/storage/repositories/auth-user-repository.js +61 -0
  279. package/dist/server/storage/repositories/auth-user-repository.js.map +1 -0
  280. package/dist/server/storage/repositories/bootstrap-state-repository.d.ts +8 -0
  281. package/dist/server/storage/repositories/bootstrap-state-repository.js +29 -0
  282. package/dist/server/storage/repositories/bootstrap-state-repository.js.map +1 -0
  283. package/dist/server/storage/repositories/commit-rule-profile-repository.d.ts +8 -0
  284. package/dist/server/storage/repositories/commit-rule-profile-repository.js +48 -0
  285. package/dist/server/storage/repositories/commit-rule-profile-repository.js.map +1 -0
  286. package/dist/server/storage/repositories/file-context-binding-repository.d.ts +12 -0
  287. package/dist/server/storage/repositories/file-context-binding-repository.js +130 -0
  288. package/dist/server/storage/repositories/file-context-binding-repository.js.map +1 -0
  289. package/dist/server/storage/repositories/recent-file-repository.d.ts +10 -0
  290. package/dist/server/storage/repositories/recent-file-repository.js +64 -0
  291. package/dist/server/storage/repositories/recent-file-repository.js.map +1 -0
  292. package/dist/server/storage/repositories/session-binding-repository.d.ts +10 -0
  293. package/dist/server/storage/repositories/session-binding-repository.js +63 -0
  294. package/dist/server/storage/repositories/session-binding-repository.js.map +1 -0
  295. package/dist/server/storage/repositories/session-changed-file-repository.d.ts +11 -0
  296. package/dist/server/storage/repositories/session-changed-file-repository.js +94 -0
  297. package/dist/server/storage/repositories/session-changed-file-repository.js.map +1 -0
  298. package/dist/server/storage/repositories/session-index-repository.d.ts +11 -0
  299. package/dist/server/storage/repositories/session-index-repository.js +200 -0
  300. package/dist/server/storage/repositories/session-index-repository.js.map +1 -0
  301. package/dist/server/storage/repositories/session-message-attachment-repository.d.ts +13 -0
  302. package/dist/server/storage/repositories/session-message-attachment-repository.js +139 -0
  303. package/dist/server/storage/repositories/session-message-attachment-repository.js.map +1 -0
  304. package/dist/server/storage/repositories/session-send-queue-repository.d.ts +15 -0
  305. package/dist/server/storage/repositories/session-send-queue-repository.js +165 -0
  306. package/dist/server/storage/repositories/session-send-queue-repository.js.map +1 -0
  307. package/dist/server/storage/repositories/session-state-repository.d.ts +8 -0
  308. package/dist/server/storage/repositories/session-state-repository.js +60 -0
  309. package/dist/server/storage/repositories/session-state-repository.js.map +1 -0
  310. package/dist/server/storage/repositories/session-status-snapshot-repository.d.ts +8 -0
  311. package/dist/server/storage/repositories/session-status-snapshot-repository.js +49 -0
  312. package/dist/server/storage/repositories/session-status-snapshot-repository.js.map +1 -0
  313. package/dist/server/storage/repositories/terminal-command-template-repository.d.ts +11 -0
  314. package/dist/server/storage/repositories/terminal-command-template-repository.js +99 -0
  315. package/dist/server/storage/repositories/terminal-command-template-repository.js.map +1 -0
  316. package/dist/server/storage/repositories/terminal-instance-repository.d.ts +23 -0
  317. package/dist/server/storage/repositories/terminal-instance-repository.js +149 -0
  318. package/dist/server/storage/repositories/terminal-instance-repository.js.map +1 -0
  319. package/dist/server/storage/repositories/terminal-log-file-repository.d.ts +20 -0
  320. package/dist/server/storage/repositories/terminal-log-file-repository.js +106 -0
  321. package/dist/server/storage/repositories/terminal-log-file-repository.js.map +1 -0
  322. package/dist/server/storage/repositories/terminal-log-segment-repository.d.ts +11 -0
  323. package/dist/server/storage/repositories/terminal-log-segment-repository.js +110 -0
  324. package/dist/server/storage/repositories/terminal-log-segment-repository.js.map +1 -0
  325. package/dist/server/storage/repositories/terminal-runtime-session-repository.d.ts +24 -0
  326. package/dist/server/storage/repositories/terminal-runtime-session-repository.js +134 -0
  327. package/dist/server/storage/repositories/terminal-runtime-session-repository.js.map +1 -0
  328. package/dist/server/storage/repositories/user-quick-phrase-preference-repository.d.ts +8 -0
  329. package/dist/server/storage/repositories/user-quick-phrase-preference-repository.js +37 -0
  330. package/dist/server/storage/repositories/user-quick-phrase-preference-repository.js.map +1 -0
  331. package/dist/server/storage/repositories/workspace-repository.d.ts +16 -0
  332. package/dist/server/storage/repositories/workspace-repository.js +71 -0
  333. package/dist/server/storage/repositories/workspace-repository.js.map +1 -0
  334. package/dist/server/storage/sqlite/client.d.ts +6 -0
  335. package/dist/server/storage/sqlite/client.js +446 -0
  336. package/dist/server/storage/sqlite/client.js.map +1 -0
  337. package/dist/server/storage/sqlite/schema.sql +357 -0
  338. package/dist/server/types/domain.d.ts +306 -0
  339. package/dist/server/types/domain.js +2 -0
  340. package/dist/server/types/domain.js.map +1 -0
  341. package/dist/server/ws/terminal-ws-hub.d.ts +32 -0
  342. package/dist/server/ws/terminal-ws-hub.js +181 -0
  343. package/dist/server/ws/terminal-ws-hub.js.map +1 -0
  344. package/dist/server/ws/workbench-ws-hub.d.ts +30 -0
  345. package/dist/server/ws/workbench-ws-hub.js +480 -0
  346. package/dist/server/ws/workbench-ws-hub.js.map +1 -0
  347. package/dist/server/ws/ws-auth-guard.d.ts +7 -0
  348. package/dist/server/ws/ws-auth-guard.js +28 -0
  349. package/dist/server/ws/ws-auth-guard.js.map +1 -0
  350. package/dist/server/ws/ws-server.d.ts +11 -0
  351. package/dist/server/ws/ws-server.js +218 -0
  352. package/dist/server/ws/ws-server.js.map +1 -0
  353. package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.d.ts +36 -0
  354. package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.js +213 -0
  355. package/node_modules/@codingns/session-sync-core/dist/claude-message-utils.js.map +1 -0
  356. package/node_modules/@codingns/session-sync-core/dist/index.d.ts +12 -0
  357. package/node_modules/@codingns/session-sync-core/dist/index.js +13 -0
  358. package/node_modules/@codingns/session-sync-core/dist/index.js.map +1 -0
  359. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.d.ts +30 -0
  360. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +567 -0
  361. package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js.map +1 -0
  362. package/node_modules/@codingns/session-sync-core/dist/providers/codex.d.ts +41 -0
  363. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +1365 -0
  364. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -0
  365. package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.d.ts +41 -0
  366. package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.js +280 -0
  367. package/node_modules/@codingns/session-sync-core/dist/providers/opencode-shared.js.map +1 -0
  368. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.d.ts +53 -0
  369. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +745 -0
  370. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -0
  371. package/node_modules/@codingns/session-sync-core/dist/providers/utils.d.ts +25 -0
  372. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js +284 -0
  373. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js.map +1 -0
  374. package/node_modules/@codingns/session-sync-core/dist/registry.d.ts +7 -0
  375. package/node_modules/@codingns/session-sync-core/dist/registry.js +22 -0
  376. package/node_modules/@codingns/session-sync-core/dist/registry.js.map +1 -0
  377. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.d.ts +18 -0
  378. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js +236 -0
  379. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js.map +1 -0
  380. package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.d.ts +21 -0
  381. package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js +732 -0
  382. package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js.map +1 -0
  383. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.d.ts +1 -0
  384. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js +16 -0
  385. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js.map +1 -0
  386. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +26 -0
  387. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +892 -0
  388. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -0
  389. package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.d.ts +31 -0
  390. package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js +626 -0
  391. package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js.map +1 -0
  392. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.d.ts +18 -0
  393. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js +148 -0
  394. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js.map +1 -0
  395. package/node_modules/@codingns/session-sync-core/dist/runtime/types.d.ts +141 -0
  396. package/node_modules/@codingns/session-sync-core/dist/runtime/types.js +2 -0
  397. package/node_modules/@codingns/session-sync-core/dist/runtime/types.js.map +1 -0
  398. package/node_modules/@codingns/session-sync-core/dist/services.d.ts +26 -0
  399. package/node_modules/@codingns/session-sync-core/dist/services.js +85 -0
  400. package/node_modules/@codingns/session-sync-core/dist/services.js.map +1 -0
  401. package/node_modules/@codingns/session-sync-core/dist/types.d.ts +159 -0
  402. package/node_modules/@codingns/session-sync-core/dist/types.js +2 -0
  403. package/node_modules/@codingns/session-sync-core/dist/types.js.map +1 -0
  404. package/node_modules/@codingns/session-sync-core/package.json +25 -0
  405. package/package.json +34 -0
@@ -0,0 +1,94 @@
1
+ export class SessionChangedFileRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ upsertMany(records) {
7
+ if (records.length === 0) {
8
+ return;
9
+ }
10
+ const statement = this.db.prepare(`INSERT INTO session_changed_files (
11
+ session_id,
12
+ workspace_id,
13
+ path,
14
+ first_detected_at,
15
+ last_detected_at,
16
+ last_tool_name
17
+ ) VALUES (?, ?, ?, ?, ?, ?)
18
+ ON CONFLICT(session_id, path) DO UPDATE SET
19
+ workspace_id = excluded.workspace_id,
20
+ first_detected_at = MIN(session_changed_files.first_detected_at, excluded.first_detected_at),
21
+ last_detected_at = MAX(session_changed_files.last_detected_at, excluded.last_detected_at),
22
+ last_tool_name = COALESCE(excluded.last_tool_name, session_changed_files.last_tool_name)`);
23
+ const persist = this.db.transaction((items) => {
24
+ for (const record of items) {
25
+ statement.run(record.sessionId, record.workspaceId, record.path, record.firstDetectedAt, record.lastDetectedAt, record.lastToolName);
26
+ }
27
+ });
28
+ persist(records);
29
+ }
30
+ listBySessionId(sessionId) {
31
+ return this.db
32
+ .prepare(`SELECT
33
+ session_id AS session_id,
34
+ workspace_id AS workspace_id,
35
+ path AS path,
36
+ first_detected_at AS first_detected_at,
37
+ last_detected_at AS last_detected_at,
38
+ last_tool_name AS last_tool_name
39
+ FROM session_changed_files
40
+ WHERE session_id = ?
41
+ ORDER BY path ASC`)
42
+ .all(sessionId)
43
+ .map((row) => mapSessionChangedFileRow(row));
44
+ }
45
+ findIndexStateBySessionId(sessionId) {
46
+ const row = this.db
47
+ .prepare(`SELECT
48
+ session_id AS session_id,
49
+ indexed_at AS indexed_at,
50
+ updated_at AS updated_at
51
+ FROM session_changed_file_states
52
+ WHERE session_id = ?`)
53
+ .get(sessionId);
54
+ return row ? mapSessionChangedFileStateRow(row) : null;
55
+ }
56
+ upsertIndexState(record) {
57
+ this.db
58
+ .prepare(`INSERT INTO session_changed_file_states (
59
+ session_id,
60
+ indexed_at,
61
+ updated_at
62
+ ) VALUES (?, ?, ?)
63
+ ON CONFLICT(session_id) DO UPDATE SET
64
+ indexed_at = excluded.indexed_at,
65
+ updated_at = excluded.updated_at`)
66
+ .run(record.sessionId, record.indexedAt, record.updatedAt);
67
+ }
68
+ deleteBySessionId(sessionId) {
69
+ this.db
70
+ .prepare("DELETE FROM session_changed_files WHERE session_id = ?")
71
+ .run(sessionId);
72
+ this.db
73
+ .prepare("DELETE FROM session_changed_file_states WHERE session_id = ?")
74
+ .run(sessionId);
75
+ }
76
+ }
77
+ function mapSessionChangedFileRow(row) {
78
+ return {
79
+ sessionId: row.session_id,
80
+ workspaceId: row.workspace_id,
81
+ path: row.path,
82
+ firstDetectedAt: row.first_detected_at,
83
+ lastDetectedAt: row.last_detected_at,
84
+ lastToolName: row.last_tool_name
85
+ };
86
+ }
87
+ function mapSessionChangedFileStateRow(row) {
88
+ return {
89
+ sessionId: row.session_id,
90
+ indexedAt: row.indexed_at,
91
+ updatedAt: row.updated_at
92
+ };
93
+ }
94
+ //# sourceMappingURL=session-changed-file-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-changed-file-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/session-changed-file-repository.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,4BAA4B;IACV;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,UAAU,CAAC,OAAmC;QAC5C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAC/B;;;;;;;;;;;;kGAY4F,CAC7F,CAAC;QAEF,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,KAAiC,EAAE,EAAE;YACxE,KAAK,MAAM,MAAM,IAAI,KAAK,EAAE,CAAC;gBAC3B,SAAS,CAAC,GAAG,CACX,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,cAAc,EACrB,MAAM,CAAC,YAAY,CACpB,CAAC;YACJ,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,OAAO,CAAC,CAAC;IACnB,CAAC;IAED,eAAe,CAAC,SAAiB;QAC/B,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;2BASmB,CACpB;aACA,GAAG,CAAC,SAAS,CAAC;aACd,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,wBAAwB,CAAC,GAA4B,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED,yBAAyB,CAAC,SAAiB;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;8BAKsB,CACvB;aACA,GAAG,CAAC,SAAS,CAA2C,CAAC;QAE5D,OAAO,GAAG,CAAC,CAAC,CAAC,6BAA6B,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACzD,CAAC;IAED,gBAAgB,CAAC,MAAoC;QACnD,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;4CAOoC,CACrC;aACA,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;IAC/D,CAAC;IAED,iBAAiB,CAAC,SAAiB;QACjC,IAAI,CAAC,EAAE;aACJ,OAAO,CAAC,wDAAwD,CAAC;aACjE,GAAG,CAAC,SAAS,CAAC,CAAC;QAClB,IAAI,CAAC,EAAE;aACJ,OAAO,CAAC,8DAA8D,CAAC;aACvE,GAAG,CAAC,SAAS,CAAC,CAAC;IACpB,CAAC;CACF;AAiBD,SAAS,wBAAwB,CAAC,GAA0B;IAC1D,OAAO;QACL,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,eAAe,EAAE,GAAG,CAAC,iBAAiB;QACtC,cAAc,EAAE,GAAG,CAAC,gBAAgB;QACpC,YAAY,EAAE,GAAG,CAAC,cAAc;KACjC,CAAC;AACJ,CAAC;AAED,SAAS,6BAA6B,CACpC,GAA+B;IAE/B,OAAO;QACL,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SessionIndexRecord, SessionListItem } from "../../types/domain.js";
3
+ export declare class SessionIndexRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ upsert(record: SessionIndexRecord): void;
7
+ listByWorkspace(workspaceId: string, userId: string): SessionListItem[];
8
+ findBySessionId(sessionId: string, userId: string): SessionListItem | null;
9
+ findIndexRecordBySessionId(sessionId: string): SessionIndexRecord | null;
10
+ renameTitle(sessionId: string, title: string, updatedAt: string): void;
11
+ }
@@ -0,0 +1,200 @@
1
+ export class SessionIndexRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ upsert(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO session_indices (
9
+ session_id,
10
+ workspace_id,
11
+ provider,
12
+ parent_session_id,
13
+ is_subagent,
14
+ subagent_label,
15
+ title,
16
+ message_count,
17
+ is_archived,
18
+ last_message_at,
19
+ created_at,
20
+ updated_at
21
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
22
+ ON CONFLICT(session_id) DO UPDATE SET
23
+ workspace_id = excluded.workspace_id,
24
+ provider = excluded.provider,
25
+ parent_session_id = excluded.parent_session_id,
26
+ is_subagent = excluded.is_subagent,
27
+ subagent_label = excluded.subagent_label,
28
+ title = excluded.title,
29
+ message_count = excluded.message_count,
30
+ is_archived = excluded.is_archived,
31
+ last_message_at = excluded.last_message_at,
32
+ updated_at = excluded.updated_at`)
33
+ .run(record.sessionId, record.workspaceId, record.provider, record.parentSessionId ?? null, record.isSubagent ? 1 : 0, record.subagentLabel ?? null, record.title, record.messageCount, record.isArchived ? 1 : 0, record.lastMessageAt, record.createdAt, record.updatedAt);
34
+ }
35
+ listByWorkspace(workspaceId, userId) {
36
+ return this.db
37
+ .prepare(`SELECT
38
+ indices.session_id AS session_id,
39
+ indices.workspace_id AS workspace_id,
40
+ indices.provider AS provider,
41
+ bindings.provider_session_id AS provider_session_id,
42
+ bindings.raw_store_ref AS raw_store_ref,
43
+ indices.parent_session_id AS parent_session_id,
44
+ indices.is_subagent AS is_subagent,
45
+ indices.subagent_label AS subagent_label,
46
+ indices.title AS title,
47
+ indices.message_count AS message_count,
48
+ indices.last_message_at AS last_message_at,
49
+ indices.created_at AS created_at,
50
+ indices.updated_at AS updated_at,
51
+ snapshots.sync_status AS sync_status,
52
+ snapshots.sync_cursor AS sync_cursor,
53
+ snapshots.last_sync_at AS last_sync_at,
54
+ snapshots.last_error_code AS last_error_code,
55
+ snapshots.last_error_detail AS last_error_detail,
56
+ snapshots.resumed_at AS resumed_at,
57
+ states.running_state AS running_state,
58
+ COALESCE(states.activity_source, 'none') AS activity_source,
59
+ COALESCE(states.favorite, 0) AS favorite,
60
+ indices.is_archived AS is_archived,
61
+ states.last_event_at AS last_event_at,
62
+ states.completed_at AS completed_at,
63
+ states.last_seen_at AS last_seen_at
64
+ FROM session_indices indices
65
+ INNER JOIN session_bindings bindings ON bindings.session_id = indices.session_id
66
+ LEFT JOIN session_status_snapshots snapshots ON snapshots.session_id = indices.session_id
67
+ LEFT JOIN session_states states
68
+ ON states.session_id = indices.session_id
69
+ AND states.user_id = ?
70
+ WHERE indices.workspace_id = ?
71
+ ORDER BY COALESCE(indices.last_message_at, indices.updated_at) DESC, indices.updated_at DESC`)
72
+ .all(userId, workspaceId)
73
+ .map((row) => mapSessionListItemRow(row));
74
+ }
75
+ findBySessionId(sessionId, userId) {
76
+ const row = this.db
77
+ .prepare(`SELECT
78
+ indices.session_id AS session_id,
79
+ indices.workspace_id AS workspace_id,
80
+ indices.provider AS provider,
81
+ bindings.provider_session_id AS provider_session_id,
82
+ bindings.raw_store_ref AS raw_store_ref,
83
+ indices.parent_session_id AS parent_session_id,
84
+ indices.is_subagent AS is_subagent,
85
+ indices.subagent_label AS subagent_label,
86
+ indices.title AS title,
87
+ indices.message_count AS message_count,
88
+ indices.last_message_at AS last_message_at,
89
+ indices.created_at AS created_at,
90
+ indices.updated_at AS updated_at,
91
+ snapshots.sync_status AS sync_status,
92
+ snapshots.sync_cursor AS sync_cursor,
93
+ snapshots.last_sync_at AS last_sync_at,
94
+ snapshots.last_error_code AS last_error_code,
95
+ snapshots.last_error_detail AS last_error_detail,
96
+ snapshots.resumed_at AS resumed_at,
97
+ states.running_state AS running_state,
98
+ COALESCE(states.activity_source, 'none') AS activity_source,
99
+ COALESCE(states.favorite, 0) AS favorite,
100
+ indices.is_archived AS is_archived,
101
+ states.last_event_at AS last_event_at,
102
+ states.completed_at AS completed_at,
103
+ states.last_seen_at AS last_seen_at
104
+ FROM session_indices indices
105
+ INNER JOIN session_bindings bindings ON bindings.session_id = indices.session_id
106
+ LEFT JOIN session_status_snapshots snapshots ON snapshots.session_id = indices.session_id
107
+ LEFT JOIN session_states states
108
+ ON states.session_id = indices.session_id
109
+ AND states.user_id = ?
110
+ WHERE indices.session_id = ?`)
111
+ .get(userId, sessionId);
112
+ return row ? mapSessionListItemRow(row) : null;
113
+ }
114
+ findIndexRecordBySessionId(sessionId) {
115
+ const row = this.db
116
+ .prepare(`SELECT
117
+ session_id AS session_id,
118
+ workspace_id AS workspace_id,
119
+ provider AS provider,
120
+ parent_session_id AS parent_session_id,
121
+ is_subagent AS is_subagent,
122
+ subagent_label AS subagent_label,
123
+ title AS title,
124
+ message_count AS message_count,
125
+ is_archived AS is_archived,
126
+ last_message_at AS last_message_at,
127
+ created_at AS created_at,
128
+ updated_at AS updated_at
129
+ FROM session_indices
130
+ WHERE session_id = ?`)
131
+ .get(sessionId);
132
+ return row ? mapSessionIndexRecordRow(row) : null;
133
+ }
134
+ renameTitle(sessionId, title, updatedAt) {
135
+ this.db
136
+ .prepare(`UPDATE session_indices
137
+ SET title = ?, updated_at = ?
138
+ WHERE session_id = ?`)
139
+ .run(title, updatedAt, sessionId);
140
+ }
141
+ }
142
+ function mapSessionListItemRow(row) {
143
+ const isRuntimeActive = row.activity_source === "runtime"
144
+ && (row.running_state === "starting" || row.running_state === "running");
145
+ const isInferredActive = row.activity_source === "inferred" && row.running_state === "running";
146
+ const hasUnreadCompletion = row.activity_source !== "none"
147
+ && !!row.completed_at
148
+ && (!row.last_seen_at || row.completed_at > row.last_seen_at);
149
+ const activityState = isRuntimeActive || isInferredActive
150
+ ? "running"
151
+ : hasUnreadCompletion
152
+ ? "completed_unread"
153
+ : "idle";
154
+ return {
155
+ sessionId: row.session_id,
156
+ workspaceId: row.workspace_id,
157
+ provider: row.provider,
158
+ providerSessionId: row.provider_session_id,
159
+ rawStoreRef: row.raw_store_ref,
160
+ parentSessionId: row.parent_session_id,
161
+ isSubagent: row.is_subagent === 1,
162
+ subagentLabel: row.subagent_label,
163
+ title: row.title,
164
+ isFavorite: row.favorite === 1,
165
+ messageCount: row.message_count,
166
+ lastMessageAt: row.last_message_at,
167
+ createdAt: row.created_at,
168
+ updatedAt: row.updated_at,
169
+ syncStatus: row.sync_status,
170
+ syncCursor: row.sync_cursor,
171
+ lastSyncAt: row.last_sync_at,
172
+ lastErrorCode: row.last_error_code,
173
+ lastErrorDetail: row.last_error_detail,
174
+ resumedAt: row.resumed_at,
175
+ runningState: row.running_state,
176
+ activitySource: row.activity_source,
177
+ isArchived: row.is_archived === 1,
178
+ lastEventAt: row.last_event_at,
179
+ completedAt: row.completed_at,
180
+ lastSeenAt: row.last_seen_at,
181
+ activityState
182
+ };
183
+ }
184
+ function mapSessionIndexRecordRow(row) {
185
+ return {
186
+ sessionId: row.session_id,
187
+ workspaceId: row.workspace_id,
188
+ provider: row.provider,
189
+ parentSessionId: row.parent_session_id,
190
+ isSubagent: row.is_subagent === 1,
191
+ subagentLabel: row.subagent_label,
192
+ title: row.title,
193
+ messageCount: row.message_count,
194
+ isArchived: row.is_archived === 1,
195
+ lastMessageAt: row.last_message_at,
196
+ createdAt: row.created_at,
197
+ updatedAt: row.updated_at
198
+ };
199
+ }
200
+ //# sourceMappingURL=session-index-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-index-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/session-index-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SessionMessageAttachmentRecord } from "../../types/domain.js";
3
+ export declare class SessionMessageAttachmentRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ listBySessionAndClientRequest(sessionId: string, clientRequestId: string): SessionMessageAttachmentRecord[];
7
+ listBySessionAndMessageIds(sessionId: string, messageIds: string[]): SessionMessageAttachmentRecord[];
8
+ findBySessionAndId(sessionId: string, attachmentId: string): SessionMessageAttachmentRecord | null;
9
+ insert(record: SessionMessageAttachmentRecord): void;
10
+ bindMessage(sessionId: string, clientRequestId: string, messageId: string): void;
11
+ listUnboundBySessionAndClientRequest(sessionId: string, clientRequestId: string): SessionMessageAttachmentRecord[];
12
+ deleteByIds(attachmentIds: string[]): void;
13
+ }
@@ -0,0 +1,139 @@
1
+ export class SessionMessageAttachmentRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ listBySessionAndClientRequest(sessionId, clientRequestId) {
7
+ const rows = this.db
8
+ .prepare(`SELECT
9
+ id,
10
+ session_id,
11
+ client_request_id,
12
+ message_id,
13
+ kind,
14
+ file_name,
15
+ mime_type,
16
+ file_size,
17
+ storage_path,
18
+ created_at
19
+ FROM session_message_attachments
20
+ WHERE session_id = ?
21
+ AND client_request_id = ?
22
+ ORDER BY created_at ASC`)
23
+ .all(sessionId, clientRequestId);
24
+ return rows.map(mapSessionMessageAttachmentRow);
25
+ }
26
+ listBySessionAndMessageIds(sessionId, messageIds) {
27
+ if (messageIds.length === 0) {
28
+ return [];
29
+ }
30
+ const placeholders = messageIds.map(() => "?").join(", ");
31
+ const rows = this.db
32
+ .prepare(`SELECT
33
+ id,
34
+ session_id,
35
+ client_request_id,
36
+ message_id,
37
+ kind,
38
+ file_name,
39
+ mime_type,
40
+ file_size,
41
+ storage_path,
42
+ created_at
43
+ FROM session_message_attachments
44
+ WHERE session_id = ?
45
+ AND message_id IN (${placeholders})
46
+ ORDER BY created_at ASC`)
47
+ .all(sessionId, ...messageIds);
48
+ return rows.map(mapSessionMessageAttachmentRow);
49
+ }
50
+ findBySessionAndId(sessionId, attachmentId) {
51
+ const row = this.db
52
+ .prepare(`SELECT
53
+ id,
54
+ session_id,
55
+ client_request_id,
56
+ message_id,
57
+ kind,
58
+ file_name,
59
+ mime_type,
60
+ file_size,
61
+ storage_path,
62
+ created_at
63
+ FROM session_message_attachments
64
+ WHERE session_id = ?
65
+ AND id = ?
66
+ LIMIT 1`)
67
+ .get(sessionId, attachmentId);
68
+ return row ? mapSessionMessageAttachmentRow(row) : null;
69
+ }
70
+ insert(record) {
71
+ this.db
72
+ .prepare(`INSERT INTO session_message_attachments (
73
+ id,
74
+ session_id,
75
+ client_request_id,
76
+ message_id,
77
+ kind,
78
+ file_name,
79
+ mime_type,
80
+ file_size,
81
+ storage_path,
82
+ created_at
83
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
84
+ .run(record.id, record.sessionId, record.clientRequestId, record.messageId, record.kind, record.fileName, record.mimeType, record.fileSize, record.storagePath, record.createdAt);
85
+ }
86
+ bindMessage(sessionId, clientRequestId, messageId) {
87
+ this.db
88
+ .prepare(`UPDATE session_message_attachments
89
+ SET message_id = ?
90
+ WHERE session_id = ?
91
+ AND client_request_id = ?`)
92
+ .run(messageId, sessionId, clientRequestId);
93
+ }
94
+ listUnboundBySessionAndClientRequest(sessionId, clientRequestId) {
95
+ const rows = this.db
96
+ .prepare(`SELECT
97
+ id,
98
+ session_id,
99
+ client_request_id,
100
+ message_id,
101
+ kind,
102
+ file_name,
103
+ mime_type,
104
+ file_size,
105
+ storage_path,
106
+ created_at
107
+ FROM session_message_attachments
108
+ WHERE session_id = ?
109
+ AND client_request_id = ?
110
+ AND message_id IS NULL
111
+ ORDER BY created_at ASC`)
112
+ .all(sessionId, clientRequestId);
113
+ return rows.map(mapSessionMessageAttachmentRow);
114
+ }
115
+ deleteByIds(attachmentIds) {
116
+ if (attachmentIds.length === 0) {
117
+ return;
118
+ }
119
+ const placeholders = attachmentIds.map(() => "?").join(", ");
120
+ this.db
121
+ .prepare(`DELETE FROM session_message_attachments WHERE id IN (${placeholders})`)
122
+ .run(...attachmentIds);
123
+ }
124
+ }
125
+ function mapSessionMessageAttachmentRow(row) {
126
+ return {
127
+ id: row.id,
128
+ sessionId: row.session_id,
129
+ clientRequestId: row.client_request_id,
130
+ messageId: row.message_id,
131
+ kind: row.kind,
132
+ fileName: row.file_name,
133
+ mimeType: row.mime_type,
134
+ fileSize: row.file_size,
135
+ storagePath: row.storage_path,
136
+ createdAt: row.created_at
137
+ };
138
+ }
139
+ //# sourceMappingURL=session-message-attachment-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-message-attachment-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/session-message-attachment-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SessionSendQueueItemRecord } from "../../types/domain.js";
3
+ export declare class SessionSendQueueRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ listBySessionAndUser(sessionId: string, userId: string): SessionSendQueueItemRecord[];
7
+ findBySessionUserAndId(sessionId: string, userId: string, queueItemId: string): SessionSendQueueItemRecord | null;
8
+ findNextQueued(sessionId: string): SessionSendQueueItemRecord | null;
9
+ getNextOrderIndex(sessionId: string): number;
10
+ insert(record: SessionSendQueueItemRecord): void;
11
+ markDispatching(queueItemId: string, dispatchedAt: string): boolean;
12
+ markQueued(queueItemId: string, updatedAt: string): void;
13
+ markFailed(queueItemId: string, errorDetail: string | null, updatedAt: string): void;
14
+ delete(queueItemId: string): boolean;
15
+ }
@@ -0,0 +1,165 @@
1
+ export class SessionSendQueueRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ listBySessionAndUser(sessionId, userId) {
7
+ const rows = this.db
8
+ .prepare(`SELECT
9
+ id,
10
+ session_id,
11
+ user_id,
12
+ content,
13
+ client_request_id,
14
+ model,
15
+ reasoning_level,
16
+ permission_mode,
17
+ status,
18
+ order_index,
19
+ error_detail,
20
+ created_at,
21
+ updated_at,
22
+ dispatched_at
23
+ FROM session_send_queue
24
+ WHERE session_id = ?
25
+ AND user_id = ?
26
+ AND status IN ('queued', 'failed')
27
+ ORDER BY order_index ASC, created_at ASC`)
28
+ .all(sessionId, userId);
29
+ return rows.map(mapSessionSendQueueRow);
30
+ }
31
+ findBySessionUserAndId(sessionId, userId, queueItemId) {
32
+ const row = this.db
33
+ .prepare(`SELECT
34
+ id,
35
+ session_id,
36
+ user_id,
37
+ content,
38
+ client_request_id,
39
+ model,
40
+ reasoning_level,
41
+ permission_mode,
42
+ status,
43
+ order_index,
44
+ error_detail,
45
+ created_at,
46
+ updated_at,
47
+ dispatched_at
48
+ FROM session_send_queue
49
+ WHERE session_id = ?
50
+ AND user_id = ?
51
+ AND id = ?
52
+ LIMIT 1`)
53
+ .get(sessionId, userId, queueItemId);
54
+ return row ? mapSessionSendQueueRow(row) : null;
55
+ }
56
+ findNextQueued(sessionId) {
57
+ const row = this.db
58
+ .prepare(`SELECT
59
+ id,
60
+ session_id,
61
+ user_id,
62
+ content,
63
+ client_request_id,
64
+ model,
65
+ reasoning_level,
66
+ permission_mode,
67
+ status,
68
+ order_index,
69
+ error_detail,
70
+ created_at,
71
+ updated_at,
72
+ dispatched_at
73
+ FROM session_send_queue
74
+ WHERE session_id = ?
75
+ AND status = 'queued'
76
+ ORDER BY order_index ASC, created_at ASC
77
+ LIMIT 1`)
78
+ .get(sessionId);
79
+ return row ? mapSessionSendQueueRow(row) : null;
80
+ }
81
+ getNextOrderIndex(sessionId) {
82
+ const row = this.db
83
+ .prepare(`SELECT COALESCE(MAX(order_index), 0) AS max_order_index
84
+ FROM session_send_queue
85
+ WHERE session_id = ?`)
86
+ .get(sessionId);
87
+ return (row?.max_order_index ?? 0) + 1;
88
+ }
89
+ insert(record) {
90
+ this.db
91
+ .prepare(`INSERT INTO session_send_queue (
92
+ id,
93
+ session_id,
94
+ user_id,
95
+ content,
96
+ client_request_id,
97
+ model,
98
+ reasoning_level,
99
+ permission_mode,
100
+ status,
101
+ order_index,
102
+ error_detail,
103
+ created_at,
104
+ updated_at,
105
+ dispatched_at
106
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
107
+ .run(record.id, record.sessionId, record.userId, record.content, record.clientRequestId, record.model, record.reasoningLevel, record.permissionMode, record.status, record.orderIndex, record.errorDetail, record.createdAt, record.updatedAt, record.dispatchedAt);
108
+ }
109
+ markDispatching(queueItemId, dispatchedAt) {
110
+ const result = this.db
111
+ .prepare(`UPDATE session_send_queue
112
+ SET status = 'dispatching',
113
+ dispatched_at = ?,
114
+ updated_at = ?,
115
+ error_detail = NULL
116
+ WHERE id = ?
117
+ AND status = 'queued'`)
118
+ .run(dispatchedAt, dispatchedAt, queueItemId);
119
+ return result.changes > 0;
120
+ }
121
+ markQueued(queueItemId, updatedAt) {
122
+ this.db
123
+ .prepare(`UPDATE session_send_queue
124
+ SET status = 'queued',
125
+ dispatched_at = NULL,
126
+ updated_at = ?,
127
+ error_detail = NULL
128
+ WHERE id = ?`)
129
+ .run(updatedAt, queueItemId);
130
+ }
131
+ markFailed(queueItemId, errorDetail, updatedAt) {
132
+ this.db
133
+ .prepare(`UPDATE session_send_queue
134
+ SET status = 'failed',
135
+ error_detail = ?,
136
+ updated_at = ?
137
+ WHERE id = ?`)
138
+ .run(errorDetail, updatedAt, queueItemId);
139
+ }
140
+ delete(queueItemId) {
141
+ const result = this.db
142
+ .prepare("DELETE FROM session_send_queue WHERE id = ?")
143
+ .run(queueItemId);
144
+ return result.changes > 0;
145
+ }
146
+ }
147
+ function mapSessionSendQueueRow(row) {
148
+ return {
149
+ id: row.id,
150
+ sessionId: row.session_id,
151
+ userId: row.user_id,
152
+ content: row.content,
153
+ clientRequestId: row.client_request_id,
154
+ model: row.model,
155
+ reasoningLevel: row.reasoning_level,
156
+ permissionMode: row.permission_mode,
157
+ status: row.status,
158
+ orderIndex: row.order_index,
159
+ errorDetail: row.error_detail,
160
+ createdAt: row.created_at,
161
+ updatedAt: row.updated_at,
162
+ dispatchedAt: row.dispatched_at
163
+ };
164
+ }
165
+ //# sourceMappingURL=session-send-queue-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-send-queue-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/session-send-queue-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SessionStateRecord } from "../../types/domain.js";
3
+ export declare class SessionStateRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ findBySessionAndUser(sessionId: string, userId: string): SessionStateRecord | null;
7
+ upsert(record: SessionStateRecord): void;
8
+ }