@jingyi0605/codingns 0.1.3 → 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 (224) hide show
  1. package/bin/codingns.mjs +47 -8
  2. package/dist/public/assets/{TerminalPage-Nq5sPc5c.js → TerminalPage-4p6EBqrR.js} +19 -19
  3. package/dist/public/assets/gemini-D4G1NbrE.png +0 -0
  4. package/dist/public/assets/index-CxeghocY.css +1 -0
  5. package/dist/public/assets/index-DXusStl0.js +108 -0
  6. package/dist/public/assets/kimi-BWNNSh7e.png +0 -0
  7. package/dist/public/index.html +2 -2
  8. package/dist/server/config/env.d.ts +7 -0
  9. package/dist/server/config/env.js +147 -1
  10. package/dist/server/config/env.js.map +1 -1
  11. package/dist/server/config/opencode-system-probe-helper-process.d.ts +24 -0
  12. package/dist/server/config/opencode-system-probe-helper-process.js +70 -5
  13. package/dist/server/config/opencode-system-probe-helper-process.js.map +1 -1
  14. package/dist/server/modules/auth/auth-service.d.ts +7 -1
  15. package/dist/server/modules/auth/auth-service.js +23 -3
  16. package/dist/server/modules/auth/auth-service.js.map +1 -1
  17. package/dist/server/modules/bootstrap/bootstrap-service.d.ts +3 -1
  18. package/dist/server/modules/bootstrap/bootstrap-service.js +7 -2
  19. package/dist/server/modules/bootstrap/bootstrap-service.js.map +1 -1
  20. package/dist/server/modules/butler/butler-action-context-service.d.ts +30 -0
  21. package/dist/server/modules/butler/butler-action-context-service.js +108 -0
  22. package/dist/server/modules/butler/butler-action-context-service.js.map +1 -0
  23. package/dist/server/modules/butler/butler-auth-service.d.ts +17 -0
  24. package/dist/server/modules/butler/butler-auth-service.js +91 -0
  25. package/dist/server/modules/butler/butler-auth-service.js.map +1 -0
  26. package/dist/server/modules/butler/butler-control-action-service.d.ts +65 -0
  27. package/dist/server/modules/butler/butler-control-action-service.js +296 -0
  28. package/dist/server/modules/butler/butler-control-action-service.js.map +1 -0
  29. package/dist/server/modules/butler/butler-control-session-service.d.ts +55 -0
  30. package/dist/server/modules/butler/butler-control-session-service.js +367 -0
  31. package/dist/server/modules/butler/butler-control-session-service.js.map +1 -0
  32. package/dist/server/modules/butler/butler-controller.d.ts +367 -0
  33. package/dist/server/modules/butler/butler-controller.js +475 -0
  34. package/dist/server/modules/butler/butler-controller.js.map +1 -0
  35. package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.d.ts +34 -0
  36. package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.js +77 -0
  37. package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.js.map +1 -0
  38. package/dist/server/modules/butler/butler-follow-up-scheduler.d.ts +23 -0
  39. package/dist/server/modules/butler/butler-follow-up-scheduler.js +57 -0
  40. package/dist/server/modules/butler/butler-follow-up-scheduler.js.map +1 -0
  41. package/dist/server/modules/butler/butler-follow-up-service.d.ts +86 -0
  42. package/dist/server/modules/butler/butler-follow-up-service.js +948 -0
  43. package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -0
  44. package/dist/server/modules/butler/butler-inbox-service.d.ts +35 -0
  45. package/dist/server/modules/butler/butler-inbox-service.js +136 -0
  46. package/dist/server/modules/butler/butler-inbox-service.js.map +1 -0
  47. package/dist/server/modules/butler/butler-notification-service.d.ts +12 -0
  48. package/dist/server/modules/butler/butler-notification-service.js +45 -0
  49. package/dist/server/modules/butler/butler-notification-service.js.map +1 -0
  50. package/dist/server/modules/butler/butler-profile-service.d.ts +26 -0
  51. package/dist/server/modules/butler/butler-profile-service.js +529 -0
  52. package/dist/server/modules/butler/butler-profile-service.js.map +1 -0
  53. package/dist/server/modules/butler/butler-project-service.d.ts +48 -0
  54. package/dist/server/modules/butler/butler-project-service.js +253 -0
  55. package/dist/server/modules/butler/butler-project-service.js.map +1 -0
  56. package/dist/server/modules/butler/butler-session-service.d.ts +79 -0
  57. package/dist/server/modules/butler/butler-session-service.js +503 -0
  58. package/dist/server/modules/butler/butler-session-service.js.map +1 -0
  59. package/dist/server/modules/butler/butler-session-summary-service.d.ts +55 -0
  60. package/dist/server/modules/butler/butler-session-summary-service.js +382 -0
  61. package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -0
  62. package/dist/server/modules/butler/context-aggregator.d.ts +187 -0
  63. package/dist/server/modules/butler/context-aggregator.js +807 -0
  64. package/dist/server/modules/butler/context-aggregator.js.map +1 -0
  65. package/dist/server/modules/butler/instruction-adapter.d.ts +28 -0
  66. package/dist/server/modules/butler/instruction-adapter.js +101 -0
  67. package/dist/server/modules/butler/instruction-adapter.js.map +1 -0
  68. package/dist/server/modules/butler/patrol-execution-service.d.ts +47 -0
  69. package/dist/server/modules/butler/patrol-execution-service.js +347 -0
  70. package/dist/server/modules/butler/patrol-execution-service.js.map +1 -0
  71. package/dist/server/modules/butler/patrol-plan-service.d.ts +54 -0
  72. package/dist/server/modules/butler/patrol-plan-service.js +272 -0
  73. package/dist/server/modules/butler/patrol-plan-service.js.map +1 -0
  74. package/dist/server/modules/butler/patrol-run-service.d.ts +60 -0
  75. package/dist/server/modules/butler/patrol-run-service.js +185 -0
  76. package/dist/server/modules/butler/patrol-run-service.js.map +1 -0
  77. package/dist/server/modules/butler/patrol-scheduler.d.ts +36 -0
  78. package/dist/server/modules/butler/patrol-scheduler.js +99 -0
  79. package/dist/server/modules/butler/patrol-scheduler.js.map +1 -0
  80. package/dist/server/modules/butler/project-memory-service.d.ts +30 -0
  81. package/dist/server/modules/butler/project-memory-service.js +103 -0
  82. package/dist/server/modules/butler/project-memory-service.js.map +1 -0
  83. package/dist/server/modules/butler/provider-adapter-registry.d.ts +61 -0
  84. package/dist/server/modules/butler/provider-adapter-registry.js +430 -0
  85. package/dist/server/modules/butler/provider-adapter-registry.js.map +1 -0
  86. package/dist/server/modules/butler/session-summary-instruction-adapter.d.ts +28 -0
  87. package/dist/server/modules/butler/session-summary-instruction-adapter.js +79 -0
  88. package/dist/server/modules/butler/session-summary-instruction-adapter.js.map +1 -0
  89. package/dist/server/modules/butler/session-summary-scheduler.d.ts +23 -0
  90. package/dist/server/modules/butler/session-summary-scheduler.js +57 -0
  91. package/dist/server/modules/butler/session-summary-scheduler.js.map +1 -0
  92. package/dist/server/modules/butler/verification-run-service.d.ts +73 -0
  93. package/dist/server/modules/butler/verification-run-service.js +633 -0
  94. package/dist/server/modules/butler/verification-run-service.js.map +1 -0
  95. package/dist/server/modules/demo/demo-cleanup-service.d.ts +41 -0
  96. package/dist/server/modules/demo/demo-cleanup-service.js +111 -0
  97. package/dist/server/modules/demo/demo-cleanup-service.js.map +1 -0
  98. package/dist/server/modules/preferences/profile-service.js +8 -2
  99. package/dist/server/modules/preferences/profile-service.js.map +1 -1
  100. package/dist/server/modules/sessions/claude-runtime-helper-process.js +1 -1
  101. package/dist/server/modules/sessions/claude-runtime-helper-process.js.map +1 -1
  102. package/dist/server/modules/sessions/codex-app-server-helper-client.d.ts +5 -1
  103. package/dist/server/modules/sessions/codex-app-server-helper-client.js +10 -2
  104. package/dist/server/modules/sessions/codex-app-server-helper-client.js.map +1 -1
  105. package/dist/server/modules/sessions/session-controller.d.ts +3 -1
  106. package/dist/server/modules/sessions/session-controller.js +11 -2
  107. package/dist/server/modules/sessions/session-controller.js.map +1 -1
  108. package/dist/server/modules/sessions/session-history-service.d.ts +14 -1
  109. package/dist/server/modules/sessions/session-history-service.js +291 -30
  110. package/dist/server/modules/sessions/session-history-service.js.map +1 -1
  111. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +25 -2
  112. package/dist/server/modules/sessions/session-live-runtime-service.js +526 -158
  113. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
  114. package/dist/server/modules/sessions/session-provider-error-mapper.js +28 -0
  115. package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -1
  116. package/dist/server/modules/terminal/terminal-service.js +2 -2
  117. package/dist/server/modules/terminal/terminal-service.js.map +1 -1
  118. package/dist/server/modules/workbench/workbench-service.d.ts +7 -1
  119. package/dist/server/modules/workbench/workbench-service.js +31 -7
  120. package/dist/server/modules/workbench/workbench-service.js.map +1 -1
  121. package/dist/server/routes/butler.d.ts +3 -0
  122. package/dist/server/routes/butler.js +54 -0
  123. package/dist/server/routes/butler.js.map +1 -0
  124. package/dist/server/routes/sessions.d.ts +1 -0
  125. package/dist/server/routes/sessions.js +12 -3
  126. package/dist/server/routes/sessions.js.map +1 -1
  127. package/dist/server/server/create-server.d.ts +61 -0
  128. package/dist/server/server/create-server.js +180 -10
  129. package/dist/server/server/create-server.js.map +1 -1
  130. package/dist/server/storage/repositories/butler-control-event-repository.d.ts +8 -0
  131. package/dist/server/storage/repositories/butler-control-event-repository.js +78 -0
  132. package/dist/server/storage/repositories/butler-control-event-repository.js.map +1 -0
  133. package/dist/server/storage/repositories/butler-control-session-repository.d.ts +11 -0
  134. package/dist/server/storage/repositories/butler-control-session-repository.js +86 -0
  135. package/dist/server/storage/repositories/butler-control-session-repository.js.map +1 -0
  136. package/dist/server/storage/repositories/butler-follow-up-task-repository.d.ts +16 -0
  137. package/dist/server/storage/repositories/butler-follow-up-task-repository.js +252 -0
  138. package/dist/server/storage/repositories/butler-follow-up-task-repository.js.map +1 -0
  139. package/dist/server/storage/repositories/butler-inbox-item-repository.d.ts +15 -0
  140. package/dist/server/storage/repositories/butler-inbox-item-repository.js +111 -0
  141. package/dist/server/storage/repositories/butler-inbox-item-repository.js.map +1 -0
  142. package/dist/server/storage/repositories/butler-notification-archive-repository.d.ts +9 -0
  143. package/dist/server/storage/repositories/butler-notification-archive-repository.js +48 -0
  144. package/dist/server/storage/repositories/butler-notification-archive-repository.js.map +1 -0
  145. package/dist/server/storage/repositories/butler-profile-repository.d.ts +9 -0
  146. package/dist/server/storage/repositories/butler-profile-repository.js +86 -0
  147. package/dist/server/storage/repositories/butler-profile-repository.js.map +1 -0
  148. package/dist/server/storage/repositories/butler-project-repository.d.ts +14 -0
  149. package/dist/server/storage/repositories/butler-project-repository.js +140 -0
  150. package/dist/server/storage/repositories/butler-project-repository.js.map +1 -0
  151. package/dist/server/storage/repositories/butler-session-repository.d.ts +11 -0
  152. package/dist/server/storage/repositories/butler-session-repository.js +106 -0
  153. package/dist/server/storage/repositories/butler-session-repository.js.map +1 -0
  154. package/dist/server/storage/repositories/butler-session-summary-state-repository.d.ts +8 -0
  155. package/dist/server/storage/repositories/butler-session-summary-state-repository.js +62 -0
  156. package/dist/server/storage/repositories/butler-session-summary-state-repository.js.map +1 -0
  157. package/dist/server/storage/repositories/patrol-plan-repository.d.ts +27 -0
  158. package/dist/server/storage/repositories/patrol-plan-repository.js +119 -0
  159. package/dist/server/storage/repositories/patrol-plan-repository.js.map +1 -0
  160. package/dist/server/storage/repositories/patrol-run-repository.d.ts +28 -0
  161. package/dist/server/storage/repositories/patrol-run-repository.js +121 -0
  162. package/dist/server/storage/repositories/patrol-run-repository.js.map +1 -0
  163. package/dist/server/storage/repositories/project-memory-repository.d.ts +15 -0
  164. package/dist/server/storage/repositories/project-memory-repository.js +150 -0
  165. package/dist/server/storage/repositories/project-memory-repository.js.map +1 -0
  166. package/dist/server/storage/repositories/session-checkpoint-repository.d.ts +9 -0
  167. package/dist/server/storage/repositories/session-checkpoint-repository.js +72 -0
  168. package/dist/server/storage/repositories/session-checkpoint-repository.js.map +1 -0
  169. package/dist/server/storage/repositories/session-message-origin-repository.d.ts +10 -0
  170. package/dist/server/storage/repositories/session-message-origin-repository.js +93 -0
  171. package/dist/server/storage/repositories/session-message-origin-repository.js.map +1 -0
  172. package/dist/server/storage/repositories/verification-run-repository.d.ts +29 -0
  173. package/dist/server/storage/repositories/verification-run-repository.js +125 -0
  174. package/dist/server/storage/repositories/verification-run-repository.js.map +1 -0
  175. package/dist/server/storage/sqlite/client.js +39 -0
  176. package/dist/server/storage/sqlite/client.js.map +1 -1
  177. package/dist/server/storage/sqlite/schema.sql +324 -0
  178. package/dist/server/types/domain.d.ts +261 -1
  179. package/dist/server/ws/ws-server.d.ts +2 -1
  180. package/dist/server/ws/ws-server.js +2 -1
  181. package/dist/server/ws/ws-server.js.map +1 -1
  182. package/node_modules/@codingns/session-sync-core/dist/index.d.ts +4 -0
  183. package/node_modules/@codingns/session-sync-core/dist/index.js +4 -0
  184. package/node_modules/@codingns/session-sync-core/dist/index.js.map +1 -1
  185. package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.d.ts +18 -0
  186. package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.js +659 -0
  187. package/node_modules/@codingns/session-sync-core/dist/kimi-message-normalizer.js.map +1 -0
  188. package/node_modules/@codingns/session-sync-core/dist/kimi-shared.d.ts +11 -0
  189. package/node_modules/@codingns/session-sync-core/dist/kimi-shared.js +72 -0
  190. package/node_modules/@codingns/session-sync-core/dist/kimi-shared.js.map +1 -0
  191. package/node_modules/@codingns/session-sync-core/dist/patch-builder.d.ts +8 -0
  192. package/node_modules/@codingns/session-sync-core/dist/patch-builder.js +89 -0
  193. package/node_modules/@codingns/session-sync-core/dist/patch-builder.js.map +1 -1
  194. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +4 -1
  195. package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
  196. package/node_modules/@codingns/session-sync-core/dist/providers/gemini.d.ts +41 -0
  197. package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js +1086 -0
  198. package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js.map +1 -0
  199. package/node_modules/@codingns/session-sync-core/dist/providers/kimi.d.ts +29 -0
  200. package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js +578 -0
  201. package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js.map +1 -0
  202. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +2 -1
  203. package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -1
  204. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js +30 -2
  205. package/node_modules/@codingns/session-sync-core/dist/providers/utils.js.map +1 -1
  206. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.d.ts +2 -0
  207. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js +43 -5
  208. package/node_modules/@codingns/session-sync-core/dist/runtime/active-run-registry.js.map +1 -1
  209. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +2 -0
  210. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +320 -69
  211. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
  212. package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.d.ts +21 -0
  213. package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.js +537 -0
  214. package/node_modules/@codingns/session-sync-core/dist/runtime/gemini-runtime.js.map +1 -0
  215. package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.d.ts +38 -0
  216. package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.js +911 -0
  217. package/node_modules/@codingns/session-sync-core/dist/runtime/kimi-runtime.js.map +1 -0
  218. package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.d.ts +6 -0
  219. package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.js +9 -0
  220. package/node_modules/@codingns/session-sync-core/dist/sqlite/node-sqlite.js.map +1 -0
  221. package/node_modules/@codingns/session-sync-core/package.json +8 -0
  222. package/package.json +1 -1
  223. package/dist/public/assets/index-9hnprhO7.css +0 -1
  224. package/dist/public/assets/index-BTpmuKhG.js +0 -108
@@ -0,0 +1,27 @@
1
+ import type Database from "better-sqlite3";
2
+ export interface PatrolPlanRecord {
3
+ id: string;
4
+ projectId: string;
5
+ name: string;
6
+ triggerType: string;
7
+ triggerConfigJson: string;
8
+ executionMode: string;
9
+ patrolScopeJson: string;
10
+ enabled: number;
11
+ lastScheduledAt: string | null;
12
+ nextRunAt: string | null;
13
+ createdAt: string;
14
+ updatedAt: string;
15
+ }
16
+ export declare class PatrolPlanRepository {
17
+ private readonly db;
18
+ constructor(db: Database.Database);
19
+ create(record: PatrolPlanRecord): PatrolPlanRecord;
20
+ listByProject(projectId: string, filters?: {
21
+ enabled?: number;
22
+ executionMode?: string;
23
+ }): PatrolPlanRecord[];
24
+ findById(id: string): PatrolPlanRecord | null;
25
+ listDue(referenceTime: string, limit?: number): PatrolPlanRecord[];
26
+ update(record: PatrolPlanRecord): PatrolPlanRecord | null;
27
+ }
@@ -0,0 +1,119 @@
1
+ export class PatrolPlanRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO patrol_plans (
9
+ id,
10
+ project_id,
11
+ name,
12
+ trigger_type,
13
+ trigger_config_json,
14
+ execution_mode,
15
+ patrol_scope_json,
16
+ enabled,
17
+ last_scheduled_at,
18
+ next_run_at,
19
+ created_at,
20
+ updated_at
21
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
22
+ .run(record.id, record.projectId, record.name, record.triggerType, record.triggerConfigJson, record.executionMode, record.patrolScopeJson, record.enabled, record.lastScheduledAt, record.nextRunAt, record.createdAt, record.updatedAt);
23
+ return record;
24
+ }
25
+ listByProject(projectId, filters) {
26
+ const conditions = ["project_id = ?"];
27
+ const values = [projectId];
28
+ if (filters?.enabled !== undefined) {
29
+ conditions.push("enabled = ?");
30
+ values.push(filters.enabled);
31
+ }
32
+ if (filters?.executionMode) {
33
+ conditions.push("execution_mode = ?");
34
+ values.push(filters.executionMode);
35
+ }
36
+ const where = `WHERE ${conditions.join(" AND ")}`;
37
+ return this.db
38
+ .prepare(`SELECT
39
+ id,
40
+ project_id,
41
+ name,
42
+ trigger_type,
43
+ trigger_config_json,
44
+ execution_mode,
45
+ patrol_scope_json,
46
+ enabled,
47
+ last_scheduled_at,
48
+ next_run_at,
49
+ created_at,
50
+ updated_at
51
+ FROM patrol_plans
52
+ ${where}
53
+ ORDER BY updated_at DESC, created_at DESC`)
54
+ .all(...values)
55
+ .map((row) => row);
56
+ }
57
+ findById(id) {
58
+ const row = this.db
59
+ .prepare(`SELECT
60
+ id,
61
+ project_id,
62
+ name,
63
+ trigger_type,
64
+ trigger_config_json,
65
+ execution_mode,
66
+ patrol_scope_json,
67
+ enabled,
68
+ last_scheduled_at,
69
+ next_run_at,
70
+ created_at,
71
+ updated_at
72
+ FROM patrol_plans
73
+ WHERE id = ?`)
74
+ .get(id);
75
+ return row ?? null;
76
+ }
77
+ listDue(referenceTime, limit = 50) {
78
+ return this.db
79
+ .prepare(`SELECT
80
+ id,
81
+ project_id,
82
+ name,
83
+ trigger_type,
84
+ trigger_config_json,
85
+ execution_mode,
86
+ patrol_scope_json,
87
+ enabled,
88
+ last_scheduled_at,
89
+ next_run_at,
90
+ created_at,
91
+ updated_at
92
+ FROM patrol_plans
93
+ WHERE enabled = 1
94
+ AND trigger_type != 'manual'
95
+ AND next_run_at IS NOT NULL
96
+ AND next_run_at <= ?
97
+ ORDER BY next_run_at ASC, updated_at ASC
98
+ LIMIT ?`)
99
+ .all(referenceTime, limit)
100
+ .map((row) => row);
101
+ }
102
+ update(record) {
103
+ this.db
104
+ .prepare(`UPDATE patrol_plans
105
+ SET name = ?,
106
+ trigger_type = ?,
107
+ trigger_config_json = ?,
108
+ execution_mode = ?,
109
+ patrol_scope_json = ?,
110
+ enabled = ?,
111
+ last_scheduled_at = ?,
112
+ next_run_at = ?,
113
+ updated_at = ?
114
+ WHERE id = ?`)
115
+ .run(record.name, record.triggerType, record.triggerConfigJson, record.executionMode, record.patrolScopeJson, record.enabled, record.lastScheduledAt, record.nextRunAt, record.updatedAt, record.id);
116
+ return this.findById(record.id);
117
+ }
118
+ }
119
+ //# sourceMappingURL=patrol-plan-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"patrol-plan-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/patrol-plan-repository.ts"],"names":[],"mappings":"AAiBA,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;;;;;;;;;;;;;uDAa+C,CAChD;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,OAAO,EACd,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,aAAa,CAAC,SAAiB,EAAE,OAAsD;QACrF,MAAM,UAAU,GAAa,CAAC,gBAAgB,CAAC,CAAC;QAChD,MAAM,MAAM,GAAc,CAAC,SAAS,CAAC,CAAC;QAEtC,IAAI,OAAO,EAAE,OAAO,KAAK,SAAS,EAAE,CAAC;YACnC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC/B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC/B,CAAC;QAED,IAAI,OAAO,EAAE,aAAa,EAAE,CAAC;YAC3B,UAAU,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;YACtC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACrC,CAAC;QAED,MAAM,KAAK,GAAG,SAAS,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;QAElD,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;;;WAcG,KAAK;mDACmC,CAC5C;aACA,GAAG,CAAC,GAAG,MAAM,CAAC;aACd,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAuB,CAAC,CAAC;IAC3C,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;;;sBAcc,CACf;aACA,GAAG,CAAC,EAAE,CAAiC,CAAC;QAE3C,OAAO,GAAG,IAAI,IAAI,CAAC;IACrB,CAAC;IAED,OAAO,CAAC,aAAqB,EAAE,KAAK,GAAG,EAAE;QACvC,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;;;;;;;;iBAmBS,CACV;aACA,GAAG,CAAC,aAAa,EAAE,KAAK,CAAC;aACzB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAuB,CAAC,CAAC;IAC3C,CAAC;IAED,MAAM,CAAC,MAAwB;QAC7B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;sBAUc,CACf;aACA,GAAG,CACF,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,OAAO,EACd,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,EAAE,CACV,CAAC;QAEJ,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC;CACF"}
@@ -0,0 +1,28 @@
1
+ import type Database from "better-sqlite3";
2
+ export interface PatrolRunRecord {
3
+ id: string;
4
+ projectId: string;
5
+ planId: string | null;
6
+ triggeredBy: string;
7
+ triggerRef: string | null;
8
+ butlerSessionId: string | null;
9
+ status: string;
10
+ summary: string | null;
11
+ riskLevel: string | null;
12
+ suggestionsJson: string;
13
+ startedAt: string | null;
14
+ finishedAt: string | null;
15
+ createdAt: string;
16
+ }
17
+ export declare class PatrolRunRepository {
18
+ private readonly db;
19
+ constructor(db: Database.Database);
20
+ create(record: PatrolRunRecord): PatrolRunRecord;
21
+ listByProject(projectId: string, filters?: {
22
+ status?: string;
23
+ triggeredBy?: string;
24
+ }): PatrolRunRecord[];
25
+ findById(id: string): PatrolRunRecord | null;
26
+ listRunningByProject(projectId: string): PatrolRunRecord[];
27
+ update(record: PatrolRunRecord): PatrolRunRecord | null;
28
+ }
@@ -0,0 +1,121 @@
1
+ export class PatrolRunRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO patrol_runs (
9
+ id,
10
+ project_id,
11
+ plan_id,
12
+ triggered_by,
13
+ trigger_ref,
14
+ butler_session_id,
15
+ status,
16
+ summary,
17
+ risk_level,
18
+ suggestions_json,
19
+ started_at,
20
+ finished_at,
21
+ created_at
22
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
23
+ .run(record.id, record.projectId, record.planId, record.triggeredBy, record.triggerRef, record.butlerSessionId, record.status, record.summary, record.riskLevel, record.suggestionsJson, record.startedAt, record.finishedAt, record.createdAt);
24
+ return record;
25
+ }
26
+ listByProject(projectId, filters) {
27
+ const conditions = ["project_id = ?"];
28
+ const values = [projectId];
29
+ if (filters?.status) {
30
+ conditions.push("status = ?");
31
+ values.push(filters.status);
32
+ }
33
+ if (filters?.triggeredBy) {
34
+ conditions.push("triggered_by = ?");
35
+ values.push(filters.triggeredBy);
36
+ }
37
+ const where = `WHERE ${conditions.join(" AND ")}`;
38
+ return this.db
39
+ .prepare(`SELECT
40
+ id,
41
+ project_id,
42
+ plan_id,
43
+ triggered_by,
44
+ trigger_ref,
45
+ butler_session_id,
46
+ status,
47
+ summary,
48
+ risk_level,
49
+ suggestions_json,
50
+ started_at,
51
+ finished_at,
52
+ created_at
53
+ FROM patrol_runs
54
+ ${where}
55
+ ORDER BY created_at DESC`)
56
+ .all(...values)
57
+ .map((row) => row);
58
+ }
59
+ findById(id) {
60
+ const row = this.db
61
+ .prepare(`SELECT
62
+ id,
63
+ project_id,
64
+ plan_id,
65
+ triggered_by,
66
+ trigger_ref,
67
+ butler_session_id,
68
+ status,
69
+ summary,
70
+ risk_level,
71
+ suggestions_json,
72
+ started_at,
73
+ finished_at,
74
+ created_at
75
+ FROM patrol_runs
76
+ WHERE id = ?`)
77
+ .get(id);
78
+ return row ?? null;
79
+ }
80
+ listRunningByProject(projectId) {
81
+ return this.db
82
+ .prepare(`SELECT
83
+ id,
84
+ project_id,
85
+ plan_id,
86
+ triggered_by,
87
+ trigger_ref,
88
+ butler_session_id,
89
+ status,
90
+ summary,
91
+ risk_level,
92
+ suggestions_json,
93
+ started_at,
94
+ finished_at,
95
+ created_at
96
+ FROM patrol_runs
97
+ WHERE project_id = ?
98
+ AND status = 'running'
99
+ ORDER BY created_at DESC`)
100
+ .all(projectId)
101
+ .map((row) => row);
102
+ }
103
+ update(record) {
104
+ this.db
105
+ .prepare(`UPDATE patrol_runs
106
+ SET plan_id = ?,
107
+ triggered_by = ?,
108
+ trigger_ref = ?,
109
+ butler_session_id = ?,
110
+ status = ?,
111
+ summary = ?,
112
+ risk_level = ?,
113
+ suggestions_json = ?,
114
+ started_at = ?,
115
+ finished_at = ?
116
+ WHERE id = ?`)
117
+ .run(record.planId, record.triggeredBy, record.triggerRef, record.butlerSessionId, record.status, record.summary, record.riskLevel, record.suggestionsJson, record.startedAt, record.finishedAt, record.id);
118
+ return this.findById(record.id);
119
+ }
120
+ }
121
+ //# sourceMappingURL=patrol-run-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"patrol-run-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/patrol-run-repository.ts"],"names":[],"mappings":"AAkBA,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;;;;;;;;;;;;;;0DAckD,CACnD;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,OAAO,EACd,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,aAAa,CAAC,SAAiB,EAAE,OAAmD;QAClF,MAAM,UAAU,GAAa,CAAC,gBAAgB,CAAC,CAAC;QAChD,MAAM,MAAM,GAAc,CAAC,SAAS,CAAC,CAAC;QAEtC,IAAI,OAAO,EAAE,MAAM,EAAE,CAAC;YACpB,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC9B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAC9B,CAAC;QAED,IAAI,OAAO,EAAE,WAAW,EAAE,CAAC;YACzB,UAAU,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YACpC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACnC,CAAC;QAED,MAAM,KAAK,GAAG,SAAS,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;QAElD,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;;;;WAeG,KAAK;kCACkB,CAC3B;aACA,GAAG,CAAC,GAAG,MAAM,CAAC;aACd,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAsB,CAAC,CAAC;IAC1C,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;;;;sBAec,CACf;aACA,GAAG,CAAC,EAAE,CAAgC,CAAC;QAE1C,OAAO,GAAG,IAAI,IAAI,CAAC;IACrB,CAAC;IAED,oBAAoB,CAAC,SAAiB;QACpC,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;;;;;;kCAiB0B,CAC3B;aACA,GAAG,CAAC,SAAS,CAAC;aACd,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAsB,CAAC,CAAC;IAC1C,CAAC;IAED,MAAM,CAAC,MAAuB;QAC5B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;sBAWc,CACf;aACA,GAAG,CACF,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,OAAO,EACd,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,EAAE,CACV,CAAC;QAEJ,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClC,CAAC;CACF"}
@@ -0,0 +1,15 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { ProjectMemory, ProjectMemoryStatus, ProjectMemoryType } from "../../types/domain.js";
3
+ export declare class ProjectMemoryRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: ProjectMemory): ProjectMemory;
7
+ listByProject(projectId: string, filters?: {
8
+ status?: ProjectMemoryStatus;
9
+ memoryType?: ProjectMemoryType;
10
+ scopePath?: string;
11
+ query?: string;
12
+ }): ProjectMemory[];
13
+ findById(id: string): ProjectMemory | null;
14
+ update(record: ProjectMemory): ProjectMemory;
15
+ }
@@ -0,0 +1,150 @@
1
+ export class ProjectMemoryRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO project_memories (
9
+ id,
10
+ project_id,
11
+ source_butler_session_id,
12
+ source_checkpoint_id,
13
+ memory_type,
14
+ title,
15
+ scope_path,
16
+ content,
17
+ tags_json,
18
+ confidence,
19
+ status,
20
+ evidence_json,
21
+ superseded_by,
22
+ created_at,
23
+ updated_at
24
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
25
+ .run(record.id, record.projectId, record.sourceButlerSessionId, record.sourceCheckpointId, record.memoryType, record.title, record.scopePath, record.content, JSON.stringify(record.tags), record.confidence, record.status, JSON.stringify(record.evidence), record.supersededBy, record.createdAt, record.updatedAt);
26
+ return record;
27
+ }
28
+ listByProject(projectId, filters) {
29
+ const conditions = ["project_id = ?"];
30
+ const values = [projectId];
31
+ if (filters?.status) {
32
+ conditions.push("status = ?");
33
+ values.push(filters.status);
34
+ }
35
+ if (filters?.memoryType) {
36
+ conditions.push("memory_type = ?");
37
+ values.push(filters.memoryType);
38
+ }
39
+ if (filters?.scopePath) {
40
+ conditions.push("scope_path LIKE ?");
41
+ values.push(`${filters.scopePath}%`);
42
+ }
43
+ if (filters?.query) {
44
+ const pattern = `%${filters.query.replace(/%/g, "\\%")}%`;
45
+ conditions.push("(title LIKE ? OR content LIKE ?)");
46
+ values.push(pattern, pattern);
47
+ }
48
+ const whereClause = `WHERE ${conditions.join(" AND ")}`;
49
+ return this.db
50
+ .prepare(`SELECT
51
+ id,
52
+ project_id,
53
+ source_butler_session_id,
54
+ source_checkpoint_id,
55
+ memory_type,
56
+ title,
57
+ scope_path,
58
+ content,
59
+ tags_json,
60
+ confidence,
61
+ status,
62
+ evidence_json,
63
+ superseded_by,
64
+ created_at,
65
+ updated_at
66
+ FROM project_memories
67
+ ${whereClause}
68
+ ORDER BY updated_at DESC, created_at DESC`)
69
+ .all(...values)
70
+ .map((row) => mapProjectMemoryRow(row));
71
+ }
72
+ findById(id) {
73
+ const row = this.db
74
+ .prepare(`SELECT
75
+ id,
76
+ project_id,
77
+ source_butler_session_id,
78
+ source_checkpoint_id,
79
+ memory_type,
80
+ title,
81
+ scope_path,
82
+ content,
83
+ tags_json,
84
+ confidence,
85
+ status,
86
+ evidence_json,
87
+ superseded_by,
88
+ created_at,
89
+ updated_at
90
+ FROM project_memories
91
+ WHERE id = ?`)
92
+ .get(id);
93
+ return row ? mapProjectMemoryRow(row) : null;
94
+ }
95
+ update(record) {
96
+ this.db
97
+ .prepare(`UPDATE project_memories
98
+ SET
99
+ title = ?,
100
+ scope_path = ?,
101
+ content = ?,
102
+ tags_json = ?,
103
+ confidence = ?,
104
+ status = ?,
105
+ evidence_json = ?,
106
+ superseded_by = ?,
107
+ updated_at = ?
108
+ WHERE id = ?`)
109
+ .run(record.title, record.scopePath, record.content, JSON.stringify(record.tags), record.confidence, record.status, JSON.stringify(record.evidence), record.supersededBy, record.updatedAt, record.id);
110
+ return record;
111
+ }
112
+ }
113
+ function mapProjectMemoryRow(row) {
114
+ return {
115
+ id: row.id,
116
+ projectId: row.project_id,
117
+ sourceButlerSessionId: row.source_butler_session_id,
118
+ sourceCheckpointId: row.source_checkpoint_id,
119
+ memoryType: row.memory_type,
120
+ title: row.title,
121
+ scopePath: row.scope_path,
122
+ content: row.content,
123
+ tags: parseJsonArray(row.tags_json),
124
+ confidence: row.confidence,
125
+ status: row.status,
126
+ evidence: parseJsonObject(row.evidence_json),
127
+ supersededBy: row.superseded_by,
128
+ createdAt: row.created_at,
129
+ updatedAt: row.updated_at
130
+ };
131
+ }
132
+ function parseJsonArray(raw) {
133
+ try {
134
+ const parsed = JSON.parse(raw);
135
+ return Array.isArray(parsed) ? parsed.filter((item) => typeof item === "string") : [];
136
+ }
137
+ catch {
138
+ return [];
139
+ }
140
+ }
141
+ function parseJsonObject(raw) {
142
+ try {
143
+ const parsed = JSON.parse(raw);
144
+ return parsed && typeof parsed === "object" && !Array.isArray(parsed) ? parsed : {};
145
+ }
146
+ catch {
147
+ return {};
148
+ }
149
+ }
150
+ //# sourceMappingURL=project-memory-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"project-memory-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/project-memory-repository.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SessionCheckpoint } from "../../types/domain.js";
3
+ export declare class SessionCheckpointRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ create(record: SessionCheckpoint): SessionCheckpoint;
7
+ listByButlerSessionId(butlerSessionId: string, limit?: number): SessionCheckpoint[];
8
+ getLatestSeq(butlerSessionId: string): number;
9
+ }
@@ -0,0 +1,72 @@
1
+ export class SessionCheckpointRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ create(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO session_checkpoints (
9
+ id,
10
+ butler_session_id,
11
+ checkpoint_seq,
12
+ source_kind,
13
+ progress_state,
14
+ summary,
15
+ risk_flags_json,
16
+ next_action_json,
17
+ captured_at
18
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`)
19
+ .run(record.id, record.butlerSessionId, record.checkpointSeq, record.sourceKind, record.progressState, record.summary, JSON.stringify(record.riskFlags), JSON.stringify(record.nextActions), record.capturedAt);
20
+ return record;
21
+ }
22
+ listByButlerSessionId(butlerSessionId, limit = 20) {
23
+ return this.db
24
+ .prepare(`SELECT
25
+ id,
26
+ butler_session_id,
27
+ checkpoint_seq,
28
+ source_kind,
29
+ progress_state,
30
+ summary,
31
+ risk_flags_json,
32
+ next_action_json,
33
+ captured_at
34
+ FROM session_checkpoints
35
+ WHERE butler_session_id = ?
36
+ ORDER BY checkpoint_seq DESC
37
+ LIMIT ?`)
38
+ .all(butlerSessionId, limit)
39
+ .map((row) => mapSessionCheckpointRow(row));
40
+ }
41
+ getLatestSeq(butlerSessionId) {
42
+ const row = this.db
43
+ .prepare(`SELECT MAX(checkpoint_seq) AS checkpoint_seq
44
+ FROM session_checkpoints
45
+ WHERE butler_session_id = ?`)
46
+ .get(butlerSessionId);
47
+ return row?.checkpoint_seq ?? 0;
48
+ }
49
+ }
50
+ function mapSessionCheckpointRow(row) {
51
+ return {
52
+ id: row.id,
53
+ butlerSessionId: row.butler_session_id,
54
+ checkpointSeq: row.checkpoint_seq,
55
+ sourceKind: row.source_kind,
56
+ progressState: row.progress_state,
57
+ summary: row.summary,
58
+ riskFlags: parseJsonArray(row.risk_flags_json),
59
+ nextActions: parseJsonArray(row.next_action_json),
60
+ capturedAt: row.captured_at
61
+ };
62
+ }
63
+ function parseJsonArray(raw) {
64
+ try {
65
+ const parsed = JSON.parse(raw);
66
+ return Array.isArray(parsed) ? parsed.filter((item) => typeof item === "string") : [];
67
+ }
68
+ catch {
69
+ return [];
70
+ }
71
+ }
72
+ //# sourceMappingURL=session-checkpoint-repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-checkpoint-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/session-checkpoint-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAAyB;QAC9B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;8CAUsC,CACvC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,OAAO,EACd,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,EAChC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,EAClC,MAAM,CAAC,UAAU,CAClB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,qBAAqB,CAAC,eAAuB,EAAE,KAAK,GAAG,EAAE;QACvD,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;;iBAaS,CACV;aACA,GAAG,CAAC,eAAe,EAAE,KAAK,CAAC;aAC3B,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,uBAAuB,CAAC,GAA2B,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,YAAY,CAAC,eAAuB;QAClC,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;qCAE6B,CAC9B;aACA,GAAG,CAAC,eAAe,CAAkD,CAAC;QAEzE,OAAO,GAAG,EAAE,cAAc,IAAI,CAAC,CAAC;IAClC,CAAC;CACF;AAcD,SAAS,uBAAuB,CAAC,GAAyB;IACxD,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,eAAe,EAAE,GAAG,CAAC,iBAAiB;QACtC,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,OAAO,EAAE,GAAG,CAAC,OAAO;QACpB,SAAS,EAAE,cAAc,CAAC,GAAG,CAAC,eAAe,CAAC;QAC9C,WAAW,EAAE,cAAc,CAAC,GAAG,CAAC,gBAAgB,CAAC;QACjD,UAAU,EAAE,GAAG,CAAC,WAAW;KAC5B,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,GAAW;IACjC,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAY,CAAC;QAC1C,OAAO,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,EAAkB,EAAE,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACxG,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type Database from "better-sqlite3";
2
+ import type { SessionMessageOriginRecord } from "../../types/domain.js";
3
+ export declare class SessionMessageOriginRepository {
4
+ private readonly db;
5
+ constructor(db: Database.Database);
6
+ upsert(record: SessionMessageOriginRecord): void;
7
+ resolveMessageId(sessionId: string, clientRequestId: string, messageId: string, updatedAt: string): void;
8
+ listBySessionAndMessageIds(sessionId: string, messageIds: string[]): SessionMessageOriginRecord[];
9
+ listUnresolvedBySessionAndContents(sessionId: string, contents: string[]): SessionMessageOriginRecord[];
10
+ }
@@ -0,0 +1,93 @@
1
+ export class SessionMessageOriginRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ upsert(record) {
7
+ this.db
8
+ .prepare(`INSERT INTO session_message_origins (
9
+ session_id,
10
+ client_request_id,
11
+ message_id,
12
+ origin,
13
+ origin_ref,
14
+ content,
15
+ created_at,
16
+ updated_at
17
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?)
18
+ ON CONFLICT(session_id, client_request_id) DO UPDATE SET
19
+ message_id = excluded.message_id,
20
+ origin = excluded.origin,
21
+ origin_ref = excluded.origin_ref,
22
+ content = excluded.content,
23
+ updated_at = excluded.updated_at`)
24
+ .run(record.sessionId, record.clientRequestId, record.messageId, record.origin, record.originRef, record.content, record.createdAt, record.updatedAt);
25
+ }
26
+ resolveMessageId(sessionId, clientRequestId, messageId, updatedAt) {
27
+ this.db
28
+ .prepare(`UPDATE session_message_origins
29
+ SET message_id = ?,
30
+ updated_at = ?
31
+ WHERE session_id = ?
32
+ AND client_request_id = ?`)
33
+ .run(messageId, updatedAt, sessionId, clientRequestId);
34
+ }
35
+ listBySessionAndMessageIds(sessionId, messageIds) {
36
+ if (messageIds.length === 0) {
37
+ return [];
38
+ }
39
+ const placeholders = messageIds.map(() => "?").join(", ");
40
+ const rows = this.db
41
+ .prepare(`SELECT
42
+ session_id,
43
+ client_request_id,
44
+ message_id,
45
+ origin,
46
+ origin_ref,
47
+ content,
48
+ created_at,
49
+ updated_at
50
+ FROM session_message_origins
51
+ WHERE session_id = ?
52
+ AND message_id IN (${placeholders})
53
+ ORDER BY updated_at DESC`)
54
+ .all(sessionId, ...messageIds);
55
+ return rows.map(mapRow);
56
+ }
57
+ listUnresolvedBySessionAndContents(sessionId, contents) {
58
+ if (contents.length === 0) {
59
+ return [];
60
+ }
61
+ const placeholders = contents.map(() => "?").join(", ");
62
+ const rows = this.db
63
+ .prepare(`SELECT
64
+ session_id,
65
+ client_request_id,
66
+ message_id,
67
+ origin,
68
+ origin_ref,
69
+ content,
70
+ created_at,
71
+ updated_at
72
+ FROM session_message_origins
73
+ WHERE session_id = ?
74
+ AND message_id IS NULL
75
+ AND content IN (${placeholders})
76
+ ORDER BY created_at ASC, updated_at ASC`)
77
+ .all(sessionId, ...contents);
78
+ return rows.map(mapRow);
79
+ }
80
+ }
81
+ function mapRow(row) {
82
+ return {
83
+ sessionId: row.session_id,
84
+ clientRequestId: row.client_request_id,
85
+ messageId: row.message_id,
86
+ origin: row.origin,
87
+ originRef: row.origin_ref,
88
+ content: row.content,
89
+ createdAt: row.created_at,
90
+ updatedAt: row.updated_at
91
+ };
92
+ }
93
+ //# sourceMappingURL=session-message-origin-repository.js.map