@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,436 @@
1
+ "use strict";
2
+ /**
3
+ * LoopShield
4
+ *
5
+ * Detects and stops semantic loop explosions in AI agents BEFORE cost escalates.
6
+ *
7
+ * ONE PURPOSE: Prevent the $3,000–$10,000 overnight runaway agent bill.
8
+ *
9
+ * DETECTS: Semantic loops (same intent, different phrasing, converging actions)
10
+ * NOT: Generic cost limits, step counting, or naive duplicate detection.
11
+ */
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.initLoopShield = initLoopShield;
14
+ exports.shield = shield;
15
+ exports.checkLoop = checkLoop;
16
+ const perf_hooks_1 = require("perf_hooks");
17
+ // ═══════════════════════════════════════════════════════════════════════════════
18
+ // COMPONENT 1: SEMANTIC EMBEDDING CACHE (simulated for <5ms)
19
+ // ═══════════════════════════════════════════════════════════════════════════════
20
+ /**
21
+ * Simulates semantic embeddings using character n-gram frequency vectors.
22
+ * Fast, deterministic, no external dependencies.
23
+ */
24
+ class SemanticEmbeddingCache {
25
+ constructor() {
26
+ this.cache = new Map();
27
+ this.maxCacheSize = 1000;
28
+ }
29
+ /**
30
+ * Generate simplified embedding (character trigram histogram)
31
+ * Runs in <0.5ms for typical inputs
32
+ */
33
+ embed(text) {
34
+ const cached = this.cache.get(text);
35
+ if (cached)
36
+ return cached;
37
+ // Character trigram frequency vector (simplified but effective)
38
+ const vector = new Array(256).fill(0);
39
+ const normalized = text.toLowerCase().replace(/[^a-z0-9\s]/g, '');
40
+ for (let i = 0; i < normalized.length - 2; i++) {
41
+ const tri = normalized.substring(i, i + 3);
42
+ const hash = this.hashTrigram(tri);
43
+ vector[hash]++;
44
+ }
45
+ // Normalize to unit vector
46
+ const magnitude = Math.sqrt(vector.reduce((sum, v) => sum + v * v, 0));
47
+ const normalizedVector = magnitude > 0 ? vector.map(v => v / magnitude) : vector;
48
+ // Cache if room
49
+ if (this.cache.size < this.maxCacheSize) {
50
+ this.cache.set(text, normalizedVector);
51
+ }
52
+ return normalizedVector;
53
+ }
54
+ hashTrigram(tri) {
55
+ let hash = 0;
56
+ for (let i = 0; i < tri.length; i++) {
57
+ hash = ((hash << 5) - hash) + tri.charCodeAt(i);
58
+ hash = hash & hash; // Convert to 32bit integer
59
+ }
60
+ return Math.abs(hash) % 256;
61
+ }
62
+ cosineSimilarity(a, b) {
63
+ let dot = 0;
64
+ let normA = 0;
65
+ let normB = 0;
66
+ for (let i = 0; i < a.length; i++) {
67
+ dot += a[i] * b[i];
68
+ normA += a[i] * a[i];
69
+ normB += b[i] * b[i];
70
+ }
71
+ return dot / (Math.sqrt(normA) * Math.sqrt(normB) + 1e-10);
72
+ }
73
+ }
74
+ class SemanticLoopDetectionEngine {
75
+ constructor(config = {}) {
76
+ this.sessions = new Map();
77
+ this.embeddings = new SemanticEmbeddingCache();
78
+ this.config = {
79
+ loopProbabilityThreshold: 0.75,
80
+ explosionRiskThreshold: 0.85,
81
+ maxSessionCost: 50,
82
+ failOpen: true,
83
+ ...config,
84
+ };
85
+ // Cleanup old sessions every minute
86
+ setInterval(() => this.cleanup(), 60000);
87
+ }
88
+ detect(sessionId, action) {
89
+ const start = perf_hooks_1.performance.now();
90
+ try {
91
+ // Get or create session
92
+ let session = this.sessions.get(sessionId);
93
+ if (!session) {
94
+ session = {
95
+ actions: [],
96
+ totalCost: 0,
97
+ startTime: Date.now(),
98
+ lastActivity: Date.now(),
99
+ };
100
+ this.sessions.set(sessionId, session);
101
+ }
102
+ // Generate embedding for this action
103
+ action.inputEmbedding = this.embeddings.embed(action.input);
104
+ // DETECTION SIGNALS
105
+ const signals = this.analyzeSignals(session, action);
106
+ // Calculate loop probability (weighted ensemble)
107
+ const loopProbability = this.calculateLoopProbability(signals);
108
+ // Calculate explosion risk (time + cost velocity)
109
+ const explosionRisk = this.calculateExplosionRisk(session, action, signals);
110
+ // Calculate avoidable cost
111
+ const estimatedAvoidableCost = this.calculateAvoidableCost(session, loopProbability);
112
+ // Build explanation
113
+ const explanation = this.buildExplanation(signals, loopProbability, explosionRisk, estimatedAvoidableCost);
114
+ // Decision
115
+ const blocked = loopProbability > this.config.loopProbabilityThreshold ||
116
+ explosionRisk > this.config.explosionRiskThreshold ||
117
+ (session.totalCost + action.estimatedCost > this.config.maxSessionCost);
118
+ // Record action if not blocked
119
+ if (!blocked) {
120
+ session.actions.push(action);
121
+ session.totalCost += action.estimatedCost;
122
+ session.lastActivity = Date.now();
123
+ }
124
+ return {
125
+ blocked,
126
+ loopProbability,
127
+ explosionRiskScore: explosionRisk,
128
+ estimatedAvoidableCost,
129
+ explanation,
130
+ detectedPatterns: signals.triggeredPatterns,
131
+ latencyMs: perf_hooks_1.performance.now() - start,
132
+ };
133
+ }
134
+ catch (error) {
135
+ return {
136
+ blocked: this.config.failOpen ? false : true,
137
+ loopProbability: 0,
138
+ explosionRiskScore: 0,
139
+ estimatedAvoidableCost: 0,
140
+ explanation: `Detection error: ${error instanceof Error ? error.message : 'unknown'}`,
141
+ detectedPatterns: [],
142
+ latencyMs: perf_hooks_1.performance.now() - start,
143
+ };
144
+ }
145
+ }
146
+ /**
147
+ * Analyze 5 required signals:
148
+ * 1. Embedding similarity between consecutive actions
149
+ * 2. Intent drift score (convergence detection)
150
+ * 3. Tool-call repetition graph
151
+ * 4. Entropy reduction over time
152
+ * 5. Cost velocity acceleration
153
+ */
154
+ analyzeSignals(session, currentAction) {
155
+ const recentActions = session.actions.slice(-10); // Look at last 10
156
+ const triggeredPatterns = [];
157
+ // SIGNAL 1: Embedding Similarity
158
+ let embeddingSimilarity = 0;
159
+ if (recentActions.length > 0 && currentAction.inputEmbedding) {
160
+ for (const prev of recentActions.slice(-3)) { // Compare with last 3
161
+ if (prev.inputEmbedding) {
162
+ const sim = this.embeddings.cosineSimilarity(currentAction.inputEmbedding, prev.inputEmbedding);
163
+ embeddingSimilarity = Math.max(embeddingSimilarity, sim);
164
+ }
165
+ }
166
+ }
167
+ if (embeddingSimilarity > 0.85)
168
+ triggeredPatterns.push('high_embedding_similarity');
169
+ // SIGNAL 2: Intent Convergence Score
170
+ // Check if we're converging to same solution repeatedly
171
+ let intentConvergenceScore = 0;
172
+ if (recentActions.length >= 3) {
173
+ const last3 = recentActions.slice(-3);
174
+ const similarities = [];
175
+ for (let i = 0; i < last3.length - 1; i++) {
176
+ if (last3[i].inputEmbedding && last3[i + 1].inputEmbedding) {
177
+ similarities.push(this.embeddings.cosineSimilarity(last3[i].inputEmbedding, last3[i + 1].inputEmbedding));
178
+ }
179
+ }
180
+ // High similarity AND stable = convergence
181
+ const avgSim = similarities.length > 0
182
+ ? similarities.reduce((a, b) => a + b, 0) / similarities.length
183
+ : 0;
184
+ const variance = similarities.length > 1
185
+ ? similarities.reduce((sum, s) => sum + Math.pow(s - avgSim, 2), 0) / similarities.length
186
+ : 1;
187
+ // High similarity with low variance = stuck in converging loop
188
+ intentConvergenceScore = avgSim * (1 - Math.min(1, variance * 3));
189
+ }
190
+ if (intentConvergenceScore > 0.8)
191
+ triggeredPatterns.push('intent_convergence');
192
+ // SIGNAL 3: Tool Repetition Score
193
+ let toolRepetitionScore = 0;
194
+ const currentTool = currentAction.toolName || currentAction.operation;
195
+ const recentTools = recentActions.map(a => a.toolName || a.operation);
196
+ const toolCounts = new Map();
197
+ for (const tool of recentTools) {
198
+ toolCounts.set(tool, (toolCounts.get(tool) || 0) + 1);
199
+ }
200
+ const currentCount = toolCounts.get(currentTool) || 0;
201
+ if (currentCount >= 2) {
202
+ toolRepetitionScore = Math.min(1, currentCount / 5);
203
+ triggeredPatterns.push('repeated_tool_calls');
204
+ }
205
+ // SIGNAL 4: Entropy Reduction
206
+ // Measure if action variety is decreasing (agent getting stuck)
207
+ let entropyReduction = 0;
208
+ if (session.actions.length >= 5) {
209
+ const firstHalf = session.actions.slice(0, Math.floor(session.actions.length / 2));
210
+ const secondHalf = session.actions.slice(Math.floor(session.actions.length / 2));
211
+ // Calculate "operation diversity" in each half
212
+ const firstOps = new Set(firstHalf.map(a => a.operation)).size;
213
+ const secondOps = new Set(secondHalf.map(a => a.operation)).size;
214
+ // If second half has fewer unique operations = entropy reduction
215
+ if (firstOps > 0) {
216
+ entropyReduction = Math.max(0, (firstOps - secondOps) / firstOps);
217
+ }
218
+ }
219
+ if (entropyReduction > 0.5)
220
+ triggeredPatterns.push('entropy_reduction');
221
+ // SIGNAL 5: Cost Velocity Acceleration
222
+ // Detect if spending is accelerating (runaway signal)
223
+ let costVelocityAcceleration = 0;
224
+ if (recentActions.length >= 3) {
225
+ const costs = recentActions.map(a => a.estimatedCost);
226
+ const diffs = [];
227
+ for (let i = 1; i < costs.length; i++) {
228
+ diffs.push(costs[i] - costs[i - 1]);
229
+ }
230
+ // If recent diffs are increasing = acceleration
231
+ if (diffs.length >= 2) {
232
+ const earlyAvg = diffs.slice(0, Math.floor(diffs.length / 2)).reduce((a, b) => a + b, 0)
233
+ / Math.floor(diffs.length / 2);
234
+ const lateAvg = diffs.slice(Math.floor(diffs.length / 2)).reduce((a, b) => a + b, 0)
235
+ / Math.ceil(diffs.length / 2);
236
+ if (earlyAvg !== 0) {
237
+ costVelocityAcceleration = Math.max(0, (lateAvg - earlyAvg) / Math.abs(earlyAvg));
238
+ }
239
+ }
240
+ }
241
+ if (costVelocityAcceleration > 1.0)
242
+ triggeredPatterns.push('cost_acceleration');
243
+ return {
244
+ embeddingSimilarity,
245
+ intentConvergenceScore,
246
+ toolRepetitionScore,
247
+ entropyReduction,
248
+ costVelocityAcceleration,
249
+ triggeredPatterns,
250
+ };
251
+ }
252
+ calculateLoopProbability(signals) {
253
+ // Weighted ensemble of signals
254
+ const weights = {
255
+ embedding: 0.30,
256
+ intent: 0.25,
257
+ tool: 0.20,
258
+ entropy: 0.15,
259
+ velocity: 0.10,
260
+ };
261
+ let score = signals.embeddingSimilarity * weights.embedding +
262
+ signals.intentConvergenceScore * weights.intent +
263
+ signals.toolRepetitionScore * weights.tool +
264
+ signals.entropyReduction * weights.entropy +
265
+ Math.min(1, signals.costVelocityAcceleration) * weights.velocity;
266
+ // Boost if multiple signals are high (ensemble effect)
267
+ const highSignals = [
268
+ signals.embeddingSimilarity > 0.8,
269
+ signals.intentConvergenceScore > 0.7,
270
+ signals.toolRepetitionScore > 0.6,
271
+ signals.entropyReduction > 0.5,
272
+ ].filter(Boolean).length;
273
+ if (highSignals >= 3)
274
+ score += 0.15;
275
+ if (highSignals >= 4)
276
+ score += 0.10;
277
+ return Math.min(1, score);
278
+ }
279
+ calculateExplosionRisk(session, action, signals) {
280
+ // Time-based risk: longer sessions = higher risk
281
+ const sessionDuration = Date.now() - session.startTime;
282
+ const timeRisk = Math.min(1, sessionDuration / (60 * 60 * 1000)); // 1 hour = max risk
283
+ // Cost velocity risk
284
+ const recentCost = session.actions.slice(-5).reduce((sum, a) => sum + a.estimatedCost, 0);
285
+ const costVelocity = recentCost / 5; // avg per recent action
286
+ const costRisk = Math.min(1, costVelocity / 0.5); // $0.50 per call = high
287
+ // Loop + high cost = explosion risk
288
+ const loopRisk = signals.embeddingSimilarity > 0.8 && signals.intentConvergenceScore > 0.7 ? 0.8 : 0;
289
+ return Math.min(1, (timeRisk * 0.3 + costRisk * 0.3 + loopRisk * 0.4));
290
+ }
291
+ calculateAvoidableCost(session, loopProbability) {
292
+ // If we don't stop now, what's the projected cost?
293
+ if (loopProbability < 0.5)
294
+ return 0;
295
+ const recentCost = session.actions.slice(-3).reduce((sum, a) => sum + a.estimatedCost, 0);
296
+ const avgCost = recentCost / 3;
297
+ // Project: if loop continues for 50 more iterations
298
+ const projectedIterations = Math.floor((1 - loopProbability) * 50) + 10;
299
+ return avgCost * projectedIterations;
300
+ }
301
+ buildExplanation(signals, loopProb, explosionRisk, avoidableCost) {
302
+ const parts = [];
303
+ if (signals.triggeredPatterns.includes('high_embedding_similarity')) {
304
+ parts.push('Input is semantically similar to recent actions');
305
+ }
306
+ if (signals.triggeredPatterns.includes('intent_convergence')) {
307
+ parts.push('Agent appears stuck converging on same solution');
308
+ }
309
+ if (signals.triggeredPatterns.includes('repeated_tool_calls')) {
310
+ parts.push('Same tools being called repeatedly');
311
+ }
312
+ if (signals.triggeredPatterns.includes('entropy_reduction')) {
313
+ parts.push('Action variety decreasing (getting stuck)');
314
+ }
315
+ if (signals.triggeredPatterns.includes('cost_acceleration')) {
316
+ parts.push('Cost per action is accelerating');
317
+ }
318
+ let explanation = parts.length > 0
319
+ ? `Loop detected: ${parts.join('; ')}.`
320
+ : 'No loop patterns detected.';
321
+ explanation += ` Loop probability: ${(loopProb * 100).toFixed(0)}%.`;
322
+ if (avoidableCost > 0) {
323
+ explanation += ` Blocking saves ~$${avoidableCost.toFixed(2)} in projected costs.`;
324
+ }
325
+ if (explosionRisk > 0.7) {
326
+ explanation += ` Explosion risk: ${(explosionRisk * 100).toFixed(0)}%.`;
327
+ }
328
+ return explanation;
329
+ }
330
+ cleanup() {
331
+ const now = Date.now();
332
+ const ttl = 2 * 60 * 60 * 1000; // 2 hours
333
+ for (const [id, session] of this.sessions) {
334
+ if (now - session.lastActivity > ttl) {
335
+ this.sessions.delete(id);
336
+ }
337
+ }
338
+ }
339
+ }
340
+ // ═══════════════════════════════════════════════════════════════════════════════
341
+ // COMPONENT 3: SDK WRAPPER (one-line integration)
342
+ // ═══════════════════════════════════════════════════════════════════════════════
343
+ let globalEngine = null;
344
+ function initLoopShield(config) {
345
+ globalEngine = new SemanticLoopDetectionEngine(config);
346
+ }
347
+ /**
348
+ * ONE-LINE INTEGRATION:
349
+ *
350
+ * const client = shield(new OpenAI({ apiKey }));
351
+ */
352
+ function shield(client, sessionId) {
353
+ if (!globalEngine) {
354
+ globalEngine = new SemanticLoopDetectionEngine();
355
+ }
356
+ const sid = sessionId || `session-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;
357
+ return new Proxy(client, {
358
+ get(target, prop) {
359
+ if (typeof prop !== 'string')
360
+ return target[prop];
361
+ const value = target[prop];
362
+ // Intercept method calls
363
+ if (typeof value === 'function') {
364
+ return async (...args) => {
365
+ // Extract operation info
366
+ const operation = prop;
367
+ const input = JSON.stringify(args);
368
+ const estimatedCost = estimateCost(operation, args);
369
+ // DETECT LOOP
370
+ const result = globalEngine.detect(sid, {
371
+ id: `${sid}-${Date.now()}`,
372
+ timestamp: Date.now(),
373
+ operation,
374
+ toolName: extractToolName(operation, args),
375
+ input,
376
+ estimatedCost,
377
+ metadata: extractMetadata(args),
378
+ });
379
+ if (result.blocked) {
380
+ const error = new Error(`LoopShield blocked: ${result.explanation}`);
381
+ error.shieldResult = result;
382
+ throw error;
383
+ }
384
+ // Execute
385
+ return value.apply(target, args);
386
+ };
387
+ }
388
+ // Handle nested objects
389
+ if (typeof value === 'object' && value !== null) {
390
+ return shield(value, sid);
391
+ }
392
+ return value;
393
+ },
394
+ });
395
+ }
396
+ function estimateCost(operation, args) {
397
+ // Estimate based on max_tokens
398
+ let tokens = 1000;
399
+ if (args[0]?.max_tokens)
400
+ tokens = args[0].max_tokens;
401
+ else if (args[0]?.maxTokens)
402
+ tokens = args[0].maxTokens;
403
+ // GPT-4 rate: $0.03 per 1K tokens
404
+ return (tokens / 1000) * 0.03;
405
+ }
406
+ function extractToolName(operation, args) {
407
+ if (args[0]?.model)
408
+ return args[0].model;
409
+ if (args[0]?.tool)
410
+ return args[0].tool;
411
+ return operation;
412
+ }
413
+ function extractMetadata(args) {
414
+ if (!args[0])
415
+ return {};
416
+ return {
417
+ model: args[0].model || args[0].modelName,
418
+ temperature: args[0].temperature,
419
+ maxTokens: args[0].max_tokens || args[0].maxTokens,
420
+ };
421
+ }
422
+ // Manual check for non-SDK usage
423
+ function checkLoop(sessionId, operation, input, estimatedCost, toolName) {
424
+ if (!globalEngine) {
425
+ globalEngine = new SemanticLoopDetectionEngine();
426
+ }
427
+ return globalEngine.detect(sessionId, {
428
+ id: `${sessionId}-${Date.now()}`,
429
+ timestamp: Date.now(),
430
+ operation,
431
+ toolName,
432
+ input,
433
+ estimatedCost,
434
+ });
435
+ }
436
+ //# sourceMappingURL=loop-shield.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loop-shield.js","sourceRoot":"","sources":["../src/loop-shield.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,109 @@
1
+ /**
2
+ * BusinessMetricsEngine.ts - Commercial Metrics Layer
3
+ *
4
+ * Tracks per-user business value:
5
+ * - Monthly savings ($)
6
+ * - Requests protected
7
+ * - Cost prevented
8
+ * - System efficiency score
9
+ * - Risk exposure prevented
10
+ *
11
+ * Purpose: Make the commercial value of the product visible and measurable.
12
+ */
13
+ export interface UserMetrics {
14
+ userId: string;
15
+ month: string;
16
+ monthlySavings: number;
17
+ totalRequestsProtected: number;
18
+ totalCostPrevented: number;
19
+ efficiencyScore: number;
20
+ averageResponseTimeMs: number;
21
+ uptimePercent: number;
22
+ riskExposurePrevented: number;
23
+ criticalBlocks: number;
24
+ loopDetections: number;
25
+ dailyActiveDays: number;
26
+ peakRequestsPerDay: number;
27
+ averageDailyRequests: number;
28
+ }
29
+ export interface LiveMetrics {
30
+ timestamp: number;
31
+ requestsLastMinute: number;
32
+ requestsLastHour: number;
33
+ savingsToday: number;
34
+ blocksLastHour: number;
35
+ activeUsers: number;
36
+ systemHealth: 'healthy' | 'degraded' | 'critical';
37
+ }
38
+ export interface MonthlySummary {
39
+ month: string;
40
+ totalSavings: number;
41
+ totalRequests: number;
42
+ totalBlocks: number;
43
+ topSavingsDay: {
44
+ date: string;
45
+ amount: number;
46
+ };
47
+ efficiencyTrend: 'improving' | 'stable' | 'declining';
48
+ projectedAnnualSavings: number;
49
+ }
50
+ export interface ProtectionEvent {
51
+ id: string;
52
+ timestamp: number;
53
+ userId: string;
54
+ type: 'block' | 'intercept' | 'loop_detected';
55
+ model: string;
56
+ estimatedCost: number;
57
+ moneySaved: number;
58
+ reason: string;
59
+ severity: 'low' | 'medium' | 'high' | 'critical';
60
+ }
61
+ /**
62
+ * BusinessMetricsEngine - Tracks commercial value of protection
63
+ *
64
+ * Every blocked request = money saved = business value delivered.
65
+ */
66
+ export declare class BusinessMetricsEngine {
67
+ private userMetrics;
68
+ private events;
69
+ private dailySavings;
70
+ /**
71
+ * Record a protection event (block, intercept, detection)
72
+ */
73
+ recordEvent(event: Omit<ProtectionEvent, 'id'>): ProtectionEvent;
74
+ /**
75
+ * Get live metrics for real-time dashboard
76
+ */
77
+ getLiveMetrics(): LiveMetrics;
78
+ /**
79
+ * Get monthly metrics for a user
80
+ */
81
+ getMonthlyMetrics(userId: string, month?: string): UserMetrics | undefined;
82
+ /**
83
+ * Get monthly summary with projections
84
+ */
85
+ getMonthlySummary(userId: string, month?: string): MonthlySummary;
86
+ /**
87
+ * Get recent protection activity for activity stream
88
+ */
89
+ getRecentActivity(userId: string, limit?: number): ProtectionEvent[];
90
+ /**
91
+ * Get risk exposure prevented (total potential disasters)
92
+ */
93
+ getRiskExposurePrevented(userId: string): {
94
+ totalExposure: number;
95
+ criticalEvents: number;
96
+ scenariosPrevented: string[];
97
+ };
98
+ /**
99
+ * Get system efficiency score
100
+ */
101
+ getEfficiencyScore(userId: string): number;
102
+ private updateUserMetrics;
103
+ private calculateSystemHealth;
104
+ private getCurrentMonth;
105
+ private getPreviousMonth;
106
+ }
107
+ export declare const businessMetrics: BusinessMetricsEngine;
108
+ export declare function createBusinessMetrics(): BusinessMetricsEngine;
109
+ //# sourceMappingURL=BusinessMetricsEngine.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BusinessMetricsEngine.d.ts","sourceRoot":"","sources":["../../src/metrics/BusinessMetricsEngine.ts"],"names":[],"mappings":"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"}