mppx 0.6.31 → 0.8.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 +50 -0
- package/README.md +20 -11
- package/dist/Challenge.d.ts.map +1 -1
- package/dist/Challenge.js +27 -13
- package/dist/Challenge.js.map +1 -1
- package/dist/Constants.d.ts +46 -0
- package/dist/Constants.d.ts.map +1 -0
- package/dist/Constants.js +46 -0
- package/dist/Constants.js.map +1 -0
- package/dist/Credential.d.ts.map +1 -1
- package/dist/Credential.js +5 -4
- package/dist/Credential.js.map +1 -1
- package/dist/Mcp.d.ts +3 -0
- package/dist/Mcp.d.ts.map +1 -1
- package/dist/Mcp.js +2 -0
- package/dist/Mcp.js.map +1 -1
- package/dist/Method.d.ts +32 -4
- package/dist/Method.d.ts.map +1 -1
- package/dist/Method.js +5 -2
- package/dist/Method.js.map +1 -1
- package/dist/PaymentRequest.d.ts +10 -10
- package/dist/PaymentRequest.js +8 -8
- package/dist/Receipt.d.ts.map +1 -1
- package/dist/Receipt.js +3 -2
- package/dist/Receipt.js.map +1 -1
- package/dist/cli/cli.d.ts.map +1 -1
- package/dist/cli/cli.js +19 -11
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/plugins/tempo.d.ts.map +1 -1
- package/dist/cli/plugins/tempo.js +17 -6
- package/dist/cli/plugins/tempo.js.map +1 -1
- package/dist/cli/utils.d.ts +5 -0
- package/dist/cli/utils.d.ts.map +1 -1
- package/dist/cli/utils.js +10 -0
- package/dist/cli/utils.js.map +1 -1
- package/dist/client/Methods.d.ts +5 -2
- package/dist/client/Methods.d.ts.map +1 -1
- package/dist/client/Methods.js +5 -2
- package/dist/client/Methods.js.map +1 -1
- package/dist/client/Mppx.js +2 -2
- package/dist/client/Mppx.js.map +1 -1
- package/dist/client/Transport.d.ts +11 -16
- package/dist/client/Transport.d.ts.map +1 -1
- package/dist/client/Transport.js +55 -76
- package/dist/client/Transport.js.map +1 -1
- package/dist/client/index.d.ts +5 -1
- package/dist/client/index.d.ts.map +1 -1
- package/dist/client/index.js +3 -1
- package/dist/client/index.js.map +1 -1
- package/dist/client/internal/Fetch.d.ts.map +1 -1
- package/dist/client/internal/Fetch.js +60 -13
- package/dist/client/internal/Fetch.js.map +1 -1
- package/dist/client/internal/protocols/Mcp.d.ts +7 -0
- package/dist/client/internal/protocols/Mcp.d.ts.map +1 -0
- package/dist/client/internal/protocols/Mcp.js +159 -0
- package/dist/client/internal/protocols/Mcp.js.map +1 -0
- package/dist/client/internal/protocols/Mpp.d.ts +4 -0
- package/dist/client/internal/protocols/Mpp.d.ts.map +1 -0
- package/dist/client/internal/protocols/Mpp.js +18 -0
- package/dist/client/internal/protocols/Mpp.js.map +1 -0
- package/dist/client/internal/protocols/Protocol.d.ts +10 -0
- package/dist/client/internal/protocols/Protocol.d.ts.map +1 -0
- package/dist/client/internal/protocols/Protocol.js +2 -0
- package/dist/client/internal/protocols/Protocol.js.map +1 -0
- package/dist/client/internal/protocols/Shared.d.ts +5 -0
- package/dist/client/internal/protocols/Shared.d.ts.map +1 -0
- package/dist/client/internal/protocols/Shared.js +20 -0
- package/dist/client/internal/protocols/Shared.js.map +1 -0
- package/dist/client/internal/protocols/X402.d.ts +8 -0
- package/dist/client/internal/protocols/X402.d.ts.map +1 -0
- package/dist/client/internal/protocols/X402.js +39 -0
- package/dist/client/internal/protocols/X402.js.map +1 -0
- package/dist/evm/client/index.d.ts +1 -0
- package/dist/evm/client/index.d.ts.map +1 -1
- package/dist/evm/client/index.js +1 -0
- package/dist/evm/client/index.js.map +1 -1
- package/dist/evm/index.d.ts +2 -0
- package/dist/evm/index.d.ts.map +1 -1
- package/dist/evm/index.js +2 -0
- package/dist/evm/index.js.map +1 -1
- package/dist/evm/server/Methods.d.ts +1 -1
- package/dist/evm/server/Methods.d.ts.map +1 -1
- package/dist/evm/server/index.d.ts +1 -0
- package/dist/evm/server/index.d.ts.map +1 -1
- package/dist/evm/server/index.js +1 -0
- package/dist/evm/server/index.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/internal/AcceptPayment.d.ts +3 -0
- package/dist/internal/AcceptPayment.d.ts.map +1 -1
- package/dist/internal/AcceptPayment.js +15 -11
- package/dist/internal/AcceptPayment.js.map +1 -1
- package/dist/mcp/client/McpClient.d.ts +101 -0
- package/dist/mcp/client/McpClient.d.ts.map +1 -0
- package/dist/mcp/client/McpClient.js +162 -0
- package/dist/mcp/client/McpClient.js.map +1 -0
- package/dist/mcp/client/index.d.ts.map +1 -0
- package/dist/mcp/client/index.js.map +1 -0
- package/dist/mcp/server/Transport.d.ts.map +1 -0
- package/dist/mcp/server/Transport.js.map +1 -0
- package/dist/mcp/server/index.d.ts.map +1 -0
- package/dist/mcp/server/index.js.map +1 -0
- package/dist/server/Mppx.d.ts +12 -4
- package/dist/server/Mppx.d.ts.map +1 -1
- package/dist/server/Mppx.js +85 -27
- package/dist/server/Mppx.js.map +1 -1
- package/dist/server/Response.d.ts.map +1 -1
- package/dist/server/Response.js +2 -1
- package/dist/server/Response.js.map +1 -1
- package/dist/server/Transport.d.ts +1 -1
- package/dist/server/Transport.d.ts.map +1 -1
- package/dist/server/Transport.js +5 -4
- package/dist/server/Transport.js.map +1 -1
- package/dist/server/index.d.ts +1 -0
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +1 -0
- package/dist/server/index.js.map +1 -1
- package/dist/stripe/client/Charge.d.ts +1 -1
- package/dist/stripe/client/Charge.d.ts.map +1 -1
- package/dist/stripe/client/Charge.js +3 -1
- package/dist/stripe/client/Charge.js.map +1 -1
- package/dist/stripe/server/Charge.d.ts +1 -1
- package/dist/stripe/server/Charge.d.ts.map +1 -1
- package/dist/stripe/server/Charge.js +9 -2
- package/dist/stripe/server/Charge.js.map +1 -1
- package/dist/stripe/server/Methods.d.ts +1 -1
- package/dist/stripe/server/Methods.d.ts.map +1 -1
- package/dist/stripe/server/internal/html.gen.d.ts +1 -1
- package/dist/stripe/server/internal/html.gen.d.ts.map +1 -1
- package/dist/stripe/server/internal/html.gen.js +1 -1
- package/dist/stripe/server/internal/html.gen.js.map +1 -1
- package/dist/tempo/Methods.d.ts +18 -0
- package/dist/tempo/Methods.d.ts.map +1 -1
- package/dist/tempo/Methods.js +16 -1
- package/dist/tempo/Methods.js.map +1 -1
- package/dist/tempo/Proof.d.ts +85 -1
- package/dist/tempo/Proof.d.ts.map +1 -1
- package/dist/tempo/Proof.js +35 -0
- package/dist/tempo/Proof.js.map +1 -1
- package/dist/tempo/client/Charge.d.ts +19 -1
- package/dist/tempo/client/Charge.d.ts.map +1 -1
- package/dist/tempo/client/Charge.js +47 -27
- package/dist/tempo/client/Charge.js.map +1 -1
- package/dist/tempo/client/Methods.d.ts +41 -10
- package/dist/tempo/client/Methods.d.ts.map +1 -1
- package/dist/tempo/client/Methods.js +16 -7
- package/dist/tempo/client/Methods.js.map +1 -1
- package/dist/tempo/client/ResolveAccount.d.ts +40 -0
- package/dist/tempo/client/ResolveAccount.d.ts.map +1 -0
- package/dist/tempo/client/ResolveAccount.js +2 -0
- package/dist/tempo/client/ResolveAccount.js.map +1 -0
- package/dist/tempo/client/index.d.ts +7 -4
- package/dist/tempo/client/index.d.ts.map +1 -1
- package/dist/tempo/client/index.js +5 -3
- package/dist/tempo/client/index.js.map +1 -1
- package/dist/tempo/index.d.ts +1 -0
- package/dist/tempo/index.d.ts.map +1 -1
- package/dist/tempo/index.js +1 -0
- package/dist/tempo/index.js.map +1 -1
- package/dist/tempo/internal/fee-payer.d.ts +29 -1
- package/dist/tempo/internal/fee-payer.d.ts.map +1 -1
- package/dist/tempo/internal/fee-payer.js +138 -4
- package/dist/tempo/internal/fee-payer.js.map +1 -1
- package/dist/tempo/internal/proof.d.ts +71 -5
- package/dist/tempo/internal/proof.d.ts.map +1 -1
- package/dist/tempo/internal/proof.js +42 -6
- package/dist/tempo/internal/proof.js.map +1 -1
- package/dist/tempo/{client → legacy/client}/ChannelOps.d.ts +19 -6
- package/dist/tempo/legacy/client/ChannelOps.d.ts.map +1 -0
- package/dist/tempo/{client → legacy/client}/ChannelOps.js +9 -3
- package/dist/tempo/legacy/client/ChannelOps.js.map +1 -0
- package/dist/tempo/{client → legacy/client}/Session.d.ts +23 -4
- package/dist/tempo/legacy/client/Session.d.ts.map +1 -0
- package/dist/tempo/{client → legacy/client}/Session.js +14 -7
- package/dist/tempo/legacy/client/Session.js.map +1 -0
- package/dist/tempo/{client → legacy/client}/SessionManager.d.ts +20 -5
- package/dist/tempo/legacy/client/SessionManager.d.ts.map +1 -0
- package/dist/tempo/{client → legacy/client}/SessionManager.js +30 -19
- package/dist/tempo/legacy/client/SessionManager.js.map +1 -0
- package/dist/tempo/legacy/client/index.d.ts +7 -0
- package/dist/tempo/legacy/client/index.d.ts.map +1 -0
- package/dist/tempo/legacy/client/index.js +5 -0
- package/dist/tempo/legacy/client/index.js.map +1 -0
- package/dist/tempo/legacy/index.d.ts +7 -0
- package/dist/tempo/legacy/index.d.ts.map +1 -0
- package/dist/tempo/legacy/index.js +7 -0
- package/dist/tempo/legacy/index.js.map +1 -0
- package/dist/tempo/{server → legacy/server}/Session.d.ts +28 -11
- package/dist/tempo/legacy/server/Session.d.ts.map +1 -0
- package/dist/tempo/{server → legacy/server}/Session.js +12 -10
- package/dist/tempo/legacy/server/Session.js.map +1 -0
- package/dist/tempo/legacy/server/index.d.ts +5 -0
- package/dist/tempo/legacy/server/index.d.ts.map +1 -0
- package/dist/tempo/legacy/server/index.js +5 -0
- package/dist/tempo/legacy/server/index.js.map +1 -0
- package/dist/tempo/{session → legacy/session}/Chain.d.ts +30 -23
- package/dist/tempo/legacy/session/Chain.d.ts.map +1 -0
- package/dist/tempo/{session → legacy/session}/Chain.js +12 -11
- package/dist/tempo/legacy/session/Chain.js.map +1 -0
- package/dist/tempo/{session → legacy/session}/Channel.d.ts +1 -0
- package/dist/tempo/legacy/session/Channel.d.ts.map +1 -0
- package/dist/tempo/legacy/session/Channel.js.map +1 -0
- package/dist/tempo/legacy/session/ChannelStore.d.ts +22 -0
- package/dist/tempo/legacy/session/ChannelStore.d.ts.map +1 -0
- package/dist/tempo/legacy/session/ChannelStore.js +6 -0
- package/dist/tempo/legacy/session/ChannelStore.js.map +1 -0
- package/dist/tempo/legacy/session/Types.d.ts +73 -0
- package/dist/tempo/legacy/session/Types.d.ts.map +1 -0
- package/dist/tempo/legacy/session/Types.js.map +1 -0
- package/dist/tempo/{session → legacy/session}/Voucher.d.ts +4 -4
- package/dist/tempo/legacy/session/Voucher.d.ts.map +1 -0
- package/dist/tempo/{session → legacy/session}/Voucher.js +1 -1
- package/dist/tempo/legacy/session/Voucher.js.map +1 -0
- package/dist/tempo/{session → legacy/session}/escrow.abi.d.ts +1 -0
- package/dist/tempo/{session → legacy/session}/escrow.abi.d.ts.map +1 -1
- package/dist/tempo/{session → legacy/session}/escrow.abi.js +1 -0
- package/dist/tempo/legacy/session/escrow.abi.js.map +1 -0
- package/dist/tempo/legacy/session/index.d.ts +9 -0
- package/dist/tempo/legacy/session/index.d.ts.map +1 -0
- package/dist/tempo/legacy/session/index.js +9 -0
- package/dist/tempo/legacy/session/index.js.map +1 -0
- package/dist/tempo/server/Charge.d.ts +1 -1
- package/dist/tempo/server/Charge.d.ts.map +1 -1
- package/dist/tempo/server/Charge.js +51 -30
- package/dist/tempo/server/Charge.js.map +1 -1
- package/dist/tempo/server/Methods.d.ts +67 -8
- package/dist/tempo/server/Methods.d.ts.map +1 -1
- package/dist/tempo/server/Methods.js +40 -10
- package/dist/tempo/server/Methods.js.map +1 -1
- package/dist/tempo/server/Subscription.d.ts +11 -1
- package/dist/tempo/server/Subscription.d.ts.map +1 -1
- package/dist/tempo/server/Subscription.js +135 -23
- package/dist/tempo/server/Subscription.js.map +1 -1
- package/dist/tempo/server/index.d.ts +6 -5
- package/dist/tempo/server/index.d.ts.map +1 -1
- package/dist/tempo/server/index.js +5 -5
- package/dist/tempo/server/index.js.map +1 -1
- package/dist/tempo/server/internal/html.gen.d.ts +1 -1
- package/dist/tempo/server/internal/html.gen.d.ts.map +1 -1
- package/dist/tempo/server/internal/html.gen.js +1 -1
- package/dist/tempo/server/internal/html.gen.js.map +1 -1
- package/dist/tempo/server/internal/request-body.d.ts +7 -2
- package/dist/tempo/server/internal/request-body.d.ts.map +1 -1
- package/dist/tempo/server/internal/request-body.js +20 -3
- package/dist/tempo/server/internal/request-body.js.map +1 -1
- package/dist/tempo/server/internal/transport.d.ts +8 -4
- package/dist/tempo/server/internal/transport.d.ts.map +1 -1
- package/dist/tempo/server/internal/transport.js +8 -7
- package/dist/tempo/server/internal/transport.js.map +1 -1
- package/dist/tempo/session/Snapshot.d.ts +32 -0
- package/dist/tempo/session/Snapshot.d.ts.map +1 -0
- package/dist/tempo/session/Snapshot.js +37 -0
- package/dist/tempo/session/Snapshot.js.map +1 -0
- package/dist/tempo/session/client/ChannelOps.d.ts +81 -0
- package/dist/tempo/session/client/ChannelOps.d.ts.map +1 -0
- package/dist/tempo/session/client/ChannelOps.js +201 -0
- package/dist/tempo/session/client/ChannelOps.js.map +1 -0
- package/dist/tempo/session/client/ChannelStore.d.ts +51 -0
- package/dist/tempo/session/client/ChannelStore.d.ts.map +1 -0
- package/dist/tempo/session/client/ChannelStore.js +63 -0
- package/dist/tempo/session/client/ChannelStore.js.map +1 -0
- package/dist/tempo/session/client/CredentialState.d.ts +245 -0
- package/dist/tempo/session/client/CredentialState.d.ts.map +1 -0
- package/dist/tempo/session/client/CredentialState.js +419 -0
- package/dist/tempo/session/client/CredentialState.js.map +1 -0
- package/dist/tempo/session/client/ReceiptCoordinator.d.ts +26 -0
- package/dist/tempo/session/client/ReceiptCoordinator.d.ts.map +1 -0
- package/dist/tempo/session/client/ReceiptCoordinator.js +61 -0
- package/dist/tempo/session/client/ReceiptCoordinator.js.map +1 -0
- package/dist/tempo/session/client/Runtime.d.ts +464 -0
- package/dist/tempo/session/client/Runtime.d.ts.map +1 -0
- package/dist/tempo/session/client/Runtime.js +499 -0
- package/dist/tempo/session/client/Runtime.js.map +1 -0
- package/dist/tempo/session/client/Session.d.ts +138 -0
- package/dist/tempo/session/client/Session.d.ts.map +1 -0
- package/dist/tempo/session/client/Session.js +69 -0
- package/dist/tempo/session/client/Session.js.map +1 -0
- package/dist/tempo/session/client/SessionManager.d.ts +84 -0
- package/dist/tempo/session/client/SessionManager.d.ts.map +1 -0
- package/dist/tempo/session/client/SessionManager.js +577 -0
- package/dist/tempo/session/client/SessionManager.js.map +1 -0
- package/dist/tempo/session/client/Transports.d.ts +449 -0
- package/dist/tempo/session/client/Transports.d.ts.map +1 -0
- package/dist/tempo/session/client/Transports.js +721 -0
- package/dist/tempo/session/client/Transports.js.map +1 -0
- package/dist/tempo/session/client/index.d.ts +11 -0
- package/dist/tempo/session/client/index.d.ts.map +1 -0
- package/dist/tempo/session/client/index.js +6 -0
- package/dist/tempo/session/client/index.js.map +1 -0
- package/dist/tempo/session/index.d.ts +7 -8
- package/dist/tempo/session/index.d.ts.map +1 -1
- package/dist/tempo/session/index.js +7 -8
- package/dist/tempo/session/index.js.map +1 -1
- package/dist/tempo/session/precompile/Chain.d.ts +319 -0
- package/dist/tempo/session/precompile/Chain.d.ts.map +1 -0
- package/dist/tempo/session/precompile/Chain.js +492 -0
- package/dist/tempo/session/precompile/Chain.js.map +1 -0
- package/dist/tempo/session/precompile/Channel.d.ts +46 -0
- package/dist/tempo/session/precompile/Channel.d.ts.map +1 -0
- package/dist/tempo/session/precompile/Channel.js +56 -0
- package/dist/tempo/session/precompile/Channel.js.map +1 -0
- package/dist/tempo/session/precompile/Protocol.d.ts +308 -0
- package/dist/tempo/session/precompile/Protocol.d.ts.map +1 -0
- package/dist/tempo/session/precompile/Protocol.js +264 -0
- package/dist/tempo/session/precompile/Protocol.js.map +1 -0
- package/dist/tempo/session/precompile/Voucher.d.ts +40 -0
- package/dist/tempo/session/precompile/Voucher.d.ts.map +1 -0
- package/dist/tempo/session/precompile/Voucher.js +125 -0
- package/dist/tempo/session/precompile/Voucher.js.map +1 -0
- package/dist/tempo/session/precompile/escrow.abi.d.ts +522 -0
- package/dist/tempo/session/precompile/escrow.abi.d.ts.map +1 -0
- package/dist/tempo/session/precompile/escrow.abi.js +224 -0
- package/dist/tempo/session/precompile/escrow.abi.js.map +1 -0
- package/dist/tempo/session/precompile/index.d.ts +24 -0
- package/dist/tempo/session/precompile/index.d.ts.map +1 -0
- package/dist/tempo/session/precompile/index.js +22 -0
- package/dist/tempo/session/precompile/index.js.map +1 -0
- package/dist/tempo/session/server/ChannelOps.d.ts +56 -0
- package/dist/tempo/session/server/ChannelOps.d.ts.map +1 -0
- package/dist/tempo/session/server/ChannelOps.js +91 -0
- package/dist/tempo/session/server/ChannelOps.js.map +1 -0
- package/dist/tempo/session/server/ChannelStore.d.ts +347 -0
- package/dist/tempo/session/server/ChannelStore.d.ts.map +1 -0
- package/dist/tempo/session/server/ChannelStore.js +404 -0
- package/dist/tempo/session/server/ChannelStore.js.map +1 -0
- package/dist/tempo/session/server/CredentialVerification.d.ts +85 -0
- package/dist/tempo/session/server/CredentialVerification.d.ts.map +1 -0
- package/dist/tempo/session/server/CredentialVerification.js +494 -0
- package/dist/tempo/session/server/CredentialVerification.js.map +1 -0
- package/dist/tempo/session/server/MeteredStream.d.ts +40 -0
- package/dist/tempo/session/server/MeteredStream.d.ts.map +1 -0
- package/dist/tempo/session/server/MeteredStream.js +42 -0
- package/dist/tempo/session/server/MeteredStream.js.map +1 -0
- package/dist/tempo/session/server/RequestState.d.ts +208 -0
- package/dist/tempo/session/server/RequestState.d.ts.map +1 -0
- package/dist/tempo/session/server/RequestState.js +252 -0
- package/dist/tempo/session/server/RequestState.js.map +1 -0
- package/dist/tempo/session/server/Session.d.ts +169 -0
- package/dist/tempo/session/server/Session.d.ts.map +1 -0
- package/dist/tempo/session/server/Session.js +351 -0
- package/dist/tempo/session/server/Session.js.map +1 -0
- package/dist/tempo/session/server/Settlement.d.ts +185 -0
- package/dist/tempo/session/server/Settlement.d.ts.map +1 -0
- package/dist/tempo/session/server/Settlement.js +252 -0
- package/dist/tempo/session/server/Settlement.js.map +1 -0
- package/dist/tempo/session/{Sse.d.ts → server/Sse.d.ts} +9 -56
- package/dist/tempo/session/server/Sse.d.ts.map +1 -0
- package/dist/tempo/session/server/Sse.js +184 -0
- package/dist/tempo/session/server/Sse.js.map +1 -0
- package/dist/tempo/session/server/Transports.d.ts +89 -0
- package/dist/tempo/session/server/Transports.d.ts.map +1 -0
- package/dist/tempo/session/server/Transports.js +149 -0
- package/dist/tempo/session/server/Transports.js.map +1 -0
- package/dist/tempo/session/server/Ws.d.ts +48 -0
- package/dist/tempo/session/server/Ws.d.ts.map +1 -0
- package/dist/tempo/session/server/Ws.js +244 -0
- package/dist/tempo/session/server/Ws.js.map +1 -0
- package/dist/tempo/session/server/index.d.ts +4 -0
- package/dist/tempo/session/server/index.d.ts.map +1 -0
- package/dist/tempo/session/server/index.js +2 -0
- package/dist/tempo/session/server/index.js.map +1 -0
- package/dist/tempo/subscription/KeyAuthorization.d.ts +712 -1
- package/dist/tempo/subscription/KeyAuthorization.d.ts.map +1 -1
- package/dist/tempo/subscription/Store.d.ts +2 -0
- package/dist/tempo/subscription/Store.d.ts.map +1 -1
- package/dist/tempo/subscription/Store.js +16 -1
- package/dist/tempo/subscription/Store.js.map +1 -1
- package/dist/x402/index.d.ts +1 -0
- package/dist/x402/index.d.ts.map +1 -1
- package/dist/x402/index.js +1 -0
- package/dist/x402/index.js.map +1 -1
- package/package.json +25 -9
- package/src/Challenge.test.ts +40 -0
- package/src/Challenge.ts +28 -13
- package/src/Constants.ts +58 -0
- package/src/Credential.ts +5 -4
- package/src/Mcp.ts +4 -0
- package/src/Method.ts +46 -5
- package/src/PaymentRequest.ts +10 -10
- package/src/Receipt.ts +3 -2
- package/src/cli/cli.test.ts +38 -43
- package/src/cli/cli.ts +23 -10
- package/src/cli/mcp.test.ts +21 -7
- package/src/cli/plugins/tempo.ts +21 -8
- package/src/cli/utils.test.ts +25 -1
- package/src/cli/utils.ts +10 -0
- package/src/client/Methods.ts +5 -2
- package/src/client/Mppx.test-d.ts +31 -1
- package/src/client/Mppx.test.ts +76 -1
- package/src/client/Mppx.ts +2 -2
- package/src/client/Transport.test.ts +225 -178
- package/src/client/Transport.ts +77 -84
- package/src/client/index.ts +25 -1
- package/src/client/internal/Fetch.test.ts +236 -6
- package/src/client/internal/Fetch.ts +69 -11
- package/src/client/internal/protocols/Mcp.test.ts +220 -0
- package/src/client/internal/protocols/Mcp.ts +162 -0
- package/src/client/internal/protocols/Mpp.ts +21 -0
- package/src/client/internal/protocols/Protocol.ts +10 -0
- package/src/client/internal/protocols/Shared.ts +25 -0
- package/src/client/internal/protocols/X402.ts +42 -0
- package/src/discovery/OpenApi.test.ts +1 -1
- package/src/env.d.ts +1 -1
- package/src/evm/PublicInterface.test-d.ts +1 -1
- package/src/evm/client/index.ts +1 -0
- package/src/evm/index.ts +2 -0
- package/src/evm/server/Charge.test.ts +1 -1
- package/src/evm/server/index.ts +1 -0
- package/src/index.ts +1 -0
- package/src/internal/AcceptPayment.test.ts +61 -0
- package/src/internal/AcceptPayment.ts +21 -14
- package/src/{mcp-sdk → mcp}/client/McpClient.integration.test.ts +18 -11
- package/src/{mcp-sdk → mcp}/client/McpClient.test-d.ts +45 -11
- package/src/{mcp-sdk → mcp}/client/McpClient.test.ts +211 -5
- package/src/mcp/client/McpClient.ts +307 -0
- package/src/mcp/client/McpClient.unit.test.ts +135 -0
- package/src/middlewares/elysia.test.ts +9 -5
- package/src/middlewares/express.test.ts +9 -5
- package/src/middlewares/hono.test.ts +5 -5
- package/src/middlewares/internal/mppx.test.ts +1 -1
- package/src/middlewares/nextjs.test.ts +9 -5
- package/src/proxy/Proxy.test.ts +9 -9
- package/src/proxy/services/anthropic.test.ts +1 -1
- package/src/proxy/services/openai.test.ts +1 -1
- package/src/proxy/services/stripe.test.ts +1 -1
- package/src/server/Mppx.authorize.test.ts +1 -1
- package/src/server/Mppx.test-d.ts +55 -1
- package/src/server/Mppx.test.ts +220 -9
- package/src/server/Mppx.ts +501 -407
- package/src/server/Response.ts +2 -1
- package/src/server/Transport.test.ts +6 -6
- package/src/server/Transport.ts +5 -4
- package/src/server/index.ts +1 -0
- package/src/stripe/Charge.integration.test.ts +1 -1
- package/src/stripe/client/Charge.test.ts +21 -6
- package/src/stripe/client/Charge.ts +6 -2
- package/src/stripe/server/Charge.test.ts +115 -2
- package/src/stripe/server/Charge.ts +13 -2
- package/src/stripe/server/internal/html/package.json +1 -1
- package/src/stripe/server/internal/html.gen.ts +1 -1
- package/src/tempo/AccessKeyAuthorization.test.ts +4 -94
- package/src/tempo/Methods.test.ts +45 -17
- package/src/tempo/Methods.ts +22 -0
- package/src/tempo/Proof.conformance.test.ts +146 -0
- package/src/tempo/Proof.test-d.ts +15 -0
- package/src/tempo/Proof.ts +52 -1
- package/src/tempo/PublicExports.test-d.ts +105 -0
- package/src/tempo/Subscription.integration.test.ts +1 -1
- package/src/tempo/client/Charge.test.ts +258 -0
- package/src/tempo/client/Charge.ts +84 -38
- package/src/tempo/client/Methods.ts +22 -8
- package/src/tempo/client/ResolveAccount.ts +46 -0
- package/src/tempo/client/index.ts +15 -4
- package/src/tempo/index.ts +1 -0
- package/src/tempo/internal/fee-payer.test.ts +296 -17
- package/src/tempo/internal/fee-payer.ts +186 -4
- package/src/tempo/internal/fee-token.test.ts +14 -9
- package/src/tempo/internal/proof.test.ts +12 -4
- package/src/tempo/internal/proof.ts +55 -6
- package/src/tempo/legacy/AccessKeyAuthorization.test.ts +162 -0
- package/src/tempo/legacy/README.md +9 -0
- package/src/tempo/{client → legacy/client}/ChannelOps.test.ts +6 -7
- package/src/tempo/{client → legacy/client}/ChannelOps.ts +22 -9
- package/src/tempo/{client → legacy/client}/Session.test.ts +51 -9
- package/src/tempo/{client → legacy/client}/Session.ts +25 -11
- package/src/tempo/{client → legacy/client}/SessionManager.test.ts +81 -9
- package/src/tempo/{client → legacy/client}/SessionManager.ts +52 -23
- package/src/tempo/legacy/client/index.ts +6 -0
- package/src/tempo/legacy/index.ts +6 -0
- package/src/tempo/{server → legacy/server}/Session.test.ts +136 -71
- package/src/tempo/{server → legacy/server}/Session.ts +32 -23
- package/src/tempo/legacy/server/index.ts +4 -0
- package/src/tempo/{session → legacy/session}/Chain.test.ts +3 -4
- package/src/tempo/{session → legacy/session}/Chain.ts +94 -63
- package/src/tempo/{session → legacy/session}/Channel.ts +1 -0
- package/src/tempo/legacy/session/ChannelStore.test.ts +58 -0
- package/src/tempo/legacy/session/ChannelStore.ts +39 -0
- package/src/tempo/legacy/session/Types.ts +91 -0
- package/src/tempo/{session → legacy/session}/Voucher.ts +12 -8
- package/src/tempo/{session → legacy/session}/escrow.abi.ts +1 -0
- package/src/tempo/legacy/session/index.ts +8 -0
- package/src/tempo/server/AtomicStore.test-d.ts +16 -11
- package/src/tempo/server/Charge.test.ts +480 -31
- package/src/tempo/server/Charge.ts +54 -30
- package/src/tempo/server/Methods.ts +58 -10
- package/src/tempo/server/Sse.test.ts +2 -2
- package/src/tempo/server/Subscription.test.ts +465 -3
- package/src/tempo/server/Subscription.ts +174 -19
- package/src/tempo/server/index.ts +6 -5
- package/src/tempo/server/internal/html/package.json +2 -2
- package/src/tempo/server/internal/html.gen.ts +1 -1
- package/src/tempo/server/internal/request-body.test.ts +37 -4
- package/src/tempo/server/internal/request-body.ts +25 -6
- package/src/tempo/server/internal/transport.test.ts +4 -4
- package/src/tempo/server/internal/transport.ts +19 -10
- package/src/tempo/session/Snapshot.test.ts +41 -0
- package/src/tempo/session/Snapshot.ts +74 -0
- package/src/tempo/session/client/ChannelOps.test.ts +163 -0
- package/src/tempo/session/client/ChannelOps.ts +330 -0
- package/src/tempo/session/client/ChannelStore.ts +111 -0
- package/src/tempo/session/client/CredentialState.test.ts +789 -0
- package/src/tempo/session/client/CredentialState.ts +799 -0
- package/src/tempo/session/client/ReceiptCoordinator.ts +95 -0
- package/src/tempo/session/client/Runtime.test.ts +1092 -0
- package/src/tempo/session/client/Runtime.ts +986 -0
- package/src/tempo/session/client/Session.test.ts +774 -0
- package/src/tempo/session/client/Session.ts +123 -0
- package/src/tempo/session/client/SessionManager.test.ts +1397 -0
- package/src/tempo/session/client/SessionManager.ts +751 -0
- package/src/tempo/session/client/Transports.test.ts +837 -0
- package/src/tempo/session/client/Transports.ts +1292 -0
- package/src/tempo/session/client/index.ts +40 -0
- package/src/tempo/session/index.ts +7 -8
- package/src/tempo/session/precompile/Chain.integration.test.ts +321 -0
- package/src/tempo/session/precompile/Chain.test.ts +1258 -0
- package/src/tempo/session/precompile/Chain.ts +979 -0
- package/src/tempo/session/precompile/Channel.test.ts +138 -0
- package/src/tempo/session/precompile/Channel.ts +103 -0
- package/src/tempo/session/precompile/Protocol.test.ts +358 -0
- package/src/tempo/session/precompile/Protocol.ts +520 -0
- package/src/tempo/session/precompile/Voucher.test.ts +354 -0
- package/src/tempo/session/precompile/Voucher.ts +162 -0
- package/src/tempo/session/precompile/escrow.abi.ts +226 -0
- package/src/tempo/session/precompile/index.ts +33 -0
- package/src/tempo/session/server/ChannelOps.test.ts +129 -0
- package/src/tempo/session/server/ChannelOps.ts +157 -0
- package/src/tempo/session/{ChannelStore.test.ts → server/ChannelStore.test.ts} +536 -29
- package/src/tempo/session/server/ChannelStore.ts +835 -0
- package/src/tempo/session/server/CredentialVerification.test.ts +146 -0
- package/src/tempo/session/server/CredentialVerification.ts +710 -0
- package/src/tempo/session/server/MeteredStream.ts +88 -0
- package/src/tempo/session/server/RequestState.test.ts +531 -0
- package/src/tempo/session/server/RequestState.ts +499 -0
- package/src/tempo/session/server/Session.integration.test.ts +444 -0
- package/src/tempo/session/server/Session.test.ts +3253 -0
- package/src/tempo/session/server/Session.ts +543 -0
- package/src/tempo/session/server/Settlement.test.ts +329 -0
- package/src/tempo/session/server/Settlement.ts +471 -0
- package/src/tempo/session/{Sse.test.ts → server/Sse.test.ts} +37 -3
- package/src/tempo/session/server/Sse.ts +254 -0
- package/src/tempo/session/server/Transports.test.ts +346 -0
- package/src/tempo/session/server/Transports.ts +255 -0
- package/src/tempo/session/{Ws.test.ts → server/Ws.test.ts} +4 -4
- package/src/tempo/session/server/Ws.ts +380 -0
- package/src/tempo/session/server/index.ts +8 -0
- package/src/tempo/subscription/Store.ts +27 -9
- package/src/x402/Exact.e2e.test.ts +1 -1
- package/src/x402/PublicInterface.test-d.ts +1 -1
- package/src/x402/index.ts +1 -0
- package/dist/mcp-sdk/client/McpClient.d.ts +0 -78
- package/dist/mcp-sdk/client/McpClient.d.ts.map +0 -1
- package/dist/mcp-sdk/client/McpClient.js +0 -105
- package/dist/mcp-sdk/client/McpClient.js.map +0 -1
- package/dist/mcp-sdk/client/index.d.ts.map +0 -1
- package/dist/mcp-sdk/client/index.js.map +0 -1
- package/dist/mcp-sdk/server/Transport.d.ts.map +0 -1
- package/dist/mcp-sdk/server/Transport.js.map +0 -1
- package/dist/mcp-sdk/server/index.d.ts.map +0 -1
- package/dist/mcp-sdk/server/index.js.map +0 -1
- package/dist/tempo/client/ChannelOps.d.ts.map +0 -1
- package/dist/tempo/client/ChannelOps.js.map +0 -1
- package/dist/tempo/client/Session.d.ts.map +0 -1
- package/dist/tempo/client/Session.js.map +0 -1
- package/dist/tempo/client/SessionManager.d.ts.map +0 -1
- package/dist/tempo/client/SessionManager.js.map +0 -1
- package/dist/tempo/server/Session.d.ts.map +0 -1
- package/dist/tempo/server/Session.js.map +0 -1
- package/dist/tempo/session/Chain.d.ts.map +0 -1
- package/dist/tempo/session/Chain.js.map +0 -1
- package/dist/tempo/session/Channel.d.ts.map +0 -1
- package/dist/tempo/session/Channel.js.map +0 -1
- package/dist/tempo/session/ChannelStore.d.ts +0 -117
- package/dist/tempo/session/ChannelStore.d.ts.map +0 -1
- package/dist/tempo/session/ChannelStore.js +0 -172
- package/dist/tempo/session/ChannelStore.js.map +0 -1
- package/dist/tempo/session/Receipt.d.ts +0 -22
- package/dist/tempo/session/Receipt.d.ts.map +0 -1
- package/dist/tempo/session/Receipt.js +0 -34
- package/dist/tempo/session/Receipt.js.map +0 -1
- package/dist/tempo/session/Sse.d.ts.map +0 -1
- package/dist/tempo/session/Sse.js +0 -363
- package/dist/tempo/session/Sse.js.map +0 -1
- package/dist/tempo/session/Types.d.ts +0 -78
- package/dist/tempo/session/Types.d.ts.map +0 -1
- package/dist/tempo/session/Types.js.map +0 -1
- package/dist/tempo/session/Voucher.d.ts.map +0 -1
- package/dist/tempo/session/Voucher.js.map +0 -1
- package/dist/tempo/session/Ws.d.ts +0 -87
- package/dist/tempo/session/Ws.d.ts.map +0 -1
- package/dist/tempo/session/Ws.js +0 -443
- package/dist/tempo/session/Ws.js.map +0 -1
- package/dist/tempo/session/escrow.abi.js.map +0 -1
- package/src/mcp-sdk/client/McpClient.ts +0 -196
- package/src/tempo/session/ChannelStore.ts +0 -308
- package/src/tempo/session/Receipt.test.ts +0 -89
- package/src/tempo/session/Receipt.ts +0 -46
- package/src/tempo/session/Sse.ts +0 -462
- package/src/tempo/session/Types.ts +0 -86
- package/src/tempo/session/Ws.ts +0 -576
- /package/dist/{mcp-sdk → mcp}/client/index.d.ts +0 -0
- /package/dist/{mcp-sdk → mcp}/client/index.js +0 -0
- /package/dist/{mcp-sdk → mcp}/server/Transport.d.ts +0 -0
- /package/dist/{mcp-sdk → mcp}/server/Transport.js +0 -0
- /package/dist/{mcp-sdk → mcp}/server/index.d.ts +0 -0
- /package/dist/{mcp-sdk → mcp}/server/index.js +0 -0
- /package/dist/tempo/{session → legacy/session}/Channel.js +0 -0
- /package/dist/tempo/{session → legacy/session}/Types.js +0 -0
- /package/src/{mcp-sdk → mcp}/client/index.ts +0 -0
- /package/src/{mcp-sdk → mcp}/server/Transport.test.ts +0 -0
- /package/src/{mcp-sdk → mcp}/server/Transport.ts +0 -0
- /package/src/{mcp-sdk → mcp}/server/index.ts +0 -0
- /package/src/tempo/{session → legacy/session}/Channel.test.ts +0 -0
- /package/src/tempo/{session → legacy/session}/Voucher.test.ts +0 -0
- /package/src/tempo/session/{Sse.fuzz.test.ts → server/Sse.fuzz.test.ts} +0 -0
|
@@ -0,0 +1,330 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared client-side TIP-1034 channel operations.
|
|
3
|
+
*
|
|
4
|
+
* Provides the low-level helpers that both `tempo.session()` and
|
|
5
|
+
* `tempo.session.manager()` rely on: channel ID computation,
|
|
6
|
+
* transaction-bound descriptor construction, on-chain open/top-up payload
|
|
7
|
+
* construction, voucher/close payload serialization, and transaction signing.
|
|
8
|
+
*
|
|
9
|
+
* @see https://tips.sh/1034-1
|
|
10
|
+
*/
|
|
11
|
+
import { Hex } from 'ox'
|
|
12
|
+
import { encodeFunctionData, isAddress, type Account, type Address, type Client } from 'viem'
|
|
13
|
+
import { prepareTransactionRequest, signTransaction } from 'viem/actions'
|
|
14
|
+
import { Transaction } from 'viem/tempo'
|
|
15
|
+
|
|
16
|
+
import type { Challenge } from '../../../Challenge.js'
|
|
17
|
+
import * as Credential from '../../../Credential.js'
|
|
18
|
+
import * as Channel from '../precompile/Channel.js'
|
|
19
|
+
import { escrowAbi } from '../precompile/escrow.abi.js'
|
|
20
|
+
import { tip20ChannelEscrow } from '../precompile/Protocol.js'
|
|
21
|
+
import type {
|
|
22
|
+
CloseCredentialPayload,
|
|
23
|
+
OpenCredentialPayload,
|
|
24
|
+
SessionCredentialPayload,
|
|
25
|
+
TopUpCredentialPayload,
|
|
26
|
+
VoucherCredentialPayload,
|
|
27
|
+
} from '../precompile/Protocol.js'
|
|
28
|
+
import { uint96 } from '../precompile/Protocol.js'
|
|
29
|
+
import * as Voucher from '../precompile/Voucher.js'
|
|
30
|
+
|
|
31
|
+
type TempoChannelCall = {
|
|
32
|
+
to: Address
|
|
33
|
+
data: Hex.Hex
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
type AccountWithAccessKey = Account & {
|
|
37
|
+
accessKeyAddress?: unknown
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/** Client-side cached channel metadata used for automatic voucher management. */
|
|
41
|
+
export type ChannelEntry = {
|
|
42
|
+
/** TIP-1034 channel ID derived from descriptor, escrow, and chain ID. */
|
|
43
|
+
channelId: Hex.Hex
|
|
44
|
+
/** Highest cumulative amount this client has locally authorized. */
|
|
45
|
+
cumulativeAmount: bigint
|
|
46
|
+
/** Latest channel deposit known by the client. */
|
|
47
|
+
deposit: bigint
|
|
48
|
+
/** TIP-1034 descriptor required for vouchers, top-ups, and close credentials. */
|
|
49
|
+
descriptor: Channel.ChannelDescriptor
|
|
50
|
+
/** Escrow contract address used to derive `channelId`. */
|
|
51
|
+
escrow: Address
|
|
52
|
+
/** EVM chain ID used for channel ID and voucher domain separation. */
|
|
53
|
+
chainId: number
|
|
54
|
+
/** Whether the client considers the channel reusable for new vouchers. */
|
|
55
|
+
opened: boolean
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function isObject(value: unknown): value is Record<string, unknown> {
|
|
59
|
+
return typeof value === 'object' && value !== null
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function readOptionalAddress(value: unknown): Address | undefined {
|
|
63
|
+
return typeof value === 'string' && isAddress(value, { strict: false }) ? value : undefined
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
function readAccessKeyAddress(account: Account): Address | undefined {
|
|
67
|
+
return readOptionalAddress((account as AccountWithAccessKey).accessKeyAddress)
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/** Resolves the voucher authority address for a client account. */
|
|
71
|
+
export function resolveAuthorizedSigner(account: Account): Address {
|
|
72
|
+
return readAccessKeyAddress(account) ?? account.address
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
async function prepareTempoChannelTransaction(
|
|
76
|
+
client: Client,
|
|
77
|
+
parameters: {
|
|
78
|
+
account: Account
|
|
79
|
+
calls: readonly TempoChannelCall[]
|
|
80
|
+
feePayer?: boolean | undefined
|
|
81
|
+
feeToken: Address
|
|
82
|
+
},
|
|
83
|
+
) {
|
|
84
|
+
const { account, calls, feePayer, feeToken } = parameters
|
|
85
|
+
// viem's stable transaction request type does not yet expose Tempo's
|
|
86
|
+
// `calls`, `feePayer`, and `feeToken` fields together. Keep the cast at
|
|
87
|
+
// this boundary so session credential builders stay typed.
|
|
88
|
+
return prepareTransactionRequest(client, {
|
|
89
|
+
account,
|
|
90
|
+
calls,
|
|
91
|
+
...(feePayer ? { feePayer: true } : {}),
|
|
92
|
+
feeToken,
|
|
93
|
+
} as never)
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
async function signPreparedTempoTransaction(client: Client, prepared: unknown): Promise<Hex.Hex> {
|
|
97
|
+
return (await signTransaction(client, prepared as never)) as Hex.Hex
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/** Resolves the escrow precompile from local override, challenge hints, or canonical default. */
|
|
101
|
+
export function resolveEscrow(
|
|
102
|
+
challenge: {
|
|
103
|
+
request: {
|
|
104
|
+
methodDetails?: unknown
|
|
105
|
+
}
|
|
106
|
+
},
|
|
107
|
+
escrowOverride?: Address | undefined,
|
|
108
|
+
): Address {
|
|
109
|
+
const methodDetails = challenge.request.methodDetails
|
|
110
|
+
const challengeEscrow = isObject(methodDetails)
|
|
111
|
+
? (readOptionalAddress(methodDetails.escrowContract) ??
|
|
112
|
+
readOptionalAddress(methodDetails.escrow))
|
|
113
|
+
: undefined
|
|
114
|
+
return escrowOverride ?? challengeEscrow ?? tip20ChannelEscrow
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
/** Serializes a session credential with a DID source bound to the payer account. */
|
|
118
|
+
export function serializeCredential(
|
|
119
|
+
challenge: Challenge,
|
|
120
|
+
payload: SessionCredentialPayload,
|
|
121
|
+
chainId: number,
|
|
122
|
+
account: Account,
|
|
123
|
+
): string {
|
|
124
|
+
return Credential.serialize({
|
|
125
|
+
challenge,
|
|
126
|
+
payload,
|
|
127
|
+
source: `did:pkh:eip155:${chainId}:${account.address}`,
|
|
128
|
+
})
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
/** Case-insensitive EVM address equality. */
|
|
132
|
+
export function isSameAddress(a: Address, b: Address): boolean {
|
|
133
|
+
return a.toLowerCase() === b.toLowerCase()
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Signs and creates a TIP-1034 voucher credential payload for an existing channel.
|
|
138
|
+
*
|
|
139
|
+
* @see https://tips.sh/1034-1#execution-semantics
|
|
140
|
+
*/
|
|
141
|
+
export async function createVoucherPayload(
|
|
142
|
+
client: Client,
|
|
143
|
+
account: Account,
|
|
144
|
+
descriptor: Channel.ChannelDescriptor,
|
|
145
|
+
cumulativeAmount: bigint,
|
|
146
|
+
chainId: number,
|
|
147
|
+
escrow: Address = tip20ChannelEscrow,
|
|
148
|
+
): Promise<VoucherCredentialPayload> {
|
|
149
|
+
const channelId = Channel.computeId({
|
|
150
|
+
...descriptor,
|
|
151
|
+
chainId,
|
|
152
|
+
escrow,
|
|
153
|
+
})
|
|
154
|
+
const amount = uint96(cumulativeAmount)
|
|
155
|
+
const signature = await Voucher.signVoucher(
|
|
156
|
+
client,
|
|
157
|
+
account,
|
|
158
|
+
{ channelId, cumulativeAmount: amount },
|
|
159
|
+
escrow,
|
|
160
|
+
chainId,
|
|
161
|
+
)
|
|
162
|
+
|
|
163
|
+
return {
|
|
164
|
+
action: 'voucher',
|
|
165
|
+
channelId,
|
|
166
|
+
descriptor,
|
|
167
|
+
cumulativeAmount: amount.toString(),
|
|
168
|
+
signature,
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Signs and creates a TIP-1034 close credential payload for an existing channel.
|
|
174
|
+
*
|
|
175
|
+
* @see https://tips.sh/1034-1#execution-semantics
|
|
176
|
+
*/
|
|
177
|
+
export async function createClosePayload(
|
|
178
|
+
client: Client,
|
|
179
|
+
account: Account,
|
|
180
|
+
descriptor: Channel.ChannelDescriptor,
|
|
181
|
+
cumulativeAmount: bigint,
|
|
182
|
+
chainId: number,
|
|
183
|
+
escrow: Address = tip20ChannelEscrow,
|
|
184
|
+
): Promise<CloseCredentialPayload> {
|
|
185
|
+
const voucher = await createVoucherPayload(
|
|
186
|
+
client,
|
|
187
|
+
account,
|
|
188
|
+
descriptor,
|
|
189
|
+
cumulativeAmount,
|
|
190
|
+
chainId,
|
|
191
|
+
escrow,
|
|
192
|
+
)
|
|
193
|
+
return {
|
|
194
|
+
action: 'close',
|
|
195
|
+
channelId: voucher.channelId,
|
|
196
|
+
descriptor,
|
|
197
|
+
cumulativeAmount: voucher.cumulativeAmount,
|
|
198
|
+
signature: voucher.signature,
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
* Prepares, signs, and creates a TIP-1034 open credential payload.
|
|
204
|
+
*
|
|
205
|
+
* The channel descriptor uses the signed transaction's expiring nonce hash
|
|
206
|
+
* because TIP-1034 binds each opened channel to that transaction context.
|
|
207
|
+
*
|
|
208
|
+
* @see https://tips.sh/1034-1#channel-identity-and-packed-state
|
|
209
|
+
*/
|
|
210
|
+
export async function createOpenPayload(
|
|
211
|
+
client: Client,
|
|
212
|
+
account: Account,
|
|
213
|
+
parameters: {
|
|
214
|
+
chainId: number
|
|
215
|
+
deposit: bigint
|
|
216
|
+
escrow?: Address | undefined
|
|
217
|
+
feePayer?: boolean | undefined
|
|
218
|
+
initialAmount: bigint
|
|
219
|
+
operator?: Address | undefined
|
|
220
|
+
payee: Address
|
|
221
|
+
token: Address
|
|
222
|
+
},
|
|
223
|
+
): Promise<OpenCredentialPayload> {
|
|
224
|
+
const authorizedSigner = resolveAuthorizedSigner(account)
|
|
225
|
+
const escrow = parameters.escrow ?? tip20ChannelEscrow
|
|
226
|
+
const operator = parameters.operator ?? '0x0000000000000000000000000000000000000000'
|
|
227
|
+
const salt = Hex.random(32)
|
|
228
|
+
|
|
229
|
+
const deposit = uint96(parameters.deposit)
|
|
230
|
+
const initialAmount = uint96(parameters.initialAmount)
|
|
231
|
+
const openData = encodeFunctionData({
|
|
232
|
+
abi: escrowAbi,
|
|
233
|
+
functionName: 'open',
|
|
234
|
+
args: [parameters.payee, operator, parameters.token, deposit, salt, authorizedSigner],
|
|
235
|
+
})
|
|
236
|
+
const prepared = await prepareTempoChannelTransaction(client, {
|
|
237
|
+
account,
|
|
238
|
+
calls: [{ to: escrow, data: openData }],
|
|
239
|
+
feePayer: parameters.feePayer,
|
|
240
|
+
feeToken: parameters.token,
|
|
241
|
+
})
|
|
242
|
+
const transaction = await signPreparedTempoTransaction(client, prepared)
|
|
243
|
+
const signed = Transaction.deserialize(transaction as Transaction.TransactionSerializedTempo)
|
|
244
|
+
|
|
245
|
+
const expiringNonceHash = Channel.computeExpiringNonceHash(
|
|
246
|
+
Channel.transactionForExpiringNonceHash({
|
|
247
|
+
...(parameters.feePayer ? { feePayer: true } : {}),
|
|
248
|
+
transaction: signed,
|
|
249
|
+
}),
|
|
250
|
+
{ sender: account.address },
|
|
251
|
+
)
|
|
252
|
+
const descriptor = {
|
|
253
|
+
authorizedSigner,
|
|
254
|
+
expiringNonceHash,
|
|
255
|
+
operator,
|
|
256
|
+
payee: parameters.payee,
|
|
257
|
+
payer: account.address,
|
|
258
|
+
salt,
|
|
259
|
+
token: parameters.token,
|
|
260
|
+
} satisfies Channel.ChannelDescriptor
|
|
261
|
+
const channelId = Channel.computeId({
|
|
262
|
+
...descriptor,
|
|
263
|
+
chainId: parameters.chainId,
|
|
264
|
+
escrow,
|
|
265
|
+
})
|
|
266
|
+
const signature = await Voucher.signVoucher(
|
|
267
|
+
client,
|
|
268
|
+
account,
|
|
269
|
+
{ channelId, cumulativeAmount: initialAmount },
|
|
270
|
+
escrow,
|
|
271
|
+
parameters.chainId,
|
|
272
|
+
)
|
|
273
|
+
return {
|
|
274
|
+
action: 'open',
|
|
275
|
+
type: 'transaction',
|
|
276
|
+
channelId,
|
|
277
|
+
transaction,
|
|
278
|
+
signature,
|
|
279
|
+
descriptor,
|
|
280
|
+
cumulativeAmount: initialAmount.toString(),
|
|
281
|
+
authorizedSigner: descriptor.authorizedSigner,
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
/**
|
|
286
|
+
* Prepares, signs, and creates a TIP-1034 top-up credential payload.
|
|
287
|
+
*
|
|
288
|
+
* @see https://tips.sh/1034-1#execution-semantics
|
|
289
|
+
*/
|
|
290
|
+
export async function createTopUpPayload(
|
|
291
|
+
client: Client,
|
|
292
|
+
account: Account,
|
|
293
|
+
descriptor: Channel.ChannelDescriptor,
|
|
294
|
+
additionalDeposit: bigint,
|
|
295
|
+
chainId: number,
|
|
296
|
+
feePayer?: boolean | undefined,
|
|
297
|
+
escrow: Address = tip20ChannelEscrow,
|
|
298
|
+
): Promise<TopUpCredentialPayload> {
|
|
299
|
+
const channelId = Channel.computeId({
|
|
300
|
+
...descriptor,
|
|
301
|
+
chainId,
|
|
302
|
+
escrow,
|
|
303
|
+
})
|
|
304
|
+
const deposit = uint96(additionalDeposit)
|
|
305
|
+
const prepared = await prepareTempoChannelTransaction(client, {
|
|
306
|
+
account,
|
|
307
|
+
calls: [
|
|
308
|
+
{
|
|
309
|
+
to: escrow,
|
|
310
|
+
data: encodeFunctionData({
|
|
311
|
+
abi: escrowAbi,
|
|
312
|
+
functionName: 'topUp',
|
|
313
|
+
args: [descriptor, deposit],
|
|
314
|
+
}),
|
|
315
|
+
},
|
|
316
|
+
],
|
|
317
|
+
feePayer,
|
|
318
|
+
feeToken: descriptor.token,
|
|
319
|
+
})
|
|
320
|
+
const transaction = await signPreparedTempoTransaction(client, prepared)
|
|
321
|
+
|
|
322
|
+
return {
|
|
323
|
+
action: 'topUp',
|
|
324
|
+
type: 'transaction',
|
|
325
|
+
channelId,
|
|
326
|
+
transaction,
|
|
327
|
+
descriptor,
|
|
328
|
+
additionalDeposit: deposit.toString(),
|
|
329
|
+
}
|
|
330
|
+
}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import type { Address } from 'viem'
|
|
2
|
+
|
|
3
|
+
import type { MaybePromise } from '../../../internal/types.js'
|
|
4
|
+
import type { ChannelEntry } from './ChannelOps.js'
|
|
5
|
+
|
|
6
|
+
/** Store of reusable payer session channels keyed by payment scope. */
|
|
7
|
+
export type ChannelStore = {
|
|
8
|
+
/** Returns the channel cached for `key`, when present. */
|
|
9
|
+
get(key: string): MaybePromise<ChannelEntry | undefined>
|
|
10
|
+
/** Inserts or replaces a channel entry. */
|
|
11
|
+
set(entry: ChannelEntry): MaybePromise<void>
|
|
12
|
+
/** Removes the channel cached for `key`. */
|
|
13
|
+
delete(key: string): MaybePromise<void>
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/** Channel persistence and update notification for credential results. */
|
|
17
|
+
export type ChannelSink = {
|
|
18
|
+
store: ChannelStore
|
|
19
|
+
notifyUpdate: (entry: ChannelEntry) => void
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/** Returns the scope key for a reusable payer session channel. */
|
|
23
|
+
export function channelKey(scope: {
|
|
24
|
+
payee: Address
|
|
25
|
+
token: Address
|
|
26
|
+
escrow: Address
|
|
27
|
+
chainId: number
|
|
28
|
+
}): string {
|
|
29
|
+
const { payee, token, escrow, chainId } = scope
|
|
30
|
+
return `${payee.toLowerCase()}:${token.toLowerCase()}:${escrow.toLowerCase()}:${chainId}`
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/** Returns the scope key for a stored channel entry. */
|
|
34
|
+
export function entryKey(entry: ChannelEntry): string {
|
|
35
|
+
return channelKey({
|
|
36
|
+
payee: entry.descriptor.payee,
|
|
37
|
+
token: entry.descriptor.token,
|
|
38
|
+
escrow: entry.escrow,
|
|
39
|
+
chainId: entry.chainId,
|
|
40
|
+
})
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/** Creates the default in-memory {@link ChannelStore}. */
|
|
44
|
+
export function createChannelStore(): ChannelStore {
|
|
45
|
+
const channels = new Map<string, ChannelEntry>()
|
|
46
|
+
return {
|
|
47
|
+
get: (key) => channels.get(key),
|
|
48
|
+
set(entry) {
|
|
49
|
+
channels.set(entryKey(entry), entry)
|
|
50
|
+
},
|
|
51
|
+
delete(key) {
|
|
52
|
+
channels.delete(key)
|
|
53
|
+
},
|
|
54
|
+
} satisfies ChannelStore
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/** JSON-safe projection of a {@link ChannelEntry}, with bigint amounts as decimal strings. */
|
|
58
|
+
export type StoredChannel = Omit<ChannelEntry, 'cumulativeAmount' | 'deposit'> & {
|
|
59
|
+
/** Cumulative voucher authorization in raw token units, as a decimal string. */
|
|
60
|
+
cumulativeAmount: string
|
|
61
|
+
/** Channel deposit in raw token units, as a decimal string. */
|
|
62
|
+
deposit: string
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/** Converts a channel entry into its JSON-safe stored form. */
|
|
66
|
+
export function serializeEntry(entry: ChannelEntry): StoredChannel {
|
|
67
|
+
return {
|
|
68
|
+
...entry,
|
|
69
|
+
cumulativeAmount: entry.cumulativeAmount.toString(),
|
|
70
|
+
deposit: entry.deposit.toString(),
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/** Restores a channel entry from its JSON-safe stored form. */
|
|
75
|
+
export function deserializeEntry(stored: StoredChannel): ChannelEntry {
|
|
76
|
+
return {
|
|
77
|
+
...stored,
|
|
78
|
+
cumulativeAmount: BigInt(stored.cumulativeAmount),
|
|
79
|
+
deposit: BigInt(stored.deposit),
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/** Prefix for serialized channel entries persisted by {@link createJsonChannelStore}. */
|
|
84
|
+
const channelPrefix = 'chan:'
|
|
85
|
+
|
|
86
|
+
/** Plain string key-value backend a {@link createJsonChannelStore} persists into. */
|
|
87
|
+
export type JsonChannelKv = {
|
|
88
|
+
/** Returns the value stored at `key`, when present. */
|
|
89
|
+
get(key: string): MaybePromise<string | undefined>
|
|
90
|
+
/** Persists a `value` at `key`. */
|
|
91
|
+
set(key: string, value: string): MaybePromise<void>
|
|
92
|
+
/** Removes the value stored at `key`. */
|
|
93
|
+
delete(key: string): MaybePromise<void>
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
/** Wraps a string KV backend as a bigint-safe channel store. */
|
|
97
|
+
export function createJsonChannelStore(kv: JsonChannelKv): ChannelStore {
|
|
98
|
+
return {
|
|
99
|
+
async get(key) {
|
|
100
|
+
const value = await kv.get(channelPrefix + key)
|
|
101
|
+
if (value === undefined) return undefined
|
|
102
|
+
return deserializeEntry(JSON.parse(value) as StoredChannel)
|
|
103
|
+
},
|
|
104
|
+
async set(entry) {
|
|
105
|
+
await kv.set(channelPrefix + entryKey(entry), JSON.stringify(serializeEntry(entry)))
|
|
106
|
+
},
|
|
107
|
+
async delete(key) {
|
|
108
|
+
await kv.delete(channelPrefix + key)
|
|
109
|
+
},
|
|
110
|
+
} satisfies ChannelStore
|
|
111
|
+
}
|