@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 @@
1
+ {"version":3,"file":"time.js","sourceRoot":"","sources":["../../../../src/shared/utils/time.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,MAAM,CAAC,IAAI,GAAG,IAAI,IAAI,EAAE;IACtC,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,IAAU,EAAE,OAAe;IACpD,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,OAAO,GAAG,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;AACjE,CAAC"}
@@ -0,0 +1 @@
1
+ export declare function createOpaqueToken(): string;
@@ -0,0 +1,5 @@
1
+ import { randomBytes } from "node:crypto";
2
+ export function createOpaqueToken() {
3
+ return randomBytes(32).toString("base64url");
4
+ }
5
+ //# sourceMappingURL=tokens.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tokens.js","sourceRoot":"","sources":["../../../../src/shared/utils/tokens.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1C,MAAM,UAAU,iBAAiB;IAC/B,OAAO,WAAW,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;AAC/C,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { AuthTokenRecord } from "../../types/domain.js";
3
+ export declare class AuthTokenRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: AuthTokenRecord): void;
7
+ findByHash(tokenHash: string, tokenType?: "access" | "refresh"): AuthTokenRecord | null;
8
+ revokeByHash(tokenHash: string, revokedAt: string): void;
9
+ }
@@ -0,0 +1,45 @@
1
+ export class AuthTokenRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO auth_tokens (id, user_id, token_type, token_hash, expires_at, revoked_at, created_at)
9
+ VALUES (?, ?, ?, ?, ?, ?, ?)`)
10
+ .run(record.id, record.userId, record.tokenType, record.tokenHash, record.expiresAt, record.revokedAt, record.createdAt);
11
+ }
12
+ findByHash(tokenHash, tokenType) {
13
+ const row = tokenType
14
+ ? this.db
15
+ .prepare(`SELECT id, user_id, token_type, token_hash, expires_at, revoked_at, created_at
16
+ FROM auth_tokens
17
+ WHERE token_hash = ? AND token_type = ?`)
18
+ .get(tokenHash, tokenType)
19
+ : this.db
20
+ .prepare(`SELECT id, user_id, token_type, token_hash, expires_at, revoked_at, created_at
21
+ FROM auth_tokens
22
+ WHERE token_hash = ?`)
23
+ .get(tokenHash);
24
+ return row ? mapTokenRow(row) : null;
25
+ }
26
+ revokeByHash(tokenHash, revokedAt) {
27
+ this.db
28
+ .prepare(`UPDATE auth_tokens
29
+ SET revoked_at = ?
30
+ WHERE token_hash = ? AND revoked_at IS NULL`)
31
+ .run(revokedAt, tokenHash);
32
+ }
33
+ }
34
+ function mapTokenRow(row) {
35
+ return {
36
+ id: row.id,
37
+ userId: row.user_id,
38
+ tokenType: row.token_type,
39
+ tokenHash: row.token_hash,
40
+ expiresAt: row.expires_at,
41
+ revokedAt: row.revoked_at,
42
+ createdAt: row.created_at
43
+ };
44
+ }
45
+ //# sourceMappingURL=auth-token-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-token-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-token-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,mBAAmB;IACD;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAAuB;QAC5B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;sCAC8B,CAC/B;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;IAED,UAAU,CAAC,SAAiB,EAAE,SAAgC;QAC5D,MAAM,GAAG,GAAG,SAAS;YACnB,CAAC,CAAE,IAAI,CAAC,EAAE;iBACL,OAAO,CACN;;qDAEyC,CAC1C;iBACA,GAAG,CAAC,SAAS,EAAE,SAAS,CAA0B;YACvD,CAAC,CAAE,IAAI,CAAC,EAAE;iBACL,OAAO,CACN;;kCAEsB,CACvB;iBACA,GAAG,CAAC,SAAS,CAA0B,CAAC;QAE/C,OAAO,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,SAAiB,EAAE,SAAiB;QAC/C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;qDAE6C,CAC9C;aACA,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IAC/B,CAAC;CACF;AAYD,SAAS,WAAW,CAAC,GAAa;IAChC,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,MAAM,EAAE,GAAG,CAAC,OAAO;QACnB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,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,11 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { AuthUser } from "../../types/domain.js";
3
+ export declare class AuthUserRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: AuthUser): void;
7
+ findByUsername(username: string): AuthUser | null;
8
+ findById(id: string): AuthUser | null;
9
+ count(): number;
10
+ listIds(): string[];
11
+ }
@@ -0,0 +1,61 @@
1
+ export class AuthUserRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO auth_users (id, username, password_hash, role, created_at, updated_at)
9
+ VALUES (?, ?, ?, ?, ?, ?)`)
10
+ .run(record.id, record.username, record.passwordHash, record.role, record.createdAt, record.updatedAt);
11
+ }
12
+ findByUsername(username) {
13
+ const row = this.db
14
+ .prepare(`SELECT id, username, password_hash, role, created_at, updated_at
15
+ FROM auth_users
16
+ WHERE username = ?`)
17
+ .get(username);
18
+ if (!row) {
19
+ return null;
20
+ }
21
+ return {
22
+ id: row.id,
23
+ username: row.username,
24
+ passwordHash: row.password_hash,
25
+ role: row.role,
26
+ createdAt: row.created_at,
27
+ updatedAt: row.updated_at
28
+ };
29
+ }
30
+ findById(id) {
31
+ const row = this.db
32
+ .prepare(`SELECT id, username, password_hash, role, created_at, updated_at
33
+ FROM auth_users
34
+ WHERE id = ?`)
35
+ .get(id);
36
+ if (!row) {
37
+ return null;
38
+ }
39
+ return {
40
+ id: row.id,
41
+ username: row.username,
42
+ passwordHash: row.password_hash,
43
+ role: row.role,
44
+ createdAt: row.created_at,
45
+ updatedAt: row.updated_at
46
+ };
47
+ }
48
+ count() {
49
+ const row = this.db.prepare("SELECT COUNT(1) AS count FROM auth_users").get();
50
+ return row.count;
51
+ }
52
+ listIds() {
53
+ return this.db
54
+ .prepare(`SELECT id
55
+ FROM auth_users
56
+ ORDER BY created_at ASC`)
57
+ .all()
58
+ .map((row) => row.id);
59
+ }
60
+ }
61
+ //# sourceMappingURL=auth-user-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-user-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-user-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,kBAAkB;IACA;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAAgB;QACrB,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;mCAC2B,CAC5B;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;IAED,cAAc,CAAC,QAAgB;QAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;4BAEoB,CACrB;aACA,GAAG,CAAC,QAAQ,CASF,CAAC;QAEd,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,YAAY,EAAE,GAAG,CAAC,aAAa;YAC/B,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,SAAS,EAAE,GAAG,CAAC,UAAU;YACzB,SAAS,EAAE,GAAG,CAAC,UAAU;SAC1B,CAAC;IACJ,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;sBAEc,CACf;aACA,GAAG,CAAC,EAAE,CASI,CAAC;QAEd,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,YAAY,EAAE,GAAG,CAAC,aAAa;YAC/B,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,SAAS,EAAE,GAAG,CAAC,UAAU;YACzB,SAAS,EAAE,GAAG,CAAC,UAAU;SAC1B,CAAC;IACJ,CAAC;IAED,KAAK;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,0CAA0C,CAAC,CAAC,GAAG,EAAuB,CAAC;QACnG,OAAO,GAAG,CAAC,KAAK,CAAC;IACnB,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;iCAEyB,CAC1B;aACA,GAAG,EAAE;aACL,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAE,GAAsB,CAAC,EAAE,CAAC,CAAC;IAC9C,CAAC;CACF"}
@@ -0,0 +1,8 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { BootstrapState } from "../../types/domain.js";
3
+ export declare class BootstrapStateRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ getState(): BootstrapState;
7
+ markInitialized(initializedAt: string, initializedByUserId: string): void;
8
+ }
@@ -0,0 +1,29 @@
1
+ export class BootstrapStateRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ getState() {
7
+ const row = this.db
8
+ .prepare(`SELECT id, initialized, initialized_at, initialized_by_user_id
9
+ FROM bootstrap_state
10
+ WHERE id = 'default'`)
11
+ .get();
12
+ return {
13
+ id: "default",
14
+ initialized: Boolean(row?.initialized),
15
+ initializedAt: row?.initialized_at ?? null,
16
+ initializedByUserId: row?.initialized_by_user_id ?? null
17
+ };
18
+ }
19
+ markInitialized(initializedAt, initializedByUserId) {
20
+ this.db
21
+ .prepare(`UPDATE bootstrap_state
22
+ SET initialized = 1,
23
+ initialized_at = ?,
24
+ initialized_by_user_id = ?
25
+ WHERE id = 'default'`)
26
+ .run(initializedAt, initializedByUserId);
27
+ }
28
+ }
29
+ //# sourceMappingURL=bootstrap-state-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bootstrap-state-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/bootstrap-state-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,wBAAwB;IACN;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,QAAQ;QACN,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;8BAEsB,CACvB;aACA,GAAG,EAOO,CAAC;QAEd,OAAO;YACL,EAAE,EAAE,SAAS;YACb,WAAW,EAAE,OAAO,CAAC,GAAG,EAAE,WAAW,CAAC;YACtC,aAAa,EAAE,GAAG,EAAE,cAAc,IAAI,IAAI;YAC1C,mBAAmB,EAAE,GAAG,EAAE,sBAAsB,IAAI,IAAI;SACzD,CAAC;IACJ,CAAC;IAED,eAAe,CAAC,aAAqB,EAAE,mBAA2B;QAChE,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;8BAIsB,CACvB;aACA,GAAG,CAAC,aAAa,EAAE,mBAAmB,CAAC,CAAC;IAC7C,CAAC;CACF"}
@@ -0,0 +1,8 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { CommitRuleProfile } from "../../modules/git/types.js";
3
+ export declare class CommitRuleProfileRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ findByWorkspaceId(workspaceId: string): CommitRuleProfile | null;
7
+ upsert(record: CommitRuleProfile): void;
8
+ }
@@ -0,0 +1,48 @@
1
+ export class CommitRuleProfileRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ findByWorkspaceId(workspaceId) {
7
+ const row = this.db
8
+ .prepare(`SELECT id, workspace_id, name, subject_pattern, max_subject_length, language,
9
+ require_body, require_issue, issue_pattern, updated_at
10
+ FROM commit_rule_profiles
11
+ WHERE workspace_id = ?`)
12
+ .get(workspaceId);
13
+ return row ? mapRow(row) : null;
14
+ }
15
+ upsert(record) {
16
+ this.db
17
+ .prepare(`INSERT INTO commit_rule_profiles (
18
+ id, workspace_id, name, subject_pattern, max_subject_length, language,
19
+ require_body, require_issue, issue_pattern, updated_at
20
+ )
21
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
22
+ ON CONFLICT(workspace_id) DO UPDATE SET
23
+ name = excluded.name,
24
+ subject_pattern = excluded.subject_pattern,
25
+ max_subject_length = excluded.max_subject_length,
26
+ language = excluded.language,
27
+ require_body = excluded.require_body,
28
+ require_issue = excluded.require_issue,
29
+ issue_pattern = excluded.issue_pattern,
30
+ updated_at = excluded.updated_at`)
31
+ .run(record.id, record.workspaceId, record.name, record.subjectPattern, record.maxSubjectLength, record.language, record.requireBody ? 1 : 0, record.requireIssue ? 1 : 0, record.issuePattern, record.updatedAt);
32
+ }
33
+ }
34
+ function mapRow(row) {
35
+ return {
36
+ id: row.id,
37
+ workspaceId: row.workspace_id,
38
+ name: row.name,
39
+ subjectPattern: row.subject_pattern,
40
+ maxSubjectLength: row.max_subject_length,
41
+ language: row.language,
42
+ requireBody: row.require_body === 1,
43
+ requireIssue: row.require_issue === 1,
44
+ issuePattern: row.issue_pattern,
45
+ updatedAt: row.updated_at
46
+ };
47
+ }
48
+ //# sourceMappingURL=commit-rule-profile-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commit-rule-profile-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/commit-rule-profile-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,iBAAiB,CAAC,WAAmB;QACnC,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;gCAGwB,CACzB;aACA,GAAG,CAAC,WAAW,CAAqC,CAAC;QAExD,OAAO,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,MAAyB;QAC9B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;4CAaoC,CACrC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,cAAc,EACrB,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAC1B,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAC3B,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;CACF;AAeD,SAAS,MAAM,CAAC,GAAyB;IACvC,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,cAAc,EAAE,GAAG,CAAC,eAAe;QACnC,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,WAAW,EAAE,GAAG,CAAC,YAAY,KAAK,CAAC;QACnC,YAAY,EAAE,GAAG,CAAC,aAAa,KAAK,CAAC;QACrC,YAAY,EAAE,GAAG,CAAC,aAAa;QAC/B,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,12 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { FileContextBinding } from "../../types/domain.js";
3
+ export declare class FileContextBindingRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: FileContextBinding): FileContextBinding;
7
+ listBySession(sessionId: string): FileContextBinding[];
8
+ findById(bindingId: string): FileContextBinding | null;
9
+ delete(bindingId: string): void;
10
+ renamePath(workspaceId: string, oldPath: string, newPath: string): void;
11
+ deleteByPath(workspaceId: string, targetPath: string): void;
12
+ }
@@ -0,0 +1,130 @@
1
+ export class FileContextBindingRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO session_file_context_bindings (
9
+ id,
10
+ session_id,
11
+ workspace_id,
12
+ path,
13
+ display_name,
14
+ selected,
15
+ pinned,
16
+ range_start,
17
+ range_end,
18
+ content_hash,
19
+ file_version,
20
+ attached_by,
21
+ attached_at
22
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
23
+ .run(record.id, record.sessionId, record.workspaceId, record.path, record.displayName, record.selected ? 1 : 0, record.pinned ? 1 : 0, record.rangeStart, record.rangeEnd, record.contentHash, record.fileVersion, record.attachedBy, record.attachedAt);
24
+ return record;
25
+ }
26
+ listBySession(sessionId) {
27
+ return this.db
28
+ .prepare(`SELECT
29
+ id,
30
+ session_id,
31
+ workspace_id,
32
+ path,
33
+ display_name,
34
+ selected,
35
+ pinned,
36
+ range_start,
37
+ range_end,
38
+ content_hash,
39
+ file_version,
40
+ attached_by,
41
+ attached_at
42
+ FROM session_file_context_bindings
43
+ WHERE session_id = ?
44
+ ORDER BY pinned DESC, attached_at DESC`)
45
+ .all(sessionId)
46
+ .map((row) => mapFileContextBindingRow(row));
47
+ }
48
+ findById(bindingId) {
49
+ const row = this.db
50
+ .prepare(`SELECT
51
+ id,
52
+ session_id,
53
+ workspace_id,
54
+ path,
55
+ display_name,
56
+ selected,
57
+ pinned,
58
+ range_start,
59
+ range_end,
60
+ content_hash,
61
+ file_version,
62
+ attached_by,
63
+ attached_at
64
+ FROM session_file_context_bindings
65
+ WHERE id = ?`)
66
+ .get(bindingId);
67
+ return row ? mapFileContextBindingRow(row) : null;
68
+ }
69
+ delete(bindingId) {
70
+ this.db
71
+ .prepare(`DELETE FROM session_file_context_bindings
72
+ WHERE id = ?`)
73
+ .run(bindingId);
74
+ }
75
+ renamePath(workspaceId, oldPath, newPath) {
76
+ const rows = this.db
77
+ .prepare(`SELECT
78
+ id,
79
+ session_id,
80
+ workspace_id,
81
+ path,
82
+ display_name,
83
+ selected,
84
+ pinned,
85
+ range_start,
86
+ range_end,
87
+ content_hash,
88
+ file_version,
89
+ attached_by,
90
+ attached_at
91
+ FROM session_file_context_bindings
92
+ WHERE workspace_id = ?
93
+ AND (path = ? OR path LIKE ?)`)
94
+ .all(workspaceId, oldPath, `${oldPath}/%`);
95
+ for (const row of rows) {
96
+ const nextPath = row.path === oldPath ? newPath : `${newPath}${row.path.slice(oldPath.length)}`;
97
+ const nextDisplayName = nextPath.split("/").pop() || nextPath;
98
+ this.db
99
+ .prepare(`UPDATE session_file_context_bindings
100
+ SET path = ?, display_name = ?
101
+ WHERE id = ?`)
102
+ .run(nextPath, nextDisplayName, row.id);
103
+ }
104
+ }
105
+ deleteByPath(workspaceId, targetPath) {
106
+ this.db
107
+ .prepare(`DELETE FROM session_file_context_bindings
108
+ WHERE workspace_id = ?
109
+ AND (path = ? OR path LIKE ?)`)
110
+ .run(workspaceId, targetPath, `${targetPath}/%`);
111
+ }
112
+ }
113
+ function mapFileContextBindingRow(row) {
114
+ return {
115
+ id: row.id,
116
+ sessionId: row.session_id,
117
+ workspaceId: row.workspace_id,
118
+ path: row.path,
119
+ displayName: row.display_name,
120
+ selected: row.selected === 1,
121
+ pinned: row.pinned === 1,
122
+ rangeStart: row.range_start,
123
+ rangeEnd: row.range_end,
124
+ contentHash: row.content_hash,
125
+ fileVersion: row.file_version,
126
+ attachedBy: row.attached_by,
127
+ attachedAt: row.attached_at
128
+ };
129
+ }
130
+ //# sourceMappingURL=file-context-binding-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-context-binding-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/file-context-binding-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,4BAA4B;IACV;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA0B;QAC/B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;0DAckD,CACnD;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACvB,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACrB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,UAAU,CAClB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,aAAa,CAAC,SAAiB;QAC7B,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;;;;;gDAgBwC,CACzC;aACA,GAAG,CAAC,SAAS,CAAC;aACd,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,wBAAwB,CAAC,GAA4B,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED,QAAQ,CAAC,SAAiB;QACxB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;;;;sBAec,CACf;aACA,GAAG,CAAC,SAAS,CAAsC,CAAC;QAEvD,OAAO,GAAG,CAAC,CAAC,CAAC,wBAAwB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACpD,CAAC;IAED,MAAM,CAAC,SAAiB;QACtB,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;sBACc,CACf;aACA,GAAG,CAAC,SAAS,CAAC,CAAC;IACpB,CAAC;IAED,UAAU,CAAC,WAAmB,EAAE,OAAe,EAAE,OAAe;QAC9D,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE;aACjB,OAAO,CACN;;;;;;;;;;;;;;;;yCAgBiC,CAClC;aACA,GAAG,CAAC,WAAW,EAAE,OAAO,EAAE,GAAG,OAAO,IAAI,CAA4B,CAAC;QAExE,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAChG,MAAM,eAAe,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,IAAI,QAAQ,CAAC;YAE9D,IAAI,CAAC,EAAE;iBACJ,OAAO,CACN;;wBAEc,CACf;iBACA,GAAG,CAAC,QAAQ,EAAE,eAAe,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IAED,YAAY,CAAC,WAAmB,EAAE,UAAkB;QAClD,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;yCAEiC,CAClC;aACA,GAAG,CAAC,WAAW,EAAE,UAAU,EAAE,GAAG,UAAU,IAAI,CAAC,CAAC;IACrD,CAAC;CACF;AAkBD,SAAS,wBAAwB,CAAC,GAA0B;IAC1D,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,QAAQ,EAAE,GAAG,CAAC,QAAQ,KAAK,CAAC;QAC5B,MAAM,EAAE,GAAG,CAAC,MAAM,KAAK,CAAC;QACxB,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,UAAU,EAAE,GAAG,CAAC,WAAW;KAC5B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { RecentFileRecord } from "../../types/domain.js";
3
+ export declare class RecentFileRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ upsert(record: RecentFileRecord): void;
7
+ listByWorkspaceAndUser(workspaceId: string, userId: string, limit: number): RecentFileRecord[];
8
+ renamePath(workspaceId: string, oldPath: string, newPath: string): void;
9
+ deleteByPath(workspaceId: string, targetPath: string): void;
10
+ }
@@ -0,0 +1,64 @@
1
+ export class RecentFileRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ upsert(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO recent_files (
9
+ id,
10
+ workspace_id,
11
+ user_id,
12
+ path,
13
+ last_opened_at,
14
+ pinned
15
+ ) VALUES (?, ?, ?, ?, ?, ?)
16
+ ON CONFLICT(workspace_id, user_id, path) DO UPDATE SET
17
+ last_opened_at = excluded.last_opened_at`)
18
+ .run(record.id, record.workspaceId, record.userId, record.path, record.lastOpenedAt, record.pinned ? 1 : 0);
19
+ }
20
+ listByWorkspaceAndUser(workspaceId, userId, limit) {
21
+ return this.db
22
+ .prepare(`SELECT id, workspace_id, user_id, path, last_opened_at, pinned
23
+ FROM recent_files
24
+ WHERE workspace_id = ? AND user_id = ?
25
+ ORDER BY pinned DESC, last_opened_at DESC
26
+ LIMIT ?`)
27
+ .all(workspaceId, userId, limit)
28
+ .map((row) => mapRecentFileRow(row));
29
+ }
30
+ renamePath(workspaceId, oldPath, newPath) {
31
+ const rows = this.db
32
+ .prepare(`SELECT id, workspace_id, user_id, path, last_opened_at, pinned
33
+ FROM recent_files
34
+ WHERE workspace_id = ?
35
+ AND (path = ? OR path LIKE ?)`)
36
+ .all(workspaceId, oldPath, `${oldPath}/%`);
37
+ for (const row of rows) {
38
+ const nextPath = row.path === oldPath ? newPath : `${newPath}${row.path.slice(oldPath.length)}`;
39
+ this.db
40
+ .prepare(`UPDATE recent_files
41
+ SET path = ?
42
+ WHERE id = ?`)
43
+ .run(nextPath, row.id);
44
+ }
45
+ }
46
+ deleteByPath(workspaceId, targetPath) {
47
+ this.db
48
+ .prepare(`DELETE FROM recent_files
49
+ WHERE workspace_id = ?
50
+ AND (path = ? OR path LIKE ?)`)
51
+ .run(workspaceId, targetPath, `${targetPath}/%`);
52
+ }
53
+ }
54
+ function mapRecentFileRow(row) {
55
+ return {
56
+ id: row.id,
57
+ workspaceId: row.workspace_id,
58
+ userId: row.user_id,
59
+ path: row.path,
60
+ lastOpenedAt: row.last_opened_at,
61
+ pinned: row.pinned === 1
62
+ };
63
+ }
64
+ //# sourceMappingURL=recent-file-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"recent-file-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/recent-file-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,oBAAoB;IACF;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAAwB;QAC7B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;oDAS4C,CAC7C;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CACtB,CAAC;IACN,CAAC;IAED,sBAAsB,CAAC,WAAmB,EAAE,MAAc,EAAE,KAAa;QACvE,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;iBAIS,CACV;aACA,GAAG,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,CAAC;aAC/B,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,gBAAgB,CAAC,GAAoB,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,UAAU,CAAC,WAAmB,EAAE,OAAe,EAAE,OAAe;QAC9D,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE;aACjB,OAAO,CACN;;;yCAGiC,CAClC;aACA,GAAG,CAAC,WAAW,EAAE,OAAO,EAAE,GAAG,OAAO,IAAI,CAAoB,CAAC;QAEhE,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAEhG,IAAI,CAAC,EAAE;iBACJ,OAAO,CACN;;wBAEc,CACf;iBACA,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,YAAY,CAAC,WAAmB,EAAE,UAAkB;QAClD,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;yCAEiC,CAClC;aACA,GAAG,CAAC,WAAW,EAAE,UAAU,EAAE,GAAG,UAAU,IAAI,CAAC,CAAC;IACrD,CAAC;CACF;AAWD,SAAS,gBAAgB,CAAC,GAAkB;IAC1C,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,MAAM,EAAE,GAAG,CAAC,OAAO;QACnB,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,YAAY,EAAE,GAAG,CAAC,cAAc;QAChC,MAAM,EAAE,GAAG,CAAC,MAAM,KAAK,CAAC;KACzB,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SessionBinding } from "../../types/domain.js";
3
+ export declare class SessionBindingRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ findBySessionId(sessionId: string): SessionBinding | null;
7
+ findByProviderSession(provider: string, providerSessionId: string): SessionBinding | null;
8
+ findByRawStoreRef(provider: string, rawStoreRef: string): SessionBinding | null;
9
+ upsert(record: SessionBinding): void;
10
+ }
@@ -0,0 +1,63 @@
1
+ export class SessionBindingRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ findBySessionId(sessionId) {
7
+ const row = this.db
8
+ .prepare(`SELECT session_id, workspace_id, provider, provider_session_id, raw_store_ref, created_at, updated_at
9
+ FROM session_bindings
10
+ WHERE session_id = ?`)
11
+ .get(sessionId);
12
+ return row ? mapSessionBindingRow(row) : null;
13
+ }
14
+ findByProviderSession(provider, providerSessionId) {
15
+ const row = this.db
16
+ .prepare(`SELECT session_id, workspace_id, provider, provider_session_id, raw_store_ref, created_at, updated_at
17
+ FROM session_bindings
18
+ WHERE provider = ?
19
+ AND provider_session_id = ?`)
20
+ .get(provider, providerSessionId);
21
+ return row ? mapSessionBindingRow(row) : null;
22
+ }
23
+ findByRawStoreRef(provider, rawStoreRef) {
24
+ const row = this.db
25
+ .prepare(`SELECT session_id, workspace_id, provider, provider_session_id, raw_store_ref, created_at, updated_at
26
+ FROM session_bindings
27
+ WHERE provider = ?
28
+ AND raw_store_ref = ?`)
29
+ .get(provider, rawStoreRef);
30
+ return row ? mapSessionBindingRow(row) : null;
31
+ }
32
+ upsert(record) {
33
+ this.db
34
+ .prepare(`INSERT INTO session_bindings (
35
+ session_id,
36
+ workspace_id,
37
+ provider,
38
+ provider_session_id,
39
+ raw_store_ref,
40
+ created_at,
41
+ updated_at
42
+ ) VALUES (?, ?, ?, ?, ?, ?, ?)
43
+ ON CONFLICT(session_id) DO UPDATE SET
44
+ workspace_id = excluded.workspace_id,
45
+ provider = excluded.provider,
46
+ provider_session_id = excluded.provider_session_id,
47
+ raw_store_ref = excluded.raw_store_ref,
48
+ updated_at = excluded.updated_at`)
49
+ .run(record.sessionId, record.workspaceId, record.provider, record.providerSessionId, record.rawStoreRef, record.createdAt, record.updatedAt);
50
+ }
51
+ }
52
+ function mapSessionBindingRow(row) {
53
+ return {
54
+ sessionId: row.session_id,
55
+ workspaceId: row.workspace_id,
56
+ provider: row.provider,
57
+ providerSessionId: row.provider_session_id,
58
+ rawStoreRef: row.raw_store_ref,
59
+ createdAt: row.created_at,
60
+ updatedAt: row.updated_at
61
+ };
62
+ }
63
+ //# sourceMappingURL=session-binding-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-binding-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/session-binding-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,wBAAwB;IACN;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,eAAe,CAAC,SAAiB;QAC/B,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;8BAEsB,CACvB;aACA,GAAG,CAAC,SAAS,CAAkC,CAAC;QAEnD,OAAO,GAAG,CAAC,CAAC,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAChD,CAAC;IAED,qBAAqB,CAAC,QAAgB,EAAE,iBAAyB;QAC/D,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;uCAG+B,CAChC;aACA,GAAG,CAAC,QAAQ,EAAE,iBAAiB,CAAkC,CAAC;QAErE,OAAO,GAAG,CAAC,CAAC,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAChD,CAAC;IAED,iBAAiB,CAAC,QAAgB,EAAE,WAAmB;QACrD,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;iCAGyB,CAC1B;aACA,GAAG,CAAC,QAAQ,EAAE,WAAW,CAAkC,CAAC;QAE/D,OAAO,GAAG,CAAC,CAAC,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAChD,CAAC;IAED,MAAM,CAAC,MAAsB;QAC3B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;4CAcoC,CACrC;aACA,GAAG,CACF,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;CACF;AAYD,SAAS,oBAAoB,CAAC,GAAsB;IAClD,OAAO;QACL,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,iBAAiB,EAAE,GAAG,CAAC,mBAAmB;QAC1C,WAAW,EAAE,GAAG,CAAC,aAAa;QAC9B,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 { SessionChangedFileIndexState, SessionChangedFileRecord } from "../../types/domain.js";
3
+ export declare class SessionChangedFileRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ upsertMany(records: SessionChangedFileRecord[]): void;
7
+ listBySessionId(sessionId: string): SessionChangedFileRecord[];
8
+ findIndexStateBySessionId(sessionId: string): SessionChangedFileIndexState | null;
9
+ upsertIndexState(record: SessionChangedFileIndexState): void;
10
+ deleteBySessionId(sessionId: string): void;
11
+ }