@oobe-protocol-labs/synapse-sap-sdk 0.12.9 → 0.14.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 +108 -0
- package/dist/cjs/client.js.map +1 -0
- package/dist/cjs/constants.js +59 -0
- package/dist/cjs/constants.js.map +1 -0
- package/dist/cjs/errors.js +250 -0
- package/dist/cjs/errors.js.map +1 -0
- package/dist/cjs/events/index.js +38 -130
- 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 +89 -0
- package/dist/cjs/instructions/agent.js.map +1 -0
- package/dist/cjs/instructions/attestation.js +112 -0
- package/dist/cjs/instructions/attestation.js.map +1 -0
- package/dist/cjs/instructions/digest.js +28 -0
- package/dist/cjs/instructions/digest.js.map +1 -0
- package/dist/cjs/instructions/dispute.js +116 -0
- package/dist/cjs/instructions/dispute.js.map +1 -0
- package/dist/cjs/instructions/escrow.js +101 -0
- package/dist/cjs/instructions/escrow.js.map +1 -0
- package/dist/cjs/instructions/global.js +28 -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 +221 -0
- package/dist/cjs/instructions/indexing.js.map +1 -0
- package/dist/cjs/instructions/misc.js +73 -0
- package/dist/cjs/instructions/misc.js.map +1 -0
- package/dist/cjs/instructions/session.js +89 -0
- package/dist/cjs/instructions/session.js.map +1 -0
- package/dist/cjs/instructions/staking.js +132 -0
- package/dist/cjs/instructions/staking.js.map +1 -0
- package/dist/cjs/instructions/subscription.js +80 -0
- package/dist/cjs/instructions/subscription.js.map +1 -0
- package/dist/cjs/instructions/tools.js +109 -0
- package/dist/cjs/instructions/tools.js.map +1 -0
- package/dist/cjs/instructions/vault.js +106 -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/types.js +42 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/utils/index.js +29 -75
- package/dist/cjs/utils/index.js.map +1 -1
- package/dist/cjs/utils/validate.js +236 -0
- package/dist/cjs/utils/validate.js.map +1 -0
- 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 +70 -0
- package/dist/esm/client.js.map +1 -0
- package/dist/esm/constants.d.ts +52 -0
- package/dist/esm/constants.d.ts.map +1 -0
- package/dist/esm/constants.js +56 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/errors.d.ts +111 -0
- package/dist/esm/errors.d.ts.map +1 -0
- package/dist/esm/errors.js +244 -0
- package/dist/esm/errors.js.map +1 -0
- package/dist/esm/events/index.d.ts +13 -0
- package/dist/esm/events/index.d.ts.map +1 -0
- package/dist/esm/events/index.js +36 -128
- package/dist/esm/events/index.js.map +1 -1
- 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 +85 -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 +108 -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 +24 -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 +112 -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 +97 -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 +24 -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 +217 -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 +69 -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 +85 -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 +128 -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 +76 -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 +105 -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 +102 -0
- package/dist/esm/instructions/vault.js.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/types.d.ts +208 -0
- package/dist/esm/types.d.ts.map +1 -0
- package/dist/esm/types.js +39 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/utils/index.d.ts +4 -0
- package/dist/esm/utils/index.d.ts.map +1 -0
- package/dist/esm/utils/index.js +13 -29
- package/dist/esm/utils/index.js.map +1 -1
- 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/package.json +59 -183
- package/LICENSE +0 -21
- package/README.md +0 -986
- package/dist/cjs/constants/addresses.js +0 -143
- package/dist/cjs/constants/addresses.js.map +0 -1
- package/dist/cjs/constants/index.js +0 -64
- package/dist/cjs/constants/index.js.map +0 -1
- package/dist/cjs/constants/limits.js +0 -161
- package/dist/cjs/constants/limits.js.map +0 -1
- package/dist/cjs/constants/network.js +0 -81
- package/dist/cjs/constants/network.js.map +0 -1
- package/dist/cjs/constants/payments.js +0 -137
- package/dist/cjs/constants/payments.js.map +0 -1
- package/dist/cjs/constants/programs.js +0 -78
- package/dist/cjs/constants/programs.js.map +0 -1
- package/dist/cjs/constants/seeds.js +0 -76
- package/dist/cjs/constants/seeds.js.map +0 -1
- package/dist/cjs/core/client.js +0 -546
- package/dist/cjs/core/client.js.map +0 -1
- package/dist/cjs/core/connection.js +0 -350
- package/dist/cjs/core/connection.js.map +0 -1
- package/dist/cjs/core/index.js +0 -25
- package/dist/cjs/core/index.js.map +0 -1
- package/dist/cjs/errors/index.js +0 -334
- package/dist/cjs/errors/index.js.map +0 -1
- package/dist/cjs/events/geyser.js +0 -295
- package/dist/cjs/events/geyser.js.map +0 -1
- package/dist/cjs/idl/index.js +0 -63
- package/dist/cjs/idl/index.js.map +0 -1
- package/dist/cjs/idl/synapse_agent_sap.json +0 -14595
- package/dist/cjs/modules/agent.js +0 -272
- package/dist/cjs/modules/agent.js.map +0 -1
- package/dist/cjs/modules/attestation.js +0 -147
- package/dist/cjs/modules/attestation.js.map +0 -1
- package/dist/cjs/modules/base.js +0 -128
- package/dist/cjs/modules/base.js.map +0 -1
- package/dist/cjs/modules/escrow-v2.js +0 -454
- package/dist/cjs/modules/escrow-v2.js.map +0 -1
- package/dist/cjs/modules/escrow.js +0 -300
- package/dist/cjs/modules/escrow.js.map +0 -1
- package/dist/cjs/modules/feedback.js +0 -166
- package/dist/cjs/modules/feedback.js.map +0 -1
- package/dist/cjs/modules/index.js +0 -43
- package/dist/cjs/modules/index.js.map +0 -1
- package/dist/cjs/modules/indexing.js +0 -375
- package/dist/cjs/modules/indexing.js.map +0 -1
- package/dist/cjs/modules/ledger.js +0 -234
- package/dist/cjs/modules/ledger.js.map +0 -1
- package/dist/cjs/modules/receipt.js +0 -148
- package/dist/cjs/modules/receipt.js.map +0 -1
- package/dist/cjs/modules/staking.js +0 -124
- package/dist/cjs/modules/staking.js.map +0 -1
- package/dist/cjs/modules/subscription.js +0 -96
- package/dist/cjs/modules/subscription.js.map +0 -1
- package/dist/cjs/modules/tools.js +0 -319
- package/dist/cjs/modules/tools.js.map +0 -1
- package/dist/cjs/modules/vault.js +0 -410
- package/dist/cjs/modules/vault.js.map +0 -1
- package/dist/cjs/parser/client.js +0 -146
- package/dist/cjs/parser/client.js.map +0 -1
- package/dist/cjs/parser/complete.js +0 -177
- package/dist/cjs/parser/complete.js.map +0 -1
- package/dist/cjs/parser/index.js +0 -57
- package/dist/cjs/parser/index.js.map +0 -1
- package/dist/cjs/parser/inner.js +0 -185
- package/dist/cjs/parser/inner.js.map +0 -1
- package/dist/cjs/parser/instructions.js +0 -114
- package/dist/cjs/parser/instructions.js.map +0 -1
- package/dist/cjs/parser/transaction.js +0 -153
- package/dist/cjs/parser/transaction.js.map +0 -1
- package/dist/cjs/parser/types.js +0 -14
- package/dist/cjs/parser/types.js.map +0 -1
- package/dist/cjs/pda/index.js +0 -672
- package/dist/cjs/pda/index.js.map +0 -1
- package/dist/cjs/plugin/index.js +0 -952
- package/dist/cjs/plugin/index.js.map +0 -1
- package/dist/cjs/plugin/protocols.js +0 -282
- package/dist/cjs/plugin/protocols.js.map +0 -1
- package/dist/cjs/plugin/schemas.js +0 -863
- package/dist/cjs/plugin/schemas.js.map +0 -1
- package/dist/cjs/postgres/adapter.js +0 -715
- package/dist/cjs/postgres/adapter.js.map +0 -1
- package/dist/cjs/postgres/index.js +0 -50
- package/dist/cjs/postgres/index.js.map +0 -1
- package/dist/cjs/postgres/serializers.js +0 -381
- package/dist/cjs/postgres/serializers.js.map +0 -1
- package/dist/cjs/postgres/sync.js +0 -289
- package/dist/cjs/postgres/sync.js.map +0 -1
- package/dist/cjs/postgres/types.js +0 -44
- package/dist/cjs/postgres/types.js.map +0 -1
- package/dist/cjs/registries/builder.js +0 -414
- package/dist/cjs/registries/builder.js.map +0 -1
- package/dist/cjs/registries/discovery.js +0 -362
- package/dist/cjs/registries/discovery.js.map +0 -1
- package/dist/cjs/registries/fairscale.js +0 -639
- package/dist/cjs/registries/fairscale.js.map +0 -1
- package/dist/cjs/registries/index.js +0 -58
- package/dist/cjs/registries/index.js.map +0 -1
- package/dist/cjs/registries/metaplex-bridge.js +0 -743
- package/dist/cjs/registries/metaplex-bridge.js.map +0 -1
- package/dist/cjs/registries/session.js +0 -433
- package/dist/cjs/registries/session.js.map +0 -1
- package/dist/cjs/registries/x402.js +0 -668
- package/dist/cjs/registries/x402.js.map +0 -1
- package/dist/cjs/types/accounts.js +0 -13
- package/dist/cjs/types/accounts.js.map +0 -1
- package/dist/cjs/types/common.js +0 -13
- package/dist/cjs/types/common.js.map +0 -1
- package/dist/cjs/types/endpoint.js +0 -15
- package/dist/cjs/types/endpoint.js.map +0 -1
- package/dist/cjs/types/enums.js +0 -269
- package/dist/cjs/types/enums.js.map +0 -1
- package/dist/cjs/types/index.js +0 -41
- package/dist/cjs/types/index.js.map +0 -1
- package/dist/cjs/types/instructions.js +0 -92
- package/dist/cjs/types/instructions.js.map +0 -1
- package/dist/cjs/utils/endpoint-validator.js +0 -232
- package/dist/cjs/utils/endpoint-validator.js.map +0 -1
- package/dist/cjs/utils/escrow-validation.js +0 -219
- package/dist/cjs/utils/escrow-validation.js.map +0 -1
- package/dist/cjs/utils/hash.js +0 -109
- package/dist/cjs/utils/hash.js.map +0 -1
- package/dist/cjs/utils/merchant-validator.js +0 -246
- package/dist/cjs/utils/merchant-validator.js.map +0 -1
- package/dist/cjs/utils/network-normalizer.js +0 -236
- package/dist/cjs/utils/network-normalizer.js.map +0 -1
- package/dist/cjs/utils/priority-fee.js +0 -215
- package/dist/cjs/utils/priority-fee.js.map +0 -1
- package/dist/cjs/utils/rpc-strategy.js +0 -239
- package/dist/cjs/utils/rpc-strategy.js.map +0 -1
- package/dist/cjs/utils/schemas.js +0 -331
- package/dist/cjs/utils/schemas.js.map +0 -1
- package/dist/cjs/utils/serialization.js +0 -105
- package/dist/cjs/utils/serialization.js.map +0 -1
- package/dist/cjs/utils/validation.js +0 -36
- package/dist/cjs/utils/validation.js.map +0 -1
- package/dist/cjs/utils/x402-direct.js +0 -231
- package/dist/cjs/utils/x402-direct.js.map +0 -1
- package/dist/esm/constants/addresses.js +0 -140
- package/dist/esm/constants/addresses.js.map +0 -1
- package/dist/esm/constants/index.js +0 -35
- package/dist/esm/constants/index.js.map +0 -1
- package/dist/esm/constants/limits.js +0 -158
- package/dist/esm/constants/limits.js.map +0 -1
- package/dist/esm/constants/network.js +0 -78
- package/dist/esm/constants/network.js.map +0 -1
- package/dist/esm/constants/payments.js +0 -131
- package/dist/esm/constants/payments.js.map +0 -1
- package/dist/esm/constants/programs.js +0 -75
- package/dist/esm/constants/programs.js.map +0 -1
- package/dist/esm/constants/seeds.js +0 -73
- package/dist/esm/constants/seeds.js.map +0 -1
- package/dist/esm/core/client.js +0 -539
- package/dist/esm/core/client.js.map +0 -1
- package/dist/esm/core/connection.js +0 -345
- package/dist/esm/core/connection.js.map +0 -1
- package/dist/esm/core/index.js +0 -19
- package/dist/esm/core/index.js.map +0 -1
- package/dist/esm/errors/index.js +0 -325
- package/dist/esm/errors/index.js.map +0 -1
- package/dist/esm/events/geyser.js +0 -258
- package/dist/esm/events/geyser.js.map +0 -1
- package/dist/esm/idl/index.js +0 -57
- package/dist/esm/idl/index.js.map +0 -1
- package/dist/esm/idl/synapse_agent_sap.json +0 -14595
- package/dist/esm/modules/agent.js +0 -268
- package/dist/esm/modules/agent.js.map +0 -1
- package/dist/esm/modules/attestation.js +0 -143
- package/dist/esm/modules/attestation.js.map +0 -1
- package/dist/esm/modules/base.js +0 -124
- package/dist/esm/modules/base.js.map +0 -1
- package/dist/esm/modules/escrow-v2.js +0 -450
- package/dist/esm/modules/escrow-v2.js.map +0 -1
- package/dist/esm/modules/escrow.js +0 -296
- package/dist/esm/modules/escrow.js.map +0 -1
- package/dist/esm/modules/feedback.js +0 -162
- package/dist/esm/modules/feedback.js.map +0 -1
- package/dist/esm/modules/index.js +0 -27
- package/dist/esm/modules/index.js.map +0 -1
- package/dist/esm/modules/indexing.js +0 -371
- package/dist/esm/modules/indexing.js.map +0 -1
- package/dist/esm/modules/ledger.js +0 -230
- package/dist/esm/modules/ledger.js.map +0 -1
- package/dist/esm/modules/receipt.js +0 -144
- package/dist/esm/modules/receipt.js.map +0 -1
- package/dist/esm/modules/staking.js +0 -120
- package/dist/esm/modules/staking.js.map +0 -1
- package/dist/esm/modules/subscription.js +0 -92
- package/dist/esm/modules/subscription.js.map +0 -1
- package/dist/esm/modules/tools.js +0 -315
- package/dist/esm/modules/tools.js.map +0 -1
- package/dist/esm/modules/vault.js +0 -406
- package/dist/esm/modules/vault.js.map +0 -1
- package/dist/esm/parser/client.js +0 -142
- package/dist/esm/parser/client.js.map +0 -1
- package/dist/esm/parser/complete.js +0 -173
- package/dist/esm/parser/complete.js.map +0 -1
- package/dist/esm/parser/index.js +0 -43
- package/dist/esm/parser/index.js.map +0 -1
- package/dist/esm/parser/inner.js +0 -180
- package/dist/esm/parser/inner.js.map +0 -1
- package/dist/esm/parser/instructions.js +0 -109
- package/dist/esm/parser/instructions.js.map +0 -1
- package/dist/esm/parser/transaction.js +0 -149
- package/dist/esm/parser/transaction.js.map +0 -1
- package/dist/esm/parser/types.js +0 -13
- package/dist/esm/parser/types.js.map +0 -1
- package/dist/esm/pda/index.js +0 -638
- package/dist/esm/pda/index.js.map +0 -1
- package/dist/esm/plugin/index.js +0 -945
- package/dist/esm/plugin/index.js.map +0 -1
- package/dist/esm/plugin/protocols.js +0 -279
- package/dist/esm/plugin/protocols.js.map +0 -1
- package/dist/esm/plugin/schemas.js +0 -860
- package/dist/esm/plugin/schemas.js.map +0 -1
- package/dist/esm/postgres/adapter.js +0 -678
- package/dist/esm/postgres/adapter.js.map +0 -1
- package/dist/esm/postgres/index.js +0 -27
- package/dist/esm/postgres/index.js.map +0 -1
- package/dist/esm/postgres/serializers.js +0 -362
- package/dist/esm/postgres/serializers.js.map +0 -1
- package/dist/esm/postgres/sync.js +0 -285
- package/dist/esm/postgres/sync.js.map +0 -1
- package/dist/esm/postgres/types.js +0 -41
- package/dist/esm/postgres/types.js.map +0 -1
- package/dist/esm/registries/builder.js +0 -410
- package/dist/esm/registries/builder.js.map +0 -1
- package/dist/esm/registries/discovery.js +0 -358
- package/dist/esm/registries/discovery.js.map +0 -1
- package/dist/esm/registries/fairscale.js +0 -633
- package/dist/esm/registries/fairscale.js.map +0 -1
- package/dist/esm/registries/index.js +0 -46
- package/dist/esm/registries/index.js.map +0 -1
- package/dist/esm/registries/metaplex-bridge.js +0 -706
- package/dist/esm/registries/metaplex-bridge.js.map +0 -1
- package/dist/esm/registries/session.js +0 -429
- package/dist/esm/registries/session.js.map +0 -1
- package/dist/esm/registries/x402.js +0 -664
- package/dist/esm/registries/x402.js.map +0 -1
- package/dist/esm/types/accounts.js +0 -12
- package/dist/esm/types/accounts.js.map +0 -1
- package/dist/esm/types/common.js +0 -12
- package/dist/esm/types/common.js.map +0 -1
- package/dist/esm/types/endpoint.js +0 -14
- package/dist/esm/types/endpoint.js.map +0 -1
- package/dist/esm/types/enums.js +0 -266
- package/dist/esm/types/enums.js.map +0 -1
- package/dist/esm/types/index.js +0 -25
- package/dist/esm/types/index.js.map +0 -1
- package/dist/esm/types/instructions.js +0 -89
- package/dist/esm/types/instructions.js.map +0 -1
- package/dist/esm/utils/endpoint-validator.js +0 -226
- package/dist/esm/utils/endpoint-validator.js.map +0 -1
- package/dist/esm/utils/escrow-validation.js +0 -212
- package/dist/esm/utils/escrow-validation.js.map +0 -1
- package/dist/esm/utils/hash.js +0 -103
- package/dist/esm/utils/hash.js.map +0 -1
- package/dist/esm/utils/merchant-validator.js +0 -241
- package/dist/esm/utils/merchant-validator.js.map +0 -1
- package/dist/esm/utils/network-normalizer.js +0 -229
- package/dist/esm/utils/network-normalizer.js.map +0 -1
- package/dist/esm/utils/priority-fee.js +0 -209
- package/dist/esm/utils/priority-fee.js.map +0 -1
- package/dist/esm/utils/rpc-strategy.js +0 -231
- package/dist/esm/utils/rpc-strategy.js.map +0 -1
- package/dist/esm/utils/schemas.js +0 -320
- package/dist/esm/utils/schemas.js.map +0 -1
- package/dist/esm/utils/serialization.js +0 -98
- package/dist/esm/utils/serialization.js.map +0 -1
- package/dist/esm/utils/validation.js +0 -33
- package/dist/esm/utils/validation.js.map +0 -1
- package/dist/esm/utils/x402-direct.js +0 -228
- package/dist/esm/utils/x402-direct.js.map +0 -1
- package/dist/types/constants/addresses.d.ts +0 -117
- package/dist/types/constants/addresses.d.ts.map +0 -1
- package/dist/types/constants/index.d.ts +0 -31
- package/dist/types/constants/index.d.ts.map +0 -1
- package/dist/types/constants/limits.d.ts +0 -149
- package/dist/types/constants/limits.d.ts.map +0 -1
- package/dist/types/constants/network.d.ts +0 -81
- package/dist/types/constants/network.d.ts.map +0 -1
- package/dist/types/constants/payments.d.ts +0 -121
- package/dist/types/constants/payments.d.ts.map +0 -1
- package/dist/types/constants/programs.d.ts +0 -69
- package/dist/types/constants/programs.d.ts.map +0 -1
- package/dist/types/constants/seeds.d.ts +0 -80
- package/dist/types/constants/seeds.d.ts.map +0 -1
- package/dist/types/core/client.d.ts +0 -452
- package/dist/types/core/client.d.ts.map +0 -1
- package/dist/types/core/connection.d.ts +0 -305
- package/dist/types/core/connection.d.ts.map +0 -1
- package/dist/types/core/index.d.ts +0 -20
- package/dist/types/core/index.d.ts.map +0 -1
- package/dist/types/errors/index.d.ts +0 -276
- package/dist/types/errors/index.d.ts.map +0 -1
- package/dist/types/events/geyser.d.ts +0 -150
- package/dist/types/events/geyser.d.ts.map +0 -1
- package/dist/types/events/index.d.ts +0 -248
- package/dist/types/events/index.d.ts.map +0 -1
- package/dist/types/idl/index.d.ts +0 -70
- package/dist/types/idl/index.d.ts.map +0 -1
- package/dist/types/index.d.ts +0 -85
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/modules/agent.d.ts +0 -166
- package/dist/types/modules/agent.d.ts.map +0 -1
- package/dist/types/modules/attestation.d.ts +0 -96
- package/dist/types/modules/attestation.d.ts.map +0 -1
- package/dist/types/modules/base.d.ts +0 -126
- package/dist/types/modules/base.d.ts.map +0 -1
- package/dist/types/modules/escrow-v2.d.ts +0 -100
- package/dist/types/modules/escrow-v2.d.ts.map +0 -1
- package/dist/types/modules/escrow.d.ts +0 -168
- package/dist/types/modules/escrow.d.ts.map +0 -1
- package/dist/types/modules/feedback.d.ts +0 -105
- package/dist/types/modules/feedback.d.ts.map +0 -1
- package/dist/types/modules/index.d.ts +0 -28
- package/dist/types/modules/index.d.ts.map +0 -1
- package/dist/types/modules/indexing.d.ts +0 -200
- package/dist/types/modules/indexing.d.ts.map +0 -1
- package/dist/types/modules/ledger.d.ts +0 -150
- package/dist/types/modules/ledger.d.ts.map +0 -1
- package/dist/types/modules/receipt.d.ts +0 -77
- package/dist/types/modules/receipt.d.ts.map +0 -1
- package/dist/types/modules/staking.d.ts +0 -51
- package/dist/types/modules/staking.d.ts.map +0 -1
- package/dist/types/modules/subscription.d.ts +0 -33
- package/dist/types/modules/subscription.d.ts.map +0 -1
- package/dist/types/modules/tools.d.ts +0 -182
- package/dist/types/modules/tools.d.ts.map +0 -1
- package/dist/types/modules/vault.d.ts +0 -240
- package/dist/types/modules/vault.d.ts.map +0 -1
- package/dist/types/parser/client.d.ts +0 -123
- package/dist/types/parser/client.d.ts.map +0 -1
- package/dist/types/parser/complete.d.ts +0 -90
- package/dist/types/parser/complete.d.ts.map +0 -1
- package/dist/types/parser/index.d.ts +0 -40
- package/dist/types/parser/index.d.ts.map +0 -1
- package/dist/types/parser/inner.d.ts +0 -114
- package/dist/types/parser/inner.d.ts.map +0 -1
- package/dist/types/parser/instructions.d.ts +0 -76
- package/dist/types/parser/instructions.d.ts.map +0 -1
- package/dist/types/parser/transaction.d.ts +0 -77
- package/dist/types/parser/transaction.d.ts.map +0 -1
- package/dist/types/parser/types.d.ts +0 -154
- package/dist/types/parser/types.d.ts.map +0 -1
- package/dist/types/pda/index.d.ts +0 -510
- package/dist/types/pda/index.d.ts.map +0 -1
- package/dist/types/plugin/index.d.ts +0 -171
- package/dist/types/plugin/index.d.ts.map +0 -1
- package/dist/types/plugin/protocols.d.ts +0 -152
- package/dist/types/plugin/protocols.d.ts.map +0 -1
- package/dist/types/plugin/schemas.d.ts +0 -829
- package/dist/types/plugin/schemas.d.ts.map +0 -1
- package/dist/types/postgres/adapter.d.ts +0 -355
- package/dist/types/postgres/adapter.d.ts.map +0 -1
- package/dist/types/postgres/index.d.ts +0 -24
- package/dist/types/postgres/index.d.ts.map +0 -1
- package/dist/types/postgres/serializers.d.ts +0 -30
- package/dist/types/postgres/serializers.d.ts.map +0 -1
- package/dist/types/postgres/sync.d.ts +0 -156
- package/dist/types/postgres/sync.d.ts.map +0 -1
- package/dist/types/postgres/types.d.ts +0 -167
- package/dist/types/postgres/types.d.ts.map +0 -1
- package/dist/types/registries/builder.d.ts +0 -340
- package/dist/types/registries/builder.d.ts.map +0 -1
- package/dist/types/registries/discovery.d.ts +0 -333
- package/dist/types/registries/discovery.d.ts.map +0 -1
- package/dist/types/registries/fairscale.d.ts +0 -680
- package/dist/types/registries/fairscale.d.ts.map +0 -1
- package/dist/types/registries/index.d.ts +0 -52
- package/dist/types/registries/index.d.ts.map +0 -1
- package/dist/types/registries/metaplex-bridge.d.ts +0 -488
- package/dist/types/registries/metaplex-bridge.d.ts.map +0 -1
- package/dist/types/registries/session.d.ts +0 -323
- package/dist/types/registries/session.d.ts.map +0 -1
- package/dist/types/registries/x402.d.ts +0 -530
- package/dist/types/registries/x402.d.ts.map +0 -1
- package/dist/types/types/accounts.d.ts +0 -765
- package/dist/types/types/accounts.d.ts.map +0 -1
- package/dist/types/types/common.d.ts +0 -166
- package/dist/types/types/common.d.ts.map +0 -1
- package/dist/types/types/endpoint.d.ts +0 -161
- package/dist/types/types/endpoint.d.ts.map +0 -1
- package/dist/types/types/enums.d.ts +0 -353
- package/dist/types/types/enums.d.ts.map +0 -1
- package/dist/types/types/index.d.ts +0 -29
- package/dist/types/types/index.d.ts.map +0 -1
- package/dist/types/types/instructions.d.ts +0 -400
- package/dist/types/types/instructions.d.ts.map +0 -1
- package/dist/types/utils/endpoint-validator.d.ts +0 -110
- package/dist/types/utils/endpoint-validator.d.ts.map +0 -1
- package/dist/types/utils/escrow-validation.d.ts +0 -145
- package/dist/types/utils/escrow-validation.d.ts.map +0 -1
- package/dist/types/utils/hash.d.ts +0 -75
- package/dist/types/utils/hash.d.ts.map +0 -1
- package/dist/types/utils/index.d.ts +0 -33
- package/dist/types/utils/index.d.ts.map +0 -1
- package/dist/types/utils/merchant-validator.d.ts +0 -176
- package/dist/types/utils/merchant-validator.d.ts.map +0 -1
- package/dist/types/utils/network-normalizer.d.ts +0 -120
- package/dist/types/utils/network-normalizer.d.ts.map +0 -1
- package/dist/types/utils/priority-fee.d.ts +0 -205
- package/dist/types/utils/priority-fee.d.ts.map +0 -1
- package/dist/types/utils/rpc-strategy.d.ts +0 -172
- package/dist/types/utils/rpc-strategy.d.ts.map +0 -1
- package/dist/types/utils/schemas.d.ts +0 -351
- package/dist/types/utils/schemas.d.ts.map +0 -1
- package/dist/types/utils/serialization.d.ts +0 -69
- package/dist/types/utils/serialization.d.ts.map +0 -1
- package/dist/types/utils/validation.d.ts +0 -29
- package/dist/types/utils/validation.d.ts.map +0 -1
- package/dist/types/utils/x402-direct.d.ts +0 -114
- package/dist/types/utils/x402-direct.d.ts.map +0 -1
- package/src/constants/addresses.ts +0 -162
- package/src/constants/index.ts +0 -69
- package/src/constants/limits.ts +0 -165
- package/src/constants/network.ts +0 -89
- package/src/constants/payments.ts +0 -145
- package/src/constants/programs.ts +0 -83
- package/src/constants/seeds.ts +0 -85
- package/src/core/client.ts +0 -583
- package/src/core/connection.ts +0 -461
- package/src/core/index.ts +0 -20
- 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/index.ts +0 -76
- 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 -158
- package/src/modules/escrow-v2.ts +0 -658
- package/src/modules/escrow.ts +0 -383
- package/src/modules/feedback.ts +0 -186
- package/src/modules/index.ts +0 -28
- 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 -157
- package/src/modules/subscription.ts +0 -147
- package/src/modules/tools.ts +0 -411
- package/src/modules/vault.ts +0 -533
- package/src/parser/client.ts +0 -211
- package/src/parser/complete.ts +0 -232
- package/src/parser/index.ts +0 -71
- package/src/parser/inner.ts +0 -255
- package/src/parser/instructions.ts +0 -135
- package/src/parser/transaction.ts +0 -200
- package/src/parser/types.ts +0 -182
- package/src/pda/index.ts +0 -919
- 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/endpoint-validator.ts +0 -300
- package/src/utils/escrow-validation.ts +0 -301
- package/src/utils/hash.ts +0 -113
- package/src/utils/index.ts +0 -102
- 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/serialization.ts +0 -98
- package/src/utils/validation.ts +0 -36
- package/src/utils/x402-direct.ts +0 -370
package/src/modules/escrow-v2.ts
DELETED
|
@@ -1,658 +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
|
-
|
|
43
|
-
/**
|
|
44
|
-
* @name EscrowV2Module
|
|
45
|
-
* @description Manages V2 escrow accounts with settlement security modes,
|
|
46
|
-
* dispute windows, and pending settlement flows.
|
|
47
|
-
*
|
|
48
|
-
* @category Modules
|
|
49
|
-
* @since v0.7.0
|
|
50
|
-
* @extends BaseModule
|
|
51
|
-
*/
|
|
52
|
-
export class EscrowV2Module extends BaseModule {
|
|
53
|
-
// ── Helpers ──────────────────────────────────────────
|
|
54
|
-
|
|
55
|
-
/** Convert BN | number | bigint → number for PDA seed functions. */
|
|
56
|
-
private toNum(v: BN | number | bigint): number {
|
|
57
|
-
return BN.isBN(v) ? v.toNumber() : Number(v);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
// ── PDA helpers ──────────────────────────────────────
|
|
61
|
-
|
|
62
|
-
deriveEscrow(
|
|
63
|
-
agentPda: PublicKey,
|
|
64
|
-
depositor?: PublicKey,
|
|
65
|
-
nonce: BN | number | bigint = 0,
|
|
66
|
-
): readonly [PublicKey, number] {
|
|
67
|
-
return deriveEscrowV2(agentPda, depositor ?? this.walletPubkey, this.toNum(nonce));
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
derivePendingSettlement(
|
|
71
|
-
escrowV2Pda: PublicKey,
|
|
72
|
-
settlementIndex: BN | number | bigint,
|
|
73
|
-
): readonly [PublicKey, number] {
|
|
74
|
-
return derivePendingPda(escrowV2Pda, this.toNum(settlementIndex));
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
deriveDispute(
|
|
78
|
-
pendingSettlementPda: PublicKey,
|
|
79
|
-
): readonly [PublicKey, number] {
|
|
80
|
-
return deriveDisputePda(pendingSettlementPda);
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// ── Instructions ─────────────────────────────────────
|
|
84
|
-
|
|
85
|
-
async create(
|
|
86
|
-
agentWallet: PublicKey,
|
|
87
|
-
args: CreateEscrowV2Args,
|
|
88
|
-
splAccounts: AccountMeta[] = [],
|
|
89
|
-
): Promise<TransactionSignature> {
|
|
90
|
-
// v0.10.0: payment-token allowlist (SOL or USDC only).
|
|
91
|
-
if (!isAcceptedPaymentToken(args.tokenMint ?? null)) {
|
|
92
|
-
throw new Error(
|
|
93
|
-
"createEscrowV2: tokenMint must be null (SOL) or USDC (mainnet/devnet). " +
|
|
94
|
-
"On-chain will reject with PaymentTokenNotAllowed.",
|
|
95
|
-
);
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
// v0.12.7 preflight: mirror the on-chain settlement-security guards
|
|
99
|
-
// (escrow_v2.rs:106-115) so callers fail fast with a clear message
|
|
100
|
-
// instead of paying for a tx that aborts with `InvalidSettlementSecurity`
|
|
101
|
-
// or `CoSignerRequired`.
|
|
102
|
-
const security = args.settlementSecurity;
|
|
103
|
-
if (security === 0) {
|
|
104
|
-
throw new Error(
|
|
105
|
-
"createEscrowV2: settlementSecurity=0 (SelfReport) is deprecated since " +
|
|
106
|
-
"v0.7. Use 1 (CoSigned) or 2 (DisputeWindow). On-chain rejects with " +
|
|
107
|
-
"SelfReportDeprecated.",
|
|
108
|
-
);
|
|
109
|
-
}
|
|
110
|
-
if (security === 1 && !args.coSigner) {
|
|
111
|
-
throw new Error(
|
|
112
|
-
"createEscrowV2: settlementSecurity=1 (CoSigned) requires `coSigner` " +
|
|
113
|
-
"to be set. On-chain rejects with CoSignerRequired.",
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
if (security === 2) {
|
|
117
|
-
// The on-chain check is `dispute_window_slots > 0` — i.e. >= 1 slot.
|
|
118
|
-
// Zero would let an agent settle and immediately drain pending funds
|
|
119
|
-
// before any depositor could possibly file a dispute, defeating the
|
|
120
|
-
// entire DisputeWindow security model. Enforce client-side too.
|
|
121
|
-
const slots = BigInt(this.bn(args.disputeWindowSlots).toString());
|
|
122
|
-
if (slots < 1n) {
|
|
123
|
-
throw new Error(
|
|
124
|
-
"createEscrowV2: settlementSecurity=2 (DisputeWindow) requires " +
|
|
125
|
-
"`disputeWindowSlots >= 1` to prevent the zero-window abuse vector. " +
|
|
126
|
-
"Recommended minimum is 2_160 slots (~15 min). On-chain rejects " +
|
|
127
|
-
"with InvalidSettlementSecurity.",
|
|
128
|
-
);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
if (security !== 0 && security !== 1 && security !== 2) {
|
|
132
|
-
throw new Error(
|
|
133
|
-
`createEscrowV2: settlementSecurity must be 1 (CoSigned) or 2 (DisputeWindow), got ${String(security)}.`,
|
|
134
|
-
);
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
138
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, args.escrowNonce);
|
|
139
|
-
const [stakePda] = deriveStake(agentPda);
|
|
140
|
-
// v0.11 H-1 preflight: surface an actionable error if the agent's stake
|
|
141
|
-
// does not cover the slashable share of the new escrow. Saves a failed
|
|
142
|
-
// tx fee and gives the caller a clear top-up amount.
|
|
143
|
-
try {
|
|
144
|
-
const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
|
|
145
|
-
if (stakeAccount) {
|
|
146
|
-
const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
|
|
147
|
-
const required = computeRequiredStakeLamports(escrowLamports);
|
|
148
|
-
const have = BigInt(stakeAccount.stakedAmount.toString());
|
|
149
|
-
if (have < required) {
|
|
150
|
-
throw new Error(
|
|
151
|
-
`createEscrowV2: agent stake ${have} lamports < required ${required} ` +
|
|
152
|
-
`lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
|
|
153
|
-
);
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
// If no stake account exists at all, on-chain will reject with
|
|
157
|
-
// AccountNotInitialized — we let that bubble up unchanged.
|
|
158
|
-
} catch (err) {
|
|
159
|
-
// Preflight is advisory; rethrow only the explicit coverage error.
|
|
160
|
-
if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
|
|
161
|
-
throw err;
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
// v0.11 H-1 preflight: surface an actionable error if the agent's stake
|
|
165
|
-
// does not cover the slashable share of the new escrow. Saves a failed
|
|
166
|
-
// tx fee and gives the caller a clear top-up amount.
|
|
167
|
-
try {
|
|
168
|
-
const stakeAccount = await this.fetchAccountNullable<{ stakedAmount: BN }>("agentStake", stakePda);
|
|
169
|
-
if (stakeAccount) {
|
|
170
|
-
const escrowLamports = BigInt(this.bn(args.initialDeposit).toString());
|
|
171
|
-
const required = computeRequiredStakeLamports(escrowLamports);
|
|
172
|
-
const have = BigInt(stakeAccount.stakedAmount.toString());
|
|
173
|
-
if (have < required) {
|
|
174
|
-
throw new Error(
|
|
175
|
-
`createEscrowV2: agent stake ${have} lamports < required ${required} ` +
|
|
176
|
-
`lamports for escrow of ${escrowLamports} lamports. Top up via stakingModule.deposit.`,
|
|
177
|
-
);
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
// If no stake account exists at all, on-chain will reject with
|
|
181
|
-
// AccountNotInitialized — we let that bubble up unchanged.
|
|
182
|
-
} catch (err) {
|
|
183
|
-
// Preflight is advisory; rethrow only the explicit coverage error.
|
|
184
|
-
if (err instanceof Error && err.message.startsWith("createEscrowV2: agent stake")) {
|
|
185
|
-
throw err;
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
return this.methods
|
|
190
|
-
.createEscrowV2(
|
|
191
|
-
this.bn(args.escrowNonce),
|
|
192
|
-
this.bn(args.pricePerCall),
|
|
193
|
-
this.bn(args.maxCalls),
|
|
194
|
-
this.bn(args.initialDeposit),
|
|
195
|
-
args.expiresAt,
|
|
196
|
-
args.volumeCurve,
|
|
197
|
-
args.tokenMint,
|
|
198
|
-
args.tokenDecimals,
|
|
199
|
-
args.settlementSecurity,
|
|
200
|
-
this.bn(args.disputeWindowSlots),
|
|
201
|
-
args.coSigner,
|
|
202
|
-
args.arbiter,
|
|
203
|
-
)
|
|
204
|
-
.accounts({
|
|
205
|
-
depositor: this.walletPubkey,
|
|
206
|
-
agent: agentPda,
|
|
207
|
-
agentStake: stakePda,
|
|
208
|
-
escrow: escrowPda,
|
|
209
|
-
systemProgram: SystemProgram.programId,
|
|
210
|
-
})
|
|
211
|
-
.remainingAccounts(splAccounts)
|
|
212
|
-
.rpc();
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
async deposit(
|
|
216
|
-
agentWallet: PublicKey,
|
|
217
|
-
nonce: BN | number | bigint,
|
|
218
|
-
amount: BN | number | bigint,
|
|
219
|
-
splAccounts: AccountMeta[] = [],
|
|
220
|
-
): Promise<TransactionSignature> {
|
|
221
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
222
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
223
|
-
|
|
224
|
-
return this.methods
|
|
225
|
-
.depositEscrowV2(this.bn(nonce), this.bn(amount))
|
|
226
|
-
.accounts({
|
|
227
|
-
depositor: this.walletPubkey,
|
|
228
|
-
escrow: escrowPda,
|
|
229
|
-
systemProgram: SystemProgram.programId,
|
|
230
|
-
})
|
|
231
|
-
.remainingAccounts(splAccounts)
|
|
232
|
-
.rpc();
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
async settle(
|
|
236
|
-
depositorWallet: PublicKey,
|
|
237
|
-
nonce: BN | number | bigint,
|
|
238
|
-
callsToSettle: BN | number | bigint,
|
|
239
|
-
serviceHash: number[],
|
|
240
|
-
splAccounts: AccountMeta[] = [],
|
|
241
|
-
opts?: SettleOptions,
|
|
242
|
-
coSigner?: Signer,
|
|
243
|
-
): Promise<TransactionSignature> {
|
|
244
|
-
const [agentPda] = deriveAgent(this.walletPubkey);
|
|
245
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
246
|
-
const [statsPda] = deriveAgentStats(agentPda);
|
|
247
|
-
const [receiptPda] = deriveSettlementReceipt(escrowPda, serviceHash);
|
|
248
|
-
|
|
249
|
-
const preIxs = buildPriorityFeeIxs(opts);
|
|
250
|
-
const rpcOpts = buildRpcOptions(opts);
|
|
251
|
-
|
|
252
|
-
// CoSigned escrows require the co-signer to appear in
|
|
253
|
-
// remaining_accounts with `is_signer = true` AND to actually sign
|
|
254
|
-
// the transaction (Anchor on-chain checks `acc.is_signer`).
|
|
255
|
-
// We dedupe so callers can also pass it manually via splAccounts.
|
|
256
|
-
const remaining: AccountMeta[] = coSigner
|
|
257
|
-
? [
|
|
258
|
-
...splAccounts.filter((a) => !a.pubkey.equals(coSigner.publicKey)),
|
|
259
|
-
{ pubkey: coSigner.publicKey, isSigner: true, isWritable: false },
|
|
260
|
-
]
|
|
261
|
-
: splAccounts;
|
|
262
|
-
|
|
263
|
-
let builder = this.methods
|
|
264
|
-
.settleCallsV2(this.bn(nonce), this.bn(callsToSettle), serviceHash)
|
|
265
|
-
.accountsPartial({
|
|
266
|
-
wallet: this.walletPubkey,
|
|
267
|
-
agent: agentPda,
|
|
268
|
-
agentStats: statsPda,
|
|
269
|
-
escrow: escrowPda,
|
|
270
|
-
settlementReceipt: receiptPda,
|
|
271
|
-
systemProgram: SystemProgram.programId,
|
|
272
|
-
})
|
|
273
|
-
.remainingAccounts(remaining);
|
|
274
|
-
|
|
275
|
-
if (coSigner) {
|
|
276
|
-
builder = builder.signers([coSigner]);
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
if (preIxs.length > 0) {
|
|
280
|
-
builder = builder.preInstructions(preIxs);
|
|
281
|
-
}
|
|
282
|
-
|
|
283
|
-
return builder.rpc(rpcOpts);
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
/**
|
|
287
|
-
* Read the current `escrow.settlement_index` from chain.
|
|
288
|
-
*
|
|
289
|
-
* In DisputeWindow mode (`settlementSecurity = 2`), every successful
|
|
290
|
-
* `settleCallsV2` increments this value. The PRE-increment value is the
|
|
291
|
-
* one to pass to {@link createPendingSettlement} for that batch.
|
|
292
|
-
*
|
|
293
|
-
* @returns the current `settlementIndex` as `bigint` (next index to use
|
|
294
|
-
* for `createPendingSettlement` if you have NOT yet called `settle` for
|
|
295
|
-
* it; if you HAVE just settled, subtract 1 — but prefer the event
|
|
296
|
-
* `SettlementPendingEvent.settlement_index` over arithmetic).
|
|
297
|
-
* @since v0.12.8
|
|
298
|
-
*/
|
|
299
|
-
async nextSettlementIndex(
|
|
300
|
-
agentWallet: PublicKey,
|
|
301
|
-
depositorWallet: PublicKey,
|
|
302
|
-
nonce: BN | number | bigint,
|
|
303
|
-
): Promise<bigint> {
|
|
304
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
305
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
306
|
-
const escrow = await this.fetchAccountNullable<EscrowAccountV2Data>(
|
|
307
|
-
"escrowAccountV2",
|
|
308
|
-
escrowPda,
|
|
309
|
-
);
|
|
310
|
-
if (!escrow) {
|
|
311
|
-
throw new Error(
|
|
312
|
-
`nextSettlementIndex: escrow PDA ${escrowPda.toBase58()} not found on-chain`,
|
|
313
|
-
);
|
|
314
|
-
}
|
|
315
|
-
return BigInt(escrow.settlementIndex.toString());
|
|
316
|
-
}
|
|
317
|
-
|
|
318
|
-
async createPendingSettlement(
|
|
319
|
-
agentWallet: PublicKey,
|
|
320
|
-
depositorWallet: PublicKey,
|
|
321
|
-
nonce: BN | number | bigint,
|
|
322
|
-
settlementIndex: BN | number | bigint,
|
|
323
|
-
callsToSettle: BN | number | bigint,
|
|
324
|
-
amount: BN | number | bigint,
|
|
325
|
-
serviceHash: number[],
|
|
326
|
-
receiptMerkleRoot: number[] = new Array(32).fill(0),
|
|
327
|
-
): Promise<TransactionSignature> {
|
|
328
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
329
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
330
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
331
|
-
|
|
332
|
-
// v0.12.8: preflight against the "Allocate: account already in use"
|
|
333
|
-
// SystemProgram error (custom 0x0). The pending_settlement PDA is
|
|
334
|
-
// seeded on `escrow + settlement_index`, so reusing the same index
|
|
335
|
-
// (e.g. always 0, or a stale retry value) collides with an existing
|
|
336
|
-
// account. Fail fast with an actionable message instead of burning a
|
|
337
|
-
// failed tx fee on simulation.
|
|
338
|
-
const existing = await this.provider.connection.getAccountInfo(pendingPda);
|
|
339
|
-
if (existing) {
|
|
340
|
-
const idx = this.bn(settlementIndex).toString();
|
|
341
|
-
throw new Error(
|
|
342
|
-
`createPendingSettlement: pending PDA ${pendingPda.toBase58()} ` +
|
|
343
|
-
`already exists for settlementIndex=${idx}. ` +
|
|
344
|
-
`Use EscrowV2Module.nextSettlementIndex() to read the current ` +
|
|
345
|
-
`escrow.settlement_index, or capture SettlementPendingEvent.settlement_index ` +
|
|
346
|
-
`from the preceding settleCallsV2 tx. Reusing a settlementIndex ` +
|
|
347
|
-
`causes SystemProgram Allocate (custom 0x0) failures.`,
|
|
348
|
-
);
|
|
349
|
-
}
|
|
350
|
-
|
|
351
|
-
return this.methods
|
|
352
|
-
.createPendingSettlement(
|
|
353
|
-
this.bn(settlementIndex),
|
|
354
|
-
this.bn(callsToSettle),
|
|
355
|
-
this.bn(amount),
|
|
356
|
-
serviceHash,
|
|
357
|
-
receiptMerkleRoot,
|
|
358
|
-
)
|
|
359
|
-
.accounts({
|
|
360
|
-
wallet: this.walletPubkey,
|
|
361
|
-
agent: agentPda,
|
|
362
|
-
escrow: escrowPda,
|
|
363
|
-
pendingSettlement: pendingPda,
|
|
364
|
-
systemProgram: SystemProgram.programId,
|
|
365
|
-
})
|
|
366
|
-
.rpc();
|
|
367
|
-
}
|
|
368
|
-
|
|
369
|
-
async finalizeSettlement(
|
|
370
|
-
agentWallet: PublicKey,
|
|
371
|
-
depositorWallet: PublicKey,
|
|
372
|
-
nonce: BN | number | bigint,
|
|
373
|
-
settlementIndex: BN | number | bigint,
|
|
374
|
-
): Promise<TransactionSignature> {
|
|
375
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
376
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
377
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
378
|
-
const [statsPda] = deriveAgentStats(agentPda);
|
|
379
|
-
|
|
380
|
-
// v0.12.9: preflight against ArithmeticOverflow at finalize.
|
|
381
|
-
//
|
|
382
|
-
// The on-chain handler subtracts `pending_settlement.amount` from BOTH
|
|
383
|
-
// `escrow.balance` AND `escrow.pending_amount`. If the PendingSettlement
|
|
384
|
-
// PDA was created without a preceding `settle_calls_v2` (orphan PDA from
|
|
385
|
-
// legacy probe loops, or a buggy caller that skipped the settle step),
|
|
386
|
-
// `escrow.pending_amount` is smaller than `pending_settlement.amount`
|
|
387
|
-
// and the program aborts with ArithmeticOverflow (error 6075) at
|
|
388
|
-
// escrow_v2.rs:633. Each retry burns ~5 000 lamports of base fee.
|
|
389
|
-
//
|
|
390
|
-
// Detect this BEFORE signing and throw with a clear, actionable message
|
|
391
|
-
// pointing at the orphan-recovery path.
|
|
392
|
-
const [escrowAcc, pendingAcc] = await Promise.all([
|
|
393
|
-
this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
|
|
394
|
-
this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
|
|
395
|
-
]);
|
|
396
|
-
if (!escrowAcc) {
|
|
397
|
-
throw new Error(
|
|
398
|
-
`finalizeSettlement: escrow PDA ${escrowPda.toBase58()} not found on-chain.`,
|
|
399
|
-
);
|
|
400
|
-
}
|
|
401
|
-
if (!pendingAcc) {
|
|
402
|
-
throw new Error(
|
|
403
|
-
`finalizeSettlement: pending PDA ${pendingPda.toBase58()} not found on-chain ` +
|
|
404
|
-
`(settlementIndex=${settlementIndex.toString()}). Nothing to finalize.`,
|
|
405
|
-
);
|
|
406
|
-
}
|
|
407
|
-
const psAmount = BigInt(pendingAcc.amount.toString());
|
|
408
|
-
const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
|
|
409
|
-
const escrowBalance = BigInt(escrowAcc.balance.toString());
|
|
410
|
-
if (psAmount > escrowPendingAmount || psAmount > escrowBalance) {
|
|
411
|
-
throw new Error(
|
|
412
|
-
`finalizeSettlement: orphan/inconsistent PendingSettlement detected ` +
|
|
413
|
-
`at ${pendingPda.toBase58()} (settlementIndex=${settlementIndex.toString()}). ` +
|
|
414
|
-
`pending.amount=${psAmount} but escrow.pending_amount=${escrowPendingAmount}, ` +
|
|
415
|
-
`escrow.balance=${escrowBalance}. The on-chain finalize would abort with ` +
|
|
416
|
-
`ArithmeticOverflow (6075). This PDA was almost certainly created by a ` +
|
|
417
|
-
`caller that skipped settle_calls_v2 (legacy probe loop). It cannot be ` +
|
|
418
|
-
`finalized and cannot be closed (close_pending_settlement requires ` +
|
|
419
|
-
`is_finalized=true). Skip this index permanently in your settle queue.`,
|
|
420
|
-
);
|
|
421
|
-
}
|
|
422
|
-
|
|
423
|
-
return this.methods
|
|
424
|
-
.finalizeSettlement()
|
|
425
|
-
.accounts({
|
|
426
|
-
payer: this.walletPubkey,
|
|
427
|
-
agentWallet,
|
|
428
|
-
escrow: escrowPda,
|
|
429
|
-
pendingSettlement: pendingPda,
|
|
430
|
-
agentStats: statsPda,
|
|
431
|
-
})
|
|
432
|
-
.rpc();
|
|
433
|
-
}
|
|
434
|
-
|
|
435
|
-
/**
|
|
436
|
-
* Identify orphan PendingSettlement PDAs that cannot be finalized.
|
|
437
|
-
*
|
|
438
|
-
* @returns `null` if the PDA is finalizable (or already finalized / disputed).
|
|
439
|
-
* Otherwise an object describing the inconsistency, suitable for
|
|
440
|
-
* logging or feeding into a quarantine list. Use this from a
|
|
441
|
-
* recovery script to scan a range of `settlement_index` values:
|
|
442
|
-
*
|
|
443
|
-
* ```ts
|
|
444
|
-
* for (let idx = 0n; idx < currentIdx; idx++) {
|
|
445
|
-
* const orphan = await sap.escrowV2.diagnoseOrphanPending(
|
|
446
|
-
* agentWallet, depositorWallet, nonce, idx,
|
|
447
|
-
* );
|
|
448
|
-
* if (orphan) log.warn({ idx, ...orphan }, "skip orphan");
|
|
449
|
-
* }
|
|
450
|
-
* ```
|
|
451
|
-
*
|
|
452
|
-
* @since v0.12.9
|
|
453
|
-
*/
|
|
454
|
-
async diagnoseOrphanPending(
|
|
455
|
-
agentWallet: PublicKey,
|
|
456
|
-
depositorWallet: PublicKey,
|
|
457
|
-
nonce: BN | number | bigint,
|
|
458
|
-
settlementIndex: BN | number | bigint,
|
|
459
|
-
): Promise<{
|
|
460
|
-
pendingPda: PublicKey;
|
|
461
|
-
psAmount: bigint;
|
|
462
|
-
escrowPendingAmount: bigint;
|
|
463
|
-
escrowBalance: bigint;
|
|
464
|
-
isFinalized: boolean;
|
|
465
|
-
isDisputed: boolean;
|
|
466
|
-
reason: "ok" | "missing" | "amount_exceeds_pending" | "amount_exceeds_balance" | "already_finalized" | "disputed";
|
|
467
|
-
} | null> {
|
|
468
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
469
|
-
const [escrowPda] = this.deriveEscrow(agentPda, depositorWallet, nonce);
|
|
470
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
471
|
-
const [escrowAcc, pendingAcc] = await Promise.all([
|
|
472
|
-
this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", escrowPda),
|
|
473
|
-
this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda),
|
|
474
|
-
]);
|
|
475
|
-
if (!escrowAcc) return null;
|
|
476
|
-
if (!pendingAcc) {
|
|
477
|
-
return {
|
|
478
|
-
pendingPda,
|
|
479
|
-
psAmount: 0n,
|
|
480
|
-
escrowPendingAmount: BigInt(escrowAcc.pendingAmount.toString()),
|
|
481
|
-
escrowBalance: BigInt(escrowAcc.balance.toString()),
|
|
482
|
-
isFinalized: false,
|
|
483
|
-
isDisputed: false,
|
|
484
|
-
reason: "missing",
|
|
485
|
-
};
|
|
486
|
-
}
|
|
487
|
-
const psAmount = BigInt(pendingAcc.amount.toString());
|
|
488
|
-
const escrowPendingAmount = BigInt(escrowAcc.pendingAmount.toString());
|
|
489
|
-
const escrowBalance = BigInt(escrowAcc.balance.toString());
|
|
490
|
-
const base = {
|
|
491
|
-
pendingPda,
|
|
492
|
-
psAmount,
|
|
493
|
-
escrowPendingAmount,
|
|
494
|
-
escrowBalance,
|
|
495
|
-
isFinalized: pendingAcc.isFinalized,
|
|
496
|
-
isDisputed: pendingAcc.isDisputed,
|
|
497
|
-
};
|
|
498
|
-
if (pendingAcc.isFinalized) return { ...base, reason: "already_finalized" };
|
|
499
|
-
if (pendingAcc.isDisputed) return { ...base, reason: "disputed" };
|
|
500
|
-
if (psAmount > escrowPendingAmount) return { ...base, reason: "amount_exceeds_pending" };
|
|
501
|
-
if (psAmount > escrowBalance) return { ...base, reason: "amount_exceeds_balance" };
|
|
502
|
-
return null;
|
|
503
|
-
}
|
|
504
|
-
|
|
505
|
-
async fileDispute(
|
|
506
|
-
agentWallet: PublicKey,
|
|
507
|
-
nonce: BN | number | bigint,
|
|
508
|
-
settlementIndex: BN | number | bigint,
|
|
509
|
-
evidenceHash: number[],
|
|
510
|
-
disputeType: number = 0,
|
|
511
|
-
): Promise<TransactionSignature> {
|
|
512
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
513
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
514
|
-
const [pendingPda] = this.derivePendingSettlement(escrowPda, settlementIndex);
|
|
515
|
-
const [disputePda] = this.deriveDispute(pendingPda);
|
|
516
|
-
|
|
517
|
-
return this.methods
|
|
518
|
-
.fileDispute(evidenceHash, disputeType)
|
|
519
|
-
.accounts({
|
|
520
|
-
depositor: this.walletPubkey,
|
|
521
|
-
escrow: escrowPda,
|
|
522
|
-
pendingSettlement: pendingPda,
|
|
523
|
-
dispute: disputePda,
|
|
524
|
-
systemProgram: SystemProgram.programId,
|
|
525
|
-
})
|
|
526
|
-
.rpc();
|
|
527
|
-
}
|
|
528
|
-
|
|
529
|
-
/**
|
|
530
|
-
* @deprecated Since v0.7.0 — Arbiter-based resolution removed.
|
|
531
|
-
* Use {@link ReceiptModule.submitReceiptProof} + {@link ReceiptModule.autoResolveDispute} instead.
|
|
532
|
-
*/
|
|
533
|
-
async resolveDispute(
|
|
534
|
-
_depositorWallet: PublicKey,
|
|
535
|
-
_agentWallet: PublicKey,
|
|
536
|
-
_nonce: BN | number | bigint,
|
|
537
|
-
_settlementIndex: BN | number | bigint,
|
|
538
|
-
_outcome: number,
|
|
539
|
-
): Promise<TransactionSignature> {
|
|
540
|
-
throw new Error("resolveDispute removed in v0.7.0 — use ReceiptModule.autoResolveDispute");
|
|
541
|
-
}
|
|
542
|
-
|
|
543
|
-
async closeDispute(
|
|
544
|
-
pendingSettlementPda: PublicKey,
|
|
545
|
-
): Promise<TransactionSignature> {
|
|
546
|
-
const [disputePda] = this.deriveDispute(pendingSettlementPda);
|
|
547
|
-
|
|
548
|
-
return this.methods
|
|
549
|
-
.closeDispute()
|
|
550
|
-
.accounts({
|
|
551
|
-
depositor: this.walletPubkey,
|
|
552
|
-
dispute: disputePda,
|
|
553
|
-
})
|
|
554
|
-
.rpc();
|
|
555
|
-
}
|
|
556
|
-
|
|
557
|
-
async closePendingSettlement(
|
|
558
|
-
pendingSettlementPda: PublicKey,
|
|
559
|
-
): Promise<TransactionSignature> {
|
|
560
|
-
return this.methods
|
|
561
|
-
.closePendingSettlement()
|
|
562
|
-
.accounts({
|
|
563
|
-
payer: this.walletPubkey,
|
|
564
|
-
pendingSettlement: pendingSettlementPda,
|
|
565
|
-
})
|
|
566
|
-
.rpc();
|
|
567
|
-
}
|
|
568
|
-
|
|
569
|
-
async withdraw(
|
|
570
|
-
agentWallet: PublicKey,
|
|
571
|
-
nonce: BN | number | bigint,
|
|
572
|
-
amount: BN | number | bigint,
|
|
573
|
-
): Promise<TransactionSignature> {
|
|
574
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
575
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
576
|
-
|
|
577
|
-
return this.methods
|
|
578
|
-
.withdrawEscrowV2(this.bn(amount))
|
|
579
|
-
.accounts({
|
|
580
|
-
depositor: this.walletPubkey,
|
|
581
|
-
escrow: escrowPda,
|
|
582
|
-
})
|
|
583
|
-
.rpc();
|
|
584
|
-
}
|
|
585
|
-
|
|
586
|
-
async close(
|
|
587
|
-
agentWallet: PublicKey,
|
|
588
|
-
nonce: BN | number | bigint = 0,
|
|
589
|
-
): Promise<TransactionSignature> {
|
|
590
|
-
const [agentPda] = deriveAgent(agentWallet);
|
|
591
|
-
const [escrowPda] = this.deriveEscrow(agentPda, undefined, nonce);
|
|
592
|
-
|
|
593
|
-
return this.methods
|
|
594
|
-
.closeEscrowV2()
|
|
595
|
-
.accounts({
|
|
596
|
-
depositor: this.walletPubkey,
|
|
597
|
-
escrow: escrowPda,
|
|
598
|
-
})
|
|
599
|
-
.rpc();
|
|
600
|
-
}
|
|
601
|
-
|
|
602
|
-
/**
|
|
603
|
-
* @deprecated Since v0.7.0 — Migration instruction removed from program.
|
|
604
|
-
*/
|
|
605
|
-
async migrateFromV1(
|
|
606
|
-
_agentWallet: PublicKey,
|
|
607
|
-
): Promise<TransactionSignature> {
|
|
608
|
-
throw new Error("migrateFromV1 removed in v0.7.0 — migration instruction was deleted");
|
|
609
|
-
}
|
|
610
|
-
|
|
611
|
-
// ── Fetchers ─────────────────────────────────────────
|
|
612
|
-
|
|
613
|
-
async fetch(
|
|
614
|
-
agentPda: PublicKey,
|
|
615
|
-
depositor?: PublicKey,
|
|
616
|
-
nonce: BN | number | bigint = 0,
|
|
617
|
-
): Promise<EscrowAccountV2Data> {
|
|
618
|
-
const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
|
|
619
|
-
return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", pda);
|
|
620
|
-
}
|
|
621
|
-
|
|
622
|
-
async fetchNullable(
|
|
623
|
-
agentPda: PublicKey,
|
|
624
|
-
depositor?: PublicKey,
|
|
625
|
-
nonce: BN | number | bigint = 0,
|
|
626
|
-
): Promise<EscrowAccountV2Data | null> {
|
|
627
|
-
const [pda] = this.deriveEscrow(agentPda, depositor, nonce);
|
|
628
|
-
return this.fetchAccountNullable<EscrowAccountV2Data>("escrowAccountV2", pda);
|
|
629
|
-
}
|
|
630
|
-
|
|
631
|
-
async fetchByPda(escrowPda: PublicKey): Promise<EscrowAccountV2Data> {
|
|
632
|
-
return this.fetchAccount<EscrowAccountV2Data>("escrowAccountV2", escrowPda);
|
|
633
|
-
}
|
|
634
|
-
|
|
635
|
-
async fetchPendingSettlement(
|
|
636
|
-
pendingPda: PublicKey,
|
|
637
|
-
): Promise<PendingSettlementData> {
|
|
638
|
-
return this.fetchAccount<PendingSettlementData>("pendingSettlement", pendingPda);
|
|
639
|
-
}
|
|
640
|
-
|
|
641
|
-
async fetchPendingSettlementNullable(
|
|
642
|
-
pendingPda: PublicKey,
|
|
643
|
-
): Promise<PendingSettlementData | null> {
|
|
644
|
-
return this.fetchAccountNullable<PendingSettlementData>("pendingSettlement", pendingPda);
|
|
645
|
-
}
|
|
646
|
-
|
|
647
|
-
async fetchDispute(
|
|
648
|
-
disputePda: PublicKey,
|
|
649
|
-
): Promise<DisputeRecordData> {
|
|
650
|
-
return this.fetchAccount<DisputeRecordData>("disputeRecord", disputePda);
|
|
651
|
-
}
|
|
652
|
-
|
|
653
|
-
async fetchDisputeNullable(
|
|
654
|
-
disputePda: PublicKey,
|
|
655
|
-
): Promise<DisputeRecordData | null> {
|
|
656
|
-
return this.fetchAccountNullable<DisputeRecordData>("disputeRecord", disputePda);
|
|
657
|
-
}
|
|
658
|
-
}
|