@plumbus/core 0.1.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 (854) hide show
  1. package/bin/plumbus.js +11 -0
  2. package/dist/.tsbuildinfo +1 -0
  3. package/dist/ai/__tests__/ai-service.test.d.ts +2 -0
  4. package/dist/ai/__tests__/ai-service.test.d.ts.map +1 -0
  5. package/dist/ai/__tests__/ai-service.test.js +347 -0
  6. package/dist/ai/__tests__/ai-service.test.js.map +1 -0
  7. package/dist/ai/__tests__/chunking.test.d.ts +2 -0
  8. package/dist/ai/__tests__/chunking.test.d.ts.map +1 -0
  9. package/dist/ai/__tests__/chunking.test.js +44 -0
  10. package/dist/ai/__tests__/chunking.test.js.map +1 -0
  11. package/dist/ai/__tests__/cost-tracker.test.d.ts +2 -0
  12. package/dist/ai/__tests__/cost-tracker.test.d.ts.map +1 -0
  13. package/dist/ai/__tests__/cost-tracker.test.js +201 -0
  14. package/dist/ai/__tests__/cost-tracker.test.js.map +1 -0
  15. package/dist/ai/__tests__/explainability.test.d.ts +2 -0
  16. package/dist/ai/__tests__/explainability.test.d.ts.map +1 -0
  17. package/dist/ai/__tests__/explainability.test.js +100 -0
  18. package/dist/ai/__tests__/explainability.test.js.map +1 -0
  19. package/dist/ai/__tests__/prompt-registry.test.d.ts +2 -0
  20. package/dist/ai/__tests__/prompt-registry.test.d.ts.map +1 -0
  21. package/dist/ai/__tests__/prompt-registry.test.js +56 -0
  22. package/dist/ai/__tests__/prompt-registry.test.js.map +1 -0
  23. package/dist/ai/__tests__/provider.test.d.ts +3 -0
  24. package/dist/ai/__tests__/provider.test.d.ts.map +1 -0
  25. package/dist/ai/__tests__/provider.test.js +151 -0
  26. package/dist/ai/__tests__/provider.test.js.map +1 -0
  27. package/dist/ai/__tests__/rag-pipeline.test.d.ts +2 -0
  28. package/dist/ai/__tests__/rag-pipeline.test.d.ts.map +1 -0
  29. package/dist/ai/__tests__/rag-pipeline.test.js +128 -0
  30. package/dist/ai/__tests__/rag-pipeline.test.js.map +1 -0
  31. package/dist/ai/__tests__/security.test.d.ts +2 -0
  32. package/dist/ai/__tests__/security.test.d.ts.map +1 -0
  33. package/dist/ai/__tests__/security.test.js +89 -0
  34. package/dist/ai/__tests__/security.test.js.map +1 -0
  35. package/dist/ai/__tests__/usage-client.test.d.ts +2 -0
  36. package/dist/ai/__tests__/usage-client.test.d.ts.map +1 -0
  37. package/dist/ai/__tests__/usage-client.test.js +120 -0
  38. package/dist/ai/__tests__/usage-client.test.js.map +1 -0
  39. package/dist/ai/__tests__/validation.test.d.ts +2 -0
  40. package/dist/ai/__tests__/validation.test.d.ts.map +1 -0
  41. package/dist/ai/__tests__/validation.test.js +114 -0
  42. package/dist/ai/__tests__/validation.test.js.map +1 -0
  43. package/dist/ai/ai-service.d.ts +36 -0
  44. package/dist/ai/ai-service.d.ts.map +1 -0
  45. package/dist/ai/ai-service.js +258 -0
  46. package/dist/ai/ai-service.js.map +1 -0
  47. package/dist/ai/cost-tracker.d.ts +53 -0
  48. package/dist/ai/cost-tracker.d.ts.map +1 -0
  49. package/dist/ai/cost-tracker.js +114 -0
  50. package/dist/ai/cost-tracker.js.map +1 -0
  51. package/dist/ai/explainability.d.ts +41 -0
  52. package/dist/ai/explainability.d.ts.map +1 -0
  53. package/dist/ai/explainability.js +38 -0
  54. package/dist/ai/explainability.js.map +1 -0
  55. package/dist/ai/index.d.ts +10 -0
  56. package/dist/ai/index.d.ts.map +1 -0
  57. package/dist/ai/index.js +25 -0
  58. package/dist/ai/index.js.map +1 -0
  59. package/dist/ai/prompt-registry.d.ts +16 -0
  60. package/dist/ai/prompt-registry.d.ts.map +1 -0
  61. package/dist/ai/prompt-registry.js +69 -0
  62. package/dist/ai/prompt-registry.js.map +1 -0
  63. package/dist/ai/provider.d.ts +73 -0
  64. package/dist/ai/provider.d.ts.map +1 -0
  65. package/dist/ai/provider.js +322 -0
  66. package/dist/ai/provider.js.map +1 -0
  67. package/dist/ai/rag/chunking.d.ts +18 -0
  68. package/dist/ai/rag/chunking.d.ts.map +1 -0
  69. package/dist/ai/rag/chunking.js +58 -0
  70. package/dist/ai/rag/chunking.js.map +1 -0
  71. package/dist/ai/rag/index.d.ts +4 -0
  72. package/dist/ai/rag/index.d.ts.map +1 -0
  73. package/dist/ai/rag/index.js +5 -0
  74. package/dist/ai/rag/index.js.map +1 -0
  75. package/dist/ai/rag/pipeline.d.ts +69 -0
  76. package/dist/ai/rag/pipeline.d.ts.map +1 -0
  77. package/dist/ai/rag/pipeline.js +135 -0
  78. package/dist/ai/rag/pipeline.js.map +1 -0
  79. package/dist/ai/rag/schema.d.ts +320 -0
  80. package/dist/ai/rag/schema.d.ts.map +1 -0
  81. package/dist/ai/rag/schema.js +31 -0
  82. package/dist/ai/rag/schema.js.map +1 -0
  83. package/dist/ai/security.d.ts +28 -0
  84. package/dist/ai/security.d.ts.map +1 -0
  85. package/dist/ai/security.js +78 -0
  86. package/dist/ai/security.js.map +1 -0
  87. package/dist/ai/usage-client.d.ts +31 -0
  88. package/dist/ai/usage-client.d.ts.map +1 -0
  89. package/dist/ai/usage-client.js +106 -0
  90. package/dist/ai/usage-client.js.map +1 -0
  91. package/dist/ai/validation.d.ts +20 -0
  92. package/dist/ai/validation.d.ts.map +1 -0
  93. package/dist/ai/validation.js +39 -0
  94. package/dist/ai/validation.js.map +1 -0
  95. package/dist/api/__tests__/route-generator.test.d.ts +2 -0
  96. package/dist/api/__tests__/route-generator.test.d.ts.map +1 -0
  97. package/dist/api/__tests__/route-generator.test.js +101 -0
  98. package/dist/api/__tests__/route-generator.test.js.map +1 -0
  99. package/dist/api/index.d.ts +3 -0
  100. package/dist/api/index.d.ts.map +1 -0
  101. package/dist/api/index.js +7 -0
  102. package/dist/api/index.js.map +1 -0
  103. package/dist/api/route-generator.d.ts +24 -0
  104. package/dist/api/route-generator.d.ts.map +1 -0
  105. package/dist/api/route-generator.js +77 -0
  106. package/dist/api/route-generator.js.map +1 -0
  107. package/dist/audit/__tests__/service.test.d.ts +2 -0
  108. package/dist/audit/__tests__/service.test.d.ts.map +1 -0
  109. package/dist/audit/__tests__/service.test.js +97 -0
  110. package/dist/audit/__tests__/service.test.js.map +1 -0
  111. package/dist/audit/index.d.ts +4 -0
  112. package/dist/audit/index.d.ts.map +1 -0
  113. package/dist/audit/index.js +8 -0
  114. package/dist/audit/index.js.map +1 -0
  115. package/dist/audit/schema.d.ts +164 -0
  116. package/dist/audit/schema.d.ts.map +1 -0
  117. package/dist/audit/schema.js +16 -0
  118. package/dist/audit/schema.js.map +1 -0
  119. package/dist/audit/service.d.ts +14 -0
  120. package/dist/audit/service.d.ts.map +1 -0
  121. package/dist/audit/service.js +28 -0
  122. package/dist/audit/service.js.map +1 -0
  123. package/dist/auth/__tests__/adapter.test.d.ts +2 -0
  124. package/dist/auth/__tests__/adapter.test.d.ts.map +1 -0
  125. package/dist/auth/__tests__/adapter.test.js +218 -0
  126. package/dist/auth/__tests__/adapter.test.js.map +1 -0
  127. package/dist/auth/__tests__/oidc-adapter.test.d.ts +2 -0
  128. package/dist/auth/__tests__/oidc-adapter.test.d.ts.map +1 -0
  129. package/dist/auth/__tests__/oidc-adapter.test.js +232 -0
  130. package/dist/auth/__tests__/oidc-adapter.test.js.map +1 -0
  131. package/dist/auth/__tests__/password.test.d.ts +2 -0
  132. package/dist/auth/__tests__/password.test.d.ts.map +1 -0
  133. package/dist/auth/__tests__/password.test.js +30 -0
  134. package/dist/auth/__tests__/password.test.js.map +1 -0
  135. package/dist/auth/__tests__/saml-adapter.test.d.ts +2 -0
  136. package/dist/auth/__tests__/saml-adapter.test.d.ts.map +1 -0
  137. package/dist/auth/__tests__/saml-adapter.test.js +188 -0
  138. package/dist/auth/__tests__/saml-adapter.test.js.map +1 -0
  139. package/dist/auth/__tests__/scim.test.d.ts +2 -0
  140. package/dist/auth/__tests__/scim.test.d.ts.map +1 -0
  141. package/dist/auth/__tests__/scim.test.js +306 -0
  142. package/dist/auth/__tests__/scim.test.js.map +1 -0
  143. package/dist/auth/adapter.d.ts +60 -0
  144. package/dist/auth/adapter.d.ts.map +1 -0
  145. package/dist/auth/adapter.js +144 -0
  146. package/dist/auth/adapter.js.map +1 -0
  147. package/dist/auth/index.d.ts +11 -0
  148. package/dist/auth/index.d.ts.map +1 -0
  149. package/dist/auth/index.js +9 -0
  150. package/dist/auth/index.js.map +1 -0
  151. package/dist/auth/oidc-adapter.d.ts +32 -0
  152. package/dist/auth/oidc-adapter.d.ts.map +1 -0
  153. package/dist/auth/oidc-adapter.js +169 -0
  154. package/dist/auth/oidc-adapter.js.map +1 -0
  155. package/dist/auth/password.d.ts +13 -0
  156. package/dist/auth/password.d.ts.map +1 -0
  157. package/dist/auth/password.js +33 -0
  158. package/dist/auth/password.js.map +1 -0
  159. package/dist/auth/saml-adapter.d.ts +38 -0
  160. package/dist/auth/saml-adapter.d.ts.map +1 -0
  161. package/dist/auth/saml-adapter.js +209 -0
  162. package/dist/auth/saml-adapter.js.map +1 -0
  163. package/dist/auth/scim.d.ts +134 -0
  164. package/dist/auth/scim.d.ts.map +1 -0
  165. package/dist/auth/scim.js +207 -0
  166. package/dist/auth/scim.js.map +1 -0
  167. package/dist/cli/__tests__/agent.test.d.ts +2 -0
  168. package/dist/cli/__tests__/agent.test.d.ts.map +1 -0
  169. package/dist/cli/__tests__/agent.test.js +63 -0
  170. package/dist/cli/__tests__/agent.test.js.map +1 -0
  171. package/dist/cli/__tests__/certify.test.d.ts +2 -0
  172. package/dist/cli/__tests__/certify.test.d.ts.map +1 -0
  173. package/dist/cli/__tests__/certify.test.js +97 -0
  174. package/dist/cli/__tests__/certify.test.js.map +1 -0
  175. package/dist/cli/__tests__/cli.test.d.ts +2 -0
  176. package/dist/cli/__tests__/cli.test.d.ts.map +1 -0
  177. package/dist/cli/__tests__/cli.test.js +30 -0
  178. package/dist/cli/__tests__/cli.test.js.map +1 -0
  179. package/dist/cli/__tests__/create.test.d.ts +2 -0
  180. package/dist/cli/__tests__/create.test.d.ts.map +1 -0
  181. package/dist/cli/__tests__/create.test.js +46 -0
  182. package/dist/cli/__tests__/create.test.js.map +1 -0
  183. package/dist/cli/__tests__/dev.test.d.ts +2 -0
  184. package/dist/cli/__tests__/dev.test.d.ts.map +1 -0
  185. package/dist/cli/__tests__/dev.test.js +132 -0
  186. package/dist/cli/__tests__/dev.test.js.map +1 -0
  187. package/dist/cli/__tests__/discover.test.d.ts +2 -0
  188. package/dist/cli/__tests__/discover.test.d.ts.map +1 -0
  189. package/dist/cli/__tests__/discover.test.js +48 -0
  190. package/dist/cli/__tests__/discover.test.js.map +1 -0
  191. package/dist/cli/__tests__/doctor.test.d.ts +2 -0
  192. package/dist/cli/__tests__/doctor.test.d.ts.map +1 -0
  193. package/dist/cli/__tests__/doctor.test.js +56 -0
  194. package/dist/cli/__tests__/doctor.test.js.map +1 -0
  195. package/dist/cli/__tests__/generate.test.d.ts +2 -0
  196. package/dist/cli/__tests__/generate.test.d.ts.map +1 -0
  197. package/dist/cli/__tests__/generate.test.js +68 -0
  198. package/dist/cli/__tests__/generate.test.js.map +1 -0
  199. package/dist/cli/__tests__/init.test.d.ts +2 -0
  200. package/dist/cli/__tests__/init.test.d.ts.map +1 -0
  201. package/dist/cli/__tests__/init.test.js +75 -0
  202. package/dist/cli/__tests__/init.test.js.map +1 -0
  203. package/dist/cli/__tests__/migrate.test.d.ts +2 -0
  204. package/dist/cli/__tests__/migrate.test.d.ts.map +1 -0
  205. package/dist/cli/__tests__/migrate.test.js +285 -0
  206. package/dist/cli/__tests__/migrate.test.js.map +1 -0
  207. package/dist/cli/__tests__/templates.test.d.ts +2 -0
  208. package/dist/cli/__tests__/templates.test.d.ts.map +1 -0
  209. package/dist/cli/__tests__/templates.test.js +49 -0
  210. package/dist/cli/__tests__/templates.test.js.map +1 -0
  211. package/dist/cli/__tests__/test.test.d.ts +2 -0
  212. package/dist/cli/__tests__/test.test.d.ts.map +1 -0
  213. package/dist/cli/__tests__/test.test.js +40 -0
  214. package/dist/cli/__tests__/test.test.js.map +1 -0
  215. package/dist/cli/__tests__/ui.test.d.ts +2 -0
  216. package/dist/cli/__tests__/ui.test.d.ts.map +1 -0
  217. package/dist/cli/__tests__/ui.test.js +62 -0
  218. package/dist/cli/__tests__/ui.test.js.map +1 -0
  219. package/dist/cli/__tests__/utils.test.d.ts +2 -0
  220. package/dist/cli/__tests__/utils.test.d.ts.map +1 -0
  221. package/dist/cli/__tests__/utils.test.js +30 -0
  222. package/dist/cli/__tests__/utils.test.js.map +1 -0
  223. package/dist/cli/__tests__/verify.test.d.ts +2 -0
  224. package/dist/cli/__tests__/verify.test.d.ts.map +1 -0
  225. package/dist/cli/__tests__/verify.test.js +138 -0
  226. package/dist/cli/__tests__/verify.test.js.map +1 -0
  227. package/dist/cli/cli.d.ts +3 -0
  228. package/dist/cli/cli.d.ts.map +1 -0
  229. package/dist/cli/cli.js +33 -0
  230. package/dist/cli/cli.js.map +1 -0
  231. package/dist/cli/commands/__tests__/commands.test.d.ts +2 -0
  232. package/dist/cli/commands/__tests__/commands.test.d.ts.map +1 -0
  233. package/dist/cli/commands/__tests__/commands.test.js +180 -0
  234. package/dist/cli/commands/__tests__/commands.test.js.map +1 -0
  235. package/dist/cli/commands/agent.d.ts +17 -0
  236. package/dist/cli/commands/agent.d.ts.map +1 -0
  237. package/dist/cli/commands/agent.js +154 -0
  238. package/dist/cli/commands/agent.js.map +1 -0
  239. package/dist/cli/commands/capability.d.ts +7 -0
  240. package/dist/cli/commands/capability.d.ts.map +1 -0
  241. package/dist/cli/commands/capability.js +27 -0
  242. package/dist/cli/commands/capability.js.map +1 -0
  243. package/dist/cli/commands/certify.d.ts +24 -0
  244. package/dist/cli/commands/certify.d.ts.map +1 -0
  245. package/dist/cli/commands/certify.js +228 -0
  246. package/dist/cli/commands/certify.js.map +1 -0
  247. package/dist/cli/commands/create.d.ts +13 -0
  248. package/dist/cli/commands/create.d.ts.map +1 -0
  249. package/dist/cli/commands/create.js +190 -0
  250. package/dist/cli/commands/create.js.map +1 -0
  251. package/dist/cli/commands/dev.d.ts +36 -0
  252. package/dist/cli/commands/dev.d.ts.map +1 -0
  253. package/dist/cli/commands/dev.js +178 -0
  254. package/dist/cli/commands/dev.js.map +1 -0
  255. package/dist/cli/commands/doctor.d.ts +31 -0
  256. package/dist/cli/commands/doctor.d.ts.map +1 -0
  257. package/dist/cli/commands/doctor.js +233 -0
  258. package/dist/cli/commands/doctor.js.map +1 -0
  259. package/dist/cli/commands/e2e.d.ts +3 -0
  260. package/dist/cli/commands/e2e.d.ts.map +1 -0
  261. package/dist/cli/commands/e2e.js +165 -0
  262. package/dist/cli/commands/e2e.js.map +1 -0
  263. package/dist/cli/commands/entity.d.ts +3 -0
  264. package/dist/cli/commands/entity.d.ts.map +1 -0
  265. package/dist/cli/commands/entity.js +21 -0
  266. package/dist/cli/commands/entity.js.map +1 -0
  267. package/dist/cli/commands/event.d.ts +3 -0
  268. package/dist/cli/commands/event.d.ts.map +1 -0
  269. package/dist/cli/commands/event.js +21 -0
  270. package/dist/cli/commands/event.js.map +1 -0
  271. package/dist/cli/commands/flow.d.ts +3 -0
  272. package/dist/cli/commands/flow.d.ts.map +1 -0
  273. package/dist/cli/commands/flow.js +25 -0
  274. package/dist/cli/commands/flow.js.map +1 -0
  275. package/dist/cli/commands/generate.d.ts +17 -0
  276. package/dist/cli/commands/generate.d.ts.map +1 -0
  277. package/dist/cli/commands/generate.js +175 -0
  278. package/dist/cli/commands/generate.js.map +1 -0
  279. package/dist/cli/commands/index.d.ts +20 -0
  280. package/dist/cli/commands/index.d.ts.map +1 -0
  281. package/dist/cli/commands/index.js +45 -0
  282. package/dist/cli/commands/index.js.map +1 -0
  283. package/dist/cli/commands/init.d.ts +20 -0
  284. package/dist/cli/commands/init.d.ts.map +1 -0
  285. package/dist/cli/commands/init.js +261 -0
  286. package/dist/cli/commands/init.js.map +1 -0
  287. package/dist/cli/commands/migrate.d.ts +7 -0
  288. package/dist/cli/commands/migrate.d.ts.map +1 -0
  289. package/dist/cli/commands/migrate.js +523 -0
  290. package/dist/cli/commands/migrate.js.map +1 -0
  291. package/dist/cli/commands/prompt.d.ts +3 -0
  292. package/dist/cli/commands/prompt.d.ts.map +1 -0
  293. package/dist/cli/commands/prompt.js +21 -0
  294. package/dist/cli/commands/prompt.js.map +1 -0
  295. package/dist/cli/commands/rag.d.ts +13 -0
  296. package/dist/cli/commands/rag.d.ts.map +1 -0
  297. package/dist/cli/commands/rag.js +100 -0
  298. package/dist/cli/commands/rag.js.map +1 -0
  299. package/dist/cli/commands/seed.d.ts +19 -0
  300. package/dist/cli/commands/seed.d.ts.map +1 -0
  301. package/dist/cli/commands/seed.js +183 -0
  302. package/dist/cli/commands/seed.js.map +1 -0
  303. package/dist/cli/commands/test.d.ts +17 -0
  304. package/dist/cli/commands/test.d.ts.map +1 -0
  305. package/dist/cli/commands/test.js +128 -0
  306. package/dist/cli/commands/test.js.map +1 -0
  307. package/dist/cli/commands/ui.d.ts +53 -0
  308. package/dist/cli/commands/ui.d.ts.map +1 -0
  309. package/dist/cli/commands/ui.js +291 -0
  310. package/dist/cli/commands/ui.js.map +1 -0
  311. package/dist/cli/commands/verify.d.ts +21 -0
  312. package/dist/cli/commands/verify.d.ts.map +1 -0
  313. package/dist/cli/commands/verify.js +153 -0
  314. package/dist/cli/commands/verify.js.map +1 -0
  315. package/dist/cli/discover.d.ts +26 -0
  316. package/dist/cli/discover.d.ts.map +1 -0
  317. package/dist/cli/discover.js +127 -0
  318. package/dist/cli/discover.js.map +1 -0
  319. package/dist/cli/index.d.ts +12 -0
  320. package/dist/cli/index.d.ts.map +1 -0
  321. package/dist/cli/index.js +21 -0
  322. package/dist/cli/index.js.map +1 -0
  323. package/dist/cli/templates/resources.d.ts +8 -0
  324. package/dist/cli/templates/resources.d.ts.map +1 -0
  325. package/dist/cli/templates/resources.js +157 -0
  326. package/dist/cli/templates/resources.js.map +1 -0
  327. package/dist/cli/utils.d.ts +27 -0
  328. package/dist/cli/utils.d.ts.map +1 -0
  329. package/dist/cli/utils.js +69 -0
  330. package/dist/cli/utils.js.map +1 -0
  331. package/dist/config/__tests__/loader.test.d.ts +2 -0
  332. package/dist/config/__tests__/loader.test.d.ts.map +1 -0
  333. package/dist/config/__tests__/loader.test.js +462 -0
  334. package/dist/config/__tests__/loader.test.js.map +1 -0
  335. package/dist/config/index.d.ts +3 -0
  336. package/dist/config/index.d.ts.map +1 -0
  337. package/dist/config/index.js +7 -0
  338. package/dist/config/index.js.map +1 -0
  339. package/dist/config/loader.d.ts +21 -0
  340. package/dist/config/loader.d.ts.map +1 -0
  341. package/dist/config/loader.js +190 -0
  342. package/dist/config/loader.js.map +1 -0
  343. package/dist/data/__tests__/registry.test.d.ts +2 -0
  344. package/dist/data/__tests__/registry.test.d.ts.map +1 -0
  345. package/dist/data/__tests__/registry.test.js +55 -0
  346. package/dist/data/__tests__/registry.test.js.map +1 -0
  347. package/dist/data/__tests__/repository.test.d.ts +2 -0
  348. package/dist/data/__tests__/repository.test.d.ts.map +1 -0
  349. package/dist/data/__tests__/repository.test.js +197 -0
  350. package/dist/data/__tests__/repository.test.js.map +1 -0
  351. package/dist/data/__tests__/schema-generator.test.d.ts +2 -0
  352. package/dist/data/__tests__/schema-generator.test.d.ts.map +1 -0
  353. package/dist/data/__tests__/schema-generator.test.js +112 -0
  354. package/dist/data/__tests__/schema-generator.test.js.map +1 -0
  355. package/dist/data/index.d.ts +5 -0
  356. package/dist/data/index.d.ts.map +1 -0
  357. package/dist/data/index.js +10 -0
  358. package/dist/data/index.js.map +1 -0
  359. package/dist/data/migration.d.ts +35 -0
  360. package/dist/data/migration.d.ts.map +1 -0
  361. package/dist/data/migration.js +55 -0
  362. package/dist/data/migration.js.map +1 -0
  363. package/dist/data/registry.d.ts +49 -0
  364. package/dist/data/registry.d.ts.map +1 -0
  365. package/dist/data/registry.js +74 -0
  366. package/dist/data/registry.js.map +1 -0
  367. package/dist/data/repository.d.ts +22 -0
  368. package/dist/data/repository.d.ts.map +1 -0
  369. package/dist/data/repository.js +170 -0
  370. package/dist/data/repository.js.map +1 -0
  371. package/dist/data/schema-generator.d.ts +12 -0
  372. package/dist/data/schema-generator.d.ts.map +1 -0
  373. package/dist/data/schema-generator.js +123 -0
  374. package/dist/data/schema-generator.js.map +1 -0
  375. package/dist/define/__tests__/defineCapability.test.d.ts +2 -0
  376. package/dist/define/__tests__/defineCapability.test.d.ts.map +1 -0
  377. package/dist/define/__tests__/defineCapability.test.js +66 -0
  378. package/dist/define/__tests__/defineCapability.test.js.map +1 -0
  379. package/dist/define/__tests__/defineEntity.test.d.ts +2 -0
  380. package/dist/define/__tests__/defineEntity.test.d.ts.map +1 -0
  381. package/dist/define/__tests__/defineEntity.test.js +50 -0
  382. package/dist/define/__tests__/defineEntity.test.js.map +1 -0
  383. package/dist/define/__tests__/defineEvent.test.d.ts +2 -0
  384. package/dist/define/__tests__/defineEvent.test.d.ts.map +1 -0
  385. package/dist/define/__tests__/defineEvent.test.js +35 -0
  386. package/dist/define/__tests__/defineEvent.test.js.map +1 -0
  387. package/dist/define/__tests__/defineFlow.test.d.ts +2 -0
  388. package/dist/define/__tests__/defineFlow.test.d.ts.map +1 -0
  389. package/dist/define/__tests__/defineFlow.test.js +49 -0
  390. package/dist/define/__tests__/defineFlow.test.js.map +1 -0
  391. package/dist/define/__tests__/definePrompt.test.d.ts +2 -0
  392. package/dist/define/__tests__/definePrompt.test.d.ts.map +1 -0
  393. package/dist/define/__tests__/definePrompt.test.js +40 -0
  394. package/dist/define/__tests__/definePrompt.test.js.map +1 -0
  395. package/dist/define/defineCapability.d.ts +38 -0
  396. package/dist/define/defineCapability.d.ts.map +1 -0
  397. package/dist/define/defineCapability.js +33 -0
  398. package/dist/define/defineCapability.js.map +1 -0
  399. package/dist/define/defineEntity.d.ts +16 -0
  400. package/dist/define/defineEntity.d.ts.map +1 -0
  401. package/dist/define/defineEntity.js +21 -0
  402. package/dist/define/defineEntity.js.map +1 -0
  403. package/dist/define/defineEvent.d.ts +13 -0
  404. package/dist/define/defineEvent.d.ts.map +1 -0
  405. package/dist/define/defineEvent.js +17 -0
  406. package/dist/define/defineEvent.js.map +1 -0
  407. package/dist/define/defineFlow.d.ts +17 -0
  408. package/dist/define/defineFlow.d.ts.map +1 -0
  409. package/dist/define/defineFlow.js +23 -0
  410. package/dist/define/defineFlow.js.map +1 -0
  411. package/dist/define/definePrompt.d.ts +15 -0
  412. package/dist/define/definePrompt.d.ts.map +1 -0
  413. package/dist/define/definePrompt.js +20 -0
  414. package/dist/define/definePrompt.js.map +1 -0
  415. package/dist/define/index.d.ts +6 -0
  416. package/dist/define/index.d.ts.map +1 -0
  417. package/dist/define/index.js +10 -0
  418. package/dist/define/index.js.map +1 -0
  419. package/dist/errors/__tests__/errors.test.d.ts +2 -0
  420. package/dist/errors/__tests__/errors.test.d.ts.map +1 -0
  421. package/dist/errors/__tests__/errors.test.js +42 -0
  422. package/dist/errors/__tests__/errors.test.js.map +1 -0
  423. package/dist/errors/__tests__/http.test.d.ts +2 -0
  424. package/dist/errors/__tests__/http.test.d.ts.map +1 -0
  425. package/dist/errors/__tests__/http.test.js +32 -0
  426. package/dist/errors/__tests__/http.test.js.map +1 -0
  427. package/dist/errors/http.d.ts +13 -0
  428. package/dist/errors/http.d.ts.map +1 -0
  429. package/dist/errors/http.js +26 -0
  430. package/dist/errors/http.js.map +1 -0
  431. package/dist/errors/index.d.ts +4 -0
  432. package/dist/errors/index.d.ts.map +1 -0
  433. package/dist/errors/index.js +22 -0
  434. package/dist/errors/index.js.map +1 -0
  435. package/dist/events/__tests__/consumer-registry.test.d.ts +2 -0
  436. package/dist/events/__tests__/consumer-registry.test.d.ts.map +1 -0
  437. package/dist/events/__tests__/consumer-registry.test.js +68 -0
  438. package/dist/events/__tests__/consumer-registry.test.js.map +1 -0
  439. package/dist/events/__tests__/dispatcher.test.d.ts +2 -0
  440. package/dist/events/__tests__/dispatcher.test.d.ts.map +1 -0
  441. package/dist/events/__tests__/dispatcher.test.js +168 -0
  442. package/dist/events/__tests__/dispatcher.test.js.map +1 -0
  443. package/dist/events/__tests__/event-emitter.test.d.ts +2 -0
  444. package/dist/events/__tests__/event-emitter.test.d.ts.map +1 -0
  445. package/dist/events/__tests__/event-emitter.test.js +100 -0
  446. package/dist/events/__tests__/event-emitter.test.js.map +1 -0
  447. package/dist/events/__tests__/event-registry.test.d.ts +2 -0
  448. package/dist/events/__tests__/event-registry.test.d.ts.map +1 -0
  449. package/dist/events/__tests__/event-registry.test.js +55 -0
  450. package/dist/events/__tests__/event-registry.test.js.map +1 -0
  451. package/dist/events/__tests__/event-worker.test.d.ts +2 -0
  452. package/dist/events/__tests__/event-worker.test.d.ts.map +1 -0
  453. package/dist/events/__tests__/event-worker.test.js +174 -0
  454. package/dist/events/__tests__/event-worker.test.js.map +1 -0
  455. package/dist/events/__tests__/queue.test.d.ts +2 -0
  456. package/dist/events/__tests__/queue.test.d.ts.map +1 -0
  457. package/dist/events/__tests__/queue.test.js +73 -0
  458. package/dist/events/__tests__/queue.test.js.map +1 -0
  459. package/dist/events/consumer-registry.d.ts +47 -0
  460. package/dist/events/consumer-registry.d.ts.map +1 -0
  461. package/dist/events/consumer-registry.js +79 -0
  462. package/dist/events/consumer-registry.js.map +1 -0
  463. package/dist/events/dispatcher.d.ts +31 -0
  464. package/dist/events/dispatcher.d.ts.map +1 -0
  465. package/dist/events/dispatcher.js +149 -0
  466. package/dist/events/dispatcher.js.map +1 -0
  467. package/dist/events/emitter.d.ts +22 -0
  468. package/dist/events/emitter.d.ts.map +1 -0
  469. package/dist/events/emitter.js +58 -0
  470. package/dist/events/emitter.js.map +1 -0
  471. package/dist/events/idempotency.d.ts +13 -0
  472. package/dist/events/idempotency.d.ts.map +1 -0
  473. package/dist/events/idempotency.js +25 -0
  474. package/dist/events/idempotency.js.map +1 -0
  475. package/dist/events/index.d.ts +15 -0
  476. package/dist/events/index.d.ts.map +1 -0
  477. package/dist/events/index.js +23 -0
  478. package/dist/events/index.js.map +1 -0
  479. package/dist/events/outbox.d.ts +475 -0
  480. package/dist/events/outbox.d.ts.map +1 -0
  481. package/dist/events/outbox.js +48 -0
  482. package/dist/events/outbox.js.map +1 -0
  483. package/dist/events/queue.d.ts +58 -0
  484. package/dist/events/queue.d.ts.map +1 -0
  485. package/dist/events/queue.js +135 -0
  486. package/dist/events/queue.js.map +1 -0
  487. package/dist/events/registry.d.ts +36 -0
  488. package/dist/events/registry.d.ts.map +1 -0
  489. package/dist/events/registry.js +59 -0
  490. package/dist/events/registry.js.map +1 -0
  491. package/dist/events/worker.d.ts +34 -0
  492. package/dist/events/worker.d.ts.map +1 -0
  493. package/dist/events/worker.js +88 -0
  494. package/dist/events/worker.js.map +1 -0
  495. package/dist/execution/__tests__/authorization.test.d.ts +2 -0
  496. package/dist/execution/__tests__/authorization.test.d.ts.map +1 -0
  497. package/dist/execution/__tests__/authorization.test.js +88 -0
  498. package/dist/execution/__tests__/authorization.test.js.map +1 -0
  499. package/dist/execution/__tests__/capability-executor.test.d.ts +2 -0
  500. package/dist/execution/__tests__/capability-executor.test.d.ts.map +1 -0
  501. package/dist/execution/__tests__/capability-executor.test.js +184 -0
  502. package/dist/execution/__tests__/capability-executor.test.js.map +1 -0
  503. package/dist/execution/__tests__/capability-registry.test.d.ts +2 -0
  504. package/dist/execution/__tests__/capability-registry.test.d.ts.map +1 -0
  505. package/dist/execution/__tests__/capability-registry.test.js +50 -0
  506. package/dist/execution/__tests__/capability-registry.test.js.map +1 -0
  507. package/dist/execution/__tests__/context-factory.test.d.ts +2 -0
  508. package/dist/execution/__tests__/context-factory.test.d.ts.map +1 -0
  509. package/dist/execution/__tests__/context-factory.test.js +116 -0
  510. package/dist/execution/__tests__/context-factory.test.js.map +1 -0
  511. package/dist/execution/authorization.d.ts +11 -0
  512. package/dist/execution/authorization.d.ts.map +1 -0
  513. package/dist/execution/authorization.js +50 -0
  514. package/dist/execution/authorization.js.map +1 -0
  515. package/dist/execution/capability-executor.d.ts +23 -0
  516. package/dist/execution/capability-executor.d.ts.map +1 -0
  517. package/dist/execution/capability-executor.js +91 -0
  518. package/dist/execution/capability-executor.js.map +1 -0
  519. package/dist/execution/capability-registry.d.ts +33 -0
  520. package/dist/execution/capability-registry.d.ts.map +1 -0
  521. package/dist/execution/capability-registry.js +49 -0
  522. package/dist/execution/capability-registry.js.map +1 -0
  523. package/dist/execution/context-factory.d.ts +20 -0
  524. package/dist/execution/context-factory.d.ts.map +1 -0
  525. package/dist/execution/context-factory.js +98 -0
  526. package/dist/execution/context-factory.js.map +1 -0
  527. package/dist/execution/index.d.ts +8 -0
  528. package/dist/execution/index.d.ts.map +1 -0
  529. package/dist/execution/index.js +10 -0
  530. package/dist/execution/index.js.map +1 -0
  531. package/dist/explanation/__tests__/tracker.test.d.ts +2 -0
  532. package/dist/explanation/__tests__/tracker.test.d.ts.map +1 -0
  533. package/dist/explanation/__tests__/tracker.test.js +169 -0
  534. package/dist/explanation/__tests__/tracker.test.js.map +1 -0
  535. package/dist/explanation/index.d.ts +3 -0
  536. package/dist/explanation/index.d.ts.map +1 -0
  537. package/dist/explanation/index.js +7 -0
  538. package/dist/explanation/index.js.map +1 -0
  539. package/dist/explanation/tracker.d.ts +81 -0
  540. package/dist/explanation/tracker.d.ts.map +1 -0
  541. package/dist/explanation/tracker.js +100 -0
  542. package/dist/explanation/tracker.js.map +1 -0
  543. package/dist/fields/__tests__/fields.test.d.ts +2 -0
  544. package/dist/fields/__tests__/fields.test.d.ts.map +1 -0
  545. package/dist/fields/__tests__/fields.test.js +60 -0
  546. package/dist/fields/__tests__/fields.test.js.map +1 -0
  547. package/dist/fields/index.d.ts +18 -0
  548. package/dist/fields/index.d.ts.map +1 -0
  549. package/dist/fields/index.js +51 -0
  550. package/dist/fields/index.js.map +1 -0
  551. package/dist/flows/__tests__/flow-engine.test.d.ts +2 -0
  552. package/dist/flows/__tests__/flow-engine.test.d.ts.map +1 -0
  553. package/dist/flows/__tests__/flow-engine.test.js +189 -0
  554. package/dist/flows/__tests__/flow-engine.test.js.map +1 -0
  555. package/dist/flows/__tests__/flow-registry.test.d.ts +2 -0
  556. package/dist/flows/__tests__/flow-registry.test.d.ts.map +1 -0
  557. package/dist/flows/__tests__/flow-registry.test.js +69 -0
  558. package/dist/flows/__tests__/flow-registry.test.js.map +1 -0
  559. package/dist/flows/__tests__/flow-service.test.d.ts +2 -0
  560. package/dist/flows/__tests__/flow-service.test.d.ts.map +1 -0
  561. package/dist/flows/__tests__/flow-service.test.js +47 -0
  562. package/dist/flows/__tests__/flow-service.test.js.map +1 -0
  563. package/dist/flows/__tests__/scheduler.test.d.ts +2 -0
  564. package/dist/flows/__tests__/scheduler.test.d.ts.map +1 -0
  565. package/dist/flows/__tests__/scheduler.test.js +120 -0
  566. package/dist/flows/__tests__/scheduler.test.js.map +1 -0
  567. package/dist/flows/__tests__/state-machine.test.d.ts +2 -0
  568. package/dist/flows/__tests__/state-machine.test.d.ts.map +1 -0
  569. package/dist/flows/__tests__/state-machine.test.js +62 -0
  570. package/dist/flows/__tests__/state-machine.test.js.map +1 -0
  571. package/dist/flows/__tests__/step-executor.test.d.ts +2 -0
  572. package/dist/flows/__tests__/step-executor.test.d.ts.map +1 -0
  573. package/dist/flows/__tests__/step-executor.test.js +139 -0
  574. package/dist/flows/__tests__/step-executor.test.js.map +1 -0
  575. package/dist/flows/__tests__/triggers.test.d.ts +2 -0
  576. package/dist/flows/__tests__/triggers.test.d.ts.map +1 -0
  577. package/dist/flows/__tests__/triggers.test.js +98 -0
  578. package/dist/flows/__tests__/triggers.test.js.map +1 -0
  579. package/dist/flows/dead-letter.d.ts +12 -0
  580. package/dist/flows/dead-letter.d.ts.map +1 -0
  581. package/dist/flows/dead-letter.js +63 -0
  582. package/dist/flows/dead-letter.js.map +1 -0
  583. package/dist/flows/engine.d.ts +35 -0
  584. package/dist/flows/engine.d.ts.map +1 -0
  585. package/dist/flows/engine.js +402 -0
  586. package/dist/flows/engine.js.map +1 -0
  587. package/dist/flows/flow-service.d.ts +10 -0
  588. package/dist/flows/flow-service.d.ts.map +1 -0
  589. package/dist/flows/flow-service.js +22 -0
  590. package/dist/flows/flow-service.js.map +1 -0
  591. package/dist/flows/index.d.ts +14 -0
  592. package/dist/flows/index.d.ts.map +1 -0
  593. package/dist/flows/index.js +25 -0
  594. package/dist/flows/index.js.map +1 -0
  595. package/dist/flows/registry.d.ts +47 -0
  596. package/dist/flows/registry.d.ts.map +1 -0
  597. package/dist/flows/registry.js +108 -0
  598. package/dist/flows/registry.js.map +1 -0
  599. package/dist/flows/scheduler.d.ts +41 -0
  600. package/dist/flows/scheduler.d.ts.map +1 -0
  601. package/dist/flows/scheduler.js +242 -0
  602. package/dist/flows/scheduler.js.map +1 -0
  603. package/dist/flows/schema.d.ts +627 -0
  604. package/dist/flows/schema.d.ts.map +1 -0
  605. package/dist/flows/schema.js +60 -0
  606. package/dist/flows/schema.js.map +1 -0
  607. package/dist/flows/state-machine.d.ts +41 -0
  608. package/dist/flows/state-machine.d.ts.map +1 -0
  609. package/dist/flows/state-machine.js +56 -0
  610. package/dist/flows/state-machine.js.map +1 -0
  611. package/dist/flows/step-executor.d.ts +36 -0
  612. package/dist/flows/step-executor.d.ts.map +1 -0
  613. package/dist/flows/step-executor.js +109 -0
  614. package/dist/flows/step-executor.js.map +1 -0
  615. package/dist/flows/triggers.d.ts +15 -0
  616. package/dist/flows/triggers.d.ts.map +1 -0
  617. package/dist/flows/triggers.js +36 -0
  618. package/dist/flows/triggers.js.map +1 -0
  619. package/dist/governance/__tests__/overrides.test.d.ts +2 -0
  620. package/dist/governance/__tests__/overrides.test.d.ts.map +1 -0
  621. package/dist/governance/__tests__/overrides.test.js +123 -0
  622. package/dist/governance/__tests__/overrides.test.js.map +1 -0
  623. package/dist/governance/__tests__/policies.test.d.ts +2 -0
  624. package/dist/governance/__tests__/policies.test.d.ts.map +1 -0
  625. package/dist/governance/__tests__/policies.test.js +203 -0
  626. package/dist/governance/__tests__/policies.test.js.map +1 -0
  627. package/dist/governance/__tests__/rules.test.d.ts +2 -0
  628. package/dist/governance/__tests__/rules.test.d.ts.map +1 -0
  629. package/dist/governance/__tests__/rules.test.js +342 -0
  630. package/dist/governance/__tests__/rules.test.js.map +1 -0
  631. package/dist/governance/index.d.ts +10 -0
  632. package/dist/governance/index.d.ts.map +1 -0
  633. package/dist/governance/index.js +12 -0
  634. package/dist/governance/index.js.map +1 -0
  635. package/dist/governance/overrides.d.ts +24 -0
  636. package/dist/governance/overrides.d.ts.map +1 -0
  637. package/dist/governance/overrides.js +74 -0
  638. package/dist/governance/overrides.js.map +1 -0
  639. package/dist/governance/policies.d.ts +22 -0
  640. package/dist/governance/policies.d.ts.map +1 -0
  641. package/dist/governance/policies.js +279 -0
  642. package/dist/governance/policies.js.map +1 -0
  643. package/dist/governance/reports.d.ts +15 -0
  644. package/dist/governance/reports.d.ts.map +1 -0
  645. package/dist/governance/reports.js +79 -0
  646. package/dist/governance/reports.js.map +1 -0
  647. package/dist/governance/rule-engine.d.ts +45 -0
  648. package/dist/governance/rule-engine.d.ts.map +1 -0
  649. package/dist/governance/rule-engine.js +60 -0
  650. package/dist/governance/rule-engine.js.map +1 -0
  651. package/dist/governance/rules/ai.d.ts +11 -0
  652. package/dist/governance/rules/ai.d.ts.map +1 -0
  653. package/dist/governance/rules/ai.js +88 -0
  654. package/dist/governance/rules/ai.js.map +1 -0
  655. package/dist/governance/rules/architecture.d.ts +13 -0
  656. package/dist/governance/rules/architecture.d.ts.map +1 -0
  657. package/dist/governance/rules/architecture.js +114 -0
  658. package/dist/governance/rules/architecture.js.map +1 -0
  659. package/dist/governance/rules/index.d.ts +5 -0
  660. package/dist/governance/rules/index.d.ts.map +1 -0
  661. package/dist/governance/rules/index.js +6 -0
  662. package/dist/governance/rules/index.js.map +1 -0
  663. package/dist/governance/rules/privacy.d.ts +11 -0
  664. package/dist/governance/rules/privacy.d.ts.map +1 -0
  665. package/dist/governance/rules/privacy.js +97 -0
  666. package/dist/governance/rules/privacy.js.map +1 -0
  667. package/dist/governance/rules/security.d.ts +11 -0
  668. package/dist/governance/rules/security.d.ts.map +1 -0
  669. package/dist/governance/rules/security.js +83 -0
  670. package/dist/governance/rules/security.js.map +1 -0
  671. package/dist/index.d.ts +40 -0
  672. package/dist/index.d.ts.map +1 -0
  673. package/dist/index.js +79 -0
  674. package/dist/index.js.map +1 -0
  675. package/dist/observability/__tests__/metrics.test.d.ts +2 -0
  676. package/dist/observability/__tests__/metrics.test.d.ts.map +1 -0
  677. package/dist/observability/__tests__/metrics.test.js +301 -0
  678. package/dist/observability/__tests__/metrics.test.js.map +1 -0
  679. package/dist/observability/index.d.ts +3 -0
  680. package/dist/observability/index.d.ts.map +1 -0
  681. package/dist/observability/index.js +7 -0
  682. package/dist/observability/index.js.map +1 -0
  683. package/dist/observability/metrics.d.ts +130 -0
  684. package/dist/observability/metrics.d.ts.map +1 -0
  685. package/dist/observability/metrics.js +255 -0
  686. package/dist/observability/metrics.js.map +1 -0
  687. package/dist/server/__tests__/bootstrap.test.d.ts +2 -0
  688. package/dist/server/__tests__/bootstrap.test.d.ts.map +1 -0
  689. package/dist/server/__tests__/bootstrap.test.js +223 -0
  690. package/dist/server/__tests__/bootstrap.test.js.map +1 -0
  691. package/dist/server/bootstrap.d.ts +44 -0
  692. package/dist/server/bootstrap.d.ts.map +1 -0
  693. package/dist/server/bootstrap.js +153 -0
  694. package/dist/server/bootstrap.js.map +1 -0
  695. package/dist/server/index.d.ts +3 -0
  696. package/dist/server/index.d.ts.map +1 -0
  697. package/dist/server/index.js +6 -0
  698. package/dist/server/index.js.map +1 -0
  699. package/dist/testing/__tests__/context.test.d.ts +2 -0
  700. package/dist/testing/__tests__/context.test.d.ts.map +1 -0
  701. package/dist/testing/__tests__/context.test.js +341 -0
  702. package/dist/testing/__tests__/context.test.js.map +1 -0
  703. package/dist/testing/__tests__/e2e.test.d.ts +2 -0
  704. package/dist/testing/__tests__/e2e.test.d.ts.map +1 -0
  705. package/dist/testing/__tests__/e2e.test.js +119 -0
  706. package/dist/testing/__tests__/e2e.test.js.map +1 -0
  707. package/dist/testing/__tests__/field-validation.test.d.ts +2 -0
  708. package/dist/testing/__tests__/field-validation.test.d.ts.map +1 -0
  709. package/dist/testing/__tests__/field-validation.test.js +178 -0
  710. package/dist/testing/__tests__/field-validation.test.js.map +1 -0
  711. package/dist/testing/__tests__/governance.test.d.ts +2 -0
  712. package/dist/testing/__tests__/governance.test.d.ts.map +1 -0
  713. package/dist/testing/__tests__/governance.test.js +222 -0
  714. package/dist/testing/__tests__/governance.test.js.map +1 -0
  715. package/dist/testing/__tests__/run-capability.test.d.ts +2 -0
  716. package/dist/testing/__tests__/run-capability.test.d.ts.map +1 -0
  717. package/dist/testing/__tests__/run-capability.test.js +114 -0
  718. package/dist/testing/__tests__/run-capability.test.js.map +1 -0
  719. package/dist/testing/__tests__/scaffolding.test.d.ts +2 -0
  720. package/dist/testing/__tests__/scaffolding.test.d.ts.map +1 -0
  721. package/dist/testing/__tests__/scaffolding.test.js +70 -0
  722. package/dist/testing/__tests__/scaffolding.test.js.map +1 -0
  723. package/dist/testing/__tests__/security.test.d.ts +2 -0
  724. package/dist/testing/__tests__/security.test.d.ts.map +1 -0
  725. package/dist/testing/__tests__/security.test.js +186 -0
  726. package/dist/testing/__tests__/security.test.js.map +1 -0
  727. package/dist/testing/__tests__/simulate-flow.test.d.ts +2 -0
  728. package/dist/testing/__tests__/simulate-flow.test.d.ts.map +1 -0
  729. package/dist/testing/__tests__/simulate-flow.test.js +198 -0
  730. package/dist/testing/__tests__/simulate-flow.test.js.map +1 -0
  731. package/dist/testing/context.d.ts +90 -0
  732. package/dist/testing/context.d.ts.map +1 -0
  733. package/dist/testing/context.js +230 -0
  734. package/dist/testing/context.js.map +1 -0
  735. package/dist/testing/e2e.d.ts +58 -0
  736. package/dist/testing/e2e.d.ts.map +1 -0
  737. package/dist/testing/e2e.js +118 -0
  738. package/dist/testing/e2e.js.map +1 -0
  739. package/dist/testing/field-validation.d.ts +18 -0
  740. package/dist/testing/field-validation.d.ts.map +1 -0
  741. package/dist/testing/field-validation.js +99 -0
  742. package/dist/testing/field-validation.js.map +1 -0
  743. package/dist/testing/governance.d.ts +38 -0
  744. package/dist/testing/governance.d.ts.map +1 -0
  745. package/dist/testing/governance.js +104 -0
  746. package/dist/testing/governance.js.map +1 -0
  747. package/dist/testing/index.d.ts +18 -0
  748. package/dist/testing/index.d.ts.map +1 -0
  749. package/dist/testing/index.js +29 -0
  750. package/dist/testing/index.js.map +1 -0
  751. package/dist/testing/run-capability.d.ts +20 -0
  752. package/dist/testing/run-capability.d.ts.map +1 -0
  753. package/dist/testing/run-capability.js +19 -0
  754. package/dist/testing/run-capability.js.map +1 -0
  755. package/dist/testing/scaffolding.d.ts +46 -0
  756. package/dist/testing/scaffolding.d.ts.map +1 -0
  757. package/dist/testing/scaffolding.js +266 -0
  758. package/dist/testing/scaffolding.js.map +1 -0
  759. package/dist/testing/security.d.ts +42 -0
  760. package/dist/testing/security.d.ts.map +1 -0
  761. package/dist/testing/security.js +102 -0
  762. package/dist/testing/security.js.map +1 -0
  763. package/dist/testing/simulate-flow.d.ts +45 -0
  764. package/dist/testing/simulate-flow.d.ts.map +1 -0
  765. package/dist/testing/simulate-flow.js +136 -0
  766. package/dist/testing/simulate-flow.js.map +1 -0
  767. package/dist/types/audit.d.ts +15 -0
  768. package/dist/types/audit.d.ts.map +1 -0
  769. package/dist/types/audit.js +2 -0
  770. package/dist/types/audit.js.map +1 -0
  771. package/dist/types/capability.d.ts +38 -0
  772. package/dist/types/capability.d.ts.map +1 -0
  773. package/dist/types/capability.js +2 -0
  774. package/dist/types/capability.js.map +1 -0
  775. package/dist/types/config.d.ts +60 -0
  776. package/dist/types/config.d.ts.map +1 -0
  777. package/dist/types/config.js +2 -0
  778. package/dist/types/config.js.map +1 -0
  779. package/dist/types/context.d.ts +90 -0
  780. package/dist/types/context.d.ts.map +1 -0
  781. package/dist/types/context.js +2 -0
  782. package/dist/types/context.js.map +1 -0
  783. package/dist/types/entity.d.ts +16 -0
  784. package/dist/types/entity.d.ts.map +1 -0
  785. package/dist/types/entity.js +2 -0
  786. package/dist/types/entity.js.map +1 -0
  787. package/dist/types/enums.d.ts +66 -0
  788. package/dist/types/enums.d.ts.map +1 -0
  789. package/dist/types/enums.js +66 -0
  790. package/dist/types/enums.js.map +1 -0
  791. package/dist/types/errors.d.ts +14 -0
  792. package/dist/types/errors.d.ts.map +1 -0
  793. package/dist/types/errors.js +2 -0
  794. package/dist/types/errors.js.map +1 -0
  795. package/dist/types/event.d.ts +21 -0
  796. package/dist/types/event.d.ts.map +1 -0
  797. package/dist/types/event.js +2 -0
  798. package/dist/types/event.js.map +1 -0
  799. package/dist/types/fields.d.ts +51 -0
  800. package/dist/types/fields.d.ts.map +1 -0
  801. package/dist/types/fields.js +2 -0
  802. package/dist/types/fields.js.map +1 -0
  803. package/dist/types/flow.d.ts +54 -0
  804. package/dist/types/flow.d.ts.map +1 -0
  805. package/dist/types/flow.js +2 -0
  806. package/dist/types/flow.js.map +1 -0
  807. package/dist/types/governance.d.ts +30 -0
  808. package/dist/types/governance.d.ts.map +1 -0
  809. package/dist/types/governance.js +2 -0
  810. package/dist/types/governance.js.map +1 -0
  811. package/dist/types/index.d.ts +14 -0
  812. package/dist/types/index.d.ts.map +1 -0
  813. package/dist/types/index.js +7 -0
  814. package/dist/types/index.js.map +1 -0
  815. package/dist/types/prompt.d.ts +18 -0
  816. package/dist/types/prompt.d.ts.map +1 -0
  817. package/dist/types/prompt.js +2 -0
  818. package/dist/types/prompt.js.map +1 -0
  819. package/dist/types/security.d.ts +17 -0
  820. package/dist/types/security.d.ts.map +1 -0
  821. package/dist/types/security.js +2 -0
  822. package/dist/types/security.js.map +1 -0
  823. package/dist/vitest/index.d.ts +2 -0
  824. package/dist/vitest/index.d.ts.map +1 -0
  825. package/dist/vitest/index.js +5 -0
  826. package/dist/vitest/index.js.map +1 -0
  827. package/dist/worker/__tests__/bootstrap.test.d.ts +2 -0
  828. package/dist/worker/__tests__/bootstrap.test.d.ts.map +1 -0
  829. package/dist/worker/__tests__/bootstrap.test.js +211 -0
  830. package/dist/worker/__tests__/bootstrap.test.js.map +1 -0
  831. package/dist/worker/bootstrap.d.ts +51 -0
  832. package/dist/worker/bootstrap.d.ts.map +1 -0
  833. package/dist/worker/bootstrap.js +166 -0
  834. package/dist/worker/bootstrap.js.map +1 -0
  835. package/dist/worker/index.d.ts +3 -0
  836. package/dist/worker/index.d.ts.map +1 -0
  837. package/dist/worker/index.js +6 -0
  838. package/dist/worker/index.js.map +1 -0
  839. package/dist/zod/index.d.ts +2 -0
  840. package/dist/zod/index.d.ts.map +1 -0
  841. package/dist/zod/index.js +5 -0
  842. package/dist/zod/index.js.map +1 -0
  843. package/instructions/ai.md +183 -0
  844. package/instructions/capabilities.md +171 -0
  845. package/instructions/cli.md +113 -0
  846. package/instructions/entities.md +94 -0
  847. package/instructions/events.md +93 -0
  848. package/instructions/flows.md +114 -0
  849. package/instructions/framework.md +86 -0
  850. package/instructions/governance.md +78 -0
  851. package/instructions/patterns.md +107 -0
  852. package/instructions/security.md +79 -0
  853. package/instructions/testing.md +244 -0
  854. package/package.json +76 -0
@@ -0,0 +1,39 @@
1
+ // ── Output Validation with Retry ──
2
+ // Validates AI responses against Zod schemas, retries on mismatch
3
+ export async function generateWithValidation(provider, request, schema, config) {
4
+ const maxRetries = config?.maxRetries ?? 2;
5
+ const feedbackOnError = config?.feedbackOnError ?? true;
6
+ let totalUsage = { inputTokens: 0, outputTokens: 0, totalTokens: 0 };
7
+ let lastError = null;
8
+ let currentPrompt = request.prompt;
9
+ for (let attempt = 1; attempt <= maxRetries + 1; attempt++) {
10
+ const response = await provider.complete({
11
+ ...request,
12
+ prompt: currentPrompt,
13
+ responseFormat: 'json',
14
+ });
15
+ totalUsage = {
16
+ inputTokens: totalUsage.inputTokens + response.usage.inputTokens,
17
+ outputTokens: totalUsage.outputTokens + response.usage.outputTokens,
18
+ totalTokens: totalUsage.totalTokens + response.usage.totalTokens,
19
+ };
20
+ try {
21
+ const parsed = JSON.parse(response.content);
22
+ const result = schema.parse(parsed);
23
+ return {
24
+ data: result,
25
+ raw: response.content,
26
+ attempts: attempt,
27
+ usage: totalUsage,
28
+ };
29
+ }
30
+ catch (err) {
31
+ lastError = err instanceof Error ? err : new Error(String(err));
32
+ if (attempt <= maxRetries && feedbackOnError) {
33
+ currentPrompt = `${request.prompt}\n\nYour previous response was invalid. Error: ${lastError.message}\nPlease fix the output to match the required schema.`;
34
+ }
35
+ }
36
+ }
37
+ throw new Error(`AI output validation failed after ${maxRetries + 1} attempts: ${lastError?.message}`);
38
+ }
39
+ //# sourceMappingURL=validation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/ai/validation.ts"],"names":[],"mappings":"AAAA,qCAAqC;AACrC,kEAAkE;AAmBlE,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,QAA2B,EAC3B,OAAwB,EACxB,MAAoB,EACpB,MAA8B;IAE9B,MAAM,UAAU,GAAG,MAAM,EAAE,UAAU,IAAI,CAAC,CAAC;IAC3C,MAAM,eAAe,GAAG,MAAM,EAAE,eAAe,IAAI,IAAI,CAAC;IAExD,IAAI,UAAU,GAAG,EAAE,WAAW,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC;IACrE,IAAI,SAAS,GAAiB,IAAI,CAAC;IACnC,IAAI,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC;IAEnC,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,UAAU,GAAG,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC;QAC3D,MAAM,QAAQ,GAAqB,MAAM,QAAQ,CAAC,QAAQ,CAAC;YACzD,GAAG,OAAO;YACV,MAAM,EAAE,aAAa;YACrB,cAAc,EAAE,MAAM;SACvB,CAAC,CAAC;QAEH,UAAU,GAAG;YACX,WAAW,EAAE,UAAU,CAAC,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC,WAAW;YAChE,YAAY,EAAE,UAAU,CAAC,YAAY,GAAG,QAAQ,CAAC,KAAK,CAAC,YAAY;YACnE,WAAW,EAAE,UAAU,CAAC,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC,WAAW;SACjE,CAAC;QAEF,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YAC5C,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACpC,OAAO;gBACL,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,QAAQ,CAAC,OAAO;gBACrB,QAAQ,EAAE,OAAO;gBACjB,KAAK,EAAE,UAAU;aAClB,CAAC;QACJ,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,SAAS,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;YAEhE,IAAI,OAAO,IAAI,UAAU,IAAI,eAAe,EAAE,CAAC;gBAC7C,aAAa,GAAG,GAAG,OAAO,CAAC,MAAM,kDAAkD,SAAS,CAAC,OAAO,uDAAuD,CAAC;YAC9J,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,IAAI,KAAK,CACb,qCAAqC,UAAU,GAAG,CAAC,cAAc,SAAS,EAAE,OAAO,EAAE,CACtF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=route-generator.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route-generator.test.d.ts","sourceRoot":"","sources":["../../../src/api/__tests__/route-generator.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,101 @@
1
+ import { describe, expect, it, vi } from 'vitest';
2
+ import { z } from 'zod';
3
+ import { registerAllRoutes, registerCapabilityRoute } from '../route-generator.js';
4
+ // ── Helpers ──
5
+ function makeCapability(overrides = {}) {
6
+ return {
7
+ name: 'getUser',
8
+ kind: 'query',
9
+ domain: 'users',
10
+ input: z.object({ id: z.string() }),
11
+ output: z.object({ id: z.string(), name: z.string() }),
12
+ effects: { data: ['User'], events: [], external: [], ai: false },
13
+ access: { roles: ['admin'] },
14
+ handler: async (_ctx, input) => ({
15
+ id: input.id,
16
+ name: 'Test User',
17
+ }),
18
+ ...overrides,
19
+ };
20
+ }
21
+ function makeMockApp() {
22
+ return {
23
+ get: vi.fn(),
24
+ post: vi.fn(),
25
+ };
26
+ }
27
+ function makeMockConfig() {
28
+ return {
29
+ authAdapter: {
30
+ authenticate: vi.fn().mockResolvedValue({
31
+ userId: 'u1',
32
+ roles: ['admin'],
33
+ scopes: [],
34
+ provider: 'test',
35
+ tenantId: 'tenant-1',
36
+ }),
37
+ },
38
+ createDependencies: vi.fn().mockReturnValue({
39
+ auth: {
40
+ userId: 'u1',
41
+ roles: ['admin'],
42
+ scopes: [],
43
+ provider: 'test',
44
+ tenantId: 'tenant-1',
45
+ },
46
+ data: {},
47
+ }),
48
+ };
49
+ }
50
+ // ── Tests ──
51
+ describe('registerCapabilityRoute', () => {
52
+ it('registers a GET route for query capabilities', () => {
53
+ const app = makeMockApp();
54
+ const config = makeMockConfig();
55
+ const cap = makeCapability({ kind: 'query' });
56
+ registerCapabilityRoute(app, cap, config);
57
+ expect(app.get).toHaveBeenCalledTimes(1);
58
+ expect(app.post).not.toHaveBeenCalled();
59
+ expect(app.get.mock.calls[0]?.[0]).toBe('/api/users/get-user');
60
+ });
61
+ it('registers a POST route for action capabilities', () => {
62
+ const app = makeMockApp();
63
+ const config = makeMockConfig();
64
+ const cap = makeCapability({ kind: 'action', name: 'createUser' });
65
+ registerCapabilityRoute(app, cap, config);
66
+ expect(app.post).toHaveBeenCalledTimes(1);
67
+ expect(app.get).not.toHaveBeenCalled();
68
+ expect(app.post.mock.calls[0]?.[0]).toBe('/api/users/create-user');
69
+ });
70
+ it('registers a POST route for job capabilities', () => {
71
+ const app = makeMockApp();
72
+ const config = makeMockConfig();
73
+ const cap = makeCapability({ kind: 'job', name: 'processReport' });
74
+ registerCapabilityRoute(app, cap, config);
75
+ expect(app.post).toHaveBeenCalledTimes(1);
76
+ expect(app.post.mock.calls[0]?.[0]).toBe('/api/users/process-report');
77
+ });
78
+ it('skips eventHandler capabilities', () => {
79
+ const app = makeMockApp();
80
+ const config = makeMockConfig();
81
+ const cap = makeCapability({ kind: 'eventHandler', name: 'onUserCreated' });
82
+ registerCapabilityRoute(app, cap, config);
83
+ expect(app.get).not.toHaveBeenCalled();
84
+ expect(app.post).not.toHaveBeenCalled();
85
+ });
86
+ });
87
+ describe('registerAllRoutes', () => {
88
+ it('registers routes for multiple capabilities', () => {
89
+ const app = makeMockApp();
90
+ const config = makeMockConfig();
91
+ const caps = [
92
+ makeCapability({ kind: 'query', name: 'getUser' }),
93
+ makeCapability({ kind: 'action', name: 'createUser' }),
94
+ makeCapability({ kind: 'eventHandler', name: 'onUserCreated' }),
95
+ ];
96
+ registerAllRoutes(app, caps, config);
97
+ expect(app.get).toHaveBeenCalledTimes(1);
98
+ expect(app.post).toHaveBeenCalledTimes(1);
99
+ });
100
+ });
101
+ //# sourceMappingURL=route-generator.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route-generator.test.js","sourceRoot":"","sources":["../../../src/api/__tests__/route-generator.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export { registerAllRoutes, registerCapabilityRoute, } from './route-generator.js';
2
+ export type { RouteGeneratorConfig } from './route-generator.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,sBAAsB,CAAC;AAC9B,YAAY,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC"}
@@ -0,0 +1,7 @@
1
+ // ── API Module ──
2
+ // HTTP route generation: registers Fastify routes for capabilities.
3
+ // Maps capability kind to HTTP method (query→GET, action/job→POST).
4
+ //
5
+ // Key exports: registerAllRoutes, registerCapabilityRoute
6
+ export { registerAllRoutes, registerCapabilityRoute, } from './route-generator.js';
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"AAAA,mBAAmB;AACnB,oEAAoE;AACpE,oEAAoE;AACpE,EAAE;AACF,0DAA0D;AAE1D,OAAO,EACL,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,sBAAsB,CAAC"}
@@ -0,0 +1,24 @@
1
+ import type { FastifyInstance } from 'fastify';
2
+ import type { AuthAdapter } from '../auth/adapter.js';
3
+ import type { EventQueue } from '../events/queue.js';
4
+ import type { ContextDependencies } from '../execution/context-factory.js';
5
+ import type { CapabilityContract } from '../types/capability.js';
6
+ export interface RouteGeneratorConfig {
7
+ /** Auth adapter for extracting identity from requests */
8
+ authAdapter: AuthAdapter;
9
+ /** Factory to build base context dependencies for each request */
10
+ createDependencies: (auth: NonNullable<Awaited<ReturnType<AuthAdapter['authenticate']>>>) => ContextDependencies;
11
+ /** Optional queue for dispatching async job capabilities */
12
+ jobQueue?: EventQueue;
13
+ }
14
+ /**
15
+ * Register Fastify routes for a single capability.
16
+ * HTTP method is derived from capability kind:
17
+ * query → GET, action → POST, job → POST (async), eventHandler → skipped
18
+ */
19
+ export declare function registerCapabilityRoute(app: FastifyInstance, capability: CapabilityContract, config: RouteGeneratorConfig): void;
20
+ /**
21
+ * Register routes for multiple capabilities at once.
22
+ */
23
+ export declare function registerAllRoutes(app: FastifyInstance, capabilities: CapabilityContract[], config: RouteGeneratorConfig): void;
24
+ //# sourceMappingURL=route-generator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route-generator.d.ts","sourceRoot":"","sources":["../../src/api/route-generator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAgC,MAAM,SAAS,CAAC;AAC7E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAErD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AAE3E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAGjE,MAAM,WAAW,oBAAoB;IACnC,yDAAyD;IACzD,WAAW,EAAE,WAAW,CAAC;IACzB,kEAAkE;IAClE,kBAAkB,EAAE,CAClB,IAAI,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,KAChE,mBAAmB,CAAC;IACzB,4DAA4D;IAC5D,QAAQ,CAAC,EAAE,UAAU,CAAC;CACvB;AAED;;;;GAIG;AACH,wBAAgB,uBAAuB,CACrC,GAAG,EAAE,eAAe,EACpB,UAAU,EAAE,kBAAkB,EAC9B,MAAM,EAAE,oBAAoB,GAC3B,IAAI,CA2DN;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,GAAG,EAAE,eAAe,EACpB,YAAY,EAAE,kBAAkB,EAAE,EAClC,MAAM,EAAE,oBAAoB,GAC3B,IAAI,CAIN"}
@@ -0,0 +1,77 @@
1
+ import { errorToHttpResponse } from '../errors/http.js';
2
+ import { executeCapability } from '../execution/capability-executor.js';
3
+ import { createExecutionContext } from '../execution/context-factory.js';
4
+ /**
5
+ * Register Fastify routes for a single capability.
6
+ * HTTP method is derived from capability kind:
7
+ * query → GET, action → POST, job → POST (async), eventHandler → skipped
8
+ */
9
+ export function registerCapabilityRoute(app, capability, config) {
10
+ // Event handlers are internal-only, no HTTP route
11
+ if (capability.kind === 'eventHandler')
12
+ return;
13
+ const method = capability.kind === 'query' ? 'GET' : 'POST';
14
+ const path = `/api/${capability.domain}/${toKebabCase(capability.name)}`;
15
+ const handler = async (request, reply) => {
16
+ // 1. Authenticate
17
+ const authHeader = request.headers.authorization;
18
+ const auth = await config.authAdapter.authenticate(authHeader);
19
+ // For public capabilities, use a minimal anonymous context
20
+ const authContext = auth ?? {
21
+ userId: undefined,
22
+ roles: [],
23
+ scopes: [],
24
+ provider: 'anonymous',
25
+ };
26
+ // 2. Build execution context
27
+ const deps = config.createDependencies(authContext);
28
+ const ctx = createExecutionContext(deps);
29
+ // 3. Extract input (query params for GET, body for POST)
30
+ const input = method === 'GET' ? request.query : request.body;
31
+ // 4. Execute capability (jobs dispatched async via queue if available)
32
+ if (capability.kind === 'job' && config.jobQueue) {
33
+ const jobId = crypto.randomUUID();
34
+ await config.jobQueue.publish({
35
+ id: jobId,
36
+ eventType: `job.${capability.domain}.${capability.name}`,
37
+ version: '1',
38
+ occurredAt: new Date(),
39
+ actor: ctx.auth.userId ?? 'anonymous',
40
+ tenantId: ctx.auth.tenantId,
41
+ correlationId: jobId,
42
+ payload: input,
43
+ });
44
+ reply.status(202).send({ data: { jobId, status: 'accepted' } });
45
+ return;
46
+ }
47
+ const result = await executeCapability(capability, ctx, input);
48
+ if (result.success) {
49
+ reply.status(200).send({ data: result.data });
50
+ }
51
+ else {
52
+ const httpError = errorToHttpResponse(result.error);
53
+ reply.status(httpError.statusCode).send(httpError.body);
54
+ }
55
+ };
56
+ if (method === 'GET') {
57
+ app.get(path, handler);
58
+ }
59
+ else {
60
+ app.post(path, handler);
61
+ }
62
+ }
63
+ /**
64
+ * Register routes for multiple capabilities at once.
65
+ */
66
+ export function registerAllRoutes(app, capabilities, config) {
67
+ for (const cap of capabilities) {
68
+ registerCapabilityRoute(app, cap, config);
69
+ }
70
+ }
71
+ function toKebabCase(str) {
72
+ return str
73
+ .replace(/([A-Z])/g, '-$1')
74
+ .toLowerCase()
75
+ .replace(/^-/, '');
76
+ }
77
+ //# sourceMappingURL=route-generator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route-generator.js","sourceRoot":"","sources":["../../src/api/route-generator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=service.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.test.d.ts","sourceRoot":"","sources":["../../../src/audit/__tests__/service.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,97 @@
1
+ import { describe, expect, it, vi } from 'vitest';
2
+ import { createAuditService } from '../service.js';
3
+ function makeMockDb() {
4
+ const inserted = [];
5
+ return {
6
+ inserted,
7
+ insert: vi.fn().mockReturnValue({
8
+ values: vi.fn().mockImplementation((row) => {
9
+ inserted.push(row);
10
+ return Promise.resolve();
11
+ }),
12
+ }),
13
+ };
14
+ }
15
+ describe('createAuditService', () => {
16
+ it('records an audit event with correct fields', async () => {
17
+ const db = makeMockDb();
18
+ const service = createAuditService({
19
+ db: db,
20
+ auth: {
21
+ userId: 'user-1',
22
+ tenantId: 'tenant-1',
23
+ roles: ['admin'],
24
+ scopes: [],
25
+ provider: 'test',
26
+ },
27
+ component: 'orders',
28
+ });
29
+ await service.record('order.created', { orderId: '123', outcome: 'success' });
30
+ expect(db.insert).toHaveBeenCalledTimes(1);
31
+ expect(db.inserted[0]).toMatchObject({
32
+ actor: 'user-1',
33
+ tenantId: 'tenant-1',
34
+ component: 'orders',
35
+ action: 'order.created',
36
+ outcome: 'success',
37
+ });
38
+ });
39
+ it('defaults actor to anonymous when userId is undefined', async () => {
40
+ const db = makeMockDb();
41
+ const service = createAuditService({
42
+ db: db,
43
+ auth: { userId: undefined, roles: [], scopes: [], provider: 'anonymous' },
44
+ });
45
+ await service.record('system.ping');
46
+ expect(db.inserted[0]).toMatchObject({
47
+ actor: 'anonymous',
48
+ component: 'system',
49
+ });
50
+ });
51
+ it('defaults outcome to success when not provided', async () => {
52
+ const db = makeMockDb();
53
+ const service = createAuditService({
54
+ db: db,
55
+ auth: { userId: 'u1', roles: [], scopes: [], provider: 'test' },
56
+ });
57
+ await service.record('check');
58
+ expect(db.inserted[0]).toMatchObject({ outcome: 'success' });
59
+ });
60
+ it('strips _maskedFields from stored metadata', async () => {
61
+ const db = makeMockDb();
62
+ const service = createAuditService({
63
+ db: db,
64
+ auth: { userId: 'u1', roles: [], scopes: [], provider: 'test' },
65
+ });
66
+ await service.record('sensitive.op', {
67
+ email: '***',
68
+ _maskedFields: ['email'],
69
+ });
70
+ const row = db.inserted[0];
71
+ expect(row.maskedFields).toEqual(['email']);
72
+ const meta = row.metadata;
73
+ expect(meta).not.toHaveProperty('_maskedFields');
74
+ expect(meta).toHaveProperty('email', '***');
75
+ });
76
+ it('records null metadata when none provided', async () => {
77
+ const db = makeMockDb();
78
+ const service = createAuditService({
79
+ db: db,
80
+ auth: { userId: 'u1', roles: [], scopes: [], provider: 'test' },
81
+ });
82
+ await service.record('simple.event');
83
+ const row = db.inserted[0];
84
+ expect(row.metadata).toBeNull();
85
+ });
86
+ it('passes tenantId as null when not in auth', async () => {
87
+ const db = makeMockDb();
88
+ const service = createAuditService({
89
+ db: db,
90
+ auth: { userId: 'u1', roles: [], scopes: [], provider: 'test' },
91
+ });
92
+ await service.record('event');
93
+ const row = db.inserted[0];
94
+ expect(row.tenantId).toBeNull();
95
+ });
96
+ });
97
+ //# sourceMappingURL=service.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.test.js","sourceRoot":"","sources":["../../../src/audit/__tests__/service.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export { auditRecords } from './schema.js';
2
+ export { createAuditService } from './service.js';
3
+ export type { AuditServiceConfig } from './service.js';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/audit/index.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClD,YAAY,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,8 @@
1
+ // ── Audit Module ──
2
+ // Audit trail: Drizzle schema for audit_records table and a service that
3
+ // writes structured audit records to PostgreSQL. Used by ctx.audit.
4
+ //
5
+ // Key exports: createAuditService, auditRecords (Drizzle table)
6
+ export { auditRecords } from './schema.js';
7
+ export { createAuditService } from './service.js';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/audit/index.ts"],"names":[],"mappings":"AAAA,qBAAqB;AACrB,yEAAyE;AACzE,oEAAoE;AACpE,EAAE;AACF,gEAAgE;AAEhE,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC"}
@@ -0,0 +1,164 @@
1
+ /**
2
+ * Drizzle schema for the audit_records table.
3
+ */
4
+ export declare const auditRecords: import("drizzle-orm/pg-core").PgTableWithColumns<{
5
+ name: "audit_records";
6
+ schema: undefined;
7
+ columns: {
8
+ id: import("drizzle-orm/pg-core").PgColumn<{
9
+ name: "id";
10
+ tableName: "audit_records";
11
+ dataType: "string";
12
+ columnType: "PgUUID";
13
+ data: string;
14
+ driverParam: string;
15
+ notNull: true;
16
+ hasDefault: true;
17
+ isPrimaryKey: true;
18
+ isAutoincrement: false;
19
+ hasRuntimeDefault: false;
20
+ enumValues: undefined;
21
+ baseColumn: never;
22
+ identity: undefined;
23
+ generated: undefined;
24
+ }, {}, {}>;
25
+ actor: import("drizzle-orm/pg-core").PgColumn<{
26
+ name: "actor";
27
+ tableName: "audit_records";
28
+ dataType: "string";
29
+ columnType: "PgText";
30
+ data: string;
31
+ driverParam: string;
32
+ notNull: true;
33
+ hasDefault: false;
34
+ isPrimaryKey: false;
35
+ isAutoincrement: false;
36
+ hasRuntimeDefault: false;
37
+ enumValues: [string, ...string[]];
38
+ baseColumn: never;
39
+ identity: undefined;
40
+ generated: undefined;
41
+ }, {}, {}>;
42
+ tenantId: import("drizzle-orm/pg-core").PgColumn<{
43
+ name: "tenant_id";
44
+ tableName: "audit_records";
45
+ dataType: "string";
46
+ columnType: "PgText";
47
+ data: string;
48
+ driverParam: string;
49
+ notNull: false;
50
+ hasDefault: false;
51
+ isPrimaryKey: false;
52
+ isAutoincrement: false;
53
+ hasRuntimeDefault: false;
54
+ enumValues: [string, ...string[]];
55
+ baseColumn: never;
56
+ identity: undefined;
57
+ generated: undefined;
58
+ }, {}, {}>;
59
+ timestamp: import("drizzle-orm/pg-core").PgColumn<{
60
+ name: "timestamp";
61
+ tableName: "audit_records";
62
+ dataType: "date";
63
+ columnType: "PgTimestamp";
64
+ data: Date;
65
+ driverParam: string;
66
+ notNull: true;
67
+ hasDefault: true;
68
+ isPrimaryKey: false;
69
+ isAutoincrement: false;
70
+ hasRuntimeDefault: false;
71
+ enumValues: undefined;
72
+ baseColumn: never;
73
+ identity: undefined;
74
+ generated: undefined;
75
+ }, {}, {}>;
76
+ component: import("drizzle-orm/pg-core").PgColumn<{
77
+ name: "component";
78
+ tableName: "audit_records";
79
+ dataType: "string";
80
+ columnType: "PgText";
81
+ data: string;
82
+ driverParam: string;
83
+ notNull: true;
84
+ hasDefault: false;
85
+ isPrimaryKey: false;
86
+ isAutoincrement: false;
87
+ hasRuntimeDefault: false;
88
+ enumValues: [string, ...string[]];
89
+ baseColumn: never;
90
+ identity: undefined;
91
+ generated: undefined;
92
+ }, {}, {}>;
93
+ action: import("drizzle-orm/pg-core").PgColumn<{
94
+ name: "action";
95
+ tableName: "audit_records";
96
+ dataType: "string";
97
+ columnType: "PgText";
98
+ data: string;
99
+ driverParam: string;
100
+ notNull: true;
101
+ hasDefault: false;
102
+ isPrimaryKey: false;
103
+ isAutoincrement: false;
104
+ hasRuntimeDefault: false;
105
+ enumValues: [string, ...string[]];
106
+ baseColumn: never;
107
+ identity: undefined;
108
+ generated: undefined;
109
+ }, {}, {}>;
110
+ outcome: import("drizzle-orm/pg-core").PgColumn<{
111
+ name: "outcome";
112
+ tableName: "audit_records";
113
+ dataType: "string";
114
+ columnType: "PgText";
115
+ data: string;
116
+ driverParam: string;
117
+ notNull: true;
118
+ hasDefault: false;
119
+ isPrimaryKey: false;
120
+ isAutoincrement: false;
121
+ hasRuntimeDefault: false;
122
+ enumValues: [string, ...string[]];
123
+ baseColumn: never;
124
+ identity: undefined;
125
+ generated: undefined;
126
+ }, {}, {}>;
127
+ metadata: import("drizzle-orm/pg-core").PgColumn<{
128
+ name: "metadata";
129
+ tableName: "audit_records";
130
+ dataType: "json";
131
+ columnType: "PgJsonb";
132
+ data: unknown;
133
+ driverParam: unknown;
134
+ notNull: false;
135
+ hasDefault: false;
136
+ isPrimaryKey: false;
137
+ isAutoincrement: false;
138
+ hasRuntimeDefault: false;
139
+ enumValues: undefined;
140
+ baseColumn: never;
141
+ identity: undefined;
142
+ generated: undefined;
143
+ }, {}, {}>;
144
+ maskedFields: import("drizzle-orm/pg-core").PgColumn<{
145
+ name: "masked_fields";
146
+ tableName: "audit_records";
147
+ dataType: "json";
148
+ columnType: "PgJsonb";
149
+ data: unknown;
150
+ driverParam: unknown;
151
+ notNull: false;
152
+ hasDefault: false;
153
+ isPrimaryKey: false;
154
+ isAutoincrement: false;
155
+ hasRuntimeDefault: false;
156
+ enumValues: undefined;
157
+ baseColumn: never;
158
+ identity: undefined;
159
+ generated: undefined;
160
+ }, {}, {}>;
161
+ };
162
+ dialect: "pg";
163
+ }>;
164
+ //# sourceMappingURL=schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../src/audit/schema.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAUvB,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { jsonb, pgTable, text, timestamp, uuid } from 'drizzle-orm/pg-core';
2
+ /**
3
+ * Drizzle schema for the audit_records table.
4
+ */
5
+ export const auditRecords = pgTable('audit_records', {
6
+ id: uuid('id').defaultRandom().primaryKey(),
7
+ actor: text('actor').notNull(),
8
+ tenantId: text('tenant_id'),
9
+ timestamp: timestamp('timestamp', { withTimezone: true }).defaultNow().notNull(),
10
+ component: text('component').notNull(),
11
+ action: text('action').notNull(),
12
+ outcome: text('outcome').notNull(), // "success" | "failure" | "denied"
13
+ metadata: jsonb('metadata'),
14
+ maskedFields: jsonb('masked_fields'),
15
+ });
16
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sourceRoot":"","sources":["../../src/audit/schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAE5E;;GAEG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,OAAO,CAAC,eAAe,EAAE;IACnD,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE;IAC3C,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE;IAC9B,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC;IAC3B,SAAS,EAAE,SAAS,CAAC,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,OAAO,EAAE;IAChF,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,EAAE;IACtC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE;IAChC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE,mCAAmC;IACvE,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC;IAC3B,YAAY,EAAE,KAAK,CAAC,eAAe,CAAC;CACrC,CAAC,CAAC"}
@@ -0,0 +1,14 @@
1
+ import type { PostgresJsDatabase } from 'drizzle-orm/postgres-js';
2
+ import type { AuditService } from '../types/audit.js';
3
+ import type { AuthContext } from '../types/security.js';
4
+ export interface AuditServiceConfig {
5
+ db: PostgresJsDatabase;
6
+ auth: AuthContext;
7
+ /** Component name for this audit context (e.g. capability name) */
8
+ component?: string;
9
+ }
10
+ /**
11
+ * Creates a persistent AuditService that writes records to PostgreSQL.
12
+ */
13
+ export declare function createAuditService(config: AuditServiceConfig): AuditService;
14
+ //# sourceMappingURL=service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../src/audit/service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGxD,MAAM,WAAW,kBAAkB;IACjC,EAAE,EAAE,kBAAkB,CAAC;IACvB,IAAI,EAAE,WAAW,CAAC;IAClB,mEAAmE;IACnE,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,kBAAkB,GAAG,YAAY,CAyB3E"}