@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,148 @@
1
+ /**
2
+ * PolicyEngine.ts - Hierarchical Policy Engine
3
+ *
4
+ * Enterprise-grade policy system:
5
+ * - Tenant-level policies
6
+ * - Team-level policies
7
+ * - User-level policies
8
+ * - Workflow-level policies
9
+ *
10
+ * Rule types:
11
+ * - max cost per workflow
12
+ * - max tool-call depth
13
+ * - semantic repetition threshold
14
+ * - warn → throttle → block modes
15
+ */
16
+ import { EventEmitter } from 'events';
17
+ export type PolicyLevel = 'tenant' | 'team' | 'user' | 'workflow';
18
+ export type EnforcementMode = 'monitor' | 'warn' | 'throttle' | 'block';
19
+ export type PolicyAction = 'allow' | 'warn' | 'throttle' | 'block';
20
+ export interface PolicyRule {
21
+ id: string;
22
+ name: string;
23
+ description: string;
24
+ enabled: boolean;
25
+ priority: number;
26
+ condition: PolicyCondition;
27
+ action: PolicyAction;
28
+ throttleParams?: {
29
+ delayMs: number;
30
+ rateLimitPerMinute?: number;
31
+ };
32
+ }
33
+ export interface PolicyCondition {
34
+ type: 'cost_threshold' | 'depth_limit' | 'repetition_score' | 'loop_detected' | 'token_limit' | 'time_window' | 'custom';
35
+ operator: 'gt' | 'gte' | 'lt' | 'lte' | 'eq' | 'contains' | 'regex';
36
+ threshold: number | string | boolean;
37
+ windowMs?: number;
38
+ and?: PolicyCondition[];
39
+ or?: PolicyCondition[];
40
+ }
41
+ export interface PolicySet {
42
+ id: string;
43
+ tenantId: string;
44
+ level: PolicyLevel;
45
+ targetId: string;
46
+ rules: PolicyRule[];
47
+ defaultAction: PolicyAction;
48
+ maxCostPerWorkflow: number;
49
+ maxDepth: number;
50
+ maxTokensPerRequest: number;
51
+ repetitionThreshold: number;
52
+ createdAt: number;
53
+ updatedAt: number;
54
+ }
55
+ export interface PolicyEvaluationContext {
56
+ tenantId: string;
57
+ teamId?: string;
58
+ userId?: string;
59
+ workflowId?: string;
60
+ sessionId: string;
61
+ requestId: string;
62
+ currentCost: number;
63
+ currentDepth: number;
64
+ currentTokens: number;
65
+ repetitionScore: number;
66
+ loopDetected: boolean;
67
+ actionType: string;
68
+ timestamp: number;
69
+ }
70
+ export interface PolicyEvaluationResult {
71
+ action: PolicyAction;
72
+ reason: string;
73
+ confidence: number;
74
+ rulesTriggered: PolicyRule[];
75
+ policyChain: Array<{
76
+ level: PolicyLevel;
77
+ policyId: string;
78
+ action: PolicyAction;
79
+ }>;
80
+ throttleParams?: {
81
+ delayMs: number;
82
+ rateLimitPerMinute?: number;
83
+ };
84
+ }
85
+ export interface PolicyViolation {
86
+ rule: PolicyRule;
87
+ context: PolicyEvaluationContext;
88
+ actualValue: any;
89
+ expectedValue: any;
90
+ timestamp: number;
91
+ }
92
+ /**
93
+ * Policy Engine
94
+ *
95
+ * Evaluates hierarchical policies in order:
96
+ * 1. Tenant-level (most restrictive applies)
97
+ * 2. Team-level
98
+ * 3. User-level
99
+ * 4. Workflow-level (most specific)
100
+ *
101
+ * Action precedence: block > throttle > warn > allow
102
+ */
103
+ export declare class PolicyEngine extends EventEmitter {
104
+ private policies;
105
+ private tenantPolicies;
106
+ private violationHistory;
107
+ private maxViolationsPerTenant;
108
+ constructor();
109
+ /**
110
+ * Register a policy set
111
+ */
112
+ registerPolicy(policySet: PolicySet): void;
113
+ /**
114
+ * Evaluate policies for a request
115
+ * Returns the most restrictive action across all policy levels
116
+ */
117
+ evaluate(context: PolicyEvaluationContext): PolicyEvaluationResult;
118
+ /**
119
+ * Evaluate a single condition
120
+ */
121
+ private evaluateCondition;
122
+ /**
123
+ * Get policies relevant to a context
124
+ */
125
+ private getPoliciesForContext;
126
+ /**
127
+ * Record a policy violation
128
+ */
129
+ private recordViolation;
130
+ /**
131
+ * Get actual value for a condition from context
132
+ */
133
+ private getActualValue;
134
+ /**
135
+ * Action precedence for determining most restrictive
136
+ */
137
+ private actionPrecedence;
138
+ /**
139
+ * Get violations for a tenant
140
+ */
141
+ getViolations(tenantId: string, limit?: number): PolicyViolation[];
142
+ /**
143
+ * Create default tenant policy
144
+ */
145
+ createDefaultPolicy(tenantId: string): PolicySet;
146
+ }
147
+ export declare const policyEngine: PolicyEngine;
148
+ //# sourceMappingURL=PolicyEngine.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PolicyEngine.d.ts","sourceRoot":"","sources":["../../src/core/PolicyEngine.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,336 @@
1
+ "use strict";
2
+ /**
3
+ * PolicyEngine.ts - Hierarchical Policy Engine
4
+ *
5
+ * Enterprise-grade policy system:
6
+ * - Tenant-level policies
7
+ * - Team-level policies
8
+ * - User-level policies
9
+ * - Workflow-level policies
10
+ *
11
+ * Rule types:
12
+ * - max cost per workflow
13
+ * - max tool-call depth
14
+ * - semantic repetition threshold
15
+ * - warn → throttle → block modes
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.policyEngine = exports.PolicyEngine = void 0;
19
+ const events_1 = require("events");
20
+ /**
21
+ * Policy Engine
22
+ *
23
+ * Evaluates hierarchical policies in order:
24
+ * 1. Tenant-level (most restrictive applies)
25
+ * 2. Team-level
26
+ * 3. User-level
27
+ * 4. Workflow-level (most specific)
28
+ *
29
+ * Action precedence: block > throttle > warn > allow
30
+ */
31
+ class PolicyEngine extends events_1.EventEmitter {
32
+ constructor() {
33
+ super();
34
+ this.maxViolationsPerTenant = 1000;
35
+ this.policies = new Map();
36
+ this.tenantPolicies = new Map();
37
+ this.violationHistory = new Map();
38
+ }
39
+ /**
40
+ * Register a policy set
41
+ */
42
+ registerPolicy(policySet) {
43
+ const key = `${policySet.tenantId}:${policySet.level}:${policySet.targetId}`;
44
+ this.policies.set(key, policySet);
45
+ // Update tenant policies list
46
+ const tenantPols = this.tenantPolicies.get(policySet.tenantId) || [];
47
+ const existingIndex = tenantPols.findIndex(p => p.level === policySet.level && p.targetId === policySet.targetId);
48
+ if (existingIndex >= 0) {
49
+ tenantPols[existingIndex] = policySet;
50
+ }
51
+ else {
52
+ tenantPols.push(policySet);
53
+ }
54
+ this.tenantPolicies.set(policySet.tenantId, tenantPols);
55
+ this.emit('policy:registered', policySet);
56
+ }
57
+ /**
58
+ * Evaluate policies for a request
59
+ * Returns the most restrictive action across all policy levels
60
+ */
61
+ evaluate(context) {
62
+ const policyChain = [];
63
+ const rulesTriggered = [];
64
+ let finalAction = 'allow';
65
+ let finalReason = 'No policies violated';
66
+ let finalThrottleParams;
67
+ // Get policies for all levels
68
+ const policies = this.getPoliciesForContext(context);
69
+ // Evaluate from tenant (least specific) to workflow (most specific)
70
+ const levels = ['tenant', 'team', 'user', 'workflow'];
71
+ for (const level of levels) {
72
+ const levelPolicies = policies.filter(p => p.level === level);
73
+ for (const policy of levelPolicies) {
74
+ // Evaluate each rule in priority order
75
+ const sortedRules = [...policy.rules].sort((a, b) => b.priority - a.priority);
76
+ for (const rule of sortedRules) {
77
+ if (!rule.enabled)
78
+ continue;
79
+ const triggered = this.evaluateCondition(rule.condition, context);
80
+ if (triggered) {
81
+ rulesTriggered.push(rule);
82
+ policyChain.push({
83
+ level,
84
+ policyId: policy.id,
85
+ action: rule.action,
86
+ });
87
+ // Record violation
88
+ this.recordViolation(rule, context);
89
+ // Apply most restrictive action
90
+ if (this.actionPrecedence(rule.action) > this.actionPrecedence(finalAction)) {
91
+ finalAction = rule.action;
92
+ finalReason = `Policy rule "${rule.name}" triggered at ${level} level`;
93
+ finalThrottleParams = rule.throttleParams;
94
+ }
95
+ // If block, no need to continue evaluating
96
+ if (finalAction === 'block') {
97
+ break;
98
+ }
99
+ }
100
+ }
101
+ if (finalAction === 'block')
102
+ break;
103
+ }
104
+ if (finalAction === 'block')
105
+ break;
106
+ }
107
+ // Apply default tenant policy if no rules triggered
108
+ if (finalAction === 'allow' && policies.length > 0) {
109
+ const tenantPolicy = policies.find(p => p.level === 'tenant');
110
+ if (tenantPolicy && tenantPolicy.defaultAction !== 'allow') {
111
+ finalAction = tenantPolicy.defaultAction;
112
+ finalReason = 'Default tenant policy applied';
113
+ }
114
+ }
115
+ return {
116
+ action: finalAction,
117
+ reason: finalReason,
118
+ confidence: rulesTriggered.length > 0 ? 0.9 : 1.0,
119
+ rulesTriggered,
120
+ policyChain,
121
+ throttleParams: finalThrottleParams,
122
+ };
123
+ }
124
+ /**
125
+ * Evaluate a single condition
126
+ */
127
+ evaluateCondition(condition, context) {
128
+ // Handle composite conditions
129
+ if (condition.and) {
130
+ return condition.and.every(c => this.evaluateCondition(c, context));
131
+ }
132
+ if (condition.or) {
133
+ return condition.or.some(c => this.evaluateCondition(c, context));
134
+ }
135
+ // Get the value to compare based on condition type
136
+ let value;
137
+ switch (condition.type) {
138
+ case 'cost_threshold':
139
+ value = context.currentCost;
140
+ break;
141
+ case 'depth_limit':
142
+ value = context.currentDepth;
143
+ break;
144
+ case 'token_limit':
145
+ value = context.currentTokens;
146
+ break;
147
+ case 'repetition_score':
148
+ value = context.repetitionScore;
149
+ break;
150
+ case 'loop_detected':
151
+ value = context.loopDetected;
152
+ break;
153
+ default:
154
+ value = null;
155
+ }
156
+ // Compare based on operator
157
+ switch (condition.operator) {
158
+ case 'gt':
159
+ return value > condition.threshold;
160
+ case 'gte':
161
+ return value >= condition.threshold;
162
+ case 'lt':
163
+ return value < condition.threshold;
164
+ case 'lte':
165
+ return value <= condition.threshold;
166
+ case 'eq':
167
+ return value === condition.threshold;
168
+ case 'contains':
169
+ return String(value).includes(String(condition.threshold));
170
+ default:
171
+ return false;
172
+ }
173
+ }
174
+ /**
175
+ * Get policies relevant to a context
176
+ */
177
+ getPoliciesForContext(context) {
178
+ const policies = [];
179
+ const tenantPols = this.tenantPolicies.get(context.tenantId) || [];
180
+ for (const policy of tenantPols) {
181
+ // Check if policy applies to this context
182
+ let applies = false;
183
+ switch (policy.level) {
184
+ case 'tenant':
185
+ applies = true;
186
+ break;
187
+ case 'team':
188
+ applies = context.teamId === policy.targetId;
189
+ break;
190
+ case 'user':
191
+ applies = context.userId === policy.targetId;
192
+ break;
193
+ case 'workflow':
194
+ applies = context.workflowId === policy.targetId;
195
+ break;
196
+ }
197
+ if (applies) {
198
+ policies.push(policy);
199
+ }
200
+ }
201
+ return policies;
202
+ }
203
+ /**
204
+ * Record a policy violation
205
+ */
206
+ recordViolation(rule, context) {
207
+ const violations = this.violationHistory.get(context.tenantId) || [];
208
+ violations.push({
209
+ rule,
210
+ context,
211
+ actualValue: this.getActualValue(rule.condition, context),
212
+ expectedValue: rule.condition.threshold,
213
+ timestamp: Date.now(),
214
+ });
215
+ // Keep only recent violations
216
+ if (violations.length > this.maxViolationsPerTenant) {
217
+ violations.splice(0, violations.length - this.maxViolationsPerTenant);
218
+ }
219
+ this.violationHistory.set(context.tenantId, violations);
220
+ this.emit('policy:violation', { rule, context });
221
+ }
222
+ /**
223
+ * Get actual value for a condition from context
224
+ */
225
+ getActualValue(condition, context) {
226
+ switch (condition.type) {
227
+ case 'cost_threshold':
228
+ return context.currentCost;
229
+ case 'depth_limit':
230
+ return context.currentDepth;
231
+ case 'token_limit':
232
+ return context.currentTokens;
233
+ case 'repetition_score':
234
+ return context.repetitionScore;
235
+ case 'loop_detected':
236
+ return context.loopDetected;
237
+ default:
238
+ return null;
239
+ }
240
+ }
241
+ /**
242
+ * Action precedence for determining most restrictive
243
+ */
244
+ actionPrecedence(action) {
245
+ const precedence = {
246
+ allow: 0,
247
+ warn: 1,
248
+ throttle: 2,
249
+ block: 3,
250
+ };
251
+ return precedence[action];
252
+ }
253
+ /**
254
+ * Get violations for a tenant
255
+ */
256
+ getViolations(tenantId, limit = 100) {
257
+ const violations = this.violationHistory.get(tenantId) || [];
258
+ return violations.slice(-limit);
259
+ }
260
+ /**
261
+ * Create default tenant policy
262
+ */
263
+ createDefaultPolicy(tenantId) {
264
+ return {
265
+ id: `default-${tenantId}`,
266
+ tenantId,
267
+ level: 'tenant',
268
+ targetId: tenantId,
269
+ rules: [
270
+ {
271
+ id: 'max-cost',
272
+ name: 'Maximum Cost Per Workflow',
273
+ description: 'Block workflows exceeding $10',
274
+ enabled: true,
275
+ priority: 100,
276
+ condition: {
277
+ type: 'cost_threshold',
278
+ operator: 'gt',
279
+ threshold: 10,
280
+ },
281
+ action: 'block',
282
+ },
283
+ {
284
+ id: 'max-depth',
285
+ name: 'Maximum Tool Call Depth',
286
+ description: 'Block workflows exceeding 10 levels deep',
287
+ enabled: true,
288
+ priority: 90,
289
+ condition: {
290
+ type: 'depth_limit',
291
+ operator: 'gt',
292
+ threshold: 10,
293
+ },
294
+ action: 'block',
295
+ },
296
+ {
297
+ id: 'loop-detection',
298
+ name: 'Loop Detection',
299
+ description: 'Block when loops are detected',
300
+ enabled: true,
301
+ priority: 95,
302
+ condition: {
303
+ type: 'loop_detected',
304
+ operator: 'eq',
305
+ threshold: true,
306
+ },
307
+ action: 'block',
308
+ },
309
+ {
310
+ id: 'high-cost-warning',
311
+ name: 'High Cost Warning',
312
+ description: 'Warn when cost exceeds $5',
313
+ enabled: true,
314
+ priority: 50,
315
+ condition: {
316
+ type: 'cost_threshold',
317
+ operator: 'gt',
318
+ threshold: 5,
319
+ },
320
+ action: 'warn',
321
+ },
322
+ ],
323
+ defaultAction: 'allow',
324
+ maxCostPerWorkflow: 10,
325
+ maxDepth: 10,
326
+ maxTokensPerRequest: 100000,
327
+ repetitionThreshold: 0.8,
328
+ createdAt: Date.now(),
329
+ updatedAt: Date.now(),
330
+ };
331
+ }
332
+ }
333
+ exports.PolicyEngine = PolicyEngine;
334
+ // Export singleton
335
+ exports.policyEngine = new PolicyEngine();
336
+ //# sourceMappingURL=PolicyEngine.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PolicyEngine.js","sourceRoot":"","sources":["../../src/core/PolicyEngine.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,55 @@
1
+ /**
2
+ * PricingConfig.ts - Real API Pricing Configuration
3
+ *
4
+ * Maps token counts to actual costs for supported models
5
+ * Used for real cost extraction from API responses
6
+ */
7
+ export interface ModelPricing {
8
+ inputPer1K: number;
9
+ outputPer1K: number;
10
+ provider: 'openai' | 'anthropic' | 'google' | 'cohere';
11
+ }
12
+ export interface TokenUsage {
13
+ prompt_tokens: number;
14
+ completion_tokens: number;
15
+ total_tokens: number;
16
+ }
17
+ export interface CostCalculation {
18
+ inputCost: number;
19
+ outputCost: number;
20
+ totalCost: number;
21
+ model: string;
22
+ pricing: ModelPricing;
23
+ }
24
+ /**
25
+ * Pricing Configuration - Singleton
26
+ * Stores real pricing data for AI providers
27
+ */
28
+ export declare class PricingConfig {
29
+ private static instance;
30
+ private pricing;
31
+ private constructor();
32
+ static getInstance(): PricingConfig;
33
+ /**
34
+ * Get pricing for a model
35
+ */
36
+ getPricing(model: string): ModelPricing;
37
+ /**
38
+ * Calculate real cost from token usage
39
+ */
40
+ calculateCost(model: string, usage: TokenUsage): CostCalculation;
41
+ /**
42
+ * Extract token usage from various API response formats
43
+ */
44
+ extractUsage(response: any): TokenUsage | null;
45
+ /**
46
+ * Update pricing for a model (for custom models)
47
+ */
48
+ updatePricing(model: string, pricing: ModelPricing): void;
49
+ /**
50
+ * Get all supported models
51
+ */
52
+ getSupportedModels(): string[];
53
+ }
54
+ export declare const pricingConfig: PricingConfig;
55
+ //# sourceMappingURL=PricingConfig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PricingConfig.d.ts","sourceRoot":"","sources":["../../src/core/PricingConfig.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,WAAW,YAAY;IAC3B,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,QAAQ,GAAG,WAAW,GAAG,QAAQ,GAAG,QAAQ,CAAC;CACxD;AAED,MAAM,WAAW,UAAU;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,YAAY,CAAC;CACvB;AAED;;;GAGG;AACH,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAgB;IACvC,OAAO,CAAC,OAAO,CAA+B;IAE9C,OAAO;IAoCP,MAAM,CAAC,WAAW,IAAI,aAAa;IAOnC;;OAEG;IACH,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY;IAevC;;OAEG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,GAAG,eAAe;IAgBhE;;OAEG;IACH,YAAY,CAAC,QAAQ,EAAE,GAAG,GAAG,UAAU,GAAG,IAAI;IAmC9C;;OAEG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,GAAG,IAAI;IAIzD;;OAEG;IACH,kBAAkB,IAAI,MAAM,EAAE;CAG/B;AAGD,eAAO,MAAM,aAAa,eAA8B,CAAC"}