envoy-pay 0.1.0
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/CHANGELOG.md +99 -0
- package/LICENSE +200 -0
- package/README.md +529 -0
- package/dist/cjs/adapters/base.js +174 -0
- package/dist/cjs/adapters/base.js.map +1 -0
- package/dist/cjs/adapters/evm.js +339 -0
- package/dist/cjs/adapters/evm.js.map +1 -0
- package/dist/cjs/adapters/index.js +15 -0
- package/dist/cjs/adapters/index.js.map +1 -0
- package/dist/cjs/adapters/ows.js +204 -0
- package/dist/cjs/adapters/ows.js.map +1 -0
- package/dist/cjs/adapters/solana.js +210 -0
- package/dist/cjs/adapters/solana.js.map +1 -0
- package/dist/cjs/adapters/stellar.js +173 -0
- package/dist/cjs/adapters/stellar.js.map +1 -0
- package/dist/cjs/adapters/stripe.js +338 -0
- package/dist/cjs/adapters/stripe.js.map +1 -0
- package/dist/cjs/adapters/types.js +3 -0
- package/dist/cjs/adapters/types.js.map +1 -0
- package/dist/cjs/client.js +309 -0
- package/dist/cjs/client.js.map +1 -0
- package/dist/cjs/contracts/abis/EnvoyFacilitator.js +197 -0
- package/dist/cjs/contracts/abis/EnvoyFacilitator.js.map +1 -0
- package/dist/cjs/contracts/addresses.js +42 -0
- package/dist/cjs/contracts/addresses.js.map +1 -0
- package/dist/cjs/contracts/facilitator.js +225 -0
- package/dist/cjs/contracts/facilitator.js.map +1 -0
- package/dist/cjs/contracts/index.js +21 -0
- package/dist/cjs/contracts/index.js.map +1 -0
- package/dist/cjs/facilitator/facilitator-service.js +305 -0
- package/dist/cjs/facilitator/facilitator-service.js.map +1 -0
- package/dist/cjs/facilitator/fee-calculator.js +134 -0
- package/dist/cjs/facilitator/fee-calculator.js.map +1 -0
- package/dist/cjs/facilitator/index.js +12 -0
- package/dist/cjs/facilitator/index.js.map +1 -0
- package/dist/cjs/facilitator/types.js +99 -0
- package/dist/cjs/facilitator/types.js.map +1 -0
- package/dist/cjs/identity/agent-card.js +143 -0
- package/dist/cjs/identity/agent-card.js.map +1 -0
- package/dist/cjs/identity/agent-identity.js +166 -0
- package/dist/cjs/identity/agent-identity.js.map +1 -0
- package/dist/cjs/identity/did-resolver.js +149 -0
- package/dist/cjs/identity/did-resolver.js.map +1 -0
- package/dist/cjs/identity/erc8004/abis.js +218 -0
- package/dist/cjs/identity/erc8004/abis.js.map +1 -0
- package/dist/cjs/identity/erc8004/identity.js +268 -0
- package/dist/cjs/identity/erc8004/identity.js.map +1 -0
- package/dist/cjs/identity/erc8004/index.js +36 -0
- package/dist/cjs/identity/erc8004/index.js.map +1 -0
- package/dist/cjs/identity/erc8004/reputation.js +110 -0
- package/dist/cjs/identity/erc8004/reputation.js.map +1 -0
- package/dist/cjs/identity/erc8004/types.js +3 -0
- package/dist/cjs/identity/erc8004/types.js.map +1 -0
- package/dist/cjs/identity/index.js +61 -0
- package/dist/cjs/identity/index.js.map +1 -0
- package/dist/cjs/identity/owner-registry.js +140 -0
- package/dist/cjs/identity/owner-registry.js.map +1 -0
- package/dist/cjs/identity/reputation.js +193 -0
- package/dist/cjs/identity/reputation.js.map +1 -0
- package/dist/cjs/identity/types.js +16 -0
- package/dist/cjs/identity/types.js.map +1 -0
- package/dist/cjs/index.js +72 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/logger.js +7 -0
- package/dist/cjs/logger.js.map +1 -0
- package/dist/cjs/monitor/evm-watcher.js +165 -0
- package/dist/cjs/monitor/evm-watcher.js.map +1 -0
- package/dist/cjs/monitor/index.js +32 -0
- package/dist/cjs/monitor/index.js.map +1 -0
- package/dist/cjs/monitor/multi-watcher.js +94 -0
- package/dist/cjs/monitor/multi-watcher.js.map +1 -0
- package/dist/cjs/monitor/solana-watcher.js +172 -0
- package/dist/cjs/monitor/solana-watcher.js.map +1 -0
- package/dist/cjs/monitor/stellar-watcher.js +125 -0
- package/dist/cjs/monitor/stellar-watcher.js.map +1 -0
- package/dist/cjs/mpp.js +187 -0
- package/dist/cjs/mpp.js.map +1 -0
- package/dist/cjs/policy.js +71 -0
- package/dist/cjs/policy.js.map +1 -0
- package/dist/cjs/providers/bridge.js +323 -0
- package/dist/cjs/providers/bridge.js.map +1 -0
- package/dist/cjs/providers/onchainos.js +210 -0
- package/dist/cjs/providers/onchainos.js.map +1 -0
- package/dist/cjs/requests/eip681.js +77 -0
- package/dist/cjs/requests/eip681.js.map +1 -0
- package/dist/cjs/requests/index.js +18 -0
- package/dist/cjs/requests/index.js.map +1 -0
- package/dist/cjs/requests/sep7.js +61 -0
- package/dist/cjs/requests/sep7.js.map +1 -0
- package/dist/cjs/requests/solana-pay.js +51 -0
- package/dist/cjs/requests/solana-pay.js.map +1 -0
- package/dist/cjs/requests/universal.js +40 -0
- package/dist/cjs/requests/universal.js.map +1 -0
- package/dist/cjs/server/index.js +35 -0
- package/dist/cjs/server/index.js.map +1 -0
- package/dist/cjs/server/mpp-gate.js +118 -0
- package/dist/cjs/server/mpp-gate.js.map +1 -0
- package/dist/cjs/server/payment-gate.js +92 -0
- package/dist/cjs/server/payment-gate.js.map +1 -0
- package/dist/cjs/server/receipt.js +52 -0
- package/dist/cjs/server/receipt.js.map +1 -0
- package/dist/cjs/server/webhook.js +122 -0
- package/dist/cjs/server/webhook.js.map +1 -0
- package/dist/cjs/server/x402-gate.js +103 -0
- package/dist/cjs/server/x402-gate.js.map +1 -0
- package/dist/cjs/solana.js +14 -0
- package/dist/cjs/solana.js.map +1 -0
- package/dist/cjs/stellar.js +14 -0
- package/dist/cjs/stellar.js.map +1 -0
- package/dist/cjs/wallet/balance-aggregator.js +149 -0
- package/dist/cjs/wallet/balance-aggregator.js.map +1 -0
- package/dist/cjs/wallet/chain-router.js +254 -0
- package/dist/cjs/wallet/chain-router.js.map +1 -0
- package/dist/cjs/wallet/index.js +15 -0
- package/dist/cjs/wallet/index.js.map +1 -0
- package/dist/cjs/wallet/intent-resolver.js +145 -0
- package/dist/cjs/wallet/intent-resolver.js.map +1 -0
- package/dist/cjs/wallet/session-manager.js +170 -0
- package/dist/cjs/wallet/session-manager.js.map +1 -0
- package/dist/cjs/wallet/types.js +14 -0
- package/dist/cjs/wallet/types.js.map +1 -0
- package/dist/cjs/wallet/unified-wallet.js +253 -0
- package/dist/cjs/wallet/unified-wallet.js.map +1 -0
- package/dist/esm/adapters/base.js +170 -0
- package/dist/esm/adapters/base.js.map +1 -0
- package/dist/esm/adapters/evm.js +334 -0
- package/dist/esm/adapters/evm.js.map +1 -0
- package/dist/esm/adapters/index.js +6 -0
- package/dist/esm/adapters/index.js.map +1 -0
- package/dist/esm/adapters/ows.js +194 -0
- package/dist/esm/adapters/ows.js.map +1 -0
- package/dist/esm/adapters/solana.js +206 -0
- package/dist/esm/adapters/solana.js.map +1 -0
- package/dist/esm/adapters/stellar.js +136 -0
- package/dist/esm/adapters/stellar.js.map +1 -0
- package/dist/esm/adapters/stripe.js +334 -0
- package/dist/esm/adapters/stripe.js.map +1 -0
- package/dist/esm/adapters/types.js +2 -0
- package/dist/esm/adapters/types.js.map +1 -0
- package/dist/esm/client.js +302 -0
- package/dist/esm/client.js.map +1 -0
- package/dist/esm/contracts/abis/EnvoyFacilitator.js +194 -0
- package/dist/esm/contracts/abis/EnvoyFacilitator.js.map +1 -0
- package/dist/esm/contracts/addresses.js +38 -0
- package/dist/esm/contracts/addresses.js.map +1 -0
- package/dist/esm/contracts/facilitator.js +218 -0
- package/dist/esm/contracts/facilitator.js.map +1 -0
- package/dist/esm/contracts/index.js +8 -0
- package/dist/esm/contracts/index.js.map +1 -0
- package/dist/esm/facilitator/facilitator-service.js +301 -0
- package/dist/esm/facilitator/facilitator-service.js.map +1 -0
- package/dist/esm/facilitator/fee-calculator.js +130 -0
- package/dist/esm/facilitator/fee-calculator.js.map +1 -0
- package/dist/esm/facilitator/index.js +5 -0
- package/dist/esm/facilitator/index.js.map +1 -0
- package/dist/esm/facilitator/types.js +96 -0
- package/dist/esm/facilitator/types.js.map +1 -0
- package/dist/esm/identity/agent-card.js +139 -0
- package/dist/esm/identity/agent-card.js.map +1 -0
- package/dist/esm/identity/agent-identity.js +162 -0
- package/dist/esm/identity/agent-identity.js.map +1 -0
- package/dist/esm/identity/did-resolver.js +145 -0
- package/dist/esm/identity/did-resolver.js.map +1 -0
- package/dist/esm/identity/erc8004/abis.js +215 -0
- package/dist/esm/identity/erc8004/abis.js.map +1 -0
- package/dist/esm/identity/erc8004/identity.js +250 -0
- package/dist/esm/identity/erc8004/identity.js.map +1 -0
- package/dist/esm/identity/erc8004/index.js +13 -0
- package/dist/esm/identity/erc8004/index.js.map +1 -0
- package/dist/esm/identity/erc8004/reputation.js +105 -0
- package/dist/esm/identity/erc8004/reputation.js.map +1 -0
- package/dist/esm/identity/erc8004/types.js +2 -0
- package/dist/esm/identity/erc8004/types.js.map +1 -0
- package/dist/esm/identity/index.js +19 -0
- package/dist/esm/identity/index.js.map +1 -0
- package/dist/esm/identity/owner-registry.js +136 -0
- package/dist/esm/identity/owner-registry.js.map +1 -0
- package/dist/esm/identity/reputation.js +189 -0
- package/dist/esm/identity/reputation.js.map +1 -0
- package/dist/esm/identity/types.js +15 -0
- package/dist/esm/identity/types.js.map +1 -0
- package/dist/esm/index.js +37 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/logger.js +3 -0
- package/dist/esm/logger.js.map +1 -0
- package/dist/esm/monitor/evm-watcher.js +162 -0
- package/dist/esm/monitor/evm-watcher.js.map +1 -0
- package/dist/esm/monitor/index.js +25 -0
- package/dist/esm/monitor/index.js.map +1 -0
- package/dist/esm/monitor/multi-watcher.js +91 -0
- package/dist/esm/monitor/multi-watcher.js.map +1 -0
- package/dist/esm/monitor/solana-watcher.js +169 -0
- package/dist/esm/monitor/solana-watcher.js.map +1 -0
- package/dist/esm/monitor/stellar-watcher.js +122 -0
- package/dist/esm/monitor/stellar-watcher.js.map +1 -0
- package/dist/esm/mpp.js +175 -0
- package/dist/esm/mpp.js.map +1 -0
- package/dist/esm/policy.js +67 -0
- package/dist/esm/policy.js.map +1 -0
- package/dist/esm/providers/bridge.js +319 -0
- package/dist/esm/providers/bridge.js.map +1 -0
- package/dist/esm/providers/onchainos.js +172 -0
- package/dist/esm/providers/onchainos.js.map +1 -0
- package/dist/esm/requests/eip681.js +74 -0
- package/dist/esm/requests/eip681.js.map +1 -0
- package/dist/esm/requests/index.js +11 -0
- package/dist/esm/requests/index.js.map +1 -0
- package/dist/esm/requests/sep7.js +58 -0
- package/dist/esm/requests/sep7.js.map +1 -0
- package/dist/esm/requests/solana-pay.js +48 -0
- package/dist/esm/requests/solana-pay.js.map +1 -0
- package/dist/esm/requests/universal.js +37 -0
- package/dist/esm/requests/universal.js.map +1 -0
- package/dist/esm/server/index.js +27 -0
- package/dist/esm/server/index.js.map +1 -0
- package/dist/esm/server/mpp-gate.js +115 -0
- package/dist/esm/server/mpp-gate.js.map +1 -0
- package/dist/esm/server/payment-gate.js +89 -0
- package/dist/esm/server/payment-gate.js.map +1 -0
- package/dist/esm/server/receipt.js +48 -0
- package/dist/esm/server/receipt.js.map +1 -0
- package/dist/esm/server/webhook.js +119 -0
- package/dist/esm/server/webhook.js.map +1 -0
- package/dist/esm/server/x402-gate.js +100 -0
- package/dist/esm/server/x402-gate.js.map +1 -0
- package/dist/esm/solana.js +8 -0
- package/dist/esm/solana.js.map +1 -0
- package/dist/esm/stellar.js +8 -0
- package/dist/esm/stellar.js.map +1 -0
- package/dist/esm/wallet/balance-aggregator.js +145 -0
- package/dist/esm/wallet/balance-aggregator.js.map +1 -0
- package/dist/esm/wallet/chain-router.js +250 -0
- package/dist/esm/wallet/chain-router.js.map +1 -0
- package/dist/esm/wallet/index.js +7 -0
- package/dist/esm/wallet/index.js.map +1 -0
- package/dist/esm/wallet/intent-resolver.js +141 -0
- package/dist/esm/wallet/intent-resolver.js.map +1 -0
- package/dist/esm/wallet/session-manager.js +166 -0
- package/dist/esm/wallet/session-manager.js.map +1 -0
- package/dist/esm/wallet/types.js +13 -0
- package/dist/esm/wallet/types.js.map +1 -0
- package/dist/esm/wallet/unified-wallet.js +249 -0
- package/dist/esm/wallet/unified-wallet.js.map +1 -0
- package/dist/types/adapters/base.d.ts +53 -0
- package/dist/types/adapters/base.d.ts.map +1 -0
- package/dist/types/adapters/evm.d.ts +93 -0
- package/dist/types/adapters/evm.d.ts.map +1 -0
- package/dist/types/adapters/index.d.ts +7 -0
- package/dist/types/adapters/index.d.ts.map +1 -0
- package/dist/types/adapters/ows.d.ts +123 -0
- package/dist/types/adapters/ows.d.ts.map +1 -0
- package/dist/types/adapters/solana.d.ts +77 -0
- package/dist/types/adapters/solana.d.ts.map +1 -0
- package/dist/types/adapters/stellar.d.ts +67 -0
- package/dist/types/adapters/stellar.d.ts.map +1 -0
- package/dist/types/adapters/stripe.d.ts +206 -0
- package/dist/types/adapters/stripe.d.ts.map +1 -0
- package/dist/types/adapters/types.d.ts +110 -0
- package/dist/types/adapters/types.d.ts.map +1 -0
- package/dist/types/client.d.ts +89 -0
- package/dist/types/client.d.ts.map +1 -0
- package/dist/types/contracts/abis/EnvoyFacilitator.d.ts +296 -0
- package/dist/types/contracts/abis/EnvoyFacilitator.d.ts.map +1 -0
- package/dist/types/contracts/addresses.d.ts +24 -0
- package/dist/types/contracts/addresses.d.ts.map +1 -0
- package/dist/types/contracts/facilitator.d.ts +172 -0
- package/dist/types/contracts/facilitator.d.ts.map +1 -0
- package/dist/types/contracts/index.d.ts +6 -0
- package/dist/types/contracts/index.d.ts.map +1 -0
- package/dist/types/facilitator/facilitator-service.d.ts +69 -0
- package/dist/types/facilitator/facilitator-service.d.ts.map +1 -0
- package/dist/types/facilitator/fee-calculator.d.ts +48 -0
- package/dist/types/facilitator/fee-calculator.d.ts.map +1 -0
- package/dist/types/facilitator/index.d.ts +5 -0
- package/dist/types/facilitator/index.d.ts.map +1 -0
- package/dist/types/facilitator/types.d.ts +221 -0
- package/dist/types/facilitator/types.d.ts.map +1 -0
- package/dist/types/identity/agent-card.d.ts +83 -0
- package/dist/types/identity/agent-card.d.ts.map +1 -0
- package/dist/types/identity/agent-identity.d.ts +102 -0
- package/dist/types/identity/agent-identity.d.ts.map +1 -0
- package/dist/types/identity/did-resolver.d.ts +70 -0
- package/dist/types/identity/did-resolver.d.ts.map +1 -0
- package/dist/types/identity/erc8004/abis.d.ts +336 -0
- package/dist/types/identity/erc8004/abis.d.ts.map +1 -0
- package/dist/types/identity/erc8004/identity.d.ts +109 -0
- package/dist/types/identity/erc8004/identity.d.ts.map +1 -0
- package/dist/types/identity/erc8004/index.d.ts +15 -0
- package/dist/types/identity/erc8004/index.d.ts.map +1 -0
- package/dist/types/identity/erc8004/reputation.d.ts +52 -0
- package/dist/types/identity/erc8004/reputation.d.ts.map +1 -0
- package/dist/types/identity/erc8004/types.d.ts +31 -0
- package/dist/types/identity/erc8004/types.d.ts.map +1 -0
- package/dist/types/identity/index.d.ts +10 -0
- package/dist/types/identity/index.d.ts.map +1 -0
- package/dist/types/identity/owner-registry.d.ts +68 -0
- package/dist/types/identity/owner-registry.d.ts.map +1 -0
- package/dist/types/identity/reputation.d.ts +66 -0
- package/dist/types/identity/reputation.d.ts.map +1 -0
- package/dist/types/identity/types.d.ts +182 -0
- package/dist/types/identity/types.d.ts.map +1 -0
- package/dist/types/index.d.ts +17 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/logger.d.ts +10 -0
- package/dist/types/logger.d.ts.map +1 -0
- package/dist/types/monitor/evm-watcher.d.ts +40 -0
- package/dist/types/monitor/evm-watcher.d.ts.map +1 -0
- package/dist/types/monitor/index.d.ts +25 -0
- package/dist/types/monitor/index.d.ts.map +1 -0
- package/dist/types/monitor/multi-watcher.d.ts +48 -0
- package/dist/types/monitor/multi-watcher.d.ts.map +1 -0
- package/dist/types/monitor/solana-watcher.d.ts +36 -0
- package/dist/types/monitor/solana-watcher.d.ts.map +1 -0
- package/dist/types/monitor/stellar-watcher.d.ts +34 -0
- package/dist/types/monitor/stellar-watcher.d.ts.map +1 -0
- package/dist/types/mpp.d.ts +153 -0
- package/dist/types/mpp.d.ts.map +1 -0
- package/dist/types/policy.d.ts +40 -0
- package/dist/types/policy.d.ts.map +1 -0
- package/dist/types/providers/bridge.d.ts +162 -0
- package/dist/types/providers/bridge.d.ts.map +1 -0
- package/dist/types/providers/onchainos.d.ts +128 -0
- package/dist/types/providers/onchainos.d.ts.map +1 -0
- package/dist/types/requests/eip681.d.ts +51 -0
- package/dist/types/requests/eip681.d.ts.map +1 -0
- package/dist/types/requests/index.d.ts +11 -0
- package/dist/types/requests/index.d.ts.map +1 -0
- package/dist/types/requests/sep7.d.ts +56 -0
- package/dist/types/requests/sep7.d.ts.map +1 -0
- package/dist/types/requests/solana-pay.d.ts +50 -0
- package/dist/types/requests/solana-pay.d.ts.map +1 -0
- package/dist/types/requests/universal.d.ts +28 -0
- package/dist/types/requests/universal.d.ts.map +1 -0
- package/dist/types/server/index.d.ts +27 -0
- package/dist/types/server/index.d.ts.map +1 -0
- package/dist/types/server/mpp-gate.d.ts +66 -0
- package/dist/types/server/mpp-gate.d.ts.map +1 -0
- package/dist/types/server/payment-gate.d.ts +33 -0
- package/dist/types/server/payment-gate.d.ts.map +1 -0
- package/dist/types/server/receipt.d.ts +52 -0
- package/dist/types/server/receipt.d.ts.map +1 -0
- package/dist/types/server/webhook.d.ts +46 -0
- package/dist/types/server/webhook.d.ts.map +1 -0
- package/dist/types/server/x402-gate.d.ts +70 -0
- package/dist/types/server/x402-gate.d.ts.map +1 -0
- package/dist/types/solana.d.ts +7 -0
- package/dist/types/solana.d.ts.map +1 -0
- package/dist/types/stellar.d.ts +7 -0
- package/dist/types/stellar.d.ts.map +1 -0
- package/dist/types/wallet/balance-aggregator.d.ts +51 -0
- package/dist/types/wallet/balance-aggregator.d.ts.map +1 -0
- package/dist/types/wallet/chain-router.d.ts +44 -0
- package/dist/types/wallet/chain-router.d.ts.map +1 -0
- package/dist/types/wallet/index.d.ts +7 -0
- package/dist/types/wallet/index.d.ts.map +1 -0
- package/dist/types/wallet/intent-resolver.d.ts +39 -0
- package/dist/types/wallet/intent-resolver.d.ts.map +1 -0
- package/dist/types/wallet/session-manager.d.ts +57 -0
- package/dist/types/wallet/session-manager.d.ts.map +1 -0
- package/dist/types/wallet/types.d.ts +161 -0
- package/dist/types/wallet/types.d.ts.map +1 -0
- package/dist/types/wallet/unified-wallet.d.ts +122 -0
- package/dist/types/wallet/unified-wallet.d.ts.map +1 -0
- package/package.json +194 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mpp-gate.js","sourceRoot":"","sources":["../../../src/server/mpp-gate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createPaymentGate = createPaymentGate;
|
|
4
|
+
const x402_gate_1 = require("./x402-gate");
|
|
5
|
+
const mpp_gate_1 = require("./mpp-gate");
|
|
6
|
+
const logger_1 = require("../logger");
|
|
7
|
+
/**
|
|
8
|
+
* Creates a dual-protocol payment gate that accepts both x402 and MPP.
|
|
9
|
+
*
|
|
10
|
+
* Detection logic:
|
|
11
|
+
* - `X-PAYMENT` header → x402 flow
|
|
12
|
+
* - `Authorization: Payment` header → MPP flow
|
|
13
|
+
* - Neither present → returns both challenge types simultaneously
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```ts
|
|
17
|
+
* app.post('/api/premium', createPaymentGate({
|
|
18
|
+
* x402: { payTo: '0x...', amount: '500000', asset: 'USDC', network: 'eip155:8453' },
|
|
19
|
+
* mpp: { realm: 'api.example.com', method: 'stripe', amount: '50', recipient: 'acct_xxx' },
|
|
20
|
+
* }), handler);
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
function createPaymentGate(config) {
|
|
24
|
+
const log = config.logger ?? logger_1.noopLogger;
|
|
25
|
+
const x402Middleware = (0, x402_gate_1.createX402Gate)({
|
|
26
|
+
...config.x402,
|
|
27
|
+
logger: log,
|
|
28
|
+
});
|
|
29
|
+
const mppMiddleware = (0, mpp_gate_1.createMppGate)({
|
|
30
|
+
...config.mpp,
|
|
31
|
+
logger: log,
|
|
32
|
+
});
|
|
33
|
+
return async (req, res, next) => {
|
|
34
|
+
// Detect which protocol the client is using
|
|
35
|
+
const hasX402 = !!(req.headers['x-payment'] || req.headers['X-PAYMENT']);
|
|
36
|
+
const hasAuth = !!(req.headers['authorization'] &&
|
|
37
|
+
req.headers['authorization'].startsWith('Payment '));
|
|
38
|
+
if (hasX402) {
|
|
39
|
+
log('[payment-gate] 🔍 Detected x402 protocol (X-PAYMENT header)');
|
|
40
|
+
return x402Middleware(req, res, next);
|
|
41
|
+
}
|
|
42
|
+
if (hasAuth) {
|
|
43
|
+
log('[payment-gate] 🔍 Detected MPP protocol (Authorization: Payment header)');
|
|
44
|
+
return mppMiddleware(req, res, next);
|
|
45
|
+
}
|
|
46
|
+
// No payment header — return dual-protocol 402 challenge
|
|
47
|
+
log('[payment-gate] 💰 No payment header — returning dual-protocol 402');
|
|
48
|
+
// Build MPP challenge header
|
|
49
|
+
const mppIntent = config.mpp.intent ?? 'payment';
|
|
50
|
+
const mppCurrency = config.mpp.currency ?? 'usd';
|
|
51
|
+
const mppDecimals = config.mpp.decimals ?? 2;
|
|
52
|
+
const ttlMs = config.mpp.ttlMs ?? 300000;
|
|
53
|
+
const challengeId = `ch_${Date.now()}_dual`;
|
|
54
|
+
const expires = new Date(Date.now() + ttlMs).toISOString();
|
|
55
|
+
const requestObj = {
|
|
56
|
+
amount: config.mpp.amount,
|
|
57
|
+
currency: mppCurrency,
|
|
58
|
+
decimals: mppDecimals,
|
|
59
|
+
recipient: config.mpp.recipient,
|
|
60
|
+
};
|
|
61
|
+
const requestEncoded = Buffer.from(JSON.stringify(requestObj))
|
|
62
|
+
.toString('base64')
|
|
63
|
+
.replace(/\+/g, '-')
|
|
64
|
+
.replace(/\//g, '_')
|
|
65
|
+
.replace(/=+$/, '');
|
|
66
|
+
const wwwAuth = `Payment id="${challengeId}",realm="${config.mpp.realm}",method="${config.mpp.method}",intent="${mppIntent}",request="${requestEncoded}",expires="${expires}"`;
|
|
67
|
+
// Build x402 challenge body
|
|
68
|
+
const x402Body = {
|
|
69
|
+
x402Version: config.x402.x402Version ?? 2,
|
|
70
|
+
resource: {
|
|
71
|
+
url: req.url || '/',
|
|
72
|
+
description: config.x402.description || 'Payment required',
|
|
73
|
+
...(config.x402.usdAmount ? { usdAmount: config.x402.usdAmount } : {}),
|
|
74
|
+
},
|
|
75
|
+
accepts: [
|
|
76
|
+
{
|
|
77
|
+
scheme: config.x402.scheme ?? 'exact',
|
|
78
|
+
network: config.x402.network,
|
|
79
|
+
amount: config.x402.amount,
|
|
80
|
+
payTo: config.x402.payTo,
|
|
81
|
+
asset: config.x402.asset,
|
|
82
|
+
},
|
|
83
|
+
],
|
|
84
|
+
};
|
|
85
|
+
res.writeHead(402, {
|
|
86
|
+
'WWW-Authenticate': wwwAuth,
|
|
87
|
+
'Content-Type': 'application/json',
|
|
88
|
+
});
|
|
89
|
+
res.end(JSON.stringify(x402Body));
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=payment-gate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"payment-gate.js","sourceRoot":"","sources":["../../../src/server/payment-gate.ts"],"names":[],"mappings":";;AAiCA,8CAuFC;AAvHD,2CAAkE;AAClE,yCAA+D;AAC/D,sCAA+C;AAc/C;;;;;;;;;;;;;;;GAeG;AACH,SAAgB,iBAAiB,CAAC,MAAyB;IACzD,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,IAAI,mBAAU,CAAC;IAExC,MAAM,cAAc,GAAG,IAAA,0BAAc,EAAC;QACpC,GAAG,MAAM,CAAC,IAAI;QACd,MAAM,EAAE,GAAG;KACZ,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG,IAAA,wBAAa,EAAC;QAClC,GAAG,MAAM,CAAC,GAAG;QACb,MAAM,EAAE,GAAG;KACZ,CAAC,CAAC;IAEH,OAAO,KAAK,EACV,GAAoB,EACpB,GAAmB,EACnB,IAAyB,EACzB,EAAE;QACF,4CAA4C;QAC5C,MAAM,OAAO,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;QACzE,MAAM,OAAO,GAAG,CAAC,CAAC,CAChB,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC;YAC3B,GAAG,CAAC,OAAO,CAAC,eAAe,CAAY,CAAC,UAAU,CAAC,UAAU,CAAC,CAChE,CAAC;QAEF,IAAI,OAAO,EAAE,CAAC;YACZ,GAAG,CAAC,6DAA6D,CAAC,CAAC;YACnE,OAAO,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACxC,CAAC;QAED,IAAI,OAAO,EAAE,CAAC;YACZ,GAAG,CAAC,yEAAyE,CAAC,CAAC;YAC/E,OAAO,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACvC,CAAC;QAED,yDAAyD;QACzD,GAAG,CAAC,mEAAmE,CAAC,CAAC;QAEzE,6BAA6B;QAC7B,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,IAAI,SAAS,CAAC;QACjD,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,IAAI,KAAK,CAAC;QACjD,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,CAAC;QAC7C,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,IAAI,MAAM,CAAC;QAEzC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,GAAG,EAAE,OAAO,CAAC;QAC5C,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;QAE3D,MAAM,UAAU,GAAG;YACjB,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM;YACzB,QAAQ,EAAE,WAAW;YACrB,QAAQ,EAAE,WAAW;YACrB,SAAS,EAAE,MAAM,CAAC,GAAG,CAAC,SAAS;SAChC,CAAC;QAEF,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;aAC3D,QAAQ,CAAC,QAAQ,CAAC;aAClB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;aACnB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;aACnB,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEtB,MAAM,OAAO,GAAG,eAAe,WAAW,YAAY,MAAM,CAAC,GAAG,CAAC,KAAK,aAAa,MAAM,CAAC,GAAG,CAAC,MAAM,aAAa,SAAS,cAAc,cAAc,cAAc,OAAO,GAAG,CAAC;QAE/K,4BAA4B;QAC5B,MAAM,QAAQ,GAAG;YACf,WAAW,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC;YACzC,QAAQ,EAAE;gBACR,GAAG,EAAE,GAAG,CAAC,GAAG,IAAI,GAAG;gBACnB,WAAW,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW,IAAI,kBAAkB;gBAC1D,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;aACvE;YACD,OAAO,EAAE;gBACP;oBACE,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,IAAI,OAAO;oBACrC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO;oBAC5B,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM;oBAC1B,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK;oBACxB,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK;iBACzB;aACF;SACF,CAAC;QAEF,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE;YACjB,kBAAkB,EAAE,OAAO;YAC3B,cAAc,EAAE,kBAAkB;SACnC,CAAC,CAAC;QACH,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;IACpC,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* MPP Payment-Receipt builder.
|
|
4
|
+
*
|
|
5
|
+
* Generates base64url-encoded receipt JSON that can be attached
|
|
6
|
+
* as a `Payment-Receipt` response header after successful payment verification.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.buildReceipt = buildReceipt;
|
|
10
|
+
exports.parseReceipt = parseReceipt;
|
|
11
|
+
/**
|
|
12
|
+
* Build a Payment-Receipt header value.
|
|
13
|
+
*
|
|
14
|
+
* @returns base64url-encoded JSON receipt.
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```ts
|
|
18
|
+
* const receipt = buildReceipt({
|
|
19
|
+
* challengeId: 'ch_123',
|
|
20
|
+
* status: 'settled',
|
|
21
|
+
* amount: '500000',
|
|
22
|
+
* asset: 'USDC',
|
|
23
|
+
* transactionHash: '0xabc...',
|
|
24
|
+
* });
|
|
25
|
+
*
|
|
26
|
+
* res.setHeader('Payment-Receipt', receipt);
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
function buildReceipt(options) {
|
|
30
|
+
const receipt = {
|
|
31
|
+
challengeId: options.challengeId,
|
|
32
|
+
status: options.status,
|
|
33
|
+
amount: options.amount,
|
|
34
|
+
asset: options.asset,
|
|
35
|
+
...(options.transactionHash ? { transactionHash: options.transactionHash } : {}),
|
|
36
|
+
issuedAt: (options.timestamp ?? new Date()).toISOString(),
|
|
37
|
+
};
|
|
38
|
+
return Buffer.from(JSON.stringify(receipt))
|
|
39
|
+
.toString('base64')
|
|
40
|
+
.replace(/\+/g, '-')
|
|
41
|
+
.replace(/\//g, '_')
|
|
42
|
+
.replace(/=+$/, '');
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Parse a Payment-Receipt header value back into a receipt object.
|
|
46
|
+
*/
|
|
47
|
+
function parseReceipt(encoded) {
|
|
48
|
+
const padded = encoded.replace(/-/g, '+').replace(/_/g, '/');
|
|
49
|
+
const decoded = Buffer.from(padded, 'base64').toString('utf-8');
|
|
50
|
+
return JSON.parse(decoded);
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=receipt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"receipt.js","sourceRoot":"","sources":["../../../src/server/receipt.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;AA4CH,oCAeC;AAKD,oCAIC;AA1CD;;;;;;;;;;;;;;;;;GAiBG;AACH,SAAgB,YAAY,CAAC,OAAuB;IAClD,MAAM,OAAO,GAAmB;QAC9B,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,OAAO,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAChF,QAAQ,EAAE,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE;KAC1D,CAAC;IAEF,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;SACxC,QAAQ,CAAC,QAAQ,CAAC;SAClB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;SACnB,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;AACxB,CAAC;AAED;;GAEG;AACH,SAAgB,YAAY,CAAC,OAAe;IAC1C,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAC7D,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAChE,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;AAC7B,CAAC"}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createWebhookHandler = createWebhookHandler;
|
|
4
|
+
const logger_1 = require("../logger");
|
|
5
|
+
/**
|
|
6
|
+
* Creates a Connect/Express-compatible webhook handler for Stripe events.
|
|
7
|
+
*
|
|
8
|
+
* Uses HMAC signature verification via the raw request body.
|
|
9
|
+
* Supports idempotency guard to prevent duplicate processing.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```ts
|
|
13
|
+
* const handler = createWebhookHandler({
|
|
14
|
+
* signingSecret: process.env.STRIPE_WEBHOOK_SECRET!,
|
|
15
|
+
* onPaymentSuccess: (event) => {
|
|
16
|
+
* console.log(`Payment received: ${event.amount} ${event.currency}`);
|
|
17
|
+
* },
|
|
18
|
+
* });
|
|
19
|
+
*
|
|
20
|
+
* app.post('/webhook', express.raw({ type: 'application/json' }), handler);
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
function createWebhookHandler(config) {
|
|
24
|
+
const log = config.logger ?? logger_1.noopLogger;
|
|
25
|
+
const processedIds = config.processedEventIds ?? new Set();
|
|
26
|
+
return async (req, res, _next) => {
|
|
27
|
+
const sig = req.headers['stripe-signature'];
|
|
28
|
+
if (!sig) {
|
|
29
|
+
log('[webhook] ❌ Missing stripe-signature header');
|
|
30
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
31
|
+
res.end(JSON.stringify({ error: 'Missing stripe-signature header' }));
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
// Get raw body
|
|
35
|
+
const rawBody = typeof req.body === 'string'
|
|
36
|
+
? req.body
|
|
37
|
+
: req.body instanceof Buffer
|
|
38
|
+
? req.body.toString('utf-8')
|
|
39
|
+
: JSON.stringify(req.body);
|
|
40
|
+
// Verify HMAC signature (simplified — in production use stripe.webhooks.constructEvent)
|
|
41
|
+
if (!verifySignature(rawBody, sig, config.signingSecret)) {
|
|
42
|
+
log('[webhook] ❌ Invalid signature');
|
|
43
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
44
|
+
res.end(JSON.stringify({ error: 'Invalid webhook signature' }));
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
let event;
|
|
48
|
+
try {
|
|
49
|
+
event = typeof req.body === 'string' ? JSON.parse(req.body) : req.body;
|
|
50
|
+
}
|
|
51
|
+
catch {
|
|
52
|
+
log('[webhook] ❌ Failed to parse event body');
|
|
53
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
54
|
+
res.end(JSON.stringify({ error: 'Invalid JSON body' }));
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
// Idempotency guard
|
|
58
|
+
if (processedIds.has(event.id)) {
|
|
59
|
+
log(`[webhook] ⏭️ Duplicate event: ${event.id}`);
|
|
60
|
+
res.writeHead(200, { 'Content-Type': 'application/json' });
|
|
61
|
+
res.end(JSON.stringify({ received: true, duplicate: true }));
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
processedIds.add(event.id);
|
|
65
|
+
// Route based on event type
|
|
66
|
+
const webhookEvent = {
|
|
67
|
+
id: event.id,
|
|
68
|
+
type: event.type,
|
|
69
|
+
amount: event.data?.object?.amount,
|
|
70
|
+
currency: event.data?.object?.currency,
|
|
71
|
+
paymentIntentId: event.data?.object?.id,
|
|
72
|
+
metadata: event.data?.object?.metadata,
|
|
73
|
+
timestamp: new Date(),
|
|
74
|
+
};
|
|
75
|
+
try {
|
|
76
|
+
if (event.type === 'payment_intent.succeeded' && config.onPaymentSuccess) {
|
|
77
|
+
log(`[webhook] ✅ Payment succeeded: ${webhookEvent.paymentIntentId}`);
|
|
78
|
+
await config.onPaymentSuccess(webhookEvent);
|
|
79
|
+
}
|
|
80
|
+
else if (event.type === 'payment_intent.payment_failed' && config.onPaymentFailure) {
|
|
81
|
+
log(`[webhook] ❌ Payment failed: ${webhookEvent.paymentIntentId}`);
|
|
82
|
+
await config.onPaymentFailure(webhookEvent);
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
log(`[webhook] 📋 Unhandled event type: ${event.type}`);
|
|
86
|
+
}
|
|
87
|
+
res.writeHead(200, { 'Content-Type': 'application/json' });
|
|
88
|
+
res.end(JSON.stringify({ received: true }));
|
|
89
|
+
}
|
|
90
|
+
catch (err) {
|
|
91
|
+
log(`[webhook] ❌ Handler error: ${err.message}`);
|
|
92
|
+
res.writeHead(500, { 'Content-Type': 'application/json' });
|
|
93
|
+
res.end(JSON.stringify({ error: 'Webhook handler error' }));
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Simplified HMAC verification for webhook signatures.
|
|
99
|
+
* In production, use Stripe's official `stripe.webhooks.constructEvent()`.
|
|
100
|
+
*/
|
|
101
|
+
function verifySignature(payload, sig, secret) {
|
|
102
|
+
try {
|
|
103
|
+
// Parse Stripe signature header format: t=timestamp,v1=hash
|
|
104
|
+
const parts = sig.split(',');
|
|
105
|
+
const timestamp = parts.find((p) => p.startsWith('t='))?.slice(2);
|
|
106
|
+
const hash = parts.find((p) => p.startsWith('v1='))?.slice(3);
|
|
107
|
+
if (!timestamp || !hash)
|
|
108
|
+
return false;
|
|
109
|
+
// In production: compute HMAC-SHA256 of `${timestamp}.${payload}` with secret
|
|
110
|
+
// For SDK purposes, we trust the Stripe library to do this
|
|
111
|
+
const crypto = require('crypto');
|
|
112
|
+
const expected = crypto
|
|
113
|
+
.createHmac('sha256', secret)
|
|
114
|
+
.update(`${timestamp}.${payload}`)
|
|
115
|
+
.digest('hex');
|
|
116
|
+
return crypto.timingSafeEqual(Buffer.from(hash, 'hex'), Buffer.from(expected, 'hex'));
|
|
117
|
+
}
|
|
118
|
+
catch {
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=webhook.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webhook.js","sourceRoot":"","sources":["../../../src/server/webhook.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createX402Gate = createX402Gate;
|
|
4
|
+
const logger_1 = require("../logger");
|
|
5
|
+
/**
|
|
6
|
+
* Creates an Express/Connect middleware that gates access behind x402 payments.
|
|
7
|
+
*
|
|
8
|
+
* When a request lacks a valid `X-PAYMENT` header, the middleware responds with
|
|
9
|
+
* 402 Payment Required and an x402-compliant JSON challenge body.
|
|
10
|
+
*
|
|
11
|
+
* When a valid `X-PAYMENT` header is present, it's decoded and optionally
|
|
12
|
+
* verified before calling `next()`.
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```ts
|
|
16
|
+
* app.post('/api/premium', createX402Gate({
|
|
17
|
+
* payTo: '0xABC...',
|
|
18
|
+
* amount: '500000',
|
|
19
|
+
* asset: 'USDC',
|
|
20
|
+
* network: 'eip155:8453',
|
|
21
|
+
* }), handler);
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
function createX402Gate(config) {
|
|
25
|
+
const log = config.logger ?? logger_1.noopLogger;
|
|
26
|
+
const version = config.x402Version ?? 2;
|
|
27
|
+
const scheme = config.scheme ?? 'exact';
|
|
28
|
+
return async (req, res, next) => {
|
|
29
|
+
// Check for existing X-PAYMENT header
|
|
30
|
+
const paymentHeader = req.headers['x-payment'] ||
|
|
31
|
+
req.headers['X-PAYMENT'];
|
|
32
|
+
if (!paymentHeader) {
|
|
33
|
+
// No payment proof — return 402 challenge
|
|
34
|
+
log('[x402-gate] 💰 No X-PAYMENT header — returning 402 challenge');
|
|
35
|
+
const challenge = {
|
|
36
|
+
x402Version: version,
|
|
37
|
+
resource: {
|
|
38
|
+
url: req.url || '/',
|
|
39
|
+
description: config.description || 'Payment required',
|
|
40
|
+
...(config.usdAmount ? { usdAmount: config.usdAmount } : {}),
|
|
41
|
+
},
|
|
42
|
+
accepts: [
|
|
43
|
+
{
|
|
44
|
+
scheme,
|
|
45
|
+
network: config.network,
|
|
46
|
+
amount: config.amount,
|
|
47
|
+
payTo: config.payTo,
|
|
48
|
+
asset: config.asset,
|
|
49
|
+
},
|
|
50
|
+
],
|
|
51
|
+
};
|
|
52
|
+
res.writeHead(402, { 'Content-Type': 'application/json' });
|
|
53
|
+
res.end(JSON.stringify(challenge));
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
// Decode X-PAYMENT proof
|
|
57
|
+
try {
|
|
58
|
+
const decoded = Buffer.from(paymentHeader, 'base64').toString('utf-8');
|
|
59
|
+
const proof = JSON.parse(decoded);
|
|
60
|
+
// Basic validation
|
|
61
|
+
if (!proof.payload?.transaction) {
|
|
62
|
+
log('[x402-gate] ❌ Missing transaction in payment proof');
|
|
63
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
64
|
+
res.end(JSON.stringify({ error: 'Invalid payment proof: missing transaction' }));
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
// Verify payment destination matches
|
|
68
|
+
if (proof.accepted?.payTo && proof.accepted.payTo !== config.payTo) {
|
|
69
|
+
log('[x402-gate] ❌ Payment destination mismatch');
|
|
70
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
71
|
+
res.end(JSON.stringify({ error: 'Payment destination mismatch' }));
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
// Verify amount matches
|
|
75
|
+
if (proof.accepted?.amount && proof.accepted.amount !== config.amount) {
|
|
76
|
+
log('[x402-gate] ❌ Payment amount mismatch');
|
|
77
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
78
|
+
res.end(JSON.stringify({ error: 'Payment amount mismatch' }));
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
// Custom verification (if provided)
|
|
82
|
+
if (config.verifyPayment) {
|
|
83
|
+
const isValid = await config.verifyPayment(proof);
|
|
84
|
+
if (!isValid) {
|
|
85
|
+
log('[x402-gate] ❌ Custom verification failed');
|
|
86
|
+
res.writeHead(402, { 'Content-Type': 'application/json' });
|
|
87
|
+
res.end(JSON.stringify({ error: 'Payment verification failed' }));
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
// Attach proof to request for downstream handlers
|
|
92
|
+
req.payment = proof;
|
|
93
|
+
log(`[x402-gate] ✅ Payment verified: tx=${proof.payload.transaction.slice(0, 16)}…`);
|
|
94
|
+
next();
|
|
95
|
+
}
|
|
96
|
+
catch (err) {
|
|
97
|
+
log(`[x402-gate] ❌ Failed to decode payment proof: ${err.message}`);
|
|
98
|
+
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
99
|
+
res.end(JSON.stringify({ error: 'Invalid X-PAYMENT header' }));
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=x402-gate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"x402-gate.js","sourceRoot":"","sources":["../../../src/server/x402-gate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildSolanaPayUri = exports.createSolanaWatcher = exports.SolanaPaymentAdapter = void 0;
|
|
4
|
+
// envoy-pay/solana — opt-in Solana rail.
|
|
5
|
+
//
|
|
6
|
+
// Pulls in @solana/web3.js + @solana/spl-token (declared as optional peer deps),
|
|
7
|
+
// so it only loads when you import this subpath — the Celo core stays light.
|
|
8
|
+
var solana_1 = require("./adapters/solana");
|
|
9
|
+
Object.defineProperty(exports, "SolanaPaymentAdapter", { enumerable: true, get: function () { return solana_1.SolanaPaymentAdapter; } });
|
|
10
|
+
var solana_watcher_1 = require("./monitor/solana-watcher");
|
|
11
|
+
Object.defineProperty(exports, "createSolanaWatcher", { enumerable: true, get: function () { return solana_watcher_1.createSolanaWatcher; } });
|
|
12
|
+
var solana_pay_1 = require("./requests/solana-pay");
|
|
13
|
+
Object.defineProperty(exports, "buildSolanaPayUri", { enumerable: true, get: function () { return solana_pay_1.buildSolanaPayUri; } });
|
|
14
|
+
//# sourceMappingURL=solana.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"solana.js","sourceRoot":"","sources":["../../src/solana.ts"],"names":[],"mappings":";;;AAAA,yCAAyC;AACzC,EAAE;AACF,iFAAiF;AACjF,6EAA6E;AAC7E,4CAAyD;AAAhD,8GAAA,oBAAoB,OAAA;AAE7B,2DAA+D;AAAtD,qHAAA,mBAAmB,OAAA;AAE5B,oDAA0D;AAAjD,+GAAA,iBAAiB,OAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildSep7Uri = exports.createStellarWatcher = exports.StellarPaymentAdapter = void 0;
|
|
4
|
+
// envoy-pay/stellar — opt-in Stellar rail.
|
|
5
|
+
//
|
|
6
|
+
// Pulls in @stellar/stellar-sdk (declared as an optional peer dep), so it only
|
|
7
|
+
// loads when you import this subpath — the Celo core stays light.
|
|
8
|
+
var stellar_1 = require("./adapters/stellar");
|
|
9
|
+
Object.defineProperty(exports, "StellarPaymentAdapter", { enumerable: true, get: function () { return stellar_1.StellarPaymentAdapter; } });
|
|
10
|
+
var stellar_watcher_1 = require("./monitor/stellar-watcher");
|
|
11
|
+
Object.defineProperty(exports, "createStellarWatcher", { enumerable: true, get: function () { return stellar_watcher_1.createStellarWatcher; } });
|
|
12
|
+
var sep7_1 = require("./requests/sep7");
|
|
13
|
+
Object.defineProperty(exports, "buildSep7Uri", { enumerable: true, get: function () { return sep7_1.buildSep7Uri; } });
|
|
14
|
+
//# sourceMappingURL=stellar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stellar.js","sourceRoot":"","sources":["../../src/stellar.ts"],"names":[],"mappings":";;;AAAA,2CAA2C;AAC3C,EAAE;AACF,+EAA+E;AAC/E,kEAAkE;AAClE,8CAA2D;AAAlD,gHAAA,qBAAqB,OAAA;AAE9B,6DAAiE;AAAxD,uHAAA,oBAAoB,OAAA;AAE7B,wCAA+C;AAAtC,oGAAA,YAAY,OAAA"}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* BalanceAggregator — Multi-chain balance aggregation.
|
|
4
|
+
*
|
|
5
|
+
* Queries all registered adapters in parallel to produce a unified
|
|
6
|
+
* balance snapshot. Handles adapters that don't implement `getBalance()`
|
|
7
|
+
* gracefully (returns 0).
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```ts
|
|
11
|
+
* const aggregator = new BalanceAggregator(adapters);
|
|
12
|
+
* const balance = await aggregator.getUnifiedBalance();
|
|
13
|
+
* console.log(balance.totalFormatted); // "$400.00"
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.BalanceAggregator = void 0;
|
|
18
|
+
/**
|
|
19
|
+
* Known stablecoin tickers treated as 1:1 USD.
|
|
20
|
+
* All others use best-effort conversion.
|
|
21
|
+
*/
|
|
22
|
+
const STABLECOIN_TICKERS = new Set([
|
|
23
|
+
'USDC', 'USDT', 'DAI', 'BUSD', 'TUSD', 'FRAX', 'PYUSD', 'USD',
|
|
24
|
+
]);
|
|
25
|
+
/**
|
|
26
|
+
* Rough USD conversion rates for non-stablecoin assets.
|
|
27
|
+
* Used only when precise oracle data is unavailable.
|
|
28
|
+
*/
|
|
29
|
+
const FALLBACK_RATES = {
|
|
30
|
+
ETH: 3200,
|
|
31
|
+
XLM: 0.12,
|
|
32
|
+
SOL: 170,
|
|
33
|
+
BTC: 95000,
|
|
34
|
+
MATIC: 0.55,
|
|
35
|
+
AVAX: 35,
|
|
36
|
+
ARB: 1.1,
|
|
37
|
+
OP: 2.5,
|
|
38
|
+
};
|
|
39
|
+
class BalanceAggregator {
|
|
40
|
+
adapters;
|
|
41
|
+
constructor(adapters) {
|
|
42
|
+
this.adapters = adapters;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Query all adapters and return a unified balance snapshot.
|
|
46
|
+
* Adapters without `getBalance()` report $0.
|
|
47
|
+
*/
|
|
48
|
+
async getUnifiedBalance() {
|
|
49
|
+
const results = await Promise.allSettled(this.adapters.map((adapter, index) => this.queryAdapter(adapter, index)));
|
|
50
|
+
const breakdown = [];
|
|
51
|
+
for (const result of results) {
|
|
52
|
+
if (result.status === 'fulfilled') {
|
|
53
|
+
breakdown.push(result.value);
|
|
54
|
+
}
|
|
55
|
+
// Silently skip failed adapters — fail-open for balance reads
|
|
56
|
+
}
|
|
57
|
+
const totalUsd = breakdown.reduce((sum, b) => sum + b.balanceUsd, 0);
|
|
58
|
+
return {
|
|
59
|
+
totalUsd,
|
|
60
|
+
totalFormatted: `$${totalUsd.toFixed(2)}`,
|
|
61
|
+
breakdown,
|
|
62
|
+
timestamp: new Date(),
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Get the balance for a specific chain by CAIP-2 ID.
|
|
67
|
+
*/
|
|
68
|
+
async getChainBalance(caip2Id) {
|
|
69
|
+
const index = this.adapters.findIndex((a) => a.caip2Id === caip2Id);
|
|
70
|
+
if (index === -1)
|
|
71
|
+
return null;
|
|
72
|
+
return this.queryAdapter(this.adapters[index], index);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Find the adapter with the highest USD balance.
|
|
76
|
+
*/
|
|
77
|
+
async getRichestChain() {
|
|
78
|
+
const unified = await this.getUnifiedBalance();
|
|
79
|
+
if (unified.breakdown.length === 0)
|
|
80
|
+
return null;
|
|
81
|
+
return unified.breakdown.reduce((richest, current) => current.balanceUsd > richest.balanceUsd ? current : richest);
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Check if sufficient funds exist across all chains.
|
|
85
|
+
*/
|
|
86
|
+
async hasSufficientFunds(amountUsd) {
|
|
87
|
+
const unified = await this.getUnifiedBalance();
|
|
88
|
+
return unified.totalUsd >= amountUsd;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Find all chains that can cover a given USD amount.
|
|
92
|
+
*/
|
|
93
|
+
async getChainsWithSufficientFunds(amountUsd) {
|
|
94
|
+
const unified = await this.getUnifiedBalance();
|
|
95
|
+
return unified.breakdown.filter((b) => b.balanceUsd >= amountUsd);
|
|
96
|
+
}
|
|
97
|
+
// ─── Internal ──────────────────────────────────────────────────────
|
|
98
|
+
async queryAdapter(adapter, index) {
|
|
99
|
+
let balance = '0';
|
|
100
|
+
let asset = 'USDC'; // default assumption
|
|
101
|
+
if (adapter.getBalance) {
|
|
102
|
+
try {
|
|
103
|
+
balance = await adapter.getBalance();
|
|
104
|
+
}
|
|
105
|
+
catch {
|
|
106
|
+
balance = '0';
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
// Detect asset from chain name heuristics
|
|
110
|
+
asset = this.detectPrimaryAsset(adapter.chainName);
|
|
111
|
+
const balanceNum = parseFloat(balance) || 0;
|
|
112
|
+
const balanceUsd = this.toUsd(balanceNum, asset);
|
|
113
|
+
return {
|
|
114
|
+
chain: adapter.chainName,
|
|
115
|
+
caip2Id: adapter.caip2Id,
|
|
116
|
+
balance: balanceNum.toFixed(2),
|
|
117
|
+
balanceUsd,
|
|
118
|
+
asset,
|
|
119
|
+
adapterIndex: index,
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Convert an asset amount to USD using stablecoin 1:1 or fallback rates.
|
|
124
|
+
*/
|
|
125
|
+
toUsd(amount, asset) {
|
|
126
|
+
if (STABLECOIN_TICKERS.has(asset.toUpperCase())) {
|
|
127
|
+
return amount;
|
|
128
|
+
}
|
|
129
|
+
const rate = FALLBACK_RATES[asset.toUpperCase()] ?? 1;
|
|
130
|
+
return amount * rate;
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Best-effort detection of the primary asset for a chain.
|
|
134
|
+
*/
|
|
135
|
+
detectPrimaryAsset(chainName) {
|
|
136
|
+
const lower = chainName.toLowerCase();
|
|
137
|
+
if (lower.includes('stripe') || lower.includes('fiat'))
|
|
138
|
+
return 'USD';
|
|
139
|
+
if (lower.includes('stellar'))
|
|
140
|
+
return 'USDC'; // Stellar USDC
|
|
141
|
+
if (lower.includes('solana'))
|
|
142
|
+
return 'USDC'; // SPL USDC
|
|
143
|
+
if (lower.includes('bitcoin'))
|
|
144
|
+
return 'BTC';
|
|
145
|
+
return 'USDC'; // Default for EVM chains (Base, Arb, etc.)
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
exports.BalanceAggregator = BalanceAggregator;
|
|
149
|
+
//# sourceMappingURL=balance-aggregator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"balance-aggregator.js","sourceRoot":"","sources":["../../../src/wallet/balance-aggregator.ts"],"names":[],"mappings":"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"}
|