@jingyi0605/codingns 0.1.4 → 0.1.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 (209) hide show
  1. package/dist/public/assets/{TerminalPage-4ulgBhv9.js → TerminalPage-4p6EBqrR.js} +1 -1
  2. package/dist/public/assets/gemini-D4G1NbrE.png +0 -0
  3. package/dist/public/assets/index-CxeghocY.css +1 -0
  4. package/dist/public/assets/index-DXusStl0.js +108 -0
  5. package/dist/public/assets/kimi-BWNNSh7e.png +0 -0
  6. package/dist/public/index.html +2 -2
  7. package/dist/server/config/env.d.ts +6 -0
  8. package/dist/server/config/env.js +145 -0
  9. package/dist/server/config/env.js.map +1 -1
  10. package/dist/server/config/opencode-system-probe-helper-process.d.ts +24 -0
  11. package/dist/server/config/opencode-system-probe-helper-process.js +70 -5
  12. package/dist/server/config/opencode-system-probe-helper-process.js.map +1 -1
  13. package/dist/server/modules/butler/butler-action-context-service.d.ts +30 -0
  14. package/dist/server/modules/butler/butler-action-context-service.js +108 -0
  15. package/dist/server/modules/butler/butler-action-context-service.js.map +1 -0
  16. package/dist/server/modules/butler/butler-auth-service.d.ts +17 -0
  17. package/dist/server/modules/butler/butler-auth-service.js +91 -0
  18. package/dist/server/modules/butler/butler-auth-service.js.map +1 -0
  19. package/dist/server/modules/butler/butler-control-action-service.d.ts +65 -0
  20. package/dist/server/modules/butler/butler-control-action-service.js +296 -0
  21. package/dist/server/modules/butler/butler-control-action-service.js.map +1 -0
  22. package/dist/server/modules/butler/butler-control-session-service.d.ts +55 -0
  23. package/dist/server/modules/butler/butler-control-session-service.js +367 -0
  24. package/dist/server/modules/butler/butler-control-session-service.js.map +1 -0
  25. package/dist/server/modules/butler/butler-controller.d.ts +367 -0
  26. package/dist/server/modules/butler/butler-controller.js +475 -0
  27. package/dist/server/modules/butler/butler-controller.js.map +1 -0
  28. package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.d.ts +34 -0
  29. package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.js +77 -0
  30. package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.js.map +1 -0
  31. package/dist/server/modules/butler/butler-follow-up-scheduler.d.ts +23 -0
  32. package/dist/server/modules/butler/butler-follow-up-scheduler.js +57 -0
  33. package/dist/server/modules/butler/butler-follow-up-scheduler.js.map +1 -0
  34. package/dist/server/modules/butler/butler-follow-up-service.d.ts +86 -0
  35. package/dist/server/modules/butler/butler-follow-up-service.js +948 -0
  36. package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -0
  37. package/dist/server/modules/butler/butler-inbox-service.d.ts +35 -0
  38. package/dist/server/modules/butler/butler-inbox-service.js +136 -0
  39. package/dist/server/modules/butler/butler-inbox-service.js.map +1 -0
  40. package/dist/server/modules/butler/butler-notification-service.d.ts +12 -0
  41. package/dist/server/modules/butler/butler-notification-service.js +45 -0
  42. package/dist/server/modules/butler/butler-notification-service.js.map +1 -0
  43. package/dist/server/modules/butler/butler-profile-service.d.ts +26 -0
  44. package/dist/server/modules/butler/butler-profile-service.js +529 -0
  45. package/dist/server/modules/butler/butler-profile-service.js.map +1 -0
  46. package/dist/server/modules/butler/butler-project-service.d.ts +48 -0
  47. package/dist/server/modules/butler/butler-project-service.js +253 -0
  48. package/dist/server/modules/butler/butler-project-service.js.map +1 -0
  49. package/dist/server/modules/butler/butler-session-service.d.ts +79 -0
  50. package/dist/server/modules/butler/butler-session-service.js +503 -0
  51. package/dist/server/modules/butler/butler-session-service.js.map +1 -0
  52. package/dist/server/modules/butler/butler-session-summary-service.d.ts +55 -0
  53. package/dist/server/modules/butler/butler-session-summary-service.js +382 -0
  54. package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -0
  55. package/dist/server/modules/butler/context-aggregator.d.ts +187 -0
  56. package/dist/server/modules/butler/context-aggregator.js +807 -0
  57. package/dist/server/modules/butler/context-aggregator.js.map +1 -0
  58. package/dist/server/modules/butler/instruction-adapter.d.ts +28 -0
  59. package/dist/server/modules/butler/instruction-adapter.js +101 -0
  60. package/dist/server/modules/butler/instruction-adapter.js.map +1 -0
  61. package/dist/server/modules/butler/patrol-execution-service.d.ts +47 -0
  62. package/dist/server/modules/butler/patrol-execution-service.js +347 -0
  63. package/dist/server/modules/butler/patrol-execution-service.js.map +1 -0
  64. package/dist/server/modules/butler/patrol-plan-service.d.ts +54 -0
  65. package/dist/server/modules/butler/patrol-plan-service.js +272 -0
  66. package/dist/server/modules/butler/patrol-plan-service.js.map +1 -0
  67. package/dist/server/modules/butler/patrol-run-service.d.ts +60 -0
  68. package/dist/server/modules/butler/patrol-run-service.js +185 -0
  69. package/dist/server/modules/butler/patrol-run-service.js.map +1 -0
  70. package/dist/server/modules/butler/patrol-scheduler.d.ts +36 -0
  71. package/dist/server/modules/butler/patrol-scheduler.js +99 -0
  72. package/dist/server/modules/butler/patrol-scheduler.js.map +1 -0
  73. package/dist/server/modules/butler/project-memory-service.d.ts +30 -0
  74. package/dist/server/modules/butler/project-memory-service.js +103 -0
  75. package/dist/server/modules/butler/project-memory-service.js.map +1 -0
  76. package/dist/server/modules/butler/provider-adapter-registry.d.ts +61 -0
  77. package/dist/server/modules/butler/provider-adapter-registry.js +430 -0
  78. package/dist/server/modules/butler/provider-adapter-registry.js.map +1 -0
  79. package/dist/server/modules/butler/session-summary-instruction-adapter.d.ts +28 -0
  80. package/dist/server/modules/butler/session-summary-instruction-adapter.js +79 -0
  81. package/dist/server/modules/butler/session-summary-instruction-adapter.js.map +1 -0
  82. package/dist/server/modules/butler/session-summary-scheduler.d.ts +23 -0
  83. package/dist/server/modules/butler/session-summary-scheduler.js +57 -0
  84. package/dist/server/modules/butler/session-summary-scheduler.js.map +1 -0
  85. package/dist/server/modules/butler/verification-run-service.d.ts +73 -0
  86. package/dist/server/modules/butler/verification-run-service.js +633 -0
  87. package/dist/server/modules/butler/verification-run-service.js.map +1 -0
  88. package/dist/server/modules/preferences/profile-service.js +8 -2
  89. package/dist/server/modules/preferences/profile-service.js.map +1 -1
  90. package/dist/server/modules/sessions/claude-runtime-helper-process.js +1 -1
  91. package/dist/server/modules/sessions/claude-runtime-helper-process.js.map +1 -1
  92. package/dist/server/modules/sessions/codex-app-server-helper-client.d.ts +5 -1
  93. package/dist/server/modules/sessions/codex-app-server-helper-client.js +10 -2
  94. package/dist/server/modules/sessions/codex-app-server-helper-client.js.map +1 -1
  95. package/dist/server/modules/sessions/session-controller.d.ts +3 -1
  96. package/dist/server/modules/sessions/session-controller.js +11 -2
  97. package/dist/server/modules/sessions/session-controller.js.map +1 -1
  98. package/dist/server/modules/sessions/session-history-service.d.ts +14 -1
  99. package/dist/server/modules/sessions/session-history-service.js +291 -30
  100. package/dist/server/modules/sessions/session-history-service.js.map +1 -1
  101. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +25 -2
  102. package/dist/server/modules/sessions/session-live-runtime-service.js +526 -158
  103. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
  104. package/dist/server/modules/sessions/session-provider-error-mapper.js +28 -0
  105. package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -1
  106. package/dist/server/modules/workbench/workbench-service.d.ts +7 -1
  107. package/dist/server/modules/workbench/workbench-service.js +31 -7
  108. package/dist/server/modules/workbench/workbench-service.js.map +1 -1
  109. package/dist/server/routes/butler.d.ts +3 -0
  110. package/dist/server/routes/butler.js +54 -0
  111. package/dist/server/routes/butler.js.map +1 -0
  112. package/dist/server/server/create-server.d.ts +61 -0
  113. package/dist/server/server/create-server.js +148 -4
  114. package/dist/server/server/create-server.js.map +1 -1
  115. package/dist/server/storage/repositories/butler-control-event-repository.d.ts +8 -0
  116. package/dist/server/storage/repositories/butler-control-event-repository.js +78 -0
  117. package/dist/server/storage/repositories/butler-control-event-repository.js.map +1 -0
  118. package/dist/server/storage/repositories/butler-control-session-repository.d.ts +11 -0
  119. package/dist/server/storage/repositories/butler-control-session-repository.js +86 -0
  120. package/dist/server/storage/repositories/butler-control-session-repository.js.map +1 -0
  121. package/dist/server/storage/repositories/butler-follow-up-task-repository.d.ts +16 -0
  122. package/dist/server/storage/repositories/butler-follow-up-task-repository.js +252 -0
  123. package/dist/server/storage/repositories/butler-follow-up-task-repository.js.map +1 -0
  124. package/dist/server/storage/repositories/butler-inbox-item-repository.d.ts +15 -0
  125. package/dist/server/storage/repositories/butler-inbox-item-repository.js +111 -0
  126. package/dist/server/storage/repositories/butler-inbox-item-repository.js.map +1 -0
  127. package/dist/server/storage/repositories/butler-notification-archive-repository.d.ts +9 -0
  128. package/dist/server/storage/repositories/butler-notification-archive-repository.js +48 -0
  129. package/dist/server/storage/repositories/butler-notification-archive-repository.js.map +1 -0
  130. package/dist/server/storage/repositories/butler-profile-repository.d.ts +9 -0
  131. package/dist/server/storage/repositories/butler-profile-repository.js +86 -0
  132. package/dist/server/storage/repositories/butler-profile-repository.js.map +1 -0
  133. package/dist/server/storage/repositories/butler-project-repository.d.ts +14 -0
  134. package/dist/server/storage/repositories/butler-project-repository.js +140 -0
  135. package/dist/server/storage/repositories/butler-project-repository.js.map +1 -0
  136. package/dist/server/storage/repositories/butler-session-repository.d.ts +11 -0
  137. package/dist/server/storage/repositories/butler-session-repository.js +106 -0
  138. package/dist/server/storage/repositories/butler-session-repository.js.map +1 -0
  139. package/dist/server/storage/repositories/butler-session-summary-state-repository.d.ts +8 -0
  140. package/dist/server/storage/repositories/butler-session-summary-state-repository.js +62 -0
  141. package/dist/server/storage/repositories/butler-session-summary-state-repository.js.map +1 -0
  142. package/dist/server/storage/repositories/patrol-plan-repository.d.ts +27 -0
  143. package/dist/server/storage/repositories/patrol-plan-repository.js +119 -0
  144. package/dist/server/storage/repositories/patrol-plan-repository.js.map +1 -0
  145. package/dist/server/storage/repositories/patrol-run-repository.d.ts +28 -0
  146. package/dist/server/storage/repositories/patrol-run-repository.js +121 -0
  147. package/dist/server/storage/repositories/patrol-run-repository.js.map +1 -0
  148. package/dist/server/storage/repositories/project-memory-repository.d.ts +15 -0
  149. package/dist/server/storage/repositories/project-memory-repository.js +150 -0
  150. package/dist/server/storage/repositories/project-memory-repository.js.map +1 -0
  151. package/dist/server/storage/repositories/session-checkpoint-repository.d.ts +9 -0
  152. package/dist/server/storage/repositories/session-checkpoint-repository.js +72 -0
  153. package/dist/server/storage/repositories/session-checkpoint-repository.js.map +1 -0
  154. package/dist/server/storage/repositories/session-message-origin-repository.d.ts +10 -0
  155. package/dist/server/storage/repositories/session-message-origin-repository.js +93 -0
  156. package/dist/server/storage/repositories/session-message-origin-repository.js.map +1 -0
  157. package/dist/server/storage/repositories/verification-run-repository.d.ts +29 -0
  158. package/dist/server/storage/repositories/verification-run-repository.js +125 -0
  159. package/dist/server/storage/repositories/verification-run-repository.js.map +1 -0
  160. package/dist/server/storage/sqlite/client.js +39 -0
  161. package/dist/server/storage/sqlite/client.js.map +1 -1
  162. package/dist/server/storage/sqlite/schema.sql +324 -0
  163. package/dist/server/types/domain.d.ts +261 -1
  164. package/dist/server/ws/ws-server.d.ts +2 -1
  165. package/dist/server/ws/ws-server.js +2 -1
  166. package/dist/server/ws/ws-server.js.map +1 -1
  167. package/node_modules/@codingns/session-sync-core/dist/index.d.ts +4 -0
  168. package/node_modules/@codingns/session-sync-core/dist/index.js +4 -0
  169. package/node_modules/@codingns/session-sync-core/dist/index.js.map +1 -1
  170. package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.d.ts +18 -0
  171. package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.js +659 -0
  172. package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.js.map +1 -0
  173. package/node_modules/@codingns/session-sync-core/dist/kimi-shared.d.ts +11 -0
  174. package/node_modules/@codingns/session-sync-core/dist/kimi-shared.js +72 -0
  175. package/node_modules/@codingns/session-sync-core/dist/kimi-shared.js.map +1 -0
  176. package/node_modules/@codingns/session-sync-core/dist/patch-builder.d.ts +8 -0
  177. package/node_modules/@codingns/session-sync-core/dist/patch-builder.js +89 -0
  178. package/node_modules/@codingns/session-sync-core/dist/patch-builder.js.map +1 -1
  179. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +4 -1
  180. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
  181. package/node_modules/@codingns/session-sync-core/dist/providers/gemini.d.ts +41 -0
  182. package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js +1086 -0
  183. package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js.map +1 -0
  184. package/node_modules/@codingns/session-sync-core/dist/providers/kimi.d.ts +29 -0
  185. package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js +578 -0
  186. package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js.map +1 -0
  187. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +2 -1
  188. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -1
  189. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js +30 -2
  190. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js.map +1 -1
  191. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.d.ts +2 -0
  192. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js +43 -5
  193. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js.map +1 -1
  194. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +2 -0
  195. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +320 -69
  196. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
  197. package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.d.ts +21 -0
  198. package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.js +537 -0
  199. package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.js.map +1 -0
  200. package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.d.ts +38 -0
  201. package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.js +911 -0
  202. package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.js.map +1 -0
  203. package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.d.ts +6 -0
  204. package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.js +9 -0
  205. package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.js.map +1 -0
  206. package/node_modules/@codingns/session-sync-core/package.json +8 -0
  207. package/package.json +1 -1
  208. package/dist/public/assets/index-C5lu52cQ.css +0 -1
  209. package/dist/public/assets/index-WpdUo_Vs.js +0 -108
@@ -0,0 +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"}
@@ -0,0 +1,16 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { ButlerFollowUpTask, ButlerFollowUpTaskStatus } from "../../types/domain.js";
3
+ export declare class ButlerFollowUpTaskRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: ButlerFollowUpTask): ButlerFollowUpTask;
7
+ findById(id: string): ButlerFollowUpTask | null;
8
+ findActiveByButlerSessionId(butlerSessionId: string): ButlerFollowUpTask | null;
9
+ list(filters?: {
10
+ statuses?: ButlerFollowUpTaskStatus[];
11
+ projectId?: string;
12
+ sessionId?: string;
13
+ limit?: number;
14
+ }): ButlerFollowUpTask[];
15
+ update(record: ButlerFollowUpTask): ButlerFollowUpTask | null;
16
+ }
@@ -0,0 +1,252 @@
1
+ export class ButlerFollowUpTaskRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO butler_follow_up_tasks (
9
+ id,
10
+ project_id,
11
+ butler_session_id,
12
+ session_id,
13
+ created_by_user_id,
14
+ objective,
15
+ completion_criteria,
16
+ max_auto_continue_count,
17
+ status,
18
+ check_interval_seconds,
19
+ last_checked_at,
20
+ next_check_at,
21
+ last_observed_running_state,
22
+ last_observed_message_at,
23
+ last_observed_message_count,
24
+ last_automation_summary,
25
+ last_automation_at,
26
+ auto_continue_count,
27
+ waiting_reason,
28
+ rounds_json,
29
+ created_at,
30
+ updated_at,
31
+ completed_at
32
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
33
+ .run(record.id, record.projectId, record.butlerSessionId, record.sessionId, record.createdByUserId, record.objective, record.completionCriteria, record.maxAutoContinueCount, record.status, record.checkIntervalSeconds, record.lastCheckedAt, record.nextCheckAt, record.lastObservedRunningState, record.lastObservedMessageAt, record.lastObservedMessageCount, record.lastAutomationSummary, record.lastAutomationAt, record.autoContinueCount, record.waitingReason, JSON.stringify(record.rounds), record.createdAt, record.updatedAt, record.completedAt);
34
+ return record;
35
+ }
36
+ findById(id) {
37
+ const row = this.db
38
+ .prepare(`SELECT
39
+ id,
40
+ project_id,
41
+ butler_session_id,
42
+ session_id,
43
+ created_by_user_id,
44
+ objective,
45
+ completion_criteria,
46
+ max_auto_continue_count,
47
+ status,
48
+ check_interval_seconds,
49
+ last_checked_at,
50
+ next_check_at,
51
+ last_observed_running_state,
52
+ last_observed_message_at,
53
+ last_observed_message_count,
54
+ last_automation_summary,
55
+ last_automation_at,
56
+ auto_continue_count,
57
+ waiting_reason,
58
+ rounds_json,
59
+ created_at,
60
+ updated_at,
61
+ completed_at
62
+ FROM butler_follow_up_tasks
63
+ WHERE id = ?`)
64
+ .get(id);
65
+ return row ? mapRow(row) : null;
66
+ }
67
+ findActiveByButlerSessionId(butlerSessionId) {
68
+ const row = this.db
69
+ .prepare(`SELECT
70
+ id,
71
+ project_id,
72
+ butler_session_id,
73
+ session_id,
74
+ created_by_user_id,
75
+ objective,
76
+ completion_criteria,
77
+ max_auto_continue_count,
78
+ status,
79
+ check_interval_seconds,
80
+ last_checked_at,
81
+ next_check_at,
82
+ last_observed_running_state,
83
+ last_observed_message_at,
84
+ last_observed_message_count,
85
+ last_automation_summary,
86
+ last_automation_at,
87
+ auto_continue_count,
88
+ waiting_reason,
89
+ rounds_json,
90
+ created_at,
91
+ updated_at,
92
+ completed_at
93
+ FROM butler_follow_up_tasks
94
+ WHERE butler_session_id = ?
95
+ AND status IN ('active', 'waiting_user')
96
+ ORDER BY updated_at DESC
97
+ LIMIT 1`)
98
+ .get(butlerSessionId);
99
+ return row ? mapRow(row) : null;
100
+ }
101
+ list(filters = {}) {
102
+ const whereParts = [];
103
+ const values = [];
104
+ if (filters.statuses && filters.statuses.length > 0) {
105
+ whereParts.push(`status IN (${filters.statuses.map(() => "?").join(", ")})`);
106
+ values.push(...filters.statuses);
107
+ }
108
+ if (filters.projectId?.trim()) {
109
+ whereParts.push("project_id = ?");
110
+ values.push(filters.projectId.trim());
111
+ }
112
+ if (filters.sessionId?.trim()) {
113
+ whereParts.push("session_id = ?");
114
+ values.push(filters.sessionId.trim());
115
+ }
116
+ const whereClause = whereParts.length > 0 ? `WHERE ${whereParts.join(" AND ")}` : "";
117
+ const limitClause = filters.limit ? "LIMIT ?" : "";
118
+ if (filters.limit) {
119
+ values.push(filters.limit);
120
+ }
121
+ return this.db
122
+ .prepare(`SELECT
123
+ id,
124
+ project_id,
125
+ butler_session_id,
126
+ session_id,
127
+ created_by_user_id,
128
+ objective,
129
+ completion_criteria,
130
+ max_auto_continue_count,
131
+ status,
132
+ check_interval_seconds,
133
+ last_checked_at,
134
+ next_check_at,
135
+ last_observed_running_state,
136
+ last_observed_message_at,
137
+ last_observed_message_count,
138
+ last_automation_summary,
139
+ last_automation_at,
140
+ auto_continue_count,
141
+ waiting_reason,
142
+ rounds_json,
143
+ created_at,
144
+ updated_at,
145
+ completed_at
146
+ FROM butler_follow_up_tasks
147
+ ${whereClause}
148
+ ORDER BY
149
+ CASE status
150
+ WHEN 'active' THEN 0
151
+ WHEN 'waiting_user' THEN 1
152
+ WHEN 'failed' THEN 2
153
+ WHEN 'completed' THEN 3
154
+ WHEN 'cancelled' THEN 4
155
+ ELSE 5
156
+ END,
157
+ updated_at DESC,
158
+ created_at DESC
159
+ ${limitClause}`)
160
+ .all(...values)
161
+ .map((row) => mapRow(row));
162
+ }
163
+ update(record) {
164
+ this.db
165
+ .prepare(`UPDATE butler_follow_up_tasks
166
+ SET project_id = ?,
167
+ butler_session_id = ?,
168
+ session_id = ?,
169
+ created_by_user_id = ?,
170
+ objective = ?,
171
+ completion_criteria = ?,
172
+ max_auto_continue_count = ?,
173
+ status = ?,
174
+ check_interval_seconds = ?,
175
+ last_checked_at = ?,
176
+ next_check_at = ?,
177
+ last_observed_running_state = ?,
178
+ last_observed_message_at = ?,
179
+ last_observed_message_count = ?,
180
+ last_automation_summary = ?,
181
+ last_automation_at = ?,
182
+ auto_continue_count = ?,
183
+ waiting_reason = ?,
184
+ rounds_json = ?,
185
+ created_at = ?,
186
+ updated_at = ?,
187
+ completed_at = ?
188
+ WHERE id = ?`)
189
+ .run(record.projectId, record.butlerSessionId, record.sessionId, record.createdByUserId, record.objective, record.completionCriteria, record.maxAutoContinueCount, record.status, record.checkIntervalSeconds, record.lastCheckedAt, record.nextCheckAt, record.lastObservedRunningState, record.lastObservedMessageAt, record.lastObservedMessageCount, record.lastAutomationSummary, record.lastAutomationAt, record.autoContinueCount, record.waitingReason, JSON.stringify(record.rounds), record.createdAt, record.updatedAt, record.completedAt, record.id);
190
+ return this.findById(record.id);
191
+ }
192
+ }
193
+ function mapRow(row) {
194
+ return {
195
+ id: row.id,
196
+ projectId: row.project_id,
197
+ butlerSessionId: row.butler_session_id,
198
+ sessionId: row.session_id,
199
+ createdByUserId: row.created_by_user_id,
200
+ objective: row.objective,
201
+ completionCriteria: row.completion_criteria,
202
+ maxAutoContinueCount: row.max_auto_continue_count,
203
+ status: row.status,
204
+ checkIntervalSeconds: row.check_interval_seconds,
205
+ lastCheckedAt: row.last_checked_at,
206
+ nextCheckAt: row.next_check_at,
207
+ lastObservedRunningState: row.last_observed_running_state,
208
+ lastObservedMessageAt: row.last_observed_message_at,
209
+ lastObservedMessageCount: row.last_observed_message_count,
210
+ lastAutomationSummary: row.last_automation_summary,
211
+ lastAutomationAt: row.last_automation_at,
212
+ autoContinueCount: row.auto_continue_count,
213
+ waitingReason: row.waiting_reason,
214
+ rounds: parseRounds(row.rounds_json),
215
+ createdAt: row.created_at,
216
+ updatedAt: row.updated_at,
217
+ completedAt: row.completed_at
218
+ };
219
+ }
220
+ function parseRounds(value) {
221
+ if (!value?.trim()) {
222
+ return [];
223
+ }
224
+ try {
225
+ const parsed = JSON.parse(value);
226
+ if (!Array.isArray(parsed)) {
227
+ return [];
228
+ }
229
+ return parsed
230
+ .filter((item) => Boolean(item && typeof item === "object"))
231
+ .filter((item) => item.kind !== "started")
232
+ .map((item, index) => ({
233
+ roundNumber: index + 1,
234
+ kind: typeof item.kind === "string" ? item.kind : "started",
235
+ status: typeof item.status === "string" ? item.status : "active",
236
+ summary: typeof item.summary === "string" ? item.summary : "",
237
+ waitingReason: typeof item.waitingReason === "string" ? item.waitingReason : null,
238
+ continuePrompt: typeof item.continuePrompt === "string" ? item.continuePrompt : null,
239
+ observedRunningState: typeof item.observedRunningState === "string"
240
+ ? item.observedRunningState
241
+ : null,
242
+ autoContinueCount: typeof item.autoContinueCount === "number" && Number.isFinite(item.autoContinueCount)
243
+ ? item.autoContinueCount
244
+ : 0,
245
+ createdAt: typeof item.createdAt === "string" ? item.createdAt : ""
246
+ }));
247
+ }
248
+ catch {
249
+ return [];
250
+ }
251
+ }
252
+ //# sourceMappingURL=butler-follow-up-task-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"butler-follow-up-task-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-follow-up-task-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { ButlerInboxItem, ButlerInboxItemStatus, ButlerInboxItemType } from "../../types/domain.js";
3
+ export declare class ButlerInboxItemRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: ButlerInboxItem): ButlerInboxItem;
7
+ list(filters?: {
8
+ projectId?: string;
9
+ status?: ButlerInboxItemStatus;
10
+ itemType?: ButlerInboxItemType;
11
+ }): ButlerInboxItem[];
12
+ findById(id: string): ButlerInboxItem | null;
13
+ update(record: ButlerInboxItem): ButlerInboxItem;
14
+ delete(id: string): void;
15
+ }
@@ -0,0 +1,111 @@
1
+ export class ButlerInboxItemRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO butler_inbox_items (
9
+ id,
10
+ project_id,
11
+ item_type,
12
+ title,
13
+ content,
14
+ priority,
15
+ status,
16
+ created_at,
17
+ updated_at,
18
+ 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);
21
+ return record;
22
+ }
23
+ list(filters) {
24
+ const conditions = [];
25
+ const values = [];
26
+ if (filters?.projectId) {
27
+ conditions.push("project_id = ?");
28
+ values.push(filters.projectId);
29
+ }
30
+ if (filters?.status) {
31
+ conditions.push("status = ?");
32
+ values.push(filters.status);
33
+ }
34
+ if (filters?.itemType) {
35
+ conditions.push("item_type = ?");
36
+ values.push(filters.itemType);
37
+ }
38
+ const whereClause = conditions.length > 0 ? `WHERE ${conditions.join(" AND ")}` : "";
39
+ return this.db
40
+ .prepare(`SELECT
41
+ id,
42
+ project_id,
43
+ item_type,
44
+ title,
45
+ content,
46
+ priority,
47
+ status,
48
+ created_at,
49
+ updated_at,
50
+ closed_at
51
+ FROM butler_inbox_items
52
+ ${whereClause}
53
+ ORDER BY updated_at DESC, created_at DESC`)
54
+ .all(...values)
55
+ .map((row) => mapButlerInboxItemRow(row));
56
+ }
57
+ findById(id) {
58
+ const row = this.db
59
+ .prepare(`SELECT
60
+ id,
61
+ project_id,
62
+ item_type,
63
+ title,
64
+ content,
65
+ priority,
66
+ status,
67
+ created_at,
68
+ updated_at,
69
+ closed_at
70
+ FROM butler_inbox_items
71
+ WHERE id = ?`)
72
+ .get(id);
73
+ return row ? mapButlerInboxItemRow(row) : null;
74
+ }
75
+ update(record) {
76
+ this.db
77
+ .prepare(`UPDATE butler_inbox_items
78
+ SET
79
+ project_id = ?,
80
+ item_type = ?,
81
+ title = ?,
82
+ content = ?,
83
+ priority = ?,
84
+ status = ?,
85
+ updated_at = ?,
86
+ closed_at = ?
87
+ WHERE id = ?`)
88
+ .run(record.projectId, record.itemType, record.title, record.content, record.priority, record.status, record.updatedAt, record.closedAt, record.id);
89
+ return record;
90
+ }
91
+ delete(id) {
92
+ this.db
93
+ .prepare("DELETE FROM butler_inbox_items WHERE id = ?")
94
+ .run(id);
95
+ }
96
+ }
97
+ function mapButlerInboxItemRow(row) {
98
+ return {
99
+ id: row.id,
100
+ projectId: row.project_id,
101
+ itemType: row.item_type,
102
+ title: row.title,
103
+ content: row.content,
104
+ priority: row.priority,
105
+ status: row.status,
106
+ createdAt: row.created_at,
107
+ updatedAt: row.updated_at,
108
+ closedAt: row.closed_at
109
+ };
110
+ }
111
+ //# sourceMappingURL=butler-inbox-item-repository.js.map
@@ -0,0 +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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"}
@@ -0,0 +1,9 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { ButlerNotificationArchiveRecord } from "../../types/domain.js";
3
+ export declare class ButlerNotificationArchiveRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ listByUserId(userId: string): ButlerNotificationArchiveRecord[];
7
+ upsert(record: ButlerNotificationArchiveRecord): ButlerNotificationArchiveRecord;
8
+ delete(userId: string, notificationId: string): void;
9
+ }
@@ -0,0 +1,48 @@
1
+ export class ButlerNotificationArchiveRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ listByUserId(userId) {
7
+ return this.db
8
+ .prepare(`SELECT
9
+ user_id,
10
+ notification_id,
11
+ archived_at,
12
+ updated_at
13
+ FROM butler_notification_archives
14
+ WHERE user_id = ?
15
+ ORDER BY updated_at DESC`)
16
+ .all(userId)
17
+ .map((row) => mapRow(row));
18
+ }
19
+ upsert(record) {
20
+ this.db
21
+ .prepare(`INSERT INTO butler_notification_archives (
22
+ user_id,
23
+ notification_id,
24
+ archived_at,
25
+ updated_at
26
+ ) VALUES (?, ?, ?, ?)
27
+ ON CONFLICT(user_id, notification_id) DO UPDATE SET
28
+ archived_at = excluded.archived_at,
29
+ updated_at = excluded.updated_at`)
30
+ .run(record.userId, record.notificationId, record.archivedAt, record.updatedAt);
31
+ return record;
32
+ }
33
+ delete(userId, notificationId) {
34
+ this.db
35
+ .prepare(`DELETE FROM butler_notification_archives
36
+ WHERE user_id = ? AND notification_id = ?`)
37
+ .run(userId, notificationId);
38
+ }
39
+ }
40
+ function mapRow(row) {
41
+ return {
42
+ userId: row.user_id,
43
+ notificationId: row.notification_id,
44
+ archivedAt: row.archived_at,
45
+ updatedAt: row.updated_at
46
+ };
47
+ }
48
+ //# sourceMappingURL=butler-notification-archive-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"butler-notification-archive-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-notification-archive-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,mCAAmC;IACjB;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,YAAY,CAAC,MAAc;QACzB,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;kCAO0B,CAC3B;aACA,GAAG,CAAC,MAAM,CAAC;aACX,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,GAAmC,CAAC,CAAC,CAAC;IAC/D,CAAC;IAED,MAAM,CAAC,MAAuC;QAC5C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;4CAQoC,CACrC;aACA,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;QAElF,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,MAAM,CAAC,MAAc,EAAE,cAAsB;QAC3C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;mDAC2C,CAC5C;aACA,GAAG,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;IACjC,CAAC;CACF;AASD,SAAS,MAAM,CAAC,GAAiC;IAC/C,OAAO;QACL,MAAM,EAAE,GAAG,CAAC,OAAO;QACnB,cAAc,EAAE,GAAG,CAAC,eAAe;QACnC,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { ButlerProfile } from "../../types/domain.js";
3
+ export declare class ButlerProfileRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ find(): ButlerProfile | null;
7
+ create(record: ButlerProfile): ButlerProfile;
8
+ update(record: ButlerProfile): ButlerProfile;
9
+ }
@@ -0,0 +1,86 @@
1
+ export class ButlerProfileRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ find() {
7
+ const row = this.db
8
+ .prepare(`SELECT
9
+ id,
10
+ display_name,
11
+ provider_id,
12
+ workspace_path,
13
+ agents_mode,
14
+ agents_file_path,
15
+ agents_content,
16
+ persona_json,
17
+ focus_json,
18
+ initialized_at,
19
+ updated_at
20
+ FROM butler_profiles
21
+ WHERE id = 'default'`)
22
+ .get();
23
+ return row ? mapButlerProfileRow(row) : null;
24
+ }
25
+ create(record) {
26
+ this.db
27
+ .prepare(`INSERT INTO butler_profiles (
28
+ id,
29
+ display_name,
30
+ provider_id,
31
+ workspace_path,
32
+ agents_mode,
33
+ agents_file_path,
34
+ agents_content,
35
+ persona_json,
36
+ focus_json,
37
+ initialized_at,
38
+ updated_at
39
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
40
+ .run(record.id, record.displayName, record.providerId, record.workspacePath, record.agentsMode, record.agentsFilePath, record.agentsContent, JSON.stringify(record.persona), JSON.stringify(record.focus), record.initializedAt, record.updatedAt);
41
+ return record;
42
+ }
43
+ update(record) {
44
+ this.db
45
+ .prepare(`UPDATE butler_profiles
46
+ SET provider_id = ?,
47
+ display_name = ?,
48
+ workspace_path = ?,
49
+ agents_mode = ?,
50
+ agents_file_path = ?,
51
+ agents_content = ?,
52
+ persona_json = ?,
53
+ focus_json = ?,
54
+ updated_at = ?
55
+ WHERE id = ?`)
56
+ .run(record.providerId, record.displayName, record.workspacePath, record.agentsMode, record.agentsFilePath, record.agentsContent, JSON.stringify(record.persona), JSON.stringify(record.focus), record.updatedAt, record.id);
57
+ return record;
58
+ }
59
+ }
60
+ function mapButlerProfileRow(row) {
61
+ return {
62
+ id: row.id,
63
+ displayName: row.display_name,
64
+ providerId: row.provider_id,
65
+ workspacePath: row.workspace_path,
66
+ agentsMode: row.agents_mode,
67
+ agentsFilePath: row.agents_file_path,
68
+ agentsContent: row.agents_content,
69
+ persona: parseJsonObject(row.persona_json),
70
+ focus: parseJsonObject(row.focus_json),
71
+ initializedAt: row.initialized_at,
72
+ updatedAt: row.updated_at
73
+ };
74
+ }
75
+ function parseJsonObject(raw) {
76
+ try {
77
+ const parsed = JSON.parse(raw);
78
+ return parsed && typeof parsed === "object" && !Array.isArray(parsed)
79
+ ? parsed
80
+ : {};
81
+ }
82
+ catch {
83
+ return {};
84
+ }
85
+ }
86
+ //# sourceMappingURL=butler-profile-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"butler-profile-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-profile-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,uBAAuB;IACL;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,IAAI;QACF,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;;8BAasB,CACvB;aACA,GAAG,EAAkC,CAAC;QAEzC,OAAO,GAAG,CAAC,CAAC,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/C,CAAC;IAED,MAAM,CAAC,MAAqB;QAC1B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;oDAY4C,CAC7C;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,cAAc,EACrB,MAAM,CAAC,aAAa,EACpB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,EAC9B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,EAC5B,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,MAAM,CAAC,MAAqB;QAC1B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;sBAUc,CACf;aACA,GAAG,CACF,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,cAAc,EACrB,MAAM,CAAC,aAAa,EACpB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,EAC9B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,EAC5B,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,EAAE,CACV,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAgBD,SAAS,mBAAmB,CAAC,GAAqB;IAChD,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,cAAc,EAAE,GAAG,CAAC,gBAAgB;QACpC,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,OAAO,EAAE,eAAe,CAAC,GAAG,CAAC,YAAY,CAA6B;QACtE,KAAK,EAAE,eAAe,CAAC,GAAG,CAAC,UAAU,CAA2B;QAChE,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,GAAW;IAClC,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAY,CAAC;QAC1C,OAAO,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;YACnE,CAAC,CAAE,MAAkC;YACrC,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,14 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { ButlerProject } from "../../types/domain.js";
3
+ export declare class ButlerProjectRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: ButlerProject): ButlerProject;
7
+ list(filters?: {
8
+ workspaceId?: string;
9
+ lifecycleStatus?: ButlerProject["lifecycleStatus"];
10
+ riskLevel?: ButlerProject["riskLevel"];
11
+ }): ButlerProject[];
12
+ findById(id: string): ButlerProject | null;
13
+ update(record: ButlerProject): ButlerProject | null;
14
+ }