@agent-native/core 0.7.19 → 0.7.21

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 (263) hide show
  1. package/README.md +1 -1
  2. package/dist/agent/engine/builder-engine.d.ts.map +1 -1
  3. package/dist/agent/engine/builder-engine.js +45 -2
  4. package/dist/agent/engine/builder-engine.js.map +1 -1
  5. package/dist/agent/loop-settings.d.ts +37 -0
  6. package/dist/agent/loop-settings.d.ts.map +1 -0
  7. package/dist/agent/loop-settings.js +127 -0
  8. package/dist/agent/loop-settings.js.map +1 -0
  9. package/dist/agent/production-agent.d.ts +8 -0
  10. package/dist/agent/production-agent.d.ts.map +1 -1
  11. package/dist/agent/production-agent.js +268 -29
  12. package/dist/agent/production-agent.js.map +1 -1
  13. package/dist/agent/run-manager.d.ts.map +1 -1
  14. package/dist/agent/run-manager.js +76 -3
  15. package/dist/agent/run-manager.js.map +1 -1
  16. package/dist/agent/run-store.d.ts +1 -1
  17. package/dist/agent/run-store.d.ts.map +1 -1
  18. package/dist/agent/run-store.js +65 -2
  19. package/dist/agent/run-store.js.map +1 -1
  20. package/dist/agent/thread-data-builder.d.ts +3 -0
  21. package/dist/agent/thread-data-builder.d.ts.map +1 -1
  22. package/dist/agent/thread-data-builder.js +52 -10
  23. package/dist/agent/thread-data-builder.js.map +1 -1
  24. package/dist/agent/tool-search.d.ts +37 -0
  25. package/dist/agent/tool-search.d.ts.map +1 -0
  26. package/dist/agent/tool-search.js +201 -0
  27. package/dist/agent/tool-search.js.map +1 -0
  28. package/dist/agent/types.d.ts +8 -1
  29. package/dist/agent/types.d.ts.map +1 -1
  30. package/dist/agent/types.js.map +1 -1
  31. package/dist/cli/create.d.ts.map +1 -1
  32. package/dist/cli/create.js +44 -9
  33. package/dist/cli/create.js.map +1 -1
  34. package/dist/cli/workspacify.d.ts +2 -0
  35. package/dist/cli/workspacify.d.ts.map +1 -1
  36. package/dist/cli/workspacify.js +34 -1
  37. package/dist/cli/workspacify.js.map +1 -1
  38. package/dist/client/AssistantChat.d.ts.map +1 -1
  39. package/dist/client/AssistantChat.js +277 -18
  40. package/dist/client/AssistantChat.js.map +1 -1
  41. package/dist/client/ConnectBuilderCard.d.ts.map +1 -1
  42. package/dist/client/ConnectBuilderCard.js +1 -1
  43. package/dist/client/ConnectBuilderCard.js.map +1 -1
  44. package/dist/client/MultiTabAssistantChat.d.ts.map +1 -1
  45. package/dist/client/MultiTabAssistantChat.js +14 -6
  46. package/dist/client/MultiTabAssistantChat.js.map +1 -1
  47. package/dist/client/NewWorkspaceAppFlow.d.ts +14 -0
  48. package/dist/client/NewWorkspaceAppFlow.d.ts.map +1 -0
  49. package/dist/client/NewWorkspaceAppFlow.js +198 -0
  50. package/dist/client/NewWorkspaceAppFlow.js.map +1 -0
  51. package/dist/client/PoweredByBadge.d.ts +10 -1
  52. package/dist/client/PoweredByBadge.d.ts.map +1 -1
  53. package/dist/client/PoweredByBadge.js +120 -8
  54. package/dist/client/PoweredByBadge.js.map +1 -1
  55. package/dist/client/agent-chat-adapter.d.ts +3 -5
  56. package/dist/client/agent-chat-adapter.d.ts.map +1 -1
  57. package/dist/client/agent-chat-adapter.js +26 -19
  58. package/dist/client/agent-chat-adapter.js.map +1 -1
  59. package/dist/client/agent-chat.d.ts.map +1 -1
  60. package/dist/client/agent-chat.js +15 -3
  61. package/dist/client/agent-chat.js.map +1 -1
  62. package/dist/client/analytics.d.ts +1 -1
  63. package/dist/client/analytics.d.ts.map +1 -1
  64. package/dist/client/analytics.js +141 -1
  65. package/dist/client/analytics.js.map +1 -1
  66. package/dist/client/builder-frame.d.ts +10 -0
  67. package/dist/client/builder-frame.d.ts.map +1 -0
  68. package/dist/client/builder-frame.js +94 -0
  69. package/dist/client/builder-frame.js.map +1 -0
  70. package/dist/client/composer/MentionPopover.d.ts.map +1 -1
  71. package/dist/client/composer/MentionPopover.js +5 -1
  72. package/dist/client/composer/MentionPopover.js.map +1 -1
  73. package/dist/client/composer/TiptapComposer.d.ts.map +1 -1
  74. package/dist/client/composer/TiptapComposer.js +11 -6
  75. package/dist/client/composer/TiptapComposer.js.map +1 -1
  76. package/dist/client/error-format.d.ts +20 -1
  77. package/dist/client/error-format.d.ts.map +1 -1
  78. package/dist/client/error-format.js +53 -5
  79. package/dist/client/error-format.js.map +1 -1
  80. package/dist/client/index.d.ts +3 -1
  81. package/dist/client/index.d.ts.map +1 -1
  82. package/dist/client/index.js +3 -1
  83. package/dist/client/index.js.map +1 -1
  84. package/dist/client/notifications/NotificationsBell.d.ts.map +1 -1
  85. package/dist/client/notifications/NotificationsBell.js +28 -1
  86. package/dist/client/notifications/NotificationsBell.js.map +1 -1
  87. package/dist/client/onboarding/OnboardingPanel.d.ts.map +1 -1
  88. package/dist/client/onboarding/OnboardingPanel.js +88 -6
  89. package/dist/client/onboarding/OnboardingPanel.js.map +1 -1
  90. package/dist/client/settings/SettingsPanel.d.ts.map +1 -1
  91. package/dist/client/settings/SettingsPanel.js +145 -9
  92. package/dist/client/settings/SettingsPanel.js.map +1 -1
  93. package/dist/client/settings/useBuilderStatus.d.ts +13 -0
  94. package/dist/client/settings/useBuilderStatus.d.ts.map +1 -1
  95. package/dist/client/settings/useBuilderStatus.js +50 -9
  96. package/dist/client/settings/useBuilderStatus.js.map +1 -1
  97. package/dist/client/sse-event-processor.d.ts +3 -0
  98. package/dist/client/sse-event-processor.d.ts.map +1 -1
  99. package/dist/client/sse-event-processor.js +88 -7
  100. package/dist/client/sse-event-processor.js.map +1 -1
  101. package/dist/client/tools/ToolsListPage.d.ts.map +1 -1
  102. package/dist/client/tools/ToolsListPage.js +16 -1
  103. package/dist/client/tools/ToolsListPage.js.map +1 -1
  104. package/dist/client/tools/ToolsSidebarSection.d.ts.map +1 -1
  105. package/dist/client/tools/ToolsSidebarSection.js +63 -8
  106. package/dist/client/tools/ToolsSidebarSection.js.map +1 -1
  107. package/dist/client/tools/tool-order.d.ts +7 -0
  108. package/dist/client/tools/tool-order.d.ts.map +1 -0
  109. package/dist/client/tools/tool-order.js +47 -0
  110. package/dist/client/tools/tool-order.js.map +1 -0
  111. package/dist/client/transcription/BuilderTranscriptionCta.d.ts.map +1 -1
  112. package/dist/client/transcription/BuilderTranscriptionCta.js +71 -6
  113. package/dist/client/transcription/BuilderTranscriptionCta.js.map +1 -1
  114. package/dist/client/use-send-to-agent-chat.d.ts.map +1 -1
  115. package/dist/client/use-send-to-agent-chat.js +11 -3
  116. package/dist/client/use-send-to-agent-chat.js.map +1 -1
  117. package/dist/client/useProductionAgent.d.ts.map +1 -1
  118. package/dist/client/useProductionAgent.js +1 -1
  119. package/dist/client/useProductionAgent.js.map +1 -1
  120. package/dist/db/client.d.ts.map +1 -1
  121. package/dist/db/client.js +5 -1
  122. package/dist/db/client.js.map +1 -1
  123. package/dist/deploy/build.d.ts +1 -0
  124. package/dist/deploy/build.d.ts.map +1 -1
  125. package/dist/deploy/build.js +4 -1
  126. package/dist/deploy/build.js.map +1 -1
  127. package/dist/oauth-tokens/index.d.ts +1 -1
  128. package/dist/oauth-tokens/index.d.ts.map +1 -1
  129. package/dist/oauth-tokens/index.js +1 -1
  130. package/dist/oauth-tokens/index.js.map +1 -1
  131. package/dist/oauth-tokens/store.d.ts.map +1 -1
  132. package/dist/oauth-tokens/store.js +6 -0
  133. package/dist/oauth-tokens/store.js.map +1 -1
  134. package/dist/observability/store.d.ts.map +1 -1
  135. package/dist/observability/store.js +19 -19
  136. package/dist/observability/store.js.map +1 -1
  137. package/dist/onboarding/default-steps.d.ts.map +1 -1
  138. package/dist/onboarding/default-steps.js +95 -61
  139. package/dist/onboarding/default-steps.js.map +1 -1
  140. package/dist/onboarding/plugin.d.ts.map +1 -1
  141. package/dist/onboarding/plugin.js +17 -8
  142. package/dist/onboarding/plugin.js.map +1 -1
  143. package/dist/org/migrations.js +2 -2
  144. package/dist/org/migrations.js.map +1 -1
  145. package/dist/scripts/agent-engines/list-agent-engines.d.ts.map +1 -1
  146. package/dist/scripts/agent-engines/list-agent-engines.js +2 -3
  147. package/dist/scripts/agent-engines/list-agent-engines.js.map +1 -1
  148. package/dist/scripts/db/exec.d.ts +2 -1
  149. package/dist/scripts/db/exec.d.ts.map +1 -1
  150. package/dist/scripts/db/exec.js +264 -61
  151. package/dist/scripts/db/exec.js.map +1 -1
  152. package/dist/scripts/db/schema.d.ts.map +1 -1
  153. package/dist/scripts/db/schema.js +16 -4
  154. package/dist/scripts/db/schema.js.map +1 -1
  155. package/dist/scripts/dev/index.d.ts.map +1 -1
  156. package/dist/scripts/dev/index.js +36 -11
  157. package/dist/scripts/dev/index.js.map +1 -1
  158. package/dist/scripts/manage-agent-loop-settings.d.ts +7 -0
  159. package/dist/scripts/manage-agent-loop-settings.d.ts.map +1 -0
  160. package/dist/scripts/manage-agent-loop-settings.js +63 -0
  161. package/dist/scripts/manage-agent-loop-settings.js.map +1 -0
  162. package/dist/scripts/runner.d.ts.map +1 -1
  163. package/dist/scripts/runner.js +11 -0
  164. package/dist/scripts/runner.js.map +1 -1
  165. package/dist/server/agent-chat-plugin.d.ts.map +1 -1
  166. package/dist/server/agent-chat-plugin.js +60 -18
  167. package/dist/server/agent-chat-plugin.js.map +1 -1
  168. package/dist/server/app-url.d.ts +5 -4
  169. package/dist/server/app-url.d.ts.map +1 -1
  170. package/dist/server/app-url.js +8 -4
  171. package/dist/server/app-url.js.map +1 -1
  172. package/dist/server/auth.d.ts +8 -0
  173. package/dist/server/auth.d.ts.map +1 -1
  174. package/dist/server/auth.js +82 -29
  175. package/dist/server/auth.js.map +1 -1
  176. package/dist/server/better-auth-instance.d.ts.map +1 -1
  177. package/dist/server/better-auth-instance.js +16 -5
  178. package/dist/server/better-auth-instance.js.map +1 -1
  179. package/dist/server/builder-browser.d.ts +12 -0
  180. package/dist/server/builder-browser.d.ts.map +1 -1
  181. package/dist/server/builder-browser.js +36 -4
  182. package/dist/server/builder-browser.js.map +1 -1
  183. package/dist/server/core-routes-plugin.d.ts.map +1 -1
  184. package/dist/server/core-routes-plugin.js +350 -53
  185. package/dist/server/core-routes-plugin.js.map +1 -1
  186. package/dist/server/credential-provider.d.ts +21 -3
  187. package/dist/server/credential-provider.d.ts.map +1 -1
  188. package/dist/server/credential-provider.js +51 -21
  189. package/dist/server/credential-provider.js.map +1 -1
  190. package/dist/server/google-oauth.d.ts +3 -0
  191. package/dist/server/google-oauth.d.ts.map +1 -1
  192. package/dist/server/google-oauth.js +27 -3
  193. package/dist/server/google-oauth.js.map +1 -1
  194. package/dist/server/index.d.ts +4 -3
  195. package/dist/server/index.d.ts.map +1 -1
  196. package/dist/server/index.js +4 -3
  197. package/dist/server/index.js.map +1 -1
  198. package/dist/server/onboarding-html.js +2 -2
  199. package/dist/server/onboarding-html.js.map +1 -1
  200. package/dist/server/schema-prompt.d.ts.map +1 -1
  201. package/dist/server/schema-prompt.js +2 -1
  202. package/dist/server/schema-prompt.js.map +1 -1
  203. package/dist/server/security-headers.d.ts +3 -0
  204. package/dist/server/security-headers.d.ts.map +1 -1
  205. package/dist/server/security-headers.js +7 -1
  206. package/dist/server/security-headers.js.map +1 -1
  207. package/dist/server/ssr-handler.d.ts.map +1 -1
  208. package/dist/server/ssr-handler.js +31 -6
  209. package/dist/server/ssr-handler.js.map +1 -1
  210. package/dist/templates/default/_gitignore +5 -1
  211. package/dist/templates/default/app/root.tsx +1 -0
  212. package/dist/templates/default/public/favicon.svg +3 -3
  213. package/dist/templates/default/public/icon-180.svg +3 -3
  214. package/dist/templates/default/public/icon-192.svg +3 -3
  215. package/dist/templates/default/public/icon-512.svg +3 -3
  216. package/dist/templates/workspace-core/AGENTS.md +23 -7
  217. package/dist/templates/workspace-core/package.json +2 -1
  218. package/dist/templates/workspace-core/src/credentials.ts +22 -11
  219. package/dist/templates/workspace-root/.env.example +7 -0
  220. package/dist/templates/workspace-root/README.md +6 -3
  221. package/dist/templates/workspace-root/_gitignore +3 -0
  222. package/dist/templates/workspace-root/package.json +3 -1
  223. package/dist/templates/workspace-root/scripts/workspace-dev.ts +375 -0
  224. package/dist/tools/actions.d.ts.map +1 -1
  225. package/dist/tools/actions.js +2 -0
  226. package/dist/tools/actions.js.map +1 -1
  227. package/dist/tools/html-shell.d.ts.map +1 -1
  228. package/dist/tools/html-shell.js +13 -1
  229. package/dist/tools/html-shell.js.map +1 -1
  230. package/dist/tools/store.d.ts.map +1 -1
  231. package/dist/tools/store.js +10 -10
  232. package/dist/tools/store.js.map +1 -1
  233. package/dist/tracking/providers.d.ts +1 -0
  234. package/dist/tracking/providers.d.ts.map +1 -1
  235. package/dist/tracking/providers.js +72 -0
  236. package/dist/tracking/providers.js.map +1 -1
  237. package/dist/vite/action-types-plugin.d.ts.map +1 -1
  238. package/dist/vite/action-types-plugin.js +106 -9
  239. package/dist/vite/action-types-plugin.js.map +1 -1
  240. package/dist/vite/client.d.ts.map +1 -1
  241. package/dist/vite/client.js +62 -1
  242. package/dist/vite/client.js.map +1 -1
  243. package/docs/content/authentication.md +17 -13
  244. package/docs/content/deployment.md +11 -11
  245. package/docs/content/mcp-clients.md +2 -2
  246. package/docs/content/onboarding.md +32 -30
  247. package/docs/content/security.md +1 -1
  248. package/docs/content/tools.md +4 -0
  249. package/package.json +2 -2
  250. package/src/templates/default/_gitignore +5 -1
  251. package/src/templates/default/app/root.tsx +1 -0
  252. package/src/templates/default/public/favicon.svg +3 -3
  253. package/src/templates/default/public/icon-180.svg +3 -3
  254. package/src/templates/default/public/icon-192.svg +3 -3
  255. package/src/templates/default/public/icon-512.svg +3 -3
  256. package/src/templates/workspace-core/AGENTS.md +23 -7
  257. package/src/templates/workspace-core/package.json +2 -1
  258. package/src/templates/workspace-core/src/credentials.ts +22 -11
  259. package/src/templates/workspace-root/.env.example +7 -0
  260. package/src/templates/workspace-root/README.md +6 -3
  261. package/src/templates/workspace-root/_gitignore +3 -0
  262. package/src/templates/workspace-root/package.json +3 -1
  263. package/src/templates/workspace-root/scripts/workspace-dev.ts +375 -0
@@ -1 +1 @@
1
- {"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/observability/store.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/observability/store.ts"],"names":[],"mappings":"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"}
@@ -6,7 +6,7 @@
6
6
  * run-store.ts and usage/store.ts — framework tables use getDbExec()
7
7
  * rather than Drizzle ORM (which is for template-level schemas).
8
8
  */
9
- import { getDbExec, intType, isPostgres } from "../db/client.js";
9
+ import { getDbExec, intType, isPostgres, retryOnDdlRace, } from "../db/client.js";
10
10
  import { isDuplicateColumnError } from "../db/migrations.js";
11
11
  function safeJsonParse(value, fallback) {
12
12
  if (!value)
@@ -47,7 +47,7 @@ export async function ensureObservabilityTables() {
47
47
  if (!_initPromise) {
48
48
  _initPromise = (async () => {
49
49
  const client = getDbExec();
50
- await client.execute(`
50
+ await retryOnDdlRace(() => client.execute(`
51
51
  CREATE TABLE IF NOT EXISTS agent_trace_spans (
52
52
  id TEXT PRIMARY KEY,
53
53
  run_id TEXT NOT NULL,
@@ -67,8 +67,8 @@ export async function ensureObservabilityTables() {
67
67
  metadata TEXT,
68
68
  created_at ${intType()} NOT NULL
69
69
  )
70
- `);
71
- await client.execute(`
70
+ `));
71
+ await retryOnDdlRace(() => client.execute(`
72
72
  CREATE TABLE IF NOT EXISTS agent_trace_summaries (
73
73
  run_id TEXT PRIMARY KEY,
74
74
  thread_id TEXT,
@@ -85,8 +85,8 @@ export async function ensureObservabilityTables() {
85
85
  model TEXT NOT NULL DEFAULT '',
86
86
  created_at ${intType()} NOT NULL
87
87
  )
88
- `);
89
- await client.execute(`
88
+ `));
89
+ await retryOnDdlRace(() => client.execute(`
90
90
  CREATE TABLE IF NOT EXISTS agent_feedback (
91
91
  id TEXT PRIMARY KEY,
92
92
  run_id TEXT,
@@ -97,8 +97,8 @@ export async function ensureObservabilityTables() {
97
97
  user_id TEXT,
98
98
  created_at ${intType()} NOT NULL
99
99
  )
100
- `);
101
- await client.execute(`
100
+ `));
101
+ await retryOnDdlRace(() => client.execute(`
102
102
  CREATE TABLE IF NOT EXISTS agent_satisfaction_scores (
103
103
  id TEXT PRIMARY KEY,
104
104
  thread_id TEXT NOT NULL,
@@ -110,8 +110,8 @@ export async function ensureObservabilityTables() {
110
110
  length_trend_score REAL NOT NULL DEFAULT 0,
111
111
  computed_at ${intType()} NOT NULL
112
112
  )
113
- `);
114
- await client.execute(`
113
+ `));
114
+ await retryOnDdlRace(() => client.execute(`
115
115
  CREATE TABLE IF NOT EXISTS agent_evals (
116
116
  id TEXT PRIMARY KEY,
117
117
  run_id TEXT NOT NULL,
@@ -124,8 +124,8 @@ export async function ensureObservabilityTables() {
124
124
  metadata TEXT,
125
125
  created_at ${intType()} NOT NULL
126
126
  )
127
- `);
128
- await client.execute(`
127
+ `));
128
+ await retryOnDdlRace(() => client.execute(`
129
129
  CREATE TABLE IF NOT EXISTS agent_eval_datasets (
130
130
  id TEXT PRIMARY KEY,
131
131
  name TEXT NOT NULL,
@@ -134,8 +134,8 @@ export async function ensureObservabilityTables() {
134
134
  created_at ${intType()} NOT NULL,
135
135
  updated_at ${intType()} NOT NULL
136
136
  )
137
- `);
138
- await client.execute(`
137
+ `));
138
+ await retryOnDdlRace(() => client.execute(`
139
139
  CREATE TABLE IF NOT EXISTS agent_experiments (
140
140
  id TEXT PRIMARY KEY,
141
141
  name TEXT NOT NULL,
@@ -148,7 +148,7 @@ export async function ensureObservabilityTables() {
148
148
  created_at ${intType()} NOT NULL,
149
149
  owner_email TEXT
150
150
  )
151
- `);
151
+ `));
152
152
  // Additive migration for DBs created before the owner column shipped
153
153
  // (any pre-existing rows have NULL owner — see `updateExperiment` for
154
154
  // the migration semantics). Mutations on those rows fall back to the
@@ -160,7 +160,7 @@ export async function ensureObservabilityTables() {
160
160
  catch {
161
161
  // Column already exists — expected after first run.
162
162
  }
163
- await client.execute(`
163
+ await retryOnDdlRace(() => client.execute(`
164
164
  CREATE TABLE IF NOT EXISTS agent_experiment_assignments (
165
165
  experiment_id TEXT NOT NULL,
166
166
  user_id TEXT NOT NULL,
@@ -168,8 +168,8 @@ export async function ensureObservabilityTables() {
168
168
  assigned_at ${intType()} NOT NULL,
169
169
  PRIMARY KEY (experiment_id, user_id)
170
170
  )
171
- `);
172
- await client.execute(`
171
+ `));
172
+ await retryOnDdlRace(() => client.execute(`
173
173
  CREATE TABLE IF NOT EXISTS agent_experiment_results (
174
174
  id TEXT PRIMARY KEY,
175
175
  experiment_id TEXT NOT NULL,
@@ -181,7 +181,7 @@ export async function ensureObservabilityTables() {
181
181
  confidence_high REAL NOT NULL DEFAULT 0,
182
182
  computed_at ${intType()} NOT NULL
183
183
  )
184
- `);
184
+ `));
185
185
  // Idempotent column upgrades for DBs created before per-user
186
186
  // isolation. SQLite has no `ADD COLUMN IF NOT EXISTS`; Postgres
187
187
  // surfaces "column ... already exists". `isDuplicateColumnError`
@@ -1 +1 @@
1
- {"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/observability/store.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SQL persistence for the agent observability system.\n *\n * Creates and manages tables for traces, feedback, evals, experiments,\n * and satisfaction scores. Follows the same raw-SQL pattern as\n * run-store.ts and usage/store.ts — framework tables use getDbExec()\n * rather than Drizzle ORM (which is for template-level schemas).\n */\nimport { getDbExec, intType, isPostgres } from \"../db/client.js\";\nimport { isDuplicateColumnError } from \"../db/migrations.js\";\nimport type {\n TraceSpan,\n TraceSummary,\n FeedbackEntry,\n SatisfactionScore,\n EvalResult,\n EvalDataset,\n Experiment,\n ExperimentAssignment,\n ExperimentMetricResult,\n} from \"./types.js\";\n\nfunction safeJsonParse<T>(value: unknown, fallback: T): T {\n if (!value) return fallback;\n try {\n return JSON.parse(String(value));\n } catch {\n return fallback;\n }\n}\n\n// Tables whose rows are owned by an end user — drives the boot-time\n// user_id ALTER loop and the per-user composite indexes below. Every\n// new user-owned observability table must be added here so the upgrade\n// path and the per-user query plan stay in sync.\nconst USER_SCOPED_TABLES = [\n \"agent_trace_spans\",\n \"agent_trace_summaries\",\n \"agent_satisfaction_scores\",\n \"agent_evals\",\n \"agent_feedback\",\n] as const;\n\n/**\n * Append an `AND user_id = ?` clause when a userId filter is requested.\n * Returns the fully-bound WHERE clause + args ready to splice into the\n * caller's SQL. Centralizes the pattern so tests can assert one shape.\n */\nfunction withUserFilter(\n baseWhere: string,\n baseArgs: any[],\n userId: string | undefined,\n): { where: string; args: any[] } {\n if (userId == null) return { where: baseWhere, args: baseArgs };\n return {\n where: `${baseWhere} AND user_id = ?`,\n args: [...baseArgs, userId],\n };\n}\n\nlet _initPromise: Promise<void> | undefined;\n\nexport async function ensureObservabilityTables(): Promise<void> {\n if (!_initPromise) {\n _initPromise = (async () => {\n const client = getDbExec();\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_trace_spans (\n id TEXT PRIMARY KEY,\n run_id TEXT NOT NULL,\n thread_id TEXT,\n user_id TEXT,\n parent_span_id TEXT,\n span_type TEXT NOT NULL,\n name TEXT NOT NULL,\n input_tokens ${intType()} NOT NULL DEFAULT 0,\n output_tokens ${intType()} NOT NULL DEFAULT 0,\n cache_read_tokens ${intType()} NOT NULL DEFAULT 0,\n cache_write_tokens ${intType()} NOT NULL DEFAULT 0,\n cost_cents_x100 ${intType()} NOT NULL DEFAULT 0,\n duration_ms ${intType()} NOT NULL DEFAULT 0,\n status TEXT NOT NULL DEFAULT 'success',\n error_message TEXT,\n metadata TEXT,\n created_at ${intType()} NOT NULL\n )\n `);\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_trace_summaries (\n run_id TEXT PRIMARY KEY,\n thread_id TEXT,\n user_id TEXT,\n total_spans ${intType()} NOT NULL DEFAULT 0,\n llm_calls ${intType()} NOT NULL DEFAULT 0,\n tool_calls ${intType()} NOT NULL DEFAULT 0,\n successful_tools ${intType()} NOT NULL DEFAULT 0,\n failed_tools ${intType()} NOT NULL DEFAULT 0,\n total_duration_ms ${intType()} NOT NULL DEFAULT 0,\n total_cost_cents_x100 ${intType()} NOT NULL DEFAULT 0,\n total_input_tokens ${intType()} NOT NULL DEFAULT 0,\n total_output_tokens ${intType()} NOT NULL DEFAULT 0,\n model TEXT NOT NULL DEFAULT '',\n created_at ${intType()} NOT NULL\n )\n `);\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_feedback (\n id TEXT PRIMARY KEY,\n run_id TEXT,\n thread_id TEXT,\n message_seq ${intType()},\n feedback_type TEXT NOT NULL,\n value TEXT NOT NULL DEFAULT '',\n user_id TEXT,\n created_at ${intType()} NOT NULL\n )\n `);\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_satisfaction_scores (\n id TEXT PRIMARY KEY,\n thread_id TEXT NOT NULL,\n user_id TEXT,\n frustration_score REAL NOT NULL DEFAULT 0,\n rephrasing_score REAL NOT NULL DEFAULT 0,\n abandonment_score REAL NOT NULL DEFAULT 0,\n sentiment_score REAL NOT NULL DEFAULT 0,\n length_trend_score REAL NOT NULL DEFAULT 0,\n computed_at ${intType()} NOT NULL\n )\n `);\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_evals (\n id TEXT PRIMARY KEY,\n run_id TEXT NOT NULL,\n thread_id TEXT,\n user_id TEXT,\n eval_type TEXT NOT NULL,\n criteria TEXT NOT NULL,\n score REAL NOT NULL DEFAULT 0,\n reasoning TEXT,\n metadata TEXT,\n created_at ${intType()} NOT NULL\n )\n `);\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_eval_datasets (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n description TEXT NOT NULL DEFAULT '',\n entries TEXT NOT NULL DEFAULT '[]',\n created_at ${intType()} NOT NULL,\n updated_at ${intType()} NOT NULL\n )\n `);\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_experiments (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n status TEXT NOT NULL DEFAULT 'draft',\n variants TEXT NOT NULL DEFAULT '[]',\n metrics TEXT NOT NULL DEFAULT '[]',\n assignment_level TEXT NOT NULL DEFAULT 'user',\n started_at ${intType()},\n ended_at ${intType()},\n created_at ${intType()} NOT NULL,\n owner_email TEXT\n )\n `);\n // Additive migration for DBs created before the owner column shipped\n // (any pre-existing rows have NULL owner — see `updateExperiment` for\n // the migration semantics). Mutations on those rows fall back to the\n // standard authentication gate but cannot enforce per-owner scoping\n // until they're re-saved.\n try {\n await client.execute(\n `ALTER TABLE agent_experiments ADD COLUMN owner_email TEXT`,\n );\n } catch {\n // Column already exists — expected after first run.\n }\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_experiment_assignments (\n experiment_id TEXT NOT NULL,\n user_id TEXT NOT NULL,\n variant_id TEXT NOT NULL,\n assigned_at ${intType()} NOT NULL,\n PRIMARY KEY (experiment_id, user_id)\n )\n `);\n\n await client.execute(`\n CREATE TABLE IF NOT EXISTS agent_experiment_results (\n id TEXT PRIMARY KEY,\n experiment_id TEXT NOT NULL,\n variant_id TEXT NOT NULL,\n metric TEXT NOT NULL,\n value REAL NOT NULL DEFAULT 0,\n sample_size ${intType()} NOT NULL DEFAULT 0,\n confidence_low REAL NOT NULL DEFAULT 0,\n confidence_high REAL NOT NULL DEFAULT 0,\n computed_at ${intType()} NOT NULL\n )\n `);\n\n // Idempotent column upgrades for DBs created before per-user\n // isolation. SQLite has no `ADD COLUMN IF NOT EXISTS`; Postgres\n // surfaces \"column ... already exists\". `isDuplicateColumnError`\n // (from db/migrations.ts) recognizes both shapes.\n for (const table of USER_SCOPED_TABLES) {\n try {\n await client.execute(`ALTER TABLE ${table} ADD COLUMN user_id TEXT`);\n } catch (err) {\n if (isDuplicateColumnError(err)) continue;\n throw err;\n }\n }\n\n // Indexes for common query patterns\n const indexes = [\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_run ON agent_trace_spans (run_id)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_thread ON agent_trace_spans (thread_id)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_created ON agent_trace_spans (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_summaries_created ON agent_trace_summaries (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_summaries_user ON agent_trace_summaries (user_id, created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_user ON agent_trace_spans (user_id)`,\n `CREATE INDEX IF NOT EXISTS idx_feedback_thread ON agent_feedback (thread_id)`,\n `CREATE INDEX IF NOT EXISTS idx_feedback_created ON agent_feedback (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_feedback_user ON agent_feedback (user_id, created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_satisfaction_thread ON agent_satisfaction_scores (thread_id)`,\n `CREATE INDEX IF NOT EXISTS idx_satisfaction_user ON agent_satisfaction_scores (user_id, computed_at)`,\n `CREATE INDEX IF NOT EXISTS idx_evals_run ON agent_evals (run_id)`,\n `CREATE INDEX IF NOT EXISTS idx_evals_created ON agent_evals (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_evals_user ON agent_evals (user_id, created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_experiment_results_exp ON agent_experiment_results (experiment_id)`,\n ];\n for (const sql of indexes) {\n try {\n await client.execute(sql);\n } catch {\n // Index might already exist\n }\n }\n })().catch((err) => {\n _initPromise = undefined;\n throw err;\n });\n }\n return _initPromise;\n}\n\n// ─── Trace span CRUD ─────────────────────────────────────────────────\n\nexport async function insertTraceSpan(span: TraceSpan): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_trace_spans\n (id, run_id, thread_id, user_id, parent_span_id, span_type, name,\n input_tokens, output_tokens, cache_read_tokens, cache_write_tokens,\n cost_cents_x100, duration_ms, status, error_message, metadata, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n span.id,\n span.runId,\n span.threadId,\n span.userId,\n span.parentSpanId,\n span.spanType,\n span.name,\n span.inputTokens,\n span.outputTokens,\n span.cacheReadTokens,\n span.cacheWriteTokens,\n span.costCentsX100,\n span.durationMs,\n span.status,\n span.errorMessage,\n span.metadata ? JSON.stringify(span.metadata) : null,\n span.createdAt,\n ],\n });\n}\n\nexport async function upsertTraceSummary(summary: TraceSummary): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n // user_id is intentionally NOT updated on conflict — once a run's\n // owner is recorded it shouldn't change under us.\n if (isPostgres()) {\n await client.execute({\n sql: `INSERT INTO agent_trace_summaries\n (run_id, thread_id, user_id, total_spans, llm_calls, tool_calls,\n successful_tools, failed_tools, total_duration_ms,\n total_cost_cents_x100, total_input_tokens, total_output_tokens,\n model, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (run_id) DO UPDATE SET\n total_spans = EXCLUDED.total_spans,\n llm_calls = EXCLUDED.llm_calls,\n tool_calls = EXCLUDED.tool_calls,\n successful_tools = EXCLUDED.successful_tools,\n failed_tools = EXCLUDED.failed_tools,\n total_duration_ms = EXCLUDED.total_duration_ms,\n total_cost_cents_x100 = EXCLUDED.total_cost_cents_x100,\n total_input_tokens = EXCLUDED.total_input_tokens,\n total_output_tokens = EXCLUDED.total_output_tokens,\n model = EXCLUDED.model`,\n args: [\n summary.runId,\n summary.threadId,\n summary.userId,\n summary.totalSpans,\n summary.llmCalls,\n summary.toolCalls,\n summary.successfulTools,\n summary.failedTools,\n summary.totalDurationMs,\n summary.totalCostCentsX100,\n summary.totalInputTokens,\n summary.totalOutputTokens,\n summary.model,\n summary.createdAt,\n ],\n });\n } else {\n await client.execute({\n sql: `INSERT INTO agent_trace_summaries\n (run_id, thread_id, user_id, total_spans, llm_calls, tool_calls,\n successful_tools, failed_tools, total_duration_ms,\n total_cost_cents_x100, total_input_tokens, total_output_tokens,\n model, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (run_id) DO UPDATE SET\n total_spans = EXCLUDED.total_spans,\n llm_calls = EXCLUDED.llm_calls,\n tool_calls = EXCLUDED.tool_calls,\n successful_tools = EXCLUDED.successful_tools,\n failed_tools = EXCLUDED.failed_tools,\n total_duration_ms = EXCLUDED.total_duration_ms,\n total_cost_cents_x100 = EXCLUDED.total_cost_cents_x100,\n total_input_tokens = EXCLUDED.total_input_tokens,\n total_output_tokens = EXCLUDED.total_output_tokens,\n model = EXCLUDED.model`,\n args: [\n summary.runId,\n summary.threadId,\n summary.userId,\n summary.totalSpans,\n summary.llmCalls,\n summary.toolCalls,\n summary.successfulTools,\n summary.failedTools,\n summary.totalDurationMs,\n summary.totalCostCentsX100,\n summary.totalInputTokens,\n summary.totalOutputTokens,\n summary.model,\n summary.createdAt,\n ],\n });\n }\n}\n\n/**\n * Purge trace spans, summaries, and eval results older than `cutoffMs`\n * (a Unix epoch in milliseconds — rows with `created_at < cutoffMs` are\n * deleted). Returns the per-table deletion counts. Satisfies the span\n * retention TTL noted in /tmp/security-audit/12-mcp-a2a-agent.md\n * (MEDIUM #14): trace metadata can hold sensitive tool inputs, so we\n * cap the storage horizon. Feedback rows are retained — they're\n * intentionally durable for product analytics. Experiments and\n * datasets are also retained because they are user-authored\n * configuration, not call telemetry.\n */\nexport async function deleteOldTraceData(cutoffMs: number): Promise<{\n spans: number;\n summaries: number;\n evals: number;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const cutoff = Math.floor(cutoffMs);\n\n const [spansResult, summariesResult, evalsResult] = await Promise.all([\n client.execute({\n sql: `DELETE FROM agent_trace_spans WHERE created_at < ?`,\n args: [cutoff],\n }),\n client.execute({\n sql: `DELETE FROM agent_trace_summaries WHERE created_at < ?`,\n args: [cutoff],\n }),\n client.execute({\n sql: `DELETE FROM agent_evals WHERE created_at < ?`,\n args: [cutoff],\n }),\n ]);\n\n return {\n spans: Number(spansResult.rowsAffected ?? 0),\n summaries: Number(summariesResult.rowsAffected ?? 0),\n evals: Number(evalsResult.rowsAffected ?? 0),\n };\n}\n\nexport async function getTraceSpansForRun(\n runId: string,\n opts: { userId?: string } = {},\n): Promise<TraceSpan[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\"run_id = ?\", [runId], opts.userId);\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_trace_spans WHERE ${where} ORDER BY created_at ASC`,\n args,\n });\n return (rows as any[]).map(rowToTraceSpan);\n}\n\nexport async function getTraceSummaries(opts: {\n sinceMs?: number;\n limit?: number;\n userId?: string;\n}): Promise<TraceSummary[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const sinceMs = opts.sinceMs ?? 0;\n const limit = opts.limit ?? 100;\n const { where, args } = withUserFilter(\n \"created_at >= ?\",\n [sinceMs],\n opts.userId,\n );\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_trace_summaries\n WHERE ${where}\n ORDER BY created_at DESC\n LIMIT ?`,\n args: [...args, limit],\n });\n return (rows as any[]).map(rowToTraceSummary);\n}\n\nexport async function getTraceSummary(\n runId: string,\n opts: { userId?: string } = {},\n): Promise<TraceSummary | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\"run_id = ?\", [runId], opts.userId);\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_trace_summaries WHERE ${where}`,\n args,\n });\n if (rows.length === 0) return null;\n return rowToTraceSummary(rows[0] as any);\n}\n\n// ─── Feedback CRUD ───────────────────────────────────────────────────\n\nexport async function insertFeedback(entry: FeedbackEntry): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_feedback\n (id, run_id, thread_id, message_seq, feedback_type, value, user_id, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n entry.id,\n entry.runId,\n entry.threadId,\n entry.messageSeq,\n entry.feedbackType,\n entry.value,\n entry.userId,\n entry.createdAt,\n ],\n });\n}\n\nexport async function getFeedback(opts: {\n threadId?: string;\n sinceMs?: number;\n limit?: number;\n feedbackType?: string;\n userId?: string;\n}): Promise<FeedbackEntry[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const conditions: string[] = [];\n const args: any[] = [];\n if (opts.threadId) {\n conditions.push(\"thread_id = ?\");\n args.push(opts.threadId);\n }\n if (opts.sinceMs) {\n conditions.push(\"created_at >= ?\");\n args.push(opts.sinceMs);\n }\n if (opts.feedbackType) {\n conditions.push(\"feedback_type = ?\");\n args.push(opts.feedbackType);\n }\n if (opts.userId) {\n conditions.push(\"user_id = ?\");\n args.push(opts.userId);\n }\n const where =\n conditions.length > 0 ? `WHERE ${conditions.join(\" AND \")}` : \"\";\n const limit = opts.limit ?? 100;\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_feedback ${where} ORDER BY created_at DESC LIMIT ?`,\n args: [...args, limit],\n });\n return (rows as any[]).map(rowToFeedback);\n}\n\nexport async function getFeedbackStats(\n sinceMs: number,\n opts: { userId?: string } = {},\n): Promise<{\n total: number;\n thumbsUp: number;\n thumbsDown: number;\n categories: Record<string, number>;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\n \"created_at >= ?\",\n [sinceMs],\n opts.userId,\n );\n const { rows } = await client.execute({\n sql: `SELECT feedback_type, value, COUNT(*) as cnt\n FROM agent_feedback WHERE ${where}\n GROUP BY feedback_type, value`,\n args,\n });\n let total = 0;\n let thumbsUp = 0;\n let thumbsDown = 0;\n const categories: Record<string, number> = {};\n for (const row of rows as any[]) {\n const cnt = Number(row.cnt);\n total += cnt;\n if (row.feedback_type === \"thumbs_up\") thumbsUp += cnt;\n else if (row.feedback_type === \"thumbs_down\") thumbsDown += cnt;\n else if (row.feedback_type === \"category\")\n categories[String(row.value)] = cnt;\n }\n return { total, thumbsUp, thumbsDown, categories };\n}\n\n// ─── Satisfaction scores CRUD ────────────────────────────────────────\n\nexport async function upsertSatisfactionScore(\n score: SatisfactionScore,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n if (isPostgres()) {\n await client.execute({\n sql: `INSERT INTO agent_satisfaction_scores\n (id, thread_id, user_id, frustration_score, rephrasing_score,\n abandonment_score, sentiment_score, length_trend_score, computed_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (id) DO UPDATE SET\n frustration_score = EXCLUDED.frustration_score,\n rephrasing_score = EXCLUDED.rephrasing_score,\n abandonment_score = EXCLUDED.abandonment_score,\n sentiment_score = EXCLUDED.sentiment_score,\n length_trend_score = EXCLUDED.length_trend_score,\n computed_at = EXCLUDED.computed_at`,\n args: [\n score.id,\n score.threadId,\n score.userId,\n score.frustrationScore,\n score.rephrasingScore,\n score.abandonmentScore,\n score.sentimentScore,\n score.lengthTrendScore,\n score.computedAt,\n ],\n });\n } else {\n await client.execute({\n sql: `INSERT INTO agent_satisfaction_scores\n (id, thread_id, user_id, frustration_score, rephrasing_score,\n abandonment_score, sentiment_score, length_trend_score, computed_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (id) DO UPDATE SET\n frustration_score = EXCLUDED.frustration_score,\n rephrasing_score = EXCLUDED.rephrasing_score,\n abandonment_score = EXCLUDED.abandonment_score,\n sentiment_score = EXCLUDED.sentiment_score,\n length_trend_score = EXCLUDED.length_trend_score,\n computed_at = EXCLUDED.computed_at`,\n args: [\n score.id,\n score.threadId,\n score.userId,\n score.frustrationScore,\n score.rephrasingScore,\n score.abandonmentScore,\n score.sentimentScore,\n score.lengthTrendScore,\n score.computedAt,\n ],\n });\n }\n}\n\nexport async function getSatisfactionScores(opts: {\n sinceMs?: number;\n limit?: number;\n minFrustration?: number;\n userId?: string;\n}): Promise<SatisfactionScore[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const conditions: string[] = [];\n const args: any[] = [];\n if (opts.sinceMs) {\n conditions.push(\"computed_at >= ?\");\n args.push(opts.sinceMs);\n }\n if (opts.minFrustration != null) {\n conditions.push(\"frustration_score >= ?\");\n args.push(opts.minFrustration);\n }\n if (opts.userId) {\n conditions.push(\"user_id = ?\");\n args.push(opts.userId);\n }\n const where =\n conditions.length > 0 ? `WHERE ${conditions.join(\" AND \")}` : \"\";\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_satisfaction_scores ${where}\n ORDER BY computed_at DESC LIMIT ?`,\n args: [...args, opts.limit ?? 100],\n });\n return (rows as any[]).map(rowToSatisfaction);\n}\n\n// ─── Evals CRUD ──────────────────────────────────────────────────────\n\nexport async function insertEvalResult(result: EvalResult): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_evals\n (id, run_id, thread_id, user_id, eval_type, criteria, score, reasoning, metadata, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n result.id,\n result.runId,\n result.threadId,\n result.userId,\n result.evalType,\n result.criteria,\n result.score,\n result.reasoning,\n result.metadata ? JSON.stringify(result.metadata) : null,\n result.createdAt,\n ],\n });\n}\n\nexport async function getEvalsForRun(\n runId: string,\n opts: { userId?: string } = {},\n): Promise<EvalResult[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\"run_id = ?\", [runId], opts.userId);\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_evals WHERE ${where} ORDER BY created_at ASC`,\n args,\n });\n return (rows as any[]).map(rowToEval);\n}\n\nexport async function getEvalStats(\n sinceMs: number,\n opts: { userId?: string } = {},\n): Promise<{\n totalEvals: number;\n avgScore: number;\n byCriteria: Array<{ criteria: string; avgScore: number; count: number }>;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\n \"created_at >= ?\",\n [sinceMs],\n opts.userId,\n );\n const { rows: totalRows } = await client.execute({\n sql: `SELECT COUNT(*) as cnt, AVG(score) as avg_score\n FROM agent_evals WHERE ${where}`,\n args,\n });\n const t = (totalRows[0] ?? {}) as Record<string, number | null>;\n\n const { rows: criteriaRows } = await client.execute({\n sql: `SELECT criteria, AVG(score) as avg_score, COUNT(*) as cnt\n FROM agent_evals WHERE ${where}\n GROUP BY criteria ORDER BY cnt DESC`,\n args,\n });\n\n return {\n totalEvals: Number(t.cnt ?? 0),\n avgScore: Number(t.avg_score ?? 0),\n byCriteria: (criteriaRows as any[]).map((r) => ({\n criteria: String(r.criteria),\n avgScore: Number(r.avg_score ?? 0),\n count: Number(r.cnt ?? 0),\n })),\n };\n}\n\n// ─── Eval datasets CRUD ──────────────────────────────────────────────\n\nexport async function insertEvalDataset(dataset: EvalDataset): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_eval_datasets\n (id, name, description, entries, created_at, updated_at)\n VALUES (?, ?, ?, ?, ?, ?)`,\n args: [\n dataset.id,\n dataset.name,\n dataset.description,\n JSON.stringify(dataset.entries),\n dataset.createdAt,\n dataset.updatedAt,\n ],\n });\n}\n\nexport async function listEvalDatasets(): Promise<EvalDataset[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute(\n `SELECT * FROM agent_eval_datasets ORDER BY updated_at DESC`,\n );\n return (rows as any[]).map(rowToDataset);\n}\n\nexport async function getEvalDataset(id: string): Promise<EvalDataset | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_eval_datasets WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return null;\n return rowToDataset(rows[0] as any);\n}\n\nexport async function updateEvalDataset(\n id: string,\n updates: Partial<Pick<EvalDataset, \"name\" | \"description\" | \"entries\">>,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const sets: string[] = [];\n const args: any[] = [];\n if (updates.name !== undefined) {\n sets.push(\"name = ?\");\n args.push(updates.name);\n }\n if (updates.description !== undefined) {\n sets.push(\"description = ?\");\n args.push(updates.description);\n }\n if (updates.entries !== undefined) {\n sets.push(\"entries = ?\");\n args.push(JSON.stringify(updates.entries));\n }\n sets.push(\"updated_at = ?\");\n args.push(Date.now());\n args.push(id);\n await client.execute({\n sql: `UPDATE agent_eval_datasets SET ${sets.join(\", \")} WHERE id = ?`,\n args,\n });\n}\n\n// ─── Experiments CRUD ────────────────────────────────────────────────\n\nexport async function insertExperiment(exp: Experiment): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_experiments\n (id, name, status, variants, metrics, assignment_level,\n started_at, ended_at, created_at, owner_email)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n exp.id,\n exp.name,\n exp.status,\n JSON.stringify(exp.variants),\n JSON.stringify(exp.metrics),\n exp.assignmentLevel,\n exp.startedAt,\n exp.endedAt,\n exp.createdAt,\n exp.ownerEmail ?? null,\n ],\n });\n}\n\nexport async function updateExperiment(\n id: string,\n updates: Partial<\n Pick<Experiment, \"name\" | \"status\" | \"variants\" | \"metrics\" | \"endedAt\">\n >,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const sets: string[] = [];\n const args: any[] = [];\n if (updates.name !== undefined) {\n sets.push(\"name = ?\");\n args.push(updates.name);\n }\n if (updates.status !== undefined) {\n sets.push(\"status = ?\");\n args.push(updates.status);\n if (updates.status === \"running\" && !updates.endedAt) {\n sets.push(\"started_at = ?\");\n args.push(Date.now());\n }\n }\n if (updates.variants !== undefined) {\n sets.push(\"variants = ?\");\n args.push(JSON.stringify(updates.variants));\n }\n if (updates.metrics !== undefined) {\n sets.push(\"metrics = ?\");\n args.push(JSON.stringify(updates.metrics));\n }\n if (updates.endedAt !== undefined) {\n sets.push(\"ended_at = ?\");\n args.push(updates.endedAt);\n }\n if (sets.length === 0) return;\n args.push(id);\n await client.execute({\n sql: `UPDATE agent_experiments SET ${sets.join(\", \")} WHERE id = ?`,\n args,\n });\n}\n\nexport async function listExperiments(): Promise<Experiment[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute(\n `SELECT * FROM agent_experiments ORDER BY created_at DESC`,\n );\n return (rows as any[]).map(rowToExperiment);\n}\n\nexport async function getExperiment(id: string): Promise<Experiment | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_experiments WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return null;\n return rowToExperiment(rows[0] as any);\n}\n\n// ─── Experiment assignments CRUD ────────────────────────────────────\n\nexport async function upsertAssignment(\n assignment: ExperimentAssignment,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n if (isPostgres()) {\n await client.execute({\n sql: `INSERT INTO agent_experiment_assignments\n (experiment_id, user_id, variant_id, assigned_at)\n VALUES (?, ?, ?, ?)\n ON CONFLICT (experiment_id, user_id) DO UPDATE SET\n variant_id = EXCLUDED.variant_id,\n assigned_at = EXCLUDED.assigned_at`,\n args: [\n assignment.experimentId,\n assignment.userId,\n assignment.variantId,\n assignment.assignedAt,\n ],\n });\n } else {\n await client.execute({\n sql: `INSERT OR REPLACE INTO agent_experiment_assignments\n (experiment_id, user_id, variant_id, assigned_at)\n VALUES (?, ?, ?, ?)`,\n args: [\n assignment.experimentId,\n assignment.userId,\n assignment.variantId,\n assignment.assignedAt,\n ],\n });\n }\n}\n\nexport async function getAssignment(\n experimentId: string,\n userId: string,\n): Promise<ExperimentAssignment | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_experiment_assignments\n WHERE experiment_id = ? AND user_id = ?`,\n args: [experimentId, userId],\n });\n if (rows.length === 0) return null;\n const r = rows[0] as any;\n return {\n experimentId: r.experiment_id,\n userId: r.user_id,\n variantId: r.variant_id,\n assignedAt: Number(r.assigned_at),\n };\n}\n\n// ─── Experiment results CRUD ─────────────────────────────────────────\n\nexport async function insertExperimentResult(\n result: ExperimentMetricResult,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_experiment_results\n (id, experiment_id, variant_id, metric, value,\n sample_size, confidence_low, confidence_high, computed_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n result.id,\n result.experimentId,\n result.variantId,\n result.metric,\n result.value,\n result.sampleSize,\n result.confidenceLow,\n result.confidenceHigh,\n result.computedAt,\n ],\n });\n}\n\nexport async function getExperimentResults(\n experimentId: string,\n): Promise<ExperimentMetricResult[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_experiment_results\n WHERE experiment_id = ?\n ORDER BY computed_at DESC`,\n args: [experimentId],\n });\n return (rows as any[]).map(rowToExperimentResult);\n}\n\n// ─── Aggregate queries for dashboard ─────────────────────────────────\n\nexport async function getObservabilityOverview(\n sinceMs: number,\n opts: { userId?: string } = {},\n): Promise<{\n totalRuns: number;\n totalCostCents: number;\n avgDurationMs: number;\n toolSuccessRate: number;\n avgFrustrationScore: number;\n thumbsUpRate: number;\n avgEvalScore: number;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n\n // Three of the four sub-queries time-key on `created_at`; satisfaction\n // uses `computed_at`. Each gets its own `withUserFilter` invocation so\n // the args array isn't aliased across calls (some drivers mutate args\n // for prepared-statement caching).\n const created = withUserFilter(\"created_at >= ?\", [sinceMs], opts.userId);\n const computed = withUserFilter(\"computed_at >= ?\", [sinceMs], opts.userId);\n\n const [tracesResult, satisfactionResult, feedbackResult, evalsResult] =\n await Promise.all([\n client.execute({\n sql: `SELECT\n COUNT(*) as total_runs,\n COALESCE(SUM(total_cost_cents_x100), 0) as total_cost,\n COALESCE(AVG(total_duration_ms), 0) as avg_duration,\n COALESCE(SUM(successful_tools), 0) as success_tools,\n COALESCE(SUM(tool_calls), 0) as total_tools\n FROM agent_trace_summaries WHERE ${created.where}`,\n args: created.args,\n }),\n client.execute({\n sql: `SELECT COALESCE(AVG(frustration_score), 0) as avg_frustration\n FROM agent_satisfaction_scores WHERE ${computed.where}`,\n args: computed.args,\n }),\n client.execute({\n sql: `SELECT\n COALESCE(SUM(CASE WHEN feedback_type = 'thumbs_up' THEN 1 ELSE 0 END), 0) as up,\n COALESCE(SUM(CASE WHEN feedback_type IN ('thumbs_up', 'thumbs_down') THEN 1 ELSE 0 END), 0) as total\n FROM agent_feedback WHERE ${created.where}`,\n args: created.args,\n }),\n client.execute({\n sql: `SELECT COALESCE(AVG(score), 0) as avg_score\n FROM agent_evals WHERE ${created.where}`,\n args: created.args,\n }),\n ]);\n\n const t = (tracesResult.rows[0] ?? {}) as Record<string, number | null>;\n const s = (satisfactionResult.rows[0] ?? {}) as Record<string, number | null>;\n const f = (feedbackResult.rows[0] ?? {}) as Record<string, number | null>;\n const e = (evalsResult.rows[0] ?? {}) as Record<string, number | null>;\n\n const totalTools = Number(t.total_tools ?? 0);\n const successTools = Number(t.success_tools ?? 0);\n const feedbackTotal = Number(f.total ?? 0);\n const feedbackUp = Number(f.up ?? 0);\n\n return {\n totalRuns: Number(t.total_runs ?? 0),\n totalCostCents: Number(t.total_cost ?? 0) / 100,\n avgDurationMs: Number(t.avg_duration ?? 0),\n toolSuccessRate: totalTools > 0 ? successTools / totalTools : 1,\n avgFrustrationScore: Number(s.avg_frustration ?? 0),\n thumbsUpRate: feedbackTotal > 0 ? feedbackUp / feedbackTotal : 0,\n avgEvalScore: Number(e.avg_score ?? 0),\n };\n}\n\n// ─── Row mappers ─────────────────────────────────────────────────────\n\nfunction rowToTraceSpan(row: Record<string, any>): TraceSpan {\n return {\n id: String(row.id),\n runId: String(row.run_id),\n threadId: row.thread_id ? String(row.thread_id) : null,\n userId: row.user_id ? String(row.user_id) : null,\n parentSpanId: row.parent_span_id ? String(row.parent_span_id) : null,\n spanType: row.span_type as TraceSpan[\"spanType\"],\n name: String(row.name),\n inputTokens: Number(row.input_tokens ?? 0),\n outputTokens: Number(row.output_tokens ?? 0),\n cacheReadTokens: Number(row.cache_read_tokens ?? 0),\n cacheWriteTokens: Number(row.cache_write_tokens ?? 0),\n costCentsX100: Number(row.cost_cents_x100 ?? 0),\n durationMs: Number(row.duration_ms ?? 0),\n status: row.status as TraceSpan[\"status\"],\n errorMessage: row.error_message ? String(row.error_message) : null,\n metadata: safeJsonParse(row.metadata, null),\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToTraceSummary(row: Record<string, any>): TraceSummary {\n return {\n runId: String(row.run_id),\n threadId: row.thread_id ? String(row.thread_id) : null,\n userId: row.user_id ? String(row.user_id) : null,\n totalSpans: Number(row.total_spans ?? 0),\n llmCalls: Number(row.llm_calls ?? 0),\n toolCalls: Number(row.tool_calls ?? 0),\n successfulTools: Number(row.successful_tools ?? 0),\n failedTools: Number(row.failed_tools ?? 0),\n totalDurationMs: Number(row.total_duration_ms ?? 0),\n totalCostCentsX100: Number(row.total_cost_cents_x100 ?? 0),\n totalInputTokens: Number(row.total_input_tokens ?? 0),\n totalOutputTokens: Number(row.total_output_tokens ?? 0),\n model: String(row.model ?? \"\"),\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToFeedback(row: Record<string, any>): FeedbackEntry {\n return {\n id: String(row.id),\n runId: row.run_id ? String(row.run_id) : null,\n threadId: row.thread_id ? String(row.thread_id) : null,\n messageSeq: row.message_seq != null ? Number(row.message_seq) : null,\n feedbackType: row.feedback_type as FeedbackEntry[\"feedbackType\"],\n value: String(row.value ?? \"\"),\n userId: row.user_id ? String(row.user_id) : null,\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToSatisfaction(row: Record<string, any>): SatisfactionScore {\n return {\n id: String(row.id),\n threadId: String(row.thread_id),\n userId: row.user_id ? String(row.user_id) : null,\n frustrationScore: Number(row.frustration_score ?? 0),\n rephrasingScore: Number(row.rephrasing_score ?? 0),\n abandonmentScore: Number(row.abandonment_score ?? 0),\n sentimentScore: Number(row.sentiment_score ?? 0),\n lengthTrendScore: Number(row.length_trend_score ?? 0),\n computedAt: Number(row.computed_at),\n };\n}\n\nfunction rowToEval(row: Record<string, any>): EvalResult {\n return {\n id: String(row.id),\n runId: String(row.run_id),\n threadId: row.thread_id ? String(row.thread_id) : null,\n userId: row.user_id ? String(row.user_id) : null,\n evalType: row.eval_type as EvalResult[\"evalType\"],\n criteria: String(row.criteria),\n score: Number(row.score ?? 0),\n reasoning: row.reasoning ? String(row.reasoning) : null,\n metadata: safeJsonParse(row.metadata, null),\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToDataset(row: Record<string, any>): EvalDataset {\n return {\n id: String(row.id),\n name: String(row.name),\n description: String(row.description ?? \"\"),\n entries: safeJsonParse(row.entries, []),\n createdAt: Number(row.created_at),\n updatedAt: Number(row.updated_at),\n };\n}\n\nfunction rowToExperiment(row: Record<string, any>): Experiment {\n return {\n id: String(row.id),\n name: String(row.name),\n status: row.status as Experiment[\"status\"],\n variants: safeJsonParse(row.variants, []),\n metrics: safeJsonParse(row.metrics, []),\n assignmentLevel: (row.assignment_level as \"user\" | \"session\") ?? \"user\",\n startedAt: row.started_at ? Number(row.started_at) : null,\n endedAt: row.ended_at ? Number(row.ended_at) : null,\n createdAt: Number(row.created_at),\n ownerEmail:\n typeof row.owner_email === \"string\" && row.owner_email\n ? row.owner_email\n : null,\n };\n}\n\nfunction rowToExperimentResult(\n row: Record<string, any>,\n): ExperimentMetricResult {\n return {\n id: String(row.id),\n experimentId: String(row.experiment_id),\n variantId: String(row.variant_id),\n metric: String(row.metric),\n value: Number(row.value ?? 0),\n sampleSize: Number(row.sample_size ?? 0),\n confidenceLow: Number(row.confidence_low ?? 0),\n confidenceHigh: Number(row.confidence_high ?? 0),\n computedAt: Number(row.computed_at),\n };\n}\n"]}
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/observability/store.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * SQL persistence for the agent observability system.\n *\n * Creates and manages tables for traces, feedback, evals, experiments,\n * and satisfaction scores. Follows the same raw-SQL pattern as\n * run-store.ts and usage/store.ts — framework tables use getDbExec()\n * rather than Drizzle ORM (which is for template-level schemas).\n */\nimport {\n getDbExec,\n intType,\n isPostgres,\n retryOnDdlRace,\n} from \"../db/client.js\";\nimport { isDuplicateColumnError } from \"../db/migrations.js\";\nimport type {\n TraceSpan,\n TraceSummary,\n FeedbackEntry,\n SatisfactionScore,\n EvalResult,\n EvalDataset,\n Experiment,\n ExperimentAssignment,\n ExperimentMetricResult,\n} from \"./types.js\";\n\nfunction safeJsonParse<T>(value: unknown, fallback: T): T {\n if (!value) return fallback;\n try {\n return JSON.parse(String(value));\n } catch {\n return fallback;\n }\n}\n\n// Tables whose rows are owned by an end user — drives the boot-time\n// user_id ALTER loop and the per-user composite indexes below. Every\n// new user-owned observability table must be added here so the upgrade\n// path and the per-user query plan stay in sync.\nconst USER_SCOPED_TABLES = [\n \"agent_trace_spans\",\n \"agent_trace_summaries\",\n \"agent_satisfaction_scores\",\n \"agent_evals\",\n \"agent_feedback\",\n] as const;\n\n/**\n * Append an `AND user_id = ?` clause when a userId filter is requested.\n * Returns the fully-bound WHERE clause + args ready to splice into the\n * caller's SQL. Centralizes the pattern so tests can assert one shape.\n */\nfunction withUserFilter(\n baseWhere: string,\n baseArgs: any[],\n userId: string | undefined,\n): { where: string; args: any[] } {\n if (userId == null) return { where: baseWhere, args: baseArgs };\n return {\n where: `${baseWhere} AND user_id = ?`,\n args: [...baseArgs, userId],\n };\n}\n\nlet _initPromise: Promise<void> | undefined;\n\nexport async function ensureObservabilityTables(): Promise<void> {\n if (!_initPromise) {\n _initPromise = (async () => {\n const client = getDbExec();\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_trace_spans (\n id TEXT PRIMARY KEY,\n run_id TEXT NOT NULL,\n thread_id TEXT,\n user_id TEXT,\n parent_span_id TEXT,\n span_type TEXT NOT NULL,\n name TEXT NOT NULL,\n input_tokens ${intType()} NOT NULL DEFAULT 0,\n output_tokens ${intType()} NOT NULL DEFAULT 0,\n cache_read_tokens ${intType()} NOT NULL DEFAULT 0,\n cache_write_tokens ${intType()} NOT NULL DEFAULT 0,\n cost_cents_x100 ${intType()} NOT NULL DEFAULT 0,\n duration_ms ${intType()} NOT NULL DEFAULT 0,\n status TEXT NOT NULL DEFAULT 'success',\n error_message TEXT,\n metadata TEXT,\n created_at ${intType()} NOT NULL\n )\n `),\n );\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_trace_summaries (\n run_id TEXT PRIMARY KEY,\n thread_id TEXT,\n user_id TEXT,\n total_spans ${intType()} NOT NULL DEFAULT 0,\n llm_calls ${intType()} NOT NULL DEFAULT 0,\n tool_calls ${intType()} NOT NULL DEFAULT 0,\n successful_tools ${intType()} NOT NULL DEFAULT 0,\n failed_tools ${intType()} NOT NULL DEFAULT 0,\n total_duration_ms ${intType()} NOT NULL DEFAULT 0,\n total_cost_cents_x100 ${intType()} NOT NULL DEFAULT 0,\n total_input_tokens ${intType()} NOT NULL DEFAULT 0,\n total_output_tokens ${intType()} NOT NULL DEFAULT 0,\n model TEXT NOT NULL DEFAULT '',\n created_at ${intType()} NOT NULL\n )\n `),\n );\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_feedback (\n id TEXT PRIMARY KEY,\n run_id TEXT,\n thread_id TEXT,\n message_seq ${intType()},\n feedback_type TEXT NOT NULL,\n value TEXT NOT NULL DEFAULT '',\n user_id TEXT,\n created_at ${intType()} NOT NULL\n )\n `),\n );\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_satisfaction_scores (\n id TEXT PRIMARY KEY,\n thread_id TEXT NOT NULL,\n user_id TEXT,\n frustration_score REAL NOT NULL DEFAULT 0,\n rephrasing_score REAL NOT NULL DEFAULT 0,\n abandonment_score REAL NOT NULL DEFAULT 0,\n sentiment_score REAL NOT NULL DEFAULT 0,\n length_trend_score REAL NOT NULL DEFAULT 0,\n computed_at ${intType()} NOT NULL\n )\n `),\n );\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_evals (\n id TEXT PRIMARY KEY,\n run_id TEXT NOT NULL,\n thread_id TEXT,\n user_id TEXT,\n eval_type TEXT NOT NULL,\n criteria TEXT NOT NULL,\n score REAL NOT NULL DEFAULT 0,\n reasoning TEXT,\n metadata TEXT,\n created_at ${intType()} NOT NULL\n )\n `),\n );\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_eval_datasets (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n description TEXT NOT NULL DEFAULT '',\n entries TEXT NOT NULL DEFAULT '[]',\n created_at ${intType()} NOT NULL,\n updated_at ${intType()} NOT NULL\n )\n `),\n );\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_experiments (\n id TEXT PRIMARY KEY,\n name TEXT NOT NULL,\n status TEXT NOT NULL DEFAULT 'draft',\n variants TEXT NOT NULL DEFAULT '[]',\n metrics TEXT NOT NULL DEFAULT '[]',\n assignment_level TEXT NOT NULL DEFAULT 'user',\n started_at ${intType()},\n ended_at ${intType()},\n created_at ${intType()} NOT NULL,\n owner_email TEXT\n )\n `),\n );\n // Additive migration for DBs created before the owner column shipped\n // (any pre-existing rows have NULL owner — see `updateExperiment` for\n // the migration semantics). Mutations on those rows fall back to the\n // standard authentication gate but cannot enforce per-owner scoping\n // until they're re-saved.\n try {\n await client.execute(\n `ALTER TABLE agent_experiments ADD COLUMN owner_email TEXT`,\n );\n } catch {\n // Column already exists — expected after first run.\n }\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_experiment_assignments (\n experiment_id TEXT NOT NULL,\n user_id TEXT NOT NULL,\n variant_id TEXT NOT NULL,\n assigned_at ${intType()} NOT NULL,\n PRIMARY KEY (experiment_id, user_id)\n )\n `),\n );\n\n await retryOnDdlRace(() =>\n client.execute(`\n CREATE TABLE IF NOT EXISTS agent_experiment_results (\n id TEXT PRIMARY KEY,\n experiment_id TEXT NOT NULL,\n variant_id TEXT NOT NULL,\n metric TEXT NOT NULL,\n value REAL NOT NULL DEFAULT 0,\n sample_size ${intType()} NOT NULL DEFAULT 0,\n confidence_low REAL NOT NULL DEFAULT 0,\n confidence_high REAL NOT NULL DEFAULT 0,\n computed_at ${intType()} NOT NULL\n )\n `),\n );\n\n // Idempotent column upgrades for DBs created before per-user\n // isolation. SQLite has no `ADD COLUMN IF NOT EXISTS`; Postgres\n // surfaces \"column ... already exists\". `isDuplicateColumnError`\n // (from db/migrations.ts) recognizes both shapes.\n for (const table of USER_SCOPED_TABLES) {\n try {\n await client.execute(`ALTER TABLE ${table} ADD COLUMN user_id TEXT`);\n } catch (err) {\n if (isDuplicateColumnError(err)) continue;\n throw err;\n }\n }\n\n // Indexes for common query patterns\n const indexes = [\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_run ON agent_trace_spans (run_id)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_thread ON agent_trace_spans (thread_id)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_created ON agent_trace_spans (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_summaries_created ON agent_trace_summaries (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_summaries_user ON agent_trace_summaries (user_id, created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_trace_spans_user ON agent_trace_spans (user_id)`,\n `CREATE INDEX IF NOT EXISTS idx_feedback_thread ON agent_feedback (thread_id)`,\n `CREATE INDEX IF NOT EXISTS idx_feedback_created ON agent_feedback (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_feedback_user ON agent_feedback (user_id, created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_satisfaction_thread ON agent_satisfaction_scores (thread_id)`,\n `CREATE INDEX IF NOT EXISTS idx_satisfaction_user ON agent_satisfaction_scores (user_id, computed_at)`,\n `CREATE INDEX IF NOT EXISTS idx_evals_run ON agent_evals (run_id)`,\n `CREATE INDEX IF NOT EXISTS idx_evals_created ON agent_evals (created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_evals_user ON agent_evals (user_id, created_at)`,\n `CREATE INDEX IF NOT EXISTS idx_experiment_results_exp ON agent_experiment_results (experiment_id)`,\n ];\n for (const sql of indexes) {\n try {\n await client.execute(sql);\n } catch {\n // Index might already exist\n }\n }\n })().catch((err) => {\n _initPromise = undefined;\n throw err;\n });\n }\n return _initPromise;\n}\n\n// ─── Trace span CRUD ─────────────────────────────────────────────────\n\nexport async function insertTraceSpan(span: TraceSpan): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_trace_spans\n (id, run_id, thread_id, user_id, parent_span_id, span_type, name,\n input_tokens, output_tokens, cache_read_tokens, cache_write_tokens,\n cost_cents_x100, duration_ms, status, error_message, metadata, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n span.id,\n span.runId,\n span.threadId,\n span.userId,\n span.parentSpanId,\n span.spanType,\n span.name,\n span.inputTokens,\n span.outputTokens,\n span.cacheReadTokens,\n span.cacheWriteTokens,\n span.costCentsX100,\n span.durationMs,\n span.status,\n span.errorMessage,\n span.metadata ? JSON.stringify(span.metadata) : null,\n span.createdAt,\n ],\n });\n}\n\nexport async function upsertTraceSummary(summary: TraceSummary): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n // user_id is intentionally NOT updated on conflict — once a run's\n // owner is recorded it shouldn't change under us.\n if (isPostgres()) {\n await client.execute({\n sql: `INSERT INTO agent_trace_summaries\n (run_id, thread_id, user_id, total_spans, llm_calls, tool_calls,\n successful_tools, failed_tools, total_duration_ms,\n total_cost_cents_x100, total_input_tokens, total_output_tokens,\n model, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (run_id) DO UPDATE SET\n total_spans = EXCLUDED.total_spans,\n llm_calls = EXCLUDED.llm_calls,\n tool_calls = EXCLUDED.tool_calls,\n successful_tools = EXCLUDED.successful_tools,\n failed_tools = EXCLUDED.failed_tools,\n total_duration_ms = EXCLUDED.total_duration_ms,\n total_cost_cents_x100 = EXCLUDED.total_cost_cents_x100,\n total_input_tokens = EXCLUDED.total_input_tokens,\n total_output_tokens = EXCLUDED.total_output_tokens,\n model = EXCLUDED.model`,\n args: [\n summary.runId,\n summary.threadId,\n summary.userId,\n summary.totalSpans,\n summary.llmCalls,\n summary.toolCalls,\n summary.successfulTools,\n summary.failedTools,\n summary.totalDurationMs,\n summary.totalCostCentsX100,\n summary.totalInputTokens,\n summary.totalOutputTokens,\n summary.model,\n summary.createdAt,\n ],\n });\n } else {\n await client.execute({\n sql: `INSERT INTO agent_trace_summaries\n (run_id, thread_id, user_id, total_spans, llm_calls, tool_calls,\n successful_tools, failed_tools, total_duration_ms,\n total_cost_cents_x100, total_input_tokens, total_output_tokens,\n model, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (run_id) DO UPDATE SET\n total_spans = EXCLUDED.total_spans,\n llm_calls = EXCLUDED.llm_calls,\n tool_calls = EXCLUDED.tool_calls,\n successful_tools = EXCLUDED.successful_tools,\n failed_tools = EXCLUDED.failed_tools,\n total_duration_ms = EXCLUDED.total_duration_ms,\n total_cost_cents_x100 = EXCLUDED.total_cost_cents_x100,\n total_input_tokens = EXCLUDED.total_input_tokens,\n total_output_tokens = EXCLUDED.total_output_tokens,\n model = EXCLUDED.model`,\n args: [\n summary.runId,\n summary.threadId,\n summary.userId,\n summary.totalSpans,\n summary.llmCalls,\n summary.toolCalls,\n summary.successfulTools,\n summary.failedTools,\n summary.totalDurationMs,\n summary.totalCostCentsX100,\n summary.totalInputTokens,\n summary.totalOutputTokens,\n summary.model,\n summary.createdAt,\n ],\n });\n }\n}\n\n/**\n * Purge trace spans, summaries, and eval results older than `cutoffMs`\n * (a Unix epoch in milliseconds — rows with `created_at < cutoffMs` are\n * deleted). Returns the per-table deletion counts. Satisfies the span\n * retention TTL noted in /tmp/security-audit/12-mcp-a2a-agent.md\n * (MEDIUM #14): trace metadata can hold sensitive tool inputs, so we\n * cap the storage horizon. Feedback rows are retained — they're\n * intentionally durable for product analytics. Experiments and\n * datasets are also retained because they are user-authored\n * configuration, not call telemetry.\n */\nexport async function deleteOldTraceData(cutoffMs: number): Promise<{\n spans: number;\n summaries: number;\n evals: number;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const cutoff = Math.floor(cutoffMs);\n\n const [spansResult, summariesResult, evalsResult] = await Promise.all([\n client.execute({\n sql: `DELETE FROM agent_trace_spans WHERE created_at < ?`,\n args: [cutoff],\n }),\n client.execute({\n sql: `DELETE FROM agent_trace_summaries WHERE created_at < ?`,\n args: [cutoff],\n }),\n client.execute({\n sql: `DELETE FROM agent_evals WHERE created_at < ?`,\n args: [cutoff],\n }),\n ]);\n\n return {\n spans: Number(spansResult.rowsAffected ?? 0),\n summaries: Number(summariesResult.rowsAffected ?? 0),\n evals: Number(evalsResult.rowsAffected ?? 0),\n };\n}\n\nexport async function getTraceSpansForRun(\n runId: string,\n opts: { userId?: string } = {},\n): Promise<TraceSpan[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\"run_id = ?\", [runId], opts.userId);\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_trace_spans WHERE ${where} ORDER BY created_at ASC`,\n args,\n });\n return (rows as any[]).map(rowToTraceSpan);\n}\n\nexport async function getTraceSummaries(opts: {\n sinceMs?: number;\n limit?: number;\n userId?: string;\n}): Promise<TraceSummary[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const sinceMs = opts.sinceMs ?? 0;\n const limit = opts.limit ?? 100;\n const { where, args } = withUserFilter(\n \"created_at >= ?\",\n [sinceMs],\n opts.userId,\n );\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_trace_summaries\n WHERE ${where}\n ORDER BY created_at DESC\n LIMIT ?`,\n args: [...args, limit],\n });\n return (rows as any[]).map(rowToTraceSummary);\n}\n\nexport async function getTraceSummary(\n runId: string,\n opts: { userId?: string } = {},\n): Promise<TraceSummary | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\"run_id = ?\", [runId], opts.userId);\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_trace_summaries WHERE ${where}`,\n args,\n });\n if (rows.length === 0) return null;\n return rowToTraceSummary(rows[0] as any);\n}\n\n// ─── Feedback CRUD ───────────────────────────────────────────────────\n\nexport async function insertFeedback(entry: FeedbackEntry): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_feedback\n (id, run_id, thread_id, message_seq, feedback_type, value, user_id, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n entry.id,\n entry.runId,\n entry.threadId,\n entry.messageSeq,\n entry.feedbackType,\n entry.value,\n entry.userId,\n entry.createdAt,\n ],\n });\n}\n\nexport async function getFeedback(opts: {\n threadId?: string;\n sinceMs?: number;\n limit?: number;\n feedbackType?: string;\n userId?: string;\n}): Promise<FeedbackEntry[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const conditions: string[] = [];\n const args: any[] = [];\n if (opts.threadId) {\n conditions.push(\"thread_id = ?\");\n args.push(opts.threadId);\n }\n if (opts.sinceMs) {\n conditions.push(\"created_at >= ?\");\n args.push(opts.sinceMs);\n }\n if (opts.feedbackType) {\n conditions.push(\"feedback_type = ?\");\n args.push(opts.feedbackType);\n }\n if (opts.userId) {\n conditions.push(\"user_id = ?\");\n args.push(opts.userId);\n }\n const where =\n conditions.length > 0 ? `WHERE ${conditions.join(\" AND \")}` : \"\";\n const limit = opts.limit ?? 100;\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_feedback ${where} ORDER BY created_at DESC LIMIT ?`,\n args: [...args, limit],\n });\n return (rows as any[]).map(rowToFeedback);\n}\n\nexport async function getFeedbackStats(\n sinceMs: number,\n opts: { userId?: string } = {},\n): Promise<{\n total: number;\n thumbsUp: number;\n thumbsDown: number;\n categories: Record<string, number>;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\n \"created_at >= ?\",\n [sinceMs],\n opts.userId,\n );\n const { rows } = await client.execute({\n sql: `SELECT feedback_type, value, COUNT(*) as cnt\n FROM agent_feedback WHERE ${where}\n GROUP BY feedback_type, value`,\n args,\n });\n let total = 0;\n let thumbsUp = 0;\n let thumbsDown = 0;\n const categories: Record<string, number> = {};\n for (const row of rows as any[]) {\n const cnt = Number(row.cnt);\n total += cnt;\n if (row.feedback_type === \"thumbs_up\") thumbsUp += cnt;\n else if (row.feedback_type === \"thumbs_down\") thumbsDown += cnt;\n else if (row.feedback_type === \"category\")\n categories[String(row.value)] = cnt;\n }\n return { total, thumbsUp, thumbsDown, categories };\n}\n\n// ─── Satisfaction scores CRUD ────────────────────────────────────────\n\nexport async function upsertSatisfactionScore(\n score: SatisfactionScore,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n if (isPostgres()) {\n await client.execute({\n sql: `INSERT INTO agent_satisfaction_scores\n (id, thread_id, user_id, frustration_score, rephrasing_score,\n abandonment_score, sentiment_score, length_trend_score, computed_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (id) DO UPDATE SET\n frustration_score = EXCLUDED.frustration_score,\n rephrasing_score = EXCLUDED.rephrasing_score,\n abandonment_score = EXCLUDED.abandonment_score,\n sentiment_score = EXCLUDED.sentiment_score,\n length_trend_score = EXCLUDED.length_trend_score,\n computed_at = EXCLUDED.computed_at`,\n args: [\n score.id,\n score.threadId,\n score.userId,\n score.frustrationScore,\n score.rephrasingScore,\n score.abandonmentScore,\n score.sentimentScore,\n score.lengthTrendScore,\n score.computedAt,\n ],\n });\n } else {\n await client.execute({\n sql: `INSERT INTO agent_satisfaction_scores\n (id, thread_id, user_id, frustration_score, rephrasing_score,\n abandonment_score, sentiment_score, length_trend_score, computed_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)\n ON CONFLICT (id) DO UPDATE SET\n frustration_score = EXCLUDED.frustration_score,\n rephrasing_score = EXCLUDED.rephrasing_score,\n abandonment_score = EXCLUDED.abandonment_score,\n sentiment_score = EXCLUDED.sentiment_score,\n length_trend_score = EXCLUDED.length_trend_score,\n computed_at = EXCLUDED.computed_at`,\n args: [\n score.id,\n score.threadId,\n score.userId,\n score.frustrationScore,\n score.rephrasingScore,\n score.abandonmentScore,\n score.sentimentScore,\n score.lengthTrendScore,\n score.computedAt,\n ],\n });\n }\n}\n\nexport async function getSatisfactionScores(opts: {\n sinceMs?: number;\n limit?: number;\n minFrustration?: number;\n userId?: string;\n}): Promise<SatisfactionScore[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const conditions: string[] = [];\n const args: any[] = [];\n if (opts.sinceMs) {\n conditions.push(\"computed_at >= ?\");\n args.push(opts.sinceMs);\n }\n if (opts.minFrustration != null) {\n conditions.push(\"frustration_score >= ?\");\n args.push(opts.minFrustration);\n }\n if (opts.userId) {\n conditions.push(\"user_id = ?\");\n args.push(opts.userId);\n }\n const where =\n conditions.length > 0 ? `WHERE ${conditions.join(\" AND \")}` : \"\";\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_satisfaction_scores ${where}\n ORDER BY computed_at DESC LIMIT ?`,\n args: [...args, opts.limit ?? 100],\n });\n return (rows as any[]).map(rowToSatisfaction);\n}\n\n// ─── Evals CRUD ──────────────────────────────────────────────────────\n\nexport async function insertEvalResult(result: EvalResult): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_evals\n (id, run_id, thread_id, user_id, eval_type, criteria, score, reasoning, metadata, created_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n result.id,\n result.runId,\n result.threadId,\n result.userId,\n result.evalType,\n result.criteria,\n result.score,\n result.reasoning,\n result.metadata ? JSON.stringify(result.metadata) : null,\n result.createdAt,\n ],\n });\n}\n\nexport async function getEvalsForRun(\n runId: string,\n opts: { userId?: string } = {},\n): Promise<EvalResult[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\"run_id = ?\", [runId], opts.userId);\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_evals WHERE ${where} ORDER BY created_at ASC`,\n args,\n });\n return (rows as any[]).map(rowToEval);\n}\n\nexport async function getEvalStats(\n sinceMs: number,\n opts: { userId?: string } = {},\n): Promise<{\n totalEvals: number;\n avgScore: number;\n byCriteria: Array<{ criteria: string; avgScore: number; count: number }>;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { where, args } = withUserFilter(\n \"created_at >= ?\",\n [sinceMs],\n opts.userId,\n );\n const { rows: totalRows } = await client.execute({\n sql: `SELECT COUNT(*) as cnt, AVG(score) as avg_score\n FROM agent_evals WHERE ${where}`,\n args,\n });\n const t = (totalRows[0] ?? {}) as Record<string, number | null>;\n\n const { rows: criteriaRows } = await client.execute({\n sql: `SELECT criteria, AVG(score) as avg_score, COUNT(*) as cnt\n FROM agent_evals WHERE ${where}\n GROUP BY criteria ORDER BY cnt DESC`,\n args,\n });\n\n return {\n totalEvals: Number(t.cnt ?? 0),\n avgScore: Number(t.avg_score ?? 0),\n byCriteria: (criteriaRows as any[]).map((r) => ({\n criteria: String(r.criteria),\n avgScore: Number(r.avg_score ?? 0),\n count: Number(r.cnt ?? 0),\n })),\n };\n}\n\n// ─── Eval datasets CRUD ──────────────────────────────────────────────\n\nexport async function insertEvalDataset(dataset: EvalDataset): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_eval_datasets\n (id, name, description, entries, created_at, updated_at)\n VALUES (?, ?, ?, ?, ?, ?)`,\n args: [\n dataset.id,\n dataset.name,\n dataset.description,\n JSON.stringify(dataset.entries),\n dataset.createdAt,\n dataset.updatedAt,\n ],\n });\n}\n\nexport async function listEvalDatasets(): Promise<EvalDataset[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute(\n `SELECT * FROM agent_eval_datasets ORDER BY updated_at DESC`,\n );\n return (rows as any[]).map(rowToDataset);\n}\n\nexport async function getEvalDataset(id: string): Promise<EvalDataset | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_eval_datasets WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return null;\n return rowToDataset(rows[0] as any);\n}\n\nexport async function updateEvalDataset(\n id: string,\n updates: Partial<Pick<EvalDataset, \"name\" | \"description\" | \"entries\">>,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const sets: string[] = [];\n const args: any[] = [];\n if (updates.name !== undefined) {\n sets.push(\"name = ?\");\n args.push(updates.name);\n }\n if (updates.description !== undefined) {\n sets.push(\"description = ?\");\n args.push(updates.description);\n }\n if (updates.entries !== undefined) {\n sets.push(\"entries = ?\");\n args.push(JSON.stringify(updates.entries));\n }\n sets.push(\"updated_at = ?\");\n args.push(Date.now());\n args.push(id);\n await client.execute({\n sql: `UPDATE agent_eval_datasets SET ${sets.join(\", \")} WHERE id = ?`,\n args,\n });\n}\n\n// ─── Experiments CRUD ────────────────────────────────────────────────\n\nexport async function insertExperiment(exp: Experiment): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_experiments\n (id, name, status, variants, metrics, assignment_level,\n started_at, ended_at, created_at, owner_email)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n exp.id,\n exp.name,\n exp.status,\n JSON.stringify(exp.variants),\n JSON.stringify(exp.metrics),\n exp.assignmentLevel,\n exp.startedAt,\n exp.endedAt,\n exp.createdAt,\n exp.ownerEmail ?? null,\n ],\n });\n}\n\nexport async function updateExperiment(\n id: string,\n updates: Partial<\n Pick<Experiment, \"name\" | \"status\" | \"variants\" | \"metrics\" | \"endedAt\">\n >,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const sets: string[] = [];\n const args: any[] = [];\n if (updates.name !== undefined) {\n sets.push(\"name = ?\");\n args.push(updates.name);\n }\n if (updates.status !== undefined) {\n sets.push(\"status = ?\");\n args.push(updates.status);\n if (updates.status === \"running\" && !updates.endedAt) {\n sets.push(\"started_at = ?\");\n args.push(Date.now());\n }\n }\n if (updates.variants !== undefined) {\n sets.push(\"variants = ?\");\n args.push(JSON.stringify(updates.variants));\n }\n if (updates.metrics !== undefined) {\n sets.push(\"metrics = ?\");\n args.push(JSON.stringify(updates.metrics));\n }\n if (updates.endedAt !== undefined) {\n sets.push(\"ended_at = ?\");\n args.push(updates.endedAt);\n }\n if (sets.length === 0) return;\n args.push(id);\n await client.execute({\n sql: `UPDATE agent_experiments SET ${sets.join(\", \")} WHERE id = ?`,\n args,\n });\n}\n\nexport async function listExperiments(): Promise<Experiment[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute(\n `SELECT * FROM agent_experiments ORDER BY created_at DESC`,\n );\n return (rows as any[]).map(rowToExperiment);\n}\n\nexport async function getExperiment(id: string): Promise<Experiment | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_experiments WHERE id = ?`,\n args: [id],\n });\n if (rows.length === 0) return null;\n return rowToExperiment(rows[0] as any);\n}\n\n// ─── Experiment assignments CRUD ────────────────────────────────────\n\nexport async function upsertAssignment(\n assignment: ExperimentAssignment,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n if (isPostgres()) {\n await client.execute({\n sql: `INSERT INTO agent_experiment_assignments\n (experiment_id, user_id, variant_id, assigned_at)\n VALUES (?, ?, ?, ?)\n ON CONFLICT (experiment_id, user_id) DO UPDATE SET\n variant_id = EXCLUDED.variant_id,\n assigned_at = EXCLUDED.assigned_at`,\n args: [\n assignment.experimentId,\n assignment.userId,\n assignment.variantId,\n assignment.assignedAt,\n ],\n });\n } else {\n await client.execute({\n sql: `INSERT OR REPLACE INTO agent_experiment_assignments\n (experiment_id, user_id, variant_id, assigned_at)\n VALUES (?, ?, ?, ?)`,\n args: [\n assignment.experimentId,\n assignment.userId,\n assignment.variantId,\n assignment.assignedAt,\n ],\n });\n }\n}\n\nexport async function getAssignment(\n experimentId: string,\n userId: string,\n): Promise<ExperimentAssignment | null> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_experiment_assignments\n WHERE experiment_id = ? AND user_id = ?`,\n args: [experimentId, userId],\n });\n if (rows.length === 0) return null;\n const r = rows[0] as any;\n return {\n experimentId: r.experiment_id,\n userId: r.user_id,\n variantId: r.variant_id,\n assignedAt: Number(r.assigned_at),\n };\n}\n\n// ─── Experiment results CRUD ─────────────────────────────────────────\n\nexport async function insertExperimentResult(\n result: ExperimentMetricResult,\n): Promise<void> {\n await ensureObservabilityTables();\n const client = getDbExec();\n await client.execute({\n sql: `INSERT INTO agent_experiment_results\n (id, experiment_id, variant_id, metric, value,\n sample_size, confidence_low, confidence_high, computed_at)\n VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,\n args: [\n result.id,\n result.experimentId,\n result.variantId,\n result.metric,\n result.value,\n result.sampleSize,\n result.confidenceLow,\n result.confidenceHigh,\n result.computedAt,\n ],\n });\n}\n\nexport async function getExperimentResults(\n experimentId: string,\n): Promise<ExperimentMetricResult[]> {\n await ensureObservabilityTables();\n const client = getDbExec();\n const { rows } = await client.execute({\n sql: `SELECT * FROM agent_experiment_results\n WHERE experiment_id = ?\n ORDER BY computed_at DESC`,\n args: [experimentId],\n });\n return (rows as any[]).map(rowToExperimentResult);\n}\n\n// ─── Aggregate queries for dashboard ─────────────────────────────────\n\nexport async function getObservabilityOverview(\n sinceMs: number,\n opts: { userId?: string } = {},\n): Promise<{\n totalRuns: number;\n totalCostCents: number;\n avgDurationMs: number;\n toolSuccessRate: number;\n avgFrustrationScore: number;\n thumbsUpRate: number;\n avgEvalScore: number;\n}> {\n await ensureObservabilityTables();\n const client = getDbExec();\n\n // Three of the four sub-queries time-key on `created_at`; satisfaction\n // uses `computed_at`. Each gets its own `withUserFilter` invocation so\n // the args array isn't aliased across calls (some drivers mutate args\n // for prepared-statement caching).\n const created = withUserFilter(\"created_at >= ?\", [sinceMs], opts.userId);\n const computed = withUserFilter(\"computed_at >= ?\", [sinceMs], opts.userId);\n\n const [tracesResult, satisfactionResult, feedbackResult, evalsResult] =\n await Promise.all([\n client.execute({\n sql: `SELECT\n COUNT(*) as total_runs,\n COALESCE(SUM(total_cost_cents_x100), 0) as total_cost,\n COALESCE(AVG(total_duration_ms), 0) as avg_duration,\n COALESCE(SUM(successful_tools), 0) as success_tools,\n COALESCE(SUM(tool_calls), 0) as total_tools\n FROM agent_trace_summaries WHERE ${created.where}`,\n args: created.args,\n }),\n client.execute({\n sql: `SELECT COALESCE(AVG(frustration_score), 0) as avg_frustration\n FROM agent_satisfaction_scores WHERE ${computed.where}`,\n args: computed.args,\n }),\n client.execute({\n sql: `SELECT\n COALESCE(SUM(CASE WHEN feedback_type = 'thumbs_up' THEN 1 ELSE 0 END), 0) as up,\n COALESCE(SUM(CASE WHEN feedback_type IN ('thumbs_up', 'thumbs_down') THEN 1 ELSE 0 END), 0) as total\n FROM agent_feedback WHERE ${created.where}`,\n args: created.args,\n }),\n client.execute({\n sql: `SELECT COALESCE(AVG(score), 0) as avg_score\n FROM agent_evals WHERE ${created.where}`,\n args: created.args,\n }),\n ]);\n\n const t = (tracesResult.rows[0] ?? {}) as Record<string, number | null>;\n const s = (satisfactionResult.rows[0] ?? {}) as Record<string, number | null>;\n const f = (feedbackResult.rows[0] ?? {}) as Record<string, number | null>;\n const e = (evalsResult.rows[0] ?? {}) as Record<string, number | null>;\n\n const totalTools = Number(t.total_tools ?? 0);\n const successTools = Number(t.success_tools ?? 0);\n const feedbackTotal = Number(f.total ?? 0);\n const feedbackUp = Number(f.up ?? 0);\n\n return {\n totalRuns: Number(t.total_runs ?? 0),\n totalCostCents: Number(t.total_cost ?? 0) / 100,\n avgDurationMs: Number(t.avg_duration ?? 0),\n toolSuccessRate: totalTools > 0 ? successTools / totalTools : 1,\n avgFrustrationScore: Number(s.avg_frustration ?? 0),\n thumbsUpRate: feedbackTotal > 0 ? feedbackUp / feedbackTotal : 0,\n avgEvalScore: Number(e.avg_score ?? 0),\n };\n}\n\n// ─── Row mappers ─────────────────────────────────────────────────────\n\nfunction rowToTraceSpan(row: Record<string, any>): TraceSpan {\n return {\n id: String(row.id),\n runId: String(row.run_id),\n threadId: row.thread_id ? String(row.thread_id) : null,\n userId: row.user_id ? String(row.user_id) : null,\n parentSpanId: row.parent_span_id ? String(row.parent_span_id) : null,\n spanType: row.span_type as TraceSpan[\"spanType\"],\n name: String(row.name),\n inputTokens: Number(row.input_tokens ?? 0),\n outputTokens: Number(row.output_tokens ?? 0),\n cacheReadTokens: Number(row.cache_read_tokens ?? 0),\n cacheWriteTokens: Number(row.cache_write_tokens ?? 0),\n costCentsX100: Number(row.cost_cents_x100 ?? 0),\n durationMs: Number(row.duration_ms ?? 0),\n status: row.status as TraceSpan[\"status\"],\n errorMessage: row.error_message ? String(row.error_message) : null,\n metadata: safeJsonParse(row.metadata, null),\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToTraceSummary(row: Record<string, any>): TraceSummary {\n return {\n runId: String(row.run_id),\n threadId: row.thread_id ? String(row.thread_id) : null,\n userId: row.user_id ? String(row.user_id) : null,\n totalSpans: Number(row.total_spans ?? 0),\n llmCalls: Number(row.llm_calls ?? 0),\n toolCalls: Number(row.tool_calls ?? 0),\n successfulTools: Number(row.successful_tools ?? 0),\n failedTools: Number(row.failed_tools ?? 0),\n totalDurationMs: Number(row.total_duration_ms ?? 0),\n totalCostCentsX100: Number(row.total_cost_cents_x100 ?? 0),\n totalInputTokens: Number(row.total_input_tokens ?? 0),\n totalOutputTokens: Number(row.total_output_tokens ?? 0),\n model: String(row.model ?? \"\"),\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToFeedback(row: Record<string, any>): FeedbackEntry {\n return {\n id: String(row.id),\n runId: row.run_id ? String(row.run_id) : null,\n threadId: row.thread_id ? String(row.thread_id) : null,\n messageSeq: row.message_seq != null ? Number(row.message_seq) : null,\n feedbackType: row.feedback_type as FeedbackEntry[\"feedbackType\"],\n value: String(row.value ?? \"\"),\n userId: row.user_id ? String(row.user_id) : null,\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToSatisfaction(row: Record<string, any>): SatisfactionScore {\n return {\n id: String(row.id),\n threadId: String(row.thread_id),\n userId: row.user_id ? String(row.user_id) : null,\n frustrationScore: Number(row.frustration_score ?? 0),\n rephrasingScore: Number(row.rephrasing_score ?? 0),\n abandonmentScore: Number(row.abandonment_score ?? 0),\n sentimentScore: Number(row.sentiment_score ?? 0),\n lengthTrendScore: Number(row.length_trend_score ?? 0),\n computedAt: Number(row.computed_at),\n };\n}\n\nfunction rowToEval(row: Record<string, any>): EvalResult {\n return {\n id: String(row.id),\n runId: String(row.run_id),\n threadId: row.thread_id ? String(row.thread_id) : null,\n userId: row.user_id ? String(row.user_id) : null,\n evalType: row.eval_type as EvalResult[\"evalType\"],\n criteria: String(row.criteria),\n score: Number(row.score ?? 0),\n reasoning: row.reasoning ? String(row.reasoning) : null,\n metadata: safeJsonParse(row.metadata, null),\n createdAt: Number(row.created_at),\n };\n}\n\nfunction rowToDataset(row: Record<string, any>): EvalDataset {\n return {\n id: String(row.id),\n name: String(row.name),\n description: String(row.description ?? \"\"),\n entries: safeJsonParse(row.entries, []),\n createdAt: Number(row.created_at),\n updatedAt: Number(row.updated_at),\n };\n}\n\nfunction rowToExperiment(row: Record<string, any>): Experiment {\n return {\n id: String(row.id),\n name: String(row.name),\n status: row.status as Experiment[\"status\"],\n variants: safeJsonParse(row.variants, []),\n metrics: safeJsonParse(row.metrics, []),\n assignmentLevel: (row.assignment_level as \"user\" | \"session\") ?? \"user\",\n startedAt: row.started_at ? Number(row.started_at) : null,\n endedAt: row.ended_at ? Number(row.ended_at) : null,\n createdAt: Number(row.created_at),\n ownerEmail:\n typeof row.owner_email === \"string\" && row.owner_email\n ? row.owner_email\n : null,\n };\n}\n\nfunction rowToExperimentResult(\n row: Record<string, any>,\n): ExperimentMetricResult {\n return {\n id: String(row.id),\n experimentId: String(row.experiment_id),\n variantId: String(row.variant_id),\n metric: String(row.metric),\n value: Number(row.value ?? 0),\n sampleSize: Number(row.sample_size ?? 0),\n confidenceLow: Number(row.confidence_low ?? 0),\n confidenceHigh: Number(row.confidence_high ?? 0),\n computedAt: Number(row.computed_at),\n };\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"default-steps.d.ts","sourceRoot":"","sources":["../../src/onboarding/default-steps.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AA+PH,6DAA6D;AAC7D,wBAAgB,8BAA8B,IAAI,IAAI,CAOrD"}
1
+ {"version":3,"file":"default-steps.d.ts","sourceRoot":"","sources":["../../src/onboarding/default-steps.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAoSH,6DAA6D;AAC7D,wBAAgB,8BAA8B,IAAI,IAAI,CAOrD"}