@oobe-protocol-labs/synapse-sap-sdk 0.13.0 → 0.15.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/dist/cjs/accounts/index.js +286 -0
- package/dist/cjs/accounts/index.js.map +1 -0
- package/dist/cjs/client.js +125 -0
- package/dist/cjs/client.js.map +1 -0
- package/dist/cjs/constants/seeds.js +9 -9
- package/dist/cjs/constants/seeds.js.map +1 -1
- package/dist/cjs/constants.js +66 -0
- package/dist/cjs/constants.js.map +1 -0
- package/dist/cjs/errors.js +260 -0
- package/dist/cjs/errors.js.map +1 -0
- package/dist/cjs/events/index.js +37 -123
- package/dist/cjs/events/index.js.map +1 -1
- package/dist/cjs/idlTypes.js +4 -0
- package/dist/cjs/idlTypes.js.map +1 -0
- package/dist/cjs/index.js +75 -241
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/instructions/agent.js +90 -0
- package/dist/cjs/instructions/agent.js.map +1 -0
- package/dist/cjs/instructions/attestation.js +113 -0
- package/dist/cjs/instructions/attestation.js.map +1 -0
- package/dist/cjs/instructions/digest.js +29 -0
- package/dist/cjs/instructions/digest.js.map +1 -0
- package/dist/cjs/instructions/dispute.js +117 -0
- package/dist/cjs/instructions/dispute.js.map +1 -0
- package/dist/cjs/instructions/escrow.js +102 -0
- package/dist/cjs/instructions/escrow.js.map +1 -0
- package/dist/cjs/instructions/global.js +29 -0
- package/dist/cjs/instructions/global.js.map +1 -0
- package/dist/cjs/instructions/index.js +31 -0
- package/dist/cjs/instructions/index.js.map +1 -0
- package/dist/cjs/instructions/indexing.js +222 -0
- package/dist/cjs/instructions/indexing.js.map +1 -0
- package/dist/cjs/instructions/misc.js +74 -0
- package/dist/cjs/instructions/misc.js.map +1 -0
- package/dist/cjs/instructions/session.js +90 -0
- package/dist/cjs/instructions/session.js.map +1 -0
- package/dist/cjs/instructions/staking.js +133 -0
- package/dist/cjs/instructions/staking.js.map +1 -0
- package/dist/cjs/instructions/subscription.js +81 -0
- package/dist/cjs/instructions/subscription.js.map +1 -0
- package/dist/cjs/instructions/tools.js +110 -0
- package/dist/cjs/instructions/tools.js.map +1 -0
- package/dist/cjs/instructions/vault.js +107 -0
- package/dist/cjs/instructions/vault.js.map +1 -0
- package/dist/cjs/pdas/index.js +120 -0
- package/dist/cjs/pdas/index.js.map +1 -0
- package/dist/cjs/registries/fairscale.js +1 -1
- package/dist/cjs/registries/fairscale.js.map +1 -1
- package/dist/cjs/registries/metaplex-bridge.js +1 -1
- package/dist/cjs/registries/metaplex-bridge.js.map +1 -1
- package/dist/cjs/types.js +45 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/utils/escrow-validation.js +1 -1
- package/dist/cjs/utils/escrow-validation.js.map +1 -1
- package/dist/cjs/utils/index.js +32 -83
- package/dist/cjs/utils/index.js.map +1 -1
- package/dist/cjs/utils/merchant-validator.js +5 -5
- package/dist/cjs/utils/merchant-validator.js.map +1 -1
- package/dist/cjs/utils/validate.js +236 -0
- package/dist/cjs/utils/validate.js.map +1 -0
- package/dist/cjs/utils/volume-curve.js +1 -1
- package/dist/cjs/utils/volume-curve.js.map +1 -1
- package/dist/esm/accounts/index.d.ts +11 -0
- package/dist/esm/accounts/index.d.ts.map +1 -0
- package/dist/esm/accounts/index.js +273 -0
- package/dist/esm/accounts/index.js.map +1 -0
- package/dist/esm/client.d.ts +55 -0
- package/dist/esm/client.d.ts.map +1 -0
- package/dist/esm/client.js +87 -0
- package/dist/esm/client.js.map +1 -0
- package/dist/esm/constants/addresses.d.ts +117 -0
- package/dist/esm/constants/addresses.d.ts.map +1 -0
- package/dist/esm/constants/index.d.ts +31 -0
- package/dist/esm/constants/index.d.ts.map +1 -0
- package/dist/esm/constants/limits.d.ts +149 -0
- package/dist/esm/constants/limits.d.ts.map +1 -0
- package/{src/constants/network.ts → dist/esm/constants/network.d.ts} +23 -31
- package/dist/esm/constants/network.d.ts.map +1 -0
- package/{src/constants/payments.ts → dist/esm/constants/payments.d.ts} +11 -35
- package/dist/esm/constants/payments.d.ts.map +1 -0
- package/{src/constants/programs.ts → dist/esm/constants/programs.d.ts} +6 -20
- package/dist/esm/constants/programs.d.ts.map +1 -0
- package/dist/esm/constants/seeds.d.ts +80 -0
- package/dist/esm/constants/seeds.d.ts.map +1 -0
- package/dist/esm/constants/seeds.js +9 -9
- package/dist/esm/constants/seeds.js.map +1 -1
- package/dist/esm/constants.d.ts +39 -0
- package/dist/esm/constants.d.ts.map +1 -0
- package/dist/esm/constants.js +41 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/core/client.d.ts +452 -0
- package/dist/esm/core/client.d.ts.map +1 -0
- package/dist/esm/core/connection.d.ts +305 -0
- package/dist/esm/core/connection.d.ts.map +1 -0
- package/{src/core/index.ts → dist/esm/core/index.d.ts} +1 -1
- package/dist/esm/core/index.d.ts.map +1 -0
- package/dist/esm/errors/index.d.ts +276 -0
- package/dist/esm/errors/index.d.ts.map +1 -0
- package/dist/esm/errors.d.ts +119 -0
- package/dist/esm/errors.d.ts.map +1 -0
- package/dist/esm/errors.js +252 -0
- package/dist/esm/errors.js.map +1 -0
- package/dist/esm/events/geyser.d.ts +150 -0
- package/dist/esm/events/geyser.d.ts.map +1 -0
- package/dist/esm/events/index.d.ts +17 -0
- package/dist/esm/events/index.d.ts.map +1 -0
- package/dist/esm/events/index.js +34 -122
- package/dist/esm/events/index.js.map +1 -1
- package/{src/idl/index.ts → dist/esm/idl/index.d.ts} +9 -15
- package/dist/esm/idl/index.d.ts.map +1 -0
- package/dist/esm/idlTypes.d.ts +925 -0
- package/dist/esm/idlTypes.d.ts.map +1 -0
- package/dist/esm/idlTypes.js +3 -0
- package/dist/esm/idlTypes.js.map +1 -0
- package/dist/esm/index.d.ts +12 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +15 -88
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/instructions/agent.d.ts +71 -0
- package/dist/esm/instructions/agent.d.ts.map +1 -0
- package/dist/esm/instructions/agent.js +86 -0
- package/dist/esm/instructions/agent.js.map +1 -0
- package/dist/esm/instructions/attestation.d.ts +76 -0
- package/dist/esm/instructions/attestation.d.ts.map +1 -0
- package/dist/esm/instructions/attestation.js +109 -0
- package/dist/esm/instructions/attestation.js.map +1 -0
- package/dist/esm/instructions/digest.d.ts +20 -0
- package/dist/esm/instructions/digest.d.ts.map +1 -0
- package/dist/esm/instructions/digest.js +25 -0
- package/dist/esm/instructions/digest.js.map +1 -0
- package/dist/esm/instructions/dispute.d.ts +81 -0
- package/dist/esm/instructions/dispute.d.ts.map +1 -0
- package/dist/esm/instructions/dispute.js +113 -0
- package/dist/esm/instructions/dispute.js.map +1 -0
- package/dist/esm/instructions/escrow.d.ts +79 -0
- package/dist/esm/instructions/escrow.d.ts.map +1 -0
- package/dist/esm/instructions/escrow.js +98 -0
- package/dist/esm/instructions/escrow.js.map +1 -0
- package/dist/esm/instructions/global.d.ts +14 -0
- package/dist/esm/instructions/global.d.ts.map +1 -0
- package/dist/esm/instructions/global.js +25 -0
- package/dist/esm/instructions/global.js.map +1 -0
- package/dist/esm/instructions/index.d.ts +14 -0
- package/dist/esm/instructions/index.d.ts.map +1 -0
- package/dist/esm/instructions/index.js +15 -0
- package/dist/esm/instructions/index.js.map +1 -0
- package/dist/esm/instructions/indexing.d.ts +150 -0
- package/dist/esm/instructions/indexing.d.ts.map +1 -0
- package/dist/esm/instructions/indexing.js +218 -0
- package/dist/esm/instructions/indexing.js.map +1 -0
- package/dist/esm/instructions/memory.d.ts +8 -0
- package/dist/esm/instructions/memory.d.ts.map +1 -0
- package/dist/esm/instructions/memory.js +234 -0
- package/dist/esm/instructions/memory.js.map +1 -0
- package/dist/esm/instructions/misc.d.ts +50 -0
- package/dist/esm/instructions/misc.d.ts.map +1 -0
- package/dist/esm/instructions/misc.js +70 -0
- package/dist/esm/instructions/misc.js.map +1 -0
- package/dist/esm/instructions/session.d.ts +57 -0
- package/dist/esm/instructions/session.d.ts.map +1 -0
- package/dist/esm/instructions/session.js +86 -0
- package/dist/esm/instructions/session.js.map +1 -0
- package/dist/esm/instructions/staking.d.ts +85 -0
- package/dist/esm/instructions/staking.d.ts.map +1 -0
- package/dist/esm/instructions/staking.js +129 -0
- package/dist/esm/instructions/staking.js.map +1 -0
- package/dist/esm/instructions/subscription.d.ts +50 -0
- package/dist/esm/instructions/subscription.d.ts.map +1 -0
- package/dist/esm/instructions/subscription.js +77 -0
- package/dist/esm/instructions/subscription.js.map +1 -0
- package/dist/esm/instructions/tools.d.ts +88 -0
- package/dist/esm/instructions/tools.d.ts.map +1 -0
- package/dist/esm/instructions/tools.js +106 -0
- package/dist/esm/instructions/tools.js.map +1 -0
- package/dist/esm/instructions/vault.d.ts +84 -0
- package/dist/esm/instructions/vault.d.ts.map +1 -0
- package/dist/esm/instructions/vault.js +103 -0
- package/dist/esm/instructions/vault.js.map +1 -0
- package/dist/esm/modules/agent.d.ts +166 -0
- package/dist/esm/modules/agent.d.ts.map +1 -0
- package/dist/esm/modules/attestation.d.ts +96 -0
- package/dist/esm/modules/attestation.d.ts.map +1 -0
- package/dist/esm/modules/base.d.ts +161 -0
- package/dist/esm/modules/base.d.ts.map +1 -0
- package/dist/esm/modules/escrow-v2.d.ts +169 -0
- package/dist/esm/modules/escrow-v2.d.ts.map +1 -0
- package/dist/esm/modules/feedback.d.ts +105 -0
- package/dist/esm/modules/feedback.d.ts.map +1 -0
- package/{src/modules/index.ts → dist/esm/modules/index.d.ts} +1 -1
- package/dist/esm/modules/index.d.ts.map +1 -0
- package/dist/esm/modules/indexing.d.ts +200 -0
- package/dist/esm/modules/indexing.d.ts.map +1 -0
- package/dist/esm/modules/ledger.d.ts +150 -0
- package/dist/esm/modules/ledger.d.ts.map +1 -0
- package/dist/esm/modules/receipt.d.ts +77 -0
- package/dist/esm/modules/receipt.d.ts.map +1 -0
- package/dist/esm/modules/staking.d.ts +51 -0
- package/dist/esm/modules/staking.d.ts.map +1 -0
- package/dist/esm/modules/subscription.d.ts +33 -0
- package/dist/esm/modules/subscription.d.ts.map +1 -0
- package/dist/esm/modules/tools.d.ts +182 -0
- package/dist/esm/modules/tools.d.ts.map +1 -0
- package/dist/esm/modules/vault.d.ts +240 -0
- package/dist/esm/modules/vault.d.ts.map +1 -0
- package/dist/esm/parser/client.d.ts +123 -0
- package/dist/esm/parser/client.d.ts.map +1 -0
- package/dist/esm/parser/complete.d.ts +90 -0
- package/dist/esm/parser/complete.d.ts.map +1 -0
- package/{src/parser/index.ts → dist/esm/parser/index.d.ts} +6 -37
- package/dist/esm/parser/index.d.ts.map +1 -0
- package/dist/esm/parser/inner.d.ts +114 -0
- package/dist/esm/parser/inner.d.ts.map +1 -0
- package/{src/parser/instructions.ts → dist/esm/parser/instructions.d.ts} +4 -63
- package/dist/esm/parser/instructions.d.ts.map +1 -0
- package/dist/esm/parser/transaction.d.ts +77 -0
- package/dist/esm/parser/transaction.d.ts.map +1 -0
- package/dist/esm/parser/types.d.ts +154 -0
- package/dist/esm/parser/types.d.ts.map +1 -0
- package/{src/pda/index.ts → dist/esm/pda/index.d.ts} +33 -442
- package/dist/esm/pda/index.d.ts.map +1 -0
- package/dist/esm/pdas/index.d.ts +37 -0
- package/dist/esm/pdas/index.d.ts.map +1 -0
- package/dist/esm/pdas/index.js +101 -0
- package/dist/esm/pdas/index.js.map +1 -0
- package/dist/esm/plugin/index.d.ts +171 -0
- package/dist/esm/plugin/index.d.ts.map +1 -0
- package/dist/esm/plugin/protocols.d.ts +152 -0
- package/dist/esm/plugin/protocols.d.ts.map +1 -0
- package/dist/esm/plugin/schemas.d.ts +829 -0
- package/dist/esm/plugin/schemas.d.ts.map +1 -0
- package/dist/esm/postgres/adapter.d.ts +355 -0
- package/dist/esm/postgres/adapter.d.ts.map +1 -0
- package/dist/esm/postgres/index.d.ts +24 -0
- package/dist/esm/postgres/index.d.ts.map +1 -0
- package/dist/esm/postgres/serializers.d.ts +30 -0
- package/dist/esm/postgres/serializers.d.ts.map +1 -0
- package/dist/esm/postgres/sync.d.ts +156 -0
- package/dist/esm/postgres/sync.d.ts.map +1 -0
- package/dist/esm/postgres/types.d.ts +167 -0
- package/dist/esm/postgres/types.d.ts.map +1 -0
- package/dist/esm/registries/builder.d.ts +340 -0
- package/dist/esm/registries/builder.d.ts.map +1 -0
- package/dist/esm/registries/discovery.d.ts +333 -0
- package/dist/esm/registries/discovery.d.ts.map +1 -0
- package/dist/esm/registries/fairscale.d.ts +680 -0
- package/dist/esm/registries/fairscale.d.ts.map +1 -0
- package/dist/esm/registries/fairscale.js +1 -1
- package/dist/esm/registries/fairscale.js.map +1 -1
- package/dist/esm/registries/index.d.ts +52 -0
- package/dist/esm/registries/index.d.ts.map +1 -0
- package/dist/esm/registries/metaplex-bridge.d.ts +489 -0
- package/dist/esm/registries/metaplex-bridge.d.ts.map +1 -0
- package/dist/esm/registries/metaplex-bridge.js +1 -1
- package/dist/esm/registries/metaplex-bridge.js.map +1 -1
- package/dist/esm/registries/session.d.ts +323 -0
- package/dist/esm/registries/session.d.ts.map +1 -0
- package/dist/esm/registries/x402.d.ts +530 -0
- package/dist/esm/registries/x402.d.ts.map +1 -0
- package/dist/esm/types/accounts.d.ts +765 -0
- package/dist/esm/types/accounts.d.ts.map +1 -0
- package/dist/esm/types/common.d.ts +166 -0
- package/dist/esm/types/common.d.ts.map +1 -0
- package/dist/esm/types/endpoint.d.ts +161 -0
- package/dist/esm/types/endpoint.d.ts.map +1 -0
- package/dist/esm/types/enums.d.ts +353 -0
- package/dist/esm/types/enums.d.ts.map +1 -0
- package/dist/esm/types/index.d.ts +29 -0
- package/dist/esm/types/index.d.ts.map +1 -0
- package/dist/esm/types/instructions.d.ts +400 -0
- package/dist/esm/types/instructions.d.ts.map +1 -0
- package/dist/esm/types.d.ts +236 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +40 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/utils/anchor-errors.d.ts +61 -0
- package/dist/esm/utils/anchor-errors.d.ts.map +1 -0
- package/dist/esm/utils/endpoint-validator.d.ts +110 -0
- package/dist/esm/utils/endpoint-validator.d.ts.map +1 -0
- package/dist/esm/utils/escrow-validation.d.ts +145 -0
- package/dist/esm/utils/escrow-validation.d.ts.map +1 -0
- package/dist/esm/utils/escrow-validation.js +1 -1
- package/dist/esm/utils/escrow-validation.js.map +1 -1
- package/{src/utils/hash.ts → dist/esm/utils/hash.d.ts} +4 -42
- package/dist/esm/utils/hash.d.ts.map +1 -0
- package/dist/esm/utils/index.d.ts +6 -0
- package/dist/esm/utils/index.d.ts.map +1 -0
- package/dist/esm/utils/index.js +16 -33
- package/dist/esm/utils/index.js.map +1 -1
- package/dist/esm/utils/merchant-validator.d.ts +176 -0
- package/dist/esm/utils/merchant-validator.d.ts.map +1 -0
- package/dist/esm/utils/merchant-validator.js +1 -1
- package/dist/esm/utils/merchant-validator.js.map +1 -1
- package/dist/esm/utils/network-normalizer.d.ts +120 -0
- package/dist/esm/utils/network-normalizer.d.ts.map +1 -0
- package/dist/esm/utils/priority-fee.d.ts +205 -0
- package/dist/esm/utils/priority-fee.d.ts.map +1 -0
- package/dist/esm/utils/rpc-strategy.d.ts +172 -0
- package/dist/esm/utils/rpc-strategy.d.ts.map +1 -0
- package/dist/esm/utils/schemas.d.ts +351 -0
- package/dist/esm/utils/schemas.d.ts.map +1 -0
- package/{src/utils/serialization.ts → dist/esm/utils/serialization.d.ts} +3 -32
- package/dist/esm/utils/serialization.d.ts.map +1 -0
- package/dist/esm/utils/validate.d.ts +66 -0
- package/dist/esm/utils/validate.d.ts.map +1 -0
- package/dist/esm/utils/validate.js +221 -0
- package/dist/esm/utils/validate.js.map +1 -0
- package/{src/utils/validation.ts → dist/esm/utils/validation.d.ts} +2 -9
- package/dist/esm/utils/validation.d.ts.map +1 -0
- package/{src/utils/volume-curve.ts → dist/esm/utils/volume-curve.d.ts} +2 -73
- package/dist/esm/utils/volume-curve.d.ts.map +1 -0
- package/dist/esm/utils/volume-curve.js +1 -1
- package/dist/esm/utils/volume-curve.js.map +1 -1
- package/dist/esm/utils/x402-direct.d.ts +114 -0
- package/dist/esm/utils/x402-direct.d.ts.map +1 -0
- package/dist/types/constants/seeds.d.ts +2 -0
- package/dist/types/constants/seeds.d.ts.map +1 -1
- package/dist/types/core/client.d.ts +21 -6
- package/dist/types/core/client.d.ts.map +1 -1
- package/dist/types/errors/index.d.ts +59 -0
- package/dist/types/errors/index.d.ts.map +1 -1
- package/dist/types/index.d.ts +3 -2
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/modules/agent.d.ts +9 -19
- package/dist/types/modules/agent.d.ts.map +1 -1
- package/dist/types/modules/attestation.d.ts.map +1 -1
- package/dist/types/modules/base.d.ts +54 -0
- package/dist/types/modules/base.d.ts.map +1 -1
- package/dist/types/modules/escrow-v2.d.ts +117 -1
- package/dist/types/modules/escrow-v2.d.ts.map +1 -1
- package/dist/types/modules/index.d.ts +1 -2
- package/dist/types/modules/index.d.ts.map +1 -1
- package/dist/types/modules/receipt.d.ts +14 -0
- package/dist/types/modules/receipt.d.ts.map +1 -1
- package/dist/types/modules/subscription.d.ts.map +1 -1
- package/dist/types/modules/tools.d.ts +0 -10
- package/dist/types/modules/tools.d.ts.map +1 -1
- package/dist/types/modules/vault.d.ts.map +1 -1
- package/dist/types/pda/index.d.ts +17 -0
- package/dist/types/pda/index.d.ts.map +1 -1
- package/dist/types/plugin/index.d.ts.map +1 -1
- package/dist/types/registries/builder.d.ts +2 -9
- package/dist/types/registries/builder.d.ts.map +1 -1
- package/dist/types/registries/metaplex-bridge.d.ts.map +1 -1
- package/dist/types/registries/session.d.ts +3 -9
- package/dist/types/registries/session.d.ts.map +1 -1
- package/dist/types/registries/x402.d.ts +2 -9
- package/dist/types/registries/x402.d.ts.map +1 -1
- package/dist/types/types/accounts.d.ts +52 -0
- package/dist/types/types/accounts.d.ts.map +1 -1
- package/dist/types/types/index.d.ts +1 -1
- package/dist/types/types/index.d.ts.map +1 -1
- package/dist/types/utils/rpc-strategy.d.ts +7 -0
- package/dist/types/utils/rpc-strategy.d.ts.map +1 -1
- package/package.json +59 -183
- package/src/constants/addresses.ts +0 -162
- package/src/constants/index.ts +0 -69
- package/src/constants/limits.ts +0 -165
- package/src/constants/seeds.ts +0 -85
- package/src/core/client.ts +0 -583
- package/src/core/connection.ts +0 -461
- package/src/errors/index.ts +0 -346
- package/src/events/geyser.ts +0 -384
- package/src/events/index.ts +0 -335
- package/src/events/yellowstone.d.ts +0 -7
- package/src/idl/synapse_agent_sap.json +0 -14595
- package/src/index.ts +0 -421
- package/src/modules/agent.ts +0 -319
- package/src/modules/attestation.ts +0 -168
- package/src/modules/base.ts +0 -247
- package/src/modules/escrow-v2.ts +0 -871
- package/src/modules/escrow.ts +0 -439
- package/src/modules/feedback.ts +0 -186
- package/src/modules/indexing.ts +0 -444
- package/src/modules/ledger.ts +0 -262
- package/src/modules/receipt.ts +0 -212
- package/src/modules/staking.ts +0 -223
- package/src/modules/subscription.ts +0 -147
- package/src/modules/tools.ts +0 -454
- package/src/modules/vault.ts +0 -558
- package/src/parser/client.ts +0 -211
- package/src/parser/complete.ts +0 -232
- package/src/parser/inner.ts +0 -255
- package/src/parser/transaction.ts +0 -200
- package/src/parser/types.ts +0 -182
- package/src/plugin/index.ts +0 -1224
- package/src/plugin/protocols.ts +0 -404
- package/src/plugin/schemas.ts +0 -941
- package/src/postgres/adapter.ts +0 -904
- package/src/postgres/index.ts +0 -59
- package/src/postgres/schema.sql +0 -683
- package/src/postgres/serializers.ts +0 -485
- package/src/postgres/sync.ts +0 -340
- package/src/postgres/types.ts +0 -245
- package/src/registries/builder.ts +0 -607
- package/src/registries/discovery.ts +0 -572
- package/src/registries/fairscale.ts +0 -1278
- package/src/registries/index.ts +0 -143
- package/src/registries/metaplex-bridge.ts +0 -1199
- package/src/registries/session.ts +0 -613
- package/src/registries/x402.ts +0 -1048
- package/src/types/accounts.ts +0 -858
- package/src/types/common.ts +0 -187
- package/src/types/endpoint.ts +0 -181
- package/src/types/enums.ts +0 -333
- package/src/types/index.ts +0 -121
- package/src/types/instructions.ts +0 -453
- package/src/utils/anchor-errors.ts +0 -461
- package/src/utils/endpoint-validator.ts +0 -300
- package/src/utils/escrow-validation.ts +0 -301
- package/src/utils/index.ts +0 -118
- package/src/utils/merchant-validator.ts +0 -359
- package/src/utils/network-normalizer.ts +0 -240
- package/src/utils/priority-fee.ts +0 -325
- package/src/utils/rpc-strategy.ts +0 -322
- package/src/utils/schemas.ts +0 -359
- package/src/utils/x402-direct.ts +0 -370
- /package/dist/{types → esm}/modules/escrow.d.ts +0 -0
- /package/dist/{types → esm}/modules/escrow.d.ts.map +0 -0
package/src/modules/escrow-v2.ts
DELETED
|
@@ -1,871 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @module escrow-v2
|
|
3
|
-
* @description V2 escrow settlement layer — supports settlement security
|
|
4
|
-
* modes (CoSigned, DisputeWindow), receipt-based dispute resolution,
|
|
5
|
-
* pending settlements, and automatic resolution via merkle proofs.
|
|
6
|
-
*
|
|
7
|
-
* @category Modules
|
|
8
|
-
* @since v0.7.0
|
|
9
|
-
* @packageDocumentation
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
import {
|
|
13
|
-
SystemProgram,
|
|
14
|
-
type PublicKey,
|
|
15
|
-
type TransactionSignature,
|
|
16
|
-
type AccountMeta,
|
|
17
|
-
type Signer,
|
|
18
|
-
} from "@solana/web3.js";
|
|
19
|
-
import { BN } from "@coral-xyz/anchor";
|
|
20
|
-
import { BaseModule } from "./base";
|
|
21
|
-
import {
|
|
22
|
-
deriveAgent,
|
|
23
|
-
deriveAgentStats,
|
|
24
|
-
deriveEscrowV2,
|
|
25
|
-
derivePendingSettlement as derivePendingPda,
|
|
26
|
-
deriveDispute as deriveDisputePda,
|
|
27
|
-
deriveStake,
|
|
28
|
-
deriveSettlementReceipt,
|
|
29
|
-
} from "../pda";
|
|
30
|
-
import type {
|
|
31
|
-
EscrowAccountV2Data,
|
|
32
|
-
PendingSettlementData,
|
|
33
|
-
DisputeRecordData,
|
|
34
|
-
CreateEscrowV2Args,
|
|
35
|
-
} from "../types";
|
|
36
|
-
import {
|
|
37
|
-
buildPriorityFeeIxs,
|
|
38
|
-
buildRpcOptions,
|
|
39
|
-
} from "../utils/priority-fee";
|
|
40
|
-
import type { SettleOptions } from "../utils/priority-fee";
|
|
41
|
-
import { isAcceptedPaymentToken, computeRequiredStakeLamports } from "../constants/payments";
|
|
42
|
-
import { throwPredicted } from "../utils/anchor-errors";
|
|
43
|
-
import { calculateSettleAmount } from "../utils/volume-curve";
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* @name EscrowV2Module
|
|
47
|
-
* @description Manages V2 escrow accounts with settlement security modes,
|
|
48
|
-
* dispute windows, and pending settlement flows.
|
|
49
|
-
*
|
|
50
|
-
* @category Modules
|
|
51
|
-
* @since v0.7.0
|
|
52
|
-
* @extends BaseModule
|
|
53
|
-
*/
|
|
54
|
-
export class EscrowV2Module extends BaseModule {
|
|
55
|
-
// ── Helpers ──────────────────────────────────────────
|
|
56
|
-
|
|
57
|
-
/** Convert BN | number | bigint → number for PDA seed functions. */
|
|
58
|
-
private toNum(v: BN | number | bigint): number {
|
|
59
|
-
return BN.isBN(v) ? v.toNumber() : Number(v);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// ── PDA helpers ──────────────────────────────────────
|
|
63
|
-
|
|
64
|
-
deriveEscrow(
|
|
65
|
-
agentPda: PublicKey,
|
|
66
|
-
depositor?: PublicKey,
|
|
67
|
-
nonce: BN | number | bigint = 0,
|
|
68
|
-
): readonly [PublicKey, number] {
|
|
69
|
-
return deriveEscrowV2(agentPda, depositor ?? this.walletPubkey, this.toNum(nonce));
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
derivePendingSettlement(
|
|
73
|
-
escrowV2Pda: PublicKey,
|
|
74
|
-
settlementIndex: BN | number | bigint,
|
|
75
|
-
): readonly [PublicKey, number] {
|
|
76
|
-
return derivePendingPda(escrowV2Pda, this.toNum(settlementIndex));
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
deriveDispute(
|
|
80
|
-
pendingSettlementPda: PublicKey,
|
|
81
|
-
): readonly [PublicKey, number] {
|
|
82
|
-
return deriveDisputePda(pendingSettlementPda);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
// ── Instructions ─────────────────────────────────────
|
|
86
|
-
|
|
87
|
-
async create(
|
|
88
|
-
agentWallet: PublicKey,
|
|
89
|
-
args: CreateEscrowV2Args,
|
|
90
|
-
splAccounts: AccountMeta[] = [],
|
|
91
|
-
): Promise<TransactionSignature> {
|
|
92
|
-
// v0.10.0: payment-token allowlist (SOL or USDC only).
|
|
93
|
-
if (!isAcceptedPaymentToken(args.tokenMint ?? null)) {
|
|
94
|
-
throw new Error(
|
|
95
|
-
"createEscrowV2: tokenMint must be null (SOL) or USDC (mainnet/devnet). " +
|
|
96
|
-
"On-chain will reject with PaymentTokenNotAllowed.",
|
|
97
|
-
);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
// v0.12.7 preflight: mirror the on-chain settlement-security guards
|
|
101
|
-
// (escrow_v2.rs:106-115) so callers fail fast with a clear message
|
|
102
|
-
// instead of paying for a tx that aborts with `InvalidSettlementSecurity`
|
|
103
|
-
// or `CoSignerRequired`.
|
|
104
|
-
const security = args.settlementSecurity;
|
|
105
|
-
if (security === 0) {
|
|
106
|
-
throw new Error(
|
|
107
|
-
"createEscrowV2: settlementSecurity=0 (SelfReport) is deprecated since " +
|
|
108
|
-
"v0.7. Use 1 (CoSigned) or 2 (DisputeWindow). On-chain rejects with " +
|
|
109
|
-
"SelfReportDeprecated.",
|
|
110
|
-
);
|
|
111
|
-
}
|
|
112
|
-
if (security === 1 && !args.coSigner) {
|
|
113
|
-
throw new Error(
|
|
114
|
-
"createEscrowV2: settlementSecurity=1 (CoSigned) requires `coSigner` " +
|
|
115
|
-
"to be set. On-chain rejects with CoSignerRequired.",
|
|
116
|
-
);
|
|
117
|
-
}
|
|
118
|
-
if (security === 2) {
|
|
119
|
-
// The on-chain check is `dispute_window_slots > 0` — i.e. >= 1 slot.
|
|
120
|
-
// Zero would let an agent settle and immediately drain pending funds
|
|
121
|
-
// before any depositor could possibly file a dispute, defeating the
|
|
122
|
-
// entire DisputeWindow security model. Enforce client-side too.
|
|
123
|
-
const slots = BigInt(this.bn(args.disputeWindowSlots).toString());
|
|
124
|
-
if (slots < 1n) {
|
|
125
|
-
throw new Error(
|
|
126
|
-
"createEscrowV2: settlementSecurity=2 (DisputeWindow) requires " +
|
|
127
|
-
"`disputeWindowSlots >= 1` to prevent the zero-window abuse vector. " +
|
|
128
|
-
"Recommended minimum is 2_160 slots (~15 min). On-chain rejects " +
|
|
129
|
-
"with InvalidSettlementSecurity.",
|
|
130
|
-
);
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
if (security !== 0 && security !== 1 && security !== 2) {
|
|
134
|
-
throw new Error(
|
|
135
|
-
`createEscrowV2: settlementSecurity must be 1 (CoSigned) or 2 (DisputeWindow), got ${String(security)}.`,
|
|
136
|
-
);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
140
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, args.escrowNonce);
|
|
141
|
-
const [stakePda] = deriveStake(agentPda);
|
|
142
|
-
// v0.11 H-1 preflight: surface an actionable error if the agent's stake
|
|
143
|
-
// does not cover the slashable share of the new escrow. Saves a failed
|
|
144
|
-
// tx fee and gives the caller a clear top-up amount.
|
|
145
|
-
try {
|
|
146
|
-
const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
|
|
147
|
-
if (stakeAccount) {
|
|
148
|
-
const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
|
|
149
|
-
const required = computeRequiredStakeLamports(escrowLamports);
|
|
150
|
-
const have = BigInt(stakeAccount.stakedAmount.toString());
|
|
151
|
-
if (have < required) {
|
|
152
|
-
throw new Error(
|
|
153
|
-
`createEscrowV2: agent stake ${have} lamports < required ${required} ` +
|
|
154
|
-
`lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
|
|
155
|
-
);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
// If no stake account exists at all, on-chain will reject with
|
|
159
|
-
// AccountNotInitialized — we let that bubble up unchanged.
|
|
160
|
-
} catch (err) {
|
|
161
|
-
// Preflight is advisory; rethrow only the explicit coverage error.
|
|
162
|
-
if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
|
|
163
|
-
throw err;
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
// v0.11 H-1 preflight: surface an actionable error if the agent's stake
|
|
167
|
-
// does not cover the slashable share of the new escrow. Saves a failed
|
|
168
|
-
// tx fee and gives the caller a clear top-up amount.
|
|
169
|
-
try {
|
|
170
|
-
const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
|
|
171
|
-
if (stakeAccount) {
|
|
172
|
-
const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
|
|
173
|
-
const required = computeRequiredStakeLamports(escrowLamports);
|
|
174
|
-
const have = BigInt(stakeAccount.stakedAmount.toString());
|
|
175
|
-
if (have < required) {
|
|
176
|
-
throw new Error(
|
|
177
|
-
`createEscrowV2: agent stake ${have} lamports < required ${required} ` +
|
|
178
|
-
`lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
|
|
179
|
-
);
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
// If no stake account exists at all, on-chain will reject with
|
|
183
|
-
// AccountNotInitialized — we let that bubble up unchanged.
|
|
184
|
-
} catch (err) {
|
|
185
|
-
// Preflight is advisory; rethrow only the explicit coverage error.
|
|
186
|
-
if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
|
|
187
|
-
throw err;
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
return this.methods
|
|
192
|
-
.createEscrowV2(
|
|
193
|
-
this.bn(args.escrowNonce),
|
|
194
|
-
this.bn(args.pricePerCall),
|
|
195
|
-
this.bn(args.maxCalls),
|
|
196
|
-
this.bn(args.initialDeposit),
|
|
197
|
-
args.expiresAt,
|
|
198
|
-
args.volumeCurve,
|
|
199
|
-
args.tokenMint,
|
|
200
|
-
args.tokenDecimals,
|
|
201
|
-
args.settlementSecurity,
|
|
202
|
-
this.bn(args.disputeWindowSlots),
|
|
203
|
-
args.coSigner,
|
|
204
|
-
args.arbiter,
|
|
205
|
-
)
|
|
206
|
-
.accounts({
|
|
207
|
-
depositor: this.walletPubkey,
|
|
208
|
-
agent: agentPda,
|
|
209
|
-
agentStake: stakePda,
|
|
210
|
-
escrow: escrowPda,
|
|
211
|
-
systemProgram: SystemProgram.programId,
|
|
212
|
-
})
|
|
213
|
-
.remainingAccounts(splAccounts)
|
|
214
|
-
.rpc();
|
|
215
|
-
}
|
|
216
|
-
|
|
217
|
-
async deposit(
|
|
218
|
-
agentWallet: PublicKey,
|
|
219
|
-
nonce: BN | number | bigint,
|
|
220
|
-
amount: BN | number | bigint,
|
|
221
|
-
splAccounts: AccountMeta[] = [],
|
|
222
|
-
): Promise<TransactionSignature> {
|
|
223
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
224
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
225
|
-
|
|
226
|
-
// v0.13.0 preflights — escrow exists, token shape matches, amount > 0
|
|
227
|
-
const escrow = await this.requireAccountExists<EscrowAccountV2Data>(
|
|
228
|
-
"escrowAccountV2",
|
|
229
|
-
escrowPda,
|
|
230
|
-
{ predicted: "NotAuthority", hint: "Escrow V2 PDA not found — call createEscrow first" },
|
|
231
|
-
);
|
|
232
|
-
const want = BigInt(this.bn(amount).toString());
|
|
233
|
-
if (want <= 0n) throwPredicted("InsufficientEscrowBalance", "Deposit amount must be > 0");
|
|
234
|
-
const isSpl = escrow.tokenMint != null;
|
|
235
|
-
if (isSpl && splAccounts.length < 4) {
|
|
236
|
-
throwPredicted("SplTokenRequired", "Pass [depositorAta, escrowAta, tokenMint, tokenProgram]");
|
|
237
|
-
}
|
|
238
|
-
if (!isSpl && splAccounts.length > 0) {
|
|
239
|
-
throwPredicted("InvalidTokenAccount", "SOL escrow does not accept splAccounts");
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
return this.methods
|
|
243
|
-
.depositEscrowV2(this.bn(nonce), this.bn(amount))
|
|
244
|
-
.accounts({
|
|
245
|
-
depositor: this.walletPubkey,
|
|
246
|
-
escrow: escrowPda,
|
|
247
|
-
systemProgram: SystemProgram.programId,
|
|
248
|
-
})
|
|
249
|
-
.remainingAccounts(splAccounts)
|
|
250
|
-
.rpc();
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
/**
|
|
254
|
-
* Settle a batch of calls against a V2 escrow.
|
|
255
|
-
*
|
|
256
|
-
* **v0.13.0 — Auto-bundle DisputeWindow:** when the escrow's
|
|
257
|
-
* `settlementSecurity` is `DisputeWindow`, this method now bundles
|
|
258
|
-
* **`settleCallsV2` + `createPendingSettlement`** into the SAME
|
|
259
|
-
* transaction. This eliminates the foot-gun where a caller would call
|
|
260
|
-
* `createPendingSettlement` directly without a preceding `settleCallsV2`,
|
|
261
|
-
* leaving `escrow.pending_amount = 0` and causing `finalizeSettlement`
|
|
262
|
-
* to abort with `ArithmeticOverflow` (6075).
|
|
263
|
-
*
|
|
264
|
-
* Flow per security mode:
|
|
265
|
-
* - **CoSigned** — single IX (`settleCallsV2`) with co-signer in
|
|
266
|
-
* remaining accounts; funds move immediately.
|
|
267
|
-
* - **DisputeWindow** — two IXs in one tx:
|
|
268
|
-
* 1. `settleCallsV2` — bumps `pending_amount` and `settlement_index`
|
|
269
|
-
* 2. `createPendingSettlement(idx)` — locks the dispute tracker PDA
|
|
270
|
-
*
|
|
271
|
-
* After this tx confirms, wait `escrow.disputeWindowSlots` slots and
|
|
272
|
-
* call {@link finalizeSettlement} with the index returned via
|
|
273
|
-
* `SettlementPendingEvent` or readable from `escrow.settlement_index - 1`.
|
|
274
|
-
*
|
|
275
|
-
* Pass `opts.skipAutoPending = true` to opt out of the auto-bundle (e.g.
|
|
276
|
-
* if you want to drive `createPendingSettlement` separately for advanced
|
|
277
|
-
* flows like batched off-chain receipt aggregation).
|
|
278
|
-
*
|
|
279
|
-
* @param depositorWallet - Depositor of the escrow being settled.
|
|
280
|
-
* @param nonce - Escrow nonce (default 0 for the canonical escrow).
|
|
281
|
-
* @param callsToSettle - Number of calls to settle in this batch.
|
|
282
|
-
* @param serviceHash - 32-byte sha256 of the service payload.
|
|
283
|
-
* @param splAccounts - Optional remaining accounts (SPL transfer + co-signer).
|
|
284
|
-
* @param opts - Priority-fee + auto-pending options.
|
|
285
|
-
* @param coSigner - Required for CoSigned escrows.
|
|
286
|
-
* @returns The transaction signature.
|
|
287
|
-
* @since v0.7.0 — initial release
|
|
288
|
-
* @since v0.13.0 — auto-bundles `createPendingSettlement` for DisputeWindow
|
|
289
|
-
*/
|
|
290
|
-
async settle(
|
|
291
|
-
depositorWallet: PublicKey,
|
|
292
|
-
nonce: BN | number | bigint,
|
|
293
|
-
callsToSettle: BN | number | bigint,
|
|
294
|
-
serviceHash: number[],
|
|
295
|
-
splAccounts: AccountMeta[] = [],
|
|
296
|
-
opts?: SettleOptions & {
|
|
297
|
-
/**
|
|
298
|
-
* v0.13.0 — Opt out of the DisputeWindow auto-bundle. When `true`,
|
|
299
|
-
* `settle()` only emits `settleCallsV2` and the caller is responsible
|
|
300
|
-
* for sending `createPendingSettlement` afterwards (legacy 2-tx flow).
|
|
301
|
-
* Default: `false` (auto-bundle is on).
|
|
302
|
-
*/
|
|
303
|
-
skipAutoPending?: boolean;
|
|
304
|
-
/**
|
|
305
|
-
* v0.13.0 — `receiptMerkleRoot` to inscribe in the auto-bundled
|
|
306
|
-
* `createPendingSettlement`. Defaults to 32 zero bytes (no receipt
|
|
307
|
-
* batch). Ignored when `skipAutoPending = true`.
|
|
308
|
-
*/
|
|
309
|
-
receiptMerkleRoot?: number[];
|
|
310
|
-
},
|
|
311
|
-
coSigner?: Signer,
|
|
312
|
-
): Promise<TransactionSignature> {
|
|
313
|
-
const [agentPda] = deriveAgent(this.walletPubkey);
|
|
314
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
315
|
-
const [statsPda] = deriveAgentStats(agentPda);
|
|
316
|
-
const [receiptPda] = deriveSettlementReceipt(escrowPda, serviceHash);
|
|
317
|
-
|
|
318
|
-
const preIxs = buildPriorityFeeIxs(opts);
|
|
319
|
-
const rpcOpts = buildRpcOptions(opts);
|
|
320
|
-
|
|
321
|
-
// CoSigned escrows require the co-signer to appear in
|
|
322
|
-
// remaining_accounts with `is_signer = true` AND to actually sign
|
|
323
|
-
// the transaction (Anchor on-chain checks `acc.is_signer`).
|
|
324
|
-
// We dedupe so callers can also pass it manually via splAccounts.
|
|
325
|
-
const remaining: AccountMeta[] = coSigner
|
|
326
|
-
? [
|
|
327
|
-
...splAccounts.filter((a) => !a.pubkey.equals(coSigner.publicKey)),
|
|
328
|
-
{ pubkey: coSigner.publicKey, isSigner: true, isWritable: false },
|
|
329
|
-
]
|
|
330
|
-
: splAccounts;
|
|
331
|
-
|
|
332
|
-
// ── v0.13.0 preflight: fetch escrow once to drive both branches ──
|
|
333
|
-
// We need it to (a) detect DisputeWindow vs CoSigned, (b) read the
|
|
334
|
-
// current `settlement_index` to feed `createPendingSettlement`, and
|
|
335
|
-
// (c) compute `amount` via the volume curve so the bundled IX matches
|
|
336
|
-
// what `settle_calls_v2` will compute on-chain.
|
|
337
|
-
const escrowAcc = await this.fetchAccountNullable<EscrowAccountV2Data>(
|
|
338
|
-
"escrowAccountV2",
|
|
339
|
-
escrowPda,
|
|
340
|
-
);
|
|
341
|
-
if (!escrowAcc) {
|
|
342
|
-
throw new Error(
|
|
343
|
-
`escrowV2.settle: escrow PDA ${escrowPda.toBase58()} not found on-chain ` +
|
|
344
|
-
`(agent=${agentPda.toBase58()}, depositor=${depositorWallet.toBase58()}, nonce=${this.bn(nonce).toString()}). ` +
|
|
345
|
-
`Did the depositor call escrowV2.create() yet?`,
|
|
346
|
-
);
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
const isDisputeWindow =
|
|
350
|
-
typeof escrowAcc.settlementSecurity === "object" &&
|
|
351
|
-
escrowAcc.settlementSecurity !== null &&
|
|
352
|
-
"disputeWindow" in (escrowAcc.settlementSecurity as Record<string, unknown>);
|
|
353
|
-
|
|
354
|
-
let builder = this.methods
|
|
355
|
-
.settleCallsV2(this.bn(nonce), this.bn(callsToSettle), serviceHash)
|
|
356
|
-
.accountsPartial({
|
|
357
|
-
wallet: this.walletPubkey,
|
|
358
|
-
agent: agentPda,
|
|
359
|
-
agentStats: statsPda,
|
|
360
|
-
escrow: escrowPda,
|
|
361
|
-
settlementReceipt: receiptPda,
|
|
362
|
-
systemProgram: SystemProgram.programId,
|
|
363
|
-
})
|
|
364
|
-
.remainingAccounts(remaining);
|
|
365
|
-
|
|
366
|
-
if (coSigner) {
|
|
367
|
-
builder = builder.signers([coSigner]);
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
if (preIxs.length > 0) {
|
|
371
|
-
builder = builder.preInstructions(preIxs);
|
|
372
|
-
}
|
|
373
|
-
|
|
374
|
-
// ── v0.13.0: auto-bundle createPendingSettlement on DisputeWindow ──
|
|
375
|
-
// The on-chain `settle_calls_v2_handler` (DisputeWindow branch) only
|
|
376
|
-
// bumps `escrow.pending_amount` and `escrow.settlement_index` — it
|
|
377
|
-
// does NOT create the PendingSettlement PDA. Without the followup
|
|
378
|
-
// `createPendingSettlement` IX in the SAME tx, a buggy caller can
|
|
379
|
-
// (a) call `createPendingSettlement` later with a stale index, or
|
|
380
|
-
// (b) skip `settleCallsV2` entirely on a fresh escrow → orphan PDA
|
|
381
|
-
// whose `amount > escrow.pending_amount` → finalize aborts forever
|
|
382
|
-
// with `ArithmeticOverflow` (6075). Bundling is the only way to
|
|
383
|
-
// make that race impossible.
|
|
384
|
-
const skipAutoPending = opts?.skipAutoPending === true;
|
|
385
|
-
if (isDisputeWindow && !skipAutoPending) {
|
|
386
|
-
// PRE-increment settlement_index — settle_calls_v2 will bump it
|
|
387
|
-
// to (current + 1) AFTER our IX runs, but the PDA seed used by
|
|
388
|
-
// create_pending_settlement is the PRE-increment value (matches
|
|
389
|
-
// `SettlementPendingEvent.settlement_index`).
|
|
390
|
-
const settlementIndex = escrowAcc.settlementIndex;
|
|
391
|
-
|
|
392
|
-
// Mirror the on-chain volume-curve math so `pending.amount`
|
|
393
|
-
// matches what `escrow.pending_amount` was bumped by.
|
|
394
|
-
const totalCallsBefore = escrowAcc.totalCallsSettled.add(escrowAcc.pendingCalls);
|
|
395
|
-
const amount = calculateSettleAmount(
|
|
396
|
-
escrowAcc.pricePerCall,
|
|
397
|
-
escrowAcc.volumeCurve,
|
|
398
|
-
totalCallsBefore,
|
|
399
|
-
this.bn(callsToSettle),
|
|
400
|
-
);
|
|
401
|
-
|
|
402
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
403
|
-
|
|
404
|
-
// Defensive: if a stale pending PDA exists at this index (orphan
|
|
405
|
-
// from an aborted prior run), refuse to send — otherwise the IX
|
|
406
|
-
// will fail with `Allocate: account already in use` (custom 0x0).
|
|
407
|
-
const existing = await this.provider.connection.getAccountInfo(pendingPda);
|
|
408
|
-
if (existing) {
|
|
409
|
-
throw new Error(
|
|
410
|
-
`escrowV2.settle (auto-bundle): pending PDA ${pendingPda.toBase58()} ` +
|
|
411
|
-
`already exists for settlementIndex=${settlementIndex.toString()}. ` +
|
|
412
|
-
`An earlier run created it but did not finalize. Either finalize ` +
|
|
413
|
-
`that index first or skip it permanently. (Pass skipAutoPending=true ` +
|
|
414
|
-
`to bypass this guard and emit only settleCallsV2.)`,
|
|
415
|
-
);
|
|
416
|
-
}
|
|
417
|
-
|
|
418
|
-
const receiptMerkleRoot = opts?.receiptMerkleRoot ?? new Array(32).fill(0);
|
|
419
|
-
const pendingIx = await this.methods
|
|
420
|
-
.createPendingSettlement(
|
|
421
|
-
settlementIndex,
|
|
422
|
-
this.bn(callsToSettle),
|
|
423
|
-
amount,
|
|
424
|
-
serviceHash,
|
|
425
|
-
receiptMerkleRoot,
|
|
426
|
-
)
|
|
427
|
-
.accounts({
|
|
428
|
-
wallet: this.walletPubkey,
|
|
429
|
-
agent: agentPda,
|
|
430
|
-
escrow: escrowPda,
|
|
431
|
-
pendingSettlement: pendingPda,
|
|
432
|
-
systemProgram: SystemProgram.programId,
|
|
433
|
-
})
|
|
434
|
-
.instruction();
|
|
435
|
-
|
|
436
|
-
builder = builder.postInstructions([pendingIx]);
|
|
437
|
-
}
|
|
438
|
-
|
|
439
|
-
return builder.rpc(rpcOpts);
|
|
440
|
-
}
|
|
441
|
-
|
|
442
|
-
/**
|
|
443
|
-
* Read the current `escrow.settlement_index` from chain.
|
|
444
|
-
*
|
|
445
|
-
* In DisputeWindow mode (`settlementSecurity = 2`), every successful
|
|
446
|
-
* `settleCallsV2` increments this value. The PRE-increment value is the
|
|
447
|
-
* one to pass to {@link createPendingSettlement} for that batch.
|
|
448
|
-
*
|
|
449
|
-
* @returns the current `settlementIndex` as `bigint` (next index to use
|
|
450
|
-
* for `createPendingSettlement` if you have NOT yet called `settle` for
|
|
451
|
-
* it; if you HAVE just settled, subtract 1 — but prefer the event
|
|
452
|
-
* `SettlementPendingEvent.settlement_index` over arithmetic).
|
|
453
|
-
* @since v0.12.8
|
|
454
|
-
*/
|
|
455
|
-
async nextSettlementIndex(
|
|
456
|
-
agentWallet: PublicKey,
|
|
457
|
-
depositorWallet: PublicKey,
|
|
458
|
-
nonce: BN | number | bigint,
|
|
459
|
-
): Promise<bigint> {
|
|
460
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
461
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
462
|
-
const escrow = await this.fetchAccountNullable<EscrowAccountV2Data>(
|
|
463
|
-
"escrowAccountV2",
|
|
464
|
-
escrowPda,
|
|
465
|
-
);
|
|
466
|
-
if (!escrow) {
|
|
467
|
-
throw new Error(
|
|
468
|
-
`nextSettlementIndex: escrow PDA ${escrowPda.toBase58()} not found on-chain`,
|
|
469
|
-
);
|
|
470
|
-
}
|
|
471
|
-
return BigInt(escrow.settlementIndex.toString());
|
|
472
|
-
}
|
|
473
|
-
|
|
474
|
-
/**
|
|
475
|
-
* Create the PendingSettlement PDA for a DisputeWindow batch.
|
|
476
|
-
*
|
|
477
|
-
* **v0.13.0 NOTE:** in almost all cases you should call
|
|
478
|
-
* {@link settle} instead — it auto-bundles `settleCallsV2 +
|
|
479
|
-
* createPendingSettlement` in a single transaction so the two
|
|
480
|
-
* cannot drift out of sync. Use this method standalone ONLY when
|
|
481
|
-
* you intentionally pass `skipAutoPending: true` to `settle()`
|
|
482
|
-
* (e.g. batched receipt-merkle aggregation across multiple
|
|
483
|
-
* `settleCallsV2` runs).
|
|
484
|
-
*
|
|
485
|
-
* Calling this without a preceding `settleCallsV2` (which bumps
|
|
486
|
-
* `escrow.pending_amount`) creates an orphan PDA whose
|
|
487
|
-
* `pending.amount > escrow.pending_amount` — `finalizeSettlement`
|
|
488
|
-
* will then abort with `ArithmeticOverflow` (6075) forever.
|
|
489
|
-
*
|
|
490
|
-
* @since v0.7.0
|
|
491
|
-
*/
|
|
492
|
-
async createPendingSettlement(
|
|
493
|
-
agentWallet: PublicKey,
|
|
494
|
-
depositorWallet: PublicKey,
|
|
495
|
-
nonce: BN | number | bigint,
|
|
496
|
-
settlementIndex: BN | number | bigint,
|
|
497
|
-
callsToSettle: BN | number | bigint,
|
|
498
|
-
amount: BN | number | bigint,
|
|
499
|
-
serviceHash: number[],
|
|
500
|
-
receiptMerkleRoot: number[] = new Array(32).fill(0),
|
|
501
|
-
): Promise<TransactionSignature> {
|
|
502
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
503
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
504
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
505
|
-
|
|
506
|
-
// v0.12.8: preflight against the "Allocate: account already in use"
|
|
507
|
-
// SystemProgram error (custom 0x0). The pending_settlement PDA is
|
|
508
|
-
// seeded on `escrow + settlement_index`, so reusing the same index
|
|
509
|
-
// (e.g. always 0, or a stale retry value) collides with an existing
|
|
510
|
-
// account. Fail fast with an actionable message instead of burning a
|
|
511
|
-
// failed tx fee on simulation.
|
|
512
|
-
const existing = await this.provider.connection.getAccountInfo(pendingPda);
|
|
513
|
-
if (existing) {
|
|
514
|
-
const idx = this.bn(settlementIndex).toString();
|
|
515
|
-
throw new Error(
|
|
516
|
-
`createPendingSettlement: pending PDA ${pendingPda.toBase58()} ` +
|
|
517
|
-
`already exists for settlementIndex=${idx}. ` +
|
|
518
|
-
`Use EscrowV2Module.nextSettlementIndex() to read the current ` +
|
|
519
|
-
`escrow.settlement_index, or capture SettlementPendingEvent.settlement_index ` +
|
|
520
|
-
`from the preceding settleCallsV2 tx. Reusing a settlementIndex ` +
|
|
521
|
-
`causes SystemProgram Allocate (custom 0x0) failures.`,
|
|
522
|
-
);
|
|
523
|
-
}
|
|
524
|
-
|
|
525
|
-
return this.methods
|
|
526
|
-
.createPendingSettlement(
|
|
527
|
-
this.bn(settlementIndex),
|
|
528
|
-
this.bn(callsToSettle),
|
|
529
|
-
this.bn(amount),
|
|
530
|
-
serviceHash,
|
|
531
|
-
receiptMerkleRoot,
|
|
532
|
-
)
|
|
533
|
-
.accounts({
|
|
534
|
-
wallet: this.walletPubkey,
|
|
535
|
-
agent: agentPda,
|
|
536
|
-
escrow: escrowPda,
|
|
537
|
-
pendingSettlement: pendingPda,
|
|
538
|
-
systemProgram: SystemProgram.programId,
|
|
539
|
-
})
|
|
540
|
-
.rpc();
|
|
541
|
-
}
|
|
542
|
-
|
|
543
|
-
async finalizeSettlement(
|
|
544
|
-
agentWallet: PublicKey,
|
|
545
|
-
depositorWallet: PublicKey,
|
|
546
|
-
nonce: BN | number | bigint,
|
|
547
|
-
settlementIndex: BN | number | bigint,
|
|
548
|
-
): Promise<TransactionSignature> {
|
|
549
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
550
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
551
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
552
|
-
const [statsPda] = deriveAgentStats(agentPda);
|
|
553
|
-
|
|
554
|
-
// v0.12.9: preflight against ArithmeticOverflow at finalize.
|
|
555
|
-
//
|
|
556
|
-
// The on-chain handler subtracts `pending_settlement.amount` from BOTH
|
|
557
|
-
// `escrow.balance` AND `escrow.pending_amount`. If the PendingSettlement
|
|
558
|
-
// PDA was created without a preceding `settle_calls_v2` (orphan PDA from
|
|
559
|
-
// legacy probe loops, or a buggy caller that skipped the settle step),
|
|
560
|
-
// `escrow.pending_amount` is smaller than `pending_settlement.amount`
|
|
561
|
-
// and the program aborts with ArithmeticOverflow (error 6075) at
|
|
562
|
-
// escrow_v2.rs:633. Each retry burns ~5 000 lamports of base fee.
|
|
563
|
-
//
|
|
564
|
-
// Detect this BEFORE signing and throw with a clear, actionable message
|
|
565
|
-
// pointing at the orphan-recovery path.
|
|
566
|
-
const [escrowAcc, pendingAcc] = await Promise.all([
|
|
567
|
-
this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
|
|
568
|
-
this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
|
|
569
|
-
]);
|
|
570
|
-
if (!escrowAcc) {
|
|
571
|
-
throw new Error(
|
|
572
|
-
`finalizeSettlement: escrow PDA ${escrowPda.toBase58()} not found on-chain.`,
|
|
573
|
-
);
|
|
574
|
-
}
|
|
575
|
-
if (!pendingAcc) {
|
|
576
|
-
throw new Error(
|
|
577
|
-
`finalizeSettlement: pending PDA ${pendingPda.toBase58()} not found on-chain ` +
|
|
578
|
-
`(settlementIndex=${settlementIndex.toString()}). Nothing to finalize.`,
|
|
579
|
-
);
|
|
580
|
-
}
|
|
581
|
-
const psAmount = BigInt(pendingAcc.amount.toString());
|
|
582
|
-
const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
|
|
583
|
-
const escrowBalance = BigInt(escrowAcc.balance.toString());
|
|
584
|
-
if (psAmount > escrowPendingAmount || psAmount > escrowBalance) {
|
|
585
|
-
throw new Error(
|
|
586
|
-
`finalizeSettlement: orphan/inconsistent PendingSettlement detected ` +
|
|
587
|
-
`at ${pendingPda.toBase58()} (settlementIndex=${settlementIndex.toString()}). ` +
|
|
588
|
-
`pending.amount=${psAmount} but escrow.pending_amount=${escrowPendingAmount}, ` +
|
|
589
|
-
`escrow.balance=${escrowBalance}. The on-chain finalize would abort with ` +
|
|
590
|
-
`ArithmeticOverflow (6075). This PDA was almost certainly created by a ` +
|
|
591
|
-
`caller that skipped settle_calls_v2 (legacy probe loop). It cannot be ` +
|
|
592
|
-
`finalized and cannot be closed (close_pending_settlement requires ` +
|
|
593
|
-
`is_finalized=true). Skip this index permanently in your settle queue.`,
|
|
594
|
-
);
|
|
595
|
-
}
|
|
596
|
-
|
|
597
|
-
return this.methods
|
|
598
|
-
.finalizeSettlement()
|
|
599
|
-
.accounts({
|
|
600
|
-
payer: this.walletPubkey,
|
|
601
|
-
agentWallet,
|
|
602
|
-
escrow: escrowPda,
|
|
603
|
-
pendingSettlement: pendingPda,
|
|
604
|
-
agentStats: statsPda,
|
|
605
|
-
})
|
|
606
|
-
.rpc();
|
|
607
|
-
}
|
|
608
|
-
|
|
609
|
-
/**
|
|
610
|
-
* Identify orphan PendingSettlement PDAs that cannot be finalized.
|
|
611
|
-
*
|
|
612
|
-
* @returns `null` if the PDA is finalizable (or already finalized / disputed).
|
|
613
|
-
* Otherwise an object describing the inconsistency, suitable for
|
|
614
|
-
* logging or feeding into a quarantine list. Use this from a
|
|
615
|
-
* recovery script to scan a range of `settlement_index` values:
|
|
616
|
-
*
|
|
617
|
-
* ```ts
|
|
618
|
-
* for (let idx = 0n; idx < currentIdx; idx++) {
|
|
619
|
-
* const orphan = await sap.escrowV2.diagnoseOrphanPending(
|
|
620
|
-
* agentWallet, depositorWallet, nonce, idx,
|
|
621
|
-
* );
|
|
622
|
-
* if (orphan) log.warn({ idx, ...orphan }, "skip orphan");
|
|
623
|
-
* }
|
|
624
|
-
* ```
|
|
625
|
-
*
|
|
626
|
-
* @since v0.12.9
|
|
627
|
-
*/
|
|
628
|
-
async diagnoseOrphanPending(
|
|
629
|
-
agentWallet: PublicKey,
|
|
630
|
-
depositorWallet: PublicKey,
|
|
631
|
-
nonce: BN | number | bigint,
|
|
632
|
-
settlementIndex: BN | number | bigint,
|
|
633
|
-
): Promise<{
|
|
634
|
-
pendingPda: PublicKey;
|
|
635
|
-
psAmount: bigint;
|
|
636
|
-
escrowPendingAmount: bigint;
|
|
637
|
-
escrowBalance: bigint;
|
|
638
|
-
isFinalized: boolean;
|
|
639
|
-
isDisputed: boolean;
|
|
640
|
-
reason: "ok" | "missing" | "amount_exceeds_pending" | "amount_exceeds_balance" | "already_finalized" | "disputed";
|
|
641
|
-
} | null> {
|
|
642
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
643
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
644
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
645
|
-
const [escrowAcc, pendingAcc] = await Promise.all([
|
|
646
|
-
this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
|
|
647
|
-
this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
|
|
648
|
-
]);
|
|
649
|
-
if (!escrowAcc) return null;
|
|
650
|
-
if (!pendingAcc) {
|
|
651
|
-
return {
|
|
652
|
-
pendingPda,
|
|
653
|
-
psAmount: 0n,
|
|
654
|
-
escrowPendingAmount: BigInt(escrowAcc.pendingAmount.toString()),
|
|
655
|
-
escrowBalance: BigInt(escrowAcc.balance.toString()),
|
|
656
|
-
isFinalized: false,
|
|
657
|
-
isDisputed: false,
|
|
658
|
-
reason: "missing",
|
|
659
|
-
};
|
|
660
|
-
}
|
|
661
|
-
const psAmount = BigInt(pendingAcc.amount.toString());
|
|
662
|
-
const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
|
|
663
|
-
const escrowBalance = BigInt(escrowAcc.balance.toString());
|
|
664
|
-
const base = {
|
|
665
|
-
pendingPda,
|
|
666
|
-
psAmount,
|
|
667
|
-
escrowPendingAmount,
|
|
668
|
-
escrowBalance,
|
|
669
|
-
isFinalized: pendingAcc.isFinalized,
|
|
670
|
-
isDisputed: pendingAcc.isDisputed,
|
|
671
|
-
};
|
|
672
|
-
if (pendingAcc.isFinalized) return { ...base, reason: "already_finalized" };
|
|
673
|
-
if (pendingAcc.isDisputed) return { ...base, reason: "disputed" };
|
|
674
|
-
if (psAmount > escrowPendingAmount) return { ...base, reason: "amount_exceeds_pending" };
|
|
675
|
-
if (psAmount > escrowBalance) return { ...base, reason: "amount_exceeds_balance" };
|
|
676
|
-
return null;
|
|
677
|
-
}
|
|
678
|
-
|
|
679
|
-
async fileDispute(
|
|
680
|
-
agentWallet: PublicKey,
|
|
681
|
-
nonce: BN | number | bigint,
|
|
682
|
-
settlementIndex: BN | number | bigint,
|
|
683
|
-
evidenceHash: number[],
|
|
684
|
-
disputeType: number = 0,
|
|
685
|
-
): Promise<TransactionSignature> {
|
|
686
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
687
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
688
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
689
|
-
const [disputePda] = this.deriveDispute(pendingPda);
|
|
690
|
-
|
|
691
|
-
return this.methods
|
|
692
|
-
.fileDispute(evidenceHash, disputeType)
|
|
693
|
-
.accounts({
|
|
694
|
-
depositor: this.walletPubkey,
|
|
695
|
-
escrow: escrowPda,
|
|
696
|
-
pendingSettlement: pendingPda,
|
|
697
|
-
dispute: disputePda,
|
|
698
|
-
systemProgram: SystemProgram.programId,
|
|
699
|
-
})
|
|
700
|
-
.rpc();
|
|
701
|
-
}
|
|
702
|
-
|
|
703
|
-
/**
|
|
704
|
-
* @deprecated Since v0.7.0 — Arbiter-based resolution removed.
|
|
705
|
-
* Use {@link ReceiptModule.submitReceiptProof} + {@link ReceiptModule.autoResolveDispute} instead.
|
|
706
|
-
*/
|
|
707
|
-
async resolveDispute(
|
|
708
|
-
_depositorWallet: PublicKey,
|
|
709
|
-
_agentWallet: PublicKey,
|
|
710
|
-
_nonce: BN | number | bigint,
|
|
711
|
-
_settlementIndex: BN | number | bigint,
|
|
712
|
-
_outcome: number,
|
|
713
|
-
): Promise<TransactionSignature> {
|
|
714
|
-
throw new Error("resolveDispute removed in v0.7.0 — use ReceiptModule.autoResolveDispute");
|
|
715
|
-
}
|
|
716
|
-
|
|
717
|
-
async closeDispute(
|
|
718
|
-
pendingSettlementPda: PublicKey,
|
|
719
|
-
): Promise<TransactionSignature> {
|
|
720
|
-
const [disputePda] = this.deriveDispute(pendingSettlementPda);
|
|
721
|
-
|
|
722
|
-
return this.methods
|
|
723
|
-
.closeDispute()
|
|
724
|
-
.accounts({
|
|
725
|
-
depositor: this.walletPubkey,
|
|
726
|
-
dispute: disputePda,
|
|
727
|
-
})
|
|
728
|
-
.rpc();
|
|
729
|
-
}
|
|
730
|
-
|
|
731
|
-
async closePendingSettlement(
|
|
732
|
-
pendingSettlementPda: PublicKey,
|
|
733
|
-
): Promise<TransactionSignature> {
|
|
734
|
-
return this.methods
|
|
735
|
-
.closePendingSettlement()
|
|
736
|
-
.accounts({
|
|
737
|
-
payer: this.walletPubkey,
|
|
738
|
-
pendingSettlement: pendingSettlementPda,
|
|
739
|
-
})
|
|
740
|
-
.rpc();
|
|
741
|
-
}
|
|
742
|
-
|
|
743
|
-
async withdraw(
|
|
744
|
-
agentWallet: PublicKey,
|
|
745
|
-
nonce: BN | number | bigint,
|
|
746
|
-
amount: BN | number | bigint,
|
|
747
|
-
): Promise<TransactionSignature> {
|
|
748
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
749
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
750
|
-
|
|
751
|
-
// v0.13.0 preflight — amount must fit (balance - pendingAmount); the
|
|
752
|
-
// on-chain handler subtracts pending_amount from withdrawable funds.
|
|
753
|
-
const escrow = await this.requireAccountExists<EscrowAccountV2Data>(
|
|
754
|
-
"escrowAccountV2",
|
|
755
|
-
escrowPda,
|
|
756
|
-
{ predicted: "NotAuthority", hint: "Escrow V2 PDA not found" },
|
|
757
|
-
);
|
|
758
|
-
const want = BigInt(this.bn(amount).toString());
|
|
759
|
-
if (want <= 0n) throwPredicted("InsufficientEscrowBalance", "Withdraw amount must be > 0");
|
|
760
|
-
const balance = BigInt(escrow.balance.toString());
|
|
761
|
-
const pending = BigInt(escrow.pendingAmount.toString());
|
|
762
|
-
const free = balance > pending ? balance - pending : 0n;
|
|
763
|
-
if (want > free) {
|
|
764
|
-
throwPredicted(
|
|
765
|
-
"InsufficientEscrowBalance",
|
|
766
|
-
`requested ${want}, withdrawable ${free} (balance ${balance} − pending ${pending})`,
|
|
767
|
-
);
|
|
768
|
-
}
|
|
769
|
-
|
|
770
|
-
return this.methods
|
|
771
|
-
.withdrawEscrowV2(this.bn(amount))
|
|
772
|
-
.accounts({
|
|
773
|
-
depositor: this.walletPubkey,
|
|
774
|
-
escrow: escrowPda,
|
|
775
|
-
})
|
|
776
|
-
.rpc();
|
|
777
|
-
}
|
|
778
|
-
|
|
779
|
-
async close(
|
|
780
|
-
agentWallet: PublicKey,
|
|
781
|
-
nonce: BN | number | bigint = 0,
|
|
782
|
-
): Promise<TransactionSignature> {
|
|
783
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
784
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
785
|
-
|
|
786
|
-
// v0.13.0 preflight — close fails if balance != 0 OR pending_amount != 0.
|
|
787
|
-
// Pending != 0 commonly indicates orphan PendingSettlement PDAs;
|
|
788
|
-
// run diagnoseOrphanPending() across the index range to identify them.
|
|
789
|
-
const escrow = await this.requireAccountExists<EscrowAccountV2Data>(
|
|
790
|
-
"escrowAccountV2",
|
|
791
|
-
escrowPda,
|
|
792
|
-
{ predicted: "NotAuthority", hint: "Escrow V2 PDA already closed" },
|
|
793
|
-
);
|
|
794
|
-
const balance = BigInt(escrow.balance.toString());
|
|
795
|
-
const pending = BigInt(escrow.pendingAmount.toString());
|
|
796
|
-
if (balance !== 0n) {
|
|
797
|
-
throwPredicted("EscrowNotEmpty", `balance ${balance} > 0 — withdraw first`);
|
|
798
|
-
}
|
|
799
|
-
if (pending !== 0n) {
|
|
800
|
-
throwPredicted(
|
|
801
|
-
"EscrowNotClosed",
|
|
802
|
-
`pending_amount ${pending} > 0 — finalize all PendingSettlements first or quarantine orphans via diagnoseOrphanPending`,
|
|
803
|
-
);
|
|
804
|
-
}
|
|
805
|
-
|
|
806
|
-
return this.methods
|
|
807
|
-
.closeEscrowV2()
|
|
808
|
-
.accounts({
|
|
809
|
-
depositor: this.walletPubkey,
|
|
810
|
-
escrow: escrowPda,
|
|
811
|
-
})
|
|
812
|
-
.rpc();
|
|
813
|
-
}
|
|
814
|
-
|
|
815
|
-
/**
|
|
816
|
-
* @deprecated Since v0.7.0 — Migration instruction removed from program.
|
|
817
|
-
*/
|
|
818
|
-
async migrateFromV1(
|
|
819
|
-
_agentWallet: PublicKey,
|
|
820
|
-
): Promise<TransactionSignature> {
|
|
821
|
-
throw new Error("migrateFromV1 removed in v0.7.0 — migration instruction was deleted");
|
|
822
|
-
}
|
|
823
|
-
|
|
824
|
-
// ── Fetchers ─────────────────────────────────────────
|
|
825
|
-
|
|
826
|
-
async fetch(
|
|
827
|
-
agentPda: PublicKey,
|
|
828
|
-
depositor?: PublicKey,
|
|
829
|
-
nonce: BN | number | bigint = 0,
|
|
830
|
-
): Promise<EscrowAccountV2Data> {
|
|
831
|
-
const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
|
|
832
|
-
return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", pda);
|
|
833
|
-
}
|
|
834
|
-
|
|
835
|
-
async fetchNullable(
|
|
836
|
-
agentPda: PublicKey,
|
|
837
|
-
depositor?: PublicKey,
|
|
838
|
-
nonce: BN | number | bigint = 0,
|
|
839
|
-
): Promise<EscrowAccountV2Data | null> {
|
|
840
|
-
const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
|
|
841
|
-
return this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", pda);
|
|
842
|
-
}
|
|
843
|
-
|
|
844
|
-
async fetchByPda(escrowPda: PublicKey): Promise<EscrowAccountV2Data> {
|
|
845
|
-
return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", escrowPda);
|
|
846
|
-
}
|
|
847
|
-
|
|
848
|
-
async fetchPendingSettlement(
|
|
849
|
-
pendingPda: PublicKey,
|
|
850
|
-
): Promise<PendingSettlementData> {
|
|
851
|
-
return this.fetchAccount<PendingSettlementData>("pendingSettlement", pendingPda);
|
|
852
|
-
}
|
|
853
|
-
|
|
854
|
-
async fetchPendingSettlementNullable(
|
|
855
|
-
pendingPda: PublicKey,
|
|
856
|
-
): Promise<PendingSettlementData | null> {
|
|
857
|
-
return this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda);
|
|
858
|
-
}
|
|
859
|
-
|
|
860
|
-
async fetchDispute(
|
|
861
|
-
disputePda: PublicKey,
|
|
862
|
-
): Promise<DisputeRecordData> {
|
|
863
|
-
return this.fetchAccount<DisputeRecordData>("disputeRecord", disputePda);
|
|
864
|
-
}
|
|
865
|
-
|
|
866
|
-
async fetchDisputeNullable(
|
|
867
|
-
disputePda: PublicKey,
|
|
868
|
-
): Promise<DisputeRecordData | null> {
|
|
869
|
-
return this.fetchAccountNullable<DisputeRecordData>("disputeRecord", disputePda);
|
|
870
|
-
}
|
|
871
|
-
}
|