@oobe-protocol-labs/synapse-sap-sdk 0.14.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/LICENSE +21 -0
- package/README.md +986 -0
- package/dist/cjs/client.js +30 -13
- package/dist/cjs/client.js.map +1 -1
- package/dist/cjs/constants/addresses.js +143 -0
- package/dist/cjs/constants/addresses.js.map +1 -0
- package/dist/cjs/constants/index.js +64 -0
- package/dist/cjs/constants/index.js.map +1 -0
- package/dist/cjs/constants/limits.js +161 -0
- package/dist/cjs/constants/limits.js.map +1 -0
- package/dist/cjs/constants/network.js +81 -0
- package/dist/cjs/constants/network.js.map +1 -0
- package/dist/cjs/constants/payments.js +137 -0
- package/dist/cjs/constants/payments.js.map +1 -0
- package/dist/cjs/constants/programs.js +78 -0
- package/dist/cjs/constants/programs.js.map +1 -0
- package/dist/cjs/constants/seeds.js +76 -0
- package/dist/cjs/constants/seeds.js.map +1 -0
- package/dist/cjs/constants.js +39 -32
- package/dist/cjs/constants.js.map +1 -1
- package/dist/cjs/core/client.js +546 -0
- package/dist/cjs/core/client.js.map +1 -0
- package/dist/cjs/core/connection.js +350 -0
- package/dist/cjs/core/connection.js.map +1 -0
- package/dist/cjs/core/index.js +25 -0
- package/dist/cjs/core/index.js.map +1 -0
- package/dist/cjs/errors/index.js +334 -0
- package/dist/cjs/errors/index.js.map +1 -0
- package/dist/cjs/errors.js +15 -5
- package/dist/cjs/errors.js.map +1 -1
- package/dist/cjs/events/geyser.js +295 -0
- package/dist/cjs/events/geyser.js.map +1 -0
- package/dist/cjs/events/index.js +32 -26
- package/dist/cjs/events/index.js.map +1 -1
- package/dist/cjs/idl/index.js +63 -0
- package/dist/cjs/idl/index.js.map +1 -0
- package/dist/cjs/idl/synapse_agent_sap.json +14595 -0
- package/dist/cjs/instructions/agent.js +1 -0
- package/dist/cjs/instructions/agent.js.map +1 -1
- package/dist/cjs/instructions/attestation.js +1 -0
- package/dist/cjs/instructions/attestation.js.map +1 -1
- package/dist/cjs/instructions/digest.js +1 -0
- package/dist/cjs/instructions/digest.js.map +1 -1
- package/dist/cjs/instructions/dispute.js +1 -0
- package/dist/cjs/instructions/dispute.js.map +1 -1
- package/dist/cjs/instructions/escrow.js +1 -0
- package/dist/cjs/instructions/escrow.js.map +1 -1
- package/dist/cjs/instructions/global.js +1 -0
- package/dist/cjs/instructions/global.js.map +1 -1
- package/dist/cjs/instructions/indexing.js +1 -0
- package/dist/cjs/instructions/indexing.js.map +1 -1
- package/dist/cjs/instructions/misc.js +1 -0
- package/dist/cjs/instructions/misc.js.map +1 -1
- package/dist/cjs/instructions/session.js +1 -0
- package/dist/cjs/instructions/session.js.map +1 -1
- package/dist/cjs/instructions/staking.js +1 -0
- package/dist/cjs/instructions/staking.js.map +1 -1
- package/dist/cjs/instructions/subscription.js +1 -0
- package/dist/cjs/instructions/subscription.js.map +1 -1
- package/dist/cjs/instructions/tools.js +1 -0
- package/dist/cjs/instructions/tools.js.map +1 -1
- package/dist/cjs/instructions/vault.js +1 -0
- package/dist/cjs/instructions/vault.js.map +1 -1
- package/dist/cjs/modules/agent.js +272 -0
- package/dist/cjs/modules/agent.js.map +1 -0
- package/dist/cjs/modules/attestation.js +147 -0
- package/dist/cjs/modules/attestation.js.map +1 -0
- package/dist/cjs/modules/base.js +189 -0
- package/dist/cjs/modules/base.js.map +1 -0
- package/dist/cjs/modules/escrow-v2.js +607 -0
- package/dist/cjs/modules/escrow-v2.js.map +1 -0
- package/dist/cjs/modules/escrow.js +336 -0
- package/dist/cjs/modules/escrow.js.map +1 -0
- package/dist/cjs/modules/feedback.js +166 -0
- package/dist/cjs/modules/feedback.js.map +1 -0
- package/dist/cjs/modules/index.js +43 -0
- package/dist/cjs/modules/index.js.map +1 -0
- package/dist/cjs/modules/indexing.js +375 -0
- package/dist/cjs/modules/indexing.js.map +1 -0
- package/dist/cjs/modules/ledger.js +234 -0
- package/dist/cjs/modules/ledger.js.map +1 -0
- package/dist/cjs/modules/receipt.js +148 -0
- package/dist/cjs/modules/receipt.js.map +1 -0
- package/dist/cjs/modules/staking.js +159 -0
- package/dist/cjs/modules/staking.js.map +1 -0
- package/dist/cjs/modules/subscription.js +96 -0
- package/dist/cjs/modules/subscription.js.map +1 -0
- package/dist/cjs/modules/tools.js +345 -0
- package/dist/cjs/modules/tools.js.map +1 -0
- package/dist/cjs/modules/vault.js +427 -0
- package/dist/cjs/modules/vault.js.map +1 -0
- package/dist/cjs/parser/client.js +146 -0
- package/dist/cjs/parser/client.js.map +1 -0
- package/dist/cjs/parser/complete.js +177 -0
- package/dist/cjs/parser/complete.js.map +1 -0
- package/dist/cjs/parser/index.js +57 -0
- package/dist/cjs/parser/index.js.map +1 -0
- package/dist/cjs/parser/inner.js +185 -0
- package/dist/cjs/parser/inner.js.map +1 -0
- package/dist/cjs/parser/instructions.js +114 -0
- package/dist/cjs/parser/instructions.js.map +1 -0
- package/dist/cjs/parser/transaction.js +153 -0
- package/dist/cjs/parser/transaction.js.map +1 -0
- package/dist/cjs/parser/types.js +14 -0
- package/dist/cjs/parser/types.js.map +1 -0
- package/dist/cjs/pda/index.js +672 -0
- package/dist/cjs/pda/index.js.map +1 -0
- package/dist/cjs/plugin/index.js +952 -0
- package/dist/cjs/plugin/index.js.map +1 -0
- package/dist/cjs/plugin/protocols.js +282 -0
- package/dist/cjs/plugin/protocols.js.map +1 -0
- package/dist/cjs/plugin/schemas.js +863 -0
- package/dist/cjs/plugin/schemas.js.map +1 -0
- package/dist/cjs/postgres/adapter.js +715 -0
- package/dist/cjs/postgres/adapter.js.map +1 -0
- package/dist/cjs/postgres/index.js +50 -0
- package/dist/cjs/postgres/index.js.map +1 -0
- package/dist/cjs/postgres/serializers.js +381 -0
- package/dist/cjs/postgres/serializers.js.map +1 -0
- package/dist/cjs/postgres/sync.js +289 -0
- package/dist/cjs/postgres/sync.js.map +1 -0
- package/dist/cjs/postgres/types.js +44 -0
- package/dist/cjs/postgres/types.js.map +1 -0
- package/dist/cjs/registries/builder.js +414 -0
- package/dist/cjs/registries/builder.js.map +1 -0
- package/dist/cjs/registries/discovery.js +362 -0
- package/dist/cjs/registries/discovery.js.map +1 -0
- package/dist/cjs/registries/fairscale.js +639 -0
- package/dist/cjs/registries/fairscale.js.map +1 -0
- package/dist/cjs/registries/index.js +58 -0
- package/dist/cjs/registries/index.js.map +1 -0
- package/dist/cjs/registries/metaplex-bridge.js +743 -0
- package/dist/cjs/registries/metaplex-bridge.js.map +1 -0
- package/dist/cjs/registries/session.js +433 -0
- package/dist/cjs/registries/session.js.map +1 -0
- package/dist/cjs/registries/x402.js +668 -0
- package/dist/cjs/registries/x402.js.map +1 -0
- package/dist/cjs/types/accounts.js +13 -0
- package/dist/cjs/types/accounts.js.map +1 -0
- package/dist/cjs/types/common.js +13 -0
- package/dist/cjs/types/common.js.map +1 -0
- package/dist/cjs/types/endpoint.js +15 -0
- package/dist/cjs/types/endpoint.js.map +1 -0
- package/dist/cjs/types/enums.js +269 -0
- package/dist/cjs/types/enums.js.map +1 -0
- package/dist/cjs/types/index.js +41 -0
- package/dist/cjs/types/index.js.map +1 -0
- package/dist/cjs/types/instructions.js +92 -0
- package/dist/cjs/types/instructions.js.map +1 -0
- package/dist/cjs/types.js +4 -1
- package/dist/cjs/types.js.map +1 -1
- package/dist/cjs/utils/anchor-errors.js +453 -0
- package/dist/cjs/utils/anchor-errors.js.map +1 -0
- package/dist/cjs/utils/endpoint-validator.js +232 -0
- package/dist/cjs/utils/endpoint-validator.js.map +1 -0
- package/dist/cjs/utils/escrow-validation.js +219 -0
- package/dist/cjs/utils/escrow-validation.js.map +1 -0
- package/dist/cjs/utils/hash.js +109 -0
- package/dist/cjs/utils/hash.js.map +1 -0
- package/dist/cjs/utils/index.js +10 -4
- package/dist/cjs/utils/index.js.map +1 -1
- package/dist/cjs/utils/merchant-validator.js +246 -0
- package/dist/cjs/utils/merchant-validator.js.map +1 -0
- package/dist/cjs/utils/network-normalizer.js +236 -0
- package/dist/cjs/utils/network-normalizer.js.map +1 -0
- package/dist/cjs/utils/priority-fee.js +215 -0
- package/dist/cjs/utils/priority-fee.js.map +1 -0
- package/dist/cjs/utils/rpc-strategy.js +239 -0
- package/dist/cjs/utils/rpc-strategy.js.map +1 -0
- package/dist/cjs/utils/schemas.js +331 -0
- package/dist/cjs/utils/schemas.js.map +1 -0
- package/dist/cjs/utils/serialization.js +105 -0
- package/dist/cjs/utils/serialization.js.map +1 -0
- package/dist/cjs/utils/validate.js +1 -1
- package/dist/cjs/utils/validate.js.map +1 -1
- package/dist/cjs/utils/validation.js +36 -0
- package/dist/cjs/utils/validation.js.map +1 -0
- package/dist/cjs/utils/volume-curve.js +117 -0
- package/dist/cjs/utils/volume-curve.js.map +1 -0
- package/dist/cjs/utils/x402-direct.js +231 -0
- package/dist/cjs/utils/x402-direct.js.map +1 -0
- package/dist/esm/client.js +30 -13
- package/dist/esm/client.js.map +1 -1
- package/dist/esm/constants/addresses.d.ts +117 -0
- package/dist/esm/constants/addresses.d.ts.map +1 -0
- package/dist/esm/constants/addresses.js +140 -0
- package/dist/esm/constants/addresses.js.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/index.js +35 -0
- package/dist/esm/constants/index.js.map +1 -0
- package/dist/esm/constants/limits.d.ts +149 -0
- package/dist/esm/constants/limits.d.ts.map +1 -0
- package/dist/esm/constants/limits.js +158 -0
- package/dist/esm/constants/limits.js.map +1 -0
- package/dist/esm/constants/network.d.ts +81 -0
- package/dist/esm/constants/network.d.ts.map +1 -0
- package/dist/esm/constants/network.js +78 -0
- package/dist/esm/constants/network.js.map +1 -0
- package/dist/esm/constants/payments.d.ts +121 -0
- package/dist/esm/constants/payments.d.ts.map +1 -0
- package/dist/esm/constants/payments.js +131 -0
- package/dist/esm/constants/payments.js.map +1 -0
- package/dist/esm/constants/programs.d.ts +69 -0
- package/dist/esm/constants/programs.d.ts.map +1 -0
- package/dist/esm/constants/programs.js +75 -0
- package/dist/esm/constants/programs.js.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 +73 -0
- package/dist/esm/constants/seeds.js.map +1 -0
- package/dist/esm/constants.d.ts +14 -27
- package/dist/esm/constants.d.ts.map +1 -1
- package/dist/esm/constants.js +16 -31
- package/dist/esm/constants.js.map +1 -1
- package/dist/esm/core/client.d.ts +452 -0
- package/dist/esm/core/client.d.ts.map +1 -0
- package/dist/esm/core/client.js +539 -0
- package/dist/esm/core/client.js.map +1 -0
- package/dist/esm/core/connection.d.ts +305 -0
- package/dist/esm/core/connection.d.ts.map +1 -0
- package/dist/esm/core/connection.js +345 -0
- package/dist/esm/core/connection.js.map +1 -0
- package/dist/esm/core/index.d.ts +20 -0
- package/dist/esm/core/index.d.ts.map +1 -0
- package/dist/esm/core/index.js +19 -0
- package/dist/esm/core/index.js.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/index.js +325 -0
- package/dist/esm/errors/index.js.map +1 -0
- package/dist/esm/errors.d.ts +8 -0
- package/dist/esm/errors.d.ts.map +1 -1
- package/dist/esm/errors.js +8 -0
- package/dist/esm/errors.js.map +1 -1
- package/dist/esm/events/geyser.d.ts +150 -0
- package/dist/esm/events/geyser.d.ts.map +1 -0
- package/dist/esm/events/geyser.js +258 -0
- package/dist/esm/events/geyser.js.map +1 -0
- package/dist/esm/events/index.d.ts +11 -7
- package/dist/esm/events/index.d.ts.map +1 -1
- package/dist/esm/events/index.js +30 -26
- package/dist/esm/events/index.js.map +1 -1
- package/dist/esm/idl/index.d.ts +70 -0
- package/dist/esm/idl/index.d.ts.map +1 -0
- package/dist/esm/idl/index.js +57 -0
- package/dist/esm/idl/index.js.map +1 -0
- package/dist/esm/idl/synapse_agent_sap.json +14595 -0
- package/dist/esm/instructions/agent.js +1 -0
- package/dist/esm/instructions/agent.js.map +1 -1
- package/dist/esm/instructions/attestation.js +1 -0
- package/dist/esm/instructions/attestation.js.map +1 -1
- package/dist/esm/instructions/digest.js +1 -0
- package/dist/esm/instructions/digest.js.map +1 -1
- package/dist/esm/instructions/dispute.js +1 -0
- package/dist/esm/instructions/dispute.js.map +1 -1
- package/dist/esm/instructions/escrow.js +1 -0
- package/dist/esm/instructions/escrow.js.map +1 -1
- package/dist/esm/instructions/global.js +1 -0
- package/dist/esm/instructions/global.js.map +1 -1
- package/dist/esm/instructions/indexing.js +1 -0
- package/dist/esm/instructions/indexing.js.map +1 -1
- package/dist/esm/instructions/misc.js +1 -0
- package/dist/esm/instructions/misc.js.map +1 -1
- package/dist/esm/instructions/session.js +1 -0
- package/dist/esm/instructions/session.js.map +1 -1
- package/dist/esm/instructions/staking.js +1 -0
- package/dist/esm/instructions/staking.js.map +1 -1
- package/dist/esm/instructions/subscription.js +1 -0
- package/dist/esm/instructions/subscription.js.map +1 -1
- package/dist/esm/instructions/tools.js +1 -0
- package/dist/esm/instructions/tools.js.map +1 -1
- package/dist/esm/instructions/vault.js +1 -0
- package/dist/esm/instructions/vault.js.map +1 -1
- package/dist/esm/modules/agent.d.ts +166 -0
- package/dist/esm/modules/agent.d.ts.map +1 -0
- package/dist/esm/modules/agent.js +268 -0
- package/dist/esm/modules/agent.js.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/attestation.js +143 -0
- package/dist/esm/modules/attestation.js.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/base.js +185 -0
- package/dist/esm/modules/base.js.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/escrow-v2.js +603 -0
- package/dist/esm/modules/escrow-v2.js.map +1 -0
- package/dist/esm/modules/escrow.d.ts +168 -0
- package/dist/esm/modules/escrow.d.ts.map +1 -0
- package/dist/esm/modules/escrow.js +332 -0
- package/dist/esm/modules/escrow.js.map +1 -0
- package/dist/esm/modules/feedback.d.ts +105 -0
- package/dist/esm/modules/feedback.d.ts.map +1 -0
- package/dist/esm/modules/feedback.js +162 -0
- package/dist/esm/modules/feedback.js.map +1 -0
- package/dist/esm/modules/index.d.ts +28 -0
- package/dist/esm/modules/index.d.ts.map +1 -0
- package/dist/esm/modules/index.js +27 -0
- package/dist/esm/modules/index.js.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/indexing.js +371 -0
- package/dist/esm/modules/indexing.js.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/ledger.js +230 -0
- package/dist/esm/modules/ledger.js.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/receipt.js +144 -0
- package/dist/esm/modules/receipt.js.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/staking.js +155 -0
- package/dist/esm/modules/staking.js.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/subscription.js +92 -0
- package/dist/esm/modules/subscription.js.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/tools.js +341 -0
- package/dist/esm/modules/tools.js.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/modules/vault.js +423 -0
- package/dist/esm/modules/vault.js.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/client.js +142 -0
- package/dist/esm/parser/client.js.map +1 -0
- package/dist/esm/parser/complete.d.ts +90 -0
- package/dist/esm/parser/complete.d.ts.map +1 -0
- package/dist/esm/parser/complete.js +173 -0
- package/dist/esm/parser/complete.js.map +1 -0
- package/dist/esm/parser/index.d.ts +40 -0
- package/dist/esm/parser/index.d.ts.map +1 -0
- package/dist/esm/parser/index.js +43 -0
- package/dist/esm/parser/index.js.map +1 -0
- package/dist/esm/parser/inner.d.ts +114 -0
- package/dist/esm/parser/inner.d.ts.map +1 -0
- package/dist/esm/parser/inner.js +180 -0
- package/dist/esm/parser/inner.js.map +1 -0
- package/dist/esm/parser/instructions.d.ts +76 -0
- package/dist/esm/parser/instructions.d.ts.map +1 -0
- package/dist/esm/parser/instructions.js +109 -0
- package/dist/esm/parser/instructions.js.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/transaction.js +149 -0
- package/dist/esm/parser/transaction.js.map +1 -0
- package/dist/esm/parser/types.d.ts +154 -0
- package/dist/esm/parser/types.d.ts.map +1 -0
- package/dist/esm/parser/types.js +13 -0
- package/dist/esm/parser/types.js.map +1 -0
- package/dist/esm/pda/index.d.ts +510 -0
- package/dist/esm/pda/index.d.ts.map +1 -0
- package/dist/esm/pda/index.js +638 -0
- package/dist/esm/pda/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/index.js +945 -0
- package/dist/esm/plugin/index.js.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/protocols.js +279 -0
- package/dist/esm/plugin/protocols.js.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/plugin/schemas.js +860 -0
- package/dist/esm/plugin/schemas.js.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/adapter.js +678 -0
- package/dist/esm/postgres/adapter.js.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/index.js +27 -0
- package/dist/esm/postgres/index.js.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/serializers.js +362 -0
- package/dist/esm/postgres/serializers.js.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/sync.js +285 -0
- package/dist/esm/postgres/sync.js.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/postgres/types.js +41 -0
- package/dist/esm/postgres/types.js.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/builder.js +410 -0
- package/dist/esm/registries/builder.js.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/discovery.js +358 -0
- package/dist/esm/registries/discovery.js.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 +633 -0
- package/dist/esm/registries/fairscale.js.map +1 -0
- package/dist/esm/registries/index.d.ts +52 -0
- package/dist/esm/registries/index.d.ts.map +1 -0
- package/dist/esm/registries/index.js +46 -0
- package/dist/esm/registries/index.js.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 +706 -0
- package/dist/esm/registries/metaplex-bridge.js.map +1 -0
- package/dist/esm/registries/session.d.ts +323 -0
- package/dist/esm/registries/session.d.ts.map +1 -0
- package/dist/esm/registries/session.js +429 -0
- package/dist/esm/registries/session.js.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/registries/x402.js +664 -0
- package/dist/esm/registries/x402.js.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/accounts.js +12 -0
- package/dist/esm/types/accounts.js.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/common.js +12 -0
- package/dist/esm/types/common.js.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/endpoint.js +14 -0
- package/dist/esm/types/endpoint.js.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/enums.js +266 -0
- package/dist/esm/types/enums.js.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/index.js +25 -0
- package/dist/esm/types/index.js.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/instructions.js +89 -0
- package/dist/esm/types/instructions.js.map +1 -0
- package/dist/esm/types.d.ts +28 -0
- package/dist/esm/types.d.ts.map +1 -1
- package/dist/esm/types.js +1 -0
- package/dist/esm/types.js.map +1 -1
- 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/anchor-errors.js +447 -0
- package/dist/esm/utils/anchor-errors.js.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/endpoint-validator.js +226 -0
- package/dist/esm/utils/endpoint-validator.js.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 +212 -0
- package/dist/esm/utils/escrow-validation.js.map +1 -0
- package/dist/esm/utils/hash.d.ts +75 -0
- package/dist/esm/utils/hash.d.ts.map +1 -0
- package/dist/esm/utils/hash.js +103 -0
- package/dist/esm/utils/hash.js.map +1 -0
- package/dist/esm/utils/index.d.ts +3 -1
- package/dist/esm/utils/index.d.ts.map +1 -1
- package/dist/esm/utils/index.js +6 -3
- 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 +241 -0
- package/dist/esm/utils/merchant-validator.js.map +1 -0
- 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/network-normalizer.js +229 -0
- package/dist/esm/utils/network-normalizer.js.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/priority-fee.js +209 -0
- package/dist/esm/utils/priority-fee.js.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/rpc-strategy.js +231 -0
- package/dist/esm/utils/rpc-strategy.js.map +1 -0
- package/dist/esm/utils/schemas.d.ts +351 -0
- package/dist/esm/utils/schemas.d.ts.map +1 -0
- package/dist/esm/utils/schemas.js +320 -0
- package/dist/esm/utils/schemas.js.map +1 -0
- package/dist/esm/utils/serialization.d.ts +69 -0
- package/dist/esm/utils/serialization.d.ts.map +1 -0
- package/dist/esm/utils/serialization.js +98 -0
- package/dist/esm/utils/serialization.js.map +1 -0
- package/dist/esm/utils/validate.js +1 -1
- package/dist/esm/utils/validate.js.map +1 -1
- package/dist/esm/utils/validation.d.ts +29 -0
- package/dist/esm/utils/validation.d.ts.map +1 -0
- package/dist/esm/utils/validation.js +33 -0
- package/dist/esm/utils/validation.js.map +1 -0
- package/dist/esm/utils/volume-curve.d.ts +60 -0
- package/dist/esm/utils/volume-curve.d.ts.map +1 -0
- package/dist/esm/utils/volume-curve.js +114 -0
- package/dist/esm/utils/volume-curve.js.map +1 -0
- package/dist/esm/utils/x402-direct.d.ts +114 -0
- package/dist/esm/utils/x402-direct.d.ts.map +1 -0
- package/dist/esm/utils/x402-direct.js +228 -0
- package/dist/esm/utils/x402-direct.js.map +1 -0
- package/dist/types/constants/addresses.d.ts +117 -0
- package/dist/types/constants/addresses.d.ts.map +1 -0
- package/dist/types/constants/index.d.ts +31 -0
- package/dist/types/constants/index.d.ts.map +1 -0
- package/dist/types/constants/limits.d.ts +149 -0
- package/dist/types/constants/limits.d.ts.map +1 -0
- package/dist/types/constants/network.d.ts +81 -0
- package/dist/types/constants/network.d.ts.map +1 -0
- package/dist/types/constants/payments.d.ts +121 -0
- package/dist/types/constants/payments.d.ts.map +1 -0
- package/dist/types/constants/programs.d.ts +69 -0
- package/dist/types/constants/programs.d.ts.map +1 -0
- package/dist/types/constants/seeds.d.ts +82 -0
- package/dist/types/constants/seeds.d.ts.map +1 -0
- package/dist/types/core/client.d.ts +467 -0
- package/dist/types/core/client.d.ts.map +1 -0
- package/dist/types/core/connection.d.ts +305 -0
- package/dist/types/core/connection.d.ts.map +1 -0
- package/dist/types/core/index.d.ts +20 -0
- package/dist/types/core/index.d.ts.map +1 -0
- package/dist/types/errors/index.d.ts +335 -0
- package/dist/types/errors/index.d.ts.map +1 -0
- package/dist/types/events/geyser.d.ts +150 -0
- package/dist/types/events/geyser.d.ts.map +1 -0
- package/dist/types/events/index.d.ts +248 -0
- package/dist/types/events/index.d.ts.map +1 -0
- package/dist/types/idl/index.d.ts +70 -0
- package/dist/types/idl/index.d.ts.map +1 -0
- package/dist/types/index.d.ts +86 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/modules/agent.d.ts +156 -0
- package/dist/types/modules/agent.d.ts.map +1 -0
- package/dist/types/modules/attestation.d.ts +96 -0
- package/dist/types/modules/attestation.d.ts.map +1 -0
- package/dist/types/modules/base.d.ts +215 -0
- package/dist/types/modules/base.d.ts.map +1 -0
- package/dist/types/modules/escrow-v2.d.ts +285 -0
- package/dist/types/modules/escrow-v2.d.ts.map +1 -0
- package/dist/types/modules/feedback.d.ts +105 -0
- package/dist/types/modules/feedback.d.ts.map +1 -0
- package/dist/types/modules/index.d.ts +27 -0
- package/dist/types/modules/index.d.ts.map +1 -0
- package/dist/types/modules/indexing.d.ts +200 -0
- package/dist/types/modules/indexing.d.ts.map +1 -0
- package/dist/types/modules/ledger.d.ts +150 -0
- package/dist/types/modules/ledger.d.ts.map +1 -0
- package/dist/types/modules/receipt.d.ts +91 -0
- package/dist/types/modules/receipt.d.ts.map +1 -0
- package/dist/types/modules/staking.d.ts +51 -0
- package/dist/types/modules/staking.d.ts.map +1 -0
- package/dist/types/modules/subscription.d.ts +33 -0
- package/dist/types/modules/subscription.d.ts.map +1 -0
- package/dist/types/modules/tools.d.ts +172 -0
- package/dist/types/modules/tools.d.ts.map +1 -0
- package/dist/types/modules/vault.d.ts +240 -0
- package/dist/types/modules/vault.d.ts.map +1 -0
- package/dist/types/parser/client.d.ts +123 -0
- package/dist/types/parser/client.d.ts.map +1 -0
- package/dist/types/parser/complete.d.ts +90 -0
- package/dist/types/parser/complete.d.ts.map +1 -0
- package/dist/types/parser/index.d.ts +40 -0
- package/dist/types/parser/index.d.ts.map +1 -0
- package/dist/types/parser/inner.d.ts +114 -0
- package/dist/types/parser/inner.d.ts.map +1 -0
- package/dist/types/parser/instructions.d.ts +76 -0
- package/dist/types/parser/instructions.d.ts.map +1 -0
- package/dist/types/parser/transaction.d.ts +77 -0
- package/dist/types/parser/transaction.d.ts.map +1 -0
- package/dist/types/parser/types.d.ts +154 -0
- package/dist/types/parser/types.d.ts.map +1 -0
- package/dist/types/pda/index.d.ts +527 -0
- package/dist/types/pda/index.d.ts.map +1 -0
- package/dist/types/plugin/index.d.ts +171 -0
- package/dist/types/plugin/index.d.ts.map +1 -0
- package/dist/types/plugin/protocols.d.ts +152 -0
- package/dist/types/plugin/protocols.d.ts.map +1 -0
- package/dist/types/plugin/schemas.d.ts +829 -0
- package/dist/types/plugin/schemas.d.ts.map +1 -0
- package/dist/types/postgres/adapter.d.ts +355 -0
- package/dist/types/postgres/adapter.d.ts.map +1 -0
- package/dist/types/postgres/index.d.ts +24 -0
- package/dist/types/postgres/index.d.ts.map +1 -0
- package/dist/types/postgres/serializers.d.ts +30 -0
- package/dist/types/postgres/serializers.d.ts.map +1 -0
- package/dist/types/postgres/sync.d.ts +156 -0
- package/dist/types/postgres/sync.d.ts.map +1 -0
- package/dist/types/postgres/types.d.ts +167 -0
- package/dist/types/postgres/types.d.ts.map +1 -0
- package/dist/types/registries/builder.d.ts +333 -0
- package/dist/types/registries/builder.d.ts.map +1 -0
- package/dist/types/registries/discovery.d.ts +333 -0
- package/dist/types/registries/discovery.d.ts.map +1 -0
- package/dist/types/registries/fairscale.d.ts +680 -0
- package/dist/types/registries/fairscale.d.ts.map +1 -0
- package/dist/types/registries/index.d.ts +52 -0
- package/dist/types/registries/index.d.ts.map +1 -0
- package/dist/types/registries/metaplex-bridge.d.ts +488 -0
- package/dist/types/registries/metaplex-bridge.d.ts.map +1 -0
- package/dist/types/registries/session.d.ts +317 -0
- package/dist/types/registries/session.d.ts.map +1 -0
- package/dist/types/registries/x402.d.ts +523 -0
- package/dist/types/registries/x402.d.ts.map +1 -0
- package/dist/types/types/accounts.d.ts +817 -0
- package/dist/types/types/accounts.d.ts.map +1 -0
- package/dist/types/types/common.d.ts +166 -0
- package/dist/types/types/common.d.ts.map +1 -0
- package/dist/types/types/endpoint.d.ts +161 -0
- package/dist/types/types/endpoint.d.ts.map +1 -0
- package/dist/types/types/enums.d.ts +353 -0
- package/dist/types/types/enums.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +29 -0
- package/dist/types/types/index.d.ts.map +1 -0
- package/dist/types/types/instructions.d.ts +400 -0
- package/dist/types/types/instructions.d.ts.map +1 -0
- package/dist/types/utils/anchor-errors.d.ts +61 -0
- package/dist/types/utils/anchor-errors.d.ts.map +1 -0
- package/dist/types/utils/endpoint-validator.d.ts +110 -0
- package/dist/types/utils/endpoint-validator.d.ts.map +1 -0
- package/dist/types/utils/escrow-validation.d.ts +145 -0
- package/dist/types/utils/escrow-validation.d.ts.map +1 -0
- package/dist/types/utils/hash.d.ts +75 -0
- package/dist/types/utils/hash.d.ts.map +1 -0
- package/dist/types/utils/index.d.ts +36 -0
- package/dist/types/utils/index.d.ts.map +1 -0
- package/dist/types/utils/merchant-validator.d.ts +176 -0
- package/dist/types/utils/merchant-validator.d.ts.map +1 -0
- package/dist/types/utils/network-normalizer.d.ts +120 -0
- package/dist/types/utils/network-normalizer.d.ts.map +1 -0
- package/dist/types/utils/priority-fee.d.ts +205 -0
- package/dist/types/utils/priority-fee.d.ts.map +1 -0
- package/dist/types/utils/rpc-strategy.d.ts +179 -0
- package/dist/types/utils/rpc-strategy.d.ts.map +1 -0
- package/dist/types/utils/schemas.d.ts +351 -0
- package/dist/types/utils/schemas.d.ts.map +1 -0
- package/dist/types/utils/serialization.d.ts +69 -0
- package/dist/types/utils/serialization.d.ts.map +1 -0
- package/dist/types/utils/validation.d.ts +29 -0
- package/dist/types/utils/validation.d.ts.map +1 -0
- package/dist/types/utils/volume-curve.d.ts +60 -0
- package/dist/types/utils/volume-curve.d.ts.map +1 -0
- package/dist/types/utils/x402-direct.d.ts +114 -0
- package/dist/types/utils/x402-direct.d.ts.map +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module utils/endpoint-validator
|
|
3
|
+
* @description Endpoint validation utilities for SAP agent discovery.
|
|
4
|
+
*
|
|
5
|
+
* Fetches advertised endpoints and verifies they respond with JSON,
|
|
6
|
+
* proper CORS headers, and SAP-compatible behavior. Designed to
|
|
7
|
+
* fail fast when an endpoint 404s, requires CSRF tokens, or
|
|
8
|
+
* serves HTML instead of JSON.
|
|
9
|
+
*
|
|
10
|
+
* Used by:
|
|
11
|
+
* - CLI `discovery validate` command
|
|
12
|
+
* - SDK programmatic validation before x402 calls
|
|
13
|
+
* - Integration test harnesses
|
|
14
|
+
*
|
|
15
|
+
* @category Utils
|
|
16
|
+
* @since v0.6.0
|
|
17
|
+
*/
|
|
18
|
+
// ═══════════════════════════════════════════════════════════════════
|
|
19
|
+
// Core Validator
|
|
20
|
+
// ═══════════════════════════════════════════════════════════════════
|
|
21
|
+
/**
|
|
22
|
+
* @name validateEndpoint
|
|
23
|
+
* @description Validate a single endpoint URL for SAP compatibility.
|
|
24
|
+
*
|
|
25
|
+
* Performs the following checks:
|
|
26
|
+
* 1. URL is reachable (no 4xx/5xx)
|
|
27
|
+
* 2. Response Content-Type is JSON
|
|
28
|
+
* 3. CORS headers are present (if checkCors enabled)
|
|
29
|
+
* 4. No redirect to HTML login pages
|
|
30
|
+
* 5. Measures response latency
|
|
31
|
+
*
|
|
32
|
+
* @param url - The endpoint URL to validate.
|
|
33
|
+
* @param opts - Validation options.
|
|
34
|
+
* @returns An {@link EndpointValidationResult} with detailed check results.
|
|
35
|
+
*
|
|
36
|
+
* @category Utils
|
|
37
|
+
* @since v0.6.0
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* ```ts
|
|
41
|
+
* const result = await validateEndpoint("https://api.example.com/x402");
|
|
42
|
+
* if (!result.reachable) console.error(result.error);
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
45
|
+
export async function validateEndpoint(url, opts = {}) {
|
|
46
|
+
const timeoutMs = opts.timeoutMs ?? 10_000;
|
|
47
|
+
const retries = opts.retries ?? 1;
|
|
48
|
+
const method = opts.method ?? "HEAD";
|
|
49
|
+
const warnings = [];
|
|
50
|
+
let lastError;
|
|
51
|
+
for (let attempt = 0; attempt <= retries; attempt++) {
|
|
52
|
+
try {
|
|
53
|
+
const controller = new AbortController();
|
|
54
|
+
const timer = setTimeout(() => controller.abort(), timeoutMs);
|
|
55
|
+
const start = Date.now();
|
|
56
|
+
const response = await fetch(url, {
|
|
57
|
+
method,
|
|
58
|
+
signal: controller.signal,
|
|
59
|
+
headers: {
|
|
60
|
+
Accept: "application/json",
|
|
61
|
+
...(opts.headers ?? {}),
|
|
62
|
+
},
|
|
63
|
+
redirect: "follow",
|
|
64
|
+
});
|
|
65
|
+
clearTimeout(timer);
|
|
66
|
+
const latencyMs = Date.now() - start;
|
|
67
|
+
const contentType = response.headers.get("content-type") ?? "";
|
|
68
|
+
const isJson = contentType.includes("application/json") || contentType.includes("text/json");
|
|
69
|
+
const hasCors = !!response.headers.get("access-control-allow-origin");
|
|
70
|
+
// Check for HTML responses (login pages, CSRF gates)
|
|
71
|
+
if (contentType.includes("text/html")) {
|
|
72
|
+
warnings.push("Endpoint returns HTML — may require CSRF or browser session");
|
|
73
|
+
}
|
|
74
|
+
// Check for redirect chains
|
|
75
|
+
if (response.redirected) {
|
|
76
|
+
warnings.push(`Endpoint redirected to ${response.url}`);
|
|
77
|
+
}
|
|
78
|
+
// Check for common error statuses
|
|
79
|
+
if (response.status === 403) {
|
|
80
|
+
warnings.push("403 Forbidden — may require authentication or CSRF tokens");
|
|
81
|
+
}
|
|
82
|
+
if (response.status === 404) {
|
|
83
|
+
warnings.push("404 Not Found — endpoint URL may be incorrect");
|
|
84
|
+
}
|
|
85
|
+
if (response.status === 405) {
|
|
86
|
+
warnings.push(`405 Method Not Allowed — endpoint may not accept ${method}`);
|
|
87
|
+
}
|
|
88
|
+
// Determine SAP capability
|
|
89
|
+
const isSapCapable = isJson &&
|
|
90
|
+
response.status < 400 &&
|
|
91
|
+
!contentType.includes("text/html");
|
|
92
|
+
// CORS check if requested
|
|
93
|
+
if (opts.checkCors && !hasCors) {
|
|
94
|
+
warnings.push("No CORS headers — cross-origin requests will fail");
|
|
95
|
+
}
|
|
96
|
+
return {
|
|
97
|
+
url,
|
|
98
|
+
reachable: response.status < 500,
|
|
99
|
+
statusCode: response.status,
|
|
100
|
+
latencyMs,
|
|
101
|
+
isJson,
|
|
102
|
+
hasCors,
|
|
103
|
+
isSapCapable,
|
|
104
|
+
error: response.status >= 400
|
|
105
|
+
? `HTTP ${response.status}: ${response.statusText}`
|
|
106
|
+
: undefined,
|
|
107
|
+
warnings,
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
catch (err) {
|
|
111
|
+
lastError =
|
|
112
|
+
err instanceof Error ? err.message : String(err);
|
|
113
|
+
if (attempt < retries)
|
|
114
|
+
continue;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
return {
|
|
118
|
+
url,
|
|
119
|
+
reachable: false,
|
|
120
|
+
statusCode: 0,
|
|
121
|
+
latencyMs: 0,
|
|
122
|
+
isJson: false,
|
|
123
|
+
hasCors: false,
|
|
124
|
+
isSapCapable: false,
|
|
125
|
+
error: lastError ?? "Unknown error",
|
|
126
|
+
warnings,
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* @name validateEndpointDescriptor
|
|
131
|
+
* @description Validate an {@link EndpointDescriptor} with context-aware checks.
|
|
132
|
+
*
|
|
133
|
+
* Uses the descriptor's method, auth requirements, and other metadata to
|
|
134
|
+
* perform a more targeted validation than raw URL checking.
|
|
135
|
+
*
|
|
136
|
+
* @param descriptor - The endpoint descriptor to validate.
|
|
137
|
+
* @param opts - Additional options.
|
|
138
|
+
* @returns An {@link EndpointValidationResult}.
|
|
139
|
+
*
|
|
140
|
+
* @category Utils
|
|
141
|
+
* @since v0.6.0
|
|
142
|
+
*/
|
|
143
|
+
export async function validateEndpointDescriptor(descriptor, opts = {}) {
|
|
144
|
+
const headers = {
|
|
145
|
+
...(opts.headers ?? {}),
|
|
146
|
+
...(descriptor.requiredHeaders ?? {}),
|
|
147
|
+
};
|
|
148
|
+
// Use the descriptor's method, falling back to HEAD for safety
|
|
149
|
+
const method = opts.method ?? (descriptor.method === "GET" ? "GET" : "HEAD");
|
|
150
|
+
const result = await validateEndpoint(descriptor.url, {
|
|
151
|
+
...opts,
|
|
152
|
+
method,
|
|
153
|
+
headers,
|
|
154
|
+
});
|
|
155
|
+
// Add descriptor-specific warnings
|
|
156
|
+
const warnings = [...result.warnings];
|
|
157
|
+
if (descriptor.requiresCSRF) {
|
|
158
|
+
warnings.push("Endpoint declares requiresCSRF — automated calls may need token management");
|
|
159
|
+
}
|
|
160
|
+
if (descriptor.requiresCookies) {
|
|
161
|
+
warnings.push("Endpoint declares requiresCookies — stateless calls may fail");
|
|
162
|
+
}
|
|
163
|
+
if (descriptor.requiresAuth && !descriptor.authType) {
|
|
164
|
+
warnings.push("Endpoint requires auth but no authType specified");
|
|
165
|
+
}
|
|
166
|
+
return { ...result, warnings };
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* @name validateHealthCheck
|
|
170
|
+
* @description Validate an agent's health-check endpoint.
|
|
171
|
+
*
|
|
172
|
+
* @param health - The health-check descriptor.
|
|
173
|
+
* @returns An {@link EndpointValidationResult}.
|
|
174
|
+
*
|
|
175
|
+
* @category Utils
|
|
176
|
+
* @since v0.6.0
|
|
177
|
+
*/
|
|
178
|
+
export async function validateHealthCheck(health) {
|
|
179
|
+
const result = await validateEndpoint(health.url, {
|
|
180
|
+
timeoutMs: health.timeoutMs,
|
|
181
|
+
method: health.method ?? "GET",
|
|
182
|
+
});
|
|
183
|
+
const warnings = [...result.warnings];
|
|
184
|
+
if (result.reachable && result.statusCode !== health.expectedStatus) {
|
|
185
|
+
warnings.push(`Expected status ${health.expectedStatus}, got ${result.statusCode}`);
|
|
186
|
+
}
|
|
187
|
+
return {
|
|
188
|
+
...result,
|
|
189
|
+
isSapCapable: result.reachable && result.statusCode === health.expectedStatus,
|
|
190
|
+
warnings,
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* @name validateAgentEndpoints
|
|
195
|
+
* @description Validate all endpoints for an agent (primary + health + tool overrides).
|
|
196
|
+
*
|
|
197
|
+
* @param params - Object containing the endpoints to validate.
|
|
198
|
+
* @param params.endpoint - Primary endpoint descriptor.
|
|
199
|
+
* @param params.healthCheck - Optional health-check descriptor.
|
|
200
|
+
* @param params.toolEndpoints - Optional array of tool-specific endpoint overrides.
|
|
201
|
+
* @param opts - Validation options.
|
|
202
|
+
* @returns A map of `label → EndpointValidationResult`.
|
|
203
|
+
*
|
|
204
|
+
* @category Utils
|
|
205
|
+
* @since v0.6.0
|
|
206
|
+
*/
|
|
207
|
+
export async function validateAgentEndpoints(params, opts = {}) {
|
|
208
|
+
const results = new Map();
|
|
209
|
+
// Validate primary endpoint
|
|
210
|
+
const primary = await validateEndpointDescriptor(params.endpoint, opts);
|
|
211
|
+
results.set("primary", primary);
|
|
212
|
+
// Validate health check
|
|
213
|
+
if (params.healthCheck) {
|
|
214
|
+
const health = await validateHealthCheck(params.healthCheck);
|
|
215
|
+
results.set("health", health);
|
|
216
|
+
}
|
|
217
|
+
// Validate tool-specific endpoints
|
|
218
|
+
if (params.toolEndpoints) {
|
|
219
|
+
for (const { name, endpoint } of params.toolEndpoints) {
|
|
220
|
+
const toolResult = await validateEndpointDescriptor(endpoint, opts);
|
|
221
|
+
results.set(`tool:${name}`, toolResult);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
return results;
|
|
225
|
+
}
|
|
226
|
+
//# sourceMappingURL=endpoint-validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"endpoint-validator.js","sourceRoot":"","sources":["../../../src/utils/endpoint-validator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module utils/escrow-validation
|
|
3
|
+
* @description Server-side escrow validation pipeline.
|
|
4
|
+
*
|
|
5
|
+
* Provides typed helpers to validate escrow state before settlement
|
|
6
|
+
* and to build the correct SPL `AccountMeta[]` for token escrows.
|
|
7
|
+
*
|
|
8
|
+
* @category Utils
|
|
9
|
+
* @since v0.6.4
|
|
10
|
+
*/
|
|
11
|
+
import { PublicKey, type Connection, type AccountMeta } from "@solana/web3.js";
|
|
12
|
+
import { SapError } from "../errors";
|
|
13
|
+
import type { EscrowAccountData } from "../types";
|
|
14
|
+
/**
|
|
15
|
+
* @interface SplAccountMeta
|
|
16
|
+
* @description Typed SPL account metadata for escrow operations.
|
|
17
|
+
* @category Utils
|
|
18
|
+
* @since v0.6.4
|
|
19
|
+
*/
|
|
20
|
+
export interface SplAccountMeta {
|
|
21
|
+
/** Account role in the escrow pipeline. */
|
|
22
|
+
readonly kind: "escrowAta" | "depositorAta" | "tokenMint" | "tokenProgram";
|
|
23
|
+
/** Account public key. */
|
|
24
|
+
readonly pubkey: PublicKey;
|
|
25
|
+
/** Whether this account is writable. */
|
|
26
|
+
readonly writable: boolean;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* @interface EscrowValidationResult
|
|
30
|
+
* @description Result of server-side escrow state validation.
|
|
31
|
+
* @category Utils
|
|
32
|
+
* @since v0.6.4
|
|
33
|
+
*/
|
|
34
|
+
export interface EscrowValidationResult {
|
|
35
|
+
/** Whether the escrow is valid for settlement. */
|
|
36
|
+
readonly valid: boolean;
|
|
37
|
+
/** Escrow account data (if found). */
|
|
38
|
+
readonly escrow: EscrowAccountData | null;
|
|
39
|
+
/** Escrow PDA address. */
|
|
40
|
+
readonly escrowPda: PublicKey;
|
|
41
|
+
/** Agent PDA address. */
|
|
42
|
+
readonly agentPda: PublicKey;
|
|
43
|
+
/** Whether this is an SPL token escrow (vs SOL). */
|
|
44
|
+
readonly isSplEscrow: boolean;
|
|
45
|
+
/** Generated SPL account metas (empty for SOL escrows). */
|
|
46
|
+
readonly splAccounts: SplAccountMeta[];
|
|
47
|
+
/** Validation errors (empty when valid). */
|
|
48
|
+
readonly errors: string[];
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* @name MissingEscrowAtaError
|
|
52
|
+
* @description Thrown when an SPL escrow operation is missing required
|
|
53
|
+
* Associated Token Accounts.
|
|
54
|
+
* @category Errors
|
|
55
|
+
* @since v0.6.4
|
|
56
|
+
*/
|
|
57
|
+
export declare class MissingEscrowAtaError extends SapError {
|
|
58
|
+
/** The ATA address that is missing. */
|
|
59
|
+
readonly ataAddress: string;
|
|
60
|
+
/** Which side is missing: depositor or escrow. */
|
|
61
|
+
readonly side: "depositor" | "escrow";
|
|
62
|
+
constructor(ataAddress: string, side: "depositor" | "escrow");
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* @name validateEscrowState
|
|
66
|
+
* @description Validates that an escrow is in a correct state for settlement.
|
|
67
|
+
*
|
|
68
|
+
* Checks:
|
|
69
|
+
* - Escrow PDA exists on-chain
|
|
70
|
+
* - If SPL: depositor ATA exists, escrow ATA exists, token mint matches
|
|
71
|
+
* - Balance >= requested settlement amount
|
|
72
|
+
* - Escrow is not expired
|
|
73
|
+
* - Max calls not exceeded
|
|
74
|
+
*
|
|
75
|
+
* @param connection - Solana RPC connection.
|
|
76
|
+
* @param agentWallet - The agent's wallet public key.
|
|
77
|
+
* @param depositorWallet - The depositor's wallet public key.
|
|
78
|
+
* @param fetchEscrow - Callback to fetch escrow data (avoids coupling to SapProgram).
|
|
79
|
+
* @param opts
|
|
80
|
+
* @param opts.callsToSettle - Number of calls to validate affordability for.
|
|
81
|
+
*
|
|
82
|
+
* @returns A detailed {@link EscrowValidationResult}.
|
|
83
|
+
*
|
|
84
|
+
* @category Utils
|
|
85
|
+
* @since v0.6.4
|
|
86
|
+
*
|
|
87
|
+
* @example
|
|
88
|
+
* ```ts
|
|
89
|
+
* const result = await validateEscrowState(
|
|
90
|
+
* connection,
|
|
91
|
+
* agentWallet,
|
|
92
|
+
* depositorWallet,
|
|
93
|
+
* (pda) => client.escrow.fetchByPda(pda),
|
|
94
|
+
* { callsToSettle: 5 },
|
|
95
|
+
* );
|
|
96
|
+
*
|
|
97
|
+
* if (!result.valid) {
|
|
98
|
+
* console.error("Escrow validation failed:", result.errors);
|
|
99
|
+
* }
|
|
100
|
+
* ```
|
|
101
|
+
*/
|
|
102
|
+
export declare function validateEscrowState(connection: Connection, agentWallet: PublicKey, depositorWallet: PublicKey, fetchEscrow: (escrowPda: PublicKey) => Promise<EscrowAccountData | null>, opts?: {
|
|
103
|
+
callsToSettle?: number;
|
|
104
|
+
}): Promise<EscrowValidationResult>;
|
|
105
|
+
/**
|
|
106
|
+
* @name attachSplAccounts
|
|
107
|
+
* @description Build the typed `SplAccountMeta[]` for an SPL token escrow operation.
|
|
108
|
+
* Does NOT validate existence — use {@link validateEscrowState} for full validation.
|
|
109
|
+
*
|
|
110
|
+
* @param escrowPda - The escrow PDA address.
|
|
111
|
+
* @param depositorWallet - The depositor's wallet public key.
|
|
112
|
+
* @param tokenMint - The SPL token mint.
|
|
113
|
+
* @returns An array of typed {@link SplAccountMeta} for SPL escrow operations.
|
|
114
|
+
*
|
|
115
|
+
* @category Utils
|
|
116
|
+
* @since v0.6.4
|
|
117
|
+
*
|
|
118
|
+
* @example
|
|
119
|
+
* ```ts
|
|
120
|
+
* const splMetas = attachSplAccounts(escrowPda, depositorWallet, usdcMint);
|
|
121
|
+
*
|
|
122
|
+
* // Convert to Anchor-compatible AccountMeta[]
|
|
123
|
+
* const accountMetas = splMetas.map(m => ({
|
|
124
|
+
* pubkey: m.pubkey,
|
|
125
|
+
* isWritable: m.writable,
|
|
126
|
+
* isSigner: false,
|
|
127
|
+
* }));
|
|
128
|
+
*
|
|
129
|
+
* await client.escrow.settle(depositor, calls, hash, accountMetas);
|
|
130
|
+
* ```
|
|
131
|
+
*/
|
|
132
|
+
export declare function attachSplAccounts(escrowPda: PublicKey, depositorWallet: PublicKey, tokenMint: PublicKey): SplAccountMeta[];
|
|
133
|
+
/**
|
|
134
|
+
* @name toAccountMetas
|
|
135
|
+
* @description Convert typed {@link SplAccountMeta} to Anchor-compatible
|
|
136
|
+
* `AccountMeta[]` for use with `.remainingAccounts()`.
|
|
137
|
+
*
|
|
138
|
+
* @param splMetas - Array of typed SPL account metas.
|
|
139
|
+
* @returns `AccountMeta[]` compatible with Anchor's `remainingAccounts`.
|
|
140
|
+
*
|
|
141
|
+
* @category Utils
|
|
142
|
+
* @since v0.6.4
|
|
143
|
+
*/
|
|
144
|
+
export declare function toAccountMetas(splMetas: SplAccountMeta[]): AccountMeta[];
|
|
145
|
+
//# sourceMappingURL=escrow-validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"escrow-validation.d.ts","sourceRoot":"","sources":["../../../src/utils/escrow-validation.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EACL,SAAS,EACT,KAAK,UAAU,EACf,KAAK,WAAW,EACjB,MAAM,iBAAiB,CAAC;AAIzB,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAMlD;;;;;GAKG;AACH,MAAM,WAAW,cAAc;IAC7B,2CAA2C;IAC3C,QAAQ,CAAC,IAAI,EAAE,WAAW,GAAG,cAAc,GAAG,WAAW,GAAG,cAAc,CAAC;IAC3E,0BAA0B;IAC1B,QAAQ,CAAC,MAAM,EAAE,SAAS,CAAC;IAC3B,wCAAwC;IACxC,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC;CAC5B;AAED;;;;;GAKG;AACH,MAAM,WAAW,sBAAsB;IACrC,kDAAkD;IAClD,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC;IACxB,sCAAsC;IACtC,QAAQ,CAAC,MAAM,EAAE,iBAAiB,GAAG,IAAI,CAAC;IAC1C,0BAA0B;IAC1B,QAAQ,CAAC,SAAS,EAAE,SAAS,CAAC;IAC9B,yBAAyB;IACzB,QAAQ,CAAC,QAAQ,EAAE,SAAS,CAAC;IAC7B,oDAAoD;IACpD,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC;IAC9B,2DAA2D;IAC3D,QAAQ,CAAC,WAAW,EAAE,cAAc,EAAE,CAAC;IACvC,4CAA4C;IAC5C,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;CAC3B;AAMD;;;;;;GAMG;AACH,qBAAa,qBAAsB,SAAQ,QAAQ;IACjD,uCAAuC;IACvC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,kDAAkD;IAClD,QAAQ,CAAC,IAAI,EAAE,WAAW,GAAG,QAAQ,CAAC;gBAE1B,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,GAAG,QAAQ;CAU7D;AASD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AACH,wBAAsB,mBAAmB,CACvC,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,SAAS,EACtB,eAAe,EAAE,SAAS,EAC1B,WAAW,EAAE,CAAC,SAAS,EAAE,SAAS,KAAK,OAAO,CAAC,iBAAiB,GAAG,IAAI,CAAC,EACxE,IAAI,CAAC,EAAE;IAAE,aAAa,CAAC,EAAE,MAAM,CAAA;CAAE,GAChC,OAAO,CAAC,sBAAsB,CAAC,CAgGjC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,iBAAiB,CAC/B,SAAS,EAAE,SAAS,EACpB,eAAe,EAAE,SAAS,EAC1B,SAAS,EAAE,SAAS,GACnB,cAAc,EAAE,CAOlB;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,cAAc,CAAC,QAAQ,EAAE,cAAc,EAAE,GAAG,WAAW,EAAE,CAMxE"}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module utils/escrow-validation
|
|
3
|
+
* @description Server-side escrow validation pipeline.
|
|
4
|
+
*
|
|
5
|
+
* Provides typed helpers to validate escrow state before settlement
|
|
6
|
+
* and to build the correct SPL `AccountMeta[]` for token escrows.
|
|
7
|
+
*
|
|
8
|
+
* @category Utils
|
|
9
|
+
* @since v0.6.4
|
|
10
|
+
*/
|
|
11
|
+
import { PublicKey, } from "@solana/web3.js";
|
|
12
|
+
import { BN } from "@coral-xyz/anchor";
|
|
13
|
+
import { findATA } from "./rpc-strategy";
|
|
14
|
+
import { deriveAgent, deriveEscrow } from "../pda";
|
|
15
|
+
import { SapError } from "../errors";
|
|
16
|
+
// ═══════════════════════════════════════════════════════════════════
|
|
17
|
+
// Error
|
|
18
|
+
// ═══════════════════════════════════════════════════════════════════
|
|
19
|
+
/**
|
|
20
|
+
* @name MissingEscrowAtaError
|
|
21
|
+
* @description Thrown when an SPL escrow operation is missing required
|
|
22
|
+
* Associated Token Accounts.
|
|
23
|
+
* @category Errors
|
|
24
|
+
* @since v0.6.4
|
|
25
|
+
*/
|
|
26
|
+
export class MissingEscrowAtaError extends SapError {
|
|
27
|
+
/** The ATA address that is missing. */
|
|
28
|
+
ataAddress;
|
|
29
|
+
/** Which side is missing: depositor or escrow. */
|
|
30
|
+
side;
|
|
31
|
+
constructor(ataAddress, side) {
|
|
32
|
+
super(`Missing ${side} ATA: ${ataAddress}. ` +
|
|
33
|
+
`Settlement mode is Escrow/SPL but the Associated Token Account does not exist. ` +
|
|
34
|
+
`The ${side} must create the ATA before escrow operations.`);
|
|
35
|
+
this.name = "MissingEscrowAtaError";
|
|
36
|
+
this.ataAddress = ataAddress;
|
|
37
|
+
this.side = side;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
// ═══════════════════════════════════════════════════════════════════
|
|
41
|
+
// Validation
|
|
42
|
+
// ═══════════════════════════════════════════════════════════════════
|
|
43
|
+
/** Standard SPL Token program ID. */
|
|
44
|
+
const TOKEN_PROGRAM_ID_STR = "TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA";
|
|
45
|
+
/**
|
|
46
|
+
* @name validateEscrowState
|
|
47
|
+
* @description Validates that an escrow is in a correct state for settlement.
|
|
48
|
+
*
|
|
49
|
+
* Checks:
|
|
50
|
+
* - Escrow PDA exists on-chain
|
|
51
|
+
* - If SPL: depositor ATA exists, escrow ATA exists, token mint matches
|
|
52
|
+
* - Balance >= requested settlement amount
|
|
53
|
+
* - Escrow is not expired
|
|
54
|
+
* - Max calls not exceeded
|
|
55
|
+
*
|
|
56
|
+
* @param connection - Solana RPC connection.
|
|
57
|
+
* @param agentWallet - The agent's wallet public key.
|
|
58
|
+
* @param depositorWallet - The depositor's wallet public key.
|
|
59
|
+
* @param fetchEscrow - Callback to fetch escrow data (avoids coupling to SapProgram).
|
|
60
|
+
* @param opts
|
|
61
|
+
* @param opts.callsToSettle - Number of calls to validate affordability for.
|
|
62
|
+
*
|
|
63
|
+
* @returns A detailed {@link EscrowValidationResult}.
|
|
64
|
+
*
|
|
65
|
+
* @category Utils
|
|
66
|
+
* @since v0.6.4
|
|
67
|
+
*
|
|
68
|
+
* @example
|
|
69
|
+
* ```ts
|
|
70
|
+
* const result = await validateEscrowState(
|
|
71
|
+
* connection,
|
|
72
|
+
* agentWallet,
|
|
73
|
+
* depositorWallet,
|
|
74
|
+
* (pda) => client.escrow.fetchByPda(pda),
|
|
75
|
+
* { callsToSettle: 5 },
|
|
76
|
+
* );
|
|
77
|
+
*
|
|
78
|
+
* if (!result.valid) {
|
|
79
|
+
* console.error("Escrow validation failed:", result.errors);
|
|
80
|
+
* }
|
|
81
|
+
* ```
|
|
82
|
+
*/
|
|
83
|
+
export async function validateEscrowState(connection, agentWallet, depositorWallet, fetchEscrow, opts) {
|
|
84
|
+
const [agentPda] = deriveAgent(agentWallet);
|
|
85
|
+
const [escrowPda] = deriveEscrow(agentPda, depositorWallet);
|
|
86
|
+
const errors = [];
|
|
87
|
+
// 1. Fetch escrow
|
|
88
|
+
const escrow = await fetchEscrow(escrowPda);
|
|
89
|
+
if (!escrow) {
|
|
90
|
+
return {
|
|
91
|
+
valid: false,
|
|
92
|
+
escrow: null,
|
|
93
|
+
escrowPda,
|
|
94
|
+
agentPda,
|
|
95
|
+
isSplEscrow: false,
|
|
96
|
+
splAccounts: [],
|
|
97
|
+
errors: [`Escrow not found at ${escrowPda.toBase58()}`],
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
// 2. Check expiry
|
|
101
|
+
if (escrow.expiresAt.gt(new BN(0))) {
|
|
102
|
+
const now = Math.floor(Date.now() / 1000);
|
|
103
|
+
if (escrow.expiresAt.lt(new BN(now))) {
|
|
104
|
+
errors.push(`Escrow expired at ${escrow.expiresAt.toString()}`);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
// 3. Check balance / calls
|
|
108
|
+
const callsToSettle = opts?.callsToSettle ?? 1;
|
|
109
|
+
const costForCalls = escrow.pricePerCall.mul(new BN(callsToSettle));
|
|
110
|
+
if (escrow.balance.lt(costForCalls)) {
|
|
111
|
+
errors.push(`Insufficient balance: ${escrow.balance.toString()} < ${costForCalls.toString()} (${callsToSettle} calls × ${escrow.pricePerCall.toString()})`);
|
|
112
|
+
}
|
|
113
|
+
// 4. Check max calls
|
|
114
|
+
if (escrow.maxCalls.gt(new BN(0))) {
|
|
115
|
+
const remaining = escrow.maxCalls.sub(escrow.totalCallsSettled);
|
|
116
|
+
if (remaining.lt(new BN(callsToSettle))) {
|
|
117
|
+
errors.push(`Max calls exceeded: ${remaining.toString()} remaining but needs ${callsToSettle}`);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
// 5. Determine if SPL
|
|
121
|
+
const isSplEscrow = escrow.tokenMint !== null &&
|
|
122
|
+
escrow.tokenMint.toBase58() !== "11111111111111111111111111111111";
|
|
123
|
+
// 6. Build SPL accounts (if SPL escrow)
|
|
124
|
+
const splAccounts = [];
|
|
125
|
+
if (isSplEscrow) {
|
|
126
|
+
const mint = escrow.tokenMint;
|
|
127
|
+
const depositorAta = findATA(depositorWallet, mint);
|
|
128
|
+
const escrowAta = findATA(escrowPda, mint);
|
|
129
|
+
// Verify depositor ATA exists
|
|
130
|
+
const depositorAtaInfo = await connection.getAccountInfo(depositorAta);
|
|
131
|
+
if (!depositorAtaInfo) {
|
|
132
|
+
errors.push(`Depositor ATA does not exist: ${depositorAta.toBase58()}`);
|
|
133
|
+
}
|
|
134
|
+
// Verify escrow ATA exists
|
|
135
|
+
const escrowAtaInfo = await connection.getAccountInfo(escrowAta);
|
|
136
|
+
if (!escrowAtaInfo) {
|
|
137
|
+
errors.push(`Escrow ATA does not exist: ${escrowAta.toBase58()}`);
|
|
138
|
+
}
|
|
139
|
+
// Verify mint matches
|
|
140
|
+
if (depositorAtaInfo) {
|
|
141
|
+
// SPL token account data: bytes 0-32 = mint
|
|
142
|
+
const ataMint = depositorAtaInfo.data.subarray(0, 32);
|
|
143
|
+
if (Buffer.from(ataMint).toString("hex") !== mint.toBuffer().toString("hex")) {
|
|
144
|
+
errors.push(`Depositor ATA mint mismatch: expected ${mint.toBase58()}`);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
splAccounts.push({ kind: "depositorAta", pubkey: depositorAta, writable: true }, { kind: "escrowAta", pubkey: escrowAta, writable: true }, { kind: "tokenMint", pubkey: mint, writable: false }, { kind: "tokenProgram", pubkey: new PublicKey(TOKEN_PROGRAM_ID_STR), writable: false });
|
|
148
|
+
}
|
|
149
|
+
return {
|
|
150
|
+
valid: errors.length === 0,
|
|
151
|
+
escrow,
|
|
152
|
+
escrowPda,
|
|
153
|
+
agentPda,
|
|
154
|
+
isSplEscrow,
|
|
155
|
+
splAccounts,
|
|
156
|
+
errors,
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* @name attachSplAccounts
|
|
161
|
+
* @description Build the typed `SplAccountMeta[]` for an SPL token escrow operation.
|
|
162
|
+
* Does NOT validate existence — use {@link validateEscrowState} for full validation.
|
|
163
|
+
*
|
|
164
|
+
* @param escrowPda - The escrow PDA address.
|
|
165
|
+
* @param depositorWallet - The depositor's wallet public key.
|
|
166
|
+
* @param tokenMint - The SPL token mint.
|
|
167
|
+
* @returns An array of typed {@link SplAccountMeta} for SPL escrow operations.
|
|
168
|
+
*
|
|
169
|
+
* @category Utils
|
|
170
|
+
* @since v0.6.4
|
|
171
|
+
*
|
|
172
|
+
* @example
|
|
173
|
+
* ```ts
|
|
174
|
+
* const splMetas = attachSplAccounts(escrowPda, depositorWallet, usdcMint);
|
|
175
|
+
*
|
|
176
|
+
* // Convert to Anchor-compatible AccountMeta[]
|
|
177
|
+
* const accountMetas = splMetas.map(m => ({
|
|
178
|
+
* pubkey: m.pubkey,
|
|
179
|
+
* isWritable: m.writable,
|
|
180
|
+
* isSigner: false,
|
|
181
|
+
* }));
|
|
182
|
+
*
|
|
183
|
+
* await client.escrow.settle(depositor, calls, hash, accountMetas);
|
|
184
|
+
* ```
|
|
185
|
+
*/
|
|
186
|
+
export function attachSplAccounts(escrowPda, depositorWallet, tokenMint) {
|
|
187
|
+
return [
|
|
188
|
+
{ kind: "depositorAta", pubkey: findATA(depositorWallet, tokenMint), writable: true },
|
|
189
|
+
{ kind: "escrowAta", pubkey: findATA(escrowPda, tokenMint), writable: true },
|
|
190
|
+
{ kind: "tokenMint", pubkey: tokenMint, writable: false },
|
|
191
|
+
{ kind: "tokenProgram", pubkey: new PublicKey(TOKEN_PROGRAM_ID_STR), writable: false },
|
|
192
|
+
];
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* @name toAccountMetas
|
|
196
|
+
* @description Convert typed {@link SplAccountMeta} to Anchor-compatible
|
|
197
|
+
* `AccountMeta[]` for use with `.remainingAccounts()`.
|
|
198
|
+
*
|
|
199
|
+
* @param splMetas - Array of typed SPL account metas.
|
|
200
|
+
* @returns `AccountMeta[]` compatible with Anchor's `remainingAccounts`.
|
|
201
|
+
*
|
|
202
|
+
* @category Utils
|
|
203
|
+
* @since v0.6.4
|
|
204
|
+
*/
|
|
205
|
+
export function toAccountMetas(splMetas) {
|
|
206
|
+
return splMetas.map((m) => ({
|
|
207
|
+
pubkey: m.pubkey,
|
|
208
|
+
isWritable: m.writable,
|
|
209
|
+
isSigner: false,
|
|
210
|
+
}));
|
|
211
|
+
}
|
|
212
|
+
//# sourceMappingURL=escrow-validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"escrow-validation.js","sourceRoot":"","sources":["../../../src/utils/escrow-validation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module utils/hash
|
|
3
|
+
* @description Cryptographic hashing utilities.
|
|
4
|
+
*
|
|
5
|
+
* @category Utils
|
|
6
|
+
* @since v0.1.0
|
|
7
|
+
*/
|
|
8
|
+
/**
|
|
9
|
+
* Compute the SHA-256 hash of a UTF-8 string or byte buffer.
|
|
10
|
+
*
|
|
11
|
+
* Returns a 32-byte `Uint8Array` suitable for PDA seeds
|
|
12
|
+
* and Anchor instruction arguments.
|
|
13
|
+
*
|
|
14
|
+
* @name sha256
|
|
15
|
+
* @description Hashes the input using Node’s `crypto.createHash("sha256")`.
|
|
16
|
+
* @param input - A UTF-8 string, `Buffer`, or `Uint8Array` to hash.
|
|
17
|
+
* @returns {Uint8Array} 32-byte SHA-256 digest.
|
|
18
|
+
* @category Utils
|
|
19
|
+
* @since v0.1.0
|
|
20
|
+
* @example
|
|
21
|
+
* ```ts
|
|
22
|
+
* import { sha256 } from "@synapse-sap/sdk/utils";
|
|
23
|
+
*
|
|
24
|
+
* const hash = sha256("jupiter:swap"); // Uint8Array (32 bytes)
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare const sha256: (input: string | Buffer | Uint8Array) => Uint8Array;
|
|
28
|
+
/**
|
|
29
|
+
* Convert a `Uint8Array` hash to a plain `number[]`.
|
|
30
|
+
*
|
|
31
|
+
* Anchor instruction argument types expect `number[]` for hash fields
|
|
32
|
+
* rather than typed arrays.
|
|
33
|
+
*
|
|
34
|
+
* @name hashToArray
|
|
35
|
+
* @description Converts a byte array (typically 32 bytes) to a plain JavaScript `number[]`.
|
|
36
|
+
* @param hash - The byte array to convert.
|
|
37
|
+
* @returns {number[]} Shallow copy as a plain array of numbers.
|
|
38
|
+
* @category Utils
|
|
39
|
+
* @since v0.1.0
|
|
40
|
+
* @example
|
|
41
|
+
* ```ts
|
|
42
|
+
* import { sha256, hashToArray } from "@synapse-sap/sdk/utils";
|
|
43
|
+
*
|
|
44
|
+
* const arr = hashToArray(sha256("jupiter:swap")); // number[]
|
|
45
|
+
* ```
|
|
46
|
+
*/
|
|
47
|
+
export declare const hashToArray: (hash: Uint8Array) => number[];
|
|
48
|
+
/**
|
|
49
|
+
* Compute the deterministic batch root used by `settle_batch` (v0.10.0).
|
|
50
|
+
*
|
|
51
|
+
* The on-chain program enforces:
|
|
52
|
+
* `batch_root == sha256(s_0 || s_1 || ... || s_{N-1})`
|
|
53
|
+
* where each `s_i` is a 32-byte service hash, in the same order as the
|
|
54
|
+
* `settlements: Settlement[]` array passed to the instruction.
|
|
55
|
+
*
|
|
56
|
+
* Use this helper to derive the seed for the {@link deriveSettlementReceipt}
|
|
57
|
+
* PDA when batching settlements.
|
|
58
|
+
*
|
|
59
|
+
* @name computeBatchRoot
|
|
60
|
+
* @param serviceHashes - Array of 32-byte service hashes (Buffer/Uint8Array/number[]).
|
|
61
|
+
* @returns {Uint8Array} 32-byte batch root.
|
|
62
|
+
* @throws If any `serviceHashes[i]` is not exactly 32 bytes long.
|
|
63
|
+
* @category Utils
|
|
64
|
+
* @since v0.10.0
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* ```ts
|
|
68
|
+
* import { computeBatchRoot, hashToArray } from "@synapse-sap/sdk/utils";
|
|
69
|
+
*
|
|
70
|
+
* const root = computeBatchRoot([h1, h2, h3]);
|
|
71
|
+
* await client.escrow.settleBatch(depositor, settlements, root);
|
|
72
|
+
* ```
|
|
73
|
+
*/
|
|
74
|
+
export declare const computeBatchRoot: (serviceHashes: ReadonlyArray<Uint8Array | Buffer | number[]>) => Uint8Array;
|
|
75
|
+
//# sourceMappingURL=hash.d.ts.map
|