@llm-dev-ops/agentics-cli 1.4.32 → 1.4.34

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 (400) hide show
  1. package/dist/agents/repo-agent-runner.d.ts +10 -0
  2. package/dist/agents/repo-agent-runner.d.ts.map +1 -1
  3. package/dist/agents/repo-agent-runner.js +264 -11
  4. package/dist/agents/repo-agent-runner.js.map +1 -1
  5. package/dist/bundled-agents/analytics-hub-agents/package-lock.json +154 -174
  6. package/dist/bundled-agents/auto-optimizer-agents/package-lock.json +9226 -0
  7. package/dist/bundled-agents/benchmark-exchange-agents/package-lock.json +16 -0
  8. package/dist/bundled-agents/copilot-agents/functions/package-lock.json +5473 -0
  9. package/dist/bundled-agents/copilot-agents/functions/src/claude.ts +71 -0
  10. package/dist/bundled-agents/copilot-agents/package-lock.json +11825 -0
  11. package/dist/bundled-agents/incident-manager-agents/functions/src/claude.ts +71 -0
  12. package/dist/bundled-agents/incident-manager-agents/package-lock.json +48 -3
  13. package/dist/bundled-agents/inference-gateway-agents/package-lock.json +0 -3
  14. package/dist/bundled-agents/latency-lens-agents/package-lock.json +11825 -0
  15. package/dist/bundled-agents/memory-graph-agents/package-lock.json +1 -3
  16. package/dist/bundled-agents/observatory-agents/package-lock.json +1710 -0
  17. package/dist/bundled-agents/orchestrator-agents/package-lock.json +13254 -0
  18. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/agent.d.ts +144 -0
  19. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/agent.d.ts.map +1 -0
  20. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/agent.js +730 -0
  21. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/agent.js.map +1 -0
  22. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/handler.d.ts +57 -0
  23. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/handler.d.ts.map +1 -0
  24. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/handler.js +286 -0
  25. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/handler.js.map +1 -0
  26. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/index.d.ts +5 -0
  27. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/index.d.ts.map +1 -0
  28. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/index.js +21 -0
  29. package/dist/bundled-agents/policy-engine-agents/dist/agents/approval-routing/index.js.map +1 -0
  30. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/agent.d.ts +106 -0
  31. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/agent.d.ts.map +1 -0
  32. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/agent.js +552 -0
  33. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/agent.js.map +1 -0
  34. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/handler.d.ts +51 -0
  35. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/handler.d.ts.map +1 -0
  36. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/handler.js +209 -0
  37. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/handler.js.map +1 -0
  38. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/index.d.ts +8 -0
  39. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/index.d.ts.map +1 -0
  40. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/index.js +20 -0
  41. package/dist/bundled-agents/policy-engine-agents/dist/agents/constraint-solver/index.js.map +1 -0
  42. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/approval-routing.d.ts +246 -0
  43. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/approval-routing.d.ts.map +1 -0
  44. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/approval-routing.js +15 -0
  45. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/approval-routing.js.map +1 -0
  46. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/constraint-solver.d.ts +131 -0
  47. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/constraint-solver.d.ts.map +1 -0
  48. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/constraint-solver.js +15 -0
  49. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/constraint-solver.js.map +1 -0
  50. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/decision-event.d.ts +207 -0
  51. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/decision-event.d.ts.map +1 -0
  52. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/decision-event.js +14 -0
  53. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/decision-event.js.map +1 -0
  54. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/index.d.ts +11 -0
  55. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/index.d.ts.map +1 -0
  56. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/index.js +27 -0
  57. package/dist/bundled-agents/policy-engine-agents/dist/agents/contracts/index.js.map +1 -0
  58. package/dist/bundled-agents/policy-engine-agents/dist/agents/index.d.ts +13 -0
  59. package/dist/bundled-agents/policy-engine-agents/dist/agents/index.d.ts.map +1 -0
  60. package/dist/bundled-agents/policy-engine-agents/dist/agents/index.js +52 -0
  61. package/dist/bundled-agents/policy-engine-agents/dist/agents/index.js.map +1 -0
  62. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/agent.d.ts +97 -0
  63. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/agent.d.ts.map +1 -0
  64. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/agent.js +521 -0
  65. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/agent.js.map +1 -0
  66. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/handler.d.ts +52 -0
  67. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/handler.d.ts.map +1 -0
  68. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/handler.js +216 -0
  69. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/handler.js.map +1 -0
  70. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/index.d.ts +8 -0
  71. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/index.d.ts.map +1 -0
  72. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/index.js +24 -0
  73. package/dist/bundled-agents/policy-engine-agents/dist/agents/policy-enforcement/index.js.map +1 -0
  74. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/auth.d.ts +39 -0
  75. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/auth.d.ts.map +1 -0
  76. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/auth.js +194 -0
  77. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/auth.js.map +1 -0
  78. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/error-handler.d.ts +22 -0
  79. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/error-handler.d.ts.map +1 -0
  80. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/error-handler.js +124 -0
  81. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/error-handler.js.map +1 -0
  82. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/rate-limit.d.ts +40 -0
  83. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/rate-limit.d.ts.map +1 -0
  84. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/rate-limit.js +154 -0
  85. package/dist/bundled-agents/policy-engine-agents/dist/api/middleware/rate-limit.js.map +1 -0
  86. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/agents.d.ts +3 -0
  87. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/agents.d.ts.map +1 -0
  88. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/agents.js +111 -0
  89. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/agents.js.map +1 -0
  90. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/approval-routing.d.ts +3 -0
  91. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/approval-routing.d.ts.map +1 -0
  92. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/approval-routing.js +135 -0
  93. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/approval-routing.js.map +1 -0
  94. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/constraint-solver.d.ts +3 -0
  95. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/constraint-solver.d.ts.map +1 -0
  96. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/constraint-solver.js +51 -0
  97. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/constraint-solver.js.map +1 -0
  98. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/evaluations.d.ts +3 -0
  99. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/evaluations.d.ts.map +1 -0
  100. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/evaluations.js +311 -0
  101. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/evaluations.js.map +1 -0
  102. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/internal-evaluate.d.ts +3 -0
  103. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/internal-evaluate.d.ts.map +1 -0
  104. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/internal-evaluate.js +133 -0
  105. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/internal-evaluate.js.map +1 -0
  106. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/policies.d.ts +3 -0
  107. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/policies.d.ts.map +1 -0
  108. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/policies.js +602 -0
  109. package/dist/bundled-agents/policy-engine-agents/dist/api/routes/policies.js.map +1 -0
  110. package/dist/bundled-agents/policy-engine-agents/dist/api/server.d.ts +8 -0
  111. package/dist/bundled-agents/policy-engine-agents/dist/api/server.d.ts.map +1 -0
  112. package/dist/bundled-agents/policy-engine-agents/dist/api/server.js +195 -0
  113. package/dist/bundled-agents/policy-engine-agents/dist/api/server.js.map +1 -0
  114. package/dist/bundled-agents/policy-engine-agents/dist/cache/cache-manager.d.ts +77 -0
  115. package/dist/bundled-agents/policy-engine-agents/dist/cache/cache-manager.d.ts.map +1 -0
  116. package/dist/bundled-agents/policy-engine-agents/dist/cache/cache-manager.js +254 -0
  117. package/dist/bundled-agents/policy-engine-agents/dist/cache/cache-manager.js.map +1 -0
  118. package/dist/bundled-agents/policy-engine-agents/dist/cache/l1/memory-cache.d.ts +68 -0
  119. package/dist/bundled-agents/policy-engine-agents/dist/cache/l1/memory-cache.d.ts.map +1 -0
  120. package/dist/bundled-agents/policy-engine-agents/dist/cache/l1/memory-cache.js +170 -0
  121. package/dist/bundled-agents/policy-engine-agents/dist/cache/l1/memory-cache.js.map +1 -0
  122. package/dist/bundled-agents/policy-engine-agents/dist/cache/l2/redis-cache.d.ts +71 -0
  123. package/dist/bundled-agents/policy-engine-agents/dist/cache/l2/redis-cache.d.ts.map +1 -0
  124. package/dist/bundled-agents/policy-engine-agents/dist/cache/l2/redis-cache.js +260 -0
  125. package/dist/bundled-agents/policy-engine-agents/dist/cache/l2/redis-cache.js.map +1 -0
  126. package/dist/bundled-agents/policy-engine-agents/dist/cli/index.d.ts +3 -0
  127. package/dist/bundled-agents/policy-engine-agents/dist/cli/index.d.ts.map +1 -0
  128. package/dist/bundled-agents/policy-engine-agents/dist/cli/index.js +794 -0
  129. package/dist/bundled-agents/policy-engine-agents/dist/cli/index.js.map +1 -0
  130. package/dist/bundled-agents/policy-engine-agents/dist/commands/agent.d.ts +46 -0
  131. package/dist/bundled-agents/policy-engine-agents/dist/commands/agent.d.ts.map +1 -0
  132. package/dist/bundled-agents/policy-engine-agents/dist/commands/agent.js +278 -0
  133. package/dist/bundled-agents/policy-engine-agents/dist/commands/agent.js.map +1 -0
  134. package/dist/bundled-agents/policy-engine-agents/dist/commands/approval-routing.d.ts +69 -0
  135. package/dist/bundled-agents/policy-engine-agents/dist/commands/approval-routing.d.ts.map +1 -0
  136. package/dist/bundled-agents/policy-engine-agents/dist/commands/approval-routing.js +425 -0
  137. package/dist/bundled-agents/policy-engine-agents/dist/commands/approval-routing.js.map +1 -0
  138. package/dist/bundled-agents/policy-engine-agents/dist/commands/index.d.ts +21 -0
  139. package/dist/bundled-agents/policy-engine-agents/dist/commands/index.d.ts.map +1 -0
  140. package/dist/bundled-agents/policy-engine-agents/dist/commands/index.js +50 -0
  141. package/dist/bundled-agents/policy-engine-agents/dist/commands/index.js.map +1 -0
  142. package/dist/bundled-agents/policy-engine-agents/dist/commands/policy.d.ts +65 -0
  143. package/dist/bundled-agents/policy-engine-agents/dist/commands/policy.d.ts.map +1 -0
  144. package/dist/bundled-agents/policy-engine-agents/dist/commands/policy.js +330 -0
  145. package/dist/bundled-agents/policy-engine-agents/dist/commands/policy.js.map +1 -0
  146. package/dist/bundled-agents/policy-engine-agents/dist/core/engine/policy-engine.d.ts +45 -0
  147. package/dist/bundled-agents/policy-engine-agents/dist/core/engine/policy-engine.d.ts.map +1 -0
  148. package/dist/bundled-agents/policy-engine-agents/dist/core/engine/policy-engine.js +210 -0
  149. package/dist/bundled-agents/policy-engine-agents/dist/core/engine/policy-engine.js.map +1 -0
  150. package/dist/bundled-agents/policy-engine-agents/dist/core/evaluator/condition-evaluator.d.ts +64 -0
  151. package/dist/bundled-agents/policy-engine-agents/dist/core/evaluator/condition-evaluator.d.ts.map +1 -0
  152. package/dist/bundled-agents/policy-engine-agents/dist/core/evaluator/condition-evaluator.js +190 -0
  153. package/dist/bundled-agents/policy-engine-agents/dist/core/evaluator/condition-evaluator.js.map +1 -0
  154. package/dist/bundled-agents/policy-engine-agents/dist/core/index.d.ts +13 -0
  155. package/dist/bundled-agents/policy-engine-agents/dist/core/index.d.ts.map +1 -0
  156. package/dist/bundled-agents/policy-engine-agents/dist/core/index.js +29 -0
  157. package/dist/bundled-agents/policy-engine-agents/dist/core/index.js.map +1 -0
  158. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/index.d.ts +17 -0
  159. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/index.d.ts.map +1 -0
  160. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/index.js +65 -0
  161. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/index.js.map +1 -0
  162. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/json-parser.d.ts +9 -0
  163. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/json-parser.d.ts.map +1 -0
  164. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/json-parser.js +65 -0
  165. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/json-parser.js.map +1 -0
  166. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/yaml-parser.d.ts +6 -0
  167. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/yaml-parser.d.ts.map +1 -0
  168. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/yaml-parser.js +69 -0
  169. package/dist/bundled-agents/policy-engine-agents/dist/core/parser/yaml-parser.js.map +1 -0
  170. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/cost-calculator.d.ts +52 -0
  171. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/cost-calculator.d.ts.map +1 -0
  172. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/cost-calculator.js +169 -0
  173. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/cost-calculator.js.map +1 -0
  174. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/index.d.ts +7 -0
  175. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/index.d.ts.map +1 -0
  176. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/index.js +23 -0
  177. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/index.js.map +1 -0
  178. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/pii-detector.d.ts +43 -0
  179. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/pii-detector.d.ts.map +1 -0
  180. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/pii-detector.js +137 -0
  181. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/pii-detector.js.map +1 -0
  182. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/token-counter.d.ts +32 -0
  183. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/token-counter.d.ts.map +1 -0
  184. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/token-counter.js +90 -0
  185. package/dist/bundled-agents/policy-engine-agents/dist/core/primitives/token-counter.js.map +1 -0
  186. package/dist/bundled-agents/policy-engine-agents/dist/core/validator/schema-validator.d.ts +10 -0
  187. package/dist/bundled-agents/policy-engine-agents/dist/core/validator/schema-validator.d.ts.map +1 -0
  188. package/dist/bundled-agents/policy-engine-agents/dist/core/validator/schema-validator.js +106 -0
  189. package/dist/bundled-agents/policy-engine-agents/dist/core/validator/schema-validator.js.map +1 -0
  190. package/dist/bundled-agents/policy-engine-agents/dist/db/client.d.ts +32 -0
  191. package/dist/bundled-agents/policy-engine-agents/dist/db/client.d.ts.map +1 -0
  192. package/dist/bundled-agents/policy-engine-agents/dist/db/client.js +108 -0
  193. package/dist/bundled-agents/policy-engine-agents/dist/db/client.js.map +1 -0
  194. package/dist/bundled-agents/policy-engine-agents/dist/db/migrate.d.ts +45 -0
  195. package/dist/bundled-agents/policy-engine-agents/dist/db/migrate.d.ts.map +1 -0
  196. package/dist/bundled-agents/policy-engine-agents/dist/db/migrate.js +407 -0
  197. package/dist/bundled-agents/policy-engine-agents/dist/db/migrate.js.map +1 -0
  198. package/dist/bundled-agents/policy-engine-agents/dist/db/models/api-key-repository.d.ts +85 -0
  199. package/dist/bundled-agents/policy-engine-agents/dist/db/models/api-key-repository.d.ts.map +1 -0
  200. package/dist/bundled-agents/policy-engine-agents/dist/db/models/api-key-repository.js +248 -0
  201. package/dist/bundled-agents/policy-engine-agents/dist/db/models/api-key-repository.js.map +1 -0
  202. package/dist/bundled-agents/policy-engine-agents/dist/db/models/evaluation-repository.d.ts +65 -0
  203. package/dist/bundled-agents/policy-engine-agents/dist/db/models/evaluation-repository.d.ts.map +1 -0
  204. package/dist/bundled-agents/policy-engine-agents/dist/db/models/evaluation-repository.js +192 -0
  205. package/dist/bundled-agents/policy-engine-agents/dist/db/models/evaluation-repository.js.map +1 -0
  206. package/dist/bundled-agents/policy-engine-agents/dist/db/models/policy-repository.d.ts +32 -0
  207. package/dist/bundled-agents/policy-engine-agents/dist/db/models/policy-repository.d.ts.map +1 -0
  208. package/dist/bundled-agents/policy-engine-agents/dist/db/models/policy-repository.js +163 -0
  209. package/dist/bundled-agents/policy-engine-agents/dist/db/models/policy-repository.js.map +1 -0
  210. package/dist/bundled-agents/policy-engine-agents/dist/execution/context.d.ts +28 -0
  211. package/dist/bundled-agents/policy-engine-agents/dist/execution/context.d.ts.map +1 -0
  212. package/dist/bundled-agents/policy-engine-agents/dist/execution/context.js +46 -0
  213. package/dist/bundled-agents/policy-engine-agents/dist/execution/context.js.map +1 -0
  214. package/dist/bundled-agents/policy-engine-agents/dist/execution/errors.d.ts +21 -0
  215. package/dist/bundled-agents/policy-engine-agents/dist/execution/errors.d.ts.map +1 -0
  216. package/dist/bundled-agents/policy-engine-agents/dist/execution/errors.js +32 -0
  217. package/dist/bundled-agents/policy-engine-agents/dist/execution/errors.js.map +1 -0
  218. package/dist/bundled-agents/policy-engine-agents/dist/execution/executor.d.ts +45 -0
  219. package/dist/bundled-agents/policy-engine-agents/dist/execution/executor.d.ts.map +1 -0
  220. package/dist/bundled-agents/policy-engine-agents/dist/execution/executor.js +96 -0
  221. package/dist/bundled-agents/policy-engine-agents/dist/execution/executor.js.map +1 -0
  222. package/dist/bundled-agents/policy-engine-agents/dist/execution/index.d.ts +21 -0
  223. package/dist/bundled-agents/policy-engine-agents/dist/execution/index.d.ts.map +1 -0
  224. package/dist/bundled-agents/policy-engine-agents/dist/execution/index.js +40 -0
  225. package/dist/bundled-agents/policy-engine-agents/dist/execution/index.js.map +1 -0
  226. package/dist/bundled-agents/policy-engine-agents/dist/execution/middleware.d.ts +22 -0
  227. package/dist/bundled-agents/policy-engine-agents/dist/execution/middleware.d.ts.map +1 -0
  228. package/dist/bundled-agents/policy-engine-agents/dist/execution/middleware.js +49 -0
  229. package/dist/bundled-agents/policy-engine-agents/dist/execution/middleware.js.map +1 -0
  230. package/dist/bundled-agents/policy-engine-agents/dist/execution/spans.d.ts +34 -0
  231. package/dist/bundled-agents/policy-engine-agents/dist/execution/spans.d.ts.map +1 -0
  232. package/dist/bundled-agents/policy-engine-agents/dist/execution/spans.js +82 -0
  233. package/dist/bundled-agents/policy-engine-agents/dist/execution/spans.js.map +1 -0
  234. package/dist/bundled-agents/policy-engine-agents/dist/execution/types.d.ts +86 -0
  235. package/dist/bundled-agents/policy-engine-agents/dist/execution/types.d.ts.map +1 -0
  236. package/dist/bundled-agents/policy-engine-agents/dist/execution/types.js +10 -0
  237. package/dist/bundled-agents/policy-engine-agents/dist/execution/types.js.map +1 -0
  238. package/dist/bundled-agents/policy-engine-agents/dist/functions/handler.d.ts +2 -0
  239. package/dist/bundled-agents/policy-engine-agents/dist/functions/handler.d.ts.map +1 -0
  240. package/dist/bundled-agents/policy-engine-agents/dist/functions/handler.js +207 -0
  241. package/dist/bundled-agents/policy-engine-agents/dist/functions/handler.js.map +1 -0
  242. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/governance-signals.d.ts +234 -0
  243. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/governance-signals.d.ts.map +1 -0
  244. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/governance-signals.js +40 -0
  245. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/governance-signals.js.map +1 -0
  246. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/index.d.ts +5 -0
  247. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/index.d.ts.map +1 -0
  248. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/index.js +21 -0
  249. package/dist/bundled-agents/policy-engine-agents/dist/governance/contracts/index.js.map +1 -0
  250. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/governance-signal-emitter.d.ts +137 -0
  251. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/governance-signal-emitter.d.ts.map +1 -0
  252. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/governance-signal-emitter.js +342 -0
  253. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/governance-signal-emitter.js.map +1 -0
  254. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/index.d.ts +5 -0
  255. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/index.d.ts.map +1 -0
  256. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/index.js +10 -0
  257. package/dist/bundled-agents/policy-engine-agents/dist/governance/emitters/index.js.map +1 -0
  258. package/dist/bundled-agents/policy-engine-agents/dist/governance/index.d.ts +49 -0
  259. package/dist/bundled-agents/policy-engine-agents/dist/governance/index.d.ts.map +1 -0
  260. package/dist/bundled-agents/policy-engine-agents/dist/governance/index.js +91 -0
  261. package/dist/bundled-agents/policy-engine-agents/dist/governance/index.js.map +1 -0
  262. package/dist/bundled-agents/policy-engine-agents/dist/grpc/server.d.ts +8 -0
  263. package/dist/bundled-agents/policy-engine-agents/dist/grpc/server.d.ts.map +1 -0
  264. package/dist/bundled-agents/policy-engine-agents/dist/grpc/server.js +137 -0
  265. package/dist/bundled-agents/policy-engine-agents/dist/grpc/server.js.map +1 -0
  266. package/dist/bundled-agents/policy-engine-agents/dist/grpc/services/policy-service.d.ts +47 -0
  267. package/dist/bundled-agents/policy-engine-agents/dist/grpc/services/policy-service.d.ts.map +1 -0
  268. package/dist/bundled-agents/policy-engine-agents/dist/grpc/services/policy-service.js +353 -0
  269. package/dist/bundled-agents/policy-engine-agents/dist/grpc/services/policy-service.js.map +1 -0
  270. package/dist/bundled-agents/policy-engine-agents/dist/index.d.ts +56 -0
  271. package/dist/bundled-agents/policy-engine-agents/dist/index.d.ts.map +1 -0
  272. package/dist/bundled-agents/policy-engine-agents/dist/index.js +130 -0
  273. package/dist/bundled-agents/policy-engine-agents/dist/index.js.map +1 -0
  274. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/client.d.ts +115 -0
  275. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/client.d.ts.map +1 -0
  276. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/client.js +256 -0
  277. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/client.js.map +1 -0
  278. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/index.d.ts +6 -0
  279. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/index.d.ts.map +1 -0
  280. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/index.js +22 -0
  281. package/dist/bundled-agents/policy-engine-agents/dist/integrations/config-manager/index.js.map +1 -0
  282. package/dist/bundled-agents/policy-engine-agents/dist/integrations/costops/client.d.ts +69 -0
  283. package/dist/bundled-agents/policy-engine-agents/dist/integrations/costops/client.d.ts.map +1 -0
  284. package/dist/bundled-agents/policy-engine-agents/dist/integrations/costops/client.js +179 -0
  285. package/dist/bundled-agents/policy-engine-agents/dist/integrations/costops/client.js.map +1 -0
  286. package/dist/bundled-agents/policy-engine-agents/dist/integrations/edge/client.d.ts +57 -0
  287. package/dist/bundled-agents/policy-engine-agents/dist/integrations/edge/client.d.ts.map +1 -0
  288. package/dist/bundled-agents/policy-engine-agents/dist/integrations/edge/client.js +191 -0
  289. package/dist/bundled-agents/policy-engine-agents/dist/integrations/edge/client.js.map +1 -0
  290. package/dist/bundled-agents/policy-engine-agents/dist/integrations/governance/client.d.ts +63 -0
  291. package/dist/bundled-agents/policy-engine-agents/dist/integrations/governance/client.d.ts.map +1 -0
  292. package/dist/bundled-agents/policy-engine-agents/dist/integrations/governance/client.js +163 -0
  293. package/dist/bundled-agents/policy-engine-agents/dist/integrations/governance/client.js.map +1 -0
  294. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/client.d.ts +174 -0
  295. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/client.d.ts.map +1 -0
  296. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/client.js +243 -0
  297. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/client.js.map +1 -0
  298. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/index.d.ts +6 -0
  299. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/index.d.ts.map +1 -0
  300. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/index.js +22 -0
  301. package/dist/bundled-agents/policy-engine-agents/dist/integrations/observatory/index.js.map +1 -0
  302. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/client.d.ts +164 -0
  303. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/client.d.ts.map +1 -0
  304. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/client.js +293 -0
  305. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/client.js.map +1 -0
  306. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/index.d.ts +7 -0
  307. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/index.d.ts.map +1 -0
  308. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/index.js +23 -0
  309. package/dist/bundled-agents/policy-engine-agents/dist/integrations/ruvector-service/index.js.map +1 -0
  310. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/client.d.ts +94 -0
  311. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/client.d.ts.map +1 -0
  312. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/client.js +174 -0
  313. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/client.js.map +1 -0
  314. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/index.d.ts +6 -0
  315. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/index.d.ts.map +1 -0
  316. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/index.js +22 -0
  317. package/dist/bundled-agents/policy-engine-agents/dist/integrations/schema-registry/index.js.map +1 -0
  318. package/dist/bundled-agents/policy-engine-agents/dist/integrations/shield/client.d.ts +40 -0
  319. package/dist/bundled-agents/policy-engine-agents/dist/integrations/shield/client.d.ts.map +1 -0
  320. package/dist/bundled-agents/policy-engine-agents/dist/integrations/shield/client.js +125 -0
  321. package/dist/bundled-agents/policy-engine-agents/dist/integrations/shield/client.js.map +1 -0
  322. package/dist/bundled-agents/policy-engine-agents/dist/observability/metrics.d.ts +66 -0
  323. package/dist/bundled-agents/policy-engine-agents/dist/observability/metrics.d.ts.map +1 -0
  324. package/dist/bundled-agents/policy-engine-agents/dist/observability/metrics.js +197 -0
  325. package/dist/bundled-agents/policy-engine-agents/dist/observability/metrics.js.map +1 -0
  326. package/dist/bundled-agents/policy-engine-agents/dist/observability/tracing.d.ts +52 -0
  327. package/dist/bundled-agents/policy-engine-agents/dist/observability/tracing.d.ts.map +1 -0
  328. package/dist/bundled-agents/policy-engine-agents/dist/observability/tracing.js +219 -0
  329. package/dist/bundled-agents/policy-engine-agents/dist/observability/tracing.js.map +1 -0
  330. package/dist/bundled-agents/policy-engine-agents/dist/security/agentics-identity.d.ts +69 -0
  331. package/dist/bundled-agents/policy-engine-agents/dist/security/agentics-identity.d.ts.map +1 -0
  332. package/dist/bundled-agents/policy-engine-agents/dist/security/agentics-identity.js +280 -0
  333. package/dist/bundled-agents/policy-engine-agents/dist/security/agentics-identity.js.map +1 -0
  334. package/dist/bundled-agents/policy-engine-agents/dist/security/audit-trail.d.ts +82 -0
  335. package/dist/bundled-agents/policy-engine-agents/dist/security/audit-trail.d.ts.map +1 -0
  336. package/dist/bundled-agents/policy-engine-agents/dist/security/audit-trail.js +234 -0
  337. package/dist/bundled-agents/policy-engine-agents/dist/security/audit-trail.js.map +1 -0
  338. package/dist/bundled-agents/policy-engine-agents/dist/security/index.d.ts +18 -0
  339. package/dist/bundled-agents/policy-engine-agents/dist/security/index.d.ts.map +1 -0
  340. package/dist/bundled-agents/policy-engine-agents/dist/security/index.js +71 -0
  341. package/dist/bundled-agents/policy-engine-agents/dist/security/index.js.map +1 -0
  342. package/dist/bundled-agents/policy-engine-agents/dist/security/metrics.d.ts +96 -0
  343. package/dist/bundled-agents/policy-engine-agents/dist/security/metrics.d.ts.map +1 -0
  344. package/dist/bundled-agents/policy-engine-agents/dist/security/metrics.js +189 -0
  345. package/dist/bundled-agents/policy-engine-agents/dist/security/metrics.js.map +1 -0
  346. package/dist/bundled-agents/policy-engine-agents/dist/security/policy-governance.d.ts +69 -0
  347. package/dist/bundled-agents/policy-engine-agents/dist/security/policy-governance.d.ts.map +1 -0
  348. package/dist/bundled-agents/policy-engine-agents/dist/security/policy-governance.js +327 -0
  349. package/dist/bundled-agents/policy-engine-agents/dist/security/policy-governance.js.map +1 -0
  350. package/dist/bundled-agents/policy-engine-agents/dist/security/rate-limiter.d.ts +40 -0
  351. package/dist/bundled-agents/policy-engine-agents/dist/security/rate-limiter.d.ts.map +1 -0
  352. package/dist/bundled-agents/policy-engine-agents/dist/security/rate-limiter.js +147 -0
  353. package/dist/bundled-agents/policy-engine-agents/dist/security/rate-limiter.js.map +1 -0
  354. package/dist/bundled-agents/policy-engine-agents/dist/security/versioned-policy-repository.d.ts +70 -0
  355. package/dist/bundled-agents/policy-engine-agents/dist/security/versioned-policy-repository.d.ts.map +1 -0
  356. package/dist/bundled-agents/policy-engine-agents/dist/security/versioned-policy-repository.js +336 -0
  357. package/dist/bundled-agents/policy-engine-agents/dist/security/versioned-policy-repository.js.map +1 -0
  358. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/builder.d.ts +80 -0
  359. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/builder.d.ts.map +1 -0
  360. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/builder.js +756 -0
  361. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/builder.js.map +1 -0
  362. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/index.d.ts +7 -0
  363. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/index.d.ts.map +1 -0
  364. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/index.js +23 -0
  365. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/index.js.map +1 -0
  366. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/types.d.ts +162 -0
  367. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/types.d.ts.map +1 -0
  368. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/types.js +7 -0
  369. package/dist/bundled-agents/policy-engine-agents/dist/synthesis/types.js.map +1 -0
  370. package/dist/bundled-agents/policy-engine-agents/dist/test/setup.d.ts +15 -0
  371. package/dist/bundled-agents/policy-engine-agents/dist/test/setup.d.ts.map +1 -0
  372. package/dist/bundled-agents/policy-engine-agents/dist/test/setup.js +138 -0
  373. package/dist/bundled-agents/policy-engine-agents/dist/test/setup.js.map +1 -0
  374. package/dist/bundled-agents/policy-engine-agents/dist/types/config.d.ts +69 -0
  375. package/dist/bundled-agents/policy-engine-agents/dist/types/config.d.ts.map +1 -0
  376. package/dist/bundled-agents/policy-engine-agents/dist/types/config.js +6 -0
  377. package/dist/bundled-agents/policy-engine-agents/dist/types/config.js.map +1 -0
  378. package/dist/bundled-agents/policy-engine-agents/dist/types/policy.d.ts +152 -0
  379. package/dist/bundled-agents/policy-engine-agents/dist/types/policy.d.ts.map +1 -0
  380. package/dist/bundled-agents/policy-engine-agents/dist/types/policy.js +38 -0
  381. package/dist/bundled-agents/policy-engine-agents/dist/types/policy.js.map +1 -0
  382. package/dist/bundled-agents/policy-engine-agents/dist/utils/config.d.ts +4 -0
  383. package/dist/bundled-agents/policy-engine-agents/dist/utils/config.d.ts.map +1 -0
  384. package/dist/bundled-agents/policy-engine-agents/dist/utils/config.js +71 -0
  385. package/dist/bundled-agents/policy-engine-agents/dist/utils/config.js.map +1 -0
  386. package/dist/bundled-agents/policy-engine-agents/dist/utils/errors.d.ts +37 -0
  387. package/dist/bundled-agents/policy-engine-agents/dist/utils/errors.d.ts.map +1 -0
  388. package/dist/bundled-agents/policy-engine-agents/dist/utils/errors.js +84 -0
  389. package/dist/bundled-agents/policy-engine-agents/dist/utils/errors.js.map +1 -0
  390. package/dist/bundled-agents/policy-engine-agents/dist/utils/logger.d.ts +8 -0
  391. package/dist/bundled-agents/policy-engine-agents/dist/utils/logger.d.ts.map +1 -0
  392. package/dist/bundled-agents/policy-engine-agents/dist/utils/logger.js +36 -0
  393. package/dist/bundled-agents/policy-engine-agents/dist/utils/logger.js.map +1 -0
  394. package/dist/bundled-agents/policy-engine-agents/package-lock.json +15388 -0
  395. package/dist/bundled-agents/registry-agents/functions/src/claude.ts +71 -0
  396. package/dist/bundled-agents/schema-registry-agents/package-lock.json +3 -0
  397. package/dist/bundled-agents/sentinel-agents/package-lock.json +2 -438
  398. package/dist/bundled-agents/simulator-agents/package-lock.json +0 -428
  399. package/dist/bundled-agents/test-bench-agents/package-lock.json +0 -3
  400. package/package.json +1 -1
@@ -0,0 +1,189 @@
1
+ "use strict";
2
+ /**
3
+ * Enterprise Metrics Module
4
+ *
5
+ * Provides structured metrics for:
6
+ * - Evaluation latency
7
+ * - Policy hit rates
8
+ * - Deny vs allow ratios
9
+ * - Validation failures
10
+ */
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.requestDuration = exports.rateLimitHits = exports.authAttempts = exports.activePolicies = exports.policyMutations = exports.governanceViolations = exports.validationFailures = exports.decisionCounter = exports.evaluationCounter = exports.evaluationLatency = exports.metricsRegistry = void 0;
13
+ exports.recordEvaluation = recordEvaluation;
14
+ exports.recordDecision = recordDecision;
15
+ exports.recordValidationFailure = recordValidationFailure;
16
+ exports.recordGovernanceViolation = recordGovernanceViolation;
17
+ exports.recordMutation = recordMutation;
18
+ exports.updateActivePolicyCount = updateActivePolicyCount;
19
+ exports.recordAuthAttempt = recordAuthAttempt;
20
+ exports.recordRateLimitHit = recordRateLimitHit;
21
+ exports.recordRequestDuration = recordRequestDuration;
22
+ exports.getMetrics = getMetrics;
23
+ exports.getMetricsJson = getMetricsJson;
24
+ const prom_client_1 = require("prom-client");
25
+ // Create a dedicated registry for policy engine metrics
26
+ exports.metricsRegistry = new prom_client_1.Registry();
27
+ // Add default metrics
28
+ const prom_client_2 = require("prom-client");
29
+ (0, prom_client_2.collectDefaultMetrics)({ register: exports.metricsRegistry });
30
+ /**
31
+ * Evaluation latency histogram
32
+ */
33
+ exports.evaluationLatency = new prom_client_1.Histogram({
34
+ name: 'policy_evaluation_latency_ms',
35
+ help: 'Policy evaluation latency in milliseconds',
36
+ labelNames: ['policy_id', 'decision', 'cached'],
37
+ buckets: [1, 5, 10, 25, 50, 100, 250, 500, 1000],
38
+ registers: [exports.metricsRegistry],
39
+ });
40
+ /**
41
+ * Policy evaluation counter
42
+ */
43
+ exports.evaluationCounter = new prom_client_1.Counter({
44
+ name: 'policy_evaluations_total',
45
+ help: 'Total number of policy evaluations',
46
+ labelNames: ['policy_id', 'decision', 'namespace'],
47
+ registers: [exports.metricsRegistry],
48
+ });
49
+ /**
50
+ * Deny vs Allow counter
51
+ */
52
+ exports.decisionCounter = new prom_client_1.Counter({
53
+ name: 'policy_decisions_total',
54
+ help: 'Total policy decisions by type',
55
+ labelNames: ['decision', 'namespace', 'policy_type'],
56
+ registers: [exports.metricsRegistry],
57
+ });
58
+ /**
59
+ * Validation failure counter
60
+ */
61
+ exports.validationFailures = new prom_client_1.Counter({
62
+ name: 'policy_validation_failures_total',
63
+ help: 'Total number of policy validation failures',
64
+ labelNames: ['violation_type', 'severity', 'namespace'],
65
+ registers: [exports.metricsRegistry],
66
+ });
67
+ /**
68
+ * Governance violation counter
69
+ */
70
+ exports.governanceViolations = new prom_client_1.Counter({
71
+ name: 'policy_governance_violations_total',
72
+ help: 'Total number of governance violations',
73
+ labelNames: ['violation_type', 'policy_type'],
74
+ registers: [exports.metricsRegistry],
75
+ });
76
+ /**
77
+ * Policy mutation counter
78
+ */
79
+ exports.policyMutations = new prom_client_1.Counter({
80
+ name: 'policy_mutations_total',
81
+ help: 'Total number of policy mutations',
82
+ labelNames: ['action', 'namespace', 'actor_type'],
83
+ registers: [exports.metricsRegistry],
84
+ });
85
+ /**
86
+ * Active policies gauge
87
+ */
88
+ exports.activePolicies = new prom_client_1.Gauge({
89
+ name: 'policy_active_count',
90
+ help: 'Number of currently active policies',
91
+ labelNames: ['namespace', 'policy_type'],
92
+ registers: [exports.metricsRegistry],
93
+ });
94
+ /**
95
+ * Authentication attempts counter
96
+ */
97
+ exports.authAttempts = new prom_client_1.Counter({
98
+ name: 'policy_auth_attempts_total',
99
+ help: 'Total authentication attempts',
100
+ labelNames: ['result', 'identity_type'],
101
+ registers: [exports.metricsRegistry],
102
+ });
103
+ /**
104
+ * Rate limit hits counter
105
+ */
106
+ exports.rateLimitHits = new prom_client_1.Counter({
107
+ name: 'policy_rate_limit_hits_total',
108
+ help: 'Total rate limit hits',
109
+ labelNames: ['endpoint', 'identity'],
110
+ registers: [exports.metricsRegistry],
111
+ });
112
+ /**
113
+ * Request duration histogram
114
+ */
115
+ exports.requestDuration = new prom_client_1.Histogram({
116
+ name: 'policy_request_duration_ms',
117
+ help: 'HTTP request duration in milliseconds',
118
+ labelNames: ['method', 'path', 'status'],
119
+ buckets: [5, 10, 25, 50, 100, 250, 500, 1000, 2500, 5000],
120
+ registers: [exports.metricsRegistry],
121
+ });
122
+ /**
123
+ * Record an evaluation metric
124
+ */
125
+ function recordEvaluation(policyId, decision, namespace, latencyMs, cached) {
126
+ exports.evaluationLatency.observe({ policy_id: policyId, decision, cached: String(cached) }, latencyMs);
127
+ exports.evaluationCounter.inc({ policy_id: policyId, decision, namespace });
128
+ }
129
+ /**
130
+ * Record a decision metric
131
+ */
132
+ function recordDecision(decision, namespace, policyType) {
133
+ exports.decisionCounter.inc({ decision, namespace, policy_type: policyType });
134
+ }
135
+ /**
136
+ * Record a validation failure
137
+ */
138
+ function recordValidationFailure(violationType, severity, namespace) {
139
+ exports.validationFailures.inc({ violation_type: violationType, severity, namespace });
140
+ }
141
+ /**
142
+ * Record a governance violation
143
+ */
144
+ function recordGovernanceViolation(violationType, policyType) {
145
+ exports.governanceViolations.inc({ violation_type: violationType, policy_type: policyType });
146
+ }
147
+ /**
148
+ * Record a policy mutation
149
+ */
150
+ function recordMutation(action, namespace, actorType) {
151
+ exports.policyMutations.inc({ action, namespace, actor_type: actorType });
152
+ }
153
+ /**
154
+ * Update active policy count
155
+ */
156
+ function updateActivePolicyCount(namespace, policyType, count) {
157
+ exports.activePolicies.set({ namespace, policy_type: policyType }, count);
158
+ }
159
+ /**
160
+ * Record authentication attempt
161
+ */
162
+ function recordAuthAttempt(result, identityType) {
163
+ exports.authAttempts.inc({ result, identity_type: identityType });
164
+ }
165
+ /**
166
+ * Record rate limit hit
167
+ */
168
+ function recordRateLimitHit(endpoint, identity) {
169
+ exports.rateLimitHits.inc({ endpoint, identity });
170
+ }
171
+ /**
172
+ * Record request duration
173
+ */
174
+ function recordRequestDuration(method, path, status, durationMs) {
175
+ exports.requestDuration.observe({ method, path, status: String(status) }, durationMs);
176
+ }
177
+ /**
178
+ * Get metrics in Prometheus format
179
+ */
180
+ async function getMetrics() {
181
+ return exports.metricsRegistry.metrics();
182
+ }
183
+ /**
184
+ * Get metrics as JSON (for debugging)
185
+ */
186
+ async function getMetricsJson() {
187
+ return exports.metricsRegistry.getMetricsAsJSON();
188
+ }
189
+ //# sourceMappingURL=metrics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../src/security/metrics.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,69 @@
1
+ /**
2
+ * Policy Governance Module
3
+ *
4
+ * Enforces enterprise governance rules:
5
+ * - Fail-closed validation
6
+ * - Production safety checks
7
+ * - Approval requirements for security/compliance policies
8
+ */
9
+ import { Policy, PolicyStatus } from '../types/policy';
10
+ /**
11
+ * Governance violation types
12
+ */
13
+ export type GovernanceViolationType = 'MISSING_CONDITIONS' | 'CONFLICTING_RULES' | 'DENY_WITHOUT_SCOPE' | 'MISSING_ENVIRONMENT' | 'MISSING_APPROVAL' | 'INVALID_RULE_STRUCTURE' | 'CRITICAL_RESOURCE_DENY';
14
+ /**
15
+ * Governance violation details
16
+ */
17
+ export interface GovernanceViolation {
18
+ type: GovernanceViolationType;
19
+ severity: 'error' | 'critical';
20
+ message: string;
21
+ ruleId?: string;
22
+ ruleName?: string;
23
+ details?: Record<string, unknown>;
24
+ }
25
+ /**
26
+ * Governance check result
27
+ */
28
+ export interface GovernanceCheckResult {
29
+ valid: boolean;
30
+ violations: GovernanceViolation[];
31
+ requiresApproval: boolean;
32
+ approvalReason?: string;
33
+ riskLevel: 'low' | 'medium' | 'high' | 'critical';
34
+ }
35
+ /**
36
+ * Policy type classification
37
+ */
38
+ export type PolicyType = 'security' | 'compliance' | 'cost' | 'operational' | 'general';
39
+ /**
40
+ * Detect policy type from tags and namespace
41
+ */
42
+ export declare function detectPolicyType(policy: Policy): PolicyType;
43
+ /**
44
+ * Check if policy targets production environment
45
+ */
46
+ export declare function isProductionPolicy(policy: Policy): boolean;
47
+ /**
48
+ * Main governance check function
49
+ * Enforces fail-closed validation
50
+ */
51
+ export declare function validatePolicyGovernance(policy: Policy, options?: {
52
+ isEnabling?: boolean;
53
+ hasApproval?: boolean;
54
+ approvedBy?: string;
55
+ }): GovernanceCheckResult;
56
+ /**
57
+ * Enforce governance - throws if validation fails
58
+ * Use this in mutation endpoints for fail-closed behavior
59
+ */
60
+ export declare function enforceGovernance(policy: Policy, options?: {
61
+ isEnabling?: boolean;
62
+ hasApproval?: boolean;
63
+ approvedBy?: string;
64
+ }): void;
65
+ /**
66
+ * Check if a status change requires approval
67
+ */
68
+ export declare function requiresApprovalForStatusChange(policy: Policy, oldStatus: PolicyStatus, newStatus: PolicyStatus): boolean;
69
+ //# sourceMappingURL=policy-governance.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy-governance.d.ts","sourceRoot":"","sources":["../../src/security/policy-governance.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,MAAM,EAAc,YAAY,EAAmC,MAAM,iBAAiB,CAAC;AAIpG;;GAEG;AACH,MAAM,MAAM,uBAAuB,GAC/B,oBAAoB,GACpB,mBAAmB,GACnB,oBAAoB,GACpB,qBAAqB,GACrB,kBAAkB,GAClB,wBAAwB,GACxB,wBAAwB,CAAC;AAE7B;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,uBAAuB,CAAC;IAC9B,QAAQ,EAAE,OAAO,GAAG,UAAU,CAAC;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,KAAK,EAAE,OAAO,CAAC;IACf,UAAU,EAAE,mBAAmB,EAAE,CAAC;IAClC,gBAAgB,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,SAAS,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;CACnD;AAED;;GAEG;AACH,MAAM,MAAM,UAAU,GAAG,UAAU,GAAG,YAAY,GAAG,MAAM,GAAG,aAAa,GAAG,SAAS,CAAC;AAExF;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,CAyB3D;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAiB1D;AA6MD;;;GAGG;AACH,wBAAgB,wBAAwB,CACtC,MAAM,EAAE,MAAM,EACd,OAAO,GAAE;IACP,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;CAChB,GACL,qBAAqB,CAyEvB;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,CAC/B,MAAM,EAAE,MAAM,EACd,OAAO,GAAE;IACP,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;CAChB,GACL,IAAI,CAeN;AAED;;GAEG;AACH,wBAAgB,+BAA+B,CAC7C,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,YAAY,EACvB,SAAS,EAAE,YAAY,GACtB,OAAO,CAUT"}
@@ -0,0 +1,327 @@
1
+ "use strict";
2
+ /**
3
+ * Policy Governance Module
4
+ *
5
+ * Enforces enterprise governance rules:
6
+ * - Fail-closed validation
7
+ * - Production safety checks
8
+ * - Approval requirements for security/compliance policies
9
+ */
10
+ var __importDefault = (this && this.__importDefault) || function (mod) {
11
+ return (mod && mod.__esModule) ? mod : { "default": mod };
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.detectPolicyType = detectPolicyType;
15
+ exports.isProductionPolicy = isProductionPolicy;
16
+ exports.validatePolicyGovernance = validatePolicyGovernance;
17
+ exports.enforceGovernance = enforceGovernance;
18
+ exports.requiresApprovalForStatusChange = requiresApprovalForStatusChange;
19
+ const policy_1 = require("../types/policy");
20
+ const errors_1 = require("@utils/errors");
21
+ const logger_1 = __importDefault(require("@utils/logger"));
22
+ /**
23
+ * Detect policy type from tags and namespace
24
+ */
25
+ function detectPolicyType(policy) {
26
+ const tags = policy.metadata.tags?.map(t => t.toLowerCase()) || [];
27
+ const namespace = policy.metadata.namespace.toLowerCase();
28
+ const name = policy.metadata.name.toLowerCase();
29
+ if (tags.includes('security') || namespace.includes('security') || name.includes('security')) {
30
+ return 'security';
31
+ }
32
+ if (tags.includes('compliance') || namespace.includes('compliance') || name.includes('audit')) {
33
+ return 'compliance';
34
+ }
35
+ if (tags.includes('cost') || namespace.includes('cost') || name.includes('budget')) {
36
+ return 'cost';
37
+ }
38
+ if (tags.includes('operational') || namespace.includes('ops')) {
39
+ return 'operational';
40
+ }
41
+ // Check rules for security indicators
42
+ const hasDenyRules = policy.rules.some(r => r.action.decision === policy_1.DecisionType.DENY);
43
+ if (hasDenyRules) {
44
+ return 'security';
45
+ }
46
+ return 'general';
47
+ }
48
+ /**
49
+ * Check if policy targets production environment
50
+ */
51
+ function isProductionPolicy(policy) {
52
+ const namespace = policy.metadata.namespace.toLowerCase();
53
+ const tags = policy.metadata.tags?.map(t => t.toLowerCase()) || [];
54
+ // Explicit production indicators
55
+ if (namespace.includes('prod') || tags.includes('production') || tags.includes('prod')) {
56
+ return true;
57
+ }
58
+ // Policies without explicit environment are implicitly production
59
+ const hasExplicitEnv = tags.some(t => ['dev', 'development', 'staging', 'test', 'qa'].includes(t)) || ['dev', 'development', 'staging', 'test', 'qa'].some(e => namespace.includes(e));
60
+ return !hasExplicitEnv;
61
+ }
62
+ /**
63
+ * Check if a rule targets critical resources
64
+ */
65
+ function isCriticalResource(rule) {
66
+ const criticalPatterns = [
67
+ 'admin', 'root', 'system', 'database', 'credentials',
68
+ 'secret', 'key', 'token', 'password', 'auth', 'pii',
69
+ 'financial', 'payment', 'ssn', 'health', 'hipaa',
70
+ ];
71
+ const ruleName = rule.name.toLowerCase();
72
+ const ruleDesc = (rule.description || '').toLowerCase();
73
+ const conditionField = rule.condition.field?.toLowerCase() || '';
74
+ return criticalPatterns.some(pattern => ruleName.includes(pattern) ||
75
+ ruleDesc.includes(pattern) ||
76
+ conditionField.includes(pattern));
77
+ }
78
+ /**
79
+ * Validate rule has proper conditions (fail-closed)
80
+ */
81
+ function validateRuleConditions(rule) {
82
+ const violations = [];
83
+ // Rule must have a condition
84
+ if (!rule.condition) {
85
+ violations.push({
86
+ type: 'MISSING_CONDITIONS',
87
+ severity: 'critical',
88
+ message: `Rule '${rule.name}' has no conditions - fail-closed requires explicit conditions`,
89
+ ruleId: rule.id,
90
+ ruleName: rule.name,
91
+ });
92
+ return violations;
93
+ }
94
+ // Non-composite conditions must have a field
95
+ const isComposite = [policy_1.ConditionOperator.AND, policy_1.ConditionOperator.OR, policy_1.ConditionOperator.NOT]
96
+ .includes(rule.condition.operator);
97
+ if (!isComposite && !rule.condition.field) {
98
+ violations.push({
99
+ type: 'MISSING_CONDITIONS',
100
+ severity: 'critical',
101
+ message: `Rule '${rule.name}' has no condition field - ambiguous evaluation`,
102
+ ruleId: rule.id,
103
+ ruleName: rule.name,
104
+ });
105
+ }
106
+ // Composite conditions must have nested conditions
107
+ if (isComposite && (!rule.condition.conditions || rule.condition.conditions.length === 0)) {
108
+ violations.push({
109
+ type: 'INVALID_RULE_STRUCTURE',
110
+ severity: 'critical',
111
+ message: `Rule '${rule.name}' has composite operator but no nested conditions`,
112
+ ruleId: rule.id,
113
+ ruleName: rule.name,
114
+ });
115
+ }
116
+ return violations;
117
+ }
118
+ /**
119
+ * Validate deny rules have proper scope
120
+ */
121
+ function validateDenyRuleScope(rule, policy) {
122
+ const violations = [];
123
+ if (rule.action.decision !== policy_1.DecisionType.DENY) {
124
+ return violations;
125
+ }
126
+ // Deny rules on critical resources need explicit environment
127
+ if (isCriticalResource(rule)) {
128
+ const hasExplicitEnv = policy.metadata.tags?.some(t => ['production', 'staging', 'development', 'test'].includes(t.toLowerCase()));
129
+ if (!hasExplicitEnv) {
130
+ violations.push({
131
+ type: 'DENY_WITHOUT_SCOPE',
132
+ severity: 'critical',
133
+ message: `Deny rule '${rule.name}' on critical resource requires explicit environment tag`,
134
+ ruleId: rule.id,
135
+ ruleName: rule.name,
136
+ details: { resource: 'critical' },
137
+ });
138
+ }
139
+ // Check for explicit scope in condition
140
+ const hasExplicitScope = rule.condition.field?.includes('scope') ||
141
+ rule.condition.field?.includes('namespace') ||
142
+ rule.condition.field?.includes('environment');
143
+ if (!hasExplicitScope && !hasExplicitEnv) {
144
+ violations.push({
145
+ type: 'CRITICAL_RESOURCE_DENY',
146
+ severity: 'critical',
147
+ message: `Deny rule '${rule.name}' on critical resource requires explicit scope condition`,
148
+ ruleId: rule.id,
149
+ ruleName: rule.name,
150
+ });
151
+ }
152
+ }
153
+ return violations;
154
+ }
155
+ /**
156
+ * Detect conflicting rules
157
+ */
158
+ function detectConflictingRules(rules) {
159
+ const violations = [];
160
+ // Group rules by condition field
161
+ const rulesByField = new Map();
162
+ for (const rule of rules) {
163
+ if (rule.enabled === false)
164
+ continue;
165
+ const field = rule.condition.field || 'composite';
166
+ if (!rulesByField.has(field)) {
167
+ rulesByField.set(field, []);
168
+ }
169
+ rulesByField.get(field).push(rule);
170
+ }
171
+ // Check for conflicting decisions on same field
172
+ for (const [field, fieldRules] of rulesByField) {
173
+ if (fieldRules.length < 2)
174
+ continue;
175
+ const allowRules = fieldRules.filter(r => r.action.decision === policy_1.DecisionType.ALLOW);
176
+ const denyRules = fieldRules.filter(r => r.action.decision === policy_1.DecisionType.DENY);
177
+ if (allowRules.length > 0 && denyRules.length > 0) {
178
+ // Check if they have overlapping conditions (simplified check)
179
+ for (const allow of allowRules) {
180
+ for (const deny of denyRules) {
181
+ if (allow.condition.value === deny.condition.value) {
182
+ violations.push({
183
+ type: 'CONFLICTING_RULES',
184
+ severity: 'critical',
185
+ message: `Rules '${allow.name}' and '${deny.name}' have conflicting ALLOW/DENY on same condition`,
186
+ details: {
187
+ field,
188
+ allowRule: allow.id,
189
+ denyRule: deny.id,
190
+ },
191
+ });
192
+ }
193
+ }
194
+ }
195
+ }
196
+ }
197
+ return violations;
198
+ }
199
+ /**
200
+ * Check if policy requires approval
201
+ */
202
+ function checkApprovalRequirement(policy, policyType, isEnabling) {
203
+ // Security policies always require approval to enable
204
+ if (policyType === 'security' && isEnabling) {
205
+ return {
206
+ required: true,
207
+ reason: 'Security policies require approval before enabling',
208
+ };
209
+ }
210
+ // Compliance policies always require approval to enable
211
+ if (policyType === 'compliance' && isEnabling) {
212
+ return {
213
+ required: true,
214
+ reason: 'Compliance policies require approval before enabling',
215
+ };
216
+ }
217
+ // Production policies with deny rules require approval
218
+ if (isProductionPolicy(policy) && isEnabling) {
219
+ const hasDenyRules = policy.rules.some(r => r.action.decision === policy_1.DecisionType.DENY && r.enabled !== false);
220
+ if (hasDenyRules) {
221
+ return {
222
+ required: true,
223
+ reason: 'Production policies with deny rules require approval',
224
+ };
225
+ }
226
+ }
227
+ return { required: false };
228
+ }
229
+ /**
230
+ * Main governance check function
231
+ * Enforces fail-closed validation
232
+ */
233
+ function validatePolicyGovernance(policy, options = {}) {
234
+ const violations = [];
235
+ const policyType = detectPolicyType(policy);
236
+ const isProduction = isProductionPolicy(policy);
237
+ // 1. Validate all rules have proper conditions (fail-closed)
238
+ for (const rule of policy.rules) {
239
+ if (rule.enabled === false)
240
+ continue;
241
+ violations.push(...validateRuleConditions(rule));
242
+ violations.push(...validateDenyRuleScope(rule, policy));
243
+ }
244
+ // 2. Detect conflicting rules
245
+ violations.push(...detectConflictingRules(policy.rules));
246
+ // 3. Check for production environment requirements
247
+ if (isProduction && !policy.metadata.tags?.some(t => t.toLowerCase() === 'production')) {
248
+ // Implicitly production - require explicit marking for clarity
249
+ logger_1.default.warn({
250
+ policyId: policy.metadata.id,
251
+ namespace: policy.metadata.namespace,
252
+ }, 'Policy implicitly affects production - consider adding explicit production tag');
253
+ }
254
+ // 4. Check approval requirements
255
+ const approvalCheck = checkApprovalRequirement(policy, policyType, options.isEnabling || false);
256
+ if (approvalCheck.required && !options.hasApproval) {
257
+ violations.push({
258
+ type: 'MISSING_APPROVAL',
259
+ severity: 'critical',
260
+ message: approvalCheck.reason || 'This policy change requires approval',
261
+ });
262
+ }
263
+ // 5. Calculate risk level
264
+ const criticalCount = violations.filter(v => v.severity === 'critical').length;
265
+ const errorCount = violations.filter(v => v.severity === 'error').length;
266
+ let riskLevel;
267
+ if (criticalCount > 0) {
268
+ riskLevel = 'critical';
269
+ }
270
+ else if (errorCount > 0 || policyType === 'security') {
271
+ riskLevel = 'high';
272
+ }
273
+ else if (isProduction || policyType === 'compliance') {
274
+ riskLevel = 'medium';
275
+ }
276
+ else {
277
+ riskLevel = 'low';
278
+ }
279
+ const result = {
280
+ valid: violations.length === 0,
281
+ violations,
282
+ requiresApproval: approvalCheck.required,
283
+ approvalReason: approvalCheck.reason,
284
+ riskLevel,
285
+ };
286
+ if (!result.valid) {
287
+ logger_1.default.warn({
288
+ policyId: policy.metadata.id,
289
+ policyName: policy.metadata.name,
290
+ violationCount: violations.length,
291
+ violations: violations.map(v => ({
292
+ type: v.type,
293
+ severity: v.severity,
294
+ message: v.message,
295
+ })),
296
+ }, 'Policy governance validation failed');
297
+ }
298
+ return result;
299
+ }
300
+ /**
301
+ * Enforce governance - throws if validation fails
302
+ * Use this in mutation endpoints for fail-closed behavior
303
+ */
304
+ function enforceGovernance(policy, options = {}) {
305
+ const result = validatePolicyGovernance(policy, options);
306
+ if (!result.valid) {
307
+ const criticalViolations = result.violations.filter(v => v.severity === 'critical');
308
+ throw new errors_1.PolicyValidationError(`Governance validation failed: ${criticalViolations.length} critical violation(s)`, {
309
+ violations: result.violations,
310
+ riskLevel: result.riskLevel,
311
+ requiresApproval: result.requiresApproval,
312
+ });
313
+ }
314
+ }
315
+ /**
316
+ * Check if a status change requires approval
317
+ */
318
+ function requiresApprovalForStatusChange(policy, oldStatus, newStatus) {
319
+ // Enabling a policy (draft/deprecated -> active) requires approval for security/compliance
320
+ const isEnabling = newStatus === policy_1.PolicyStatus.ACTIVE && oldStatus !== policy_1.PolicyStatus.ACTIVE;
321
+ if (!isEnabling) {
322
+ return false;
323
+ }
324
+ const policyType = detectPolicyType(policy);
325
+ return policyType === 'security' || policyType === 'compliance';
326
+ }
327
+ //# sourceMappingURL=policy-governance.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy-governance.js","sourceRoot":"","sources":["../../src/security/policy-governance.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * Post-Authentication Rate Limiter
3
+ *
4
+ * Rate limiting that applies AFTER authentication.
5
+ * Limits are per-identity, not per-IP.
6
+ */
7
+ import { Response, NextFunction } from 'express';
8
+ import { AuthenticatedRequest } from './agentics-identity';
9
+ /**
10
+ * Rate limit configuration
11
+ */
12
+ interface RateLimitConfig {
13
+ windowMs: number;
14
+ maxRequests: number;
15
+ keyPrefix: string;
16
+ }
17
+ /**
18
+ * Create post-auth rate limiter middleware
19
+ */
20
+ export declare function createPostAuthRateLimiter(config?: Partial<RateLimitConfig>): (req: AuthenticatedRequest, res: Response, next: NextFunction) => void;
21
+ /**
22
+ * Evaluation endpoint rate limiter
23
+ * More restrictive for evaluation to prevent abuse
24
+ */
25
+ export declare const evaluationRateLimiter: (req: AuthenticatedRequest, res: Response, next: NextFunction) => void;
26
+ /**
27
+ * Mutation endpoint rate limiter
28
+ * More restrictive for mutations
29
+ */
30
+ export declare const mutationRateLimiter: (req: AuthenticatedRequest, res: Response, next: NextFunction) => void;
31
+ /**
32
+ * Read endpoint rate limiter
33
+ */
34
+ export declare const readRateLimiter: (req: AuthenticatedRequest, res: Response, next: NextFunction) => void;
35
+ /**
36
+ * Strict rate limiter for sensitive operations
37
+ */
38
+ export declare const strictRateLimiter: (req: AuthenticatedRequest, res: Response, next: NextFunction) => void;
39
+ export {};
40
+ //# sourceMappingURL=rate-limiter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rate-limiter.d.ts","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEjD,OAAO,EAAE,oBAAoB,EAAoB,MAAM,qBAAqB,CAAC;AAG7E;;GAEG;AACH,UAAU,eAAe;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;CACnB;AAqED;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,MAAM,GAAE,OAAO,CAAC,eAAe,CAAM,IAOrE,KAAK,oBAAoB,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,KAAG,IAAI,CAqC5E;AAED;;;GAGG;AACH,eAAO,MAAM,qBAAqB,QA3CnB,oBAAoB,OAAO,QAAQ,QAAQ,YAAY,KAAG,IA+CvE,CAAC;AAEH;;;GAGG;AACH,eAAO,MAAM,mBAAmB,QArDjB,oBAAoB,OAAO,QAAQ,QAAQ,YAAY,KAAG,IAyDvE,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,eAAe,QA9Db,oBAAoB,OAAO,QAAQ,QAAQ,YAAY,KAAG,IAkEvE,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,iBAAiB,QAvEf,oBAAoB,OAAO,QAAQ,QAAQ,YAAY,KAAG,IA2EvE,CAAC"}