@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.
- package/README.md +112 -0
- package/dist/aecl/ExecutionInterceptor.d.ts +111 -0
- package/dist/aecl/ExecutionInterceptor.d.ts.map +1 -0
- package/dist/aecl/ExecutionInterceptor.js +280 -0
- package/dist/aecl/ExecutionInterceptor.js.map +1 -0
- package/dist/aecl/ExecutionMemory.d.ts +103 -0
- package/dist/aecl/ExecutionMemory.d.ts.map +1 -0
- package/dist/aecl/ExecutionMemory.js +164 -0
- package/dist/aecl/ExecutionMemory.js.map +1 -0
- package/dist/aecl/PolicyEngine.d.ts +77 -0
- package/dist/aecl/PolicyEngine.d.ts.map +1 -0
- package/dist/aecl/PolicyEngine.js +170 -0
- package/dist/aecl/PolicyEngine.js.map +1 -0
- package/dist/aecl/ROITelemetry.d.ts +110 -0
- package/dist/aecl/ROITelemetry.d.ts.map +1 -0
- package/dist/aecl/ROITelemetry.js +211 -0
- package/dist/aecl/ROITelemetry.js.map +1 -0
- package/dist/aecl/RiskEngine.d.ts +90 -0
- package/dist/aecl/RiskEngine.d.ts.map +1 -0
- package/dist/aecl/RiskEngine.js +207 -0
- package/dist/aecl/RiskEngine.js.map +1 -0
- package/dist/aecl/index.d.ts +76 -0
- package/dist/aecl/index.d.ts.map +1 -0
- package/dist/aecl/index.js +111 -0
- package/dist/aecl/index.js.map +1 -0
- package/dist/aerl/ExecutionGraph.d.ts +123 -0
- package/dist/aerl/ExecutionGraph.d.ts.map +1 -0
- package/dist/aerl/ExecutionGraph.js +289 -0
- package/dist/aerl/ExecutionGraph.js.map +1 -0
- package/dist/aerl/ExecutionInterceptor.d.ts +94 -0
- package/dist/aerl/ExecutionInterceptor.d.ts.map +1 -0
- package/dist/aerl/ExecutionInterceptor.js +246 -0
- package/dist/aerl/ExecutionInterceptor.js.map +1 -0
- package/dist/aerl/ExecutionMemory.d.ts +138 -0
- package/dist/aerl/ExecutionMemory.d.ts.map +1 -0
- package/dist/aerl/ExecutionMemory.js +284 -0
- package/dist/aerl/ExecutionMemory.js.map +1 -0
- package/dist/aerl/FailurePrediction.d.ts +71 -0
- package/dist/aerl/FailurePrediction.d.ts.map +1 -0
- package/dist/aerl/FailurePrediction.js +204 -0
- package/dist/aerl/FailurePrediction.js.map +1 -0
- package/dist/aerl/RecoveryEngine.d.ts +74 -0
- package/dist/aerl/RecoveryEngine.d.ts.map +1 -0
- package/dist/aerl/RecoveryEngine.js +194 -0
- package/dist/aerl/RecoveryEngine.js.map +1 -0
- package/dist/aerl/ReliabilityEngine.d.ts +74 -0
- package/dist/aerl/ReliabilityEngine.d.ts.map +1 -0
- package/dist/aerl/ReliabilityEngine.js +205 -0
- package/dist/aerl/ReliabilityEngine.js.map +1 -0
- package/dist/aerl/ReliabilityTelemetry.d.ts +118 -0
- package/dist/aerl/ReliabilityTelemetry.d.ts.map +1 -0
- package/dist/aerl/ReliabilityTelemetry.js +247 -0
- package/dist/aerl/ReliabilityTelemetry.js.map +1 -0
- package/dist/aerl/index.d.ts +170 -0
- package/dist/aerl/index.d.ts.map +1 -0
- package/dist/aerl/index.js +223 -0
- package/dist/aerl/index.js.map +1 -0
- package/dist/ambient/AmbientProtection.d.ts +79 -0
- package/dist/ambient/AmbientProtection.d.ts.map +1 -0
- package/dist/ambient/AmbientProtection.js +251 -0
- package/dist/ambient/AmbientProtection.js.map +1 -0
- package/dist/bin/start.d.ts +14 -0
- package/dist/bin/start.d.ts.map +1 -0
- package/dist/bin/start.js +54 -0
- package/dist/bin/start.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +64 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/outputContract.d.ts +19 -0
- package/dist/cli/outputContract.d.ts.map +1 -0
- package/dist/cli/outputContract.js +54 -0
- package/dist/cli/outputContract.js.map +1 -0
- package/dist/cli/storage.d.ts +61 -0
- package/dist/cli/storage.d.ts.map +1 -0
- package/dist/cli/storage.js +143 -0
- package/dist/cli/storage.js.map +1 -0
- package/dist/client.d.ts +29 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +58 -0
- package/dist/client.js.map +1 -0
- package/dist/config/constants.d.ts +109 -0
- package/dist/config/constants.d.ts.map +1 -0
- package/dist/config/constants.js +151 -0
- package/dist/config/constants.js.map +1 -0
- package/dist/config/index.d.ts +5 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +21 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/pricing.d.ts +12 -0
- package/dist/config/pricing.d.ts.map +1 -0
- package/dist/config/pricing.js +45 -0
- package/dist/config/pricing.js.map +1 -0
- package/dist/config/productionConfig.d.ts +8 -0
- package/dist/config/productionConfig.d.ts.map +1 -0
- package/dist/config/productionConfig.js +21 -0
- package/dist/config/productionConfig.js.map +1 -0
- package/dist/config/userConfig.d.ts +31 -0
- package/dist/config/userConfig.d.ts.map +1 -0
- package/dist/config/userConfig.js +116 -0
- package/dist/config/userConfig.js.map +1 -0
- package/dist/controlPlane/configServer.d.ts +7 -0
- package/dist/controlPlane/configServer.d.ts.map +1 -0
- package/dist/controlPlane/configServer.js +47 -0
- package/dist/controlPlane/configServer.js.map +1 -0
- package/dist/core/AgentBehaviorGraph.d.ts +163 -0
- package/dist/core/AgentBehaviorGraph.d.ts.map +1 -0
- package/dist/core/AgentBehaviorGraph.js +341 -0
- package/dist/core/AgentBehaviorGraph.js.map +1 -0
- package/dist/core/AlertManager.d.ts +19 -0
- package/dist/core/AlertManager.d.ts.map +1 -0
- package/dist/core/AlertManager.js +64 -0
- package/dist/core/AlertManager.js.map +1 -0
- package/dist/core/AuditTrail.d.ts +107 -0
- package/dist/core/AuditTrail.d.ts.map +1 -0
- package/dist/core/AuditTrail.js +256 -0
- package/dist/core/AuditTrail.js.map +1 -0
- package/dist/core/CostLedger.d.ts +135 -0
- package/dist/core/CostLedger.d.ts.map +1 -0
- package/dist/core/CostLedger.js +224 -0
- package/dist/core/CostLedger.js.map +1 -0
- package/dist/core/CostPredictionEngine.d.ts +110 -0
- package/dist/core/CostPredictionEngine.d.ts.map +1 -0
- package/dist/core/CostPredictionEngine.js +225 -0
- package/dist/core/CostPredictionEngine.js.map +1 -0
- package/dist/core/CostTruthEngine.d.ts +108 -0
- package/dist/core/CostTruthEngine.d.ts.map +1 -0
- package/dist/core/CostTruthEngine.js +170 -0
- package/dist/core/CostTruthEngine.js.map +1 -0
- package/dist/core/DetectionEngine.d.ts +147 -0
- package/dist/core/DetectionEngine.d.ts.map +1 -0
- package/dist/core/DetectionEngine.js +429 -0
- package/dist/core/DetectionEngine.js.map +1 -0
- package/dist/core/ExecutionInterceptor.d.ts +135 -0
- package/dist/core/ExecutionInterceptor.d.ts.map +1 -0
- package/dist/core/ExecutionInterceptor.js +285 -0
- package/dist/core/ExecutionInterceptor.js.map +1 -0
- package/dist/core/ExplainabilityLayer.d.ts +109 -0
- package/dist/core/ExplainabilityLayer.d.ts.map +1 -0
- package/dist/core/ExplainabilityLayer.js +277 -0
- package/dist/core/ExplainabilityLayer.js.map +1 -0
- package/dist/core/LearningSystem.d.ts +124 -0
- package/dist/core/LearningSystem.d.ts.map +1 -0
- package/dist/core/LearningSystem.js +294 -0
- package/dist/core/LearningSystem.js.map +1 -0
- package/dist/core/Logger.d.ts +122 -0
- package/dist/core/Logger.d.ts.map +1 -0
- package/dist/core/Logger.js +233 -0
- package/dist/core/Logger.js.map +1 -0
- package/dist/core/PolicyEngine.d.ts +148 -0
- package/dist/core/PolicyEngine.d.ts.map +1 -0
- package/dist/core/PolicyEngine.js +336 -0
- package/dist/core/PolicyEngine.js.map +1 -0
- package/dist/core/PricingConfig.d.ts +55 -0
- package/dist/core/PricingConfig.d.ts.map +1 -0
- package/dist/core/PricingConfig.js +132 -0
- package/dist/core/PricingConfig.js.map +1 -0
- package/dist/core/SessionStats.d.ts +101 -0
- package/dist/core/SessionStats.d.ts.map +1 -0
- package/dist/core/SessionStats.js +261 -0
- package/dist/core/SessionStats.js.map +1 -0
- package/dist/core/StateStore.d.ts +100 -0
- package/dist/core/StateStore.d.ts.map +1 -0
- package/dist/core/StateStore.js +336 -0
- package/dist/core/StateStore.js.map +1 -0
- package/dist/core/index.d.ts +3 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +19 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/types.d.ts +26 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +3 -0
- package/dist/core/types.js.map +1 -0
- package/dist/cost-guard.d.ts +41 -0
- package/dist/cost-guard.d.ts.map +1 -0
- package/dist/cost-guard.js +274 -0
- package/dist/cost-guard.js.map +1 -0
- package/dist/dashboard/roiDashboard.d.ts +12 -0
- package/dist/dashboard/roiDashboard.d.ts.map +1 -0
- package/dist/dashboard/roiDashboard.js +28 -0
- package/dist/dashboard/roiDashboard.js.map +1 -0
- package/dist/demo/compareExecution.d.ts +9 -0
- package/dist/demo/compareExecution.d.ts.map +1 -0
- package/dist/demo/compareExecution.js +43 -0
- package/dist/demo/compareExecution.js.map +1 -0
- package/dist/demo/demoRunner.d.ts +16 -0
- package/dist/demo/demoRunner.d.ts.map +1 -0
- package/dist/demo/demoRunner.js +73 -0
- package/dist/demo/demoRunner.js.map +1 -0
- package/dist/firewall/costEstimator.d.ts +3 -0
- package/dist/firewall/costEstimator.d.ts.map +1 -0
- package/dist/firewall/costEstimator.js +22 -0
- package/dist/firewall/costEstimator.js.map +1 -0
- package/dist/firewall/executionGuard.d.ts +18 -0
- package/dist/firewall/executionGuard.d.ts.map +1 -0
- package/dist/firewall/executionGuard.js +80 -0
- package/dist/firewall/executionGuard.js.map +1 -0
- package/dist/firewall/loopDetector.d.ts +13 -0
- package/dist/firewall/loopDetector.d.ts.map +1 -0
- package/dist/firewall/loopDetector.js +24 -0
- package/dist/firewall/loopDetector.js.map +1 -0
- package/dist/firewall/policy.d.ts +4 -0
- package/dist/firewall/policy.d.ts.map +1 -0
- package/dist/firewall/policy.js +16 -0
- package/dist/firewall/policy.js.map +1 -0
- package/dist/firewall/types.d.ts +38 -0
- package/dist/firewall/types.d.ts.map +1 -0
- package/dist/firewall/types.js +3 -0
- package/dist/firewall/types.js.map +1 -0
- package/dist/index.d.ts +40 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +76 -0
- package/dist/index.js.map +1 -0
- package/dist/logger/console.d.ts +27 -0
- package/dist/logger/console.d.ts.map +1 -0
- package/dist/logger/console.js +68 -0
- package/dist/logger/console.js.map +1 -0
- package/dist/logger/database.d.ts +40 -0
- package/dist/logger/database.d.ts.map +1 -0
- package/dist/logger/database.js +127 -0
- package/dist/logger/database.js.map +1 -0
- package/dist/logger/index.d.ts +3 -0
- package/dist/logger/index.d.ts.map +1 -0
- package/dist/logger/index.js +11 -0
- package/dist/logger/index.js.map +1 -0
- package/dist/loop-shield.d.ts +48 -0
- package/dist/loop-shield.d.ts.map +1 -0
- package/dist/loop-shield.js +436 -0
- package/dist/loop-shield.js.map +1 -0
- package/dist/metrics/BusinessMetricsEngine.d.ts +109 -0
- package/dist/metrics/BusinessMetricsEngine.d.ts.map +1 -0
- package/dist/metrics/BusinessMetricsEngine.js +222 -0
- package/dist/metrics/BusinessMetricsEngine.js.map +1 -0
- package/dist/metrics/index.d.ts +11 -0
- package/dist/metrics/index.d.ts.map +1 -0
- package/dist/metrics/index.js +17 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/middleware/expressFirewall.d.ts +51 -0
- package/dist/middleware/expressFirewall.d.ts.map +1 -0
- package/dist/middleware/expressFirewall.js +140 -0
- package/dist/middleware/expressFirewall.js.map +1 -0
- package/dist/middleware/index.d.ts +8 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js +15 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/withFirewall.d.ts +50 -0
- package/dist/middleware/withFirewall.d.ts.map +1 -0
- package/dist/middleware/withFirewall.js +155 -0
- package/dist/middleware/withFirewall.js.map +1 -0
- package/dist/observability/logger.d.ts +14 -0
- package/dist/observability/logger.d.ts.map +1 -0
- package/dist/observability/logger.js +21 -0
- package/dist/observability/logger.js.map +1 -0
- package/dist/observability/metrics.d.ts +17 -0
- package/dist/observability/metrics.d.ts.map +1 -0
- package/dist/observability/metrics.js +36 -0
- package/dist/observability/metrics.js.map +1 -0
- package/dist/os/ExecutionOS.d.ts +220 -0
- package/dist/os/ExecutionOS.d.ts.map +1 -0
- package/dist/os/ExecutionOS.js +398 -0
- package/dist/os/ExecutionOS.js.map +1 -0
- package/dist/os/GlobalIntelligence.d.ts +154 -0
- package/dist/os/GlobalIntelligence.d.ts.map +1 -0
- package/dist/os/GlobalIntelligence.js +374 -0
- package/dist/os/GlobalIntelligence.js.map +1 -0
- package/dist/os/PolicyMarketplace.d.ts +192 -0
- package/dist/os/PolicyMarketplace.d.ts.map +1 -0
- package/dist/os/PolicyMarketplace.js +384 -0
- package/dist/os/PolicyMarketplace.js.map +1 -0
- package/dist/os/SDKInterception.d.ts +115 -0
- package/dist/os/SDKInterception.d.ts.map +1 -0
- package/dist/os/SDKInterception.js +317 -0
- package/dist/os/SDKInterception.js.map +1 -0
- package/dist/os/index.d.ts +60 -0
- package/dist/os/index.d.ts.map +1 -0
- package/dist/os/index.js +82 -0
- package/dist/os/index.js.map +1 -0
- package/dist/proxy/index.d.ts +2 -0
- package/dist/proxy/index.d.ts.map +1 -0
- package/dist/proxy/index.js +18 -0
- package/dist/proxy/index.js.map +1 -0
- package/dist/proxy/server.d.ts +24 -0
- package/dist/proxy/server.d.ts.map +1 -0
- package/dist/proxy/server.js +395 -0
- package/dist/proxy/server.js.map +1 -0
- package/dist/public/BenchmarksPage.d.ts +60 -0
- package/dist/public/BenchmarksPage.d.ts.map +1 -0
- package/dist/public/BenchmarksPage.js +397 -0
- package/dist/public/BenchmarksPage.js.map +1 -0
- package/dist/public/DocsPage.d.ts +11 -0
- package/dist/public/DocsPage.d.ts.map +1 -0
- package/dist/public/DocsPage.js +496 -0
- package/dist/public/DocsPage.js.map +1 -0
- package/dist/public/StatusPage.d.ts +55 -0
- package/dist/public/StatusPage.d.ts.map +1 -0
- package/dist/public/StatusPage.js +344 -0
- package/dist/public/StatusPage.js.map +1 -0
- package/dist/public/index.d.ts +12 -0
- package/dist/public/index.d.ts.map +1 -0
- package/dist/public/index.js +20 -0
- package/dist/public/index.js.map +1 -0
- package/dist/replacements/axios.d.ts +14 -0
- package/dist/replacements/axios.d.ts.map +1 -0
- package/dist/replacements/axios.js +35 -0
- package/dist/replacements/axios.js.map +1 -0
- package/dist/replacements/fetch.d.ts +13 -0
- package/dist/replacements/fetch.d.ts.map +1 -0
- package/dist/replacements/fetch.js +20 -0
- package/dist/replacements/fetch.js.map +1 -0
- package/dist/replacements/openai.d.ts +14 -0
- package/dist/replacements/openai.d.ts.map +1 -0
- package/dist/replacements/openai.js +22 -0
- package/dist/replacements/openai.js.map +1 -0
- package/dist/saas/CostExplosionDemo.d.ts +56 -0
- package/dist/saas/CostExplosionDemo.d.ts.map +1 -0
- package/dist/saas/CostExplosionDemo.js +190 -0
- package/dist/saas/CostExplosionDemo.js.map +1 -0
- package/dist/saas/LiveProtection.d.ts +61 -0
- package/dist/saas/LiveProtection.d.ts.map +1 -0
- package/dist/saas/LiveProtection.js +187 -0
- package/dist/saas/LiveProtection.js.map +1 -0
- package/dist/saas/ProductionSaaS.d.ts +56 -0
- package/dist/saas/ProductionSaaS.d.ts.map +1 -0
- package/dist/saas/ProductionSaaS.js +831 -0
- package/dist/saas/ProductionSaaS.js.map +1 -0
- package/dist/saas/SaaSServer.d.ts +50 -0
- package/dist/saas/SaaSServer.d.ts.map +1 -0
- package/dist/saas/SaaSServer.js +669 -0
- package/dist/saas/SaaSServer.js.map +1 -0
- package/dist/saas/UserStore.d.ts +49 -0
- package/dist/saas/UserStore.d.ts.map +1 -0
- package/dist/saas/UserStore.js +137 -0
- package/dist/saas/UserStore.js.map +1 -0
- package/dist/saas/billingMetrics.d.ts +14 -0
- package/dist/saas/billingMetrics.d.ts.map +1 -0
- package/dist/saas/billingMetrics.js +23 -0
- package/dist/saas/billingMetrics.js.map +1 -0
- package/dist/saas/index.d.ts +12 -0
- package/dist/saas/index.d.ts.map +1 -0
- package/dist/saas/index.js +23 -0
- package/dist/saas/index.js.map +1 -0
- package/dist/saas/telemetry.d.ts +24 -0
- package/dist/saas/telemetry.d.ts.map +1 -0
- package/dist/saas/telemetry.js +30 -0
- package/dist/saas/telemetry.js.map +1 -0
- package/dist/saas/usageMeter.d.ts +28 -0
- package/dist/saas/usageMeter.d.ts.map +1 -0
- package/dist/saas/usageMeter.js +41 -0
- package/dist/saas/usageMeter.js.map +1 -0
- package/dist/security/TrustBoundaryValidator.d.ts +105 -0
- package/dist/security/TrustBoundaryValidator.d.ts.map +1 -0
- package/dist/security/TrustBoundaryValidator.js +305 -0
- package/dist/security/TrustBoundaryValidator.js.map +1 -0
- package/dist/starters/express-protected.d.ts +18 -0
- package/dist/starters/express-protected.d.ts.map +1 -0
- package/dist/starters/express-protected.js +93 -0
- package/dist/starters/express-protected.js.map +1 -0
- package/dist/starters/langchain-protected.d.ts +18 -0
- package/dist/starters/langchain-protected.d.ts.map +1 -0
- package/dist/starters/langchain-protected.js +85 -0
- package/dist/starters/langchain-protected.js.map +1 -0
- package/dist/starters/openai-protected.d.ts +19 -0
- package/dist/starters/openai-protected.d.ts.map +1 -0
- package/dist/starters/openai-protected.js +84 -0
- package/dist/starters/openai-protected.js.map +1 -0
- package/dist/starters/serverless-protected.d.ts +19 -0
- package/dist/starters/serverless-protected.d.ts.map +1 -0
- package/dist/starters/serverless-protected.js +83 -0
- package/dist/starters/serverless-protected.js.map +1 -0
- package/dist/storage/adapters.d.ts +24 -0
- package/dist/storage/adapters.d.ts.map +1 -0
- package/dist/storage/adapters.js +123 -0
- package/dist/storage/adapters.js.map +1 -0
- package/dist/storage/index.d.ts +2 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +8 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/tests/b2b-hardening.test.d.ts +2 -0
- package/dist/tests/b2b-hardening.test.d.ts.map +1 -0
- package/dist/tests/b2b-hardening.test.js +164 -0
- package/dist/tests/b2b-hardening.test.js.map +1 -0
- package/dist/tests/cli.contract.test.d.ts +2 -0
- package/dist/tests/cli.contract.test.d.ts.map +1 -0
- package/dist/tests/cli.contract.test.js +28 -0
- package/dist/tests/cli.contract.test.js.map +1 -0
- package/dist/tests/cli.snapshot.test.d.ts +14 -0
- package/dist/tests/cli.snapshot.test.d.ts.map +1 -0
- package/dist/tests/cli.snapshot.test.js +132 -0
- package/dist/tests/cli.snapshot.test.js.map +1 -0
- package/dist/tests/cli.strict.test.d.ts +6 -0
- package/dist/tests/cli.strict.test.d.ts.map +1 -0
- package/dist/tests/cli.strict.test.js +173 -0
- package/dist/tests/cli.strict.test.js.map +1 -0
- package/dist/tests/cli.test.d.ts +5 -0
- package/dist/tests/cli.test.d.ts.map +1 -0
- package/dist/tests/cli.test.js +54 -0
- package/dist/tests/cli.test.js.map +1 -0
- package/dist/tests/concurrency.state.test.d.ts +6 -0
- package/dist/tests/concurrency.state.test.d.ts.map +1 -0
- package/dist/tests/concurrency.state.test.js +231 -0
- package/dist/tests/concurrency.state.test.js.map +1 -0
- package/dist/tests/detection-engine.strict.test.d.ts +6 -0
- package/dist/tests/detection-engine.strict.test.d.ts.map +1 -0
- package/dist/tests/detection-engine.strict.test.js +323 -0
- package/dist/tests/detection-engine.strict.test.js.map +1 -0
- package/dist/tests/e2e.system.test.d.ts +7 -0
- package/dist/tests/e2e.system.test.d.ts.map +1 -0
- package/dist/tests/e2e.system.test.js +189 -0
- package/dist/tests/e2e.system.test.js.map +1 -0
- package/dist/tests/edge-cases.test.d.ts +6 -0
- package/dist/tests/edge-cases.test.d.ts.map +1 -0
- package/dist/tests/edge-cases.test.js +357 -0
- package/dist/tests/edge-cases.test.js.map +1 -0
- package/dist/tests/performance.benchmark.test.d.ts +2 -0
- package/dist/tests/performance.benchmark.test.d.ts.map +1 -0
- package/dist/tests/performance.benchmark.test.js +24 -0
- package/dist/tests/performance.benchmark.test.js.map +1 -0
- package/dist/tests/proxy.production.test.d.ts +6 -0
- package/dist/tests/proxy.production.test.d.ts.map +1 -0
- package/dist/tests/proxy.production.test.js +274 -0
- package/dist/tests/proxy.production.test.js.map +1 -0
- package/dist/tests/proxy.strict.test.d.ts +6 -0
- package/dist/tests/proxy.strict.test.d.ts.map +1 -0
- package/dist/tests/proxy.strict.test.js +188 -0
- package/dist/tests/proxy.strict.test.js.map +1 -0
- package/dist/tests/proxy.test.d.ts +5 -0
- package/dist/tests/proxy.test.d.ts.map +1 -0
- package/dist/tests/proxy.test.js +61 -0
- package/dist/tests/proxy.test.js.map +1 -0
- package/dist/tests/roi.scenario.test.d.ts +2 -0
- package/dist/tests/roi.scenario.test.d.ts.map +1 -0
- package/dist/tests/roi.scenario.test.js +26 -0
- package/dist/tests/roi.scenario.test.js.map +1 -0
- package/dist/tests/server.contract.test.d.ts +6 -0
- package/dist/tests/server.contract.test.d.ts.map +1 -0
- package/dist/tests/server.contract.test.js +48 -0
- package/dist/tests/server.contract.test.js.map +1 -0
- package/dist/tests/tokenCounter.test.d.ts +5 -0
- package/dist/tests/tokenCounter.test.d.ts.map +1 -0
- package/dist/tests/tokenCounter.test.js +66 -0
- package/dist/tests/tokenCounter.test.js.map +1 -0
- package/dist/tests/v113/client.test.d.ts +2 -0
- package/dist/tests/v113/client.test.d.ts.map +1 -0
- package/dist/tests/v113/client.test.js +22 -0
- package/dist/tests/v113/client.test.js.map +1 -0
- package/dist/tests/v113/executionGuard.test.d.ts +2 -0
- package/dist/tests/v113/executionGuard.test.d.ts.map +1 -0
- package/dist/tests/v113/executionGuard.test.js +39 -0
- package/dist/tests/v113/executionGuard.test.js.map +1 -0
- package/dist/token-counter/index.d.ts +2 -0
- package/dist/token-counter/index.d.ts.map +1 -0
- package/dist/token-counter/index.js +18 -0
- package/dist/token-counter/index.js.map +1 -0
- package/dist/token-counter/tokenCounter.d.ts +18 -0
- package/dist/token-counter/tokenCounter.d.ts.map +1 -0
- package/dist/token-counter/tokenCounter.js +91 -0
- package/dist/token-counter/tokenCounter.js.map +1 -0
- package/dist/trust/ImmutableAudit.d.ts +159 -0
- package/dist/trust/ImmutableAudit.d.ts.map +1 -0
- package/dist/trust/ImmutableAudit.js +340 -0
- package/dist/trust/ImmutableAudit.js.map +1 -0
- package/dist/trust/PublicVerificationLedger.d.ts +91 -0
- package/dist/trust/PublicVerificationLedger.d.ts.map +1 -0
- package/dist/trust/PublicVerificationLedger.js +223 -0
- package/dist/trust/PublicVerificationLedger.js.map +1 -0
- package/dist/trust/index.d.ts +11 -0
- package/dist/trust/index.d.ts.map +1 -0
- package/dist/trust/index.js +20 -0
- package/dist/trust/index.js.map +1 -0
- package/dist/utils/alert.d.ts +13 -0
- package/dist/utils/alert.d.ts.map +1 -0
- package/dist/utils/alert.js +49 -0
- package/dist/utils/alert.js.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +18 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/wrapper/aiFirewall.d.ts +61 -0
- package/dist/wrapper/aiFirewall.d.ts.map +1 -0
- package/dist/wrapper/aiFirewall.js +117 -0
- package/dist/wrapper/aiFirewall.js.map +1 -0
- package/dist/wrapper/index.d.ts +3 -0
- package/dist/wrapper/index.d.ts.map +1 -0
- package/dist/wrapper/index.js +21 -0
- package/dist/wrapper/index.js.map +1 -0
- package/dist/wrapper/sdk.d.ts +49 -0
- package/dist/wrapper/sdk.d.ts.map +1 -0
- package/dist/wrapper/sdk.js +140 -0
- package/dist/wrapper/sdk.js.map +1 -0
- package/package.json +84 -0
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Starter Template: Serverless Protected Function
|
|
3
|
+
*
|
|
4
|
+
* AWS Lambda / Vercel / Cloud Functions with automatic protection.
|
|
5
|
+
* Already protected. Zero configuration. Production ready.
|
|
6
|
+
*/
|
|
7
|
+
export declare const STARTER_SERVERLESS_PROTECTED: {
|
|
8
|
+
name: string;
|
|
9
|
+
description: string;
|
|
10
|
+
files: {
|
|
11
|
+
'package.json': string;
|
|
12
|
+
'index.js': string;
|
|
13
|
+
'vercel.json': string;
|
|
14
|
+
'.env.example': string;
|
|
15
|
+
'README.md': string;
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export declare function generateServerlessStarter(): string;
|
|
19
|
+
//# sourceMappingURL=serverless-protected.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serverless-protected.d.ts","sourceRoot":"","sources":["../../src/starters/serverless-protected.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,eAAO,MAAM,4BAA4B;;;;;;;;;;CAyExC,CAAC;AAEF,wBAAgB,yBAAyB,IAAI,MAAM,CAElD"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Starter Template: Serverless Protected Function
|
|
4
|
+
*
|
|
5
|
+
* AWS Lambda / Vercel / Cloud Functions with automatic protection.
|
|
6
|
+
* Already protected. Zero configuration. Production ready.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.STARTER_SERVERLESS_PROTECTED = void 0;
|
|
10
|
+
exports.generateServerlessStarter = generateServerlessStarter;
|
|
11
|
+
exports.STARTER_SERVERLESS_PROTECTED = {
|
|
12
|
+
name: 'serverless-protected',
|
|
13
|
+
description: 'Serverless function with automatic AI cost protection',
|
|
14
|
+
files: {
|
|
15
|
+
'package.json': JSON.stringify({
|
|
16
|
+
name: 'serverless-ai-function',
|
|
17
|
+
version: '1.0.0',
|
|
18
|
+
type: 'module',
|
|
19
|
+
dependencies: {
|
|
20
|
+
'ai-costguard': '^2.0.0',
|
|
21
|
+
'openai': '^4.0.0',
|
|
22
|
+
},
|
|
23
|
+
}, null, 2),
|
|
24
|
+
'index.js': `// AI Cost Guard automatically activates on import
|
|
25
|
+
// All AI calls in this function are protected
|
|
26
|
+
import { OpenAI } from 'ai-costguard/openai';
|
|
27
|
+
|
|
28
|
+
const openai = new OpenAI({
|
|
29
|
+
apiKey: process.env.OPENAI_API_KEY,
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
export default async function handler(request) {
|
|
33
|
+
const { message } = await request.json();
|
|
34
|
+
|
|
35
|
+
// Protection is automatic
|
|
36
|
+
const response = await openai.chat.completions.create({
|
|
37
|
+
model: 'gpt-4',
|
|
38
|
+
messages: [{ role: 'user', content: message }],
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
return new Response(
|
|
42
|
+
JSON.stringify({
|
|
43
|
+
reply: response.choices[0].message.content,
|
|
44
|
+
protected: true,
|
|
45
|
+
}),
|
|
46
|
+
{ headers: { 'Content-Type': 'application/json' } }
|
|
47
|
+
);
|
|
48
|
+
}
|
|
49
|
+
`,
|
|
50
|
+
'vercel.json': JSON.stringify({
|
|
51
|
+
functions: {
|
|
52
|
+
'index.js': {
|
|
53
|
+
maxDuration: 30,
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
}, null, 2),
|
|
57
|
+
'.env.example': `OPENAI_API_KEY=sk-...
|
|
58
|
+
AI_COSTGUARD_API_KEY=ak-...
|
|
59
|
+
`,
|
|
60
|
+
'README.md': `# Protected Serverless Function
|
|
61
|
+
|
|
62
|
+
Serverless function with automatic AI cost explosion protection.
|
|
63
|
+
|
|
64
|
+
## Deploy
|
|
65
|
+
|
|
66
|
+
\`\`\`bash
|
|
67
|
+
npm install
|
|
68
|
+
vercel deploy
|
|
69
|
+
\`\`\`
|
|
70
|
+
|
|
71
|
+
All AI calls are automatically protected.
|
|
72
|
+
|
|
73
|
+
## How It Works
|
|
74
|
+
|
|
75
|
+
The import \`from 'ai-costguard/openai'\` activates automatic protection.
|
|
76
|
+
No configuration needed. Already protected on deployment.
|
|
77
|
+
`,
|
|
78
|
+
},
|
|
79
|
+
};
|
|
80
|
+
function generateServerlessStarter() {
|
|
81
|
+
return JSON.stringify(exports.STARTER_SERVERLESS_PROTECTED, null, 2);
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=serverless-protected.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serverless-protected.js","sourceRoot":"","sources":["../../src/starters/serverless-protected.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AA6EH,8DAEC;AA7EY,QAAA,4BAA4B,GAAG;IAC1C,IAAI,EAAE,sBAAsB;IAC5B,WAAW,EAAE,uDAAuD;IAEpE,KAAK,EAAE;QACL,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC;YAC7B,IAAI,EAAE,wBAAwB;YAC9B,OAAO,EAAE,OAAO;YAChB,IAAI,EAAE,QAAQ;YACd,YAAY,EAAE;gBACZ,cAAc,EAAE,QAAQ;gBACxB,QAAQ,EAAE,QAAQ;aACnB;SACF,EAAE,IAAI,EAAE,CAAC,CAAC;QAEX,UAAU,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;CAyBf;QAEG,aAAa,EAAE,IAAI,CAAC,SAAS,CAAC;YAC5B,SAAS,EAAE;gBACT,UAAU,EAAE;oBACV,WAAW,EAAE,EAAE;iBAChB;aACF;SACF,EAAE,IAAI,EAAE,CAAC,CAAC;QAEX,cAAc,EAAE;;CAEnB;QAEG,WAAW,EAAE;;;;;;;;;;;;;;;;;CAiBhB;KACE;CACF,CAAC;AAEF,SAAgB,yBAAyB;IACvC,OAAO,IAAI,CAAC,SAAS,CAAC,oCAA4B,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAC/D,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { StorageAdapterType, StorageConfig } from '../config/userConfig';
|
|
2
|
+
export interface StorageAdapter<TRecord> {
|
|
3
|
+
readonly type: StorageAdapterType;
|
|
4
|
+
load(): TRecord[];
|
|
5
|
+
append(record: TRecord): void;
|
|
6
|
+
clear(): void;
|
|
7
|
+
}
|
|
8
|
+
export declare class MemoryStorageAdapter<TRecord> implements StorageAdapter<TRecord> {
|
|
9
|
+
readonly type: "memory";
|
|
10
|
+
private records;
|
|
11
|
+
load(): TRecord[];
|
|
12
|
+
append(record: TRecord): void;
|
|
13
|
+
clear(): void;
|
|
14
|
+
}
|
|
15
|
+
export declare class JsonlStorageAdapter<TRecord> implements StorageAdapter<TRecord> {
|
|
16
|
+
readonly type: "jsonl";
|
|
17
|
+
private filePath;
|
|
18
|
+
constructor(filePath?: string);
|
|
19
|
+
load(): TRecord[];
|
|
20
|
+
append(record: TRecord): void;
|
|
21
|
+
clear(): void;
|
|
22
|
+
}
|
|
23
|
+
export declare function createStorageAdapter<TRecord>(config?: Partial<StorageConfig>): StorageAdapter<TRecord>;
|
|
24
|
+
//# sourceMappingURL=adapters.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapters.d.ts","sourceRoot":"","sources":["../../src/storage/adapters.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAEzE,MAAM,WAAW,cAAc,CAAC,OAAO;IACrC,QAAQ,CAAC,IAAI,EAAE,kBAAkB,CAAC;IAClC,IAAI,IAAI,OAAO,EAAE,CAAC;IAClB,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI,CAAC;IAC9B,KAAK,IAAI,IAAI,CAAC;CACf;AAED,qBAAa,oBAAoB,CAAC,OAAO,CAAE,YAAW,cAAc,CAAC,OAAO,CAAC;IAC3E,QAAQ,CAAC,IAAI,EAAG,QAAQ,CAAU;IAClC,OAAO,CAAC,OAAO,CAAiB;IAEhC,IAAI,IAAI,OAAO,EAAE;IAIjB,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI;IAI7B,KAAK,IAAI,IAAI;CAGd;AAED,qBAAa,mBAAmB,CAAC,OAAO,CAAE,YAAW,cAAc,CAAC,OAAO,CAAC;IAC1E,QAAQ,CAAC,IAAI,EAAG,OAAO,CAAU;IACjC,OAAO,CAAC,QAAQ,CAAS;gBAEb,QAAQ,CAAC,EAAE,MAAM;IAQ7B,IAAI,IAAI,OAAO,EAAE;IAYjB,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI;IAQ7B,KAAK,IAAI,IAAI;CAWd;AA8BD,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAE,OAAO,CAAC,aAAa,CAAM,GAAG,cAAc,CAAC,OAAO,CAAC,CAY1G"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.JsonlStorageAdapter = exports.MemoryStorageAdapter = void 0;
|
|
37
|
+
exports.createStorageAdapter = createStorageAdapter;
|
|
38
|
+
const fs = __importStar(require("fs"));
|
|
39
|
+
const path = __importStar(require("path"));
|
|
40
|
+
const os = __importStar(require("os"));
|
|
41
|
+
const constants_1 = require("../config/constants");
|
|
42
|
+
class MemoryStorageAdapter {
|
|
43
|
+
constructor() {
|
|
44
|
+
this.type = 'memory';
|
|
45
|
+
this.records = [];
|
|
46
|
+
}
|
|
47
|
+
load() {
|
|
48
|
+
return [...this.records];
|
|
49
|
+
}
|
|
50
|
+
append(record) {
|
|
51
|
+
this.records.push(record);
|
|
52
|
+
}
|
|
53
|
+
clear() {
|
|
54
|
+
this.records = [];
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
exports.MemoryStorageAdapter = MemoryStorageAdapter;
|
|
58
|
+
class JsonlStorageAdapter {
|
|
59
|
+
constructor(filePath) {
|
|
60
|
+
this.type = 'jsonl';
|
|
61
|
+
const appDir = path.join(os.homedir(), constants_1.PATHS.APP_DIR);
|
|
62
|
+
if (!fs.existsSync(appDir)) {
|
|
63
|
+
fs.mkdirSync(appDir, { recursive: true });
|
|
64
|
+
}
|
|
65
|
+
this.filePath = filePath || path.join(appDir, constants_1.PATHS.HISTORY_FILE);
|
|
66
|
+
}
|
|
67
|
+
load() {
|
|
68
|
+
if (!fs.existsSync(this.filePath)) {
|
|
69
|
+
return [];
|
|
70
|
+
}
|
|
71
|
+
return fs
|
|
72
|
+
.readFileSync(this.filePath, 'utf-8')
|
|
73
|
+
.split('\n')
|
|
74
|
+
.filter((line) => line.trim().length > 0)
|
|
75
|
+
.map((line) => JSON.parse(line));
|
|
76
|
+
}
|
|
77
|
+
append(record) {
|
|
78
|
+
const dir = path.dirname(this.filePath);
|
|
79
|
+
if (!fs.existsSync(dir)) {
|
|
80
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
81
|
+
}
|
|
82
|
+
fs.appendFileSync(this.filePath, JSON.stringify(record) + '\n', 'utf-8');
|
|
83
|
+
}
|
|
84
|
+
clear() {
|
|
85
|
+
try {
|
|
86
|
+
if (fs.existsSync(this.filePath)) {
|
|
87
|
+
fs.unlinkSync(this.filePath);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
catch (error) {
|
|
91
|
+
if (error?.code !== 'ENOENT') {
|
|
92
|
+
throw error;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
exports.JsonlStorageAdapter = JsonlStorageAdapter;
|
|
98
|
+
class OptionalExternalStorageAdapter {
|
|
99
|
+
constructor(type) {
|
|
100
|
+
this.type = type;
|
|
101
|
+
this.name = type === 'sqlite' ? 'SQLite' : 'Postgres';
|
|
102
|
+
}
|
|
103
|
+
load() {
|
|
104
|
+
throw new Error(`${this.name} storage is configured but the production adapter is not installed in this package build yet. Use "jsonl" or "memory", or provide a custom adapter with createStorageAdapter().`);
|
|
105
|
+
}
|
|
106
|
+
append() {
|
|
107
|
+
throw new Error(`${this.name} storage is configured but the production adapter is not installed in this package build yet. Use "jsonl" or "memory", or provide a custom adapter with createStorageAdapter().`);
|
|
108
|
+
}
|
|
109
|
+
clear() {
|
|
110
|
+
throw new Error(`${this.name} storage is configured but the production adapter is not installed in this package build yet. Use "jsonl" or "memory", or provide a custom adapter with createStorageAdapter().`);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
function createStorageAdapter(config = {}) {
|
|
114
|
+
const adapter = config.adapter || 'jsonl';
|
|
115
|
+
if (adapter === 'memory') {
|
|
116
|
+
return new MemoryStorageAdapter();
|
|
117
|
+
}
|
|
118
|
+
if (adapter === 'jsonl') {
|
|
119
|
+
return new JsonlStorageAdapter(config.path);
|
|
120
|
+
}
|
|
121
|
+
return new OptionalExternalStorageAdapter(adapter);
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=adapters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../src/storage/adapters.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/storage/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createStorageAdapter = exports.JsonlStorageAdapter = exports.MemoryStorageAdapter = void 0;
|
|
4
|
+
var adapters_1 = require("./adapters");
|
|
5
|
+
Object.defineProperty(exports, "MemoryStorageAdapter", { enumerable: true, get: function () { return adapters_1.MemoryStorageAdapter; } });
|
|
6
|
+
Object.defineProperty(exports, "JsonlStorageAdapter", { enumerable: true, get: function () { return adapters_1.JsonlStorageAdapter; } });
|
|
7
|
+
Object.defineProperty(exports, "createStorageAdapter", { enumerable: true, get: function () { return adapters_1.createStorageAdapter; } });
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/storage/index.ts"],"names":[],"mappings":";;;AAAA,uCAA6G;AAApF,gHAAA,oBAAoB,OAAA;AAAE,+GAAA,mBAAmB,OAAA;AAAE,gHAAA,oBAAoB,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"b2b-hardening.test.d.ts","sourceRoot":"","sources":["../../src/tests/b2b-hardening.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const fs = __importStar(require("fs"));
|
|
37
|
+
const os = __importStar(require("os"));
|
|
38
|
+
const path = __importStar(require("path"));
|
|
39
|
+
const DetectionEngine_1 = require("../core/DetectionEngine");
|
|
40
|
+
const config_1 = require("../config");
|
|
41
|
+
describe('B2B production hardening', () => {
|
|
42
|
+
let engine;
|
|
43
|
+
let config;
|
|
44
|
+
let originalConfig;
|
|
45
|
+
beforeEach(() => {
|
|
46
|
+
engine = DetectionEngine_1.DetectionEngine.getInstance();
|
|
47
|
+
config = new config_1.ConfigManager();
|
|
48
|
+
originalConfig = config.getConfig();
|
|
49
|
+
engine.clear();
|
|
50
|
+
});
|
|
51
|
+
afterEach(() => {
|
|
52
|
+
config.updateConfig(originalConfig);
|
|
53
|
+
engine.reset();
|
|
54
|
+
});
|
|
55
|
+
test('stores hash-only prompt history by default', () => {
|
|
56
|
+
config.updateConfig({
|
|
57
|
+
privacy: {
|
|
58
|
+
...originalConfig.privacy,
|
|
59
|
+
promptStorage: 'hash',
|
|
60
|
+
},
|
|
61
|
+
});
|
|
62
|
+
engine.reset();
|
|
63
|
+
const secretPrompt = 'customer email test@example.com with api key sk-testsecret1234567890';
|
|
64
|
+
engine.analyze({
|
|
65
|
+
model: 'gpt-4',
|
|
66
|
+
prompt: secretPrompt,
|
|
67
|
+
estimatedCost: 0.001,
|
|
68
|
+
});
|
|
69
|
+
const historyPath = path.join(os.homedir(), '.aifw', 'history.jsonl');
|
|
70
|
+
const persisted = fs.readFileSync(historyPath, 'utf-8');
|
|
71
|
+
expect(persisted).not.toContain(secretPrompt);
|
|
72
|
+
expect(persisted).not.toContain('test@example.com');
|
|
73
|
+
expect(persisted).toContain('[hash:');
|
|
74
|
+
});
|
|
75
|
+
test('applies scoped daily budgets from request metadata', () => {
|
|
76
|
+
config.updateConfig({
|
|
77
|
+
trustMode: 'block',
|
|
78
|
+
budgets: {
|
|
79
|
+
...originalConfig.budgets,
|
|
80
|
+
perRequestUsd: 1,
|
|
81
|
+
dailyUsd: 50,
|
|
82
|
+
monthlyUsd: 1000,
|
|
83
|
+
},
|
|
84
|
+
policies: [
|
|
85
|
+
{
|
|
86
|
+
id: 'tenant-low-budget',
|
|
87
|
+
scope: { orgId: 'org-low' },
|
|
88
|
+
budgets: { dailyUsd: 0.015 },
|
|
89
|
+
},
|
|
90
|
+
],
|
|
91
|
+
});
|
|
92
|
+
engine.reset();
|
|
93
|
+
const first = engine.analyze({
|
|
94
|
+
model: 'gpt-4',
|
|
95
|
+
prompt: 'first tenant budget request',
|
|
96
|
+
estimatedCost: 0.01,
|
|
97
|
+
metadata: { orgId: 'org-low', userId: 'user-1' },
|
|
98
|
+
});
|
|
99
|
+
expect(first.decision).toBe('allow');
|
|
100
|
+
const second = engine.analyze({
|
|
101
|
+
model: 'gpt-4',
|
|
102
|
+
prompt: 'second unrelated tenant request',
|
|
103
|
+
estimatedCost: 0.01,
|
|
104
|
+
metadata: { orgId: 'org-low', userId: 'user-1' },
|
|
105
|
+
});
|
|
106
|
+
expect(second.decision).toBe('block');
|
|
107
|
+
expect(second.category).toBe('budget');
|
|
108
|
+
expect(second.metadata.policyId).toBe('tenant-low-budget');
|
|
109
|
+
});
|
|
110
|
+
test('scoped budgets block before cost-spike warnings in warn mode', () => {
|
|
111
|
+
config.updateConfig({
|
|
112
|
+
trustMode: 'warn',
|
|
113
|
+
policies: [
|
|
114
|
+
{
|
|
115
|
+
id: 'tenant-hard-cap',
|
|
116
|
+
scope: { orgId: 'org-hard-cap' },
|
|
117
|
+
budgets: {
|
|
118
|
+
perRequestUsd: 0.05,
|
|
119
|
+
dailyUsd: 1,
|
|
120
|
+
monthlyUsd: 10,
|
|
121
|
+
},
|
|
122
|
+
},
|
|
123
|
+
],
|
|
124
|
+
});
|
|
125
|
+
engine.reset();
|
|
126
|
+
const result = engine.analyze({
|
|
127
|
+
model: 'gpt-4',
|
|
128
|
+
prompt: 'request over tenant cap',
|
|
129
|
+
estimatedCost: 0.1,
|
|
130
|
+
trustMode: 'warn',
|
|
131
|
+
metadata: { orgId: 'org-hard-cap' },
|
|
132
|
+
});
|
|
133
|
+
expect(result.decision).toBe('block');
|
|
134
|
+
expect(result.category).toBe('budget');
|
|
135
|
+
expect(result.metadata.policyId).toBe('tenant-hard-cap');
|
|
136
|
+
});
|
|
137
|
+
test('registers custom pricing models and aliases', () => {
|
|
138
|
+
(0, config_1.registerPricingModel)('acme-agent-model', {
|
|
139
|
+
provider: 'custom',
|
|
140
|
+
inputPrice: 0.002,
|
|
141
|
+
outputPrice: 0.004,
|
|
142
|
+
cachedInputPrice: 0.001,
|
|
143
|
+
aliases: ['openrouter/acme-agent-model'],
|
|
144
|
+
});
|
|
145
|
+
const pricing = (0, config_1.getModelPricing)('openrouter/acme-agent-model');
|
|
146
|
+
const cost = (0, config_1.estimateCost)('openrouter/acme-agent-model', 1000, 1000, {
|
|
147
|
+
cachedInputTokens: 500,
|
|
148
|
+
});
|
|
149
|
+
expect(pricing?.model).toBe('acme-agent-model');
|
|
150
|
+
expect(cost).toBeCloseTo(0.0055);
|
|
151
|
+
});
|
|
152
|
+
test('returns budget status for metadata scopes', () => {
|
|
153
|
+
engine.analyze({
|
|
154
|
+
model: 'gpt-4',
|
|
155
|
+
prompt: 'budget status request',
|
|
156
|
+
estimatedCost: 0.01,
|
|
157
|
+
metadata: { orgId: 'org-status', workflowId: 'wf-1' },
|
|
158
|
+
});
|
|
159
|
+
const status = engine.getBudgetStatus({ orgId: 'org-status', workflowId: 'wf-1' });
|
|
160
|
+
expect(status.dailySpend).toBeCloseTo(0.01);
|
|
161
|
+
expect(status.workflowSpend).toBeCloseTo(0.01);
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
//# sourceMappingURL=b2b-hardening.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"b2b-hardening.test.js","sourceRoot":"","sources":["../../src/tests/b2b-hardening.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.contract.test.d.ts","sourceRoot":"","sources":["../../src/tests/cli.contract.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const outputContract_1 = require("../cli/outputContract");
|
|
4
|
+
describe('CLI Output Contract', () => {
|
|
5
|
+
test('validates frozen schema shape', () => {
|
|
6
|
+
const output = (0, outputContract_1.createCliOutputContract)('report', { hours: 24, stats: { totalRequests: 1 } }, {
|
|
7
|
+
total_cost_saved: 1.23,
|
|
8
|
+
blocked_requests_count: 2,
|
|
9
|
+
false_positive_indicator: 0.1,
|
|
10
|
+
avg_analysis_latency_ms: 1.5,
|
|
11
|
+
storage_backend: 'file',
|
|
12
|
+
});
|
|
13
|
+
expect((0, outputContract_1.validateCliOutputContract)(output)).toBe(true);
|
|
14
|
+
});
|
|
15
|
+
test('snapshot protects output contract', () => {
|
|
16
|
+
const output = (0, outputContract_1.createCliOutputContract)('metrics', { hours: 24 }, {
|
|
17
|
+
total_cost_saved: 10.5,
|
|
18
|
+
blocked_requests_count: 7,
|
|
19
|
+
false_positive_indicator: 0.2,
|
|
20
|
+
avg_analysis_latency_ms: 0.9,
|
|
21
|
+
storage_backend: 'redis',
|
|
22
|
+
});
|
|
23
|
+
expect(output).toMatchSnapshot({
|
|
24
|
+
timestamp: expect.any(String),
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
//# sourceMappingURL=cli.contract.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.contract.test.js","sourceRoot":"","sources":["../../src/tests/cli.contract.test.ts"],"names":[],"mappings":";;AAAA,0DAA2F;AAE3F,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,IAAI,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACzC,MAAM,MAAM,GAAG,IAAA,wCAAuB,EACpC,QAAQ,EACR,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,aAAa,EAAE,CAAC,EAAE,EAAE,EAC1C;YACE,gBAAgB,EAAE,IAAI;YACtB,sBAAsB,EAAE,CAAC;YACzB,wBAAwB,EAAE,GAAG;YAC7B,uBAAuB,EAAE,GAAG;YAC5B,eAAe,EAAE,MAAM;SACxB,CACF,CAAC;QACF,MAAM,CAAC,IAAA,0CAAyB,EAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC7C,MAAM,MAAM,GAAG,IAAA,wCAAuB,EACpC,SAAS,EACT,EAAE,KAAK,EAAE,EAAE,EAAE,EACb;YACE,gBAAgB,EAAE,IAAI;YACtB,sBAAsB,EAAE,CAAC;YACzB,wBAAwB,EAAE,GAAG;YAC7B,uBAAuB,EAAE,GAAG;YAC5B,eAAe,EAAE,OAAO;SACzB,CACF,CAAC;QACF,MAAM,CAAC,MAAM,CAAC,CAAC,eAAe,CAAC;YAC7B,SAAS,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC;SAC9B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CLI OUTPUT FORMAT SNAPSHOT TESTS
|
|
3
|
+
* Freezes CLI output format to prevent string drift
|
|
4
|
+
*
|
|
5
|
+
* These tests use snapshot-style exact matching to ensure
|
|
6
|
+
* CLI output format never changes without explicit intent.
|
|
7
|
+
*
|
|
8
|
+
* If you need to change the format:
|
|
9
|
+
* 1. Update the test expectations
|
|
10
|
+
* 2. Document the change in CHANGELOG
|
|
11
|
+
* 3. Update any dependent integrations
|
|
12
|
+
*/
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=cli.snapshot.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.snapshot.test.d.ts","sourceRoot":"","sources":["../../src/tests/cli.snapshot.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG"}
|