@jingyi0605/codingns 0.2.5 → 0.3.5

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 (227) hide show
  1. package/bin/codingns.mjs +278 -2
  2. package/dist/public/assets/{TerminalPage-BkjqU9NG.js → TerminalPage-CgrfstRm.js} +19 -19
  3. package/dist/public/assets/index-Cek6u0b9.css +1 -0
  4. package/dist/public/assets/index-THHY79si.js +122 -0
  5. package/dist/public/index.html +2 -2
  6. package/dist/server/config/env.d.ts +4 -0
  7. package/dist/server/config/env.js +67 -3
  8. package/dist/server/config/env.js.map +1 -1
  9. package/dist/server/modules/auth/auth-service.d.ts +18 -1
  10. package/dist/server/modules/auth/auth-service.js +168 -7
  11. package/dist/server/modules/auth/auth-service.js.map +1 -1
  12. package/dist/server/modules/butler/butler-codex-model-policy.d.ts +1 -0
  13. package/dist/server/modules/butler/butler-codex-model-policy.js +36 -0
  14. package/dist/server/modules/butler/butler-codex-model-policy.js.map +1 -0
  15. package/dist/server/modules/butler/butler-control-session-service.d.ts +16 -2
  16. package/dist/server/modules/butler/butler-control-session-service.js +58 -210
  17. package/dist/server/modules/butler/butler-control-session-service.js.map +1 -1
  18. package/dist/server/modules/butler/butler-controller.d.ts +17 -0
  19. package/dist/server/modules/butler/butler-controller.js +20 -1
  20. package/dist/server/modules/butler/butler-controller.js.map +1 -1
  21. package/dist/server/modules/butler/butler-follow-up-service.js +7 -3
  22. package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -1
  23. package/dist/server/modules/butler/butler-inbox-analysis-service.d.ts +36 -0
  24. package/dist/server/modules/butler/butler-inbox-analysis-service.js +375 -0
  25. package/dist/server/modules/butler/butler-inbox-analysis-service.js.map +1 -0
  26. package/dist/server/modules/butler/butler-inbox-instruction-adapter.d.ts +23 -0
  27. package/dist/server/modules/butler/butler-inbox-instruction-adapter.js +96 -0
  28. package/dist/server/modules/butler/butler-inbox-instruction-adapter.js.map +1 -0
  29. package/dist/server/modules/butler/butler-inbox-service.d.ts +39 -2
  30. package/dist/server/modules/butler/butler-inbox-service.js +392 -2
  31. package/dist/server/modules/butler/butler-inbox-service.js.map +1 -1
  32. package/dist/server/modules/butler/butler-session-service.d.ts +9 -0
  33. package/dist/server/modules/butler/butler-session-service.js +277 -68
  34. package/dist/server/modules/butler/butler-session-service.js.map +1 -1
  35. package/dist/server/modules/butler/butler-session-summary-service.d.ts +1 -0
  36. package/dist/server/modules/butler/butler-session-summary-service.js +48 -23
  37. package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -1
  38. package/dist/server/modules/butler/butler-workspace-context.d.ts +13 -0
  39. package/dist/server/modules/butler/butler-workspace-context.js +223 -0
  40. package/dist/server/modules/butler/butler-workspace-context.js.map +1 -0
  41. package/dist/server/modules/client/client-controller.d.ts +6 -0
  42. package/dist/server/modules/client/client-controller.js +30 -8
  43. package/dist/server/modules/client/client-controller.js.map +1 -1
  44. package/dist/server/modules/client/client-service.d.ts +22 -10
  45. package/dist/server/modules/client/client-service.js +77 -100
  46. package/dist/server/modules/client/client-service.js.map +1 -1
  47. package/dist/server/modules/client/npm-global-package-service.d.ts +21 -0
  48. package/dist/server/modules/client/npm-global-package-service.js +210 -0
  49. package/dist/server/modules/client/npm-global-package-service.js.map +1 -0
  50. package/dist/server/modules/client/service-update-task-service.d.ts +15 -0
  51. package/dist/server/modules/client/service-update-task-service.js +147 -0
  52. package/dist/server/modules/client/service-update-task-service.js.map +1 -0
  53. package/dist/server/modules/client/service-update-types.d.ts +30 -0
  54. package/dist/server/modules/client/service-update-types.js +2 -0
  55. package/dist/server/modules/client/service-update-types.js.map +1 -0
  56. package/dist/server/modules/debug-target/debug-target-service.d.ts +5 -2
  57. package/dist/server/modules/debug-target/debug-target-service.js +170 -10
  58. package/dist/server/modules/debug-target/debug-target-service.js.map +1 -1
  59. package/dist/server/modules/file/file-constants.d.ts +1 -0
  60. package/dist/server/modules/file/file-constants.js +1 -0
  61. package/dist/server/modules/file/file-constants.js.map +1 -1
  62. package/dist/server/modules/file/file-controller.js +12 -3
  63. package/dist/server/modules/file/file-controller.js.map +1 -1
  64. package/dist/server/modules/file/file-preview-link-service.js +6 -37
  65. package/dist/server/modules/file/file-preview-link-service.js.map +1 -1
  66. package/dist/server/modules/file/file-preview-service.d.ts +6 -12
  67. package/dist/server/modules/file/file-preview-service.js +114 -28
  68. package/dist/server/modules/file/file-preview-service.js.map +1 -1
  69. package/dist/server/modules/file/file-preview-types.d.ts +37 -0
  70. package/dist/server/modules/file/file-preview-types.js +84 -0
  71. package/dist/server/modules/file/file-preview-types.js.map +1 -0
  72. package/dist/server/modules/git/git-controller.d.ts +6 -0
  73. package/dist/server/modules/git/git-controller.js +13 -0
  74. package/dist/server/modules/git/git-controller.js.map +1 -1
  75. package/dist/server/modules/git/git-read-service.d.ts +2 -1
  76. package/dist/server/modules/git/git-read-service.js +100 -0
  77. package/dist/server/modules/git/git-read-service.js.map +1 -1
  78. package/dist/server/modules/git/types.d.ts +23 -0
  79. package/dist/server/modules/model-switch/cc-switch-adapter.d.ts +36 -0
  80. package/dist/server/modules/model-switch/cc-switch-adapter.js +317 -0
  81. package/dist/server/modules/model-switch/cc-switch-adapter.js.map +1 -0
  82. package/dist/server/modules/model-switch/model-switch-controller.d.ts +11 -0
  83. package/dist/server/modules/model-switch/model-switch-controller.js +30 -0
  84. package/dist/server/modules/model-switch/model-switch-controller.js.map +1 -0
  85. package/dist/server/modules/model-switch/model-switch-service.d.ts +16 -0
  86. package/dist/server/modules/model-switch/model-switch-service.js +29 -0
  87. package/dist/server/modules/model-switch/model-switch-service.js.map +1 -0
  88. package/dist/server/modules/preferences/profile-service.d.ts +1 -0
  89. package/dist/server/modules/preferences/profile-service.js +9 -0
  90. package/dist/server/modules/preferences/profile-service.js.map +1 -1
  91. package/dist/server/modules/sessions/codex-app-server-helper-process.js +3 -0
  92. package/dist/server/modules/sessions/codex-app-server-helper-process.js.map +1 -1
  93. package/dist/server/modules/sessions/session-activity-authority-service.d.ts +3 -1
  94. package/dist/server/modules/sessions/session-activity-authority-service.js +16 -1
  95. package/dist/server/modules/sessions/session-activity-authority-service.js.map +1 -1
  96. package/dist/server/modules/sessions/session-activity-inspector.d.ts +1 -1
  97. package/dist/server/modules/sessions/session-activity-inspector.js +52 -9
  98. package/dist/server/modules/sessions/session-activity-inspector.js.map +1 -1
  99. package/dist/server/modules/sessions/session-controller.d.ts +3 -3
  100. package/dist/server/modules/sessions/session-controller.js +3 -3
  101. package/dist/server/modules/sessions/session-controller.js.map +1 -1
  102. package/dist/server/modules/sessions/session-history-service.d.ts +11 -2
  103. package/dist/server/modules/sessions/session-history-service.js +373 -78
  104. package/dist/server/modules/sessions/session-history-service.js.map +1 -1
  105. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +9 -4
  106. package/dist/server/modules/sessions/session-live-runtime-service.js +59 -11
  107. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
  108. package/dist/server/modules/sessions/session-message-attachment-service.d.ts +8 -8
  109. package/dist/server/modules/sessions/session-message-attachment-service.js +25 -34
  110. package/dist/server/modules/sessions/session-message-attachment-service.js.map +1 -1
  111. package/dist/server/modules/sessions/session-provider-error-mapper.js +7 -0
  112. package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -1
  113. package/dist/server/modules/skills/skill-controller.d.ts +23 -0
  114. package/dist/server/modules/skills/skill-controller.js +35 -0
  115. package/dist/server/modules/skills/skill-controller.js.map +1 -0
  116. package/dist/server/modules/skills/skill-manager-service.d.ts +86 -0
  117. package/dist/server/modules/skills/skill-manager-service.js +557 -0
  118. package/dist/server/modules/skills/skill-manager-service.js.map +1 -0
  119. package/dist/server/modules/skills/skill-reconciler.d.ts +21 -0
  120. package/dist/server/modules/skills/skill-reconciler.js +99 -0
  121. package/dist/server/modules/skills/skill-reconciler.js.map +1 -0
  122. package/dist/server/modules/skills/skill-sync-planner.d.ts +8 -0
  123. package/dist/server/modules/skills/skill-sync-planner.js +20 -0
  124. package/dist/server/modules/skills/skill-sync-planner.js.map +1 -0
  125. package/dist/server/modules/skills/skill-target-adapter.d.ts +34 -0
  126. package/dist/server/modules/skills/skill-target-adapter.js +65 -0
  127. package/dist/server/modules/skills/skill-target-adapter.js.map +1 -0
  128. package/dist/server/modules/tailscale/tailscale-controller.d.ts +15 -0
  129. package/dist/server/modules/tailscale/tailscale-controller.js +33 -0
  130. package/dist/server/modules/tailscale/tailscale-controller.js.map +1 -0
  131. package/dist/server/modules/tailscale/tailscale-helper-client.d.ts +41 -0
  132. package/dist/server/modules/tailscale/tailscale-helper-client.js +135 -0
  133. package/dist/server/modules/tailscale/tailscale-helper-client.js.map +1 -0
  134. package/dist/server/modules/tailscale/tailscale-helper-process.d.ts +1 -0
  135. package/dist/server/modules/tailscale/tailscale-helper-process.js +327 -0
  136. package/dist/server/modules/tailscale/tailscale-helper-process.js.map +1 -0
  137. package/dist/server/modules/tailscale/tailscale-manager.d.ts +41 -0
  138. package/dist/server/modules/tailscale/tailscale-manager.js +263 -0
  139. package/dist/server/modules/tailscale/tailscale-manager.js.map +1 -0
  140. package/dist/server/modules/tailscale/tailscale-service.d.ts +43 -0
  141. package/dist/server/modules/tailscale/tailscale-service.js +201 -0
  142. package/dist/server/modules/tailscale/tailscale-service.js.map +1 -0
  143. package/dist/server/modules/tasks/task-lane-executors.js +3 -0
  144. package/dist/server/modules/tasks/task-lane-executors.js.map +1 -1
  145. package/dist/server/modules/tasks/task-types.d.ts +2 -0
  146. package/dist/server/modules/tasks/task-types.js +3 -1
  147. package/dist/server/modules/tasks/task-types.js.map +1 -1
  148. package/dist/server/modules/terminal/command-template-service.js +10 -1
  149. package/dist/server/modules/terminal/command-template-service.js.map +1 -1
  150. package/dist/server/modules/terminal/template-port-runtime.d.ts +12 -1
  151. package/dist/server/modules/terminal/template-port-runtime.js +189 -17
  152. package/dist/server/modules/terminal/template-port-runtime.js.map +1 -1
  153. package/dist/server/modules/terminal/terminal-service.js +30 -3
  154. package/dist/server/modules/terminal/terminal-service.js.map +1 -1
  155. package/dist/server/modules/workspace/workspace-code-composition.js +95 -2
  156. package/dist/server/modules/workspace/workspace-code-composition.js.map +1 -1
  157. package/dist/server/routes/butler.js +4 -0
  158. package/dist/server/routes/butler.js.map +1 -1
  159. package/dist/server/routes/client.js +2 -0
  160. package/dist/server/routes/client.js.map +1 -1
  161. package/dist/server/routes/git.js +1 -0
  162. package/dist/server/routes/git.js.map +1 -1
  163. package/dist/server/routes/sessions.js +1 -1
  164. package/dist/server/routes/sessions.js.map +1 -1
  165. package/dist/server/routes/skills.d.ts +3 -0
  166. package/dist/server/routes/skills.js +7 -0
  167. package/dist/server/routes/skills.js.map +1 -0
  168. package/dist/server/routes/system.d.ts +4 -0
  169. package/dist/server/routes/system.js +11 -0
  170. package/dist/server/routes/system.js.map +1 -0
  171. package/dist/server/server/create-server.d.ts +16 -0
  172. package/dist/server/server/create-server.js +91 -8
  173. package/dist/server/server/create-server.js.map +1 -1
  174. package/dist/server/shared/errors/app-error.d.ts +2 -0
  175. package/dist/server/shared/errors/app-error.js +2 -0
  176. package/dist/server/shared/errors/app-error.js.map +1 -1
  177. package/dist/server/shared/http/error-handler.d.ts +2 -1
  178. package/dist/server/shared/http/error-handler.js +3 -2
  179. package/dist/server/shared/http/error-handler.js.map +1 -1
  180. package/dist/server/shared/utils/command-availability.d.ts +1 -0
  181. package/dist/server/shared/utils/command-availability.js +26 -3
  182. package/dist/server/shared/utils/command-availability.js.map +1 -1
  183. package/dist/server/storage/repositories/auth-login-attempt-repository.d.ts +9 -0
  184. package/dist/server/storage/repositories/auth-login-attempt-repository.js +59 -0
  185. package/dist/server/storage/repositories/auth-login-attempt-repository.js.map +1 -0
  186. package/dist/server/storage/repositories/butler-control-session-repository.d.ts +3 -0
  187. package/dist/server/storage/repositories/butler-control-session-repository.js +80 -4
  188. package/dist/server/storage/repositories/butler-control-session-repository.js.map +1 -1
  189. package/dist/server/storage/repositories/butler-inbox-item-repository.js +54 -3
  190. package/dist/server/storage/repositories/butler-inbox-item-repository.js.map +1 -1
  191. package/dist/server/storage/repositories/instance-tailscale-repository.d.ts +10 -0
  192. package/dist/server/storage/repositories/instance-tailscale-repository.js +112 -0
  193. package/dist/server/storage/repositories/instance-tailscale-repository.js.map +1 -0
  194. package/dist/server/storage/repositories/managed-skill-repository.d.ts +11 -0
  195. package/dist/server/storage/repositories/managed-skill-repository.js +102 -0
  196. package/dist/server/storage/repositories/managed-skill-repository.js.map +1 -0
  197. package/dist/server/storage/repositories/skill-target-binding-repository.d.ts +10 -0
  198. package/dist/server/storage/repositories/skill-target-binding-repository.js +77 -0
  199. package/dist/server/storage/repositories/skill-target-binding-repository.js.map +1 -0
  200. package/dist/server/storage/repositories/terminal-instance-repository.js +1 -1
  201. package/dist/server/storage/repositories/terminal-instance-repository.js.map +1 -1
  202. package/dist/server/storage/repositories/user-preference-profile-repository.js +6 -3
  203. package/dist/server/storage/repositories/user-preference-profile-repository.js.map +1 -1
  204. package/dist/server/storage/sqlite/client.js +137 -0
  205. package/dist/server/storage/sqlite/client.js.map +1 -1
  206. package/dist/server/storage/sqlite/schema.sql +84 -1
  207. package/dist/server/types/domain.d.ts +109 -1
  208. package/dist/server/ws/ws-server.js +4 -4
  209. package/dist/server/ws/ws-server.js.map +1 -1
  210. package/node_modules/@codingns/session-sync-core/dist/patch-builder.d.ts +23 -0
  211. package/node_modules/@codingns/session-sync-core/dist/patch-builder.js +162 -0
  212. package/node_modules/@codingns/session-sync-core/dist/patch-builder.js.map +1 -1
  213. package/node_modules/@codingns/session-sync-core/dist/providers/codex.d.ts +1 -0
  214. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +89 -33
  215. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
  216. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js +18 -2
  217. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js.map +1 -1
  218. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +3 -1
  219. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +238 -53
  220. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
  221. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js +1 -0
  222. package/node_modules/@codingns/session-sync-core/dist/runtime/provider-runtime-service.js.map +1 -1
  223. package/node_modules/@codingns/session-sync-core/dist/runtime/types.d.ts +6 -2
  224. package/node_modules/@codingns/session-sync-core/dist/types.d.ts +1 -1
  225. package/package.json +1 -1
  226. package/dist/public/assets/index-C6U8-9jg.css +0 -1
  227. package/dist/public/assets/index-CKSumuV2.js +0 -109
@@ -0,0 +1,59 @@
1
+ export class AuthLoginAttemptRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ findByUsername(username) {
7
+ const row = this.db
8
+ .prepare(`SELECT
9
+ username,
10
+ failed_attempt_count,
11
+ captcha_id,
12
+ captcha_code_hash,
13
+ captcha_expires_at,
14
+ created_at,
15
+ updated_at
16
+ FROM auth_login_attempts
17
+ WHERE username = ?`)
18
+ .get(username);
19
+ return row ? mapAuthLoginAttemptRow(row) : null;
20
+ }
21
+ upsert(record) {
22
+ this.db
23
+ .prepare(`INSERT INTO auth_login_attempts (
24
+ username,
25
+ failed_attempt_count,
26
+ captcha_id,
27
+ captcha_code_hash,
28
+ captcha_expires_at,
29
+ created_at,
30
+ updated_at
31
+ )
32
+ VALUES (?, ?, ?, ?, ?, ?, ?)
33
+ ON CONFLICT(username) DO UPDATE SET
34
+ failed_attempt_count = excluded.failed_attempt_count,
35
+ captcha_id = excluded.captcha_id,
36
+ captcha_code_hash = excluded.captcha_code_hash,
37
+ captcha_expires_at = excluded.captcha_expires_at,
38
+ updated_at = excluded.updated_at`)
39
+ .run(record.username, record.failedAttemptCount, record.captchaId, record.captchaCodeHash, record.captchaExpiresAt, record.createdAt, record.updatedAt);
40
+ }
41
+ deleteByUsername(username) {
42
+ this.db
43
+ .prepare(`DELETE FROM auth_login_attempts
44
+ WHERE username = ?`)
45
+ .run(username);
46
+ }
47
+ }
48
+ function mapAuthLoginAttemptRow(row) {
49
+ return {
50
+ username: row.username,
51
+ failedAttemptCount: row.failed_attempt_count,
52
+ captchaId: row.captcha_id,
53
+ captchaCodeHash: row.captcha_code_hash,
54
+ captchaExpiresAt: row.captcha_expires_at,
55
+ createdAt: row.created_at,
56
+ updatedAt: row.updated_at
57
+ };
58
+ }
59
+ //# sourceMappingURL=auth-login-attempt-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-login-attempt-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-login-attempt-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,0BAA0B;IACR;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,cAAc,CAAC,QAAgB;QAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;4BASoB,CACrB;aACA,GAAG,CAAC,QAAQ,CAAoC,CAAC;QAEpD,OAAO,GAAG,CAAC,CAAC,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAClD,CAAC;IAED,MAAM,CAAC,MAA8B;QACnC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;;4CAeoC,CACrC;aACA,GAAG,CACF,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,kBAAkB,EACzB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;IAED,gBAAgB,CAAC,QAAgB;QAC/B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;4BACoB,CACrB;aACA,GAAG,CAAC,QAAQ,CAAC,CAAC;IACnB,CAAC;CACF;AAYD,SAAS,sBAAsB,CAAC,GAAwB;IACtD,OAAO;QACL,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;QAC5C,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,eAAe,EAAE,GAAG,CAAC,iBAAiB;QACtC,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
@@ -6,6 +6,9 @@ export declare class ButlerControlSessionRepository {
6
6
  create(record: ButlerControlSession): ButlerControlSession;
7
7
  findById(id: string): ButlerControlSession | null;
8
8
  findLatestByProvider(providerId: ButlerControlSession["providerId"]): ButlerControlSession | null;
9
+ findLatestOpenByProvider(providerId: ButlerControlSession["providerId"]): ButlerControlSession | null;
10
+ listByProvider(providerId: ButlerControlSession["providerId"]): ButlerControlSession[];
11
+ findBySessionId(sessionId: string): ButlerControlSession | null;
9
12
  listSessionIds(): string[];
10
13
  update(record: ButlerControlSession): ButlerControlSession;
11
14
  }
@@ -9,13 +9,16 @@ export class ButlerControlSessionRepository {
9
9
  id,
10
10
  provider_id,
11
11
  session_id,
12
+ purpose,
13
+ title,
14
+ source_item_id,
12
15
  status,
13
16
  last_context_version,
14
17
  last_summary,
15
18
  created_at,
16
19
  updated_at
17
- ) VALUES (?, ?, ?, ?, ?, ?, ?, ?)`)
18
- .run(record.id, record.providerId, record.sessionId, record.status, record.lastContextVersion, record.lastSummary, record.createdAt, record.updatedAt);
20
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
21
+ .run(record.id, record.providerId, record.sessionId, record.purpose, record.title, record.sourceItemId, record.status, record.lastContextVersion, record.lastSummary, record.createdAt, record.updatedAt);
19
22
  return record;
20
23
  }
21
24
  findById(id) {
@@ -24,6 +27,9 @@ export class ButlerControlSessionRepository {
24
27
  id,
25
28
  provider_id,
26
29
  session_id,
30
+ purpose,
31
+ title,
32
+ source_item_id,
27
33
  status,
28
34
  last_context_version,
29
35
  last_summary,
@@ -40,6 +46,9 @@ export class ButlerControlSessionRepository {
40
46
  id,
41
47
  provider_id,
42
48
  session_id,
49
+ purpose,
50
+ title,
51
+ source_item_id,
43
52
  status,
44
53
  last_context_version,
45
54
  last_summary,
@@ -52,6 +61,67 @@ export class ButlerControlSessionRepository {
52
61
  .get(providerId);
53
62
  return row ? mapButlerControlSessionRow(row) : null;
54
63
  }
64
+ findLatestOpenByProvider(providerId) {
65
+ const row = this.db
66
+ .prepare(`SELECT
67
+ id,
68
+ provider_id,
69
+ session_id,
70
+ purpose,
71
+ title,
72
+ source_item_id,
73
+ status,
74
+ last_context_version,
75
+ last_summary,
76
+ created_at,
77
+ updated_at
78
+ FROM butler_control_sessions
79
+ WHERE provider_id = ?
80
+ AND status != 'closed'
81
+ ORDER BY updated_at DESC, created_at DESC
82
+ LIMIT 1`)
83
+ .get(providerId);
84
+ return row ? mapButlerControlSessionRow(row) : null;
85
+ }
86
+ listByProvider(providerId) {
87
+ return this.db
88
+ .prepare(`SELECT
89
+ id,
90
+ provider_id,
91
+ session_id,
92
+ purpose,
93
+ title,
94
+ source_item_id,
95
+ status,
96
+ last_context_version,
97
+ last_summary,
98
+ created_at,
99
+ updated_at
100
+ FROM butler_control_sessions
101
+ WHERE provider_id = ?
102
+ ORDER BY updated_at DESC, created_at DESC`)
103
+ .all(providerId)
104
+ .map((row) => mapButlerControlSessionRow(row));
105
+ }
106
+ findBySessionId(sessionId) {
107
+ const row = this.db
108
+ .prepare(`SELECT
109
+ id,
110
+ provider_id,
111
+ session_id,
112
+ purpose,
113
+ title,
114
+ source_item_id,
115
+ status,
116
+ last_context_version,
117
+ last_summary,
118
+ created_at,
119
+ updated_at
120
+ FROM butler_control_sessions
121
+ WHERE session_id = ?`)
122
+ .get(sessionId);
123
+ return row ? mapButlerControlSessionRow(row) : null;
124
+ }
55
125
  listSessionIds() {
56
126
  return this.db
57
127
  .prepare(`SELECT session_id
@@ -62,12 +132,15 @@ export class ButlerControlSessionRepository {
62
132
  update(record) {
63
133
  this.db
64
134
  .prepare(`UPDATE butler_control_sessions
65
- SET status = ?,
135
+ SET purpose = ?,
136
+ title = ?,
137
+ source_item_id = ?,
138
+ status = ?,
66
139
  last_context_version = ?,
67
140
  last_summary = ?,
68
141
  updated_at = ?
69
142
  WHERE id = ?`)
70
- .run(record.status, record.lastContextVersion, record.lastSummary, record.updatedAt, record.id);
143
+ .run(record.purpose, record.title, record.sourceItemId, record.status, record.lastContextVersion, record.lastSummary, record.updatedAt, record.id);
71
144
  return record;
72
145
  }
73
146
  }
@@ -76,6 +149,9 @@ function mapButlerControlSessionRow(row) {
76
149
  id: row.id,
77
150
  providerId: row.provider_id,
78
151
  sessionId: row.session_id,
152
+ purpose: row.purpose,
153
+ title: row.title,
154
+ sourceItemId: row.source_item_id,
79
155
  status: row.status,
80
156
  lastContextVersion: row.last_context_version,
81
157
  lastSummary: row.last_summary,
@@ -1 +1 @@
1
- {"version":3,"file":"butler-control-session-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-control-session-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,8BAA8B;IACZ;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA4B;QACjC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;2CASmC,CACpC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,kBAAkB,EACzB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;sBAUc,CACf;aACA,GAAG,CAAC,EAAE,CAAwC,CAAC;QAElD,OAAO,GAAG,CAAC,CAAC,CAAC,0BAA0B,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACtD,CAAC;IAED,oBAAoB,CAAC,UAA8C;QACjE,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;iBAYS,CACV;aACA,GAAG,CAAC,UAAU,CAAwC,CAAC;QAE1D,OAAO,GAAG,CAAC,CAAC,CAAC,0BAA0B,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACtD,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;sCAC8B,CAC/B;aACA,GAAG,EAAE;aACL,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAE,GAA8B,CAAC,UAAU,CAAC,CAAC,CAAC;IACtE,CAAC;IAED,MAAM,CAAC,MAA4B;QACjC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;sBAKc,CACf;aACA,GAAG,CACF,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,kBAAkB,EACzB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,EAAE,CACV,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAaD,SAAS,0BAA0B,CAAC,GAA4B;IAC9D,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,kBAAkB,EAAE,GAAG,CAAC,oBAAoB;QAC5C,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"butler-control-session-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-control-session-repository.ts"],"names":[],"mappings":"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"}
@@ -13,11 +13,12 @@ export class ButlerInboxItemRepository {
13
13
  content,
14
14
  priority,
15
15
  status,
16
+ assistant_state_json,
16
17
  created_at,
17
18
  updated_at,
18
19
  closed_at
19
- ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
20
- .run(record.id, record.projectId, record.itemType, record.title, record.content, record.priority, record.status, record.createdAt, record.updatedAt, record.closedAt);
20
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
21
+ .run(record.id, record.projectId, record.itemType, record.title, record.content, record.priority, record.status, JSON.stringify(record.assistantState), record.createdAt, record.updatedAt, record.closedAt);
21
22
  return record;
22
23
  }
23
24
  list(filters) {
@@ -45,6 +46,7 @@ export class ButlerInboxItemRepository {
45
46
  content,
46
47
  priority,
47
48
  status,
49
+ assistant_state_json,
48
50
  created_at,
49
51
  updated_at,
50
52
  closed_at
@@ -64,6 +66,7 @@ export class ButlerInboxItemRepository {
64
66
  content,
65
67
  priority,
66
68
  status,
69
+ assistant_state_json,
67
70
  created_at,
68
71
  updated_at,
69
72
  closed_at
@@ -82,10 +85,11 @@ export class ButlerInboxItemRepository {
82
85
  content = ?,
83
86
  priority = ?,
84
87
  status = ?,
88
+ assistant_state_json = ?,
85
89
  updated_at = ?,
86
90
  closed_at = ?
87
91
  WHERE id = ?`)
88
- .run(record.projectId, record.itemType, record.title, record.content, record.priority, record.status, record.updatedAt, record.closedAt, record.id);
92
+ .run(record.projectId, record.itemType, record.title, record.content, record.priority, record.status, JSON.stringify(record.assistantState), record.updatedAt, record.closedAt, record.id);
89
93
  return record;
90
94
  }
91
95
  delete(id) {
@@ -103,9 +107,56 @@ function mapButlerInboxItemRow(row) {
103
107
  content: row.content,
104
108
  priority: row.priority,
105
109
  status: row.status,
110
+ assistantState: parseAssistantState(row.assistant_state_json),
106
111
  createdAt: row.created_at,
107
112
  updatedAt: row.updated_at,
108
113
  closedAt: row.closed_at
109
114
  };
110
115
  }
116
+ function parseAssistantState(value) {
117
+ if (!value?.trim()) {
118
+ return createDefaultAssistantState();
119
+ }
120
+ try {
121
+ const parsed = JSON.parse(value);
122
+ return {
123
+ lifecycleStage: parsed.lifecycleStage ?? "pending",
124
+ analysisSummary: normalizeNullableText(parsed.analysisSummary),
125
+ generatedPrompt: normalizeNullableText(parsed.generatedPrompt),
126
+ analysisControlSessionId: normalizeNullableText(parsed.analysisControlSessionId),
127
+ analysisSessionId: normalizeNullableText(parsed.analysisSessionId),
128
+ linkedButlerSessionId: normalizeNullableText(parsed.linkedButlerSessionId),
129
+ linkedSessionId: normalizeNullableText(parsed.linkedSessionId),
130
+ linkedFollowUpTaskId: normalizeNullableText(parsed.linkedFollowUpTaskId),
131
+ lastError: normalizeNullableText(parsed.lastError),
132
+ lastAnalyzedAt: normalizeNullableText(parsed.lastAnalyzedAt),
133
+ lastSessionCreatedAt: normalizeNullableText(parsed.lastSessionCreatedAt),
134
+ lastFollowUpAt: normalizeNullableText(parsed.lastFollowUpAt)
135
+ };
136
+ }
137
+ catch {
138
+ return createDefaultAssistantState();
139
+ }
140
+ }
141
+ function createDefaultAssistantState() {
142
+ return {
143
+ lifecycleStage: "pending",
144
+ analysisSummary: null,
145
+ generatedPrompt: null,
146
+ analysisControlSessionId: null,
147
+ analysisSessionId: null,
148
+ linkedButlerSessionId: null,
149
+ linkedSessionId: null,
150
+ linkedFollowUpTaskId: null,
151
+ lastError: null,
152
+ lastAnalyzedAt: null,
153
+ lastSessionCreatedAt: null,
154
+ lastFollowUpAt: null
155
+ };
156
+ }
157
+ function normalizeNullableText(value) {
158
+ return typeof value === "string" && value.trim().length > 0
159
+ ? value.trim()
160
+ : null;
161
+ }
111
162
  //# sourceMappingURL=butler-inbox-item-repository.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"butler-inbox-item-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-inbox-item-repository.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"butler-inbox-item-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-inbox-item-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { InstanceTailscaleConfig, InstanceTailscaleStatus } from "../../types/domain.js";
3
+ export declare class InstanceTailscaleRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ findConfig(): InstanceTailscaleConfig | null;
7
+ upsertConfig(config: InstanceTailscaleConfig): InstanceTailscaleConfig;
8
+ findStatus(): InstanceTailscaleStatus | null;
9
+ upsertStatus(status: InstanceTailscaleStatus): InstanceTailscaleStatus;
10
+ }
@@ -0,0 +1,112 @@
1
+ export class InstanceTailscaleRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ findConfig() {
7
+ const row = this.db
8
+ .prepare(`SELECT enabled, control_server_url, hostname, state_dir, updated_at
9
+ FROM instance_tailscale_config
10
+ WHERE id = 'default'`)
11
+ .get();
12
+ return row ? mapConfigRow(row) : null;
13
+ }
14
+ upsertConfig(config) {
15
+ this.db
16
+ .prepare(`INSERT INTO instance_tailscale_config (
17
+ id,
18
+ enabled,
19
+ control_server_url,
20
+ hostname,
21
+ state_dir,
22
+ updated_at
23
+ ) VALUES ('default', ?, ?, ?, ?, ?)
24
+ ON CONFLICT(id) DO UPDATE SET
25
+ enabled = excluded.enabled,
26
+ control_server_url = excluded.control_server_url,
27
+ hostname = excluded.hostname,
28
+ state_dir = excluded.state_dir,
29
+ updated_at = excluded.updated_at`)
30
+ .run(config.enabled ? 1 : 0, config.controlServerUrl, config.hostname, config.stateDir, config.updatedAt);
31
+ return config;
32
+ }
33
+ findStatus() {
34
+ const row = this.db
35
+ .prepare(`SELECT
36
+ phase,
37
+ connected,
38
+ login_url,
39
+ control_server_url,
40
+ hostname,
41
+ account_name,
42
+ tailnet_fqdn,
43
+ tailnet_ipv4,
44
+ tailnet_ipv6,
45
+ reachable_base_url,
46
+ last_error,
47
+ observed_at
48
+ FROM instance_tailscale_status
49
+ WHERE id = 'default'`)
50
+ .get();
51
+ return row ? mapStatusRow(row) : null;
52
+ }
53
+ upsertStatus(status) {
54
+ this.db
55
+ .prepare(`INSERT INTO instance_tailscale_status (
56
+ id,
57
+ phase,
58
+ connected,
59
+ login_url,
60
+ control_server_url,
61
+ hostname,
62
+ account_name,
63
+ tailnet_fqdn,
64
+ tailnet_ipv4,
65
+ tailnet_ipv6,
66
+ reachable_base_url,
67
+ last_error,
68
+ observed_at
69
+ ) VALUES ('default', ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
70
+ ON CONFLICT(id) DO UPDATE SET
71
+ phase = excluded.phase,
72
+ connected = excluded.connected,
73
+ login_url = excluded.login_url,
74
+ control_server_url = excluded.control_server_url,
75
+ hostname = excluded.hostname,
76
+ account_name = excluded.account_name,
77
+ tailnet_fqdn = excluded.tailnet_fqdn,
78
+ tailnet_ipv4 = excluded.tailnet_ipv4,
79
+ tailnet_ipv6 = excluded.tailnet_ipv6,
80
+ reachable_base_url = excluded.reachable_base_url,
81
+ last_error = excluded.last_error,
82
+ observed_at = excluded.observed_at`)
83
+ .run(status.phase, status.connected ? 1 : 0, status.loginUrl, status.controlServerUrl, status.hostname, status.accountName, status.tailnetFqdn, status.tailnetIpv4, status.tailnetIpv6, status.reachableBaseUrl, status.lastError, status.observedAt);
84
+ return status;
85
+ }
86
+ }
87
+ function mapConfigRow(row) {
88
+ return {
89
+ enabled: Boolean(row.enabled),
90
+ controlServerUrl: row.control_server_url,
91
+ hostname: row.hostname,
92
+ stateDir: row.state_dir,
93
+ updatedAt: row.updated_at
94
+ };
95
+ }
96
+ function mapStatusRow(row) {
97
+ return {
98
+ phase: row.phase,
99
+ connected: Boolean(row.connected),
100
+ loginUrl: row.login_url,
101
+ controlServerUrl: row.control_server_url,
102
+ hostname: row.hostname,
103
+ accountName: row.account_name,
104
+ tailnetFqdn: row.tailnet_fqdn,
105
+ tailnetIpv4: row.tailnet_ipv4,
106
+ tailnetIpv6: row.tailnet_ipv6,
107
+ reachableBaseUrl: row.reachable_base_url,
108
+ lastError: row.last_error,
109
+ observedAt: row.observed_at
110
+ };
111
+ }
112
+ //# sourceMappingURL=instance-tailscale-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instance-tailscale-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/instance-tailscale-repository.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,UAAU;QACR,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;8BAEsB,CACvB;aACA,GAAG,EAA4C,CAAC;QAEnD,OAAO,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxC,CAAC;IAED,YAAY,CAAC,MAA+B;QAC1C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;2CAamC,CACpC;aACA,GAAG,CACF,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACtB,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,UAAU;QACR,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;;;8BAcsB,CACvB;aACA,GAAG,EAA4C,CAAC;QAEnD,OAAO,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxC,CAAC;IAED,YAAY,CAAC,MAA+B;QAC1C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;;;;;;;;;;;;;;6CA2BqC,CACtC;aACA,GAAG,CACF,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACxB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,UAAU,CAClB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAyBD,SAAS,YAAY,CAAC,GAA+B;IACnD,OAAO;QACL,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC;QAC7B,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC;AAED,SAAS,YAAY,CAAC,GAA+B;IACnD,OAAO;QACL,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC;QACjC,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,UAAU,EAAE,GAAG,CAAC,WAAW;KAC5B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { ManagedSkillRecord } from "../../types/domain.js";
3
+ export declare class ManagedSkillRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ findById(id: string): ManagedSkillRecord | null;
7
+ findByDirectoryName(directoryName: string): ManagedSkillRecord | null;
8
+ list(): ManagedSkillRecord[];
9
+ upsert(record: ManagedSkillRecord): ManagedSkillRecord;
10
+ delete(id: string): boolean;
11
+ }
@@ -0,0 +1,102 @@
1
+ export class ManagedSkillRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ findById(id) {
7
+ const row = this.db
8
+ .prepare(`SELECT
9
+ id,
10
+ name,
11
+ directory_name,
12
+ source_type,
13
+ source_path,
14
+ content_hash,
15
+ managed_state,
16
+ created_at,
17
+ updated_at
18
+ FROM managed_skills
19
+ WHERE id = ?`)
20
+ .get(id);
21
+ return row ? mapManagedSkillRow(row) : null;
22
+ }
23
+ findByDirectoryName(directoryName) {
24
+ const row = this.db
25
+ .prepare(`SELECT
26
+ id,
27
+ name,
28
+ directory_name,
29
+ source_type,
30
+ source_path,
31
+ content_hash,
32
+ managed_state,
33
+ created_at,
34
+ updated_at
35
+ FROM managed_skills
36
+ WHERE directory_name = ?`)
37
+ .get(directoryName);
38
+ return row ? mapManagedSkillRow(row) : null;
39
+ }
40
+ list() {
41
+ return this.db
42
+ .prepare(`SELECT
43
+ id,
44
+ name,
45
+ directory_name,
46
+ source_type,
47
+ source_path,
48
+ content_hash,
49
+ managed_state,
50
+ created_at,
51
+ updated_at
52
+ FROM managed_skills
53
+ ORDER BY updated_at DESC, created_at DESC, id ASC`)
54
+ .all()
55
+ .map((row) => mapManagedSkillRow(row));
56
+ }
57
+ upsert(record) {
58
+ this.db
59
+ .prepare(`INSERT INTO managed_skills (
60
+ id,
61
+ name,
62
+ directory_name,
63
+ source_type,
64
+ source_path,
65
+ content_hash,
66
+ managed_state,
67
+ created_at,
68
+ updated_at
69
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
70
+ ON CONFLICT(id) DO UPDATE SET
71
+ name = excluded.name,
72
+ directory_name = excluded.directory_name,
73
+ source_type = excluded.source_type,
74
+ source_path = excluded.source_path,
75
+ content_hash = excluded.content_hash,
76
+ managed_state = excluded.managed_state,
77
+ updated_at = excluded.updated_at`)
78
+ .run(record.id, record.name, record.directoryName, record.sourceType, record.sourcePath, record.contentHash, record.managedState, record.createdAt, record.updatedAt);
79
+ return record;
80
+ }
81
+ delete(id) {
82
+ const result = this.db
83
+ .prepare(`DELETE FROM managed_skills
84
+ WHERE id = ?`)
85
+ .run(id);
86
+ return result.changes > 0;
87
+ }
88
+ }
89
+ function mapManagedSkillRow(row) {
90
+ return {
91
+ id: row.id,
92
+ name: row.name,
93
+ directoryName: row.directory_name,
94
+ sourceType: row.source_type,
95
+ sourcePath: row.source_path,
96
+ contentHash: row.content_hash,
97
+ managedState: row.managed_state,
98
+ createdAt: row.created_at,
99
+ updatedAt: row.updated_at
100
+ };
101
+ }
102
+ //# sourceMappingURL=managed-skill-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"managed-skill-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/managed-skill-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,sBAAsB;IACJ;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;sBAWc,CACf;aACA,GAAG,CAAC,EAAE,CAAgC,CAAC;QAE1C,OAAO,GAAG,CAAC,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC9C,CAAC;IAED,mBAAmB,CAAC,aAAqB;QACvC,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;kCAW0B,CAC3B;aACA,GAAG,CAAC,aAAa,CAAgC,CAAC;QAErD,OAAO,GAAG,CAAC,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC9C,CAAC;IAED,IAAI;QACF,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;2DAWmD,CACpD;aACA,GAAG,EAAE;aACL,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAsB,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,MAAM,CAAC,MAA0B;QAC/B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;;;;;4CAkBoC,CACrC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,MAAM,CAAC,EAAU;QACf,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE;aACnB,OAAO,CACN;sBACc,CACf;aACA,GAAG,CAAC,EAAE,CAAC,CAAC;QAEX,OAAO,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;IAC5B,CAAC;CACF;AAcD,SAAS,kBAAkB,CAAC,GAAoB;IAC9C,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,YAAY,EAAE,GAAG,CAAC,aAAa;QAC/B,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SkillTargetBindingRecord, SkillTargetCli } from "../../types/domain.js";
3
+ export declare class SkillTargetBindingRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ findBySkillAndTarget(skillId: string, targetCli: SkillTargetCli): SkillTargetBindingRecord | null;
7
+ listBySkillId(skillId: string): SkillTargetBindingRecord[];
8
+ upsert(record: SkillTargetBindingRecord): SkillTargetBindingRecord;
9
+ deleteBySkillId(skillId: string): number;
10
+ }
@@ -0,0 +1,77 @@
1
+ export class SkillTargetBindingRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ findBySkillAndTarget(skillId, targetCli) {
7
+ const row = this.db
8
+ .prepare(`SELECT
9
+ skill_id,
10
+ target_cli,
11
+ enabled,
12
+ sync_status,
13
+ last_synced_at,
14
+ last_error_code,
15
+ last_error_detail
16
+ FROM skill_target_bindings
17
+ WHERE skill_id = ?
18
+ AND target_cli = ?`)
19
+ .get(skillId, targetCli);
20
+ return row ? mapSkillTargetBindingRow(row) : null;
21
+ }
22
+ listBySkillId(skillId) {
23
+ return this.db
24
+ .prepare(`SELECT
25
+ skill_id,
26
+ target_cli,
27
+ enabled,
28
+ sync_status,
29
+ last_synced_at,
30
+ last_error_code,
31
+ last_error_detail
32
+ FROM skill_target_bindings
33
+ WHERE skill_id = ?
34
+ ORDER BY target_cli ASC`)
35
+ .all(skillId)
36
+ .map((row) => mapSkillTargetBindingRow(row));
37
+ }
38
+ upsert(record) {
39
+ this.db
40
+ .prepare(`INSERT INTO skill_target_bindings (
41
+ skill_id,
42
+ target_cli,
43
+ enabled,
44
+ sync_status,
45
+ last_synced_at,
46
+ last_error_code,
47
+ last_error_detail
48
+ ) VALUES (?, ?, ?, ?, ?, ?, ?)
49
+ ON CONFLICT(skill_id, target_cli) DO UPDATE SET
50
+ enabled = excluded.enabled,
51
+ sync_status = excluded.sync_status,
52
+ last_synced_at = excluded.last_synced_at,
53
+ last_error_code = excluded.last_error_code,
54
+ last_error_detail = excluded.last_error_detail`)
55
+ .run(record.skillId, record.targetCli, record.enabled ? 1 : 0, record.syncStatus, record.lastSyncedAt, record.lastErrorCode, record.lastErrorDetail);
56
+ return record;
57
+ }
58
+ deleteBySkillId(skillId) {
59
+ const result = this.db
60
+ .prepare(`DELETE FROM skill_target_bindings
61
+ WHERE skill_id = ?`)
62
+ .run(skillId);
63
+ return result.changes;
64
+ }
65
+ }
66
+ function mapSkillTargetBindingRow(row) {
67
+ return {
68
+ skillId: row.skill_id,
69
+ targetCli: row.target_cli,
70
+ enabled: row.enabled === 1,
71
+ syncStatus: row.sync_status,
72
+ lastSyncedAt: row.last_synced_at,
73
+ lastErrorCode: row.last_error_code,
74
+ lastErrorDetail: row.last_error_detail
75
+ };
76
+ }
77
+ //# sourceMappingURL=skill-target-binding-repository.js.map