@salimassili/ai-costguard 1.1.3

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 (490) hide show
  1. package/README.md +112 -0
  2. package/dist/aecl/ExecutionInterceptor.d.ts +111 -0
  3. package/dist/aecl/ExecutionInterceptor.d.ts.map +1 -0
  4. package/dist/aecl/ExecutionInterceptor.js +280 -0
  5. package/dist/aecl/ExecutionInterceptor.js.map +1 -0
  6. package/dist/aecl/ExecutionMemory.d.ts +103 -0
  7. package/dist/aecl/ExecutionMemory.d.ts.map +1 -0
  8. package/dist/aecl/ExecutionMemory.js +164 -0
  9. package/dist/aecl/ExecutionMemory.js.map +1 -0
  10. package/dist/aecl/PolicyEngine.d.ts +77 -0
  11. package/dist/aecl/PolicyEngine.d.ts.map +1 -0
  12. package/dist/aecl/PolicyEngine.js +170 -0
  13. package/dist/aecl/PolicyEngine.js.map +1 -0
  14. package/dist/aecl/ROITelemetry.d.ts +110 -0
  15. package/dist/aecl/ROITelemetry.d.ts.map +1 -0
  16. package/dist/aecl/ROITelemetry.js +211 -0
  17. package/dist/aecl/ROITelemetry.js.map +1 -0
  18. package/dist/aecl/RiskEngine.d.ts +90 -0
  19. package/dist/aecl/RiskEngine.d.ts.map +1 -0
  20. package/dist/aecl/RiskEngine.js +207 -0
  21. package/dist/aecl/RiskEngine.js.map +1 -0
  22. package/dist/aecl/index.d.ts +76 -0
  23. package/dist/aecl/index.d.ts.map +1 -0
  24. package/dist/aecl/index.js +111 -0
  25. package/dist/aecl/index.js.map +1 -0
  26. package/dist/aerl/ExecutionGraph.d.ts +123 -0
  27. package/dist/aerl/ExecutionGraph.d.ts.map +1 -0
  28. package/dist/aerl/ExecutionGraph.js +289 -0
  29. package/dist/aerl/ExecutionGraph.js.map +1 -0
  30. package/dist/aerl/ExecutionInterceptor.d.ts +94 -0
  31. package/dist/aerl/ExecutionInterceptor.d.ts.map +1 -0
  32. package/dist/aerl/ExecutionInterceptor.js +246 -0
  33. package/dist/aerl/ExecutionInterceptor.js.map +1 -0
  34. package/dist/aerl/ExecutionMemory.d.ts +138 -0
  35. package/dist/aerl/ExecutionMemory.d.ts.map +1 -0
  36. package/dist/aerl/ExecutionMemory.js +284 -0
  37. package/dist/aerl/ExecutionMemory.js.map +1 -0
  38. package/dist/aerl/FailurePrediction.d.ts +71 -0
  39. package/dist/aerl/FailurePrediction.d.ts.map +1 -0
  40. package/dist/aerl/FailurePrediction.js +204 -0
  41. package/dist/aerl/FailurePrediction.js.map +1 -0
  42. package/dist/aerl/RecoveryEngine.d.ts +74 -0
  43. package/dist/aerl/RecoveryEngine.d.ts.map +1 -0
  44. package/dist/aerl/RecoveryEngine.js +194 -0
  45. package/dist/aerl/RecoveryEngine.js.map +1 -0
  46. package/dist/aerl/ReliabilityEngine.d.ts +74 -0
  47. package/dist/aerl/ReliabilityEngine.d.ts.map +1 -0
  48. package/dist/aerl/ReliabilityEngine.js +205 -0
  49. package/dist/aerl/ReliabilityEngine.js.map +1 -0
  50. package/dist/aerl/ReliabilityTelemetry.d.ts +118 -0
  51. package/dist/aerl/ReliabilityTelemetry.d.ts.map +1 -0
  52. package/dist/aerl/ReliabilityTelemetry.js +247 -0
  53. package/dist/aerl/ReliabilityTelemetry.js.map +1 -0
  54. package/dist/aerl/index.d.ts +170 -0
  55. package/dist/aerl/index.d.ts.map +1 -0
  56. package/dist/aerl/index.js +223 -0
  57. package/dist/aerl/index.js.map +1 -0
  58. package/dist/ambient/AmbientProtection.d.ts +79 -0
  59. package/dist/ambient/AmbientProtection.d.ts.map +1 -0
  60. package/dist/ambient/AmbientProtection.js +251 -0
  61. package/dist/ambient/AmbientProtection.js.map +1 -0
  62. package/dist/bin/start.d.ts +14 -0
  63. package/dist/bin/start.d.ts.map +1 -0
  64. package/dist/bin/start.js +54 -0
  65. package/dist/bin/start.js.map +1 -0
  66. package/dist/cli/index.d.ts +3 -0
  67. package/dist/cli/index.d.ts.map +1 -0
  68. package/dist/cli/index.js +64 -0
  69. package/dist/cli/index.js.map +1 -0
  70. package/dist/cli/outputContract.d.ts +19 -0
  71. package/dist/cli/outputContract.d.ts.map +1 -0
  72. package/dist/cli/outputContract.js +54 -0
  73. package/dist/cli/outputContract.js.map +1 -0
  74. package/dist/cli/storage.d.ts +61 -0
  75. package/dist/cli/storage.d.ts.map +1 -0
  76. package/dist/cli/storage.js +143 -0
  77. package/dist/cli/storage.js.map +1 -0
  78. package/dist/client.d.ts +29 -0
  79. package/dist/client.d.ts.map +1 -0
  80. package/dist/client.js +58 -0
  81. package/dist/client.js.map +1 -0
  82. package/dist/config/constants.d.ts +109 -0
  83. package/dist/config/constants.d.ts.map +1 -0
  84. package/dist/config/constants.js +151 -0
  85. package/dist/config/constants.js.map +1 -0
  86. package/dist/config/index.d.ts +5 -0
  87. package/dist/config/index.d.ts.map +1 -0
  88. package/dist/config/index.js +21 -0
  89. package/dist/config/index.js.map +1 -0
  90. package/dist/config/pricing.d.ts +12 -0
  91. package/dist/config/pricing.d.ts.map +1 -0
  92. package/dist/config/pricing.js +45 -0
  93. package/dist/config/pricing.js.map +1 -0
  94. package/dist/config/productionConfig.d.ts +8 -0
  95. package/dist/config/productionConfig.d.ts.map +1 -0
  96. package/dist/config/productionConfig.js +21 -0
  97. package/dist/config/productionConfig.js.map +1 -0
  98. package/dist/config/userConfig.d.ts +31 -0
  99. package/dist/config/userConfig.d.ts.map +1 -0
  100. package/dist/config/userConfig.js +116 -0
  101. package/dist/config/userConfig.js.map +1 -0
  102. package/dist/controlPlane/configServer.d.ts +7 -0
  103. package/dist/controlPlane/configServer.d.ts.map +1 -0
  104. package/dist/controlPlane/configServer.js +47 -0
  105. package/dist/controlPlane/configServer.js.map +1 -0
  106. package/dist/core/AgentBehaviorGraph.d.ts +163 -0
  107. package/dist/core/AgentBehaviorGraph.d.ts.map +1 -0
  108. package/dist/core/AgentBehaviorGraph.js +341 -0
  109. package/dist/core/AgentBehaviorGraph.js.map +1 -0
  110. package/dist/core/AlertManager.d.ts +19 -0
  111. package/dist/core/AlertManager.d.ts.map +1 -0
  112. package/dist/core/AlertManager.js +64 -0
  113. package/dist/core/AlertManager.js.map +1 -0
  114. package/dist/core/AuditTrail.d.ts +107 -0
  115. package/dist/core/AuditTrail.d.ts.map +1 -0
  116. package/dist/core/AuditTrail.js +256 -0
  117. package/dist/core/AuditTrail.js.map +1 -0
  118. package/dist/core/CostLedger.d.ts +135 -0
  119. package/dist/core/CostLedger.d.ts.map +1 -0
  120. package/dist/core/CostLedger.js +224 -0
  121. package/dist/core/CostLedger.js.map +1 -0
  122. package/dist/core/CostPredictionEngine.d.ts +110 -0
  123. package/dist/core/CostPredictionEngine.d.ts.map +1 -0
  124. package/dist/core/CostPredictionEngine.js +225 -0
  125. package/dist/core/CostPredictionEngine.js.map +1 -0
  126. package/dist/core/CostTruthEngine.d.ts +108 -0
  127. package/dist/core/CostTruthEngine.d.ts.map +1 -0
  128. package/dist/core/CostTruthEngine.js +170 -0
  129. package/dist/core/CostTruthEngine.js.map +1 -0
  130. package/dist/core/DetectionEngine.d.ts +147 -0
  131. package/dist/core/DetectionEngine.d.ts.map +1 -0
  132. package/dist/core/DetectionEngine.js +429 -0
  133. package/dist/core/DetectionEngine.js.map +1 -0
  134. package/dist/core/ExecutionInterceptor.d.ts +135 -0
  135. package/dist/core/ExecutionInterceptor.d.ts.map +1 -0
  136. package/dist/core/ExecutionInterceptor.js +285 -0
  137. package/dist/core/ExecutionInterceptor.js.map +1 -0
  138. package/dist/core/ExplainabilityLayer.d.ts +109 -0
  139. package/dist/core/ExplainabilityLayer.d.ts.map +1 -0
  140. package/dist/core/ExplainabilityLayer.js +277 -0
  141. package/dist/core/ExplainabilityLayer.js.map +1 -0
  142. package/dist/core/LearningSystem.d.ts +124 -0
  143. package/dist/core/LearningSystem.d.ts.map +1 -0
  144. package/dist/core/LearningSystem.js +294 -0
  145. package/dist/core/LearningSystem.js.map +1 -0
  146. package/dist/core/Logger.d.ts +122 -0
  147. package/dist/core/Logger.d.ts.map +1 -0
  148. package/dist/core/Logger.js +233 -0
  149. package/dist/core/Logger.js.map +1 -0
  150. package/dist/core/PolicyEngine.d.ts +148 -0
  151. package/dist/core/PolicyEngine.d.ts.map +1 -0
  152. package/dist/core/PolicyEngine.js +336 -0
  153. package/dist/core/PolicyEngine.js.map +1 -0
  154. package/dist/core/PricingConfig.d.ts +55 -0
  155. package/dist/core/PricingConfig.d.ts.map +1 -0
  156. package/dist/core/PricingConfig.js +132 -0
  157. package/dist/core/PricingConfig.js.map +1 -0
  158. package/dist/core/SessionStats.d.ts +101 -0
  159. package/dist/core/SessionStats.d.ts.map +1 -0
  160. package/dist/core/SessionStats.js +261 -0
  161. package/dist/core/SessionStats.js.map +1 -0
  162. package/dist/core/StateStore.d.ts +100 -0
  163. package/dist/core/StateStore.d.ts.map +1 -0
  164. package/dist/core/StateStore.js +336 -0
  165. package/dist/core/StateStore.js.map +1 -0
  166. package/dist/core/index.d.ts +3 -0
  167. package/dist/core/index.d.ts.map +1 -0
  168. package/dist/core/index.js +19 -0
  169. package/dist/core/index.js.map +1 -0
  170. package/dist/core/types.d.ts +26 -0
  171. package/dist/core/types.d.ts.map +1 -0
  172. package/dist/core/types.js +3 -0
  173. package/dist/core/types.js.map +1 -0
  174. package/dist/cost-guard.d.ts +41 -0
  175. package/dist/cost-guard.d.ts.map +1 -0
  176. package/dist/cost-guard.js +274 -0
  177. package/dist/cost-guard.js.map +1 -0
  178. package/dist/dashboard/roiDashboard.d.ts +12 -0
  179. package/dist/dashboard/roiDashboard.d.ts.map +1 -0
  180. package/dist/dashboard/roiDashboard.js +28 -0
  181. package/dist/dashboard/roiDashboard.js.map +1 -0
  182. package/dist/demo/compareExecution.d.ts +9 -0
  183. package/dist/demo/compareExecution.d.ts.map +1 -0
  184. package/dist/demo/compareExecution.js +43 -0
  185. package/dist/demo/compareExecution.js.map +1 -0
  186. package/dist/demo/demoRunner.d.ts +16 -0
  187. package/dist/demo/demoRunner.d.ts.map +1 -0
  188. package/dist/demo/demoRunner.js +73 -0
  189. package/dist/demo/demoRunner.js.map +1 -0
  190. package/dist/firewall/costEstimator.d.ts +3 -0
  191. package/dist/firewall/costEstimator.d.ts.map +1 -0
  192. package/dist/firewall/costEstimator.js +22 -0
  193. package/dist/firewall/costEstimator.js.map +1 -0
  194. package/dist/firewall/executionGuard.d.ts +18 -0
  195. package/dist/firewall/executionGuard.d.ts.map +1 -0
  196. package/dist/firewall/executionGuard.js +80 -0
  197. package/dist/firewall/executionGuard.js.map +1 -0
  198. package/dist/firewall/loopDetector.d.ts +13 -0
  199. package/dist/firewall/loopDetector.d.ts.map +1 -0
  200. package/dist/firewall/loopDetector.js +24 -0
  201. package/dist/firewall/loopDetector.js.map +1 -0
  202. package/dist/firewall/policy.d.ts +4 -0
  203. package/dist/firewall/policy.d.ts.map +1 -0
  204. package/dist/firewall/policy.js +16 -0
  205. package/dist/firewall/policy.js.map +1 -0
  206. package/dist/firewall/types.d.ts +38 -0
  207. package/dist/firewall/types.d.ts.map +1 -0
  208. package/dist/firewall/types.js +3 -0
  209. package/dist/firewall/types.js.map +1 -0
  210. package/dist/index.d.ts +40 -0
  211. package/dist/index.d.ts.map +1 -0
  212. package/dist/index.js +76 -0
  213. package/dist/index.js.map +1 -0
  214. package/dist/logger/console.d.ts +27 -0
  215. package/dist/logger/console.d.ts.map +1 -0
  216. package/dist/logger/console.js +68 -0
  217. package/dist/logger/console.js.map +1 -0
  218. package/dist/logger/database.d.ts +40 -0
  219. package/dist/logger/database.d.ts.map +1 -0
  220. package/dist/logger/database.js +127 -0
  221. package/dist/logger/database.js.map +1 -0
  222. package/dist/logger/index.d.ts +3 -0
  223. package/dist/logger/index.d.ts.map +1 -0
  224. package/dist/logger/index.js +11 -0
  225. package/dist/logger/index.js.map +1 -0
  226. package/dist/loop-shield.d.ts +48 -0
  227. package/dist/loop-shield.d.ts.map +1 -0
  228. package/dist/loop-shield.js +436 -0
  229. package/dist/loop-shield.js.map +1 -0
  230. package/dist/metrics/BusinessMetricsEngine.d.ts +109 -0
  231. package/dist/metrics/BusinessMetricsEngine.d.ts.map +1 -0
  232. package/dist/metrics/BusinessMetricsEngine.js +222 -0
  233. package/dist/metrics/BusinessMetricsEngine.js.map +1 -0
  234. package/dist/metrics/index.d.ts +11 -0
  235. package/dist/metrics/index.d.ts.map +1 -0
  236. package/dist/metrics/index.js +17 -0
  237. package/dist/metrics/index.js.map +1 -0
  238. package/dist/middleware/expressFirewall.d.ts +51 -0
  239. package/dist/middleware/expressFirewall.d.ts.map +1 -0
  240. package/dist/middleware/expressFirewall.js +140 -0
  241. package/dist/middleware/expressFirewall.js.map +1 -0
  242. package/dist/middleware/index.d.ts +8 -0
  243. package/dist/middleware/index.d.ts.map +1 -0
  244. package/dist/middleware/index.js +15 -0
  245. package/dist/middleware/index.js.map +1 -0
  246. package/dist/middleware/withFirewall.d.ts +50 -0
  247. package/dist/middleware/withFirewall.d.ts.map +1 -0
  248. package/dist/middleware/withFirewall.js +155 -0
  249. package/dist/middleware/withFirewall.js.map +1 -0
  250. package/dist/observability/logger.d.ts +14 -0
  251. package/dist/observability/logger.d.ts.map +1 -0
  252. package/dist/observability/logger.js +21 -0
  253. package/dist/observability/logger.js.map +1 -0
  254. package/dist/observability/metrics.d.ts +17 -0
  255. package/dist/observability/metrics.d.ts.map +1 -0
  256. package/dist/observability/metrics.js +36 -0
  257. package/dist/observability/metrics.js.map +1 -0
  258. package/dist/os/ExecutionOS.d.ts +220 -0
  259. package/dist/os/ExecutionOS.d.ts.map +1 -0
  260. package/dist/os/ExecutionOS.js +398 -0
  261. package/dist/os/ExecutionOS.js.map +1 -0
  262. package/dist/os/GlobalIntelligence.d.ts +154 -0
  263. package/dist/os/GlobalIntelligence.d.ts.map +1 -0
  264. package/dist/os/GlobalIntelligence.js +374 -0
  265. package/dist/os/GlobalIntelligence.js.map +1 -0
  266. package/dist/os/PolicyMarketplace.d.ts +192 -0
  267. package/dist/os/PolicyMarketplace.d.ts.map +1 -0
  268. package/dist/os/PolicyMarketplace.js +384 -0
  269. package/dist/os/PolicyMarketplace.js.map +1 -0
  270. package/dist/os/SDKInterception.d.ts +115 -0
  271. package/dist/os/SDKInterception.d.ts.map +1 -0
  272. package/dist/os/SDKInterception.js +317 -0
  273. package/dist/os/SDKInterception.js.map +1 -0
  274. package/dist/os/index.d.ts +60 -0
  275. package/dist/os/index.d.ts.map +1 -0
  276. package/dist/os/index.js +82 -0
  277. package/dist/os/index.js.map +1 -0
  278. package/dist/proxy/index.d.ts +2 -0
  279. package/dist/proxy/index.d.ts.map +1 -0
  280. package/dist/proxy/index.js +18 -0
  281. package/dist/proxy/index.js.map +1 -0
  282. package/dist/proxy/server.d.ts +24 -0
  283. package/dist/proxy/server.d.ts.map +1 -0
  284. package/dist/proxy/server.js +395 -0
  285. package/dist/proxy/server.js.map +1 -0
  286. package/dist/public/BenchmarksPage.d.ts +60 -0
  287. package/dist/public/BenchmarksPage.d.ts.map +1 -0
  288. package/dist/public/BenchmarksPage.js +397 -0
  289. package/dist/public/BenchmarksPage.js.map +1 -0
  290. package/dist/public/DocsPage.d.ts +11 -0
  291. package/dist/public/DocsPage.d.ts.map +1 -0
  292. package/dist/public/DocsPage.js +496 -0
  293. package/dist/public/DocsPage.js.map +1 -0
  294. package/dist/public/StatusPage.d.ts +55 -0
  295. package/dist/public/StatusPage.d.ts.map +1 -0
  296. package/dist/public/StatusPage.js +344 -0
  297. package/dist/public/StatusPage.js.map +1 -0
  298. package/dist/public/index.d.ts +12 -0
  299. package/dist/public/index.d.ts.map +1 -0
  300. package/dist/public/index.js +20 -0
  301. package/dist/public/index.js.map +1 -0
  302. package/dist/replacements/axios.d.ts +14 -0
  303. package/dist/replacements/axios.d.ts.map +1 -0
  304. package/dist/replacements/axios.js +35 -0
  305. package/dist/replacements/axios.js.map +1 -0
  306. package/dist/replacements/fetch.d.ts +13 -0
  307. package/dist/replacements/fetch.d.ts.map +1 -0
  308. package/dist/replacements/fetch.js +20 -0
  309. package/dist/replacements/fetch.js.map +1 -0
  310. package/dist/replacements/openai.d.ts +14 -0
  311. package/dist/replacements/openai.d.ts.map +1 -0
  312. package/dist/replacements/openai.js +22 -0
  313. package/dist/replacements/openai.js.map +1 -0
  314. package/dist/saas/CostExplosionDemo.d.ts +56 -0
  315. package/dist/saas/CostExplosionDemo.d.ts.map +1 -0
  316. package/dist/saas/CostExplosionDemo.js +190 -0
  317. package/dist/saas/CostExplosionDemo.js.map +1 -0
  318. package/dist/saas/LiveProtection.d.ts +61 -0
  319. package/dist/saas/LiveProtection.d.ts.map +1 -0
  320. package/dist/saas/LiveProtection.js +187 -0
  321. package/dist/saas/LiveProtection.js.map +1 -0
  322. package/dist/saas/ProductionSaaS.d.ts +56 -0
  323. package/dist/saas/ProductionSaaS.d.ts.map +1 -0
  324. package/dist/saas/ProductionSaaS.js +831 -0
  325. package/dist/saas/ProductionSaaS.js.map +1 -0
  326. package/dist/saas/SaaSServer.d.ts +50 -0
  327. package/dist/saas/SaaSServer.d.ts.map +1 -0
  328. package/dist/saas/SaaSServer.js +669 -0
  329. package/dist/saas/SaaSServer.js.map +1 -0
  330. package/dist/saas/UserStore.d.ts +49 -0
  331. package/dist/saas/UserStore.d.ts.map +1 -0
  332. package/dist/saas/UserStore.js +137 -0
  333. package/dist/saas/UserStore.js.map +1 -0
  334. package/dist/saas/billingMetrics.d.ts +14 -0
  335. package/dist/saas/billingMetrics.d.ts.map +1 -0
  336. package/dist/saas/billingMetrics.js +23 -0
  337. package/dist/saas/billingMetrics.js.map +1 -0
  338. package/dist/saas/index.d.ts +12 -0
  339. package/dist/saas/index.d.ts.map +1 -0
  340. package/dist/saas/index.js +23 -0
  341. package/dist/saas/index.js.map +1 -0
  342. package/dist/saas/telemetry.d.ts +24 -0
  343. package/dist/saas/telemetry.d.ts.map +1 -0
  344. package/dist/saas/telemetry.js +30 -0
  345. package/dist/saas/telemetry.js.map +1 -0
  346. package/dist/saas/usageMeter.d.ts +28 -0
  347. package/dist/saas/usageMeter.d.ts.map +1 -0
  348. package/dist/saas/usageMeter.js +41 -0
  349. package/dist/saas/usageMeter.js.map +1 -0
  350. package/dist/security/TrustBoundaryValidator.d.ts +105 -0
  351. package/dist/security/TrustBoundaryValidator.d.ts.map +1 -0
  352. package/dist/security/TrustBoundaryValidator.js +305 -0
  353. package/dist/security/TrustBoundaryValidator.js.map +1 -0
  354. package/dist/starters/express-protected.d.ts +18 -0
  355. package/dist/starters/express-protected.d.ts.map +1 -0
  356. package/dist/starters/express-protected.js +93 -0
  357. package/dist/starters/express-protected.js.map +1 -0
  358. package/dist/starters/langchain-protected.d.ts +18 -0
  359. package/dist/starters/langchain-protected.d.ts.map +1 -0
  360. package/dist/starters/langchain-protected.js +85 -0
  361. package/dist/starters/langchain-protected.js.map +1 -0
  362. package/dist/starters/openai-protected.d.ts +19 -0
  363. package/dist/starters/openai-protected.d.ts.map +1 -0
  364. package/dist/starters/openai-protected.js +84 -0
  365. package/dist/starters/openai-protected.js.map +1 -0
  366. package/dist/starters/serverless-protected.d.ts +19 -0
  367. package/dist/starters/serverless-protected.d.ts.map +1 -0
  368. package/dist/starters/serverless-protected.js +83 -0
  369. package/dist/starters/serverless-protected.js.map +1 -0
  370. package/dist/storage/adapters.d.ts +24 -0
  371. package/dist/storage/adapters.d.ts.map +1 -0
  372. package/dist/storage/adapters.js +123 -0
  373. package/dist/storage/adapters.js.map +1 -0
  374. package/dist/storage/index.d.ts +2 -0
  375. package/dist/storage/index.d.ts.map +1 -0
  376. package/dist/storage/index.js +8 -0
  377. package/dist/storage/index.js.map +1 -0
  378. package/dist/tests/b2b-hardening.test.d.ts +2 -0
  379. package/dist/tests/b2b-hardening.test.d.ts.map +1 -0
  380. package/dist/tests/b2b-hardening.test.js +164 -0
  381. package/dist/tests/b2b-hardening.test.js.map +1 -0
  382. package/dist/tests/cli.contract.test.d.ts +2 -0
  383. package/dist/tests/cli.contract.test.d.ts.map +1 -0
  384. package/dist/tests/cli.contract.test.js +28 -0
  385. package/dist/tests/cli.contract.test.js.map +1 -0
  386. package/dist/tests/cli.snapshot.test.d.ts +14 -0
  387. package/dist/tests/cli.snapshot.test.d.ts.map +1 -0
  388. package/dist/tests/cli.snapshot.test.js +132 -0
  389. package/dist/tests/cli.snapshot.test.js.map +1 -0
  390. package/dist/tests/cli.strict.test.d.ts +6 -0
  391. package/dist/tests/cli.strict.test.d.ts.map +1 -0
  392. package/dist/tests/cli.strict.test.js +173 -0
  393. package/dist/tests/cli.strict.test.js.map +1 -0
  394. package/dist/tests/cli.test.d.ts +5 -0
  395. package/dist/tests/cli.test.d.ts.map +1 -0
  396. package/dist/tests/cli.test.js +54 -0
  397. package/dist/tests/cli.test.js.map +1 -0
  398. package/dist/tests/concurrency.state.test.d.ts +6 -0
  399. package/dist/tests/concurrency.state.test.d.ts.map +1 -0
  400. package/dist/tests/concurrency.state.test.js +231 -0
  401. package/dist/tests/concurrency.state.test.js.map +1 -0
  402. package/dist/tests/detection-engine.strict.test.d.ts +6 -0
  403. package/dist/tests/detection-engine.strict.test.d.ts.map +1 -0
  404. package/dist/tests/detection-engine.strict.test.js +323 -0
  405. package/dist/tests/detection-engine.strict.test.js.map +1 -0
  406. package/dist/tests/e2e.system.test.d.ts +7 -0
  407. package/dist/tests/e2e.system.test.d.ts.map +1 -0
  408. package/dist/tests/e2e.system.test.js +189 -0
  409. package/dist/tests/e2e.system.test.js.map +1 -0
  410. package/dist/tests/edge-cases.test.d.ts +6 -0
  411. package/dist/tests/edge-cases.test.d.ts.map +1 -0
  412. package/dist/tests/edge-cases.test.js +357 -0
  413. package/dist/tests/edge-cases.test.js.map +1 -0
  414. package/dist/tests/performance.benchmark.test.d.ts +2 -0
  415. package/dist/tests/performance.benchmark.test.d.ts.map +1 -0
  416. package/dist/tests/performance.benchmark.test.js +24 -0
  417. package/dist/tests/performance.benchmark.test.js.map +1 -0
  418. package/dist/tests/proxy.production.test.d.ts +6 -0
  419. package/dist/tests/proxy.production.test.d.ts.map +1 -0
  420. package/dist/tests/proxy.production.test.js +274 -0
  421. package/dist/tests/proxy.production.test.js.map +1 -0
  422. package/dist/tests/proxy.strict.test.d.ts +6 -0
  423. package/dist/tests/proxy.strict.test.d.ts.map +1 -0
  424. package/dist/tests/proxy.strict.test.js +188 -0
  425. package/dist/tests/proxy.strict.test.js.map +1 -0
  426. package/dist/tests/proxy.test.d.ts +5 -0
  427. package/dist/tests/proxy.test.d.ts.map +1 -0
  428. package/dist/tests/proxy.test.js +61 -0
  429. package/dist/tests/proxy.test.js.map +1 -0
  430. package/dist/tests/roi.scenario.test.d.ts +2 -0
  431. package/dist/tests/roi.scenario.test.d.ts.map +1 -0
  432. package/dist/tests/roi.scenario.test.js +26 -0
  433. package/dist/tests/roi.scenario.test.js.map +1 -0
  434. package/dist/tests/server.contract.test.d.ts +6 -0
  435. package/dist/tests/server.contract.test.d.ts.map +1 -0
  436. package/dist/tests/server.contract.test.js +48 -0
  437. package/dist/tests/server.contract.test.js.map +1 -0
  438. package/dist/tests/tokenCounter.test.d.ts +5 -0
  439. package/dist/tests/tokenCounter.test.d.ts.map +1 -0
  440. package/dist/tests/tokenCounter.test.js +66 -0
  441. package/dist/tests/tokenCounter.test.js.map +1 -0
  442. package/dist/tests/v113/client.test.d.ts +2 -0
  443. package/dist/tests/v113/client.test.d.ts.map +1 -0
  444. package/dist/tests/v113/client.test.js +22 -0
  445. package/dist/tests/v113/client.test.js.map +1 -0
  446. package/dist/tests/v113/executionGuard.test.d.ts +2 -0
  447. package/dist/tests/v113/executionGuard.test.d.ts.map +1 -0
  448. package/dist/tests/v113/executionGuard.test.js +39 -0
  449. package/dist/tests/v113/executionGuard.test.js.map +1 -0
  450. package/dist/token-counter/index.d.ts +2 -0
  451. package/dist/token-counter/index.d.ts.map +1 -0
  452. package/dist/token-counter/index.js +18 -0
  453. package/dist/token-counter/index.js.map +1 -0
  454. package/dist/token-counter/tokenCounter.d.ts +18 -0
  455. package/dist/token-counter/tokenCounter.d.ts.map +1 -0
  456. package/dist/token-counter/tokenCounter.js +91 -0
  457. package/dist/token-counter/tokenCounter.js.map +1 -0
  458. package/dist/trust/ImmutableAudit.d.ts +159 -0
  459. package/dist/trust/ImmutableAudit.d.ts.map +1 -0
  460. package/dist/trust/ImmutableAudit.js +340 -0
  461. package/dist/trust/ImmutableAudit.js.map +1 -0
  462. package/dist/trust/PublicVerificationLedger.d.ts +91 -0
  463. package/dist/trust/PublicVerificationLedger.d.ts.map +1 -0
  464. package/dist/trust/PublicVerificationLedger.js +223 -0
  465. package/dist/trust/PublicVerificationLedger.js.map +1 -0
  466. package/dist/trust/index.d.ts +11 -0
  467. package/dist/trust/index.d.ts.map +1 -0
  468. package/dist/trust/index.js +20 -0
  469. package/dist/trust/index.js.map +1 -0
  470. package/dist/utils/alert.d.ts +13 -0
  471. package/dist/utils/alert.d.ts.map +1 -0
  472. package/dist/utils/alert.js +49 -0
  473. package/dist/utils/alert.js.map +1 -0
  474. package/dist/utils/index.d.ts +2 -0
  475. package/dist/utils/index.d.ts.map +1 -0
  476. package/dist/utils/index.js +18 -0
  477. package/dist/utils/index.js.map +1 -0
  478. package/dist/wrapper/aiFirewall.d.ts +61 -0
  479. package/dist/wrapper/aiFirewall.d.ts.map +1 -0
  480. package/dist/wrapper/aiFirewall.js +117 -0
  481. package/dist/wrapper/aiFirewall.js.map +1 -0
  482. package/dist/wrapper/index.d.ts +3 -0
  483. package/dist/wrapper/index.d.ts.map +1 -0
  484. package/dist/wrapper/index.js +21 -0
  485. package/dist/wrapper/index.js.map +1 -0
  486. package/dist/wrapper/sdk.d.ts +49 -0
  487. package/dist/wrapper/sdk.d.ts.map +1 -0
  488. package/dist/wrapper/sdk.js +140 -0
  489. package/dist/wrapper/sdk.js.map +1 -0
  490. package/package.json +84 -0
@@ -0,0 +1,246 @@
1
+ "use strict";
2
+ /**
3
+ * AERL - AI Execution Reliability Layer
4
+ * Execution Interceptor Module
5
+ *
6
+ * PURPOSE:
7
+ * - Synchronous pre-call decision engine
8
+ * - Allow / block / modify decisions
9
+ * - Deterministic + cached
10
+ * - <5ms p95 latency
11
+ *
12
+ * DESIGN:
13
+ * - In-process only
14
+ * - No external I/O in hot path
15
+ * - LRU cache for sub-millisecond repeat decisions
16
+ * - Fail-open with logging
17
+ */
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ exports.interceptor = exports.ExecutionInterceptor = void 0;
20
+ const perf_hooks_1 = require("perf_hooks");
21
+ const crypto_1 = require("crypto");
22
+ // LRU Cache for fast-path decisions
23
+ class LRUCache {
24
+ constructor(maxSize) {
25
+ this.cache = new Map();
26
+ this.maxSize = maxSize;
27
+ }
28
+ get(key) {
29
+ const value = this.cache.get(key);
30
+ if (value !== undefined) {
31
+ this.cache.delete(key);
32
+ this.cache.set(key, value);
33
+ }
34
+ return value;
35
+ }
36
+ set(key, value) {
37
+ if (this.cache.has(key)) {
38
+ this.cache.delete(key);
39
+ }
40
+ else if (this.cache.size >= this.maxSize) {
41
+ const first = this.cache.keys().next();
42
+ if (!first.done && first.value !== undefined) {
43
+ this.cache.delete(first.value);
44
+ }
45
+ }
46
+ this.cache.set(key, value);
47
+ }
48
+ clear() {
49
+ this.cache.clear();
50
+ }
51
+ }
52
+ class ExecutionInterceptor {
53
+ constructor(config = {}) {
54
+ this.config = {
55
+ failOpen: true,
56
+ maxLatencyMs: 5,
57
+ cacheSize: 10000,
58
+ defaultPolicy: {
59
+ maxCostPerWorkflow: 50, // $50 default
60
+ maxStepsPerWorkflow: 100, // 100 steps default
61
+ maxCostPerStep: 10, // $10 per step
62
+ minReliabilityScore: 0.3, // Block if reliability < 30%
63
+ },
64
+ ...config,
65
+ };
66
+ this.cache = new LRUCache(this.config.cacheSize);
67
+ this.metrics = {
68
+ totalRequests: 0,
69
+ cacheHits: 0,
70
+ blockedRequests: 0,
71
+ modifiedRequests: 0,
72
+ latencySamples: [],
73
+ };
74
+ }
75
+ /**
76
+ * Main interception - MUST complete in <5ms p95
77
+ */
78
+ intercept(request) {
79
+ const startTime = perf_hooks_1.performance.now();
80
+ try {
81
+ // 1. Cache check (sub-millisecond)
82
+ const cacheKey = this.generateCacheKey(request);
83
+ const cached = this.cache.get(cacheKey);
84
+ if (cached) {
85
+ this.metrics.cacheHits++;
86
+ this.recordLatency(perf_hooks_1.performance.now() - startTime);
87
+ return { ...cached, cacheHit: true, latencyMs: perf_hooks_1.performance.now() - startTime };
88
+ }
89
+ // 2. Evaluate against policy
90
+ const policyResult = this.evaluatePolicy(request);
91
+ // 3. Build decision result
92
+ const result = {
93
+ action: policyResult.action,
94
+ reason: policyResult.reason,
95
+ reliabilityScore: policyResult.reliabilityScore,
96
+ confidence: policyResult.confidence,
97
+ latencyMs: 0,
98
+ suggestedModification: policyResult.modification,
99
+ estimatedSavings: policyResult.action === 'block' ? request.estimatedCost : undefined,
100
+ cacheHit: false,
101
+ };
102
+ // 4. Cache decision
103
+ this.cache.set(cacheKey, result);
104
+ // 5. Record metrics
105
+ const latency = perf_hooks_1.performance.now() - startTime;
106
+ result.latencyMs = latency;
107
+ this.recordLatency(latency);
108
+ if (result.action === 'block') {
109
+ this.metrics.blockedRequests++;
110
+ }
111
+ else if (result.action === 'modify') {
112
+ this.metrics.modifiedRequests++;
113
+ }
114
+ return result;
115
+ }
116
+ catch (error) {
117
+ console.error('[AERL] Interceptor error:', error);
118
+ return {
119
+ action: this.config.failOpen ? 'allow' : 'block',
120
+ reason: `Interceptor error: ${error instanceof Error ? error.message : 'unknown'}`,
121
+ reliabilityScore: this.config.failOpen ? 0.5 : 0,
122
+ confidence: 0,
123
+ latencyMs: perf_hooks_1.performance.now() - startTime,
124
+ cacheHit: false,
125
+ };
126
+ }
127
+ }
128
+ evaluatePolicy(request) {
129
+ const ctx = request.context;
130
+ const policy = this.config.defaultPolicy;
131
+ // Calculate reliability score
132
+ const reliabilityScore = this.calculateReliabilityScore(request);
133
+ // Policy 1: Hard cost limit
134
+ if (ctx.totalCost + request.estimatedCost > policy.maxCostPerWorkflow) {
135
+ return {
136
+ action: 'block',
137
+ reason: `Workflow cost limit: $${ctx.totalCost.toFixed(2)} + $${request.estimatedCost.toFixed(2)} > $${policy.maxCostPerWorkflow}`,
138
+ reliabilityScore: 0.1,
139
+ confidence: 1.0,
140
+ };
141
+ }
142
+ // Policy 2: Step limit
143
+ if (ctx.stepNumber >= policy.maxStepsPerWorkflow) {
144
+ return {
145
+ action: 'block',
146
+ reason: `Step limit reached: ${ctx.stepNumber} >= ${policy.maxStepsPerWorkflow}`,
147
+ reliabilityScore: 0.05,
148
+ confidence: 1.0,
149
+ };
150
+ }
151
+ // Policy 3: Single step cost
152
+ if (request.estimatedCost > policy.maxCostPerStep) {
153
+ return {
154
+ action: 'modify',
155
+ reason: `Step cost high: $${request.estimatedCost.toFixed(2)} > $${policy.maxCostPerStep}, suggesting cheaper alternative`,
156
+ reliabilityScore: 0.4,
157
+ confidence: 0.8,
158
+ modification: {
159
+ alternativeTool: 'cheaper_model',
160
+ retryStrategy: 'backoff',
161
+ },
162
+ };
163
+ }
164
+ // Policy 4: Low reliability score
165
+ if (reliabilityScore < policy.minReliabilityScore) {
166
+ return {
167
+ action: 'modify',
168
+ reason: `Low reliability score: ${(reliabilityScore * 100).toFixed(0)}% < ${(policy.minReliabilityScore * 100).toFixed(0)}%, suggesting retry strategy`,
169
+ reliabilityScore,
170
+ confidence: 0.85,
171
+ modification: {
172
+ retryStrategy: 'backoff',
173
+ parameterAdjustments: { temperature: 0.3 },
174
+ },
175
+ };
176
+ }
177
+ // Allow
178
+ return {
179
+ action: 'allow',
180
+ reason: reliabilityScore > 0.8 ? 'High reliability' : 'Acceptable risk',
181
+ reliabilityScore,
182
+ confidence: reliabilityScore,
183
+ };
184
+ }
185
+ calculateReliabilityScore(request) {
186
+ const ctx = request.context;
187
+ let score = 0.5; // Start neutral
188
+ // Factor 1: Recent failure rate
189
+ const totalSteps = ctx.successCount + ctx.failureCount;
190
+ if (totalSteps > 0) {
191
+ const failureRate = ctx.failureCount / totalSteps;
192
+ score -= failureRate * 0.4; // Up to -0.4 for 100% failure rate
193
+ }
194
+ // Factor 2: Step progression
195
+ const stepRatio = ctx.stepNumber / this.config.defaultPolicy.maxStepsPerWorkflow;
196
+ if (stepRatio > 0.8)
197
+ score -= 0.2;
198
+ else if (stepRatio > 0.5)
199
+ score -= 0.1;
200
+ // Factor 3: Cost escalation
201
+ const costRatio = ctx.totalCost / this.config.defaultPolicy.maxCostPerWorkflow;
202
+ if (costRatio > 0.8)
203
+ score -= 0.2;
204
+ else if (costRatio > 0.5)
205
+ score -= 0.1;
206
+ // Factor 4: Success streak
207
+ if (ctx.successCount > 5)
208
+ score += 0.1;
209
+ if (ctx.successCount > 10)
210
+ score += 0.1;
211
+ return Math.max(0, Math.min(1, score));
212
+ }
213
+ generateCacheKey(request) {
214
+ const key = `${request.context.sessionId}:${request.context.stepNumber}:${request.operation}:${request.estimatedCost}`;
215
+ return (0, crypto_1.createHash)('sha256').update(key).digest('hex').substring(0, 32);
216
+ }
217
+ recordLatency(latencyMs) {
218
+ this.metrics.totalRequests++;
219
+ this.metrics.latencySamples.push(latencyMs);
220
+ if (this.metrics.latencySamples.length > 1000) {
221
+ this.metrics.latencySamples.shift();
222
+ }
223
+ }
224
+ getMetrics() {
225
+ const sorted = [...this.metrics.latencySamples].sort((a, b) => a - b);
226
+ return {
227
+ ...this.metrics,
228
+ cacheHitRate: this.metrics.totalRequests > 0 ? this.metrics.cacheHits / this.metrics.totalRequests : 0,
229
+ blockRate: this.metrics.totalRequests > 0 ? this.metrics.blockedRequests / this.metrics.totalRequests : 0,
230
+ p95LatencyMs: sorted[Math.floor(sorted.length * 0.95)] || 0,
231
+ };
232
+ }
233
+ reset() {
234
+ this.cache.clear();
235
+ this.metrics = {
236
+ totalRequests: 0,
237
+ cacheHits: 0,
238
+ blockedRequests: 0,
239
+ modifiedRequests: 0,
240
+ latencySamples: [],
241
+ };
242
+ }
243
+ }
244
+ exports.ExecutionInterceptor = ExecutionInterceptor;
245
+ exports.interceptor = new ExecutionInterceptor();
246
+ //# sourceMappingURL=ExecutionInterceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExecutionInterceptor.js","sourceRoot":"","sources":["../../src/aerl/ExecutionInterceptor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,138 @@
1
+ /**
2
+ * AERL - Execution Memory Layer
3
+ *
4
+ * Stores hashed execution data for pattern recognition:
5
+ * - Hashed execution traces (no raw prompts)
6
+ * - Failure patterns
7
+ * - Loop signatures
8
+ * - Success/failure sequences
9
+ *
10
+ * PURPOSE: Improve future reliability decisions without storing sensitive data
11
+ *
12
+ * REQUIREMENTS:
13
+ * - No raw sensitive data stored
14
+ * - In-memory with TTL
15
+ * - Fixed memory budget
16
+ * - Pattern lookup in <1ms
17
+ */
18
+ export interface ExecutionTrace {
19
+ traceId: string;
20
+ sessionId: string;
21
+ workflowId: string;
22
+ stepNumber: number;
23
+ operation: string;
24
+ inputHash: string;
25
+ outputHash?: string;
26
+ cost: number;
27
+ tokens: number;
28
+ durationMs: number;
29
+ timestamp: number;
30
+ success: boolean;
31
+ failureType?: string;
32
+ }
33
+ export interface FailurePattern {
34
+ patternId: string;
35
+ signature: string;
36
+ operation: string;
37
+ failureType: string;
38
+ occurrenceCount: number;
39
+ lastSeen: number;
40
+ avgCostBeforeFailure: number;
41
+ avgStepsBeforeFailure: number;
42
+ }
43
+ export interface LoopSignature {
44
+ loopId: string;
45
+ signature: string;
46
+ nodeSequence: string[];
47
+ occurrenceCount: number;
48
+ lastSeen: number;
49
+ }
50
+ export interface SuccessSequence {
51
+ sequenceId: string;
52
+ signature: string;
53
+ operations: string[];
54
+ avgCost: number;
55
+ avgDurationMs: number;
56
+ occurrenceCount: number;
57
+ lastSeen: number;
58
+ }
59
+ export declare class ExecutionMemory {
60
+ private traces;
61
+ private failurePatterns;
62
+ private loopSignatures;
63
+ private successSequences;
64
+ private maxTracesPerSession;
65
+ private maxPatterns;
66
+ private ttlMs;
67
+ constructor(config?: {
68
+ maxTracesPerSession?: number;
69
+ maxPatterns?: number;
70
+ ttlMinutes?: number;
71
+ });
72
+ /**
73
+ * Record execution trace
74
+ */
75
+ recordTrace(trace: ExecutionTrace): void;
76
+ /**
77
+ * Record loop signature
78
+ */
79
+ recordLoop(workflowId: string, nodeHashes: string[]): void;
80
+ /**
81
+ * Record success sequence for future optimization
82
+ */
83
+ recordSuccessSequence(sessionId: string, operations: string[], avgCost: number, avgDuration: number): void;
84
+ /**
85
+ * Check if input hash matches known failure pattern
86
+ */
87
+ checkFailureRisk(operation: string, inputHash: string): {
88
+ riskScore: number;
89
+ similarFailures: number;
90
+ avgCostBeforeFailure: number;
91
+ };
92
+ /**
93
+ * Check if loop pattern exists
94
+ */
95
+ checkLoopPattern(nodeHashes: string[]): {
96
+ isKnownLoop: boolean;
97
+ occurrenceCount: number;
98
+ };
99
+ /**
100
+ * Get session traces
101
+ */
102
+ getSessionTraces(sessionId: string): ExecutionTrace[];
103
+ /**
104
+ * Get recommended approach based on success sequences
105
+ */
106
+ getRecommendedApproach(operations: string[]): {
107
+ hasRecommendation: boolean;
108
+ avgCost: number;
109
+ avgDurationMs: number;
110
+ confidence: number;
111
+ };
112
+ private indexFailurePattern;
113
+ private hashLoop;
114
+ private hashSequence;
115
+ private cleanup;
116
+ private evictOldPatterns;
117
+ private evictOldest;
118
+ /**
119
+ * Get memory stats
120
+ */
121
+ getStats(): {
122
+ activeSessions: number;
123
+ totalTraces: number;
124
+ failurePatterns: number;
125
+ loopSignatures: number;
126
+ successSequences: number;
127
+ };
128
+ /**
129
+ * Clear session
130
+ */
131
+ clearSession(sessionId: string): void;
132
+ /**
133
+ * Reset all
134
+ */
135
+ reset(): void;
136
+ }
137
+ export declare const executionMemory: ExecutionMemory;
138
+ //# sourceMappingURL=ExecutionMemory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExecutionMemory.d.ts","sourceRoot":"","sources":["../../src/aerl/ExecutionMemory.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,284 @@
1
+ "use strict";
2
+ /**
3
+ * AERL - Execution Memory Layer
4
+ *
5
+ * Stores hashed execution data for pattern recognition:
6
+ * - Hashed execution traces (no raw prompts)
7
+ * - Failure patterns
8
+ * - Loop signatures
9
+ * - Success/failure sequences
10
+ *
11
+ * PURPOSE: Improve future reliability decisions without storing sensitive data
12
+ *
13
+ * REQUIREMENTS:
14
+ * - No raw sensitive data stored
15
+ * - In-memory with TTL
16
+ * - Fixed memory budget
17
+ * - Pattern lookup in <1ms
18
+ */
19
+ Object.defineProperty(exports, "__esModule", { value: true });
20
+ exports.executionMemory = exports.ExecutionMemory = void 0;
21
+ const crypto_1 = require("crypto");
22
+ class ExecutionMemory {
23
+ constructor(config) {
24
+ this.traces = new Map();
25
+ this.failurePatterns = new Map();
26
+ this.loopSignatures = new Map();
27
+ this.successSequences = new Map();
28
+ this.maxTracesPerSession = config?.maxTracesPerSession || 100;
29
+ this.maxPatterns = config?.maxPatterns || 1000;
30
+ this.ttlMs = (config?.ttlMinutes || 60) * 60 * 1000;
31
+ setInterval(() => this.cleanup(), 60000);
32
+ }
33
+ /**
34
+ * Record execution trace
35
+ */
36
+ recordTrace(trace) {
37
+ let sessionTraces = this.traces.get(trace.sessionId);
38
+ if (!sessionTraces) {
39
+ sessionTraces = [];
40
+ this.traces.set(trace.sessionId, sessionTraces);
41
+ }
42
+ sessionTraces.push(trace);
43
+ // Limit traces per session
44
+ if (sessionTraces.length > this.maxTracesPerSession) {
45
+ sessionTraces.shift();
46
+ }
47
+ // Index by pattern if failure
48
+ if (!trace.success && trace.failureType) {
49
+ this.indexFailurePattern(trace);
50
+ }
51
+ }
52
+ /**
53
+ * Record loop signature
54
+ */
55
+ recordLoop(workflowId, nodeHashes) {
56
+ const signature = this.hashLoop(nodeHashes);
57
+ const existing = this.loopSignatures.get(signature);
58
+ if (existing) {
59
+ existing.occurrenceCount++;
60
+ existing.lastSeen = Date.now();
61
+ }
62
+ else {
63
+ this.loopSignatures.set(signature, {
64
+ loopId: `loop-${signature.substring(0, 8)}`,
65
+ signature,
66
+ nodeSequence: nodeHashes,
67
+ occurrenceCount: 1,
68
+ lastSeen: Date.now(),
69
+ });
70
+ }
71
+ // Evict old patterns if at capacity
72
+ if (this.loopSignatures.size > this.maxPatterns) {
73
+ this.evictOldest(this.loopSignatures);
74
+ }
75
+ }
76
+ /**
77
+ * Record success sequence for future optimization
78
+ */
79
+ recordSuccessSequence(sessionId, operations, avgCost, avgDuration) {
80
+ const signature = this.hashSequence(operations);
81
+ const existing = this.successSequences.get(signature);
82
+ if (existing) {
83
+ existing.occurrenceCount++;
84
+ existing.lastSeen = Date.now();
85
+ // Update averages
86
+ const n = existing.occurrenceCount;
87
+ existing.avgCost = (existing.avgCost * (n - 1) + avgCost) / n;
88
+ existing.avgDurationMs = (existing.avgDurationMs * (n - 1) + avgDuration) / n;
89
+ }
90
+ else {
91
+ this.successSequences.set(signature, {
92
+ sequenceId: `seq-${signature.substring(0, 8)}`,
93
+ signature,
94
+ operations: [...operations],
95
+ avgCost,
96
+ avgDurationMs: avgDuration,
97
+ occurrenceCount: 1,
98
+ lastSeen: Date.now(),
99
+ });
100
+ }
101
+ }
102
+ /**
103
+ * Check if input hash matches known failure pattern
104
+ */
105
+ checkFailureRisk(operation, inputHash) {
106
+ let matches = 0;
107
+ let totalCost = 0;
108
+ for (const pattern of this.failurePatterns.values()) {
109
+ if (pattern.operation === operation) {
110
+ // Simple similarity: check if hashes share prefix
111
+ if (inputHash.substring(0, 8) === pattern.signature.substring(0, 8)) {
112
+ matches++;
113
+ totalCost += pattern.avgCostBeforeFailure;
114
+ }
115
+ }
116
+ }
117
+ const riskScore = Math.min(1, matches / 5); // 5+ similar failures = high risk
118
+ const avgCost = matches > 0 ? totalCost / matches : 0;
119
+ return {
120
+ riskScore,
121
+ similarFailures: matches,
122
+ avgCostBeforeFailure: avgCost,
123
+ };
124
+ }
125
+ /**
126
+ * Check if loop pattern exists
127
+ */
128
+ checkLoopPattern(nodeHashes) {
129
+ const signature = this.hashLoop(nodeHashes);
130
+ const pattern = this.loopSignatures.get(signature);
131
+ return {
132
+ isKnownLoop: !!pattern,
133
+ occurrenceCount: pattern?.occurrenceCount || 0,
134
+ };
135
+ }
136
+ /**
137
+ * Get session traces
138
+ */
139
+ getSessionTraces(sessionId) {
140
+ return this.traces.get(sessionId) || [];
141
+ }
142
+ /**
143
+ * Get recommended approach based on success sequences
144
+ */
145
+ getRecommendedApproach(operations) {
146
+ const signature = this.hashSequence(operations);
147
+ const sequence = this.successSequences.get(signature);
148
+ if (!sequence) {
149
+ return {
150
+ hasRecommendation: false,
151
+ avgCost: 0,
152
+ avgDurationMs: 0,
153
+ confidence: 0,
154
+ };
155
+ }
156
+ // Confidence based on occurrence count
157
+ const confidence = Math.min(0.95, sequence.occurrenceCount / 10);
158
+ return {
159
+ hasRecommendation: true,
160
+ avgCost: sequence.avgCost,
161
+ avgDurationMs: sequence.avgDurationMs,
162
+ confidence,
163
+ };
164
+ }
165
+ indexFailurePattern(trace) {
166
+ // Create signature from operation + input prefix
167
+ const signature = (0, crypto_1.createHash)('sha256')
168
+ .update(`${trace.operation}:${trace.inputHash.substring(0, 16)}`)
169
+ .digest('hex')
170
+ .substring(0, 32);
171
+ const existing = this.failurePatterns.get(signature);
172
+ if (existing) {
173
+ existing.occurrenceCount++;
174
+ existing.lastSeen = Date.now();
175
+ // Update averages
176
+ const sessionTraces = this.traces.get(trace.sessionId) || [];
177
+ const stepsBefore = sessionTraces.filter(t => t.timestamp < trace.timestamp).length;
178
+ const costBefore = sessionTraces
179
+ .filter(t => t.timestamp < trace.timestamp)
180
+ .reduce((sum, t) => sum + t.cost, 0);
181
+ const n = existing.occurrenceCount;
182
+ existing.avgStepsBeforeFailure = (existing.avgStepsBeforeFailure * (n - 1) + stepsBefore) / n;
183
+ existing.avgCostBeforeFailure = (existing.avgCostBeforeFailure * (n - 1) + costBefore) / n;
184
+ }
185
+ else {
186
+ const sessionTraces = this.traces.get(trace.sessionId) || [];
187
+ const stepsBefore = sessionTraces.filter(t => t.timestamp < trace.timestamp).length;
188
+ const costBefore = sessionTraces
189
+ .filter(t => t.timestamp < trace.timestamp)
190
+ .reduce((sum, t) => sum + t.cost, 0);
191
+ this.failurePatterns.set(signature, {
192
+ patternId: `fail-${signature.substring(0, 8)}`,
193
+ signature,
194
+ operation: trace.operation,
195
+ failureType: trace.failureType || 'unknown',
196
+ occurrenceCount: 1,
197
+ lastSeen: Date.now(),
198
+ avgCostBeforeFailure: costBefore,
199
+ avgStepsBeforeFailure: stepsBefore,
200
+ });
201
+ }
202
+ }
203
+ hashLoop(nodeHashes) {
204
+ return (0, crypto_1.createHash)('sha256')
205
+ .update(nodeHashes.join(':'))
206
+ .digest('hex')
207
+ .substring(0, 32);
208
+ }
209
+ hashSequence(operations) {
210
+ return (0, crypto_1.createHash)('sha256')
211
+ .update(operations.join(':'))
212
+ .digest('hex')
213
+ .substring(0, 32);
214
+ }
215
+ cleanup() {
216
+ const now = Date.now();
217
+ // Clean up old traces
218
+ for (const [sessionId, traces] of this.traces) {
219
+ const recent = traces.filter(t => now - t.timestamp < this.ttlMs);
220
+ if (recent.length === 0) {
221
+ this.traces.delete(sessionId);
222
+ }
223
+ else if (recent.length < traces.length) {
224
+ this.traces.set(sessionId, recent);
225
+ }
226
+ }
227
+ // Clean up old patterns
228
+ this.evictOldPatterns(this.failurePatterns, now);
229
+ this.evictOldPatterns(this.loopSignatures, now);
230
+ this.evictOldPatterns(this.successSequences, now);
231
+ }
232
+ evictOldPatterns(patterns, now) {
233
+ for (const [key, pattern] of patterns) {
234
+ if (now - pattern.lastSeen > this.ttlMs) {
235
+ patterns.delete(key);
236
+ }
237
+ }
238
+ }
239
+ evictOldest(map) {
240
+ let oldest = null;
241
+ for (const [key, value] of map) {
242
+ if (!oldest || value.lastSeen < oldest.time) {
243
+ oldest = { key, time: value.lastSeen };
244
+ }
245
+ }
246
+ if (oldest) {
247
+ map.delete(oldest.key);
248
+ }
249
+ }
250
+ /**
251
+ * Get memory stats
252
+ */
253
+ getStats() {
254
+ let totalTraces = 0;
255
+ for (const traces of this.traces.values()) {
256
+ totalTraces += traces.length;
257
+ }
258
+ return {
259
+ activeSessions: this.traces.size,
260
+ totalTraces,
261
+ failurePatterns: this.failurePatterns.size,
262
+ loopSignatures: this.loopSignatures.size,
263
+ successSequences: this.successSequences.size,
264
+ };
265
+ }
266
+ /**
267
+ * Clear session
268
+ */
269
+ clearSession(sessionId) {
270
+ this.traces.delete(sessionId);
271
+ }
272
+ /**
273
+ * Reset all
274
+ */
275
+ reset() {
276
+ this.traces.clear();
277
+ this.failurePatterns.clear();
278
+ this.loopSignatures.clear();
279
+ this.successSequences.clear();
280
+ }
281
+ }
282
+ exports.ExecutionMemory = ExecutionMemory;
283
+ exports.executionMemory = new ExecutionMemory();
284
+ //# sourceMappingURL=ExecutionMemory.js.map