@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
@@ -0,0 +1,92 @@
1
+ /**
2
+ * Audit Log Service (S-2.6)
3
+ *
4
+ * Append-only, immutable audit log for security-relevant events.
5
+ * Supports: auth events, API key ops, member management, settings changes,
6
+ * data exports, billing events.
7
+ */
8
+ export class AuditLogService {
9
+ db;
10
+ constructor(db) {
11
+ this.db = db;
12
+ }
13
+ /**
14
+ * Write an audit log entry. Append-only — no updates or deletes.
15
+ */
16
+ async write(entry) {
17
+ const result = await this.db.query(`INSERT INTO audit_log (org_id, actor_type, actor_id, action, resource_type, resource_id, details, ip_address, result)
18
+ VALUES ($1, $2, $3, $4, $5, $6, $7, $8::inet, $9)
19
+ RETURNING *`, [
20
+ entry.org_id,
21
+ entry.actor_type,
22
+ entry.actor_id,
23
+ entry.action,
24
+ entry.resource_type,
25
+ entry.resource_id ?? null,
26
+ entry.details ? JSON.stringify(entry.details) : null,
27
+ entry.ip_address ?? null,
28
+ entry.result,
29
+ ]);
30
+ return result.rows[0];
31
+ }
32
+ /**
33
+ * Query audit log with filters. Results ordered by created_at DESC.
34
+ */
35
+ async query(filters) {
36
+ const conditions = ['org_id = $1'];
37
+ const params = [filters.org_id];
38
+ let paramIdx = 2;
39
+ if (filters.action) {
40
+ conditions.push(`action = $${paramIdx++}`);
41
+ params.push(filters.action);
42
+ }
43
+ if (filters.actor_id) {
44
+ conditions.push(`actor_id = $${paramIdx++}`);
45
+ params.push(filters.actor_id);
46
+ }
47
+ if (filters.resource_type) {
48
+ conditions.push(`resource_type = $${paramIdx++}`);
49
+ params.push(filters.resource_type);
50
+ }
51
+ if (filters.from) {
52
+ conditions.push(`created_at >= $${paramIdx++}`);
53
+ params.push(filters.from.toISOString());
54
+ }
55
+ if (filters.to) {
56
+ conditions.push(`created_at <= $${paramIdx++}`);
57
+ params.push(filters.to.toISOString());
58
+ }
59
+ const where = conditions.join(' AND ');
60
+ const limit = filters.limit ?? 50;
61
+ const offset = filters.offset ?? 0;
62
+ const [dataResult, countResult] = await Promise.all([
63
+ this.db.query(`SELECT * FROM audit_log WHERE ${where} ORDER BY created_at DESC LIMIT $${paramIdx++} OFFSET $${paramIdx++}`, [...params, limit, offset]),
64
+ this.db.query(`SELECT COUNT(*)::int as total FROM audit_log WHERE ${where}`, params),
65
+ ]);
66
+ return {
67
+ entries: dataResult.rows,
68
+ total: countResult.rows[0].total,
69
+ };
70
+ }
71
+ /**
72
+ * Export all audit log entries for an org within a time range.
73
+ * Returns JSON array (for download).
74
+ */
75
+ async export(org_id, from, to) {
76
+ const conditions = ['org_id = $1'];
77
+ const params = [org_id];
78
+ let paramIdx = 2;
79
+ if (from) {
80
+ conditions.push(`created_at >= $${paramIdx++}`);
81
+ params.push(from.toISOString());
82
+ }
83
+ if (to) {
84
+ conditions.push(`created_at <= $${paramIdx++}`);
85
+ params.push(to.toISOString());
86
+ }
87
+ const where = conditions.join(' AND ');
88
+ const result = await this.db.query(`SELECT * FROM audit_log WHERE ${where} ORDER BY created_at ASC`, params);
89
+ return result.rows;
90
+ }
91
+ }
92
+ //# sourceMappingURL=audit-log.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit-log.js","sourceRoot":"","sources":["../../../src/cloud/auth/audit-log.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,77 @@
1
+ /**
2
+ * Auth Service — orchestrates user creation, login, OAuth, and sessions.
3
+ *
4
+ * Uses MigrationClient (pg Pool) for database operations.
5
+ * In-memory brute-force protection (replaceable with Redis in prod).
6
+ */
7
+ import type { MigrationClient } from '../migrate.js';
8
+ import { BruteForceProtection } from './brute-force.js';
9
+ import type { OAuthUserProfile } from './oauth.js';
10
+ export interface AuthServiceConfig {
11
+ jwtSecret: string;
12
+ jwtExpiresInSeconds?: number;
13
+ }
14
+ export interface AuthUser {
15
+ id: string;
16
+ email: string;
17
+ email_verified: boolean;
18
+ password_hash: string | null;
19
+ display_name: string | null;
20
+ avatar_url: string | null;
21
+ oauth_provider: string | null;
22
+ oauth_provider_id: string | null;
23
+ }
24
+ export interface AuthResult {
25
+ token: string;
26
+ user: {
27
+ id: string;
28
+ email: string;
29
+ name: string | null;
30
+ };
31
+ }
32
+ export declare class AuthService {
33
+ private db;
34
+ private config;
35
+ private bruteForce;
36
+ constructor(db: MigrationClient, config: AuthServiceConfig, bruteForce?: BruteForceProtection);
37
+ /**
38
+ * Handle OAuth callback: find or create user, return JWT.
39
+ */
40
+ oauthLogin(profile: OAuthUserProfile): Promise<AuthResult>;
41
+ private createOAuthUser;
42
+ /**
43
+ * Register a new user with email and password.
44
+ * Returns verification token (to be sent via email).
45
+ */
46
+ register(email: string, password: string, displayName?: string): Promise<{
47
+ user: AuthUser;
48
+ verificationToken: string;
49
+ }>;
50
+ /**
51
+ * Verify email address with token.
52
+ */
53
+ verifyEmail(token: string): Promise<boolean>;
54
+ /**
55
+ * Login with email and password.
56
+ */
57
+ login(email: string, password: string): Promise<AuthResult>;
58
+ /**
59
+ * Request password reset. Returns token to be sent via email.
60
+ * Always succeeds (even if email not found) to prevent enumeration.
61
+ */
62
+ requestPasswordReset(email: string): Promise<string | null>;
63
+ /**
64
+ * Reset password using token.
65
+ */
66
+ resetPassword(token: string, newPassword: string): Promise<boolean>;
67
+ private issueToken;
68
+ private findUserByEmail;
69
+ private findUserById;
70
+ private findUserByOAuth;
71
+ private createDefaultOrg;
72
+ }
73
+ export declare class AuthError extends Error {
74
+ code: string;
75
+ constructor(code: string, message: string);
76
+ }
77
+ //# sourceMappingURL=auth-service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-service.d.ts","sourceRoot":"","sources":["../../../src/cloud/auth/auth-service.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAIrD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,MAAM,WAAW,iBAAiB;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,cAAc,EAAE,OAAO,CAAC;IACxB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;CAClC;AAED,MAAM,WAAW,UAAU;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,CAAC;CAC1D;AAED,qBAAa,WAAW;IAEpB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,UAAU;gBAFV,EAAE,EAAE,eAAe,EACnB,MAAM,EAAE,iBAAiB,EACzB,UAAU,uBAA6B;IAOjD;;OAEG;IACG,UAAU,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,UAAU,CAAC;YA6BlD,eAAe;IAmB7B;;;OAGG;IACG,QAAQ,CACZ,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,MAAM,EAChB,WAAW,CAAC,EAAE,MAAM,GACnB,OAAO,CAAC;QAAE,IAAI,EAAE,QAAQ,CAAC;QAAC,iBAAiB,EAAE,MAAM,CAAA;KAAE,CAAC;IAqCzD;;OAEG;IACG,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAwBlD;;OAEG;IACG,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAmCjE;;;OAGG;IACG,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAsBjE;;OAEG;IACG,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;YAkC3D,UAAU;YAsBV,eAAe;YAKf,YAAY;YAKZ,eAAe;YAQf,gBAAgB;CAsB/B;AAED,qBAAa,SAAU,SAAQ,KAAK;IAEzB,IAAI,EAAE,MAAM;gBAAZ,IAAI,EAAE,MAAM,EACnB,OAAO,EAAE,MAAM;CAKlB"}
@@ -0,0 +1,229 @@
1
+ /**
2
+ * Auth Service — orchestrates user creation, login, OAuth, and sessions.
3
+ *
4
+ * Uses MigrationClient (pg Pool) for database operations.
5
+ * In-memory brute-force protection (replaceable with Redis in prod).
6
+ */
7
+ import { hashPassword, verifyPassword, validatePasswordComplexity } from './passwords.js';
8
+ import { signJwt, verifyJwt } from './jwt.js';
9
+ import { generateToken, hashToken, verifyToken } from './tokens.js';
10
+ import { BruteForceProtection } from './brute-force.js';
11
+ export class AuthService {
12
+ db;
13
+ config;
14
+ bruteForce;
15
+ constructor(db, config, bruteForce = new BruteForceProtection()) {
16
+ this.db = db;
17
+ this.config = config;
18
+ this.bruteForce = bruteForce;
19
+ }
20
+ // ═══════════════════════════════════════════
21
+ // OAuth Login / Registration
22
+ // ═══════════════════════════════════════════
23
+ /**
24
+ * Handle OAuth callback: find or create user, return JWT.
25
+ */
26
+ async oauthLogin(profile) {
27
+ // 1. Try to find by OAuth provider + ID
28
+ let user = await this.findUserByOAuth(profile.provider, profile.providerId);
29
+ if (!user) {
30
+ // 2. Try to find by email (link OAuth to existing account)
31
+ user = await this.findUserByEmail(profile.email);
32
+ if (user) {
33
+ // Link OAuth to existing user
34
+ await this.db.query(`UPDATE users SET oauth_provider = $1, oauth_provider_id = $2,
35
+ email_verified = TRUE, avatar_url = COALESCE(avatar_url, $3),
36
+ display_name = COALESCE(display_name, $4), updated_at = now()
37
+ WHERE id = $5`, [profile.provider, profile.providerId, profile.avatarUrl, profile.name, user.id]);
38
+ user.email_verified = true;
39
+ }
40
+ else {
41
+ // 3. Create new user
42
+ user = await this.createOAuthUser(profile);
43
+ }
44
+ }
45
+ // Issue JWT
46
+ const token = await this.issueToken(user);
47
+ return { token, user: { id: user.id, email: user.email, name: user.display_name } };
48
+ }
49
+ async createOAuthUser(profile) {
50
+ // Create user
51
+ const result = await this.db.query(`INSERT INTO users (email, email_verified, display_name, avatar_url, oauth_provider, oauth_provider_id)
52
+ VALUES ($1, TRUE, $2, $3, $4, $5)
53
+ RETURNING *`, [profile.email, profile.name, profile.avatarUrl, profile.provider, profile.providerId]);
54
+ const user = result.rows[0];
55
+ // Create default personal org
56
+ await this.createDefaultOrg(user);
57
+ return user;
58
+ }
59
+ // ═══════════════════════════════════════════
60
+ // Email/Password Registration
61
+ // ═══════════════════════════════════════════
62
+ /**
63
+ * Register a new user with email and password.
64
+ * Returns verification token (to be sent via email).
65
+ */
66
+ async register(email, password, displayName) {
67
+ // Validate password
68
+ const complexity = validatePasswordComplexity(password);
69
+ if (!complexity.valid) {
70
+ throw new AuthError('invalid_password', complexity.errors.join('; '));
71
+ }
72
+ // Check if email already exists
73
+ const existing = await this.findUserByEmail(email);
74
+ if (existing) {
75
+ throw new AuthError('email_exists', 'An account with this email already exists');
76
+ }
77
+ // Hash password & create user
78
+ const passwordHash = await hashPassword(password);
79
+ const verificationToken = generateToken();
80
+ const tokenHash = hashToken(verificationToken);
81
+ const result = await this.db.query(`INSERT INTO users (email, email_verified, password_hash, display_name)
82
+ VALUES ($1, FALSE, $2, $3)
83
+ RETURNING *`, [email, passwordHash, displayName ?? null]);
84
+ const user = result.rows[0];
85
+ // Store verification token (using a simple approach: store in users table or a tokens table)
86
+ // For simplicity, we'll use the email_verification_token approach
87
+ await this.db.query(`INSERT INTO _email_tokens (user_id, token_hash, type, expires_at)
88
+ VALUES ($1, $2, 'verification', now() + interval '24 hours')`, [user.id, tokenHash]);
89
+ return { user, verificationToken };
90
+ }
91
+ /**
92
+ * Verify email address with token.
93
+ */
94
+ async verifyEmail(token) {
95
+ const tokenHash = hashToken(token);
96
+ const result = await this.db.query(`SELECT user_id FROM _email_tokens
97
+ WHERE token_hash = $1 AND type = 'verification' AND expires_at > now()`, [tokenHash]);
98
+ if (result.rows.length === 0)
99
+ return false;
100
+ const userId = result.rows[0].user_id;
101
+ await this.db.query(`UPDATE users SET email_verified = TRUE, updated_at = now() WHERE id = $1`, [userId]);
102
+ await this.db.query(`DELETE FROM _email_tokens WHERE token_hash = $1`, [tokenHash]);
103
+ // Create default org after verification
104
+ const user = await this.findUserById(userId);
105
+ if (user)
106
+ await this.createDefaultOrg(user);
107
+ return true;
108
+ }
109
+ // ═══════════════════════════════════════════
110
+ // Email/Password Login
111
+ // ═══════════════════════════════════════════
112
+ /**
113
+ * Login with email and password.
114
+ */
115
+ async login(email, password) {
116
+ // Check brute-force lock
117
+ if (this.bruteForce.isLocked(email)) {
118
+ throw new AuthError('account_locked', 'Account temporarily locked due to too many failed attempts');
119
+ }
120
+ const user = await this.findUserByEmail(email);
121
+ if (!user || !user.password_hash) {
122
+ this.bruteForce.recordFailure(email);
123
+ throw new AuthError('invalid_credentials', 'Invalid email or password');
124
+ }
125
+ if (!user.email_verified) {
126
+ throw new AuthError('email_not_verified', 'Please verify your email before logging in');
127
+ }
128
+ const valid = await verifyPassword(password, user.password_hash);
129
+ if (!valid) {
130
+ const locked = this.bruteForce.recordFailure(email);
131
+ if (locked) {
132
+ throw new AuthError('account_locked', 'Account temporarily locked due to too many failed attempts');
133
+ }
134
+ throw new AuthError('invalid_credentials', 'Invalid email or password');
135
+ }
136
+ this.bruteForce.recordSuccess(email);
137
+ const token = await this.issueToken(user);
138
+ return { token, user: { id: user.id, email: user.email, name: user.display_name } };
139
+ }
140
+ // ═══════════════════════════════════════════
141
+ // Password Reset
142
+ // ═══════════════════════════════════════════
143
+ /**
144
+ * Request password reset. Returns token to be sent via email.
145
+ * Always succeeds (even if email not found) to prevent enumeration.
146
+ */
147
+ async requestPasswordReset(email) {
148
+ const user = await this.findUserByEmail(email);
149
+ if (!user)
150
+ return null; // Don't reveal whether email exists
151
+ const token = generateToken();
152
+ const tokenHash = hashToken(token);
153
+ // Delete old reset tokens for this user
154
+ await this.db.query(`DELETE FROM _email_tokens WHERE user_id = $1 AND type = 'reset'`, [user.id]);
155
+ await this.db.query(`INSERT INTO _email_tokens (user_id, token_hash, type, expires_at)
156
+ VALUES ($1, $2, 'reset', now() + interval '1 hour')`, [user.id, tokenHash]);
157
+ return token;
158
+ }
159
+ /**
160
+ * Reset password using token.
161
+ */
162
+ async resetPassword(token, newPassword) {
163
+ const complexity = validatePasswordComplexity(newPassword);
164
+ if (!complexity.valid) {
165
+ throw new AuthError('invalid_password', complexity.errors.join('; '));
166
+ }
167
+ const tokenHash = hashToken(token);
168
+ const result = await this.db.query(`SELECT user_id FROM _email_tokens
169
+ WHERE token_hash = $1 AND type = 'reset' AND expires_at > now()`, [tokenHash]);
170
+ if (result.rows.length === 0)
171
+ return false;
172
+ const userId = result.rows[0].user_id;
173
+ const passwordHash = await hashPassword(newPassword);
174
+ await this.db.query(`UPDATE users SET password_hash = $1, updated_at = now() WHERE id = $2`, [passwordHash, userId]);
175
+ await this.db.query(`DELETE FROM _email_tokens WHERE token_hash = $1`, [tokenHash]);
176
+ // Clear brute-force records for this user's email
177
+ const user = await this.findUserById(userId);
178
+ if (user)
179
+ this.bruteForce.recordSuccess(user.email);
180
+ return true;
181
+ }
182
+ // ═══════════════════════════════════════════
183
+ // Token Issuance
184
+ // ═══════════════════════════════════════════
185
+ async issueToken(user) {
186
+ // Fetch user's org memberships
187
+ const orgsResult = await this.db.query(`SELECT om.org_id, om.role FROM org_members om WHERE om.user_id = $1`, [user.id]);
188
+ const orgs = orgsResult.rows.map((r) => ({
189
+ org_id: r.org_id,
190
+ role: r.role,
191
+ }));
192
+ return signJwt({ sub: user.id, email: user.email, name: user.display_name, orgs }, this.config.jwtSecret, this.config.jwtExpiresInSeconds ?? 7 * 24 * 3600);
193
+ }
194
+ // ═══════════════════════════════════════════
195
+ // Helpers
196
+ // ═══════════════════════════════════════════
197
+ async findUserByEmail(email) {
198
+ const result = await this.db.query(`SELECT * FROM users WHERE email = $1`, [email]);
199
+ return result.rows[0] ?? null;
200
+ }
201
+ async findUserById(id) {
202
+ const result = await this.db.query(`SELECT * FROM users WHERE id = $1`, [id]);
203
+ return result.rows[0] ?? null;
204
+ }
205
+ async findUserByOAuth(provider, providerId) {
206
+ const result = await this.db.query(`SELECT * FROM users WHERE oauth_provider = $1 AND oauth_provider_id = $2`, [provider, providerId]);
207
+ return result.rows[0] ?? null;
208
+ }
209
+ async createDefaultOrg(user) {
210
+ // Check if user already has an org
211
+ const existing = await this.db.query(`SELECT 1 FROM org_members WHERE user_id = $1 LIMIT 1`, [user.id]);
212
+ if (existing.rows.length > 0)
213
+ return;
214
+ const displayName = user.display_name || user.email.split('@')[0];
215
+ const slug = `${displayName.toLowerCase().replace(/[^a-z0-9]/g, '-')}-${user.id.slice(0, 8)}`;
216
+ const orgResult = await this.db.query(`INSERT INTO orgs (name, slug) VALUES ($1, $2) RETURNING id`, [`${displayName}'s Org`, slug]);
217
+ const orgId = orgResult.rows[0].id;
218
+ await this.db.query(`INSERT INTO org_members (org_id, user_id, role) VALUES ($1, $2, 'owner')`, [orgId, user.id]);
219
+ }
220
+ }
221
+ export class AuthError extends Error {
222
+ code;
223
+ constructor(code, message) {
224
+ super(message);
225
+ this.code = code;
226
+ this.name = 'AuthError';
227
+ }
228
+ }
229
+ //# sourceMappingURL=auth-service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-service.js","sourceRoot":"","sources":["../../../src/cloud/auth/auth-service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ /**
2
+ * Brute-force protection: in-memory rate limiter.
3
+ * Locks account after 10 failed attempts in 15 minutes.
4
+ *
5
+ * In production, this would use Redis. For now, in-memory is sufficient
6
+ * for single-instance deployments and testing.
7
+ */
8
+ export interface BruteForceConfig {
9
+ maxAttempts: number;
10
+ windowMs: number;
11
+ lockDurationMs: number;
12
+ }
13
+ export declare class BruteForceProtection {
14
+ private records;
15
+ private config;
16
+ constructor(config?: Partial<BruteForceConfig>);
17
+ /**
18
+ * Check if a key (email) is currently locked.
19
+ */
20
+ isLocked(key: string): boolean;
21
+ /**
22
+ * Record a failed attempt. Returns true if account is now locked.
23
+ */
24
+ recordFailure(key: string): boolean;
25
+ /**
26
+ * Clear attempts on successful login.
27
+ */
28
+ recordSuccess(key: string): void;
29
+ /**
30
+ * Reset all records (for testing).
31
+ */
32
+ reset(): void;
33
+ }
34
+ /** Singleton instance */
35
+ export declare const bruteForce: BruteForceProtection;
36
+ //# sourceMappingURL=brute-force.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"brute-force.d.ts","sourceRoot":"","sources":["../../../src/cloud/auth/brute-force.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,MAAM,WAAW,gBAAgB;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,cAAc,EAAE,MAAM,CAAC;CACxB;AAaD,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,OAAO,CAAoC;IACnD,OAAO,CAAC,MAAM,CAAmB;gBAErB,MAAM,GAAE,OAAO,CAAC,gBAAgB,CAAM;IAIlD;;OAEG;IACH,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAW9B;;OAEG;IACH,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAmBnC;;OAEG;IACH,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAIhC;;OAEG;IACH,KAAK,IAAI,IAAI;CAGd;AAED,yBAAyB;AACzB,eAAO,MAAM,UAAU,sBAA6B,CAAC"}
@@ -0,0 +1,67 @@
1
+ /**
2
+ * Brute-force protection: in-memory rate limiter.
3
+ * Locks account after 10 failed attempts in 15 minutes.
4
+ *
5
+ * In production, this would use Redis. For now, in-memory is sufficient
6
+ * for single-instance deployments and testing.
7
+ */
8
+ const DEFAULT_CONFIG = {
9
+ maxAttempts: 10,
10
+ windowMs: 15 * 60 * 1000,
11
+ lockDurationMs: 15 * 60 * 1000,
12
+ };
13
+ export class BruteForceProtection {
14
+ records = new Map();
15
+ config;
16
+ constructor(config = {}) {
17
+ this.config = { ...DEFAULT_CONFIG, ...config };
18
+ }
19
+ /**
20
+ * Check if a key (email) is currently locked.
21
+ */
22
+ isLocked(key) {
23
+ const record = this.records.get(key);
24
+ if (!record?.lockedUntil)
25
+ return false;
26
+ if (Date.now() >= record.lockedUntil) {
27
+ // Lock expired, clear
28
+ this.records.delete(key);
29
+ return false;
30
+ }
31
+ return true;
32
+ }
33
+ /**
34
+ * Record a failed attempt. Returns true if account is now locked.
35
+ */
36
+ recordFailure(key) {
37
+ const now = Date.now();
38
+ let record = this.records.get(key);
39
+ if (!record) {
40
+ record = { attempts: [], lockedUntil: null };
41
+ this.records.set(key, record);
42
+ }
43
+ // Prune old attempts outside the window
44
+ record.attempts = record.attempts.filter((t) => now - t < this.config.windowMs);
45
+ record.attempts.push(now);
46
+ if (record.attempts.length >= this.config.maxAttempts) {
47
+ record.lockedUntil = now + this.config.lockDurationMs;
48
+ return true;
49
+ }
50
+ return false;
51
+ }
52
+ /**
53
+ * Clear attempts on successful login.
54
+ */
55
+ recordSuccess(key) {
56
+ this.records.delete(key);
57
+ }
58
+ /**
59
+ * Reset all records (for testing).
60
+ */
61
+ reset() {
62
+ this.records.clear();
63
+ }
64
+ }
65
+ /** Singleton instance */
66
+ export const bruteForce = new BruteForceProtection();
67
+ //# sourceMappingURL=brute-force.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"brute-force.js","sourceRoot":"","sources":["../../../src/cloud/auth/brute-force.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAaH,MAAM,cAAc,GAAqB;IACvC,WAAW,EAAE,EAAE;IACf,QAAQ,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI;IACxB,cAAc,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI;CAC/B,CAAC;AAEF,MAAM,OAAO,oBAAoB;IACvB,OAAO,GAAG,IAAI,GAAG,EAAyB,CAAC;IAC3C,MAAM,CAAmB;IAEjC,YAAY,SAAoC,EAAE;QAChD,IAAI,CAAC,MAAM,GAAG,EAAE,GAAG,cAAc,EAAE,GAAG,MAAM,EAAE,CAAC;IACjD,CAAC;IAED;;OAEG;IACH,QAAQ,CAAC,GAAW;QAClB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACrC,IAAI,CAAC,MAAM,EAAE,WAAW;YAAE,OAAO,KAAK,CAAC;QACvC,IAAI,IAAI,CAAC,GAAG,EAAE,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;YACrC,sBAAsB;YACtB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACzB,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,GAAW;QACvB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACnC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;YAC7C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAChC,CAAC;QAED,wCAAwC;QACxC,MAAM,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChF,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAE1B,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;YACtD,MAAM,CAAC,WAAW,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC;YACtD,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,GAAW;QACvB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;CACF;AAED,yBAAyB;AACzB,MAAM,CAAC,MAAM,UAAU,GAAG,IAAI,oBAAoB,EAAE,CAAC"}
@@ -0,0 +1,11 @@
1
+ export { AuthService, AuthError, type AuthServiceConfig, type AuthResult, type AuthUser } from './auth-service.js';
2
+ export { signJwt, verifyJwt, JWT_COOKIE_OPTIONS, type JwtPayload } from './jwt.js';
3
+ export { hashPassword, verifyPassword, validatePasswordComplexity } from './passwords.js';
4
+ export { generateToken, hashToken, verifyToken } from './tokens.js';
5
+ export { BruteForceProtection } from './brute-force.js';
6
+ export { ApiKeyService, ApiKeyError, generateApiKey, type ApiKeyRecord, type CreateApiKeyInput, type CreateApiKeyResult, type ApiKeyEnvironment, } from './api-keys.js';
7
+ export { ApiKeyAuthMiddleware, ApiKeyAuthError, InMemoryApiKeyCache, type ApiKeyAuthContext, type ApiKeyCache, type CacheEntry, } from './api-key-middleware.js';
8
+ export { AuditLogService, type AuditAction, type ActorType, type AuditResult, type AuditEntry, type WriteAuditEntry, type AuditQueryFilters, } from './audit-log.js';
9
+ export { requireRole, requireActionCategory, isRoleAllowed, categorizeAction, PERMISSION_MATRIX, type Role, type ActionCategory, type RbacRequest, type RbacResult, } from './rbac.js';
10
+ export { type OAuthConfig, type OAuthProviderConfig, type OAuthUserProfile, getGoogleAuthUrl, exchangeGoogleCode, getGoogleProfile, getGithubAuthUrl, exchangeGithubCode, getGithubProfile, } from './oauth.js';
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/cloud/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,KAAK,iBAAiB,EAAE,KAAK,UAAU,EAAE,KAAK,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AACnH,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,KAAK,UAAU,EAAE,MAAM,UAAU,CAAC;AACnF,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,0BAA0B,EAAE,MAAM,gBAAgB,CAAC;AAC1F,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EACL,aAAa,EACb,WAAW,EACX,cAAc,EACd,KAAK,YAAY,EACjB,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,GACvB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,oBAAoB,EACpB,eAAe,EACf,mBAAmB,EACnB,KAAK,iBAAiB,EACtB,KAAK,WAAW,EAChB,KAAK,UAAU,GAChB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACL,eAAe,EACf,KAAK,WAAW,EAChB,KAAK,SAAS,EACd,KAAK,WAAW,EAChB,KAAK,UAAU,EACf,KAAK,eAAe,EACpB,KAAK,iBAAiB,GACvB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,WAAW,EACX,qBAAqB,EACrB,aAAa,EACb,gBAAgB,EAChB,iBAAiB,EACjB,KAAK,IAAI,EACT,KAAK,cAAc,EACnB,KAAK,WAAW,EAChB,KAAK,UAAU,GAChB,MAAM,WAAW,CAAC;AACnB,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,mBAAmB,EACxB,KAAK,gBAAgB,EACrB,gBAAgB,EAChB,kBAAkB,EAClB,gBAAgB,EAChB,gBAAgB,EAChB,kBAAkB,EAClB,gBAAgB,GACjB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,11 @@
1
+ export { AuthService, AuthError } from './auth-service.js';
2
+ export { signJwt, verifyJwt, JWT_COOKIE_OPTIONS } from './jwt.js';
3
+ export { hashPassword, verifyPassword, validatePasswordComplexity } from './passwords.js';
4
+ export { generateToken, hashToken, verifyToken } from './tokens.js';
5
+ export { BruteForceProtection } from './brute-force.js';
6
+ export { ApiKeyService, ApiKeyError, generateApiKey, } from './api-keys.js';
7
+ export { ApiKeyAuthMiddleware, ApiKeyAuthError, InMemoryApiKeyCache, } from './api-key-middleware.js';
8
+ export { AuditLogService, } from './audit-log.js';
9
+ export { requireRole, requireActionCategory, isRoleAllowed, categorizeAction, PERMISSION_MATRIX, } from './rbac.js';
10
+ export { getGoogleAuthUrl, exchangeGoogleCode, getGoogleProfile, getGithubAuthUrl, exchangeGithubCode, getGithubProfile, } from './oauth.js';
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/cloud/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,SAAS,EAA0D,MAAM,mBAAmB,CAAC;AACnH,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAmB,MAAM,UAAU,CAAC;AACnF,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,0BAA0B,EAAE,MAAM,gBAAgB,CAAC;AAC1F,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EACL,aAAa,EACb,WAAW,EACX,cAAc,GAKf,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,oBAAoB,EACpB,eAAe,EACf,mBAAmB,GAIpB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACL,eAAe,GAOhB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,WAAW,EACX,qBAAqB,EACrB,aAAa,EACb,gBAAgB,EAChB,iBAAiB,GAKlB,MAAM,WAAW,CAAC;AACnB,OAAO,EAIL,gBAAgB,EAChB,kBAAkB,EAClB,gBAAgB,EAChB,gBAAgB,EAChB,kBAAkB,EAClB,gBAAgB,GACjB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,34 @@
1
+ /**
2
+ * JWT utilities using Node.js built-in crypto (HMAC-SHA256).
3
+ * No external dependencies.
4
+ */
5
+ export interface JwtPayload {
6
+ sub: string;
7
+ email: string;
8
+ name: string | null;
9
+ orgs: Array<{
10
+ org_id: string;
11
+ role: string;
12
+ }>;
13
+ iat: number;
14
+ exp: number;
15
+ }
16
+ /**
17
+ * Sign a JWT payload. Returns a compact JWT string.
18
+ */
19
+ export declare function signJwt(payload: Omit<JwtPayload, 'iat' | 'exp'>, secret: string, expiresInSeconds?: number): string;
20
+ /**
21
+ * Verify and decode a JWT. Returns null if invalid or expired.
22
+ */
23
+ export declare function verifyJwt(token: string, secret: string): JwtPayload | null;
24
+ /**
25
+ * Cookie options for JWT storage.
26
+ */
27
+ export declare const JWT_COOKIE_OPTIONS: {
28
+ httpOnly: boolean;
29
+ secure: boolean;
30
+ sameSite: "Strict";
31
+ path: string;
32
+ maxAge: number;
33
+ };
34
+ //# sourceMappingURL=jwt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jwt.d.ts","sourceRoot":"","sources":["../../../src/cloud/auth/jwt.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,MAAM,WAAW,UAAU;IACzB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,IAAI,EAAE,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC9C,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;CACb;AAaD;;GAEG;AACH,wBAAgB,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,GAAG,KAAK,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,SAAgB,GAAG,MAAM,CAe1H;AAED;;GAEG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,CAwB1E;AAED;;GAEG;AACH,eAAO,MAAM,kBAAkB;;;;;;CAM9B,CAAC"}