@agirails/sdk 2.0.1-beta → 2.0.2
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/LICENSE +190 -0
- package/README.md +116 -108
- package/bin/actp +10 -0
- package/dist/ACTPClient.d.ts +456 -33
- package/dist/ACTPClient.d.ts.map +1 -1
- package/dist/ACTPClient.js +477 -93
- package/dist/ACTPClient.js.map +1 -1
- package/dist/abi/AgentRegistry.json +782 -0
- package/dist/abi/EscrowVault.json +106 -38
- package/dist/abi/IdentityRegistry.json +316 -0
- package/dist/adapters/BaseAdapter.d.ts +231 -0
- package/dist/adapters/BaseAdapter.d.ts.map +1 -0
- package/dist/adapters/BaseAdapter.js +393 -0
- package/dist/adapters/BaseAdapter.js.map +1 -0
- package/dist/adapters/BeginnerAdapter.d.ts +152 -0
- package/dist/adapters/BeginnerAdapter.d.ts.map +1 -0
- package/dist/adapters/BeginnerAdapter.js +168 -0
- package/dist/adapters/BeginnerAdapter.js.map +1 -0
- package/dist/adapters/IntermediateAdapter.d.ts +211 -0
- package/dist/adapters/IntermediateAdapter.d.ts.map +1 -0
- package/dist/adapters/IntermediateAdapter.js +260 -0
- package/dist/adapters/IntermediateAdapter.js.map +1 -0
- package/dist/adapters/index.d.ts +15 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +26 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/builders/DeliveryProofBuilder.d.ts +60 -1
- package/dist/builders/DeliveryProofBuilder.d.ts.map +1 -1
- package/dist/builders/DeliveryProofBuilder.js +81 -5
- package/dist/builders/DeliveryProofBuilder.js.map +1 -1
- package/dist/builders/QuoteBuilder.d.ts +101 -0
- package/dist/builders/QuoteBuilder.d.ts.map +1 -1
- package/dist/builders/QuoteBuilder.js +120 -3
- package/dist/builders/QuoteBuilder.js.map +1 -1
- package/dist/builders/index.d.ts +4 -0
- package/dist/builders/index.d.ts.map +1 -1
- package/dist/builders/index.js +4 -0
- package/dist/builders/index.js.map +1 -1
- package/dist/cli/commands/balance.d.ts +13 -0
- package/dist/cli/commands/balance.d.ts.map +1 -0
- package/dist/cli/commands/balance.js +89 -0
- package/dist/cli/commands/balance.js.map +1 -0
- package/dist/cli/commands/batch.d.ts +24 -0
- package/dist/cli/commands/batch.d.ts.map +1 -0
- package/dist/cli/commands/batch.js +424 -0
- package/dist/cli/commands/batch.js.map +1 -0
- package/dist/cli/commands/config.d.ts +13 -0
- package/dist/cli/commands/config.d.ts.map +1 -0
- package/dist/cli/commands/config.js +192 -0
- package/dist/cli/commands/config.js.map +1 -0
- package/dist/cli/commands/init.d.ts +19 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +143 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/mint.d.ts +13 -0
- package/dist/cli/commands/mint.d.ts.map +1 -0
- package/dist/cli/commands/mint.js +91 -0
- package/dist/cli/commands/mint.js.map +1 -0
- package/dist/cli/commands/pay.d.ts +18 -0
- package/dist/cli/commands/pay.d.ts.map +1 -0
- package/dist/cli/commands/pay.js +87 -0
- package/dist/cli/commands/pay.js.map +1 -0
- package/dist/cli/commands/simulate.d.ts +32 -0
- package/dist/cli/commands/simulate.d.ts.map +1 -0
- package/dist/cli/commands/simulate.js +290 -0
- package/dist/cli/commands/simulate.js.map +1 -0
- package/dist/cli/commands/time.d.ts +29 -0
- package/dist/cli/commands/time.d.ts.map +1 -0
- package/dist/cli/commands/time.js +252 -0
- package/dist/cli/commands/time.js.map +1 -0
- package/dist/cli/commands/tx.d.ts +16 -0
- package/dist/cli/commands/tx.d.ts.map +1 -0
- package/dist/cli/commands/tx.js +379 -0
- package/dist/cli/commands/tx.js.map +1 -0
- package/dist/cli/commands/watch.d.ts +20 -0
- package/dist/cli/commands/watch.d.ts.map +1 -0
- package/dist/cli/commands/watch.js +160 -0
- package/dist/cli/commands/watch.js.map +1 -0
- package/dist/cli/index.d.ts +17 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +104 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/utils/client.d.ts +70 -0
- package/dist/cli/utils/client.d.ts.map +1 -0
- package/dist/cli/utils/client.js +240 -0
- package/dist/cli/utils/client.js.map +1 -0
- package/dist/cli/utils/config.d.ts +91 -0
- package/dist/cli/utils/config.d.ts.map +1 -0
- package/dist/cli/utils/config.js +240 -0
- package/dist/cli/utils/config.js.map +1 -0
- package/dist/cli/utils/output.d.ts +174 -0
- package/dist/cli/utils/output.d.ts.map +1 -0
- package/dist/cli/utils/output.js +380 -0
- package/dist/cli/utils/output.js.map +1 -0
- package/dist/config/networks.d.ts +28 -0
- package/dist/config/networks.d.ts.map +1 -1
- package/dist/config/networks.js +60 -12
- package/dist/config/networks.js.map +1 -1
- package/dist/errors/index.d.ts +165 -2
- package/dist/errors/index.d.ts.map +1 -1
- package/dist/errors/index.js +260 -2
- package/dist/errors/index.js.map +1 -1
- package/dist/index.d.ts +61 -13
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +141 -36
- package/dist/index.js.map +1 -1
- package/dist/level0/Provider.d.ts +106 -0
- package/dist/level0/Provider.d.ts.map +1 -0
- package/dist/level0/Provider.js +10 -0
- package/dist/level0/Provider.js.map +1 -0
- package/dist/level0/ServiceDirectory.d.ts +74 -0
- package/dist/level0/ServiceDirectory.d.ts.map +1 -0
- package/dist/level0/ServiceDirectory.js +122 -0
- package/dist/level0/ServiceDirectory.js.map +1 -0
- package/dist/level0/index.d.ts +10 -0
- package/dist/level0/index.d.ts.map +1 -0
- package/dist/level0/index.js +15 -0
- package/dist/level0/index.js.map +1 -0
- package/dist/level0/provide.d.ts +51 -0
- package/dist/level0/provide.d.ts.map +1 -0
- package/dist/level0/provide.js +113 -0
- package/dist/level0/provide.js.map +1 -0
- package/dist/level0/request.d.ts +53 -0
- package/dist/level0/request.d.ts.map +1 -0
- package/dist/level0/request.js +462 -0
- package/dist/level0/request.js.map +1 -0
- package/dist/level1/Agent.d.ts +472 -0
- package/dist/level1/Agent.d.ts.map +1 -0
- package/dist/level1/Agent.js +1091 -0
- package/dist/level1/Agent.js.map +1 -0
- package/dist/level1/index.d.ts +10 -0
- package/dist/level1/index.d.ts.map +1 -0
- package/dist/level1/index.js +30 -0
- package/dist/level1/index.js.map +1 -0
- package/dist/level1/pricing/PriceCalculator.d.ts +62 -0
- package/dist/level1/pricing/PriceCalculator.d.ts.map +1 -0
- package/dist/level1/pricing/PriceCalculator.js +237 -0
- package/dist/level1/pricing/PriceCalculator.js.map +1 -0
- package/dist/level1/pricing/PricingStrategy.d.ts +179 -0
- package/dist/level1/pricing/PricingStrategy.d.ts.map +1 -0
- package/dist/level1/pricing/PricingStrategy.js +11 -0
- package/dist/level1/pricing/PricingStrategy.js.map +1 -0
- package/dist/level1/types/Job.d.ts +166 -0
- package/dist/level1/types/Job.d.ts.map +1 -0
- package/dist/level1/types/Job.js +11 -0
- package/dist/level1/types/Job.js.map +1 -0
- package/dist/level1/types/Options.d.ts +258 -0
- package/dist/level1/types/Options.d.ts.map +1 -0
- package/dist/level1/types/Options.js +8 -0
- package/dist/level1/types/Options.js.map +1 -0
- package/dist/level1/types/index.d.ts +8 -0
- package/dist/level1/types/index.d.ts.map +1 -0
- package/dist/level1/types/index.js +8 -0
- package/dist/level1/types/index.js.map +1 -0
- package/dist/protocol/ACTPKernel.d.ts +229 -2
- package/dist/protocol/ACTPKernel.d.ts.map +1 -1
- package/dist/protocol/ACTPKernel.js +367 -33
- package/dist/protocol/ACTPKernel.js.map +1 -1
- package/dist/protocol/AgentRegistry.d.ts +177 -0
- package/dist/protocol/AgentRegistry.d.ts.map +1 -0
- package/dist/protocol/AgentRegistry.js +449 -0
- package/dist/protocol/AgentRegistry.js.map +1 -0
- package/dist/protocol/DIDManager.d.ts +289 -0
- package/dist/protocol/DIDManager.d.ts.map +1 -0
- package/dist/protocol/DIDManager.js +481 -0
- package/dist/protocol/DIDManager.js.map +1 -0
- package/dist/protocol/DIDResolver.d.ts +236 -0
- package/dist/protocol/DIDResolver.d.ts.map +1 -0
- package/dist/protocol/DIDResolver.js +495 -0
- package/dist/protocol/DIDResolver.js.map +1 -0
- package/dist/protocol/EASHelper.d.ts +57 -2
- package/dist/protocol/EASHelper.d.ts.map +1 -1
- package/dist/protocol/EASHelper.js +230 -37
- package/dist/protocol/EASHelper.js.map +1 -1
- package/dist/protocol/EscrowVault.d.ts +93 -2
- package/dist/protocol/EscrowVault.d.ts.map +1 -1
- package/dist/protocol/EscrowVault.js +122 -33
- package/dist/protocol/EscrowVault.js.map +1 -1
- package/dist/protocol/EventMonitor.d.ts +45 -1
- package/dist/protocol/EventMonitor.d.ts.map +1 -1
- package/dist/protocol/EventMonitor.js +64 -8
- package/dist/protocol/EventMonitor.js.map +1 -1
- package/dist/protocol/MessageSigner.d.ts +116 -2
- package/dist/protocol/MessageSigner.d.ts.map +1 -1
- package/dist/protocol/MessageSigner.js +215 -9
- package/dist/protocol/MessageSigner.js.map +1 -1
- package/dist/protocol/ProofGenerator.d.ts +93 -0
- package/dist/protocol/ProofGenerator.d.ts.map +1 -1
- package/dist/protocol/ProofGenerator.js +194 -9
- package/dist/protocol/ProofGenerator.js.map +1 -1
- package/dist/protocol/QuoteBuilder.d.ts +8 -0
- package/dist/protocol/QuoteBuilder.d.ts.map +1 -1
- package/dist/protocol/QuoteBuilder.js +8 -0
- package/dist/protocol/QuoteBuilder.js.map +1 -1
- package/dist/runtime/BlockchainRuntime.d.ts +360 -0
- package/dist/runtime/BlockchainRuntime.d.ts.map +1 -0
- package/dist/runtime/BlockchainRuntime.js +767 -0
- package/dist/runtime/BlockchainRuntime.js.map +1 -0
- package/dist/runtime/IACTPRuntime.d.ts +271 -0
- package/dist/runtime/IACTPRuntime.d.ts.map +1 -0
- package/dist/runtime/IACTPRuntime.js +15 -0
- package/dist/runtime/IACTPRuntime.js.map +1 -0
- package/dist/runtime/MockRuntime.d.ts +445 -0
- package/dist/runtime/MockRuntime.d.ts.map +1 -0
- package/dist/runtime/MockRuntime.js +1065 -0
- package/dist/runtime/MockRuntime.js.map +1 -0
- package/dist/runtime/MockStateManager.d.ts +233 -0
- package/dist/runtime/MockStateManager.d.ts.map +1 -0
- package/dist/runtime/MockStateManager.js +533 -0
- package/dist/runtime/MockStateManager.js.map +1 -0
- package/dist/runtime/index.d.ts +14 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +42 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/types/MockState.d.ts +167 -0
- package/dist/runtime/types/MockState.d.ts.map +1 -0
- package/dist/runtime/types/MockState.js +43 -0
- package/dist/runtime/types/MockState.js.map +1 -0
- package/dist/types/agent.d.ts +76 -0
- package/dist/types/agent.d.ts.map +1 -0
- package/dist/types/agent.js +8 -0
- package/dist/types/agent.js.map +1 -0
- package/dist/types/did.d.ts +192 -0
- package/dist/types/did.d.ts.map +1 -0
- package/dist/types/did.js +38 -0
- package/dist/types/did.js.map +1 -0
- package/dist/types/eip712.d.ts +34 -0
- package/dist/types/eip712.d.ts.map +1 -1
- package/dist/types/eip712.js +31 -5
- package/dist/types/eip712.js.map +1 -1
- package/dist/types/escrow.d.ts +17 -10
- package/dist/types/escrow.d.ts.map +1 -1
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +8 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/message.d.ts +32 -0
- package/dist/types/message.d.ts.map +1 -1
- package/dist/types/message.js +4 -0
- package/dist/types/message.js.map +1 -1
- package/dist/types/state.d.ts +28 -0
- package/dist/types/state.d.ts.map +1 -1
- package/dist/types/state.js +37 -6
- package/dist/types/state.js.map +1 -1
- package/dist/types/transaction.d.ts +17 -0
- package/dist/types/transaction.d.ts.map +1 -1
- package/dist/utils/ErrorRecoveryGuide.d.ts +125 -0
- package/dist/utils/ErrorRecoveryGuide.d.ts.map +1 -0
- package/dist/utils/ErrorRecoveryGuide.js +579 -0
- package/dist/utils/ErrorRecoveryGuide.js.map +1 -0
- package/dist/utils/Helpers.d.ts +453 -0
- package/dist/utils/Helpers.d.ts.map +1 -0
- package/dist/utils/Helpers.js +623 -0
- package/dist/utils/Helpers.js.map +1 -0
- package/dist/utils/IPFSClient.d.ts +113 -0
- package/dist/utils/IPFSClient.d.ts.map +1 -1
- package/dist/utils/IPFSClient.js +128 -7
- package/dist/utils/IPFSClient.js.map +1 -1
- package/dist/utils/Logger.d.ts +195 -0
- package/dist/utils/Logger.d.ts.map +1 -0
- package/dist/utils/Logger.js +382 -0
- package/dist/utils/Logger.js.map +1 -0
- package/dist/utils/NonceManager.d.ts +234 -1
- package/dist/utils/NonceManager.d.ts.map +1 -1
- package/dist/utils/NonceManager.js +372 -7
- package/dist/utils/NonceManager.js.map +1 -1
- package/dist/utils/RateLimiter.d.ts +253 -0
- package/dist/utils/RateLimiter.d.ts.map +1 -0
- package/dist/utils/RateLimiter.js +424 -0
- package/dist/utils/RateLimiter.js.map +1 -0
- package/dist/utils/ReceivedNonceTracker.d.ts +175 -0
- package/dist/utils/ReceivedNonceTracker.d.ts.map +1 -1
- package/dist/utils/ReceivedNonceTracker.js +261 -5
- package/dist/utils/ReceivedNonceTracker.js.map +1 -1
- package/dist/utils/SDKLifecycle.d.ts +156 -0
- package/dist/utils/SDKLifecycle.d.ts.map +1 -0
- package/dist/utils/SDKLifecycle.js +347 -0
- package/dist/utils/SDKLifecycle.js.map +1 -0
- package/dist/utils/SecureNonce.d.ts +57 -0
- package/dist/utils/SecureNonce.d.ts.map +1 -0
- package/dist/utils/SecureNonce.js +80 -0
- package/dist/utils/SecureNonce.js.map +1 -0
- package/dist/utils/Semaphore.d.ts +123 -0
- package/dist/utils/Semaphore.d.ts.map +1 -0
- package/dist/utils/Semaphore.js +247 -0
- package/dist/utils/Semaphore.js.map +1 -0
- package/dist/utils/UsedAttestationTracker.d.ts +167 -0
- package/dist/utils/UsedAttestationTracker.d.ts.map +1 -0
- package/dist/utils/UsedAttestationTracker.js +309 -0
- package/dist/utils/UsedAttestationTracker.js.map +1 -0
- package/dist/utils/canonicalJson.d.ts +22 -0
- package/dist/utils/canonicalJson.d.ts.map +1 -1
- package/dist/utils/canonicalJson.js +26 -3
- package/dist/utils/canonicalJson.js.map +1 -1
- package/dist/utils/computeTypeHash.d.ts +14 -0
- package/dist/utils/computeTypeHash.d.ts.map +1 -1
- package/dist/utils/computeTypeHash.js +19 -2
- package/dist/utils/computeTypeHash.js.map +1 -1
- package/dist/utils/fsSafe.d.ts +14 -0
- package/dist/utils/fsSafe.d.ts.map +1 -0
- package/dist/utils/fsSafe.js +89 -0
- package/dist/utils/fsSafe.js.map +1 -0
- package/dist/utils/index.d.ts +15 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +51 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/security.d.ts +147 -0
- package/dist/utils/security.d.ts.map +1 -0
- package/dist/utils/security.js +391 -0
- package/dist/utils/security.js.map +1 -0
- package/dist/utils/validation.d.ts +40 -0
- package/dist/utils/validation.d.ts.map +1 -1
- package/dist/utils/validation.js +184 -7
- package/dist/utils/validation.js.map +1 -1
- package/package.json +54 -37
- package/src/ACTPClient.ts +692 -178
- package/src/abi/AgentRegistry.json +782 -0
- package/src/abi/EscrowVault.json +106 -38
- package/src/abi/IdentityRegistry.json +316 -0
- package/src/adapters/BaseAdapter.ts +473 -0
- package/src/adapters/BeginnerAdapter.ts +232 -0
- package/src/adapters/IntermediateAdapter.ts +316 -0
- package/src/adapters/index.ts +25 -0
- package/src/builders/DeliveryProofBuilder.ts +3 -2
- package/src/cli/commands/balance.ts +110 -0
- package/src/cli/commands/batch.ts +487 -0
- package/src/cli/commands/config.ts +231 -0
- package/src/cli/commands/init.ts +161 -0
- package/src/cli/commands/mint.ts +116 -0
- package/src/cli/commands/pay.ts +113 -0
- package/src/cli/commands/simulate.ts +345 -0
- package/src/cli/commands/time.ts +303 -0
- package/src/cli/commands/tx.ts +448 -0
- package/src/cli/commands/watch.ts +211 -0
- package/src/cli/index.ts +116 -0
- package/src/cli/utils/client.ts +249 -0
- package/src/cli/utils/config.ts +282 -0
- package/src/cli/utils/output.ts +465 -0
- package/src/config/networks.ts +32 -9
- package/src/errors/index.ts +298 -1
- package/src/index.ts +207 -71
- package/src/level0/Provider.ts +117 -0
- package/src/level0/ServiceDirectory.ts +131 -0
- package/src/level0/index.ts +10 -0
- package/src/level0/provide.ts +131 -0
- package/src/level0/request.ts +494 -0
- package/src/level1/Agent.ts +1432 -0
- package/src/level1/index.ts +10 -0
- package/src/level1/pricing/PriceCalculator.ts +255 -0
- package/src/level1/pricing/PricingStrategy.ts +198 -0
- package/src/level1/types/Job.ts +179 -0
- package/src/level1/types/Options.ts +291 -0
- package/src/level1/types/index.ts +8 -0
- package/src/protocol/ACTPKernel.ts +175 -23
- package/src/protocol/AgentRegistry.ts +559 -0
- package/src/protocol/DIDManager.ts +629 -0
- package/src/protocol/DIDResolver.ts +554 -0
- package/src/protocol/EASHelper.ts +230 -46
- package/src/protocol/EscrowVault.ts +68 -50
- package/src/protocol/EventMonitor.ts +44 -15
- package/src/protocol/MessageSigner.ts +193 -13
- package/src/protocol/ProofGenerator.ts +223 -4
- package/src/runtime/BlockchainRuntime.ts +993 -0
- package/src/runtime/IACTPRuntime.ts +284 -0
- package/src/runtime/MockRuntime.ts +1244 -0
- package/src/runtime/MockStateManager.ts +576 -0
- package/src/runtime/index.ts +25 -0
- package/src/runtime/types/MockState.ts +227 -0
- package/src/types/agent.ts +79 -0
- package/src/types/did.ts +223 -0
- package/src/types/escrow.ts +12 -11
- package/src/types/index.ts +5 -1
- package/src/types/state.ts +12 -3
- package/src/types/transaction.ts +4 -1
- package/src/utils/ErrorRecoveryGuide.ts +675 -0
- package/src/utils/Helpers.ts +688 -0
- package/src/utils/IPFSClient.ts +122 -5
- package/src/utils/Logger.ts +484 -0
- package/src/utils/NonceManager.ts +305 -8
- package/src/utils/RateLimiter.ts +534 -0
- package/src/utils/ReceivedNonceTracker.ts +170 -0
- package/src/utils/SDKLifecycle.ts +416 -0
- package/src/utils/SecureNonce.ts +78 -0
- package/src/utils/Semaphore.ts +276 -0
- package/src/utils/UsedAttestationTracker.ts +387 -0
- package/src/utils/fsSafe.ts +75 -0
- package/src/utils/index.ts +80 -0
- package/src/utils/security.ts +418 -0
- package/src/utils/validation.ts +164 -0
- package/src/__tests__/ProofGenerator.test.ts +0 -124
- package/src/__tests__/QuoteBuilder.test.ts +0 -516
- package/src/__tests__/StateMachine.test.ts +0 -82
- package/src/__tests__/builders/DeliveryProofBuilder.test.ts +0 -581
- package/src/__tests__/integration/ACTPClient.test.ts +0 -263
- package/src/__tests__/integration.test.ts +0 -289
- package/src/__tests__/protocol/EASHelper.test.ts +0 -472
- package/src/__tests__/protocol/EventMonitor.test.ts +0 -382
- package/src/__tests__/security/ACTPKernel.security.test.ts +0 -1167
- package/src/__tests__/security/EscrowVault.security.test.ts +0 -570
- package/src/__tests__/security/MessageSigner.security.test.ts +0 -286
- package/src/__tests__/security/NonceReplay.security.test.ts +0 -501
- package/src/__tests__/security/validation.security.test.ts +0 -376
- package/src/__tests__/utils/IPFSClient.test.ts +0 -262
- package/src/__tests__/utils/NonceManager.test.ts +0 -205
- package/src/__tests__/utils/canonicalJson.test.ts +0 -153
package/dist/utils/validation.js
CHANGED
|
@@ -1,12 +1,37 @@
|
|
|
1
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 (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.validateAddress =
|
|
4
|
-
exports.validateAmount = validateAmount;
|
|
5
|
-
exports.validateDeadline = validateDeadline;
|
|
6
|
-
exports.validateDisputeWindow = validateDisputeWindow;
|
|
7
|
-
exports.validateTxId = validateTxId;
|
|
26
|
+
exports.validateEndpointURL = exports.validateTxId = exports.validateDisputeWindow = exports.validateDeadline = exports.validateAmount = exports.validateAddress = void 0;
|
|
8
27
|
const ethers_1 = require("ethers");
|
|
9
28
|
const errors_1 = require("../errors");
|
|
29
|
+
/**
|
|
30
|
+
* Input validation utilities
|
|
31
|
+
*/
|
|
32
|
+
/**
|
|
33
|
+
* Validate Ethereum address
|
|
34
|
+
*/
|
|
10
35
|
function validateAddress(address, fieldName = 'address') {
|
|
11
36
|
if (!address || !(0, ethers_1.isAddress)(address)) {
|
|
12
37
|
throw new errors_1.InvalidAddressError(address);
|
|
@@ -15,22 +40,35 @@ function validateAddress(address, fieldName = 'address') {
|
|
|
15
40
|
throw new errors_1.ValidationError(fieldName, 'Address cannot be zero address');
|
|
16
41
|
}
|
|
17
42
|
}
|
|
43
|
+
exports.validateAddress = validateAddress;
|
|
44
|
+
/**
|
|
45
|
+
* Validate amount (must be > 0)
|
|
46
|
+
*/
|
|
18
47
|
function validateAmount(amount, _fieldName = 'amount') {
|
|
48
|
+
// Handle null/undefined before calling toString()
|
|
19
49
|
if (!amount) {
|
|
20
|
-
throw new errors_1.InvalidAmountError(String(amount));
|
|
50
|
+
throw new errors_1.InvalidAmountError(String(amount)); // Convert safely to string
|
|
21
51
|
}
|
|
22
52
|
if (amount <= 0n) {
|
|
23
53
|
throw new errors_1.InvalidAmountError(amount.toString());
|
|
24
54
|
}
|
|
25
55
|
}
|
|
56
|
+
exports.validateAmount = validateAmount;
|
|
57
|
+
/**
|
|
58
|
+
* Validate deadline (must be future timestamp)
|
|
59
|
+
*/
|
|
26
60
|
function validateDeadline(deadline, fieldName = 'deadline') {
|
|
27
61
|
const now = Math.floor(Date.now() / 1000);
|
|
28
62
|
if (deadline <= now) {
|
|
29
63
|
throw new errors_1.ValidationError(fieldName, `Deadline must be in the future (now: ${now}, deadline: ${deadline})`);
|
|
30
64
|
}
|
|
31
65
|
}
|
|
66
|
+
exports.validateDeadline = validateDeadline;
|
|
67
|
+
/**
|
|
68
|
+
* Validate dispute window (max 30 days per spec)
|
|
69
|
+
*/
|
|
32
70
|
function validateDisputeWindow(disputeWindow, fieldName = 'disputeWindow') {
|
|
33
|
-
const MAX_DISPUTE_WINDOW = 30 * 24 * 60 * 60;
|
|
71
|
+
const MAX_DISPUTE_WINDOW = 30 * 24 * 60 * 60; // 30 days in seconds
|
|
34
72
|
if (disputeWindow < 0) {
|
|
35
73
|
throw new errors_1.ValidationError(fieldName, 'Dispute window cannot be negative');
|
|
36
74
|
}
|
|
@@ -38,9 +76,148 @@ function validateDisputeWindow(disputeWindow, fieldName = 'disputeWindow') {
|
|
|
38
76
|
throw new errors_1.ValidationError(fieldName, `Dispute window exceeds maximum (${MAX_DISPUTE_WINDOW}s = 30 days)`);
|
|
39
77
|
}
|
|
40
78
|
}
|
|
79
|
+
exports.validateDisputeWindow = validateDisputeWindow;
|
|
80
|
+
/**
|
|
81
|
+
* Validate transaction ID format
|
|
82
|
+
*/
|
|
41
83
|
function validateTxId(txId, fieldName = 'txId') {
|
|
42
84
|
if (!txId || !txId.match(/^0x[a-fA-F0-9]{64}$/)) {
|
|
43
85
|
throw new errors_1.ValidationError(fieldName, 'Invalid transaction ID format (expected bytes32)');
|
|
44
86
|
}
|
|
45
87
|
}
|
|
88
|
+
exports.validateTxId = validateTxId;
|
|
89
|
+
/**
|
|
90
|
+
* Check if IP address is private/local (SSRF protection)
|
|
91
|
+
*
|
|
92
|
+
* SECURITY FIX (H-1): Comprehensive private IP detection
|
|
93
|
+
* - IPv4: 127.0.0.0/8, 10.0.0.0/8, 172.16.0.0/12, 192.168.0.0/16, 169.254.0.0/16
|
|
94
|
+
* - IPv6: ::1, fc00::/7, fd00::/8, fe80::/10
|
|
95
|
+
* - IPv4-mapped IPv6: ::ffff:127.0.0.0/8, ::ffff:10.0.0.0/8, etc.
|
|
96
|
+
*
|
|
97
|
+
* @param ip - IP address (v4 or v6, no brackets)
|
|
98
|
+
* @returns true if IP is private/local
|
|
99
|
+
*/
|
|
100
|
+
function isPrivateIP(ip) {
|
|
101
|
+
// Remove IPv6 brackets if present
|
|
102
|
+
const cleanIP = ip.replace(/^\[|\]$/g, '');
|
|
103
|
+
// IPv4 patterns
|
|
104
|
+
const ipv4PrivatePatterns = [
|
|
105
|
+
/^127\./, // Loopback
|
|
106
|
+
/^10\./, // Private class A
|
|
107
|
+
/^172\.(1[6-9]|2\d|3[01])\./, // Private class B (172.16-172.31)
|
|
108
|
+
/^192\.168\./, // Private class C
|
|
109
|
+
/^169\.254\./, // Link-local / AWS metadata
|
|
110
|
+
/^0\./, // Invalid source
|
|
111
|
+
/^localhost$/i // Localhost hostname
|
|
112
|
+
];
|
|
113
|
+
for (const pattern of ipv4PrivatePatterns) {
|
|
114
|
+
if (pattern.test(cleanIP)) {
|
|
115
|
+
return true;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
// IPv6 patterns (without brackets)
|
|
119
|
+
const ipv6PrivatePatterns = [
|
|
120
|
+
/^::1$/, // IPv6 loopback
|
|
121
|
+
/^::ffff:127\./, // IPv4-mapped localhost
|
|
122
|
+
/^::ffff:10\./, // IPv4-mapped private 10.x
|
|
123
|
+
/^::ffff:192\.168\./, // IPv4-mapped private 192.168.x
|
|
124
|
+
/^::ffff:172\.(1[6-9]|2\d|3[01])\./, // IPv4-mapped private 172.16-31.x
|
|
125
|
+
/^::ffff:169\.254\./, // IPv4-mapped link-local (CRITICAL: AWS metadata)
|
|
126
|
+
/^fc00:/i, // IPv6 ULA fc00::/7
|
|
127
|
+
/^fd/i, // IPv6 ULA fd00::/8
|
|
128
|
+
/^fe80:/i // IPv6 link-local fe80::/10
|
|
129
|
+
];
|
|
130
|
+
for (const pattern of ipv6PrivatePatterns) {
|
|
131
|
+
if (pattern.test(cleanIP)) {
|
|
132
|
+
return true;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
return false;
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Validate endpoint URL (for AgentRegistry)
|
|
139
|
+
*
|
|
140
|
+
* SECURITY FIX (H-1): Enhanced SSRF protection with DNS resolution
|
|
141
|
+
*
|
|
142
|
+
* Security checks:
|
|
143
|
+
* - Valid URL format
|
|
144
|
+
* - HTTPS or IPFS protocols only
|
|
145
|
+
* - Maximum length 256 characters
|
|
146
|
+
* - DNS resolution check (hostname → IP validation)
|
|
147
|
+
* - No private/local IP addresses (SSRF protection)
|
|
148
|
+
* - Blocks AWS metadata endpoint (169.254.169.254)
|
|
149
|
+
* - Fail-secure: if DNS lookup fails, reject
|
|
150
|
+
*
|
|
151
|
+
* **CRITICAL**: This function is now ASYNC due to DNS resolution.
|
|
152
|
+
* All callers MUST await this function.
|
|
153
|
+
*
|
|
154
|
+
* @param endpoint - URL to validate
|
|
155
|
+
* @param fieldName - Field name for error messages
|
|
156
|
+
* @throws {ValidationError} If endpoint is invalid or points to private IP
|
|
157
|
+
*/
|
|
158
|
+
async function validateEndpointURL(endpoint, fieldName = 'endpoint') {
|
|
159
|
+
if (!endpoint || endpoint.length === 0) {
|
|
160
|
+
throw new errors_1.ValidationError(fieldName, 'Endpoint is required');
|
|
161
|
+
}
|
|
162
|
+
const MAX_LENGTH = 256;
|
|
163
|
+
if (endpoint.length > MAX_LENGTH) {
|
|
164
|
+
throw new errors_1.ValidationError(fieldName, `Endpoint exceeds maximum length (${MAX_LENGTH})`);
|
|
165
|
+
}
|
|
166
|
+
let parsedUrl;
|
|
167
|
+
try {
|
|
168
|
+
parsedUrl = new URL(endpoint);
|
|
169
|
+
}
|
|
170
|
+
catch (e) {
|
|
171
|
+
throw new errors_1.ValidationError(fieldName, 'Endpoint must be a valid URL');
|
|
172
|
+
}
|
|
173
|
+
const allowedProtocols = ['https:', 'ipfs:'];
|
|
174
|
+
if (!allowedProtocols.includes(parsedUrl.protocol)) {
|
|
175
|
+
throw new errors_1.ValidationError(fieldName, `Endpoint protocol must be one of: ${allowedProtocols.join(', ')}`);
|
|
176
|
+
}
|
|
177
|
+
// SECURITY FIX (H-1): First check hostname syntax
|
|
178
|
+
// URL().hostname strips brackets from IPv6 addresses
|
|
179
|
+
const hostname = parsedUrl.hostname;
|
|
180
|
+
// Check if hostname itself looks like a private IP (bypass DNS for direct IPs)
|
|
181
|
+
if (isPrivateIP(hostname)) {
|
|
182
|
+
throw new errors_1.ValidationError(fieldName, `Endpoint hostname "${hostname}" is a private/local address (SSRF protection)`);
|
|
183
|
+
}
|
|
184
|
+
// SECURITY FIX (H-1): DNS resolution check
|
|
185
|
+
// Resolve hostname to IP address(es) and validate each resolved IP
|
|
186
|
+
// This prevents DNS rebinding attacks where hostname resolves to private IP
|
|
187
|
+
if (parsedUrl.protocol === 'https:') {
|
|
188
|
+
try {
|
|
189
|
+
// Dynamic import for Node.js dns module (not available in browser)
|
|
190
|
+
// If running in browser, skip DNS check (browsers have their own SSRF protection)
|
|
191
|
+
const dns = await Promise.resolve().then(() => __importStar(require('dns'))).catch(() => null);
|
|
192
|
+
if (dns) {
|
|
193
|
+
// Resolve hostname to ALL IP addresses and validate each (prevents AAAA/A bypass)
|
|
194
|
+
const results = await dns.promises.lookup(hostname, { all: true });
|
|
195
|
+
for (const { address, family } of results) {
|
|
196
|
+
// Validate resolved IP is not private
|
|
197
|
+
if (isPrivateIP(address)) {
|
|
198
|
+
throw new errors_1.ValidationError(fieldName, `Endpoint hostname "${hostname}" resolves to private IP address ${address} (SSRF protection). ` +
|
|
199
|
+
`This could be an attempt to access internal services. ` +
|
|
200
|
+
`IP family: IPv${family}`);
|
|
201
|
+
}
|
|
202
|
+
// SECURITY FIX (H-1): CRITICAL - Block AWS metadata endpoint explicitly
|
|
203
|
+
if (address === '169.254.169.254') {
|
|
204
|
+
throw new errors_1.ValidationError(fieldName, `Endpoint resolves to AWS metadata endpoint (169.254.169.254). ` +
|
|
205
|
+
`This is blocked for security reasons (credential theft prevention).`);
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
catch (error) {
|
|
211
|
+
// SECURITY FIX (H-1): Fail-secure - if DNS lookup fails, reject
|
|
212
|
+
// Don't allow requests to unresolvable hostnames (could be DNS rebinding setup)
|
|
213
|
+
if (error instanceof errors_1.ValidationError) {
|
|
214
|
+
throw error; // Re-throw validation errors
|
|
215
|
+
}
|
|
216
|
+
throw new errors_1.ValidationError(fieldName, `Failed to resolve hostname "${hostname}": ${error.message}. ` +
|
|
217
|
+
`DNS resolution is required for SSRF protection (fail-secure mode).`);
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
// IPFS endpoints skip DNS check (no DNS resolution for IPFS CIDs)
|
|
221
|
+
}
|
|
222
|
+
exports.validateEndpointURL = validateEndpointURL;
|
|
46
223
|
//# sourceMappingURL=validation.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,23 +1,30 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@agirails/sdk",
|
|
3
|
-
"version": "2.0.
|
|
4
|
-
"description": "
|
|
3
|
+
"version": "2.0.2",
|
|
4
|
+
"description": "AGIRAILS SDK for the ACTP (Agent Commerce Transaction Protocol) - Unified mock + blockchain support",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
7
|
+
"bin": {
|
|
8
|
+
"actp": "./bin/actp"
|
|
9
|
+
},
|
|
7
10
|
"files": [
|
|
8
11
|
"dist",
|
|
9
12
|
"src",
|
|
10
|
-
"
|
|
13
|
+
"!src/**/*.test.ts",
|
|
14
|
+
"!src/**/*.spec.ts",
|
|
15
|
+
"bin",
|
|
16
|
+
"README.md",
|
|
17
|
+
"LICENSE"
|
|
11
18
|
],
|
|
12
19
|
"scripts": {
|
|
13
20
|
"build": "tsc",
|
|
14
|
-
"test": "jest",
|
|
21
|
+
"test": "jest --runInBand",
|
|
22
|
+
"test:watch": "jest --watch --runInBand",
|
|
23
|
+
"test:coverage": "jest --coverage --runInBand",
|
|
15
24
|
"test:onchain": "hardhat test",
|
|
16
|
-
"
|
|
17
|
-
"
|
|
18
|
-
"
|
|
19
|
-
"format": "prettier --write \"src/**/*.ts\"",
|
|
20
|
-
"prepublishOnly": "npm run build && npm test && npm run test:onchain",
|
|
25
|
+
"lint": "eslint src --ext .ts",
|
|
26
|
+
"format": "prettier --write 'src/**/*.ts'",
|
|
27
|
+
"prepublishOnly": "npm run build && npm test",
|
|
21
28
|
"test:setup": "ts-node test-scripts/00-setup.ts",
|
|
22
29
|
"test:happy-path": "ts-node test-scripts/01-happy-path.ts",
|
|
23
30
|
"test:dispute": "ts-node test-scripts/02-dispute.ts",
|
|
@@ -27,49 +34,59 @@
|
|
|
27
34
|
"test:all": "npm run test:setup && npm run test:happy-path && npm run test:dispute && npm run test:cancel"
|
|
28
35
|
},
|
|
29
36
|
"keywords": [
|
|
37
|
+
"agirails",
|
|
30
38
|
"actp",
|
|
31
|
-
"agent-commerce",
|
|
32
39
|
"blockchain",
|
|
40
|
+
"escrow",
|
|
41
|
+
"payments",
|
|
42
|
+
"ai-agents",
|
|
43
|
+
"cli",
|
|
44
|
+
"agent-commerce",
|
|
33
45
|
"ethereum",
|
|
34
46
|
"base",
|
|
35
|
-
"smart-contracts"
|
|
36
|
-
"ai-agents",
|
|
37
|
-
"escrow"
|
|
47
|
+
"smart-contracts"
|
|
38
48
|
],
|
|
39
49
|
"author": "AGIRAILS Inc.",
|
|
40
50
|
"license": "Apache-2.0",
|
|
41
51
|
"repository": {
|
|
42
52
|
"type": "git",
|
|
43
|
-
"url": "https://github.com/agirails/sdk
|
|
53
|
+
"url": "https://github.com/agirails/sdk"
|
|
44
54
|
},
|
|
45
55
|
"bugs": {
|
|
46
|
-
"url": "https://github.com/agirails/sdk
|
|
56
|
+
"url": "https://github.com/agirails/sdk/issues"
|
|
47
57
|
},
|
|
48
|
-
"homepage": "https://github.com/agirails/sdk
|
|
58
|
+
"homepage": "https://github.com/agirails/sdk#readme",
|
|
49
59
|
"dependencies": {
|
|
50
|
-
"@
|
|
51
|
-
"
|
|
52
|
-
"
|
|
53
|
-
"
|
|
54
|
-
"
|
|
60
|
+
"@aws-sdk/client-s3": "3.943.0",
|
|
61
|
+
"@ethereum-attestation-service/eas-sdk": "1.6.1",
|
|
62
|
+
"@irys/sdk": "0.2.11",
|
|
63
|
+
"commander": "11.1.0",
|
|
64
|
+
"did-resolver": "4.1.0",
|
|
65
|
+
"dotenv": "17.2.3",
|
|
66
|
+
"ethers": "6.15.0",
|
|
67
|
+
"ethr-did-resolver": "11.0.5",
|
|
68
|
+
"fast-json-stable-stringify": "2.1.0",
|
|
69
|
+
"kubo-rpc-client": "3.0.1",
|
|
70
|
+
"proper-lockfile": "4.1.2"
|
|
55
71
|
},
|
|
56
72
|
"devDependencies": {
|
|
57
|
-
"@nomicfoundation/hardhat-ethers": "
|
|
58
|
-
"@types/chai": "
|
|
59
|
-
"@types/fast-json-stable-stringify": "
|
|
60
|
-
"@types/jest": "
|
|
61
|
-
"@types/mocha": "
|
|
62
|
-
"@types/node": "
|
|
63
|
-
"@
|
|
64
|
-
"@typescript-eslint/
|
|
65
|
-
"
|
|
66
|
-
"
|
|
67
|
-
"
|
|
68
|
-
"
|
|
69
|
-
"
|
|
70
|
-
"
|
|
71
|
-
"ts-
|
|
72
|
-
"
|
|
73
|
+
"@nomicfoundation/hardhat-ethers": "3.0.0",
|
|
74
|
+
"@types/chai": "4.3.11",
|
|
75
|
+
"@types/fast-json-stable-stringify": "2.1.0",
|
|
76
|
+
"@types/jest": "29.5.11",
|
|
77
|
+
"@types/mocha": "10.0.6",
|
|
78
|
+
"@types/node": "20.10.0",
|
|
79
|
+
"@types/proper-lockfile": "4.1.4",
|
|
80
|
+
"@typescript-eslint/eslint-plugin": "6.0.0",
|
|
81
|
+
"@typescript-eslint/parser": "6.0.0",
|
|
82
|
+
"chai": "4.3.8",
|
|
83
|
+
"eslint": "8.50.0",
|
|
84
|
+
"hardhat": "2.19.4",
|
|
85
|
+
"jest": "29.7.0",
|
|
86
|
+
"prettier": "3.0.0",
|
|
87
|
+
"ts-jest": "29.1.1",
|
|
88
|
+
"ts-node": "10.9.1",
|
|
89
|
+
"typescript": "5.3.3"
|
|
73
90
|
},
|
|
74
91
|
"engines": {
|
|
75
92
|
"node": ">=16.0.0"
|