@agentlensai/server 0.10.0 → 0.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (807) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cloud/auth/api-key-middleware.d.ts +66 -0
  3. package/dist/cloud/auth/api-key-middleware.d.ts.map +1 -0
  4. package/dist/cloud/auth/api-key-middleware.js +147 -0
  5. package/dist/cloud/auth/api-key-middleware.js.map +1 -0
  6. package/dist/cloud/auth/api-keys.d.ts +90 -0
  7. package/dist/cloud/auth/api-keys.d.ts.map +1 -0
  8. package/dist/cloud/auth/api-keys.js +162 -0
  9. package/dist/cloud/auth/api-keys.js.map +1 -0
  10. package/dist/cloud/auth/audit-log.d.ts +66 -0
  11. package/dist/cloud/auth/audit-log.d.ts.map +1 -0
  12. package/dist/cloud/auth/audit-log.js +92 -0
  13. package/dist/cloud/auth/audit-log.js.map +1 -0
  14. package/dist/cloud/auth/auth-service.d.ts +77 -0
  15. package/dist/cloud/auth/auth-service.d.ts.map +1 -0
  16. package/dist/cloud/auth/auth-service.js +229 -0
  17. package/dist/cloud/auth/auth-service.js.map +1 -0
  18. package/dist/cloud/auth/brute-force.d.ts +36 -0
  19. package/dist/cloud/auth/brute-force.d.ts.map +1 -0
  20. package/dist/cloud/auth/brute-force.js +67 -0
  21. package/dist/cloud/auth/brute-force.js.map +1 -0
  22. package/dist/cloud/auth/index.d.ts +11 -0
  23. package/dist/cloud/auth/index.d.ts.map +1 -0
  24. package/dist/cloud/auth/index.js +11 -0
  25. package/dist/cloud/auth/index.js.map +1 -0
  26. package/dist/cloud/auth/jwt.d.ts +34 -0
  27. package/dist/cloud/auth/jwt.d.ts.map +1 -0
  28. package/dist/cloud/auth/jwt.js +68 -0
  29. package/dist/cloud/auth/jwt.js.map +1 -0
  30. package/dist/cloud/auth/oauth.d.ts +37 -0
  31. package/dist/cloud/auth/oauth.d.ts.map +1 -0
  32. package/dist/cloud/auth/oauth.js +120 -0
  33. package/dist/cloud/auth/oauth.js.map +1 -0
  34. package/dist/cloud/auth/passwords.d.ts +25 -0
  35. package/dist/cloud/auth/passwords.d.ts.map +1 -0
  36. package/dist/cloud/auth/passwords.js +50 -0
  37. package/dist/cloud/auth/passwords.js.map +1 -0
  38. package/dist/cloud/auth/rbac.d.ts +51 -0
  39. package/dist/cloud/auth/rbac.d.ts.map +1 -0
  40. package/dist/cloud/auth/rbac.js +89 -0
  41. package/dist/cloud/auth/rbac.js.map +1 -0
  42. package/dist/cloud/auth/tokens.d.ts +18 -0
  43. package/dist/cloud/auth/tokens.d.ts.map +1 -0
  44. package/dist/cloud/auth/tokens.js +29 -0
  45. package/dist/cloud/auth/tokens.js.map +1 -0
  46. package/dist/cloud/billing/billing-service.d.ts +44 -0
  47. package/dist/cloud/billing/billing-service.d.ts.map +1 -0
  48. package/dist/cloud/billing/billing-service.js +153 -0
  49. package/dist/cloud/billing/billing-service.js.map +1 -0
  50. package/dist/cloud/billing/index.d.ts +11 -0
  51. package/dist/cloud/billing/index.d.ts.map +1 -0
  52. package/dist/cloud/billing/index.js +11 -0
  53. package/dist/cloud/billing/index.js.map +1 -0
  54. package/dist/cloud/billing/invoice-service.d.ts +57 -0
  55. package/dist/cloud/billing/invoice-service.d.ts.map +1 -0
  56. package/dist/cloud/billing/invoice-service.js +123 -0
  57. package/dist/cloud/billing/invoice-service.js.map +1 -0
  58. package/dist/cloud/billing/plan-management.d.ts +46 -0
  59. package/dist/cloud/billing/plan-management.d.ts.map +1 -0
  60. package/dist/cloud/billing/plan-management.js +157 -0
  61. package/dist/cloud/billing/plan-management.js.map +1 -0
  62. package/dist/cloud/billing/quota-enforcement.d.ts +53 -0
  63. package/dist/cloud/billing/quota-enforcement.d.ts.map +1 -0
  64. package/dist/cloud/billing/quota-enforcement.js +143 -0
  65. package/dist/cloud/billing/quota-enforcement.js.map +1 -0
  66. package/dist/cloud/billing/stripe-client.d.ts +142 -0
  67. package/dist/cloud/billing/stripe-client.d.ts.map +1 -0
  68. package/dist/cloud/billing/stripe-client.js +174 -0
  69. package/dist/cloud/billing/stripe-client.js.map +1 -0
  70. package/dist/cloud/billing/trial-service.d.ts +47 -0
  71. package/dist/cloud/billing/trial-service.d.ts.map +1 -0
  72. package/dist/cloud/billing/trial-service.js +104 -0
  73. package/dist/cloud/billing/trial-service.js.map +1 -0
  74. package/dist/cloud/billing/usage-metering.d.ts +83 -0
  75. package/dist/cloud/billing/usage-metering.d.ts.map +1 -0
  76. package/dist/cloud/billing/usage-metering.js +174 -0
  77. package/dist/cloud/billing/usage-metering.js.map +1 -0
  78. package/dist/cloud/ingestion/backpressure.d.ts +107 -0
  79. package/dist/cloud/ingestion/backpressure.d.ts.map +1 -0
  80. package/dist/cloud/ingestion/backpressure.js +134 -0
  81. package/dist/cloud/ingestion/backpressure.js.map +1 -0
  82. package/dist/cloud/ingestion/batch-writer.d.ts +115 -0
  83. package/dist/cloud/ingestion/batch-writer.d.ts.map +1 -0
  84. package/dist/cloud/ingestion/batch-writer.js +319 -0
  85. package/dist/cloud/ingestion/batch-writer.js.map +1 -0
  86. package/dist/cloud/ingestion/dlq-manager.d.ts +116 -0
  87. package/dist/cloud/ingestion/dlq-manager.d.ts.map +1 -0
  88. package/dist/cloud/ingestion/dlq-manager.js +244 -0
  89. package/dist/cloud/ingestion/dlq-manager.js.map +1 -0
  90. package/dist/cloud/ingestion/event-queue.d.ts +105 -0
  91. package/dist/cloud/ingestion/event-queue.d.ts.map +1 -0
  92. package/dist/cloud/ingestion/event-queue.js +185 -0
  93. package/dist/cloud/ingestion/event-queue.js.map +1 -0
  94. package/dist/cloud/ingestion/gateway.d.ts +68 -0
  95. package/dist/cloud/ingestion/gateway.d.ts.map +1 -0
  96. package/dist/cloud/ingestion/gateway.js +197 -0
  97. package/dist/cloud/ingestion/gateway.js.map +1 -0
  98. package/dist/cloud/ingestion/index.d.ts +7 -0
  99. package/dist/cloud/ingestion/index.d.ts.map +1 -0
  100. package/dist/cloud/ingestion/index.js +7 -0
  101. package/dist/cloud/ingestion/index.js.map +1 -0
  102. package/dist/cloud/ingestion/rate-limiter.d.ts +73 -0
  103. package/dist/cloud/ingestion/rate-limiter.d.ts.map +1 -0
  104. package/dist/cloud/ingestion/rate-limiter.js +153 -0
  105. package/dist/cloud/ingestion/rate-limiter.js.map +1 -0
  106. package/dist/cloud/middleware/validate-org-access.d.ts +14 -0
  107. package/dist/cloud/middleware/validate-org-access.d.ts.map +1 -0
  108. package/dist/cloud/middleware/validate-org-access.js +38 -0
  109. package/dist/cloud/middleware/validate-org-access.js.map +1 -0
  110. package/dist/cloud/migrate.d.ts +45 -0
  111. package/dist/cloud/migrate.d.ts.map +1 -0
  112. package/dist/cloud/migrate.js +147 -0
  113. package/dist/cloud/migrate.js.map +1 -0
  114. package/dist/cloud/migration/export-import.d.ts +56 -0
  115. package/dist/cloud/migration/export-import.d.ts.map +1 -0
  116. package/dist/cloud/migration/export-import.js +289 -0
  117. package/dist/cloud/migration/export-import.js.map +1 -0
  118. package/dist/cloud/migration/index.d.ts +5 -0
  119. package/dist/cloud/migration/index.d.ts.map +1 -0
  120. package/dist/cloud/migration/index.js +5 -0
  121. package/dist/cloud/migration/index.js.map +1 -0
  122. package/dist/cloud/org-service.d.ts +68 -0
  123. package/dist/cloud/org-service.d.ts.map +1 -0
  124. package/dist/cloud/org-service.js +169 -0
  125. package/dist/cloud/org-service.js.map +1 -0
  126. package/dist/cloud/partition-maintenance.d.ts +29 -0
  127. package/dist/cloud/partition-maintenance.d.ts.map +1 -0
  128. package/dist/cloud/partition-maintenance.js +96 -0
  129. package/dist/cloud/partition-maintenance.js.map +1 -0
  130. package/dist/cloud/retention/index.d.ts +7 -0
  131. package/dist/cloud/retention/index.d.ts.map +1 -0
  132. package/dist/cloud/retention/index.js +7 -0
  133. package/dist/cloud/retention/index.js.map +1 -0
  134. package/dist/cloud/retention/partition-management.d.ts +61 -0
  135. package/dist/cloud/retention/partition-management.d.ts.map +1 -0
  136. package/dist/cloud/retention/partition-management.js +167 -0
  137. package/dist/cloud/retention/partition-management.js.map +1 -0
  138. package/dist/cloud/retention/retention-job.d.ts +70 -0
  139. package/dist/cloud/retention/retention-job.d.ts.map +1 -0
  140. package/dist/cloud/retention/retention-job.js +160 -0
  141. package/dist/cloud/retention/retention-job.js.map +1 -0
  142. package/dist/cloud/retention/retention-policy.d.ts +27 -0
  143. package/dist/cloud/retention/retention-policy.d.ts.map +1 -0
  144. package/dist/cloud/retention/retention-policy.js +36 -0
  145. package/dist/cloud/retention/retention-policy.js.map +1 -0
  146. package/dist/cloud/routes/api-key-routes.d.ts +38 -0
  147. package/dist/cloud/routes/api-key-routes.d.ts.map +1 -0
  148. package/dist/cloud/routes/api-key-routes.js +84 -0
  149. package/dist/cloud/routes/api-key-routes.js.map +1 -0
  150. package/dist/cloud/routes/audit-routes.d.ts +36 -0
  151. package/dist/cloud/routes/audit-routes.d.ts.map +1 -0
  152. package/dist/cloud/routes/audit-routes.js +47 -0
  153. package/dist/cloud/routes/audit-routes.js.map +1 -0
  154. package/dist/cloud/routes/billing-routes.d.ts +51 -0
  155. package/dist/cloud/routes/billing-routes.d.ts.map +1 -0
  156. package/dist/cloud/routes/billing-routes.js +114 -0
  157. package/dist/cloud/routes/billing-routes.js.map +1 -0
  158. package/dist/cloud/routes/index.d.ts +13 -0
  159. package/dist/cloud/routes/index.d.ts.map +1 -0
  160. package/dist/cloud/routes/index.js +98 -0
  161. package/dist/cloud/routes/index.js.map +1 -0
  162. package/dist/cloud/routes/onboarding-routes.d.ts +34 -0
  163. package/dist/cloud/routes/onboarding-routes.d.ts.map +1 -0
  164. package/dist/cloud/routes/onboarding-routes.js +58 -0
  165. package/dist/cloud/routes/onboarding-routes.js.map +1 -0
  166. package/dist/cloud/routes/org-routes.d.ts +80 -0
  167. package/dist/cloud/routes/org-routes.d.ts.map +1 -0
  168. package/dist/cloud/routes/org-routes.js +153 -0
  169. package/dist/cloud/routes/org-routes.js.map +1 -0
  170. package/dist/cloud/routes/usage-routes.d.ts +18 -0
  171. package/dist/cloud/routes/usage-routes.d.ts.map +1 -0
  172. package/dist/cloud/routes/usage-routes.js +66 -0
  173. package/dist/cloud/routes/usage-routes.js.map +1 -0
  174. package/dist/cloud/storage/adapter.d.ts +102 -0
  175. package/dist/cloud/storage/adapter.d.ts.map +1 -0
  176. package/dist/cloud/storage/adapter.js +21 -0
  177. package/dist/cloud/storage/adapter.js.map +1 -0
  178. package/dist/cloud/storage/index.d.ts +8 -0
  179. package/dist/cloud/storage/index.d.ts.map +1 -0
  180. package/dist/cloud/storage/index.js +7 -0
  181. package/dist/cloud/storage/index.js.map +1 -0
  182. package/dist/cloud/storage/postgres-adapter.d.ts +34 -0
  183. package/dist/cloud/storage/postgres-adapter.d.ts.map +1 -0
  184. package/dist/cloud/storage/postgres-adapter.js +544 -0
  185. package/dist/cloud/storage/postgres-adapter.js.map +1 -0
  186. package/dist/cloud/storage/sqlite-adapter.d.ts +29 -0
  187. package/dist/cloud/storage/sqlite-adapter.d.ts.map +1 -0
  188. package/dist/cloud/storage/sqlite-adapter.js +176 -0
  189. package/dist/cloud/storage/sqlite-adapter.js.map +1 -0
  190. package/dist/cloud/tenant-pool.d.ts +49 -0
  191. package/dist/cloud/tenant-pool.d.ts.map +1 -0
  192. package/dist/cloud/tenant-pool.js +61 -0
  193. package/dist/cloud/tenant-pool.js.map +1 -0
  194. package/dist/config.d.ts +33 -1
  195. package/dist/config.d.ts.map +1 -1
  196. package/dist/config.js +71 -1
  197. package/dist/config.js.map +1 -1
  198. package/dist/db/api-key-lookup.d.ts +25 -0
  199. package/dist/db/api-key-lookup.d.ts.map +1 -0
  200. package/dist/db/api-key-lookup.js +38 -0
  201. package/dist/db/api-key-lookup.js.map +1 -0
  202. package/dist/db/connection.postgres.d.ts +44 -0
  203. package/dist/db/connection.postgres.d.ts.map +1 -0
  204. package/dist/db/connection.postgres.js +79 -0
  205. package/dist/db/connection.postgres.js.map +1 -0
  206. package/dist/db/cost-budget-store.d.ts +30 -0
  207. package/dist/db/cost-budget-store.d.ts.map +1 -0
  208. package/dist/db/cost-budget-store.js +201 -0
  209. package/dist/db/cost-budget-store.js.map +1 -0
  210. package/dist/db/drizzle/0000_initial.sql +336 -0
  211. package/dist/db/drizzle/0001_indexes.sql +20 -0
  212. package/dist/db/drizzle/0002_pgvector.sql +19 -0
  213. package/dist/db/drizzle/drizzle/0000_initial.sql +336 -0
  214. package/dist/db/drizzle/drizzle/0001_indexes.sql +20 -0
  215. package/dist/db/drizzle/drizzle/0002_pgvector.sql +19 -0
  216. package/dist/db/drizzle/drizzle/meta/0000_snapshot.json +2593 -0
  217. package/dist/db/drizzle/drizzle/meta/_journal.json +27 -0
  218. package/dist/db/drizzle/meta/0000_snapshot.json +2593 -0
  219. package/dist/db/drizzle/meta/_journal.json +27 -0
  220. package/dist/db/embedding-store.d.ts +2 -1
  221. package/dist/db/embedding-store.d.ts.map +1 -1
  222. package/dist/db/embedding-store.interface.d.ts +19 -0
  223. package/dist/db/embedding-store.interface.d.ts.map +1 -0
  224. package/dist/db/embedding-store.interface.js +7 -0
  225. package/dist/db/embedding-store.interface.js.map +1 -0
  226. package/dist/db/embedding-store.js +3 -1
  227. package/dist/db/embedding-store.js.map +1 -1
  228. package/dist/db/eval-store.d.ts +88 -0
  229. package/dist/db/eval-store.d.ts.map +1 -0
  230. package/dist/db/eval-store.js +408 -0
  231. package/dist/db/eval-store.js.map +1 -0
  232. package/dist/db/guardrail-store.d.ts +9 -0
  233. package/dist/db/guardrail-store.d.ts.map +1 -1
  234. package/dist/db/guardrail-store.js +57 -3
  235. package/dist/db/guardrail-store.js.map +1 -1
  236. package/dist/db/index.d.ts +7 -0
  237. package/dist/db/index.d.ts.map +1 -1
  238. package/dist/db/index.js +4 -12
  239. package/dist/db/index.js.map +1 -1
  240. package/dist/db/migrate.d.ts +5 -22
  241. package/dist/db/migrate.d.ts.map +1 -1
  242. package/dist/db/migrate.js +7 -637
  243. package/dist/db/migrate.js.map +1 -1
  244. package/dist/db/migrate.postgres.d.ts +16 -0
  245. package/dist/db/migrate.postgres.d.ts.map +1 -0
  246. package/dist/db/migrate.postgres.js +23 -0
  247. package/dist/db/migrate.postgres.js.map +1 -0
  248. package/dist/db/migrate.sqlite.d.ts +26 -0
  249. package/dist/db/migrate.sqlite.d.ts.map +1 -0
  250. package/dist/db/migrate.sqlite.js +920 -0
  251. package/dist/db/migrate.sqlite.js.map +1 -0
  252. package/dist/db/postgres-embedding-store.d.ts +23 -0
  253. package/dist/db/postgres-embedding-store.d.ts.map +1 -0
  254. package/dist/db/postgres-embedding-store.js +218 -0
  255. package/dist/db/postgres-embedding-store.js.map +1 -0
  256. package/dist/db/postgres-store.d.ts +80 -0
  257. package/dist/db/postgres-store.d.ts.map +1 -0
  258. package/dist/db/postgres-store.js +910 -0
  259. package/dist/db/postgres-store.js.map +1 -0
  260. package/dist/db/prompt-store.d.ts +57 -0
  261. package/dist/db/prompt-store.d.ts.map +1 -0
  262. package/dist/db/prompt-store.js +300 -0
  263. package/dist/db/prompt-store.js.map +1 -0
  264. package/dist/db/repositories/agent-repository.d.ts +21 -0
  265. package/dist/db/repositories/agent-repository.d.ts.map +1 -0
  266. package/dist/db/repositories/agent-repository.js +142 -0
  267. package/dist/db/repositories/agent-repository.js.map +1 -0
  268. package/dist/db/repositories/alert-repository.d.ts +27 -0
  269. package/dist/db/repositories/alert-repository.d.ts.map +1 -0
  270. package/dist/db/repositories/alert-repository.js +164 -0
  271. package/dist/db/repositories/alert-repository.js.map +1 -0
  272. package/dist/db/repositories/analytics-repository.d.ts +24 -0
  273. package/dist/db/repositories/analytics-repository.d.ts.map +1 -0
  274. package/dist/db/repositories/analytics-repository.js +147 -0
  275. package/dist/db/repositories/analytics-repository.js.map +1 -0
  276. package/dist/db/repositories/event-repository.d.ts +81 -0
  277. package/dist/db/repositories/event-repository.d.ts.map +1 -0
  278. package/dist/db/repositories/event-repository.js +331 -0
  279. package/dist/db/repositories/event-repository.js.map +1 -0
  280. package/dist/db/repositories/notification-channel-repository.d.ts +28 -0
  281. package/dist/db/repositories/notification-channel-repository.d.ts.map +1 -0
  282. package/dist/db/repositories/notification-channel-repository.js +151 -0
  283. package/dist/db/repositories/notification-channel-repository.js.map +1 -0
  284. package/dist/db/repositories/session-repository.d.ts +26 -0
  285. package/dist/db/repositories/session-repository.d.ts.map +1 -0
  286. package/dist/db/repositories/session-repository.js +240 -0
  287. package/dist/db/repositories/session-repository.js.map +1 -0
  288. package/dist/db/schema.postgres.d.ts +4681 -0
  289. package/dist/db/schema.postgres.d.ts.map +1 -0
  290. package/dist/db/schema.postgres.js +458 -0
  291. package/dist/db/schema.postgres.js.map +1 -0
  292. package/dist/db/schema.sqlite.d.ts +2221 -671
  293. package/dist/db/schema.sqlite.d.ts.map +1 -1
  294. package/dist/db/schema.sqlite.js +137 -2
  295. package/dist/db/schema.sqlite.js.map +1 -1
  296. package/dist/db/services/retention-service.d.ts +13 -0
  297. package/dist/db/services/retention-service.d.ts.map +1 -0
  298. package/dist/db/services/retention-service.js +48 -0
  299. package/dist/db/services/retention-service.js.map +1 -0
  300. package/dist/db/shared/query-helpers.d.ts +32 -0
  301. package/dist/db/shared/query-helpers.d.ts.map +1 -0
  302. package/dist/db/shared/query-helpers.js +180 -0
  303. package/dist/db/shared/query-helpers.js.map +1 -0
  304. package/dist/db/sqlite-store.d.ts +48 -55
  305. package/dist/db/sqlite-store.d.ts.map +1 -1
  306. package/dist/db/sqlite-store.js +78 -945
  307. package/dist/db/sqlite-store.js.map +1 -1
  308. package/dist/db/tenant-scoped-store.d.ts +18 -1
  309. package/dist/db/tenant-scoped-store.d.ts.map +1 -1
  310. package/dist/db/tenant-scoped-store.js +6 -0
  311. package/dist/db/tenant-scoped-store.js.map +1 -1
  312. package/dist/index.d.ts +28 -14
  313. package/dist/index.d.ts.map +1 -1
  314. package/dist/index.js +432 -97
  315. package/dist/index.js.map +1 -1
  316. package/dist/lib/alert-engine.d.ts +10 -0
  317. package/dist/lib/alert-engine.d.ts.map +1 -1
  318. package/dist/lib/alert-engine.js +73 -20
  319. package/dist/lib/alert-engine.js.map +1 -1
  320. package/dist/lib/audit-verify.d.ts +40 -0
  321. package/dist/lib/audit-verify.d.ts.map +1 -0
  322. package/dist/lib/audit-verify.js +128 -0
  323. package/dist/lib/audit-verify.js.map +1 -0
  324. package/dist/lib/audit.d.ts +37 -0
  325. package/dist/lib/audit.d.ts.map +1 -0
  326. package/dist/lib/audit.js +59 -0
  327. package/dist/lib/audit.js.map +1 -0
  328. package/dist/lib/budget-engine.d.ts +26 -0
  329. package/dist/lib/budget-engine.d.ts.map +1 -0
  330. package/dist/lib/budget-engine.js +201 -0
  331. package/dist/lib/budget-engine.js.map +1 -0
  332. package/dist/lib/compliance-export.d.ts +41 -0
  333. package/dist/lib/compliance-export.d.ts.map +1 -0
  334. package/dist/lib/compliance-export.js +124 -0
  335. package/dist/lib/compliance-export.js.map +1 -0
  336. package/dist/lib/compliance-report.d.ts +87 -0
  337. package/dist/lib/compliance-report.d.ts.map +1 -0
  338. package/dist/lib/compliance-report.js +148 -0
  339. package/dist/lib/compliance-report.js.map +1 -0
  340. package/dist/lib/context/retrieval.d.ts +5 -3
  341. package/dist/lib/context/retrieval.d.ts.map +1 -1
  342. package/dist/lib/context/retrieval.js +5 -2
  343. package/dist/lib/context/retrieval.js.map +1 -1
  344. package/dist/lib/cost-anomaly-detector.d.ts +23 -0
  345. package/dist/lib/cost-anomaly-detector.d.ts.map +1 -0
  346. package/dist/lib/cost-anomaly-detector.js +108 -0
  347. package/dist/lib/cost-anomaly-detector.js.map +1 -0
  348. package/dist/lib/db-resilience.d.ts +15 -0
  349. package/dist/lib/db-resilience.d.ts.map +1 -0
  350. package/dist/lib/db-resilience.js +49 -0
  351. package/dist/lib/db-resilience.js.map +1 -0
  352. package/dist/lib/diagnostics/cache.d.ts +29 -0
  353. package/dist/lib/diagnostics/cache.d.ts.map +1 -0
  354. package/dist/lib/diagnostics/cache.js +88 -0
  355. package/dist/lib/diagnostics/cache.js.map +1 -0
  356. package/dist/lib/diagnostics/context-builder.d.ts +41 -0
  357. package/dist/lib/diagnostics/context-builder.d.ts.map +1 -0
  358. package/dist/lib/diagnostics/context-builder.js +135 -0
  359. package/dist/lib/diagnostics/context-builder.js.map +1 -0
  360. package/dist/lib/diagnostics/index.d.ts +34 -0
  361. package/dist/lib/diagnostics/index.d.ts.map +1 -0
  362. package/dist/lib/diagnostics/index.js +223 -0
  363. package/dist/lib/diagnostics/index.js.map +1 -0
  364. package/dist/lib/diagnostics/llm-client.d.ts +24 -0
  365. package/dist/lib/diagnostics/llm-client.d.ts.map +1 -0
  366. package/dist/lib/diagnostics/llm-client.js +42 -0
  367. package/dist/lib/diagnostics/llm-client.js.map +1 -0
  368. package/dist/lib/diagnostics/prompt-templates.d.ts +18 -0
  369. package/dist/lib/diagnostics/prompt-templates.d.ts.map +1 -0
  370. package/dist/lib/diagnostics/prompt-templates.js +144 -0
  371. package/dist/lib/diagnostics/prompt-templates.js.map +1 -0
  372. package/dist/lib/diagnostics/providers/anthropic.d.ts +8 -0
  373. package/dist/lib/diagnostics/providers/anthropic.d.ts.map +1 -0
  374. package/dist/lib/diagnostics/providers/anthropic.js +79 -0
  375. package/dist/lib/diagnostics/providers/anthropic.js.map +1 -0
  376. package/dist/lib/diagnostics/providers/openai.d.ts +8 -0
  377. package/dist/lib/diagnostics/providers/openai.d.ts.map +1 -0
  378. package/dist/lib/diagnostics/providers/openai.js +70 -0
  379. package/dist/lib/diagnostics/providers/openai.js.map +1 -0
  380. package/dist/lib/diagnostics/providers/types.d.ts +23 -0
  381. package/dist/lib/diagnostics/providers/types.d.ts.map +1 -0
  382. package/dist/lib/diagnostics/providers/types.js +5 -0
  383. package/dist/lib/diagnostics/providers/types.js.map +1 -0
  384. package/dist/lib/diagnostics/response-parser.d.ts +60 -0
  385. package/dist/lib/diagnostics/response-parser.d.ts.map +1 -0
  386. package/dist/lib/diagnostics/response-parser.js +55 -0
  387. package/dist/lib/diagnostics/response-parser.js.map +1 -0
  388. package/dist/lib/diagnostics/types.d.ts +60 -0
  389. package/dist/lib/diagnostics/types.d.ts.map +1 -0
  390. package/dist/lib/diagnostics/types.js +7 -0
  391. package/dist/lib/diagnostics/types.js.map +1 -0
  392. package/dist/lib/embeddings/index.d.ts +6 -3
  393. package/dist/lib/embeddings/index.d.ts.map +1 -1
  394. package/dist/lib/embeddings/index.js +7 -15
  395. package/dist/lib/embeddings/index.js.map +1 -1
  396. package/dist/lib/embeddings/worker.d.ts +2 -2
  397. package/dist/lib/embeddings/worker.d.ts.map +1 -1
  398. package/dist/lib/embeddings/worker.js +3 -1
  399. package/dist/lib/embeddings/worker.js.map +1 -1
  400. package/dist/lib/error-sanitizer.d.ts +28 -0
  401. package/dist/lib/error-sanitizer.d.ts.map +1 -0
  402. package/dist/lib/error-sanitizer.js +106 -0
  403. package/dist/lib/error-sanitizer.js.map +1 -0
  404. package/dist/lib/eval/index.d.ts +15 -0
  405. package/dist/lib/eval/index.d.ts.map +1 -0
  406. package/dist/lib/eval/index.js +24 -0
  407. package/dist/lib/eval/index.js.map +1 -0
  408. package/dist/lib/eval/runner.d.ts +28 -0
  409. package/dist/lib/eval/runner.d.ts.map +1 -0
  410. package/dist/lib/eval/runner.js +260 -0
  411. package/dist/lib/eval/runner.js.map +1 -0
  412. package/dist/lib/eval/scorers/contains.d.ts +10 -0
  413. package/dist/lib/eval/scorers/contains.d.ts.map +1 -0
  414. package/dist/lib/eval/scorers/contains.js +33 -0
  415. package/dist/lib/eval/scorers/contains.js.map +1 -0
  416. package/dist/lib/eval/scorers/exact-match.d.ts +10 -0
  417. package/dist/lib/eval/scorers/exact-match.d.ts.map +1 -0
  418. package/dist/lib/eval/scorers/exact-match.js +33 -0
  419. package/dist/lib/eval/scorers/exact-match.js.map +1 -0
  420. package/dist/lib/eval/scorers/index.d.ts +20 -0
  421. package/dist/lib/eval/scorers/index.d.ts.map +1 -0
  422. package/dist/lib/eval/scorers/index.js +19 -0
  423. package/dist/lib/eval/scorers/index.js.map +1 -0
  424. package/dist/lib/eval/scorers/llm-judge.d.ts +22 -0
  425. package/dist/lib/eval/scorers/llm-judge.d.ts.map +1 -0
  426. package/dist/lib/eval/scorers/llm-judge.js +79 -0
  427. package/dist/lib/eval/scorers/llm-judge.js.map +1 -0
  428. package/dist/lib/eval/scorers/regex.d.ts +10 -0
  429. package/dist/lib/eval/scorers/regex.d.ts.map +1 -0
  430. package/dist/lib/eval/scorers/regex.js +36 -0
  431. package/dist/lib/eval/scorers/regex.js.map +1 -0
  432. package/dist/lib/guardrails/actions.d.ts +6 -0
  433. package/dist/lib/guardrails/actions.d.ts.map +1 -1
  434. package/dist/lib/guardrails/actions.js +82 -0
  435. package/dist/lib/guardrails/actions.js.map +1 -1
  436. package/dist/lib/guardrails/conditions.d.ts +47 -0
  437. package/dist/lib/guardrails/conditions.d.ts.map +1 -1
  438. package/dist/lib/guardrails/conditions.js +55 -10
  439. package/dist/lib/guardrails/conditions.js.map +1 -1
  440. package/dist/lib/guardrails/content-engine.d.ts +19 -0
  441. package/dist/lib/guardrails/content-engine.d.ts.map +1 -0
  442. package/dist/lib/guardrails/content-engine.js +154 -0
  443. package/dist/lib/guardrails/content-engine.js.map +1 -0
  444. package/dist/lib/guardrails/engine.d.ts +33 -0
  445. package/dist/lib/guardrails/engine.d.ts.map +1 -1
  446. package/dist/lib/guardrails/engine.js +37 -2
  447. package/dist/lib/guardrails/engine.js.map +1 -1
  448. package/dist/lib/guardrails/scanners/base-scanner.d.ts +23 -0
  449. package/dist/lib/guardrails/scanners/base-scanner.d.ts.map +1 -0
  450. package/dist/lib/guardrails/scanners/base-scanner.js +7 -0
  451. package/dist/lib/guardrails/scanners/base-scanner.js.map +1 -0
  452. package/dist/lib/guardrails/scanners/patterns/pii-patterns.d.ts +13 -0
  453. package/dist/lib/guardrails/scanners/patterns/pii-patterns.d.ts.map +1 -0
  454. package/dist/lib/guardrails/scanners/patterns/pii-patterns.js +49 -0
  455. package/dist/lib/guardrails/scanners/patterns/pii-patterns.js.map +1 -0
  456. package/dist/lib/guardrails/scanners/patterns/secret-patterns.d.ts +6 -0
  457. package/dist/lib/guardrails/scanners/patterns/secret-patterns.d.ts.map +1 -0
  458. package/dist/lib/guardrails/scanners/patterns/secret-patterns.js +69 -0
  459. package/dist/lib/guardrails/scanners/patterns/secret-patterns.js.map +1 -0
  460. package/dist/lib/guardrails/scanners/pii-scanner.d.ts +10 -0
  461. package/dist/lib/guardrails/scanners/pii-scanner.d.ts.map +1 -0
  462. package/dist/lib/guardrails/scanners/pii-scanner.js +57 -0
  463. package/dist/lib/guardrails/scanners/pii-scanner.js.map +1 -0
  464. package/dist/lib/guardrails/scanners/scanner-registry.d.ts +14 -0
  465. package/dist/lib/guardrails/scanners/scanner-registry.d.ts.map +1 -0
  466. package/dist/lib/guardrails/scanners/scanner-registry.js +51 -0
  467. package/dist/lib/guardrails/scanners/scanner-registry.js.map +1 -0
  468. package/dist/lib/guardrails/scanners/secrets-scanner.d.ts +9 -0
  469. package/dist/lib/guardrails/scanners/secrets-scanner.d.ts.map +1 -0
  470. package/dist/lib/guardrails/scanners/secrets-scanner.js +47 -0
  471. package/dist/lib/guardrails/scanners/secrets-scanner.js.map +1 -0
  472. package/dist/lib/logger.d.ts +8 -0
  473. package/dist/lib/logger.d.ts.map +1 -0
  474. package/dist/lib/logger.js +31 -0
  475. package/dist/lib/logger.js.map +1 -0
  476. package/dist/lib/lore-client.d.ts +128 -0
  477. package/dist/lib/lore-client.d.ts.map +1 -0
  478. package/dist/lib/lore-client.js +188 -0
  479. package/dist/lib/lore-client.js.map +1 -0
  480. package/dist/lib/mesh-client.d.ts +31 -0
  481. package/dist/lib/mesh-client.d.ts.map +1 -0
  482. package/dist/lib/mesh-client.js +72 -0
  483. package/dist/lib/mesh-client.js.map +1 -0
  484. package/dist/lib/notifications/grouping-buffer.d.ts +25 -0
  485. package/dist/lib/notifications/grouping-buffer.d.ts.map +1 -0
  486. package/dist/lib/notifications/grouping-buffer.js +73 -0
  487. package/dist/lib/notifications/grouping-buffer.js.map +1 -0
  488. package/dist/lib/notifications/provider.d.ts +10 -0
  489. package/dist/lib/notifications/provider.d.ts.map +1 -0
  490. package/dist/lib/notifications/provider.js +5 -0
  491. package/dist/lib/notifications/provider.js.map +1 -0
  492. package/dist/lib/notifications/providers/email.d.ts +14 -0
  493. package/dist/lib/notifications/providers/email.d.ts.map +1 -0
  494. package/dist/lib/notifications/providers/email.js +88 -0
  495. package/dist/lib/notifications/providers/email.js.map +1 -0
  496. package/dist/lib/notifications/providers/pagerduty.d.ts +16 -0
  497. package/dist/lib/notifications/providers/pagerduty.d.ts.map +1 -0
  498. package/dist/lib/notifications/providers/pagerduty.js +94 -0
  499. package/dist/lib/notifications/providers/pagerduty.js.map +1 -0
  500. package/dist/lib/notifications/providers/slack.d.ts +14 -0
  501. package/dist/lib/notifications/providers/slack.d.ts.map +1 -0
  502. package/dist/lib/notifications/providers/slack.js +106 -0
  503. package/dist/lib/notifications/providers/slack.js.map +1 -0
  504. package/dist/lib/notifications/providers/webhook.d.ts +16 -0
  505. package/dist/lib/notifications/providers/webhook.d.ts.map +1 -0
  506. package/dist/lib/notifications/providers/webhook.js +78 -0
  507. package/dist/lib/notifications/providers/webhook.js.map +1 -0
  508. package/dist/lib/notifications/router.d.ts +30 -0
  509. package/dist/lib/notifications/router.d.ts.map +1 -0
  510. package/dist/lib/notifications/router.js +137 -0
  511. package/dist/lib/notifications/router.js.map +1 -0
  512. package/dist/lib/notifications/ssrf.d.ts +13 -0
  513. package/dist/lib/notifications/ssrf.d.ts.map +1 -0
  514. package/dist/lib/notifications/ssrf.js +37 -0
  515. package/dist/lib/notifications/ssrf.js.map +1 -0
  516. package/dist/lib/optimization/analyzers/model-downgrade.d.ts +15 -0
  517. package/dist/lib/optimization/analyzers/model-downgrade.d.ts.map +1 -0
  518. package/dist/lib/optimization/analyzers/model-downgrade.js +58 -0
  519. package/dist/lib/optimization/analyzers/model-downgrade.js.map +1 -0
  520. package/dist/lib/optimization/analyzers/prompt-optimization.d.ts +17 -0
  521. package/dist/lib/optimization/analyzers/prompt-optimization.d.ts.map +1 -0
  522. package/dist/lib/optimization/analyzers/prompt-optimization.js +160 -0
  523. package/dist/lib/optimization/analyzers/prompt-optimization.js.map +1 -0
  524. package/dist/lib/optimization/analyzers/types.d.ts +23 -0
  525. package/dist/lib/optimization/analyzers/types.d.ts.map +1 -0
  526. package/dist/lib/optimization/analyzers/types.js +5 -0
  527. package/dist/lib/optimization/analyzers/types.js.map +1 -0
  528. package/dist/lib/optimization/classifier.d.ts +4 -3
  529. package/dist/lib/optimization/classifier.d.ts.map +1 -1
  530. package/dist/lib/optimization/classifier.js +15 -9
  531. package/dist/lib/optimization/classifier.js.map +1 -1
  532. package/dist/lib/optimization/cost-optimizer.d.ts +21 -0
  533. package/dist/lib/optimization/cost-optimizer.d.ts.map +1 -0
  534. package/dist/lib/optimization/cost-optimizer.js +114 -0
  535. package/dist/lib/optimization/cost-optimizer.js.map +1 -0
  536. package/dist/lib/optimization/engine.d.ts.map +1 -1
  537. package/dist/lib/optimization/engine.js +45 -6
  538. package/dist/lib/optimization/engine.js.map +1 -1
  539. package/dist/lib/optimization/forecast.d.ts +39 -0
  540. package/dist/lib/optimization/forecast.d.ts.map +1 -0
  541. package/dist/lib/optimization/forecast.js +128 -0
  542. package/dist/lib/optimization/forecast.js.map +1 -0
  543. package/dist/lib/secrets.d.ts +30 -0
  544. package/dist/lib/secrets.d.ts.map +1 -0
  545. package/dist/lib/secrets.js +103 -0
  546. package/dist/lib/secrets.js.map +1 -0
  547. package/dist/lib/threshold-monitor.d.ts +53 -0
  548. package/dist/lib/threshold-monitor.d.ts.map +1 -0
  549. package/dist/lib/threshold-monitor.js +112 -0
  550. package/dist/lib/threshold-monitor.js.map +1 -0
  551. package/dist/middleware/audit.d.ts +16 -0
  552. package/dist/middleware/audit.d.ts.map +1 -0
  553. package/dist/middleware/audit.js +16 -0
  554. package/dist/middleware/audit.js.map +1 -0
  555. package/dist/middleware/auth-errors.d.ts +67 -0
  556. package/dist/middleware/auth-errors.d.ts.map +1 -0
  557. package/dist/middleware/auth-errors.js +84 -0
  558. package/dist/middleware/auth-errors.js.map +1 -0
  559. package/dist/middleware/auth.d.ts +5 -2
  560. package/dist/middleware/auth.d.ts.map +1 -1
  561. package/dist/middleware/auth.js +44 -17
  562. package/dist/middleware/auth.js.map +1 -1
  563. package/dist/middleware/body-limit.d.ts +9 -0
  564. package/dist/middleware/body-limit.d.ts.map +1 -0
  565. package/dist/middleware/body-limit.js +15 -0
  566. package/dist/middleware/body-limit.js.map +1 -0
  567. package/dist/middleware/cors-config.d.ts +30 -0
  568. package/dist/middleware/cors-config.d.ts.map +1 -0
  569. package/dist/middleware/cors-config.js +55 -0
  570. package/dist/middleware/cors-config.js.map +1 -0
  571. package/dist/middleware/rate-limit.d.ts +9 -0
  572. package/dist/middleware/rate-limit.d.ts.map +1 -0
  573. package/dist/middleware/rate-limit.js +56 -0
  574. package/dist/middleware/rate-limit.js.map +1 -0
  575. package/dist/middleware/rbac.d.ts +30 -0
  576. package/dist/middleware/rbac.d.ts.map +1 -0
  577. package/dist/middleware/rbac.js +87 -0
  578. package/dist/middleware/rbac.js.map +1 -0
  579. package/dist/middleware/security-headers.d.ts +12 -0
  580. package/dist/middleware/security-headers.d.ts.map +1 -0
  581. package/dist/middleware/security-headers.js +57 -0
  582. package/dist/middleware/security-headers.js.map +1 -0
  583. package/dist/middleware/unified-auth.d.ts +49 -0
  584. package/dist/middleware/unified-auth.d.ts.map +1 -0
  585. package/dist/middleware/unified-auth.js +246 -0
  586. package/dist/middleware/unified-auth.js.map +1 -0
  587. package/dist/middleware/validation.d.ts +31 -0
  588. package/dist/middleware/validation.d.ts.map +1 -0
  589. package/dist/middleware/validation.js +45 -0
  590. package/dist/middleware/validation.js.map +1 -0
  591. package/dist/routes/alerts.d.ts.map +1 -1
  592. package/dist/routes/alerts.js +4 -3
  593. package/dist/routes/alerts.js.map +1 -1
  594. package/dist/routes/analytics.d.ts +2 -1
  595. package/dist/routes/analytics.d.ts.map +1 -1
  596. package/dist/routes/analytics.js +175 -95
  597. package/dist/routes/analytics.js.map +1 -1
  598. package/dist/routes/api-keys.d.ts +5 -0
  599. package/dist/routes/api-keys.d.ts.map +1 -1
  600. package/dist/routes/api-keys.js +89 -8
  601. package/dist/routes/api-keys.js.map +1 -1
  602. package/dist/routes/audit-verify.d.ts +12 -0
  603. package/dist/routes/audit-verify.d.ts.map +1 -0
  604. package/dist/routes/audit-verify.js +73 -0
  605. package/dist/routes/audit-verify.js.map +1 -0
  606. package/dist/routes/audit.d.ts +4 -6
  607. package/dist/routes/audit.d.ts.map +1 -1
  608. package/dist/routes/audit.js +54 -157
  609. package/dist/routes/audit.js.map +1 -1
  610. package/dist/routes/auth.d.ts +21 -0
  611. package/dist/routes/auth.d.ts.map +1 -0
  612. package/dist/routes/auth.js +235 -0
  613. package/dist/routes/auth.js.map +1 -0
  614. package/dist/routes/benchmarks.d.ts.map +1 -1
  615. package/dist/routes/benchmarks.js +63 -11
  616. package/dist/routes/benchmarks.js.map +1 -1
  617. package/dist/routes/capabilities-top.d.ts.map +1 -1
  618. package/dist/routes/capabilities-top.js +1 -4
  619. package/dist/routes/capabilities-top.js.map +1 -1
  620. package/dist/routes/capabilities.d.ts.map +1 -1
  621. package/dist/routes/capabilities.js +1 -7
  622. package/dist/routes/capabilities.js.map +1 -1
  623. package/dist/routes/compliance.d.ts +17 -0
  624. package/dist/routes/compliance.d.ts.map +1 -0
  625. package/dist/routes/compliance.js +151 -0
  626. package/dist/routes/compliance.js.map +1 -0
  627. package/dist/routes/config.d.ts +1 -13
  628. package/dist/routes/config.d.ts.map +1 -1
  629. package/dist/routes/context.d.ts.map +1 -1
  630. package/dist/routes/context.js +6 -5
  631. package/dist/routes/context.js.map +1 -1
  632. package/dist/routes/cost-budgets.d.ts +20 -0
  633. package/dist/routes/cost-budgets.d.ts.map +1 -0
  634. package/dist/routes/cost-budgets.js +194 -0
  635. package/dist/routes/cost-budgets.js.map +1 -0
  636. package/dist/routes/delegation.d.ts.map +1 -1
  637. package/dist/routes/delegation.js +67 -41
  638. package/dist/routes/delegation.js.map +1 -1
  639. package/dist/routes/delegations-top.d.ts.map +1 -1
  640. package/dist/routes/delegations-top.js +1 -3
  641. package/dist/routes/delegations-top.js.map +1 -1
  642. package/dist/routes/diagnose.d.ts +16 -0
  643. package/dist/routes/diagnose.d.ts.map +1 -0
  644. package/dist/routes/diagnose.js +82 -0
  645. package/dist/routes/diagnose.js.map +1 -0
  646. package/dist/routes/discovery.d.ts.map +1 -1
  647. package/dist/routes/discovery.js +50 -38
  648. package/dist/routes/discovery.js.map +1 -1
  649. package/dist/routes/eval.d.ts +24 -0
  650. package/dist/routes/eval.d.ts.map +1 -0
  651. package/dist/routes/eval.js +281 -0
  652. package/dist/routes/eval.js.map +1 -0
  653. package/dist/routes/events.d.ts.map +1 -1
  654. package/dist/routes/events.js +11 -6
  655. package/dist/routes/events.js.map +1 -1
  656. package/dist/routes/guardrails.d.ts +2 -1
  657. package/dist/routes/guardrails.d.ts.map +1 -1
  658. package/dist/routes/guardrails.js +85 -14
  659. package/dist/routes/guardrails.js.map +1 -1
  660. package/dist/routes/health.d.ts +14 -11
  661. package/dist/routes/health.d.ts.map +1 -1
  662. package/dist/routes/health.js +181 -61
  663. package/dist/routes/health.js.map +1 -1
  664. package/dist/routes/lore-proxy.d.ts +13 -0
  665. package/dist/routes/lore-proxy.d.ts.map +1 -0
  666. package/dist/routes/lore-proxy.js +229 -0
  667. package/dist/routes/lore-proxy.js.map +1 -0
  668. package/dist/routes/mesh-proxy.d.ts +7 -0
  669. package/dist/routes/mesh-proxy.d.ts.map +1 -0
  670. package/dist/routes/mesh-proxy.js +94 -0
  671. package/dist/routes/mesh-proxy.js.map +1 -0
  672. package/dist/routes/notifications.d.ts +19 -0
  673. package/dist/routes/notifications.d.ts.map +1 -0
  674. package/dist/routes/notifications.js +129 -0
  675. package/dist/routes/notifications.js.map +1 -0
  676. package/dist/routes/optimize.d.ts.map +1 -1
  677. package/dist/routes/optimize.js +44 -0
  678. package/dist/routes/optimize.js.map +1 -1
  679. package/dist/routes/otlp.d.ts +17 -0
  680. package/dist/routes/otlp.d.ts.map +1 -0
  681. package/dist/routes/otlp.js +544 -0
  682. package/dist/routes/otlp.js.map +1 -0
  683. package/dist/routes/prompts.d.ts +21 -0
  684. package/dist/routes/prompts.d.ts.map +1 -0
  685. package/dist/routes/prompts.js +173 -0
  686. package/dist/routes/prompts.js.map +1 -0
  687. package/dist/routes/recall.d.ts.map +1 -1
  688. package/dist/routes/recall.js +6 -4
  689. package/dist/routes/recall.js.map +1 -1
  690. package/dist/routes/replay.d.ts.map +1 -1
  691. package/dist/routes/replay.js +2 -1
  692. package/dist/routes/replay.js.map +1 -1
  693. package/dist/routes/server-info.d.ts +9 -0
  694. package/dist/routes/server-info.d.ts.map +1 -0
  695. package/dist/routes/server-info.js +18 -0
  696. package/dist/routes/server-info.js.map +1 -0
  697. package/dist/routes/sessions.d.ts +7 -7
  698. package/dist/routes/sessions.d.ts.map +1 -1
  699. package/dist/routes/sessions.js +112 -35
  700. package/dist/routes/sessions.js.map +1 -1
  701. package/dist/routes/stats.d.ts.map +1 -1
  702. package/dist/routes/stats.js +40 -0
  703. package/dist/routes/stats.js.map +1 -1
  704. package/dist/routes/stream.d.ts +2 -2
  705. package/dist/routes/stream.d.ts.map +1 -1
  706. package/dist/routes/stream.js +7 -11
  707. package/dist/routes/stream.js.map +1 -1
  708. package/dist/routes/tenant-helper.d.ts +15 -10
  709. package/dist/routes/tenant-helper.d.ts.map +1 -1
  710. package/dist/routes/tenant-helper.js +36 -22
  711. package/dist/routes/tenant-helper.js.map +1 -1
  712. package/dist/routes/trust.d.ts.map +1 -1
  713. package/dist/routes/trust.js +1 -3
  714. package/dist/routes/trust.js.map +1 -1
  715. package/dist/schemas/api-keys.d.ts +11 -0
  716. package/dist/schemas/api-keys.d.ts.map +1 -0
  717. package/dist/schemas/api-keys.js +10 -0
  718. package/dist/schemas/api-keys.js.map +1 -0
  719. package/dist/schemas/common.d.ts +34 -0
  720. package/dist/schemas/common.d.ts.map +1 -0
  721. package/dist/schemas/common.js +43 -0
  722. package/dist/schemas/common.js.map +1 -0
  723. package/dist/schemas/delegation.d.ts +23 -0
  724. package/dist/schemas/delegation.d.ts.map +1 -0
  725. package/dist/schemas/delegation.js +22 -0
  726. package/dist/schemas/delegation.js.map +1 -0
  727. package/dist/schemas/discovery.d.ts +17 -0
  728. package/dist/schemas/discovery.d.ts.map +1 -0
  729. package/dist/schemas/discovery.js +15 -0
  730. package/dist/schemas/discovery.js.map +1 -0
  731. package/dist/schemas/health.d.ts +75 -0
  732. package/dist/schemas/health.d.ts.map +1 -0
  733. package/dist/schemas/health.js +55 -0
  734. package/dist/schemas/health.js.map +1 -0
  735. package/dist/schemas/index.d.ts +6 -0
  736. package/dist/schemas/index.d.ts.map +1 -0
  737. package/dist/schemas/index.js +6 -0
  738. package/dist/schemas/index.js.map +1 -0
  739. package/dist/schemas/sessions.d.ts +67 -0
  740. package/dist/schemas/sessions.d.ts.map +1 -0
  741. package/dist/schemas/sessions.js +58 -0
  742. package/dist/schemas/sessions.js.map +1 -0
  743. package/dist/services/delegation-service.d.ts +1 -4
  744. package/dist/services/delegation-service.d.ts.map +1 -1
  745. package/dist/services/delegation-service.js +5 -31
  746. package/dist/services/delegation-service.js.map +1 -1
  747. package/package.json +29 -19
  748. package/dist/db/lesson-store.d.ts +0 -57
  749. package/dist/db/lesson-store.d.ts.map +0 -1
  750. package/dist/db/lesson-store.js +0 -217
  751. package/dist/db/lesson-store.js.map +0 -1
  752. package/dist/lib/embeddings/local.d.ts +0 -15
  753. package/dist/lib/embeddings/local.d.ts.map +0 -1
  754. package/dist/lib/embeddings/local.js +0 -65
  755. package/dist/lib/embeddings/local.js.map +0 -1
  756. package/dist/lib/redaction/human-review-layer.d.ts +0 -37
  757. package/dist/lib/redaction/human-review-layer.d.ts.map +0 -1
  758. package/dist/lib/redaction/human-review-layer.js +0 -62
  759. package/dist/lib/redaction/human-review-layer.js.map +0 -1
  760. package/dist/lib/redaction/index.d.ts +0 -12
  761. package/dist/lib/redaction/index.d.ts.map +0 -1
  762. package/dist/lib/redaction/index.js +0 -12
  763. package/dist/lib/redaction/index.js.map +0 -1
  764. package/dist/lib/redaction/pii-detection-layer.d.ts +0 -30
  765. package/dist/lib/redaction/pii-detection-layer.d.ts.map +0 -1
  766. package/dist/lib/redaction/pii-detection-layer.js +0 -183
  767. package/dist/lib/redaction/pii-detection-layer.js.map +0 -1
  768. package/dist/lib/redaction/pipeline.d.ts +0 -26
  769. package/dist/lib/redaction/pipeline.d.ts.map +0 -1
  770. package/dist/lib/redaction/pipeline.js +0 -91
  771. package/dist/lib/redaction/pipeline.js.map +0 -1
  772. package/dist/lib/redaction/secret-detection-layer.d.ts +0 -10
  773. package/dist/lib/redaction/secret-detection-layer.d.ts.map +0 -1
  774. package/dist/lib/redaction/secret-detection-layer.js +0 -79
  775. package/dist/lib/redaction/secret-detection-layer.js.map +0 -1
  776. package/dist/lib/redaction/secret-patterns.d.ts +0 -29
  777. package/dist/lib/redaction/secret-patterns.d.ts.map +0 -1
  778. package/dist/lib/redaction/secret-patterns.js +0 -133
  779. package/dist/lib/redaction/secret-patterns.js.map +0 -1
  780. package/dist/lib/redaction/semantic-denylist-layer.d.ts +0 -10
  781. package/dist/lib/redaction/semantic-denylist-layer.d.ts.map +0 -1
  782. package/dist/lib/redaction/semantic-denylist-layer.js +0 -64
  783. package/dist/lib/redaction/semantic-denylist-layer.js.map +0 -1
  784. package/dist/lib/redaction/tenant-deidentification-layer.d.ts +0 -10
  785. package/dist/lib/redaction/tenant-deidentification-layer.d.ts.map +0 -1
  786. package/dist/lib/redaction/tenant-deidentification-layer.js +0 -64
  787. package/dist/lib/redaction/tenant-deidentification-layer.js.map +0 -1
  788. package/dist/lib/redaction/url-path-scrubbing-layer.d.ts +0 -14
  789. package/dist/lib/redaction/url-path-scrubbing-layer.d.ts.map +0 -1
  790. package/dist/lib/redaction/url-path-scrubbing-layer.js +0 -156
  791. package/dist/lib/redaction/url-path-scrubbing-layer.js.map +0 -1
  792. package/dist/routes/community.d.ts +0 -24
  793. package/dist/routes/community.d.ts.map +0 -1
  794. package/dist/routes/community.js +0 -272
  795. package/dist/routes/community.js.map +0 -1
  796. package/dist/routes/lessons.d.ts +0 -19
  797. package/dist/routes/lessons.d.ts.map +0 -1
  798. package/dist/routes/lessons.js +0 -164
  799. package/dist/routes/lessons.js.map +0 -1
  800. package/dist/routes/redaction-test.d.ts +0 -14
  801. package/dist/routes/redaction-test.d.ts.map +0 -1
  802. package/dist/routes/redaction-test.js +0 -33
  803. package/dist/routes/redaction-test.js.map +0 -1
  804. package/dist/services/community-service.d.ts +0 -283
  805. package/dist/services/community-service.d.ts.map +0 -1
  806. package/dist/services/community-service.js +0 -816
  807. package/dist/services/community-service.js.map +0 -1
@@ -1,641 +1,11 @@
1
1
  /**
2
- * Database migration runner.
2
+ * Database migration dispatcher.
3
3
  *
4
- * For SQLite, uses Drizzle's push-based approach to create/update tables
5
- * on first start. For production, Drizzle Kit migrations can be used.
4
+ * Re-exports the SQLite migration runner (default path) and provides
5
+ * a Postgres migration runner for the Drizzle Kit managed migration flow.
6
6
  */
7
- import { sql } from 'drizzle-orm';
8
- /**
9
- * Run migrations: create all tables and indexes if they don't exist.
10
- *
11
- * Uses CREATE TABLE IF NOT EXISTS for idempotent startup.
12
- * This approach is simpler than file-based migrations for an
13
- * embedded SQLite database that auto-creates on first start.
14
- */
15
- export function runMigrations(db) {
16
- // Create all tables using raw SQL for CREATE IF NOT EXISTS
17
- // Drizzle doesn't have a built-in "push" that works at runtime,
18
- // so we use the schema definitions to generate DDL.
19
- db.run(sql `
20
- CREATE TABLE IF NOT EXISTS events (
21
- id TEXT PRIMARY KEY,
22
- timestamp TEXT NOT NULL,
23
- session_id TEXT NOT NULL,
24
- agent_id TEXT NOT NULL,
25
- event_type TEXT NOT NULL,
26
- severity TEXT NOT NULL DEFAULT 'info',
27
- payload TEXT NOT NULL,
28
- metadata TEXT NOT NULL DEFAULT '{}',
29
- prev_hash TEXT,
30
- hash TEXT NOT NULL
31
- )
32
- `);
33
- db.run(sql `
34
- CREATE TABLE IF NOT EXISTS sessions (
35
- id TEXT NOT NULL,
36
- agent_id TEXT NOT NULL,
37
- agent_name TEXT,
38
- started_at TEXT NOT NULL,
39
- ended_at TEXT,
40
- status TEXT NOT NULL DEFAULT 'active',
41
- event_count INTEGER NOT NULL DEFAULT 0,
42
- tool_call_count INTEGER NOT NULL DEFAULT 0,
43
- error_count INTEGER NOT NULL DEFAULT 0,
44
- total_cost_usd REAL NOT NULL DEFAULT 0,
45
- llm_call_count INTEGER NOT NULL DEFAULT 0,
46
- total_input_tokens INTEGER NOT NULL DEFAULT 0,
47
- total_output_tokens INTEGER NOT NULL DEFAULT 0,
48
- tags TEXT NOT NULL DEFAULT '[]',
49
- tenant_id TEXT NOT NULL DEFAULT 'default',
50
- PRIMARY KEY (id, tenant_id)
51
- )
52
- `);
53
- db.run(sql `
54
- CREATE TABLE IF NOT EXISTS agents (
55
- id TEXT NOT NULL,
56
- name TEXT NOT NULL,
57
- description TEXT,
58
- first_seen_at TEXT NOT NULL,
59
- last_seen_at TEXT NOT NULL,
60
- session_count INTEGER NOT NULL DEFAULT 0,
61
- tenant_id TEXT NOT NULL DEFAULT 'default',
62
- PRIMARY KEY (id, tenant_id)
63
- )
64
- `);
65
- db.run(sql `
66
- CREATE TABLE IF NOT EXISTS alert_rules (
67
- id TEXT PRIMARY KEY,
68
- name TEXT NOT NULL,
69
- enabled INTEGER NOT NULL DEFAULT 1,
70
- condition TEXT NOT NULL,
71
- threshold REAL NOT NULL,
72
- window_minutes INTEGER NOT NULL,
73
- scope TEXT NOT NULL DEFAULT '{}',
74
- notify_channels TEXT NOT NULL DEFAULT '[]',
75
- created_at TEXT NOT NULL,
76
- updated_at TEXT NOT NULL
77
- )
78
- `);
79
- db.run(sql `
80
- CREATE TABLE IF NOT EXISTS alert_history (
81
- id TEXT PRIMARY KEY,
82
- rule_id TEXT NOT NULL REFERENCES alert_rules(id),
83
- triggered_at TEXT NOT NULL,
84
- resolved_at TEXT,
85
- current_value REAL NOT NULL,
86
- threshold REAL NOT NULL,
87
- message TEXT NOT NULL
88
- )
89
- `);
90
- db.run(sql `
91
- CREATE TABLE IF NOT EXISTS api_keys (
92
- id TEXT PRIMARY KEY,
93
- key_hash TEXT NOT NULL,
94
- name TEXT NOT NULL,
95
- scopes TEXT NOT NULL,
96
- created_at INTEGER NOT NULL,
97
- last_used_at INTEGER,
98
- revoked_at INTEGER,
99
- rate_limit INTEGER
100
- )
101
- `);
102
- // Create indexes (IF NOT EXISTS)
103
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_timestamp ON events(timestamp)`);
104
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_session_id ON events(session_id)`);
105
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_agent_id ON events(agent_id)`);
106
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_type ON events(event_type)`);
107
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_session_ts ON events(session_id, timestamp)`);
108
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_agent_type_ts ON events(agent_id, event_type, timestamp)`);
109
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sessions_agent_id ON sessions(agent_id)`);
110
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sessions_started_at ON sessions(started_at)`);
111
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sessions_status ON sessions(status)`);
112
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_api_keys_hash ON api_keys(key_hash)`);
113
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_alert_history_rule_id ON alert_history(rule_id)`);
114
- // ─── Migrations for existing databases ──────────────────
115
- // Add LLM tracking columns to sessions (v0.3.0)
116
- // SQLite doesn't support ADD COLUMN IF NOT EXISTS, so we check first
117
- const sessionColumns = db.all(sql `PRAGMA table_info(sessions)`);
118
- const sessionColumnNames = new Set(sessionColumns.map((c) => c.name));
119
- if (!sessionColumnNames.has('llm_call_count')) {
120
- db.run(sql `ALTER TABLE sessions ADD COLUMN llm_call_count INTEGER NOT NULL DEFAULT 0`);
121
- }
122
- if (!sessionColumnNames.has('total_input_tokens')) {
123
- db.run(sql `ALTER TABLE sessions ADD COLUMN total_input_tokens INTEGER NOT NULL DEFAULT 0`);
124
- }
125
- if (!sessionColumnNames.has('total_output_tokens')) {
126
- db.run(sql `ALTER TABLE sessions ADD COLUMN total_output_tokens INTEGER NOT NULL DEFAULT 0`);
127
- }
128
- // ─── Tenant isolation migration (Epic 1) ──────────────────
129
- // Add tenant_id to all data tables for multi-tenant support
130
- // api_keys.tenant_id
131
- const apiKeyColumns = db.all(sql `PRAGMA table_info(api_keys)`);
132
- const apiKeyColumnNames = new Set(apiKeyColumns.map((c) => c.name));
133
- if (!apiKeyColumnNames.has('tenant_id')) {
134
- db.run(sql `ALTER TABLE api_keys ADD COLUMN tenant_id TEXT NOT NULL DEFAULT 'default'`);
135
- }
136
- // events.tenant_id
137
- const eventColumns = db.all(sql `PRAGMA table_info(events)`);
138
- const eventColumnNames = new Set(eventColumns.map((c) => c.name));
139
- if (!eventColumnNames.has('tenant_id')) {
140
- db.run(sql `ALTER TABLE events ADD COLUMN tenant_id TEXT NOT NULL DEFAULT 'default'`);
141
- }
142
- // sessions.tenant_id
143
- if (!sessionColumnNames.has('tenant_id')) {
144
- db.run(sql `ALTER TABLE sessions ADD COLUMN tenant_id TEXT NOT NULL DEFAULT 'default'`);
145
- }
146
- // agents.tenant_id
147
- const agentColumns = db.all(sql `PRAGMA table_info(agents)`);
148
- const agentColumnNames = new Set(agentColumns.map((c) => c.name));
149
- if (!agentColumnNames.has('tenant_id')) {
150
- db.run(sql `ALTER TABLE agents ADD COLUMN tenant_id TEXT NOT NULL DEFAULT 'default'`);
151
- }
152
- // alert_rules.tenant_id
153
- const alertRuleColumns = db.all(sql `PRAGMA table_info(alert_rules)`);
154
- const alertRuleColumnNames = new Set(alertRuleColumns.map((c) => c.name));
155
- if (!alertRuleColumnNames.has('tenant_id')) {
156
- db.run(sql `ALTER TABLE alert_rules ADD COLUMN tenant_id TEXT NOT NULL DEFAULT 'default'`);
157
- }
158
- // alert_history.tenant_id
159
- const alertHistoryColumns = db.all(sql `PRAGMA table_info(alert_history)`);
160
- const alertHistoryColumnNames = new Set(alertHistoryColumns.map((c) => c.name));
161
- if (!alertHistoryColumnNames.has('tenant_id')) {
162
- db.run(sql `ALTER TABLE alert_history ADD COLUMN tenant_id TEXT NOT NULL DEFAULT 'default'`);
163
- }
164
- // Tenant isolation indexes
165
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_tenant_id ON events(tenant_id)`);
166
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_tenant_session ON events(tenant_id, session_id)`);
167
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_events_tenant_agent_ts ON events(tenant_id, agent_id, timestamp)`);
168
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sessions_tenant_id ON sessions(tenant_id)`);
169
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sessions_tenant_agent ON sessions(tenant_id, agent_id)`);
170
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sessions_tenant_started ON sessions(tenant_id, started_at)`);
171
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_agents_tenant_id ON agents(tenant_id)`);
172
- // ─── Embeddings table (Epic 2 — Story 2.2) ──────────────────
173
- db.run(sql `
174
- CREATE TABLE IF NOT EXISTS embeddings (
175
- id TEXT PRIMARY KEY,
176
- tenant_id TEXT NOT NULL,
177
- source_type TEXT NOT NULL,
178
- source_id TEXT NOT NULL,
179
- content_hash TEXT NOT NULL,
180
- text_content TEXT NOT NULL,
181
- embedding BLOB NOT NULL,
182
- embedding_model TEXT NOT NULL,
183
- dimensions INTEGER NOT NULL,
184
- created_at TEXT NOT NULL
185
- )
186
- `);
187
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_embeddings_tenant ON embeddings(tenant_id)`);
188
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_embeddings_source ON embeddings(source_type, source_id)`);
189
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_embeddings_content_hash ON embeddings(tenant_id, content_hash)`);
190
- // ─── Session Summaries table (Epic 2 — Story 2.2) ──────────────────
191
- db.run(sql `
192
- CREATE TABLE IF NOT EXISTS session_summaries (
193
- session_id TEXT NOT NULL,
194
- tenant_id TEXT NOT NULL,
195
- summary TEXT NOT NULL,
196
- topics TEXT NOT NULL DEFAULT '[]',
197
- tool_sequence TEXT NOT NULL DEFAULT '[]',
198
- error_summary TEXT,
199
- outcome TEXT,
200
- created_at TEXT NOT NULL,
201
- updated_at TEXT NOT NULL,
202
- PRIMARY KEY (session_id, tenant_id)
203
- )
204
- `);
205
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_session_summaries_tenant ON session_summaries(tenant_id)`);
206
- // ─── Composite PK migration (CRITICAL-2) ──────────────────
207
- // SQLite doesn't support ALTER TABLE to change PKs, so we recreate
208
- // tables with composite PKs (id, tenant_id) for tenant isolation.
209
- // Check if sessions table still has single-column PK
210
- // by looking at the CREATE TABLE statement
211
- const sessionsSchema = db.get(sql `SELECT sql FROM sqlite_master WHERE type='table' AND name='sessions'`);
212
- if (sessionsSchema && sessionsSchema.sql.includes('id TEXT PRIMARY KEY')) {
213
- // Drop old indexes that reference sessions (they'll be recreated)
214
- db.run(sql `DROP INDEX IF EXISTS idx_sessions_agent_id`);
215
- db.run(sql `DROP INDEX IF EXISTS idx_sessions_started_at`);
216
- db.run(sql `DROP INDEX IF EXISTS idx_sessions_status`);
217
- db.run(sql `DROP INDEX IF EXISTS idx_sessions_tenant_id`);
218
- db.run(sql `DROP INDEX IF EXISTS idx_sessions_tenant_agent`);
219
- db.run(sql `DROP INDEX IF EXISTS idx_sessions_tenant_started`);
220
- db.run(sql `
221
- CREATE TABLE sessions_new (
222
- id TEXT NOT NULL,
223
- agent_id TEXT NOT NULL,
224
- agent_name TEXT,
225
- started_at TEXT NOT NULL,
226
- ended_at TEXT,
227
- status TEXT NOT NULL DEFAULT 'active',
228
- event_count INTEGER NOT NULL DEFAULT 0,
229
- tool_call_count INTEGER NOT NULL DEFAULT 0,
230
- error_count INTEGER NOT NULL DEFAULT 0,
231
- total_cost_usd REAL NOT NULL DEFAULT 0,
232
- llm_call_count INTEGER NOT NULL DEFAULT 0,
233
- total_input_tokens INTEGER NOT NULL DEFAULT 0,
234
- total_output_tokens INTEGER NOT NULL DEFAULT 0,
235
- tags TEXT NOT NULL DEFAULT '[]',
236
- tenant_id TEXT NOT NULL DEFAULT 'default',
237
- PRIMARY KEY (id, tenant_id)
238
- )
239
- `);
240
- db.run(sql `
241
- INSERT INTO sessions_new
242
- SELECT id, agent_id, agent_name, started_at, ended_at, status,
243
- event_count, tool_call_count, error_count, total_cost_usd,
244
- llm_call_count, total_input_tokens, total_output_tokens,
245
- tags, tenant_id
246
- FROM sessions
247
- `);
248
- db.run(sql `DROP TABLE sessions`);
249
- db.run(sql `ALTER TABLE sessions_new RENAME TO sessions`);
250
- // Recreate indexes
251
- db.run(sql `CREATE INDEX idx_sessions_agent_id ON sessions(agent_id)`);
252
- db.run(sql `CREATE INDEX idx_sessions_started_at ON sessions(started_at)`);
253
- db.run(sql `CREATE INDEX idx_sessions_status ON sessions(status)`);
254
- db.run(sql `CREATE INDEX idx_sessions_tenant_id ON sessions(tenant_id)`);
255
- db.run(sql `CREATE INDEX idx_sessions_tenant_agent ON sessions(tenant_id, agent_id)`);
256
- db.run(sql `CREATE INDEX idx_sessions_tenant_started ON sessions(tenant_id, started_at)`);
257
- }
258
- // Check if agents table still has single-column PK
259
- const agentsSchema = db.get(sql `SELECT sql FROM sqlite_master WHERE type='table' AND name='agents'`);
260
- if (agentsSchema && agentsSchema.sql.includes('id TEXT PRIMARY KEY')) {
261
- db.run(sql `DROP INDEX IF EXISTS idx_agents_tenant_id`);
262
- db.run(sql `
263
- CREATE TABLE agents_new (
264
- id TEXT NOT NULL,
265
- name TEXT NOT NULL,
266
- description TEXT,
267
- first_seen_at TEXT NOT NULL,
268
- last_seen_at TEXT NOT NULL,
269
- session_count INTEGER NOT NULL DEFAULT 0,
270
- tenant_id TEXT NOT NULL DEFAULT 'default',
271
- PRIMARY KEY (id, tenant_id)
272
- )
273
- `);
274
- db.run(sql `
275
- INSERT INTO agents_new
276
- SELECT id, name, description, first_seen_at, last_seen_at,
277
- session_count, tenant_id
278
- FROM agents
279
- `);
280
- db.run(sql `DROP TABLE agents`);
281
- db.run(sql `ALTER TABLE agents_new RENAME TO agents`);
282
- db.run(sql `CREATE INDEX idx_agents_tenant_id ON agents(tenant_id)`);
283
- }
284
- // ─── Lessons table (Epic 3) ──────────────────────────────
285
- db.run(sql `
286
- CREATE TABLE IF NOT EXISTS lessons (
287
- id TEXT NOT NULL,
288
- tenant_id TEXT NOT NULL,
289
- agent_id TEXT,
290
- category TEXT NOT NULL DEFAULT 'general',
291
- title TEXT NOT NULL,
292
- content TEXT NOT NULL,
293
- context TEXT NOT NULL DEFAULT '{}',
294
- importance TEXT NOT NULL DEFAULT 'normal',
295
- source_session_id TEXT,
296
- source_event_id TEXT,
297
- access_count INTEGER NOT NULL DEFAULT 0,
298
- last_accessed_at TEXT,
299
- created_at TEXT NOT NULL,
300
- updated_at TEXT NOT NULL,
301
- archived_at TEXT,
302
- PRIMARY KEY (id, tenant_id)
303
- )
304
- `);
305
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_lessons_tenant ON lessons(tenant_id)`);
306
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_lessons_tenant_agent ON lessons(tenant_id, agent_id)`);
307
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_lessons_tenant_category ON lessons(tenant_id, category)`);
308
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_lessons_tenant_importance ON lessons(tenant_id, importance)`);
309
- // ─── Lessons PK migration (H5) ──────────────────────────
310
- // Migrate existing lessons tables from single-column PK to composite PK
311
- const lessonsSchema = db.get(sql `SELECT sql FROM sqlite_master WHERE type='table' AND name='lessons'`);
312
- if (lessonsSchema && lessonsSchema.sql.includes('id TEXT PRIMARY KEY')) {
313
- db.run(sql `DROP INDEX IF EXISTS idx_lessons_tenant`);
314
- db.run(sql `DROP INDEX IF EXISTS idx_lessons_tenant_agent`);
315
- db.run(sql `DROP INDEX IF EXISTS idx_lessons_tenant_category`);
316
- db.run(sql `DROP INDEX IF EXISTS idx_lessons_tenant_importance`);
317
- db.run(sql `
318
- CREATE TABLE lessons_new (
319
- id TEXT NOT NULL,
320
- tenant_id TEXT NOT NULL,
321
- agent_id TEXT,
322
- category TEXT NOT NULL DEFAULT 'general',
323
- title TEXT NOT NULL,
324
- content TEXT NOT NULL,
325
- context TEXT NOT NULL DEFAULT '{}',
326
- importance TEXT NOT NULL DEFAULT 'normal',
327
- source_session_id TEXT,
328
- source_event_id TEXT,
329
- access_count INTEGER NOT NULL DEFAULT 0,
330
- last_accessed_at TEXT,
331
- created_at TEXT NOT NULL,
332
- updated_at TEXT NOT NULL,
333
- archived_at TEXT,
334
- PRIMARY KEY (id, tenant_id)
335
- )
336
- `);
337
- db.run(sql `
338
- INSERT INTO lessons_new
339
- SELECT id, tenant_id, agent_id, category, title, content, context,
340
- importance, source_session_id, source_event_id, access_count,
341
- last_accessed_at, created_at, updated_at, archived_at
342
- FROM lessons
343
- `);
344
- db.run(sql `DROP TABLE lessons`);
345
- db.run(sql `ALTER TABLE lessons_new RENAME TO lessons`);
346
- db.run(sql `CREATE INDEX idx_lessons_tenant ON lessons(tenant_id)`);
347
- db.run(sql `CREATE INDEX idx_lessons_tenant_agent ON lessons(tenant_id, agent_id)`);
348
- db.run(sql `CREATE INDEX idx_lessons_tenant_category ON lessons(tenant_id, category)`);
349
- db.run(sql `CREATE INDEX idx_lessons_tenant_importance ON lessons(tenant_id, importance)`);
350
- }
351
- // ─── Composite index for similarity search (M6) ──────────────────
352
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_embeddings_tenant_source_time ON embeddings(tenant_id, source_type, created_at)`);
353
- // ─── Health Snapshots table (Epic 6 — Story 1.3) ──────────────────
354
- db.run(sql `
355
- CREATE TABLE IF NOT EXISTS health_snapshots (
356
- id TEXT NOT NULL,
357
- tenant_id TEXT NOT NULL,
358
- agent_id TEXT NOT NULL,
359
- date TEXT NOT NULL,
360
- overall_score REAL NOT NULL,
361
- error_rate_score REAL NOT NULL,
362
- cost_efficiency_score REAL NOT NULL,
363
- tool_success_score REAL NOT NULL,
364
- latency_score REAL NOT NULL,
365
- completion_rate_score REAL NOT NULL,
366
- session_count INTEGER NOT NULL,
367
- created_at TEXT NOT NULL,
368
- PRIMARY KEY (tenant_id, agent_id, date)
369
- )
370
- `);
371
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_health_snapshots_agent ON health_snapshots(tenant_id, agent_id, date DESC)`);
372
- // ─── Benchmark tables (v0.7.0 — Story 1.3) ──────────────────
373
- db.run(sql `
374
- CREATE TABLE IF NOT EXISTS benchmarks (
375
- id TEXT PRIMARY KEY,
376
- tenant_id TEXT NOT NULL,
377
- name TEXT NOT NULL,
378
- description TEXT,
379
- status TEXT NOT NULL DEFAULT 'draft',
380
- agent_id TEXT,
381
- metrics TEXT NOT NULL DEFAULT '[]',
382
- min_sessions_per_variant INTEGER NOT NULL DEFAULT 10,
383
- time_range_from TEXT,
384
- time_range_to TEXT,
385
- created_at TEXT NOT NULL,
386
- updated_at TEXT NOT NULL,
387
- completed_at TEXT
388
- )
389
- `);
390
- db.run(sql `
391
- CREATE TABLE IF NOT EXISTS benchmark_variants (
392
- id TEXT PRIMARY KEY,
393
- benchmark_id TEXT NOT NULL REFERENCES benchmarks(id) ON DELETE CASCADE,
394
- tenant_id TEXT NOT NULL,
395
- name TEXT NOT NULL,
396
- description TEXT,
397
- tag TEXT NOT NULL,
398
- agent_id TEXT,
399
- sort_order INTEGER NOT NULL DEFAULT 0
400
- )
401
- `);
402
- db.run(sql `
403
- CREATE TABLE IF NOT EXISTS benchmark_results (
404
- id TEXT PRIMARY KEY,
405
- benchmark_id TEXT NOT NULL REFERENCES benchmarks(id) ON DELETE CASCADE,
406
- tenant_id TEXT NOT NULL,
407
- variant_metrics TEXT NOT NULL DEFAULT '[]',
408
- comparisons TEXT NOT NULL DEFAULT '[]',
409
- summary TEXT,
410
- computed_at TEXT NOT NULL
411
- )
412
- `);
413
- // Benchmark indexes
414
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_benchmarks_tenant_id ON benchmarks(tenant_id)`);
415
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_benchmarks_tenant_status ON benchmarks(tenant_id, status)`);
416
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_benchmark_variants_benchmark_id ON benchmark_variants(benchmark_id)`);
417
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_benchmark_variants_tenant_tag ON benchmark_variants(tenant_id, tag)`);
418
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_benchmark_results_benchmark_id ON benchmark_results(benchmark_id)`);
419
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_benchmark_results_tenant_id ON benchmark_results(tenant_id)`);
420
- // ─── Guardrail tables (v0.8.0 — Phase 3) ──────────────────
421
- db.run(sql `
422
- CREATE TABLE IF NOT EXISTS guardrail_rules (
423
- id TEXT PRIMARY KEY,
424
- tenant_id TEXT NOT NULL,
425
- name TEXT NOT NULL,
426
- description TEXT,
427
- enabled INTEGER NOT NULL DEFAULT 1,
428
- condition_type TEXT NOT NULL,
429
- condition_config TEXT NOT NULL DEFAULT '{}',
430
- action_type TEXT NOT NULL,
431
- action_config TEXT NOT NULL DEFAULT '{}',
432
- agent_id TEXT,
433
- cooldown_minutes INTEGER NOT NULL DEFAULT 15,
434
- dry_run INTEGER NOT NULL DEFAULT 0,
435
- created_at TEXT NOT NULL,
436
- updated_at TEXT NOT NULL
437
- )
438
- `);
439
- db.run(sql `
440
- CREATE TABLE IF NOT EXISTS guardrail_state (
441
- rule_id TEXT NOT NULL,
442
- tenant_id TEXT NOT NULL,
443
- last_triggered_at TEXT,
444
- trigger_count INTEGER NOT NULL DEFAULT 0,
445
- last_evaluated_at TEXT,
446
- current_value REAL,
447
- PRIMARY KEY (rule_id, tenant_id)
448
- )
449
- `);
450
- db.run(sql `
451
- CREATE TABLE IF NOT EXISTS guardrail_trigger_history (
452
- id TEXT PRIMARY KEY,
453
- rule_id TEXT NOT NULL,
454
- tenant_id TEXT NOT NULL,
455
- triggered_at TEXT NOT NULL,
456
- condition_value REAL NOT NULL,
457
- condition_threshold REAL NOT NULL,
458
- action_executed INTEGER NOT NULL DEFAULT 0,
459
- action_result TEXT,
460
- metadata TEXT NOT NULL DEFAULT '{}'
461
- )
462
- `);
463
- // Guardrail indexes
464
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_guardrail_rules_tenant ON guardrail_rules(tenant_id)`);
465
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_guardrail_rules_tenant_enabled ON guardrail_rules(tenant_id, enabled)`);
466
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_guardrail_state_tenant ON guardrail_state(tenant_id)`);
467
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_guardrail_trigger_history_tenant ON guardrail_trigger_history(tenant_id)`);
468
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_guardrail_trigger_history_rule ON guardrail_trigger_history(rule_id, triggered_at)`);
469
- // ─── Agent model override & pause columns (B1 — Story 1.2) ──────
470
- // Idempotent: only adds columns if they don't already exist
471
- const agentColsB1 = db.all(sql `PRAGMA table_info(agents)`);
472
- const agentColNamesB1 = new Set(agentColsB1.map((c) => c.name));
473
- if (!agentColNamesB1.has('model_override')) {
474
- db.run(sql `ALTER TABLE agents ADD COLUMN model_override TEXT`);
475
- }
476
- if (!agentColNamesB1.has('paused_at')) {
477
- db.run(sql `ALTER TABLE agents ADD COLUMN paused_at TEXT`);
478
- }
479
- if (!agentColNamesB1.has('pause_reason')) {
480
- db.run(sql `ALTER TABLE agents ADD COLUMN pause_reason TEXT`);
481
- }
482
- // Partial index for finding paused agents efficiently
483
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_agents_paused ON agents(tenant_id, paused_at) WHERE paused_at IS NOT NULL`);
484
- // ─── Phase 4: Sharing & Discovery tables (Stories 1.3) ──────────
485
- db.run(sql `
486
- CREATE TABLE IF NOT EXISTS sharing_config (
487
- tenant_id TEXT PRIMARY KEY,
488
- enabled INTEGER NOT NULL DEFAULT 0,
489
- human_review_enabled INTEGER NOT NULL DEFAULT 0,
490
- pool_endpoint TEXT,
491
- anonymous_contributor_id TEXT,
492
- purge_token TEXT,
493
- rate_limit_per_hour INTEGER NOT NULL DEFAULT 50,
494
- volume_alert_threshold INTEGER NOT NULL DEFAULT 100,
495
- updated_at TEXT NOT NULL
496
- )
497
- `);
498
- db.run(sql `
499
- CREATE TABLE IF NOT EXISTS agent_sharing_config (
500
- tenant_id TEXT NOT NULL,
501
- agent_id TEXT NOT NULL,
502
- enabled INTEGER NOT NULL DEFAULT 0,
503
- categories TEXT NOT NULL DEFAULT '[]',
504
- updated_at TEXT NOT NULL,
505
- PRIMARY KEY (tenant_id, agent_id)
506
- )
507
- `);
508
- db.run(sql `
509
- CREATE TABLE IF NOT EXISTS deny_list_rules (
510
- id TEXT PRIMARY KEY,
511
- tenant_id TEXT NOT NULL,
512
- pattern TEXT NOT NULL,
513
- is_regex INTEGER NOT NULL DEFAULT 0,
514
- reason TEXT NOT NULL,
515
- created_at TEXT NOT NULL
516
- )
517
- `);
518
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_deny_list_rules_tenant ON deny_list_rules(tenant_id)`);
519
- db.run(sql `
520
- CREATE TABLE IF NOT EXISTS sharing_audit_log (
521
- id TEXT PRIMARY KEY,
522
- tenant_id TEXT NOT NULL,
523
- event_type TEXT NOT NULL,
524
- lesson_id TEXT,
525
- anonymous_lesson_id TEXT,
526
- lesson_hash TEXT,
527
- redaction_findings TEXT,
528
- query_text TEXT,
529
- result_ids TEXT,
530
- pool_endpoint TEXT,
531
- initiated_by TEXT,
532
- timestamp TEXT NOT NULL
533
- )
534
- `);
535
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sharing_audit_tenant_ts ON sharing_audit_log(tenant_id, timestamp)`);
536
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_sharing_audit_type ON sharing_audit_log(tenant_id, event_type)`);
537
- db.run(sql `
538
- CREATE TABLE IF NOT EXISTS sharing_review_queue (
539
- id TEXT PRIMARY KEY,
540
- tenant_id TEXT NOT NULL,
541
- lesson_id TEXT NOT NULL,
542
- original_title TEXT NOT NULL,
543
- original_content TEXT NOT NULL,
544
- redacted_title TEXT NOT NULL,
545
- redacted_content TEXT NOT NULL,
546
- redaction_findings TEXT NOT NULL,
547
- status TEXT NOT NULL DEFAULT 'pending',
548
- reviewed_by TEXT,
549
- reviewed_at TEXT,
550
- created_at TEXT NOT NULL,
551
- expires_at TEXT NOT NULL
552
- )
553
- `);
554
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_review_queue_tenant_status ON sharing_review_queue(tenant_id, status)`);
555
- db.run(sql `
556
- CREATE TABLE IF NOT EXISTS anonymous_id_map (
557
- tenant_id TEXT NOT NULL,
558
- agent_id TEXT NOT NULL,
559
- anonymous_agent_id TEXT NOT NULL,
560
- valid_from TEXT NOT NULL,
561
- valid_until TEXT NOT NULL,
562
- PRIMARY KEY (tenant_id, agent_id, valid_from)
563
- )
564
- `);
565
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_anon_map_anon_id ON anonymous_id_map(anonymous_agent_id)`);
566
- db.run(sql `
567
- CREATE TABLE IF NOT EXISTS capability_registry (
568
- id TEXT PRIMARY KEY,
569
- tenant_id TEXT NOT NULL,
570
- agent_id TEXT NOT NULL,
571
- task_type TEXT NOT NULL,
572
- custom_type TEXT,
573
- input_schema TEXT NOT NULL,
574
- output_schema TEXT NOT NULL,
575
- quality_metrics TEXT NOT NULL DEFAULT '{}',
576
- estimated_latency_ms INTEGER,
577
- estimated_cost_usd REAL,
578
- max_input_bytes INTEGER,
579
- scope TEXT NOT NULL DEFAULT 'internal',
580
- enabled INTEGER NOT NULL DEFAULT 1,
581
- accept_delegations INTEGER NOT NULL DEFAULT 0,
582
- inbound_rate_limit INTEGER NOT NULL DEFAULT 10,
583
- outbound_rate_limit INTEGER NOT NULL DEFAULT 20,
584
- created_at TEXT NOT NULL,
585
- updated_at TEXT NOT NULL
586
- )
587
- `);
588
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_capability_tenant_agent ON capability_registry(tenant_id, agent_id)`);
589
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_capability_task_type ON capability_registry(tenant_id, task_type)`);
590
- db.run(sql `
591
- CREATE TABLE IF NOT EXISTS delegation_log (
592
- id TEXT PRIMARY KEY,
593
- tenant_id TEXT NOT NULL,
594
- direction TEXT NOT NULL,
595
- agent_id TEXT NOT NULL,
596
- anonymous_target_id TEXT,
597
- anonymous_source_id TEXT,
598
- task_type TEXT NOT NULL,
599
- status TEXT NOT NULL,
600
- request_size_bytes INTEGER,
601
- response_size_bytes INTEGER,
602
- execution_time_ms INTEGER,
603
- cost_usd REAL,
604
- created_at TEXT NOT NULL,
605
- completed_at TEXT
606
- )
607
- `);
608
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_delegation_tenant_ts ON delegation_log(tenant_id, created_at)`);
609
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_delegation_agent ON delegation_log(tenant_id, agent_id)`);
610
- db.run(sql `CREATE INDEX IF NOT EXISTS idx_delegation_status ON delegation_log(tenant_id, status)`);
611
- // ─── Discovery Config (Story 5.4) ──────────────────────
612
- db.run(sql `
613
- CREATE TABLE IF NOT EXISTS discovery_config (
614
- tenant_id TEXT PRIMARY KEY,
615
- min_trust_threshold INTEGER NOT NULL DEFAULT 60,
616
- delegation_enabled INTEGER NOT NULL DEFAULT 0,
617
- updated_at TEXT NOT NULL
618
- )
619
- `);
620
- }
621
- /**
622
- * Verify that WAL mode is enabled.
623
- */
624
- export function verifyPragmas(db) {
625
- const journalMode = db.get(sql `PRAGMA journal_mode`)?.journal_mode ?? '';
626
- const synchronous = db.get(sql `PRAGMA synchronous`)?.synchronous ?? -1;
627
- const cacheSize = db.get(sql `PRAGMA cache_size`)?.cache_size ?? 0;
628
- // SQLite returns { timeout: N } for PRAGMA busy_timeout
629
- const busyTimeout = db.get(sql `PRAGMA busy_timeout`)?.timeout ?? 0;
630
- const foreignKeys = db.get(sql `PRAGMA foreign_keys`)?.foreign_keys === 1;
631
- // synchronous: 0=OFF, 1=NORMAL, 2=FULL, 3=EXTRA
632
- const syncNames = { 0: 'OFF', 1: 'NORMAL', 2: 'FULL', 3: 'EXTRA' };
633
- return {
634
- journalMode,
635
- synchronous: syncNames[synchronous] ?? String(synchronous),
636
- cacheSize,
637
- busyTimeout,
638
- foreignKeys,
639
- };
640
- }
7
+ // Re-export SQLite migrations keeps every existing import working unchanged.
8
+ export { runMigrations, verifyPragmas } from './migrate.sqlite.js';
9
+ // Postgres programmatic migration (Drizzle Kit managed folder)
10
+ export { runPostgresMigrations } from './migrate.postgres.js';
641
11
  //# sourceMappingURL=migrate.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"migrate.js","sourceRoot":"","sources":["../../src/db/migrate.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"migrate.js","sourceRoot":"","sources":["../../src/db/migrate.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,+EAA+E;AAC/E,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEnE,+DAA+D;AAC/D,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC"}