@algorandfoundation/algokit-utils 9.2.0-beta.7 → 10.0.0-alpha.2
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/README.md +60 -1
- package/_virtual/rolldown_runtime.js +34 -0
- package/_virtual/rolldown_runtime.mjs +13 -0
- package/abi/index.d.ts +6 -0
- package/abi/index.js +40 -0
- package/abi/index.mjs +5 -0
- package/algod-client/index.d.ts +76 -0
- package/algod-client/index.js +17 -0
- package/algod-client/index.mjs +8 -0
- package/amount.d.ts +40 -35
- package/amount.js +36 -36
- package/amount.js.map +1 -1
- package/amount.mjs +36 -34
- package/amount.mjs.map +1 -1
- package/config.d.ts +7 -2
- package/config.js +5 -5
- package/config.js.map +1 -1
- package/config.mjs +4 -2
- package/config.mjs.map +1 -1
- package/index.d.ts +10 -18
- package/index.js +41 -143
- package/index.mjs +11 -29
- package/indexer-client/index.d.ts +78 -0
- package/indexer-client/index.js +17 -0
- package/indexer-client/index.mjs +8 -0
- package/indexer-lookup.d.ts +20 -27
- package/indexer-lookup.js +98 -128
- package/indexer-lookup.js.map +1 -1
- package/indexer-lookup.mjs +93 -123
- package/indexer-lookup.mjs.map +1 -1
- package/kmd-client/index.d.ts +54 -0
- package/kmd-client/index.js +17 -0
- package/kmd-client/index.mjs +8 -0
- package/package.json +43 -5
- package/packages/abi/src/abi-method.d.ts +117 -0
- package/packages/abi/src/abi-method.js +209 -0
- package/packages/abi/src/abi-method.js.map +1 -0
- package/packages/abi/src/abi-method.mjs +196 -0
- package/packages/abi/src/abi-method.mjs.map +1 -0
- package/packages/abi/src/abi-type.d.ts +253 -0
- package/packages/abi/src/abi-type.js +685 -0
- package/packages/abi/src/abi-type.js.map +1 -0
- package/packages/abi/src/abi-type.mjs +674 -0
- package/packages/abi/src/abi-type.mjs.map +1 -0
- package/packages/abi/src/abi-value.d.ts +11 -0
- package/packages/abi/src/arc28-event.d.ts +20 -0
- package/packages/abi/src/arc56-contract.d.ts +389 -0
- package/packages/abi/src/arc56-contract.js +196 -0
- package/packages/abi/src/arc56-contract.js.map +1 -0
- package/packages/abi/src/arc56-contract.mjs +185 -0
- package/packages/abi/src/arc56-contract.mjs.map +1 -0
- package/packages/abi/src/bigint.js +32 -0
- package/packages/abi/src/bigint.js.map +1 -0
- package/packages/abi/src/bigint.mjs +30 -0
- package/packages/abi/src/bigint.mjs.map +1 -0
- package/packages/algo25/src/english.js +2057 -0
- package/packages/algo25/src/english.js.map +1 -0
- package/packages/algo25/src/english.mjs +2056 -0
- package/packages/algo25/src/english.mjs.map +1 -0
- package/packages/algo25/src/index.js +75 -0
- package/packages/algo25/src/index.js.map +1 -0
- package/packages/algo25/src/index.mjs +75 -0
- package/packages/algo25/src/index.mjs.map +1 -0
- package/packages/algod_client/src/apis/api-service.d.ts +184 -0
- package/packages/algod_client/src/apis/api-service.js +627 -0
- package/packages/algod_client/src/apis/api-service.js.map +1 -0
- package/packages/algod_client/src/apis/api-service.mjs +627 -0
- package/packages/algod_client/src/apis/api-service.mjs.map +1 -0
- package/packages/algod_client/src/client.d.ts +10 -0
- package/packages/algod_client/src/client.js +13 -0
- package/packages/algod_client/src/client.js.map +1 -0
- package/packages/algod_client/src/client.mjs +13 -0
- package/packages/algod_client/src/client.mjs.map +1 -0
- package/packages/algod_client/src/core/api-error.d.ts +10 -0
- package/packages/algod_client/src/core/api-error.js +17 -0
- package/packages/algod_client/src/core/api-error.js.map +1 -0
- package/packages/algod_client/src/core/api-error.mjs +16 -0
- package/packages/algod_client/src/core/api-error.mjs.map +1 -0
- package/packages/algod_client/src/core/base-http-request.d.ts +25 -0
- package/packages/algod_client/src/core/base-http-request.js +16 -0
- package/packages/algod_client/src/core/base-http-request.js.map +1 -0
- package/packages/algod_client/src/core/base-http-request.mjs +14 -0
- package/packages/algod_client/src/core/base-http-request.mjs.map +1 -0
- package/packages/algod_client/src/core/client-config.d.ts +17 -0
- package/packages/algod_client/src/core/fetch-http-request.d.ts +10 -0
- package/packages/algod_client/src/core/fetch-http-request.js +85 -0
- package/packages/algod_client/src/core/fetch-http-request.js.map +1 -0
- package/packages/algod_client/src/core/fetch-http-request.mjs +85 -0
- package/packages/algod_client/src/core/fetch-http-request.mjs.map +1 -0
- package/packages/algod_client/src/core/model-runtime.d.ts +10 -0
- package/packages/algod_client/src/core/model-runtime.js +25 -0
- package/packages/algod_client/src/core/model-runtime.js.map +1 -0
- package/packages/algod_client/src/core/model-runtime.mjs +22 -0
- package/packages/algod_client/src/core/model-runtime.mjs.map +1 -0
- package/packages/algod_client/src/core/request.js +62 -0
- package/packages/algod_client/src/core/request.js.map +1 -0
- package/packages/algod_client/src/core/request.mjs +62 -0
- package/packages/algod_client/src/core/request.mjs.map +1 -0
- package/packages/algod_client/src/models/account-application-response.d.ts +15 -0
- package/packages/algod_client/src/models/account-application-response.js +34 -0
- package/packages/algod_client/src/models/account-application-response.js.map +1 -0
- package/packages/algod_client/src/models/account-application-response.mjs +34 -0
- package/packages/algod_client/src/models/account-application-response.mjs.map +1 -0
- package/packages/algod_client/src/models/account-asset-response.d.ts +15 -0
- package/packages/algod_client/src/models/account-asset-response.js +34 -0
- package/packages/algod_client/src/models/account-asset-response.js.map +1 -0
- package/packages/algod_client/src/models/account-asset-response.mjs +34 -0
- package/packages/algod_client/src/models/account-asset-response.mjs.map +1 -0
- package/packages/algod_client/src/models/account-participation.d.ts +33 -0
- package/packages/algod_client/src/models/account-participation.js +50 -0
- package/packages/algod_client/src/models/account-participation.js.map +1 -0
- package/packages/algod_client/src/models/account-participation.mjs +50 -0
- package/packages/algod_client/src/models/account-participation.mjs.map +1 -0
- package/packages/algod_client/src/models/account-state-delta.d.ts +15 -0
- package/packages/algod_client/src/models/account-state-delta.js +24 -0
- package/packages/algod_client/src/models/account-state-delta.js.map +1 -0
- package/packages/algod_client/src/models/account-state-delta.mjs +24 -0
- package/packages/algod_client/src/models/account-state-delta.mjs.map +1 -0
- package/packages/algod_client/src/models/account.d.ts +139 -0
- package/packages/algod_client/src/models/account.js +187 -0
- package/packages/algod_client/src/models/account.js.map +1 -0
- package/packages/algod_client/src/models/account.mjs +187 -0
- package/packages/algod_client/src/models/account.mjs.map +1 -0
- package/packages/algod_client/src/models/application-initial-states.d.ts +22 -0
- package/packages/algod_client/src/models/application-initial-states.js +40 -0
- package/packages/algod_client/src/models/application-initial-states.js.map +1 -0
- package/packages/algod_client/src/models/application-initial-states.mjs +40 -0
- package/packages/algod_client/src/models/application-initial-states.mjs.map +1 -0
- package/packages/algod_client/src/models/application-kv-storage.d.ts +21 -0
- package/packages/algod_client/src/models/application-kv-storage.js +25 -0
- package/packages/algod_client/src/models/application-kv-storage.js.map +1 -0
- package/packages/algod_client/src/models/application-kv-storage.mjs +25 -0
- package/packages/algod_client/src/models/application-kv-storage.mjs.map +1 -0
- package/packages/algod_client/src/models/application-local-reference.d.ts +20 -0
- package/packages/algod_client/src/models/application-local-reference.js +23 -0
- package/packages/algod_client/src/models/application-local-reference.js.map +1 -0
- package/packages/algod_client/src/models/application-local-reference.mjs +23 -0
- package/packages/algod_client/src/models/application-local-reference.mjs.map +1 -0
- package/packages/algod_client/src/models/application-local-state.d.ts +19 -0
- package/packages/algod_client/src/models/application-local-state.js +35 -0
- package/packages/algod_client/src/models/application-local-state.js.map +1 -0
- package/packages/algod_client/src/models/application-local-state.mjs +35 -0
- package/packages/algod_client/src/models/application-local-state.mjs.map +1 -0
- package/packages/algod_client/src/models/application-params.d.ts +37 -0
- package/packages/algod_client/src/models/application-params.js +67 -0
- package/packages/algod_client/src/models/application-params.js.map +1 -0
- package/packages/algod_client/src/models/application-params.mjs +67 -0
- package/packages/algod_client/src/models/application-params.mjs.map +1 -0
- package/packages/algod_client/src/models/application-state-operation.d.ts +30 -0
- package/packages/algod_client/src/models/application-state-operation.js +47 -0
- package/packages/algod_client/src/models/application-state-operation.js.map +1 -0
- package/packages/algod_client/src/models/application-state-operation.mjs +47 -0
- package/packages/algod_client/src/models/application-state-operation.mjs.map +1 -0
- package/packages/algod_client/src/models/application-state-schema.d.ts +17 -0
- package/packages/algod_client/src/models/application-state-schema.js +22 -0
- package/packages/algod_client/src/models/application-state-schema.js.map +1 -0
- package/packages/algod_client/src/models/application-state-schema.mjs +22 -0
- package/packages/algod_client/src/models/application-state-schema.mjs.map +1 -0
- package/packages/algod_client/src/models/application.d.ts +17 -0
- package/packages/algod_client/src/models/application.js +24 -0
- package/packages/algod_client/src/models/application.js.map +1 -0
- package/packages/algod_client/src/models/application.mjs +24 -0
- package/packages/algod_client/src/models/application.mjs.map +1 -0
- package/packages/algod_client/src/models/asset-holding-reference.d.ts +20 -0
- package/packages/algod_client/src/models/asset-holding-reference.js +23 -0
- package/packages/algod_client/src/models/asset-holding-reference.js.map +1 -0
- package/packages/algod_client/src/models/asset-holding-reference.mjs +23 -0
- package/packages/algod_client/src/models/asset-holding-reference.mjs.map +1 -0
- package/packages/algod_client/src/models/asset-holding.d.ts +24 -0
- package/packages/algod_client/src/models/asset-holding.js +32 -0
- package/packages/algod_client/src/models/asset-holding.js.map +1 -0
- package/packages/algod_client/src/models/asset-holding.mjs +32 -0
- package/packages/algod_client/src/models/asset-holding.mjs.map +1 -0
- package/packages/algod_client/src/models/asset-params.d.ts +74 -0
- package/packages/algod_client/src/models/asset-params.js +107 -0
- package/packages/algod_client/src/models/asset-params.js.map +1 -0
- package/packages/algod_client/src/models/asset-params.mjs +107 -0
- package/packages/algod_client/src/models/asset-params.mjs.map +1 -0
- package/packages/algod_client/src/models/asset.d.ts +17 -0
- package/packages/algod_client/src/models/asset.js +24 -0
- package/packages/algod_client/src/models/asset.js.map +1 -0
- package/packages/algod_client/src/models/asset.mjs +24 -0
- package/packages/algod_client/src/models/asset.mjs.map +1 -0
- package/packages/algod_client/src/models/avm-key-value.d.ts +14 -0
- package/packages/algod_client/src/models/avm-key-value.js +24 -0
- package/packages/algod_client/src/models/avm-key-value.js.map +1 -0
- package/packages/algod_client/src/models/avm-key-value.mjs +24 -0
- package/packages/algod_client/src/models/avm-key-value.mjs.map +1 -0
- package/packages/algod_client/src/models/avm-value.d.ts +21 -0
- package/packages/algod_client/src/models/avm-value.js +33 -0
- package/packages/algod_client/src/models/avm-value.js.map +1 -0
- package/packages/algod_client/src/models/avm-value.mjs +33 -0
- package/packages/algod_client/src/models/avm-value.mjs.map +1 -0
- package/packages/algod_client/src/models/block-hash-response.d.ts +10 -0
- package/packages/algod_client/src/models/block-hash-response.js +17 -0
- package/packages/algod_client/src/models/block-hash-response.js.map +1 -0
- package/packages/algod_client/src/models/block-hash-response.mjs +17 -0
- package/packages/algod_client/src/models/block-hash-response.mjs.map +1 -0
- package/packages/algod_client/src/models/block-response.d.ts +12 -0
- package/packages/algod_client/src/models/block-response.js +25 -0
- package/packages/algod_client/src/models/block-response.js.map +1 -0
- package/packages/algod_client/src/models/block-response.mjs +25 -0
- package/packages/algod_client/src/models/block-response.mjs.map +1 -0
- package/packages/algod_client/src/models/block-txids-response.d.ts +10 -0
- package/packages/algod_client/src/models/block-txids-response.js +17 -0
- package/packages/algod_client/src/models/block-txids-response.js.map +1 -0
- package/packages/algod_client/src/models/block-txids-response.mjs +17 -0
- package/packages/algod_client/src/models/block-txids-response.mjs.map +1 -0
- package/packages/algod_client/src/models/block.d.ts +146 -0
- package/packages/algod_client/src/models/block.js +415 -0
- package/packages/algod_client/src/models/block.js.map +1 -0
- package/packages/algod_client/src/models/block.mjs +415 -0
- package/packages/algod_client/src/models/block.mjs.map +1 -0
- package/packages/algod_client/src/models/box-descriptor.d.ts +13 -0
- package/packages/algod_client/src/models/box-descriptor.js +17 -0
- package/packages/algod_client/src/models/box-descriptor.js.map +1 -0
- package/packages/algod_client/src/models/box-descriptor.mjs +17 -0
- package/packages/algod_client/src/models/box-descriptor.mjs.map +1 -0
- package/packages/algod_client/src/models/box-reference.d.ts +17 -0
- package/packages/algod_client/src/models/box-reference.js +23 -0
- package/packages/algod_client/src/models/box-reference.js.map +1 -0
- package/packages/algod_client/src/models/box-reference.mjs +23 -0
- package/packages/algod_client/src/models/box-reference.mjs.map +1 -0
- package/packages/algod_client/src/models/box.d.ts +21 -0
- package/packages/algod_client/src/models/box.js +32 -0
- package/packages/algod_client/src/models/box.js.map +1 -0
- package/packages/algod_client/src/models/box.mjs +32 -0
- package/packages/algod_client/src/models/box.mjs.map +1 -0
- package/packages/algod_client/src/models/boxes-response.d.ts +9 -0
- package/packages/algod_client/src/models/boxes-response.js +19 -0
- package/packages/algod_client/src/models/boxes-response.js.map +1 -0
- package/packages/algod_client/src/models/boxes-response.mjs +19 -0
- package/packages/algod_client/src/models/boxes-response.mjs.map +1 -0
- package/packages/algod_client/src/models/build-version.d.ts +12 -0
- package/packages/algod_client/src/models/build-version.js +50 -0
- package/packages/algod_client/src/models/build-version.js.map +1 -0
- package/packages/algod_client/src/models/build-version.mjs +50 -0
- package/packages/algod_client/src/models/build-version.mjs.map +1 -0
- package/packages/algod_client/src/models/compile-response.d.ts +17 -0
- package/packages/algod_client/src/models/compile-response.js +33 -0
- package/packages/algod_client/src/models/compile-response.js.map +1 -0
- package/packages/algod_client/src/models/compile-response.mjs +33 -0
- package/packages/algod_client/src/models/compile-response.mjs.map +1 -0
- package/packages/algod_client/src/models/disassemble-response.d.ts +10 -0
- package/packages/algod_client/src/models/disassemble-response.js +17 -0
- package/packages/algod_client/src/models/disassemble-response.js.map +1 -0
- package/packages/algod_client/src/models/disassemble-response.mjs +17 -0
- package/packages/algod_client/src/models/disassemble-response.mjs.map +1 -0
- package/packages/algod_client/src/models/eval-delta-key-value.d.ts +14 -0
- package/packages/algod_client/src/models/eval-delta-key-value.js +24 -0
- package/packages/algod_client/src/models/eval-delta-key-value.js.map +1 -0
- package/packages/algod_client/src/models/eval-delta-key-value.mjs +24 -0
- package/packages/algod_client/src/models/eval-delta-key-value.mjs.map +1 -0
- package/packages/algod_client/src/models/eval-delta.d.ts +21 -0
- package/packages/algod_client/src/models/eval-delta.js +33 -0
- package/packages/algod_client/src/models/eval-delta.js.map +1 -0
- package/packages/algod_client/src/models/eval-delta.mjs +33 -0
- package/packages/algod_client/src/models/eval-delta.mjs.map +1 -0
- package/packages/algod_client/src/models/genesis-allocation.d.ts +18 -0
- package/packages/algod_client/src/models/genesis-allocation.js +88 -0
- package/packages/algod_client/src/models/genesis-allocation.js.map +1 -0
- package/packages/algod_client/src/models/genesis-allocation.mjs +88 -0
- package/packages/algod_client/src/models/genesis-allocation.mjs.map +1 -0
- package/packages/algod_client/src/models/genesis.d.ts +17 -0
- package/packages/algod_client/src/models/genesis.js +72 -0
- package/packages/algod_client/src/models/genesis.js.map +1 -0
- package/packages/algod_client/src/models/genesis.mjs +72 -0
- package/packages/algod_client/src/models/genesis.mjs.map +1 -0
- package/packages/algod_client/src/models/get-block-time-stamp-offset-response.d.ts +10 -0
- package/packages/algod_client/src/models/get-block-time-stamp-offset-response.js +17 -0
- package/packages/algod_client/src/models/get-block-time-stamp-offset-response.js.map +1 -0
- package/packages/algod_client/src/models/get-block-time-stamp-offset-response.mjs +17 -0
- package/packages/algod_client/src/models/get-block-time-stamp-offset-response.mjs.map +1 -0
- package/packages/algod_client/src/models/get-sync-round-response.d.ts +10 -0
- package/packages/algod_client/src/models/get-sync-round-response.js +17 -0
- package/packages/algod_client/src/models/get-sync-round-response.js.map +1 -0
- package/packages/algod_client/src/models/get-sync-round-response.mjs +17 -0
- package/packages/algod_client/src/models/get-sync-round-response.mjs.map +1 -0
- package/packages/algod_client/src/models/ledger-state-delta-for-transaction-group.d.ts +14 -0
- package/packages/algod_client/src/models/ledger-state-delta-for-transaction-group.js +24 -0
- package/packages/algod_client/src/models/ledger-state-delta-for-transaction-group.js.map +1 -0
- package/packages/algod_client/src/models/ledger-state-delta-for-transaction-group.mjs +24 -0
- package/packages/algod_client/src/models/ledger-state-delta-for-transaction-group.mjs.map +1 -0
- package/packages/algod_client/src/models/ledger-state-delta.d.ts +351 -0
- package/packages/algod_client/src/models/ledger-state-delta.js +688 -0
- package/packages/algod_client/src/models/ledger-state-delta.js.map +1 -0
- package/packages/algod_client/src/models/ledger-state-delta.mjs +688 -0
- package/packages/algod_client/src/models/ledger-state-delta.mjs.map +1 -0
- package/packages/algod_client/src/models/light-block-header-proof.d.ts +21 -0
- package/packages/algod_client/src/models/light-block-header-proof.js +32 -0
- package/packages/algod_client/src/models/light-block-header-proof.js.map +1 -0
- package/packages/algod_client/src/models/light-block-header-proof.mjs +32 -0
- package/packages/algod_client/src/models/light-block-header-proof.mjs.map +1 -0
- package/packages/algod_client/src/models/node-status-response.d.ts +113 -0
- package/packages/algod_client/src/models/node-status-response.js +172 -0
- package/packages/algod_client/src/models/node-status-response.js.map +1 -0
- package/packages/algod_client/src/models/node-status-response.mjs +172 -0
- package/packages/algod_client/src/models/node-status-response.mjs.map +1 -0
- package/packages/algod_client/src/models/pending-transaction-response.d.ts +67 -0
- package/packages/algod_client/src/models/pending-transaction-response.js +104 -0
- package/packages/algod_client/src/models/pending-transaction-response.js.map +1 -0
- package/packages/algod_client/src/models/pending-transaction-response.mjs +104 -0
- package/packages/algod_client/src/models/pending-transaction-response.mjs.map +1 -0
- package/packages/algod_client/src/models/pending-transactions-response.d.ts +20 -0
- package/packages/algod_client/src/models/pending-transactions-response.js +25 -0
- package/packages/algod_client/src/models/pending-transactions-response.js.map +1 -0
- package/packages/algod_client/src/models/pending-transactions-response.mjs +25 -0
- package/packages/algod_client/src/models/pending-transactions-response.mjs.map +1 -0
- package/packages/algod_client/src/models/post-transactions-response.d.ts +10 -0
- package/packages/algod_client/src/models/post-transactions-response.js +17 -0
- package/packages/algod_client/src/models/post-transactions-response.js.map +1 -0
- package/packages/algod_client/src/models/post-transactions-response.mjs +17 -0
- package/packages/algod_client/src/models/post-transactions-response.mjs.map +1 -0
- package/packages/algod_client/src/models/scratch-change.d.ts +17 -0
- package/packages/algod_client/src/models/scratch-change.js +24 -0
- package/packages/algod_client/src/models/scratch-change.js.map +1 -0
- package/packages/algod_client/src/models/scratch-change.mjs +24 -0
- package/packages/algod_client/src/models/scratch-change.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-initial-states.d.ts +16 -0
- package/packages/algod_client/src/models/simulate-initial-states.js +19 -0
- package/packages/algod_client/src/models/simulate-initial-states.js.map +1 -0
- package/packages/algod_client/src/models/simulate-initial-states.mjs +19 -0
- package/packages/algod_client/src/models/simulate-initial-states.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-request-transaction-group.d.ts +16 -0
- package/packages/algod_client/src/models/simulate-request-transaction-group.js +19 -0
- package/packages/algod_client/src/models/simulate-request-transaction-group.js.map +1 -0
- package/packages/algod_client/src/models/simulate-request-transaction-group.mjs +19 -0
- package/packages/algod_client/src/models/simulate-request-transaction-group.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-request.d.ts +42 -0
- package/packages/algod_client/src/models/simulate-request.js +67 -0
- package/packages/algod_client/src/models/simulate-request.js.map +1 -0
- package/packages/algod_client/src/models/simulate-request.mjs +67 -0
- package/packages/algod_client/src/models/simulate-request.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-response.d.ts +26 -0
- package/packages/algod_client/src/models/simulate-response.js +56 -0
- package/packages/algod_client/src/models/simulate-response.js.map +1 -0
- package/packages/algod_client/src/models/simulate-response.mjs +56 -0
- package/packages/algod_client/src/models/simulate-response.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-trace-config.d.ts +25 -0
- package/packages/algod_client/src/models/simulate-trace-config.js +37 -0
- package/packages/algod_client/src/models/simulate-trace-config.js.map +1 -0
- package/packages/algod_client/src/models/simulate-trace-config.mjs +37 -0
- package/packages/algod_client/src/models/simulate-trace-config.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-transaction-group-result.d.ts +34 -0
- package/packages/algod_client/src/models/simulate-transaction-group-result.js +54 -0
- package/packages/algod_client/src/models/simulate-transaction-group-result.js.map +1 -0
- package/packages/algod_client/src/models/simulate-transaction-group-result.mjs +54 -0
- package/packages/algod_client/src/models/simulate-transaction-group-result.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-transaction-result.d.ts +30 -0
- package/packages/algod_client/src/models/simulate-transaction-result.js +54 -0
- package/packages/algod_client/src/models/simulate-transaction-result.js.map +1 -0
- package/packages/algod_client/src/models/simulate-transaction-result.mjs +54 -0
- package/packages/algod_client/src/models/simulate-transaction-result.mjs.map +1 -0
- package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.d.ts +43 -0
- package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.js +60 -0
- package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.js.map +1 -0
- package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.mjs +60 -0
- package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.mjs.map +1 -0
- package/packages/algod_client/src/models/simulation-eval-overrides.d.ts +33 -0
- package/packages/algod_client/src/models/simulation-eval-overrides.js +50 -0
- package/packages/algod_client/src/models/simulation-eval-overrides.js.map +1 -0
- package/packages/algod_client/src/models/simulation-eval-overrides.mjs +50 -0
- package/packages/algod_client/src/models/simulation-eval-overrides.mjs.map +1 -0
- package/packages/algod_client/src/models/simulation-opcode-trace-unit.d.ts +38 -0
- package/packages/algod_client/src/models/simulation-opcode-trace-unit.js +54 -0
- package/packages/algod_client/src/models/simulation-opcode-trace-unit.js.map +1 -0
- package/packages/algod_client/src/models/simulation-opcode-trace-unit.mjs +54 -0
- package/packages/algod_client/src/models/simulation-opcode-trace-unit.mjs.map +1 -0
- package/packages/algod_client/src/models/simulation-transaction-exec-trace.d.ts +48 -0
- package/packages/algod_client/src/models/simulation-transaction-exec-trace.js +72 -0
- package/packages/algod_client/src/models/simulation-transaction-exec-trace.js.map +1 -0
- package/packages/algod_client/src/models/simulation-transaction-exec-trace.mjs +72 -0
- package/packages/algod_client/src/models/simulation-transaction-exec-trace.mjs.map +1 -0
- package/packages/algod_client/src/models/source-map.d.ts +22 -0
- package/packages/algod_client/src/models/source-map.js +39 -0
- package/packages/algod_client/src/models/source-map.js.map +1 -0
- package/packages/algod_client/src/models/source-map.mjs +39 -0
- package/packages/algod_client/src/models/source-map.mjs.map +1 -0
- package/packages/algod_client/src/models/state-delta.d.ts +11 -0
- package/packages/algod_client/src/models/state-delta.js +14 -0
- package/packages/algod_client/src/models/state-delta.js.map +1 -0
- package/packages/algod_client/src/models/state-delta.mjs +14 -0
- package/packages/algod_client/src/models/state-delta.mjs.map +1 -0
- package/packages/algod_client/src/models/state-proof-message.d.ts +29 -0
- package/packages/algod_client/src/models/state-proof-message.js +44 -0
- package/packages/algod_client/src/models/state-proof-message.js.map +1 -0
- package/packages/algod_client/src/models/state-proof-message.mjs +44 -0
- package/packages/algod_client/src/models/state-proof-message.mjs.map +1 -0
- package/packages/algod_client/src/models/state-proof.d.ts +17 -0
- package/packages/algod_client/src/models/state-proof.js +24 -0
- package/packages/algod_client/src/models/state-proof.js.map +1 -0
- package/packages/algod_client/src/models/state-proof.mjs +24 -0
- package/packages/algod_client/src/models/state-proof.mjs.map +1 -0
- package/packages/algod_client/src/models/suggested-params.d.ts +14 -0
- package/packages/algod_client/src/models/supply-response.d.ts +21 -0
- package/packages/algod_client/src/models/supply-response.js +31 -0
- package/packages/algod_client/src/models/supply-response.js.map +1 -0
- package/packages/algod_client/src/models/supply-response.mjs +31 -0
- package/packages/algod_client/src/models/supply-response.mjs.map +1 -0
- package/packages/algod_client/src/models/teal-key-value-store.d.ts +11 -0
- package/packages/algod_client/src/models/teal-key-value-store.js +14 -0
- package/packages/algod_client/src/models/teal-key-value-store.js.map +1 -0
- package/packages/algod_client/src/models/teal-key-value-store.mjs +14 -0
- package/packages/algod_client/src/models/teal-key-value-store.mjs.map +1 -0
- package/packages/algod_client/src/models/teal-key-value.d.ts +14 -0
- package/packages/algod_client/src/models/teal-key-value.js +24 -0
- package/packages/algod_client/src/models/teal-key-value.js.map +1 -0
- package/packages/algod_client/src/models/teal-key-value.mjs +24 -0
- package/packages/algod_client/src/models/teal-key-value.mjs.map +1 -0
- package/packages/algod_client/src/models/teal-value.d.ts +21 -0
- package/packages/algod_client/src/models/teal-value.js +33 -0
- package/packages/algod_client/src/models/teal-value.js.map +1 -0
- package/packages/algod_client/src/models/teal-value.mjs +33 -0
- package/packages/algod_client/src/models/teal-value.mjs.map +1 -0
- package/packages/algod_client/src/models/transaction-group-ledger-state-deltas-for-round-response.d.ts +9 -0
- package/packages/algod_client/src/models/transaction-group-ledger-state-deltas-for-round-response.js +19 -0
- package/packages/algod_client/src/models/transaction-group-ledger-state-deltas-for-round-response.js.map +1 -0
- package/packages/algod_client/src/models/transaction-group-ledger-state-deltas-for-round-response.mjs +19 -0
- package/packages/algod_client/src/models/transaction-group-ledger-state-deltas-for-round-response.mjs.map +1 -0
- package/packages/algod_client/src/models/transaction-parameters-response.d.ts +39 -0
- package/packages/algod_client/src/models/transaction-parameters-response.js +51 -0
- package/packages/algod_client/src/models/transaction-parameters-response.js.map +1 -0
- package/packages/algod_client/src/models/transaction-parameters-response.mjs +51 -0
- package/packages/algod_client/src/models/transaction-parameters-response.mjs.map +1 -0
- package/packages/algod_client/src/models/transaction-proof.d.ts +31 -0
- package/packages/algod_client/src/models/transaction-proof.js +45 -0
- package/packages/algod_client/src/models/transaction-proof.js.map +1 -0
- package/packages/algod_client/src/models/transaction-proof.mjs +45 -0
- package/packages/algod_client/src/models/transaction-proof.mjs.map +1 -0
- package/packages/algod_client/src/models/version.d.ts +16 -0
- package/packages/algod_client/src/models/version.js +41 -0
- package/packages/algod_client/src/models/version.js.map +1 -0
- package/packages/algod_client/src/models/version.mjs +41 -0
- package/packages/algod_client/src/models/version.mjs.map +1 -0
- package/packages/common/src/address.d.ts +71 -0
- package/packages/common/src/address.js +156 -0
- package/packages/common/src/address.js.map +1 -0
- package/packages/common/src/address.mjs +144 -0
- package/packages/common/src/address.mjs.map +1 -0
- package/packages/common/src/array.js +21 -0
- package/packages/common/src/array.js.map +1 -0
- package/packages/common/src/array.mjs +19 -0
- package/packages/common/src/array.mjs.map +1 -0
- package/packages/common/src/codecs/codec.d.ts +71 -0
- package/packages/common/src/codecs/codec.js +87 -0
- package/packages/common/src/codecs/codec.js.map +1 -0
- package/packages/common/src/codecs/codec.mjs +86 -0
- package/packages/common/src/codecs/codec.mjs.map +1 -0
- package/packages/common/src/codecs/composite/array.js +45 -0
- package/packages/common/src/codecs/composite/array.js.map +1 -0
- package/packages/common/src/codecs/composite/array.mjs +40 -0
- package/packages/common/src/codecs/composite/array.mjs.map +1 -0
- package/packages/common/src/codecs/composite/map.js +65 -0
- package/packages/common/src/codecs/composite/map.js.map +1 -0
- package/packages/common/src/codecs/composite/map.mjs +65 -0
- package/packages/common/src/codecs/composite/map.mjs.map +1 -0
- package/packages/common/src/codecs/composite/record.js +41 -0
- package/packages/common/src/codecs/composite/record.js.map +1 -0
- package/packages/common/src/codecs/composite/record.mjs +39 -0
- package/packages/common/src/codecs/composite/record.mjs.map +1 -0
- package/packages/common/src/codecs/models/array-model.js +36 -0
- package/packages/common/src/codecs/models/array-model.js.map +1 -0
- package/packages/common/src/codecs/models/array-model.mjs +36 -0
- package/packages/common/src/codecs/models/array-model.mjs.map +1 -0
- package/packages/common/src/codecs/models/object-model.d.ts +22 -0
- package/packages/common/src/codecs/models/object-model.js +87 -0
- package/packages/common/src/codecs/models/object-model.js.map +1 -0
- package/packages/common/src/codecs/models/object-model.mjs +87 -0
- package/packages/common/src/codecs/models/object-model.mjs.map +1 -0
- package/packages/common/src/codecs/models/primitive-model.js +36 -0
- package/packages/common/src/codecs/models/primitive-model.js.map +1 -0
- package/packages/common/src/codecs/models/primitive-model.mjs +36 -0
- package/packages/common/src/codecs/models/primitive-model.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/address.js +33 -0
- package/packages/common/src/codecs/primitives/address.js.map +1 -0
- package/packages/common/src/codecs/primitives/address.mjs +31 -0
- package/packages/common/src/codecs/primitives/address.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/bigint.js +18 -0
- package/packages/common/src/codecs/primitives/bigint.js.map +1 -0
- package/packages/common/src/codecs/primitives/bigint.mjs +18 -0
- package/packages/common/src/codecs/primitives/bigint.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/boolean.js +13 -0
- package/packages/common/src/codecs/primitives/boolean.js.map +1 -0
- package/packages/common/src/codecs/primitives/boolean.mjs +13 -0
- package/packages/common/src/codecs/primitives/boolean.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/bytes.js +28 -0
- package/packages/common/src/codecs/primitives/bytes.js.map +1 -0
- package/packages/common/src/codecs/primitives/bytes.mjs +26 -0
- package/packages/common/src/codecs/primitives/bytes.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/fixed-bytes.js +37 -0
- package/packages/common/src/codecs/primitives/fixed-bytes.js.map +1 -0
- package/packages/common/src/codecs/primitives/fixed-bytes.mjs +33 -0
- package/packages/common/src/codecs/primitives/fixed-bytes.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/number.js +16 -0
- package/packages/common/src/codecs/primitives/number.js.map +1 -0
- package/packages/common/src/codecs/primitives/number.mjs +16 -0
- package/packages/common/src/codecs/primitives/number.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/string.js +17 -0
- package/packages/common/src/codecs/primitives/string.js.map +1 -0
- package/packages/common/src/codecs/primitives/string.mjs +17 -0
- package/packages/common/src/codecs/primitives/string.mjs.map +1 -0
- package/packages/common/src/codecs/primitives/unknown.js +58 -0
- package/packages/common/src/codecs/primitives/unknown.js.map +1 -0
- package/packages/common/src/codecs/primitives/unknown.mjs +58 -0
- package/packages/common/src/codecs/primitives/unknown.mjs.map +1 -0
- package/packages/common/src/codecs/types.d.ts +27 -0
- package/packages/common/src/codecs/wire.d.ts +15 -0
- package/packages/common/src/codecs/wire.js +24 -0
- package/packages/common/src/codecs/wire.js.map +1 -0
- package/packages/common/src/codecs/wire.mjs +21 -0
- package/packages/common/src/codecs/wire.mjs.map +1 -0
- package/packages/common/src/constants.js +63 -0
- package/packages/common/src/constants.js.map +1 -0
- package/packages/common/src/constants.mjs +34 -0
- package/packages/common/src/constants.mjs.map +1 -0
- package/packages/common/src/crypto.js +13 -0
- package/packages/common/src/crypto.js.map +1 -0
- package/packages/common/src/crypto.mjs +11 -0
- package/packages/common/src/crypto.mjs.map +1 -0
- package/packages/common/src/expand.d.ts +9 -0
- package/packages/common/src/json.js +38 -0
- package/packages/common/src/json.js.map +1 -0
- package/packages/common/src/json.mjs +35 -0
- package/packages/common/src/json.mjs.map +1 -0
- package/packages/common/src/logger.d.ts +12 -0
- package/packages/common/src/msgpack.js +26 -0
- package/packages/common/src/msgpack.js.map +1 -0
- package/packages/common/src/msgpack.mjs +23 -0
- package/packages/common/src/msgpack.mjs.map +1 -0
- package/packages/indexer_client/src/apis/api-service.d.ts +251 -0
- package/packages/indexer_client/src/apis/api-service.js +482 -0
- package/packages/indexer_client/src/apis/api-service.js.map +1 -0
- package/packages/indexer_client/src/apis/api-service.mjs +482 -0
- package/packages/indexer_client/src/apis/api-service.mjs.map +1 -0
- package/packages/indexer_client/src/client.d.ts +10 -0
- package/packages/indexer_client/src/client.js +13 -0
- package/packages/indexer_client/src/client.js.map +1 -0
- package/packages/indexer_client/src/client.mjs +13 -0
- package/packages/indexer_client/src/client.mjs.map +1 -0
- package/packages/indexer_client/src/core/api-error.d.ts +10 -0
- package/packages/indexer_client/src/core/api-error.js +17 -0
- package/packages/indexer_client/src/core/api-error.js.map +1 -0
- package/packages/indexer_client/src/core/api-error.mjs +16 -0
- package/packages/indexer_client/src/core/api-error.mjs.map +1 -0
- package/packages/indexer_client/src/core/base-http-request.d.ts +25 -0
- package/packages/indexer_client/src/core/base-http-request.js +16 -0
- package/packages/indexer_client/src/core/base-http-request.js.map +1 -0
- package/packages/indexer_client/src/core/base-http-request.mjs +14 -0
- package/packages/indexer_client/src/core/base-http-request.mjs.map +1 -0
- package/packages/indexer_client/src/core/client-config.d.ts +17 -0
- package/packages/indexer_client/src/core/fetch-http-request.d.ts +10 -0
- package/packages/indexer_client/src/core/fetch-http-request.js +85 -0
- package/packages/indexer_client/src/core/fetch-http-request.js.map +1 -0
- package/packages/indexer_client/src/core/fetch-http-request.mjs +85 -0
- package/packages/indexer_client/src/core/fetch-http-request.mjs.map +1 -0
- package/packages/indexer_client/src/core/model-runtime.d.ts +10 -0
- package/packages/indexer_client/src/core/model-runtime.js +25 -0
- package/packages/indexer_client/src/core/model-runtime.js.map +1 -0
- package/packages/indexer_client/src/core/model-runtime.mjs +22 -0
- package/packages/indexer_client/src/core/model-runtime.mjs.map +1 -0
- package/packages/indexer_client/src/core/request.js +62 -0
- package/packages/indexer_client/src/core/request.js.map +1 -0
- package/packages/indexer_client/src/core/request.mjs +62 -0
- package/packages/indexer_client/src/core/request.mjs.map +1 -0
- package/packages/indexer_client/src/models/account-participation.d.ts +33 -0
- package/packages/indexer_client/src/models/account-participation.js +50 -0
- package/packages/indexer_client/src/models/account-participation.js.map +1 -0
- package/packages/indexer_client/src/models/account-participation.mjs +50 -0
- package/packages/indexer_client/src/models/account-participation.mjs.map +1 -0
- package/packages/indexer_client/src/models/account-response.d.ts +13 -0
- package/packages/indexer_client/src/models/account-response.js +24 -0
- package/packages/indexer_client/src/models/account-response.js.map +1 -0
- package/packages/indexer_client/src/models/account-response.mjs +24 -0
- package/packages/indexer_client/src/models/account-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/account-state-delta.d.ts +14 -0
- package/packages/indexer_client/src/models/account-state-delta.js +24 -0
- package/packages/indexer_client/src/models/account-state-delta.js.map +1 -0
- package/packages/indexer_client/src/models/account-state-delta.mjs +24 -0
- package/packages/indexer_client/src/models/account-state-delta.mjs.map +1 -0
- package/packages/indexer_client/src/models/account.d.ts +152 -0
- package/packages/indexer_client/src/models/account.js +205 -0
- package/packages/indexer_client/src/models/account.js.map +1 -0
- package/packages/indexer_client/src/models/account.mjs +205 -0
- package/packages/indexer_client/src/models/account.mjs.map +1 -0
- package/packages/indexer_client/src/models/accounts-response.d.ts +17 -0
- package/packages/indexer_client/src/models/accounts-response.js +35 -0
- package/packages/indexer_client/src/models/accounts-response.js.map +1 -0
- package/packages/indexer_client/src/models/accounts-response.mjs +35 -0
- package/packages/indexer_client/src/models/accounts-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/application-local-state.d.ts +31 -0
- package/packages/indexer_client/src/models/application-local-state.js +54 -0
- package/packages/indexer_client/src/models/application-local-state.js.map +1 -0
- package/packages/indexer_client/src/models/application-local-state.mjs +54 -0
- package/packages/indexer_client/src/models/application-local-state.mjs.map +1 -0
- package/packages/indexer_client/src/models/application-local-states-response.d.ts +17 -0
- package/packages/indexer_client/src/models/application-local-states-response.js +35 -0
- package/packages/indexer_client/src/models/application-local-states-response.js.map +1 -0
- package/packages/indexer_client/src/models/application-local-states-response.mjs +35 -0
- package/packages/indexer_client/src/models/application-local-states-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/application-log-data.d.ts +17 -0
- package/packages/indexer_client/src/models/application-log-data.js +23 -0
- package/packages/indexer_client/src/models/application-log-data.js.map +1 -0
- package/packages/indexer_client/src/models/application-log-data.mjs +23 -0
- package/packages/indexer_client/src/models/application-log-data.mjs.map +1 -0
- package/packages/indexer_client/src/models/application-logs-response.d.ts +21 -0
- package/packages/indexer_client/src/models/application-logs-response.js +41 -0
- package/packages/indexer_client/src/models/application-logs-response.js.map +1 -0
- package/packages/indexer_client/src/models/application-logs-response.mjs +41 -0
- package/packages/indexer_client/src/models/application-logs-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/application-params.d.ts +37 -0
- package/packages/indexer_client/src/models/application-params.js +67 -0
- package/packages/indexer_client/src/models/application-params.js.map +1 -0
- package/packages/indexer_client/src/models/application-params.mjs +67 -0
- package/packages/indexer_client/src/models/application-params.mjs.map +1 -0
- package/packages/indexer_client/src/models/application-response.d.ts +13 -0
- package/packages/indexer_client/src/models/application-response.js +24 -0
- package/packages/indexer_client/src/models/application-response.js.map +1 -0
- package/packages/indexer_client/src/models/application-response.mjs +24 -0
- package/packages/indexer_client/src/models/application-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/application-state-schema.d.ts +17 -0
- package/packages/indexer_client/src/models/application-state-schema.js +22 -0
- package/packages/indexer_client/src/models/application-state-schema.js.map +1 -0
- package/packages/indexer_client/src/models/application-state-schema.mjs +22 -0
- package/packages/indexer_client/src/models/application-state-schema.mjs.map +1 -0
- package/packages/indexer_client/src/models/application.d.ts +29 -0
- package/packages/indexer_client/src/models/application.js +46 -0
- package/packages/indexer_client/src/models/application.js.map +1 -0
- package/packages/indexer_client/src/models/application.mjs +46 -0
- package/packages/indexer_client/src/models/application.mjs.map +1 -0
- package/packages/indexer_client/src/models/applications-response.d.ts +17 -0
- package/packages/indexer_client/src/models/applications-response.js +35 -0
- package/packages/indexer_client/src/models/applications-response.js.map +1 -0
- package/packages/indexer_client/src/models/applications-response.mjs +35 -0
- package/packages/indexer_client/src/models/applications-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/asset-balances-response.d.ts +17 -0
- package/packages/indexer_client/src/models/asset-balances-response.js +35 -0
- package/packages/indexer_client/src/models/asset-balances-response.js.map +1 -0
- package/packages/indexer_client/src/models/asset-balances-response.mjs +35 -0
- package/packages/indexer_client/src/models/asset-balances-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/asset-holding.d.ts +36 -0
- package/packages/indexer_client/src/models/asset-holding.js +50 -0
- package/packages/indexer_client/src/models/asset-holding.js.map +1 -0
- package/packages/indexer_client/src/models/asset-holding.mjs +50 -0
- package/packages/indexer_client/src/models/asset-holding.mjs.map +1 -0
- package/packages/indexer_client/src/models/asset-holdings-response.d.ts +17 -0
- package/packages/indexer_client/src/models/asset-holdings-response.js +35 -0
- package/packages/indexer_client/src/models/asset-holdings-response.js.map +1 -0
- package/packages/indexer_client/src/models/asset-holdings-response.mjs +35 -0
- package/packages/indexer_client/src/models/asset-holdings-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/asset-params.d.ts +74 -0
- package/packages/indexer_client/src/models/asset-params.js +107 -0
- package/packages/indexer_client/src/models/asset-params.js.map +1 -0
- package/packages/indexer_client/src/models/asset-params.mjs +107 -0
- package/packages/indexer_client/src/models/asset-params.mjs.map +1 -0
- package/packages/indexer_client/src/models/asset-response.d.ts +13 -0
- package/packages/indexer_client/src/models/asset-response.js +24 -0
- package/packages/indexer_client/src/models/asset-response.js.map +1 -0
- package/packages/indexer_client/src/models/asset-response.mjs +24 -0
- package/packages/indexer_client/src/models/asset-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/asset.d.ts +29 -0
- package/packages/indexer_client/src/models/asset.js +46 -0
- package/packages/indexer_client/src/models/asset.js.map +1 -0
- package/packages/indexer_client/src/models/asset.mjs +46 -0
- package/packages/indexer_client/src/models/asset.mjs.map +1 -0
- package/packages/indexer_client/src/models/assets-response.d.ts +17 -0
- package/packages/indexer_client/src/models/assets-response.js +35 -0
- package/packages/indexer_client/src/models/assets-response.js.map +1 -0
- package/packages/indexer_client/src/models/assets-response.mjs +35 -0
- package/packages/indexer_client/src/models/assets-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/block-headers-response.d.ts +17 -0
- package/packages/indexer_client/src/models/block-headers-response.js +35 -0
- package/packages/indexer_client/src/models/block-headers-response.js.map +1 -0
- package/packages/indexer_client/src/models/block-headers-response.mjs +35 -0
- package/packages/indexer_client/src/models/block-headers-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/block-rewards.d.ts +33 -0
- package/packages/indexer_client/src/models/block-rewards.js +50 -0
- package/packages/indexer_client/src/models/block-rewards.js.map +1 -0
- package/packages/indexer_client/src/models/block-rewards.mjs +50 -0
- package/packages/indexer_client/src/models/block-rewards.mjs.map +1 -0
- package/packages/indexer_client/src/models/block-upgrade-state.d.ts +29 -0
- package/packages/indexer_client/src/models/block-upgrade-state.js +45 -0
- package/packages/indexer_client/src/models/block-upgrade-state.js.map +1 -0
- package/packages/indexer_client/src/models/block-upgrade-state.mjs +45 -0
- package/packages/indexer_client/src/models/block-upgrade-state.mjs.map +1 -0
- package/packages/indexer_client/src/models/block-upgrade-vote.d.ts +21 -0
- package/packages/indexer_client/src/models/block-upgrade-vote.js +33 -0
- package/packages/indexer_client/src/models/block-upgrade-vote.js.map +1 -0
- package/packages/indexer_client/src/models/block-upgrade-vote.mjs +33 -0
- package/packages/indexer_client/src/models/block-upgrade-vote.mjs.map +1 -0
- package/packages/indexer_client/src/models/block.d.ts +95 -0
- package/packages/indexer_client/src/models/block.js +151 -0
- package/packages/indexer_client/src/models/block.js.map +1 -0
- package/packages/indexer_client/src/models/block.mjs +151 -0
- package/packages/indexer_client/src/models/block.mjs.map +1 -0
- package/packages/indexer_client/src/models/box-descriptor.d.ts +13 -0
- package/packages/indexer_client/src/models/box-descriptor.js +17 -0
- package/packages/indexer_client/src/models/box-descriptor.js.map +1 -0
- package/packages/indexer_client/src/models/box-descriptor.mjs +17 -0
- package/packages/indexer_client/src/models/box-descriptor.mjs.map +1 -0
- package/packages/indexer_client/src/models/box-reference.d.ts +17 -0
- package/packages/indexer_client/src/models/box-reference.js +23 -0
- package/packages/indexer_client/src/models/box-reference.js.map +1 -0
- package/packages/indexer_client/src/models/box-reference.mjs +23 -0
- package/packages/indexer_client/src/models/box-reference.mjs.map +1 -0
- package/packages/indexer_client/src/models/box.d.ts +21 -0
- package/packages/indexer_client/src/models/box.js +32 -0
- package/packages/indexer_client/src/models/box.js.map +1 -0
- package/packages/indexer_client/src/models/box.mjs +32 -0
- package/packages/indexer_client/src/models/box.mjs.map +1 -0
- package/packages/indexer_client/src/models/boxes-response.d.ts +17 -0
- package/packages/indexer_client/src/models/boxes-response.js +35 -0
- package/packages/indexer_client/src/models/boxes-response.js.map +1 -0
- package/packages/indexer_client/src/models/boxes-response.mjs +35 -0
- package/packages/indexer_client/src/models/boxes-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/eval-delta-key-value.d.ts +14 -0
- package/packages/indexer_client/src/models/eval-delta-key-value.js +24 -0
- package/packages/indexer_client/src/models/eval-delta-key-value.js.map +1 -0
- package/packages/indexer_client/src/models/eval-delta-key-value.mjs +24 -0
- package/packages/indexer_client/src/models/eval-delta-key-value.mjs.map +1 -0
- package/packages/indexer_client/src/models/eval-delta.d.ts +21 -0
- package/packages/indexer_client/src/models/eval-delta.js +33 -0
- package/packages/indexer_client/src/models/eval-delta.js.map +1 -0
- package/packages/indexer_client/src/models/eval-delta.mjs +33 -0
- package/packages/indexer_client/src/models/eval-delta.mjs.map +1 -0
- package/packages/indexer_client/src/models/hash-factory.d.ts +10 -0
- package/packages/indexer_client/src/models/hash-factory.js +17 -0
- package/packages/indexer_client/src/models/hash-factory.js.map +1 -0
- package/packages/indexer_client/src/models/hash-factory.mjs +17 -0
- package/packages/indexer_client/src/models/hash-factory.mjs.map +1 -0
- package/packages/indexer_client/src/models/hb-proof-fields.d.ts +29 -0
- package/packages/indexer_client/src/models/hb-proof-fields.js +43 -0
- package/packages/indexer_client/src/models/hb-proof-fields.js.map +1 -0
- package/packages/indexer_client/src/models/hb-proof-fields.mjs +43 -0
- package/packages/indexer_client/src/models/hb-proof-fields.mjs.map +1 -0
- package/packages/indexer_client/src/models/health-check.d.ts +19 -0
- package/packages/indexer_client/src/models/health-check.js +60 -0
- package/packages/indexer_client/src/models/health-check.js.map +1 -0
- package/packages/indexer_client/src/models/health-check.mjs +60 -0
- package/packages/indexer_client/src/models/health-check.mjs.map +1 -0
- package/packages/indexer_client/src/models/holding-ref.d.ts +20 -0
- package/packages/indexer_client/src/models/holding-ref.js +23 -0
- package/packages/indexer_client/src/models/holding-ref.js.map +1 -0
- package/packages/indexer_client/src/models/holding-ref.mjs +23 -0
- package/packages/indexer_client/src/models/holding-ref.mjs.map +1 -0
- package/packages/indexer_client/src/models/indexer-state-proof-message.d.ts +26 -0
- package/packages/indexer_client/src/models/indexer-state-proof-message.js +44 -0
- package/packages/indexer_client/src/models/indexer-state-proof-message.js.map +1 -0
- package/packages/indexer_client/src/models/indexer-state-proof-message.mjs +44 -0
- package/packages/indexer_client/src/models/indexer-state-proof-message.mjs.map +1 -0
- package/packages/indexer_client/src/models/locals-ref.d.ts +20 -0
- package/packages/indexer_client/src/models/locals-ref.js +23 -0
- package/packages/indexer_client/src/models/locals-ref.js.map +1 -0
- package/packages/indexer_client/src/models/locals-ref.mjs +23 -0
- package/packages/indexer_client/src/models/locals-ref.mjs.map +1 -0
- package/packages/indexer_client/src/models/merkle-array-proof.d.ts +17 -0
- package/packages/indexer_client/src/models/merkle-array-proof.js +34 -0
- package/packages/indexer_client/src/models/merkle-array-proof.js.map +1 -0
- package/packages/indexer_client/src/models/merkle-array-proof.mjs +34 -0
- package/packages/indexer_client/src/models/merkle-array-proof.mjs.map +1 -0
- package/packages/indexer_client/src/models/mini-asset-holding.d.ts +24 -0
- package/packages/indexer_client/src/models/mini-asset-holding.js +51 -0
- package/packages/indexer_client/src/models/mini-asset-holding.js.map +1 -0
- package/packages/indexer_client/src/models/mini-asset-holding.mjs +51 -0
- package/packages/indexer_client/src/models/mini-asset-holding.mjs.map +1 -0
- package/packages/indexer_client/src/models/on-completion.d.ts +16 -0
- package/packages/indexer_client/src/models/on-completion.js +12 -0
- package/packages/indexer_client/src/models/on-completion.js.map +1 -0
- package/packages/indexer_client/src/models/on-completion.mjs +12 -0
- package/packages/indexer_client/src/models/on-completion.mjs.map +1 -0
- package/packages/indexer_client/src/models/participation-updates.d.ts +17 -0
- package/packages/indexer_client/src/models/participation-updates.js +22 -0
- package/packages/indexer_client/src/models/participation-updates.js.map +1 -0
- package/packages/indexer_client/src/models/participation-updates.mjs +22 -0
- package/packages/indexer_client/src/models/participation-updates.mjs.map +1 -0
- package/packages/indexer_client/src/models/resource-ref.d.ts +32 -0
- package/packages/indexer_client/src/models/resource-ref.js +54 -0
- package/packages/indexer_client/src/models/resource-ref.js.map +1 -0
- package/packages/indexer_client/src/models/resource-ref.mjs +54 -0
- package/packages/indexer_client/src/models/resource-ref.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-delta.d.ts +11 -0
- package/packages/indexer_client/src/models/state-delta.js +14 -0
- package/packages/indexer_client/src/models/state-delta.js.map +1 -0
- package/packages/indexer_client/src/models/state-delta.mjs +14 -0
- package/packages/indexer_client/src/models/state-delta.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-proof-fields.d.ts +38 -0
- package/packages/indexer_client/src/models/state-proof-fields.js +61 -0
- package/packages/indexer_client/src/models/state-proof-fields.js.map +1 -0
- package/packages/indexer_client/src/models/state-proof-fields.mjs +61 -0
- package/packages/indexer_client/src/models/state-proof-fields.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-proof-participant.d.ts +13 -0
- package/packages/indexer_client/src/models/state-proof-participant.js +24 -0
- package/packages/indexer_client/src/models/state-proof-participant.js.map +1 -0
- package/packages/indexer_client/src/models/state-proof-participant.mjs +24 -0
- package/packages/indexer_client/src/models/state-proof-participant.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-proof-reveal.d.ts +15 -0
- package/packages/indexer_client/src/models/state-proof-reveal.js +34 -0
- package/packages/indexer_client/src/models/state-proof-reveal.js.map +1 -0
- package/packages/indexer_client/src/models/state-proof-reveal.mjs +34 -0
- package/packages/indexer_client/src/models/state-proof-reveal.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-proof-sig-slot.d.ts +13 -0
- package/packages/indexer_client/src/models/state-proof-sig-slot.js +24 -0
- package/packages/indexer_client/src/models/state-proof-sig-slot.js.map +1 -0
- package/packages/indexer_client/src/models/state-proof-sig-slot.mjs +24 -0
- package/packages/indexer_client/src/models/state-proof-sig-slot.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-proof-signature.d.ts +15 -0
- package/packages/indexer_client/src/models/state-proof-signature.js +40 -0
- package/packages/indexer_client/src/models/state-proof-signature.js.map +1 -0
- package/packages/indexer_client/src/models/state-proof-signature.mjs +40 -0
- package/packages/indexer_client/src/models/state-proof-signature.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-proof-tracking.d.ts +22 -0
- package/packages/indexer_client/src/models/state-proof-tracking.js +39 -0
- package/packages/indexer_client/src/models/state-proof-tracking.js.map +1 -0
- package/packages/indexer_client/src/models/state-proof-tracking.mjs +39 -0
- package/packages/indexer_client/src/models/state-proof-tracking.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-proof-verifier.d.ts +14 -0
- package/packages/indexer_client/src/models/state-proof-verifier.js +23 -0
- package/packages/indexer_client/src/models/state-proof-verifier.js.map +1 -0
- package/packages/indexer_client/src/models/state-proof-verifier.mjs +23 -0
- package/packages/indexer_client/src/models/state-proof-verifier.mjs.map +1 -0
- package/packages/indexer_client/src/models/state-schema.d.ts +17 -0
- package/packages/indexer_client/src/models/state-schema.js +22 -0
- package/packages/indexer_client/src/models/state-schema.js.map +1 -0
- package/packages/indexer_client/src/models/state-schema.mjs +22 -0
- package/packages/indexer_client/src/models/state-schema.mjs.map +1 -0
- package/packages/indexer_client/src/models/teal-key-value-store.d.ts +11 -0
- package/packages/indexer_client/src/models/teal-key-value-store.js +14 -0
- package/packages/indexer_client/src/models/teal-key-value-store.js.map +1 -0
- package/packages/indexer_client/src/models/teal-key-value-store.mjs +14 -0
- package/packages/indexer_client/src/models/teal-key-value-store.mjs.map +1 -0
- package/packages/indexer_client/src/models/teal-key-value.d.ts +14 -0
- package/packages/indexer_client/src/models/teal-key-value.js +24 -0
- package/packages/indexer_client/src/models/teal-key-value.js.map +1 -0
- package/packages/indexer_client/src/models/teal-key-value.mjs +24 -0
- package/packages/indexer_client/src/models/teal-key-value.mjs.map +1 -0
- package/packages/indexer_client/src/models/teal-value.d.ts +21 -0
- package/packages/indexer_client/src/models/teal-value.js +33 -0
- package/packages/indexer_client/src/models/teal-value.js.map +1 -0
- package/packages/indexer_client/src/models/teal-value.mjs +33 -0
- package/packages/indexer_client/src/models/teal-value.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-application.d.ts +66 -0
- package/packages/indexer_client/src/models/transaction-application.js +106 -0
- package/packages/indexer_client/src/models/transaction-application.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-application.mjs +106 -0
- package/packages/indexer_client/src/models/transaction-application.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-asset-config.d.ts +24 -0
- package/packages/indexer_client/src/models/transaction-asset-config.js +24 -0
- package/packages/indexer_client/src/models/transaction-asset-config.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-asset-config.mjs +24 -0
- package/packages/indexer_client/src/models/transaction-asset-config.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-asset-freeze.d.ts +24 -0
- package/packages/indexer_client/src/models/transaction-asset-freeze.js +33 -0
- package/packages/indexer_client/src/models/transaction-asset-freeze.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-asset-freeze.mjs +33 -0
- package/packages/indexer_client/src/models/transaction-asset-freeze.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-asset-transfer.d.ts +36 -0
- package/packages/indexer_client/src/models/transaction-asset-transfer.js +50 -0
- package/packages/indexer_client/src/models/transaction-asset-transfer.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-asset-transfer.mjs +50 -0
- package/packages/indexer_client/src/models/transaction-asset-transfer.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-heartbeat.d.ts +32 -0
- package/packages/indexer_client/src/models/transaction-heartbeat.js +47 -0
- package/packages/indexer_client/src/models/transaction-heartbeat.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-heartbeat.mjs +47 -0
- package/packages/indexer_client/src/models/transaction-heartbeat.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-keyreg.d.ts +40 -0
- package/packages/indexer_client/src/models/transaction-keyreg.js +57 -0
- package/packages/indexer_client/src/models/transaction-keyreg.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-keyreg.mjs +57 -0
- package/packages/indexer_client/src/models/transaction-keyreg.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-payment.d.ts +28 -0
- package/packages/indexer_client/src/models/transaction-payment.js +38 -0
- package/packages/indexer_client/src/models/transaction-payment.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-payment.mjs +38 -0
- package/packages/indexer_client/src/models/transaction-payment.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-response.d.ts +13 -0
- package/packages/indexer_client/src/models/transaction-response.js +24 -0
- package/packages/indexer_client/src/models/transaction-response.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-response.mjs +24 -0
- package/packages/indexer_client/src/models/transaction-response.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature-logicsig.d.ts +29 -0
- package/packages/indexer_client/src/models/transaction-signature-logicsig.js +46 -0
- package/packages/indexer_client/src/models/transaction-signature-logicsig.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature-logicsig.mjs +46 -0
- package/packages/indexer_client/src/models/transaction-signature-logicsig.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.d.ts +14 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.js +22 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.mjs +22 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig.d.ts +27 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig.js +34 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig.mjs +34 -0
- package/packages/indexer_client/src/models/transaction-signature-multisig.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature.d.ts +19 -0
- package/packages/indexer_client/src/models/transaction-signature.js +34 -0
- package/packages/indexer_client/src/models/transaction-signature.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-signature.mjs +34 -0
- package/packages/indexer_client/src/models/transaction-signature.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction-state-proof.d.ts +22 -0
- package/packages/indexer_client/src/models/transaction-state-proof.js +34 -0
- package/packages/indexer_client/src/models/transaction-state-proof.js.map +1 -0
- package/packages/indexer_client/src/models/transaction-state-proof.mjs +34 -0
- package/packages/indexer_client/src/models/transaction-state-proof.mjs.map +1 -0
- package/packages/indexer_client/src/models/transaction.d.ts +147 -0
- package/packages/indexer_client/src/models/transaction.js +241 -0
- package/packages/indexer_client/src/models/transaction.js.map +1 -0
- package/packages/indexer_client/src/models/transaction.mjs +241 -0
- package/packages/indexer_client/src/models/transaction.mjs.map +1 -0
- package/packages/indexer_client/src/models/transactions-response.d.ts +17 -0
- package/packages/indexer_client/src/models/transactions-response.js +35 -0
- package/packages/indexer_client/src/models/transactions-response.js.map +1 -0
- package/packages/indexer_client/src/models/transactions-response.mjs +35 -0
- package/packages/indexer_client/src/models/transactions-response.mjs.map +1 -0
- package/packages/kmd_client/src/apis/api-service.d.ts +152 -0
- package/packages/kmd_client/src/apis/api-service.js +517 -0
- package/packages/kmd_client/src/apis/api-service.js.map +1 -0
- package/packages/kmd_client/src/apis/api-service.mjs +517 -0
- package/packages/kmd_client/src/apis/api-service.mjs.map +1 -0
- package/packages/kmd_client/src/client.d.ts +10 -0
- package/packages/kmd_client/src/client.js +13 -0
- package/packages/kmd_client/src/client.js.map +1 -0
- package/packages/kmd_client/src/client.mjs +13 -0
- package/packages/kmd_client/src/client.mjs.map +1 -0
- package/packages/kmd_client/src/core/api-error.d.ts +10 -0
- package/packages/kmd_client/src/core/api-error.js +17 -0
- package/packages/kmd_client/src/core/api-error.js.map +1 -0
- package/packages/kmd_client/src/core/api-error.mjs +16 -0
- package/packages/kmd_client/src/core/api-error.mjs.map +1 -0
- package/packages/kmd_client/src/core/base-http-request.d.ts +25 -0
- package/packages/kmd_client/src/core/base-http-request.js +16 -0
- package/packages/kmd_client/src/core/base-http-request.js.map +1 -0
- package/packages/kmd_client/src/core/base-http-request.mjs +14 -0
- package/packages/kmd_client/src/core/base-http-request.mjs.map +1 -0
- package/packages/kmd_client/src/core/client-config.d.ts +17 -0
- package/packages/kmd_client/src/core/fetch-http-request.d.ts +10 -0
- package/packages/kmd_client/src/core/fetch-http-request.js +85 -0
- package/packages/kmd_client/src/core/fetch-http-request.js.map +1 -0
- package/packages/kmd_client/src/core/fetch-http-request.mjs +85 -0
- package/packages/kmd_client/src/core/fetch-http-request.mjs.map +1 -0
- package/packages/kmd_client/src/core/model-runtime.d.ts +10 -0
- package/packages/kmd_client/src/core/model-runtime.js +25 -0
- package/packages/kmd_client/src/core/model-runtime.js.map +1 -0
- package/packages/kmd_client/src/core/model-runtime.mjs +22 -0
- package/packages/kmd_client/src/core/model-runtime.mjs.map +1 -0
- package/packages/kmd_client/src/core/request.js +62 -0
- package/packages/kmd_client/src/core/request.js.map +1 -0
- package/packages/kmd_client/src/core/request.mjs +62 -0
- package/packages/kmd_client/src/core/request.mjs.map +1 -0
- package/packages/kmd_client/src/models/create-wallet-request.d.ts +13 -0
- package/packages/kmd_client/src/models/create-wallet-request.js +38 -0
- package/packages/kmd_client/src/models/create-wallet-request.js.map +1 -0
- package/packages/kmd_client/src/models/create-wallet-request.mjs +38 -0
- package/packages/kmd_client/src/models/create-wallet-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/create-wallet-response.d.ts +13 -0
- package/packages/kmd_client/src/models/create-wallet-response.js +18 -0
- package/packages/kmd_client/src/models/create-wallet-response.js.map +1 -0
- package/packages/kmd_client/src/models/create-wallet-response.mjs +18 -0
- package/packages/kmd_client/src/models/create-wallet-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/delete-key-request.d.ts +15 -0
- package/packages/kmd_client/src/models/delete-key-request.js +32 -0
- package/packages/kmd_client/src/models/delete-key-request.js.map +1 -0
- package/packages/kmd_client/src/models/delete-key-request.mjs +32 -0
- package/packages/kmd_client/src/models/delete-key-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/delete-multisig-request.d.ts +15 -0
- package/packages/kmd_client/src/models/delete-multisig-request.js +32 -0
- package/packages/kmd_client/src/models/delete-multisig-request.js.map +1 -0
- package/packages/kmd_client/src/models/delete-multisig-request.mjs +32 -0
- package/packages/kmd_client/src/models/delete-multisig-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/export-key-request.d.ts +15 -0
- package/packages/kmd_client/src/models/export-key-request.js +32 -0
- package/packages/kmd_client/src/models/export-key-request.js.map +1 -0
- package/packages/kmd_client/src/models/export-key-request.mjs +32 -0
- package/packages/kmd_client/src/models/export-key-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/export-key-response.d.ts +10 -0
- package/packages/kmd_client/src/models/export-key-response.js +17 -0
- package/packages/kmd_client/src/models/export-key-response.js.map +1 -0
- package/packages/kmd_client/src/models/export-key-response.mjs +17 -0
- package/packages/kmd_client/src/models/export-key-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/export-master-key-request.d.ts +11 -0
- package/packages/kmd_client/src/models/export-master-key-request.js +22 -0
- package/packages/kmd_client/src/models/export-master-key-request.js.map +1 -0
- package/packages/kmd_client/src/models/export-master-key-request.mjs +22 -0
- package/packages/kmd_client/src/models/export-master-key-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/export-master-key-response.d.ts +10 -0
- package/packages/kmd_client/src/models/export-master-key-response.js +17 -0
- package/packages/kmd_client/src/models/export-master-key-response.js.map +1 -0
- package/packages/kmd_client/src/models/export-master-key-response.mjs +17 -0
- package/packages/kmd_client/src/models/export-master-key-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/export-multisig-request.d.ts +14 -0
- package/packages/kmd_client/src/models/export-multisig-request.js +23 -0
- package/packages/kmd_client/src/models/export-multisig-request.js.map +1 -0
- package/packages/kmd_client/src/models/export-multisig-request.mjs +23 -0
- package/packages/kmd_client/src/models/export-multisig-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/export-multisig-response.d.ts +12 -0
- package/packages/kmd_client/src/models/export-multisig-response.js +32 -0
- package/packages/kmd_client/src/models/export-multisig-response.js.map +1 -0
- package/packages/kmd_client/src/models/export-multisig-response.mjs +32 -0
- package/packages/kmd_client/src/models/export-multisig-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/generate-key-request.d.ts +10 -0
- package/packages/kmd_client/src/models/generate-key-request.js +17 -0
- package/packages/kmd_client/src/models/generate-key-request.js.map +1 -0
- package/packages/kmd_client/src/models/generate-key-request.mjs +17 -0
- package/packages/kmd_client/src/models/generate-key-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/generate-key-response.d.ts +13 -0
- package/packages/kmd_client/src/models/generate-key-response.js +17 -0
- package/packages/kmd_client/src/models/generate-key-response.js.map +1 -0
- package/packages/kmd_client/src/models/generate-key-response.mjs +17 -0
- package/packages/kmd_client/src/models/generate-key-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/import-key-request.d.ts +11 -0
- package/packages/kmd_client/src/models/import-key-request.js +23 -0
- package/packages/kmd_client/src/models/import-key-request.js.map +1 -0
- package/packages/kmd_client/src/models/import-key-request.mjs +23 -0
- package/packages/kmd_client/src/models/import-key-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/import-key-response.d.ts +13 -0
- package/packages/kmd_client/src/models/import-key-response.js +17 -0
- package/packages/kmd_client/src/models/import-key-response.js.map +1 -0
- package/packages/kmd_client/src/models/import-key-response.mjs +17 -0
- package/packages/kmd_client/src/models/import-key-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/import-multisig-request.d.ts +13 -0
- package/packages/kmd_client/src/models/import-multisig-request.js +39 -0
- package/packages/kmd_client/src/models/import-multisig-request.js.map +1 -0
- package/packages/kmd_client/src/models/import-multisig-request.mjs +39 -0
- package/packages/kmd_client/src/models/import-multisig-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/import-multisig-response.d.ts +13 -0
- package/packages/kmd_client/src/models/import-multisig-response.js +17 -0
- package/packages/kmd_client/src/models/import-multisig-response.js.map +1 -0
- package/packages/kmd_client/src/models/import-multisig-response.mjs +17 -0
- package/packages/kmd_client/src/models/import-multisig-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-request.d.ts +11 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-request.js +22 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-request.js.map +1 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-request.mjs +22 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-response.d.ts +10 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-response.js +17 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-response.js.map +1 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-response.mjs +17 -0
- package/packages/kmd_client/src/models/init-wallet-handle-token-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/list-keys-request.d.ts +10 -0
- package/packages/kmd_client/src/models/list-keys-request.js +17 -0
- package/packages/kmd_client/src/models/list-keys-request.js.map +1 -0
- package/packages/kmd_client/src/models/list-keys-request.mjs +17 -0
- package/packages/kmd_client/src/models/list-keys-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/list-keys-response.d.ts +13 -0
- package/packages/kmd_client/src/models/list-keys-response.js +17 -0
- package/packages/kmd_client/src/models/list-keys-response.js.map +1 -0
- package/packages/kmd_client/src/models/list-keys-response.mjs +17 -0
- package/packages/kmd_client/src/models/list-keys-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/list-multisig-request.d.ts +10 -0
- package/packages/kmd_client/src/models/list-multisig-request.js +17 -0
- package/packages/kmd_client/src/models/list-multisig-request.js.map +1 -0
- package/packages/kmd_client/src/models/list-multisig-request.mjs +17 -0
- package/packages/kmd_client/src/models/list-multisig-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/list-multisig-response.d.ts +13 -0
- package/packages/kmd_client/src/models/list-multisig-response.js +17 -0
- package/packages/kmd_client/src/models/list-multisig-response.js.map +1 -0
- package/packages/kmd_client/src/models/list-multisig-response.mjs +17 -0
- package/packages/kmd_client/src/models/list-multisig-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/list-wallets-response.d.ts +13 -0
- package/packages/kmd_client/src/models/list-wallets-response.js +19 -0
- package/packages/kmd_client/src/models/list-wallets-response.js.map +1 -0
- package/packages/kmd_client/src/models/list-wallets-response.mjs +19 -0
- package/packages/kmd_client/src/models/list-wallets-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/multisig-sig.d.ts +15 -0
- package/packages/kmd_client/src/models/multisig-sig.js +34 -0
- package/packages/kmd_client/src/models/multisig-sig.js.map +1 -0
- package/packages/kmd_client/src/models/multisig-sig.mjs +34 -0
- package/packages/kmd_client/src/models/multisig-sig.mjs.map +1 -0
- package/packages/kmd_client/src/models/multisig-subsig.d.ts +12 -0
- package/packages/kmd_client/src/models/multisig-subsig.js +22 -0
- package/packages/kmd_client/src/models/multisig-subsig.js.map +1 -0
- package/packages/kmd_client/src/models/multisig-subsig.mjs +22 -0
- package/packages/kmd_client/src/models/multisig-subsig.mjs.map +1 -0
- package/packages/kmd_client/src/models/release-wallet-handle-token-request.d.ts +10 -0
- package/packages/kmd_client/src/models/release-wallet-handle-token-request.js +17 -0
- package/packages/kmd_client/src/models/release-wallet-handle-token-request.js.map +1 -0
- package/packages/kmd_client/src/models/release-wallet-handle-token-request.mjs +17 -0
- package/packages/kmd_client/src/models/release-wallet-handle-token-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/rename-wallet-request.d.ts +12 -0
- package/packages/kmd_client/src/models/rename-wallet-request.js +31 -0
- package/packages/kmd_client/src/models/rename-wallet-request.js.map +1 -0
- package/packages/kmd_client/src/models/rename-wallet-request.mjs +31 -0
- package/packages/kmd_client/src/models/rename-wallet-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/rename-wallet-response.d.ts +13 -0
- package/packages/kmd_client/src/models/rename-wallet-response.js +18 -0
- package/packages/kmd_client/src/models/rename-wallet-response.js.map +1 -0
- package/packages/kmd_client/src/models/rename-wallet-response.mjs +18 -0
- package/packages/kmd_client/src/models/rename-wallet-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-request.d.ts +10 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-request.js +17 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-request.js.map +1 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-request.mjs +17 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-response.d.ts +13 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-response.js +18 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-response.js.map +1 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-response.mjs +18 -0
- package/packages/kmd_client/src/models/renew-wallet-handle-token-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-multisig-request.d.ts +11 -0
- package/packages/kmd_client/src/models/sign-multisig-response.d.ts +10 -0
- package/packages/kmd_client/src/models/sign-multisig-response.js +17 -0
- package/packages/kmd_client/src/models/sign-multisig-response.js.map +1 -0
- package/packages/kmd_client/src/models/sign-multisig-response.mjs +17 -0
- package/packages/kmd_client/src/models/sign-multisig-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-multisig-txn-request.d.ts +18 -0
- package/packages/kmd_client/src/models/sign-multisig-txn-request.js +52 -0
- package/packages/kmd_client/src/models/sign-multisig-txn-request.js.map +1 -0
- package/packages/kmd_client/src/models/sign-multisig-txn-request.mjs +52 -0
- package/packages/kmd_client/src/models/sign-multisig-txn-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-program-multisig-request.d.ts +20 -0
- package/packages/kmd_client/src/models/sign-program-multisig-request.js +60 -0
- package/packages/kmd_client/src/models/sign-program-multisig-request.js.map +1 -0
- package/packages/kmd_client/src/models/sign-program-multisig-request.mjs +60 -0
- package/packages/kmd_client/src/models/sign-program-multisig-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-program-multisig-response.d.ts +10 -0
- package/packages/kmd_client/src/models/sign-program-multisig-response.js +17 -0
- package/packages/kmd_client/src/models/sign-program-multisig-response.js.map +1 -0
- package/packages/kmd_client/src/models/sign-program-multisig-response.mjs +17 -0
- package/packages/kmd_client/src/models/sign-program-multisig-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-program-request.d.ts +16 -0
- package/packages/kmd_client/src/models/sign-program-request.js +39 -0
- package/packages/kmd_client/src/models/sign-program-request.js.map +1 -0
- package/packages/kmd_client/src/models/sign-program-request.mjs +39 -0
- package/packages/kmd_client/src/models/sign-program-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-program-response.d.ts +10 -0
- package/packages/kmd_client/src/models/sign-program-response.js +17 -0
- package/packages/kmd_client/src/models/sign-program-response.js.map +1 -0
- package/packages/kmd_client/src/models/sign-program-response.mjs +17 -0
- package/packages/kmd_client/src/models/sign-program-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-transaction-request.d.ts +11 -0
- package/packages/kmd_client/src/models/sign-transaction-response.d.ts +10 -0
- package/packages/kmd_client/src/models/sign-transaction-response.js +17 -0
- package/packages/kmd_client/src/models/sign-transaction-response.js.map +1 -0
- package/packages/kmd_client/src/models/sign-transaction-response.mjs +17 -0
- package/packages/kmd_client/src/models/sign-transaction-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/sign-txn-request.d.ts +19 -0
- package/packages/kmd_client/src/models/sign-txn-request.js +38 -0
- package/packages/kmd_client/src/models/sign-txn-request.js.map +1 -0
- package/packages/kmd_client/src/models/sign-txn-request.mjs +38 -0
- package/packages/kmd_client/src/models/sign-txn-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/tx-type.d.ts +8 -0
- package/packages/kmd_client/src/models/tx-type.js +12 -0
- package/packages/kmd_client/src/models/tx-type.js.map +1 -0
- package/packages/kmd_client/src/models/tx-type.mjs +12 -0
- package/packages/kmd_client/src/models/tx-type.mjs.map +1 -0
- package/packages/kmd_client/src/models/versions-response.d.ts +11 -0
- package/packages/kmd_client/src/models/versions-response.js +17 -0
- package/packages/kmd_client/src/models/versions-response.js.map +1 -0
- package/packages/kmd_client/src/models/versions-response.mjs +17 -0
- package/packages/kmd_client/src/models/versions-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/wallet-handle.d.ts +15 -0
- package/packages/kmd_client/src/models/wallet-handle.js +24 -0
- package/packages/kmd_client/src/models/wallet-handle.js.map +1 -0
- package/packages/kmd_client/src/models/wallet-handle.mjs +24 -0
- package/packages/kmd_client/src/models/wallet-handle.mjs.map +1 -0
- package/packages/kmd_client/src/models/wallet-info-request.d.ts +10 -0
- package/packages/kmd_client/src/models/wallet-info-request.js +17 -0
- package/packages/kmd_client/src/models/wallet-info-request.js.map +1 -0
- package/packages/kmd_client/src/models/wallet-info-request.mjs +17 -0
- package/packages/kmd_client/src/models/wallet-info-request.mjs.map +1 -0
- package/packages/kmd_client/src/models/wallet-info-response.d.ts +13 -0
- package/packages/kmd_client/src/models/wallet-info-response.js +18 -0
- package/packages/kmd_client/src/models/wallet-info-response.js.map +1 -0
- package/packages/kmd_client/src/models/wallet-info-response.mjs +18 -0
- package/packages/kmd_client/src/models/wallet-info-response.mjs.map +1 -0
- package/packages/kmd_client/src/models/wallet.d.ts +18 -0
- package/packages/kmd_client/src/models/wallet.js +54 -0
- package/packages/kmd_client/src/models/wallet.js.map +1 -0
- package/packages/kmd_client/src/models/wallet.mjs +54 -0
- package/packages/kmd_client/src/models/wallet.mjs.map +1 -0
- package/packages/sdk/src/convert.d.ts +17 -0
- package/packages/sdk/src/convert.js +28 -0
- package/packages/sdk/src/convert.js.map +1 -0
- package/packages/sdk/src/convert.mjs +25 -0
- package/packages/sdk/src/convert.mjs.map +1 -0
- package/packages/sdk/src/encoding/binarydata.d.ts +34 -0
- package/packages/sdk/src/encoding/binarydata.js +65 -0
- package/packages/sdk/src/encoding/binarydata.js.map +1 -0
- package/packages/sdk/src/encoding/binarydata.mjs +60 -0
- package/packages/sdk/src/encoding/binarydata.mjs.map +1 -0
- package/packages/sdk/src/encoding/encoding.d.ts +237 -0
- package/packages/sdk/src/encoding/encoding.js +302 -0
- package/packages/sdk/src/encoding/encoding.js.map +1 -0
- package/packages/sdk/src/encoding/encoding.mjs +287 -0
- package/packages/sdk/src/encoding/encoding.mjs.map +1 -0
- package/packages/sdk/src/encoding/schema/array.js +35 -0
- package/packages/sdk/src/encoding/schema/array.js.map +1 -0
- package/packages/sdk/src/encoding/schema/array.mjs +35 -0
- package/packages/sdk/src/encoding/schema/array.mjs.map +1 -0
- package/packages/sdk/src/encoding/schema/bytearray.js +49 -0
- package/packages/sdk/src/encoding/schema/bytearray.js.map +1 -0
- package/packages/sdk/src/encoding/schema/bytearray.mjs +49 -0
- package/packages/sdk/src/encoding/schema/bytearray.mjs.map +1 -0
- package/packages/sdk/src/encoding/schema/map.d.ts +58 -0
- package/packages/sdk/src/encoding/schema/map.js +110 -0
- package/packages/sdk/src/encoding/schema/map.js.map +1 -0
- package/packages/sdk/src/encoding/schema/map.mjs +107 -0
- package/packages/sdk/src/encoding/schema/map.mjs.map +1 -0
- package/packages/sdk/src/encoding/schema/optional.js +46 -0
- package/packages/sdk/src/encoding/schema/optional.js.map +1 -0
- package/packages/sdk/src/encoding/schema/optional.mjs +46 -0
- package/packages/sdk/src/encoding/schema/optional.mjs.map +1 -0
- package/packages/sdk/src/encoding/schema/uint64.js +30 -0
- package/packages/sdk/src/encoding/schema/uint64.js.map +1 -0
- package/packages/sdk/src/encoding/schema/uint64.mjs +30 -0
- package/packages/sdk/src/encoding/schema/uint64.mjs.map +1 -0
- package/packages/sdk/src/encoding/uint64.d.ts +34 -0
- package/packages/sdk/src/encoding/uint64.js +34 -0
- package/packages/sdk/src/encoding/uint64.js.map +1 -0
- package/packages/sdk/src/encoding/uint64.mjs +33 -0
- package/packages/sdk/src/encoding/uint64.mjs.map +1 -0
- package/packages/sdk/src/index.d.ts +44 -0
- package/packages/sdk/src/index.js +62 -0
- package/packages/sdk/src/index.js.map +1 -0
- package/packages/sdk/src/index.mjs +58 -0
- package/packages/sdk/src/index.mjs.map +1 -0
- package/packages/sdk/src/logic/sourcemap.d.ts +55 -0
- package/packages/sdk/src/logic/sourcemap.js +88 -0
- package/packages/sdk/src/logic/sourcemap.js.map +1 -0
- package/packages/sdk/src/logic/sourcemap.mjs +86 -0
- package/packages/sdk/src/logic/sourcemap.mjs.map +1 -0
- package/packages/sdk/src/nacl/naclWrappers.js +14 -0
- package/packages/sdk/src/nacl/naclWrappers.js.map +1 -0
- package/packages/sdk/src/nacl/naclWrappers.mjs +11 -0
- package/packages/sdk/src/nacl/naclWrappers.mjs.map +1 -0
- package/packages/sdk/src/types/intDecoding.d.ts +28 -0
- package/packages/sdk/src/types/intDecoding.js +32 -0
- package/packages/sdk/src/types/intDecoding.js.map +1 -0
- package/packages/sdk/src/types/intDecoding.mjs +31 -0
- package/packages/sdk/src/types/intDecoding.mjs.map +1 -0
- package/packages/sdk/src/types/transactions/encoded.d.ts +40 -0
- package/packages/sdk/src/types/transactions/encoded.js +64 -0
- package/packages/sdk/src/types/transactions/encoded.js.map +1 -0
- package/packages/sdk/src/types/transactions/encoded.mjs +59 -0
- package/packages/sdk/src/types/transactions/encoded.mjs.map +1 -0
- package/packages/sdk/src/utils/utils.d.ts +64 -0
- package/packages/sdk/src/utils/utils.js +140 -0
- package/packages/sdk/src/utils/utils.js.map +1 -0
- package/packages/sdk/src/utils/utils.mjs +128 -0
- package/packages/sdk/src/utils/utils.mjs.map +1 -0
- package/packages/transact/src/logicsig.d.ts +47 -0
- package/packages/transact/src/logicsig.js +118 -0
- package/packages/transact/src/logicsig.js.map +1 -0
- package/packages/transact/src/logicsig.mjs +116 -0
- package/packages/transact/src/logicsig.mjs.map +1 -0
- package/packages/transact/src/multisig.d.ts +153 -0
- package/packages/transact/src/multisig.js +388 -0
- package/packages/transact/src/multisig.js.map +1 -0
- package/packages/transact/src/multisig.mjs +368 -0
- package/packages/transact/src/multisig.mjs.map +1 -0
- package/packages/transact/src/signer.d.ts +47 -0
- package/packages/transact/src/signer.js +71 -0
- package/packages/transact/src/signer.js.map +1 -0
- package/packages/transact/src/signer.mjs +70 -0
- package/packages/transact/src/signer.mjs.map +1 -0
- package/packages/transact/src/transactions/app-call.d.ts +209 -0
- package/packages/transact/src/transactions/app-call.js +251 -0
- package/packages/transact/src/transactions/app-call.js.map +1 -0
- package/packages/transact/src/transactions/app-call.mjs +250 -0
- package/packages/transact/src/transactions/app-call.mjs.map +1 -0
- package/packages/transact/src/transactions/asset-config.d.ts +131 -0
- package/packages/transact/src/transactions/asset-config.js +101 -0
- package/packages/transact/src/transactions/asset-config.js.map +1 -0
- package/packages/transact/src/transactions/asset-config.mjs +101 -0
- package/packages/transact/src/transactions/asset-config.mjs.map +1 -0
- package/packages/transact/src/transactions/asset-freeze.d.ts +35 -0
- package/packages/transact/src/transactions/asset-freeze.js +18 -0
- package/packages/transact/src/transactions/asset-freeze.js.map +1 -0
- package/packages/transact/src/transactions/asset-freeze.mjs +18 -0
- package/packages/transact/src/transactions/asset-freeze.mjs.map +1 -0
- package/packages/transact/src/transactions/asset-transfer.d.ts +56 -0
- package/packages/transact/src/transactions/asset-transfer.js +18 -0
- package/packages/transact/src/transactions/asset-transfer.js.map +1 -0
- package/packages/transact/src/transactions/asset-transfer.mjs +18 -0
- package/packages/transact/src/transactions/asset-transfer.mjs.map +1 -0
- package/packages/transact/src/transactions/common.d.ts +37 -0
- package/packages/transact/src/transactions/common.js +24 -0
- package/packages/transact/src/transactions/common.js.map +1 -0
- package/packages/transact/src/transactions/common.mjs +22 -0
- package/packages/transact/src/transactions/common.mjs.map +1 -0
- package/packages/transact/src/transactions/heartbeat.d.ts +37 -0
- package/packages/transact/src/transactions/key-registration.d.ts +45 -0
- package/packages/transact/src/transactions/key-registration.js +54 -0
- package/packages/transact/src/transactions/key-registration.js.map +1 -0
- package/packages/transact/src/transactions/key-registration.mjs +54 -0
- package/packages/transact/src/transactions/key-registration.mjs.map +1 -0
- package/packages/transact/src/transactions/payment.d.ts +32 -0
- package/packages/transact/src/transactions/signed-transaction-meta.d.ts +12 -0
- package/packages/transact/src/transactions/signed-transaction-meta.js +132 -0
- package/packages/transact/src/transactions/signed-transaction-meta.js.map +1 -0
- package/packages/transact/src/transactions/signed-transaction-meta.mjs +129 -0
- package/packages/transact/src/transactions/signed-transaction-meta.mjs.map +1 -0
- package/packages/transact/src/transactions/signed-transaction.d.ts +126 -0
- package/packages/transact/src/transactions/signed-transaction.js +67 -0
- package/packages/transact/src/transactions/signed-transaction.js.map +1 -0
- package/packages/transact/src/transactions/signed-transaction.mjs +64 -0
- package/packages/transact/src/transactions/signed-transaction.mjs.map +1 -0
- package/packages/transact/src/transactions/state-proof.d.ts +64 -0
- package/packages/transact/src/transactions/transaction-meta.d.ts +14 -0
- package/packages/transact/src/transactions/transaction-meta.js +1007 -0
- package/packages/transact/src/transactions/transaction-meta.js.map +1 -0
- package/packages/transact/src/transactions/transaction-meta.mjs +1006 -0
- package/packages/transact/src/transactions/transaction-meta.mjs.map +1 -0
- package/packages/transact/src/transactions/transaction-type.d.ts +47 -0
- package/packages/transact/src/transactions/transaction-type.js +50 -0
- package/packages/transact/src/transactions/transaction-type.js.map +1 -0
- package/packages/transact/src/transactions/transaction-type.mjs +49 -0
- package/packages/transact/src/transactions/transaction-type.mjs.map +1 -0
- package/packages/transact/src/transactions/transaction.d.ts +312 -0
- package/packages/transact/src/transactions/transaction.js +351 -0
- package/packages/transact/src/transactions/transaction.js.map +1 -0
- package/packages/transact/src/transactions/transaction.mjs +337 -0
- package/packages/transact/src/transactions/transaction.mjs.map +1 -0
- package/sdk/index.d.ts +10 -0
- package/sdk/index.js +59 -0
- package/sdk/index.mjs +11 -0
- package/testing/account.d.ts +14 -9
- package/testing/account.js +27 -31
- package/testing/account.js.map +1 -1
- package/testing/account.mjs +27 -29
- package/testing/account.mjs.map +1 -1
- package/testing/fixtures/algokit-log-capture-fixture.d.ts +8 -2
- package/testing/fixtures/algokit-log-capture-fixture.js +35 -39
- package/testing/fixtures/algokit-log-capture-fixture.js.map +1 -1
- package/testing/fixtures/algokit-log-capture-fixture.mjs +35 -37
- package/testing/fixtures/algokit-log-capture-fixture.mjs.map +1 -1
- package/testing/fixtures/algorand-fixture.d.ts +11 -5
- package/testing/fixtures/algorand-fixture.js +66 -60
- package/testing/fixtures/algorand-fixture.js.map +1 -1
- package/testing/fixtures/algorand-fixture.mjs +65 -57
- package/testing/fixtures/algorand-fixture.mjs.map +1 -1
- package/testing/index.d.ts +7 -5
- package/testing/index.js +13 -18
- package/testing/index.mjs +8 -7
- package/testing/indexer.d.ts +5 -1
- package/testing/indexer.js +27 -35
- package/testing/indexer.js.map +1 -1
- package/testing/indexer.mjs +27 -34
- package/testing/indexer.mjs.map +1 -1
- package/testing/test-logger.d.ts +42 -36
- package/testing/test-logger.js +70 -74
- package/testing/test-logger.js.map +1 -1
- package/testing/test-logger.mjs +70 -72
- package/testing/test-logger.mjs.map +1 -1
- package/testing/transaction-logger.d.ts +33 -28
- package/testing/transaction-logger.js +73 -91
- package/testing/transaction-logger.js.map +1 -1
- package/testing/transaction-logger.mjs +73 -89
- package/testing/transaction-logger.mjs.map +1 -1
- package/transact/index.d.ts +17 -0
- package/transact/index.js +66 -0
- package/transact/index.mjs +15 -0
- package/transaction/perform-transaction-composer-simulate.d.ts +20 -0
- package/transaction/perform-transaction-composer-simulate.js +33 -0
- package/transaction/perform-transaction-composer-simulate.js.map +1 -0
- package/transaction/perform-transaction-composer-simulate.mjs +32 -0
- package/transaction/perform-transaction-composer-simulate.mjs.map +1 -0
- package/transaction/transaction.d.ts +37 -163
- package/transaction/transaction.js +115 -970
- package/transaction/transaction.js.map +1 -1
- package/transaction/transaction.mjs +115 -953
- package/transaction/transaction.mjs.map +1 -1
- package/transactions/app-call.d.ts +78 -0
- package/transactions/app-call.js +333 -0
- package/transactions/app-call.js.map +1 -0
- package/transactions/app-call.mjs +329 -0
- package/transactions/app-call.mjs.map +1 -0
- package/transactions/asset-config.d.ts +177 -0
- package/transactions/asset-config.js +64 -0
- package/transactions/asset-config.js.map +1 -0
- package/transactions/asset-config.mjs +61 -0
- package/transactions/asset-config.mjs.map +1 -0
- package/transactions/asset-transfer.d.ts +44 -0
- package/transactions/asset-transfer.js +50 -0
- package/transactions/asset-transfer.js.map +1 -0
- package/transactions/asset-transfer.mjs +48 -0
- package/transactions/asset-transfer.mjs.map +1 -0
- package/transactions/common.d.ts +48 -0
- package/transactions/common.js +31 -0
- package/transactions/common.js.map +1 -0
- package/transactions/common.mjs +30 -0
- package/transactions/common.mjs.map +1 -0
- package/transactions/fee-coverage.js +115 -0
- package/transactions/fee-coverage.js.map +1 -0
- package/transactions/fee-coverage.mjs +112 -0
- package/transactions/fee-coverage.mjs.map +1 -0
- package/transactions/key-registration.d.ts +27 -0
- package/transactions/key-registration.js +30 -0
- package/transactions/key-registration.js.map +1 -0
- package/transactions/key-registration.mjs +30 -0
- package/transactions/key-registration.mjs.map +1 -0
- package/transactions/method-call.d.ts +45 -0
- package/transactions/method-call.js +326 -0
- package/transactions/method-call.js.map +1 -0
- package/transactions/method-call.mjs +322 -0
- package/transactions/method-call.mjs.map +1 -0
- package/transactions/payment.d.ts +21 -0
- package/transactions/payment.js +21 -0
- package/transactions/payment.js.map +1 -0
- package/transactions/payment.mjs +21 -0
- package/transactions/payment.mjs.map +1 -0
- package/types/account-manager.d.ts +434 -428
- package/types/account-manager.js +606 -600
- package/types/account-manager.js.map +1 -1
- package/types/account-manager.mjs +604 -598
- package/types/account-manager.mjs.map +1 -1
- package/types/account.d.ts +149 -212
- package/types/account.js +6 -90
- package/types/account.js.map +1 -1
- package/types/account.mjs +7 -88
- package/types/account.mjs.map +1 -1
- package/types/algorand-client-transaction-creator.d.ts +1087 -761
- package/types/algorand-client-transaction-creator.js +723 -722
- package/types/algorand-client-transaction-creator.js.map +1 -1
- package/types/algorand-client-transaction-creator.mjs +723 -721
- package/types/algorand-client-transaction-creator.mjs.map +1 -1
- package/types/algorand-client-transaction-sender.d.ts +1298 -1268
- package/types/algorand-client-transaction-sender.js +920 -951
- package/types/algorand-client-transaction-sender.js.map +1 -1
- package/types/algorand-client-transaction-sender.mjs +918 -949
- package/types/algorand-client-transaction-sender.mjs.map +1 -1
- package/types/algorand-client.d.ts +242 -236
- package/types/algorand-client.js +321 -318
- package/types/algorand-client.js.map +1 -1
- package/types/algorand-client.mjs +321 -316
- package/types/algorand-client.mjs.map +1 -1
- package/types/amount.d.ts +47 -43
- package/types/amount.js +62 -68
- package/types/amount.js.map +1 -1
- package/types/amount.mjs +62 -66
- package/types/amount.mjs.map +1 -1
- package/types/app-client.d.ts +2018 -1972
- package/types/app-client.js +900 -1794
- package/types/app-client.js.map +1 -1
- package/types/app-client.mjs +899 -1792
- package/types/app-client.mjs.map +1 -1
- package/types/app-deployer.d.ts +149 -141
- package/types/app-deployer.js +349 -382
- package/types/app-deployer.js.map +1 -1
- package/types/app-deployer.mjs +349 -380
- package/types/app-deployer.mjs.map +1 -1
- package/types/app-factory.d.ts +931 -914
- package/types/app-factory.js +444 -486
- package/types/app-factory.js.map +1 -1
- package/types/app-factory.mjs +444 -484
- package/types/app-factory.mjs.map +1 -1
- package/types/app-manager.d.ts +299 -325
- package/types/app-manager.js +447 -498
- package/types/app-manager.js.map +1 -1
- package/types/app-manager.mjs +448 -496
- package/types/app-manager.mjs.map +1 -1
- package/types/app-spec.d.ts +154 -117
- package/types/app-spec.js +124 -133
- package/types/app-spec.js.map +1 -1
- package/types/app-spec.mjs +124 -131
- package/types/app-spec.mjs.map +1 -1
- package/types/app.d.ts +186 -291
- package/types/app.js +34 -26
- package/types/app.js.map +1 -1
- package/types/app.mjs +32 -25
- package/types/app.mjs.map +1 -1
- package/types/asset-manager.d.ts +206 -199
- package/types/asset-manager.js +162 -172
- package/types/asset-manager.js.map +1 -1
- package/types/asset-manager.mjs +162 -170
- package/types/asset-manager.mjs.map +1 -1
- package/types/async-event-emitter.d.ts +18 -13
- package/types/async-event-emitter.js +35 -47
- package/types/async-event-emitter.js.map +1 -1
- package/types/async-event-emitter.mjs +35 -46
- package/types/async-event-emitter.mjs.map +1 -1
- package/types/client-manager.d.ts +455 -451
- package/types/client-manager.js +612 -596
- package/types/client-manager.js.map +1 -1
- package/types/client-manager.mjs +612 -594
- package/types/client-manager.mjs.map +1 -1
- package/types/composer.d.ts +921 -1312
- package/types/composer.js +1569 -1469
- package/types/composer.js.map +1 -1
- package/types/composer.mjs +1568 -1467
- package/types/composer.mjs.map +1 -1
- package/types/config.d.ts +53 -48
- package/types/config.js +76 -75
- package/types/config.js.map +1 -1
- package/types/config.mjs +76 -73
- package/types/config.mjs.map +1 -1
- package/types/debugging.d.ts +26 -23
- package/types/debugging.js +7 -9
- package/types/debugging.js.map +1 -1
- package/types/debugging.mjs +7 -8
- package/types/debugging.mjs.map +1 -1
- package/types/dispenser-client.d.ts +57 -52
- package/types/dispenser-client.js +122 -139
- package/types/dispenser-client.js.map +1 -1
- package/types/dispenser-client.mjs +122 -137
- package/types/dispenser-client.mjs.map +1 -1
- package/types/expand.d.ts +5 -3
- package/types/expand.js +0 -3
- package/types/expand.mjs +0 -2
- package/types/indexer.d.ts +32 -160
- package/types/indexer.js +34 -29
- package/types/indexer.js.map +1 -1
- package/types/indexer.mjs +30 -28
- package/types/indexer.mjs.map +1 -1
- package/types/instance-of.d.ts +5 -3
- package/types/instance-of.js +0 -3
- package/types/instance-of.mjs +0 -2
- package/types/kmd-account-manager.d.ts +70 -70
- package/types/kmd-account-manager.js +152 -182
- package/types/kmd-account-manager.js.map +1 -1
- package/types/kmd-account-manager.mjs +150 -180
- package/types/kmd-account-manager.mjs.map +1 -1
- package/types/lifecycle-events.d.ts +13 -8
- package/types/lifecycle-events.js +10 -7
- package/types/lifecycle-events.js.map +1 -1
- package/types/lifecycle-events.mjs +8 -6
- package/types/lifecycle-events.mjs.map +1 -1
- package/types/logging.d.ts +11 -13
- package/types/logging.js +28 -29
- package/types/logging.js.map +1 -1
- package/types/logging.mjs +28 -28
- package/types/logging.mjs.map +1 -1
- package/types/logic-error.d.ts +33 -29
- package/types/logic-error.js +48 -47
- package/types/logic-error.js.map +1 -1
- package/types/logic-error.mjs +48 -46
- package/types/logic-error.mjs.map +1 -1
- package/types/network-client.d.ts +32 -27
- package/types/network-client.js +8 -7
- package/types/network-client.js.map +1 -1
- package/types/network-client.mjs +8 -6
- package/types/network-client.mjs.map +1 -1
- package/types/testing.d.ts +138 -132
- package/types/testing.js +0 -3
- package/types/testing.mjs +0 -2
- package/types/transaction.d.ts +108 -123
- package/types/transaction.js +0 -3
- package/types/transaction.mjs +0 -2
- package/util.js +51 -125
- package/util.js.map +1 -1
- package/util.mjs +52 -121
- package/util.mjs.map +1 -1
- package/account/account.d.ts +0 -144
- package/account/account.js +0 -182
- package/account/account.js.map +0 -1
- package/account/account.mjs +0 -172
- package/account/account.mjs.map +0 -1
- package/account/get-account-config-from-environment.d.ts +0 -12
- package/account/get-account-config-from-environment.js +0 -25
- package/account/get-account-config-from-environment.js.map +0 -1
- package/account/get-account-config-from-environment.mjs +0 -23
- package/account/get-account-config-from-environment.mjs.map +0 -1
- package/account/get-account.d.ts +0 -65
- package/account/get-account.js +0 -63
- package/account/get-account.js.map +0 -1
- package/account/get-account.mjs +0 -61
- package/account/get-account.mjs.map +0 -1
- package/account/get-dispenser-account.d.ts +0 -17
- package/account/get-dispenser-account.js +0 -22
- package/account/get-dispenser-account.js.map +0 -1
- package/account/get-dispenser-account.mjs +0 -20
- package/account/get-dispenser-account.mjs.map +0 -1
- package/account/index.d.ts +0 -5
- package/account/mnemonic-account.d.ts +0 -13
- package/account/mnemonic-account.js +0 -21
- package/account/mnemonic-account.js.map +0 -1
- package/account/mnemonic-account.mjs +0 -19
- package/account/mnemonic-account.mjs.map +0 -1
- package/app-client.d.ts +0 -86
- package/app-client.js +0 -98
- package/app-client.js.map +0 -1
- package/app-client.mjs +0 -94
- package/app-client.mjs.map +0 -1
- package/app-deploy.d.ts +0 -120
- package/app-deploy.js +0 -285
- package/app-deploy.js.map +0 -1
- package/app-deploy.mjs +0 -276
- package/app-deploy.mjs.map +0 -1
- package/app.d.ts +0 -205
- package/app.js +0 -349
- package/app.js.map +0 -1
- package/app.mjs +0 -329
- package/app.mjs.map +0 -1
- package/asset.d.ts +0 -74
- package/asset.js +0 -142
- package/asset.js.map +0 -1
- package/asset.mjs +0 -136
- package/asset.mjs.map +0 -1
- package/debugging/debugging.d.ts +0 -8
- package/debugging/debugging.js +0 -15
- package/debugging/debugging.js.map +0 -1
- package/debugging/debugging.mjs +0 -13
- package/debugging/debugging.mjs.map +0 -1
- package/debugging/index.d.ts +0 -1
- package/dispenser-client.d.ts +0 -20
- package/dispenser-client.js +0 -28
- package/dispenser-client.js.map +0 -1
- package/dispenser-client.mjs +0 -26
- package/dispenser-client.mjs.map +0 -1
- package/index.js.map +0 -1
- package/index.mjs.map +0 -1
- package/localnet/get-kmd-wallet-account.d.ts +0 -27
- package/localnet/get-kmd-wallet-account.js +0 -30
- package/localnet/get-kmd-wallet-account.js.map +0 -1
- package/localnet/get-kmd-wallet-account.mjs +0 -28
- package/localnet/get-kmd-wallet-account.mjs.map +0 -1
- package/localnet/get-localnet-dispenser-account.d.ts +0 -13
- package/localnet/get-localnet-dispenser-account.js +0 -19
- package/localnet/get-localnet-dispenser-account.js.map +0 -1
- package/localnet/get-localnet-dispenser-account.mjs +0 -17
- package/localnet/get-localnet-dispenser-account.mjs.map +0 -1
- package/localnet/get-or-create-kmd-wallet-account.d.ts +0 -28
- package/localnet/get-or-create-kmd-wallet-account.js +0 -30
- package/localnet/get-or-create-kmd-wallet-account.js.map +0 -1
- package/localnet/get-or-create-kmd-wallet-account.mjs +0 -28
- package/localnet/get-or-create-kmd-wallet-account.mjs.map +0 -1
- package/localnet/index.d.ts +0 -4
- package/localnet/is-localnet.d.ts +0 -7
- package/localnet/is-localnet.js +0 -14
- package/localnet/is-localnet.js.map +0 -1
- package/localnet/is-localnet.mjs +0 -12
- package/localnet/is-localnet.mjs.map +0 -1
- package/network-client.d.ts +0 -125
- package/network-client.js +0 -156
- package/network-client.js.map +0 -1
- package/network-client.mjs +0 -145
- package/network-client.mjs.map +0 -1
- package/testing/_asset.d.ts +0 -3
- package/testing/fixtures/index.d.ts +0 -2
- package/testing/index.js.map +0 -1
- package/testing/index.mjs.map +0 -1
- package/transaction/index.d.ts +0 -2
- package/transaction/legacy-bridge.d.ts +0 -35
- package/transaction/legacy-bridge.js +0 -129
- package/transaction/legacy-bridge.js.map +0 -1
- package/transaction/legacy-bridge.mjs +0 -124
- package/transaction/legacy-bridge.mjs.map +0 -1
- package/transaction/perform-atomic-transaction-composer-simulate.d.ts +0 -13
- package/transaction/perform-atomic-transaction-composer-simulate.js +0 -40
- package/transaction/perform-atomic-transaction-composer-simulate.js.map +0 -1
- package/transaction/perform-atomic-transaction-composer-simulate.mjs +0 -38
- package/transaction/perform-atomic-transaction-composer-simulate.mjs.map +0 -1
- package/transfer/index.d.ts +0 -2
- package/transfer/transfer-algos.d.ts +0 -18
- package/transfer/transfer-algos.js +0 -31
- package/transfer/transfer-algos.js.map +0 -1
- package/transfer/transfer-algos.mjs +0 -29
- package/transfer/transfer-algos.mjs.map +0 -1
- package/transfer/transfer.d.ts +0 -52
- package/transfer/transfer.js +0 -112
- package/transfer/transfer.js.map +0 -1
- package/transfer/transfer.mjs +0 -108
- package/transfer/transfer.mjs.map +0 -1
- package/types/algo-http-client-with-retry.d.ts +0 -12
- package/types/algo-http-client-with-retry.js +0 -94
- package/types/algo-http-client-with-retry.js.map +0 -1
- package/types/algo-http-client-with-retry.mjs +0 -92
- package/types/algo-http-client-with-retry.mjs.map +0 -1
- package/types/app-arc56.d.ts +0 -359
- package/types/app-arc56.js +0 -200
- package/types/app-arc56.js.map +0 -1
- package/types/app-arc56.mjs +0 -191
- package/types/app-arc56.mjs.map +0 -1
- package/types/asset.d.ts +0 -99
- package/types/asset.js +0 -3
- package/types/asset.js.map +0 -1
- package/types/asset.mjs +0 -2
- package/types/asset.mjs.map +0 -1
- package/types/expand.js.map +0 -1
- package/types/expand.mjs.map +0 -1
- package/types/instance-of.js.map +0 -1
- package/types/instance-of.mjs.map +0 -1
- package/types/testing.js.map +0 -1
- package/types/testing.mjs.map +0 -1
- package/types/transaction.js.map +0 -1
- package/types/transaction.mjs.map +0 -1
- package/types/transfer.d.ts +0 -76
- package/types/transfer.js +0 -3
- package/types/transfer.js.map +0 -1
- package/types/transfer.mjs +0 -2
- package/types/transfer.mjs.map +0 -1
- package/util.d.ts +0 -48
package/types/app-client.js
CHANGED
|
@@ -1,1804 +1,910 @@
|
|
|
1
|
-
|
|
1
|
+
const require_rolldown_runtime = require('../_virtual/rolldown_runtime.js');
|
|
2
|
+
const require_address = require('../packages/common/src/address.js');
|
|
3
|
+
const require_app_call = require('../packages/transact/src/transactions/app-call.js');
|
|
4
|
+
const require_sourcemap = require('../packages/sdk/src/logic/sourcemap.js');
|
|
5
|
+
const require_config = require('../config.js');
|
|
6
|
+
const require_util = require('../util.js');
|
|
7
|
+
const require_abi_method = require('../packages/abi/src/abi-method.js');
|
|
8
|
+
const require_arc56_contract = require('../packages/abi/src/arc56-contract.js');
|
|
9
|
+
const require_lifecycle_events = require('./lifecycle-events.js');
|
|
10
|
+
const require_app_spec = require('./app-spec.js');
|
|
11
|
+
const require_logic_error = require('./logic-error.js');
|
|
12
|
+
let buffer = require("buffer");
|
|
13
|
+
buffer = require_rolldown_runtime.__toESM(buffer);
|
|
2
14
|
|
|
3
|
-
|
|
4
|
-
var buffer = require('buffer');
|
|
5
|
-
var app = require('../app.js');
|
|
6
|
-
var appDeploy = require('../app-deploy.js');
|
|
7
|
-
var config = require('../config.js');
|
|
8
|
-
var legacyBridge = require('../transaction/legacy-bridge.js');
|
|
9
|
-
var transaction = require('../transaction/transaction.js');
|
|
10
|
-
var util = require('../util.js');
|
|
11
|
-
var types_app = require('./app.js');
|
|
12
|
-
var types_appArc56 = require('./app-arc56.js');
|
|
13
|
-
var types_appSpec = require('./app-spec.js');
|
|
14
|
-
var types_lifecycleEvents = require('./lifecycle-events.js');
|
|
15
|
-
var types_logicError = require('./logic-error.js');
|
|
16
|
-
|
|
17
|
-
var ABIMethod = algosdk.ABIMethod;
|
|
18
|
-
var AtomicTransactionComposer = algosdk.AtomicTransactionComposer;
|
|
19
|
-
var getApplicationAddress = algosdk.getApplicationAddress;
|
|
20
|
-
var Indexer = algosdk.Indexer;
|
|
21
|
-
var OnApplicationComplete = algosdk.OnApplicationComplete;
|
|
22
|
-
var SourceMap = algosdk.ProgramSourceMap;
|
|
15
|
+
//#region src/types/app-client.ts
|
|
23
16
|
/** The maximum opcode budget for a simulate call as per https://github.com/algorand/go-algorand/blob/807b29a91c371d225e12b9287c5d56e9b33c4e4c/ledger/simulation/trace.go#L104 */
|
|
24
|
-
const MAX_SIMULATE_OPCODE_BUDGET =
|
|
25
|
-
/**
|
|
26
|
-
* Determines deploy time control (UPDATABLE, DELETABLE) value by inspecting application specification
|
|
27
|
-
* @param approval TEAL Approval program, not the base64 version found on the appSpec
|
|
28
|
-
* @param appSpec Application Specification
|
|
29
|
-
* @param templateVariableName Template variable
|
|
30
|
-
* @param callConfigKey Call config type
|
|
31
|
-
* @returns true if applicable call config is found, false if not found or undefined if variable not present
|
|
32
|
-
*/
|
|
33
|
-
function getDeployTimeControl(approval, appSpec, templateVariableName, callConfigKey) {
|
|
34
|
-
// variable not present, so unknown control value
|
|
35
|
-
if (!approval.includes(templateVariableName))
|
|
36
|
-
return undefined;
|
|
37
|
-
// a bare call for specified CallConfig is present and configured
|
|
38
|
-
const bareCallConfig = appSpec.bare_call_config[callConfigKey];
|
|
39
|
-
if (!!bareCallConfig && bareCallConfig !== 'NEVER')
|
|
40
|
-
return true;
|
|
41
|
-
// an ABI call for specified CallConfig is present and configured
|
|
42
|
-
return Object.values(appSpec.hints).some((h) => {
|
|
43
|
-
const abiCallConfig = h.call_config[callConfigKey];
|
|
44
|
-
return !!abiCallConfig && abiCallConfig !== 'NEVER';
|
|
45
|
-
});
|
|
46
|
-
}
|
|
17
|
+
const MAX_SIMULATE_OPCODE_BUDGET = 2e4 * 16;
|
|
47
18
|
const BYTE_CBLOCK = 38;
|
|
48
19
|
const INT_CBLOCK = 32;
|
|
49
20
|
/**
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
21
|
+
* Get the offset of the last constant block at the beginning of the program
|
|
22
|
+
* This value is used to calculate the program counter for an ARC56 program that has a pcOffsetMethod of "cblocks"
|
|
23
|
+
*
|
|
24
|
+
* @param program The program to parse
|
|
25
|
+
* @returns The PC value of the opcode after the last constant block
|
|
26
|
+
*/
|
|
56
27
|
function getConstantBlockOffset(program) {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
// Do nothing...
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
if (isBytecblock)
|
|
87
|
-
bytecblockOffset = programSize - bytes.length - 1;
|
|
88
|
-
else
|
|
89
|
-
intcblockOffset = programSize - bytes.length - 1;
|
|
90
|
-
if (bytes[0] !== BYTE_CBLOCK && bytes[0] !== INT_CBLOCK) {
|
|
91
|
-
// if the next opcode isn't a constant block, we're done
|
|
92
|
-
break;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
return Math.max(bytecblockOffset ?? 0, intcblockOffset ?? 0);
|
|
28
|
+
const bytes = [...program];
|
|
29
|
+
const programSize = bytes.length;
|
|
30
|
+
bytes.shift();
|
|
31
|
+
/** The PC of the opcode after the bytecblock */
|
|
32
|
+
let bytecblockOffset;
|
|
33
|
+
/** The PC of the opcode after the intcblock */
|
|
34
|
+
let intcblockOffset;
|
|
35
|
+
while (bytes.length > 0) {
|
|
36
|
+
/** The current byte from the beginning of the byte array */
|
|
37
|
+
const byte = bytes.shift();
|
|
38
|
+
if (byte === BYTE_CBLOCK || byte === INT_CBLOCK) {
|
|
39
|
+
const isBytecblock = byte === BYTE_CBLOCK;
|
|
40
|
+
/** The byte following the opcode is the number of values in the constant block */
|
|
41
|
+
const valuesRemaining = bytes.shift();
|
|
42
|
+
for (let i = 0; i < valuesRemaining; i++) if (isBytecblock) {
|
|
43
|
+
/** The byte following the opcode is the length of the next element */
|
|
44
|
+
const length = bytes.shift();
|
|
45
|
+
bytes.splice(0, length);
|
|
46
|
+
} else while ((bytes.shift() & 128) !== 0);
|
|
47
|
+
if (isBytecblock) bytecblockOffset = programSize - bytes.length - 1;
|
|
48
|
+
else intcblockOffset = programSize - bytes.length - 1;
|
|
49
|
+
if (bytes[0] !== BYTE_CBLOCK && bytes[0] !== INT_CBLOCK) break;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return Math.max(bytecblockOffset ?? 0, intcblockOffset ?? 0);
|
|
97
53
|
}
|
|
98
54
|
/** ARC-56/ARC-32 application client that allows you to manage calls and
|
|
99
|
-
|
|
100
|
-
class AppClient {
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
|
|
830
|
-
|
|
831
|
-
|
|
832
|
-
|
|
833
|
-
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
862
|
-
|
|
863
|
-
|
|
864
|
-
|
|
865
|
-
|
|
866
|
-
|
|
867
|
-
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
|
|
872
|
-
|
|
873
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
899
|
-
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
|
|
904
|
-
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
const error = e;
|
|
952
|
-
// For read-only calls with max opcode budget, fee issues should be rare
|
|
953
|
-
// but we can still provide helpful error message if they occur
|
|
954
|
-
if (params.coverAppCallInnerTransactionFees && error && error.message && error.message.match(/fee too small/)) {
|
|
955
|
-
throw Error(`Fees were too small. You may need to increase the transaction maxFee.`);
|
|
956
|
-
}
|
|
957
|
-
throw e;
|
|
958
|
-
}
|
|
959
|
-
}
|
|
960
|
-
return this.processMethodCallReturn(this._algorand.send.appCallMethodCall(await this.params.call(params)), types_appArc56.getArc56Method(params.method, this._appSpec));
|
|
961
|
-
},
|
|
962
|
-
};
|
|
963
|
-
}
|
|
964
|
-
getMethodCallCreateTransactionMethods() {
|
|
965
|
-
return {
|
|
966
|
-
/** Return transaction for a payment transaction to fund the app account
|
|
967
|
-
* @param params The parameters for the fund app account payment transaction
|
|
968
|
-
* @returns A transaction which can be used to fund the app account
|
|
969
|
-
*/
|
|
970
|
-
fundAppAccount: (params) => {
|
|
971
|
-
return this._algorand.createTransaction.payment(this.params.fundAppAccount(params));
|
|
972
|
-
},
|
|
973
|
-
/**
|
|
974
|
-
* Return transactions for an update ABI call, including deploy-time TEAL template replacements and compilation if provided
|
|
975
|
-
* @param params The parameters for the update ABI method call
|
|
976
|
-
* @returns The transactions which can be used to create an update ABI method call
|
|
977
|
-
*/
|
|
978
|
-
update: async (params) => {
|
|
979
|
-
return this._algorand.createTransaction.appUpdateMethodCall(await this.params.update(params));
|
|
980
|
-
},
|
|
981
|
-
/**
|
|
982
|
-
* Return transactions for an opt-in ABI call
|
|
983
|
-
* @param params The parameters for the opt-in ABI method call
|
|
984
|
-
* @returns The transactions which can be used to create an opt-in ABI method call
|
|
985
|
-
*/
|
|
986
|
-
optIn: async (params) => {
|
|
987
|
-
return this._algorand.createTransaction.appCallMethodCall(await this.params.optIn(params));
|
|
988
|
-
},
|
|
989
|
-
/**
|
|
990
|
-
* Return transactions for a delete ABI call
|
|
991
|
-
* @param params The parameters for the delete ABI method call
|
|
992
|
-
* @returns The transactions which can be used to create a delete ABI method call
|
|
993
|
-
*/
|
|
994
|
-
delete: async (params) => {
|
|
995
|
-
return this._algorand.createTransaction.appDeleteMethodCall(await this.params.delete(params));
|
|
996
|
-
},
|
|
997
|
-
/**
|
|
998
|
-
* Return transactions for a close out ABI call
|
|
999
|
-
* @param params The parameters for the close out ABI method call
|
|
1000
|
-
* @returns The transactions which can be used to create a close out ABI method call
|
|
1001
|
-
*/
|
|
1002
|
-
closeOut: async (params) => {
|
|
1003
|
-
return this._algorand.createTransaction.appCallMethodCall(await this.params.closeOut(params));
|
|
1004
|
-
},
|
|
1005
|
-
/**
|
|
1006
|
-
* Return transactions for an ABI call (defaults to no-op)
|
|
1007
|
-
* @param params The parameters for the ABI method call
|
|
1008
|
-
* @returns The transactions which can be used to create an ABI method call
|
|
1009
|
-
*/
|
|
1010
|
-
call: async (params) => {
|
|
1011
|
-
return this._algorand.createTransaction.appCallMethodCall(await this.params.call(params));
|
|
1012
|
-
},
|
|
1013
|
-
};
|
|
1014
|
-
}
|
|
1015
|
-
/** Returns the sender for a call, using the provided sender or using the `defaultSender`
|
|
1016
|
-
* if none provided and throws an error if neither provided */
|
|
1017
|
-
getSender(sender) {
|
|
1018
|
-
if (!sender && !this._defaultSender) {
|
|
1019
|
-
throw new Error(`No sender provided and no default sender present in app client for call to app ${this._appName}`);
|
|
1020
|
-
}
|
|
1021
|
-
return typeof sender === 'string' ? algosdk.Address.fromString(sender) : (sender ?? this._defaultSender);
|
|
1022
|
-
}
|
|
1023
|
-
/** Returns the signer for a call, using the provided signer or the `defaultSigner`
|
|
1024
|
-
* if no signer was provided and the sender resolves to the default sender, the call will use default signer
|
|
1025
|
-
* or `undefined` otherwise (so the signer is resolved from `AlgorandClient`) */
|
|
1026
|
-
getSigner(sender, signer) {
|
|
1027
|
-
return signer ?? (!sender || sender === this._defaultSender ? this._defaultSigner : undefined);
|
|
1028
|
-
}
|
|
1029
|
-
getBareParams(params, onComplete) {
|
|
1030
|
-
return {
|
|
1031
|
-
...params,
|
|
1032
|
-
appId: this._appId,
|
|
1033
|
-
sender: this.getSender(params?.sender),
|
|
1034
|
-
signer: this.getSigner(params?.sender, params?.signer),
|
|
1035
|
-
onComplete,
|
|
1036
|
-
};
|
|
1037
|
-
}
|
|
1038
|
-
async getABIParams(params, onComplete) {
|
|
1039
|
-
const sender = this.getSender(params.sender);
|
|
1040
|
-
const method = types_appArc56.getArc56Method(params.method, this._appSpec);
|
|
1041
|
-
const args = await this.getABIArgsWithDefaultValues(params.method, params.args, sender);
|
|
1042
|
-
return {
|
|
1043
|
-
...params,
|
|
1044
|
-
appId: this._appId,
|
|
1045
|
-
sender: sender,
|
|
1046
|
-
signer: this.getSigner(params.sender, params.signer),
|
|
1047
|
-
method,
|
|
1048
|
-
onComplete,
|
|
1049
|
-
args,
|
|
1050
|
-
};
|
|
1051
|
-
}
|
|
1052
|
-
getBoxMethods() {
|
|
1053
|
-
// eslint-disable-next-line @typescript-eslint/no-this-alias
|
|
1054
|
-
const that = this;
|
|
1055
|
-
const stateMethods = {
|
|
1056
|
-
/**
|
|
1057
|
-
* Returns all single-key state values in a record keyed by the key name and the value a decoded ABI value.
|
|
1058
|
-
*/
|
|
1059
|
-
getAll: async () => {
|
|
1060
|
-
return Object.fromEntries(await Promise.all(Object.keys(that._appSpec.state.keys.box).map(async (key) => [key, await stateMethods.getValue(key)])));
|
|
1061
|
-
},
|
|
1062
|
-
/**
|
|
1063
|
-
* Returns a single state value for the current app with the value a decoded ABI value.
|
|
1064
|
-
* @param name The name of the state value to retrieve the value for
|
|
1065
|
-
* @returns
|
|
1066
|
-
*/
|
|
1067
|
-
getValue: async (name) => {
|
|
1068
|
-
const metadata = that._appSpec.state.keys.box[name];
|
|
1069
|
-
const value = await that.getBoxValue(buffer.Buffer.from(metadata.key, 'base64'));
|
|
1070
|
-
return types_appArc56.getABIDecodedValue(value, metadata.valueType, that._appSpec.structs);
|
|
1071
|
-
},
|
|
1072
|
-
/**
|
|
1073
|
-
*
|
|
1074
|
-
* @param mapName The name of the map to read from
|
|
1075
|
-
* @param key The key within the map (without any map prefix) as either a Buffer with the bytes or a value
|
|
1076
|
-
* that will be converted to bytes by encoding it using the specified ABI key type
|
|
1077
|
-
* in the ARC-56 spec
|
|
1078
|
-
*/
|
|
1079
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
1080
|
-
getMapValue: async (mapName, key) => {
|
|
1081
|
-
const metadata = that._appSpec.state.maps.box[mapName];
|
|
1082
|
-
const prefix = buffer.Buffer.from(metadata.prefix ?? '', 'base64');
|
|
1083
|
-
const encodedKey = buffer.Buffer.concat([prefix, types_appArc56.getABIEncodedValue(key, metadata.keyType, that._appSpec.structs)]);
|
|
1084
|
-
const base64Key = buffer.Buffer.from(encodedKey).toString('base64');
|
|
1085
|
-
const value = await that.getBoxValue(buffer.Buffer.from(base64Key, 'base64'));
|
|
1086
|
-
return types_appArc56.getABIDecodedValue(value, metadata.valueType, that._appSpec.structs);
|
|
1087
|
-
},
|
|
1088
|
-
/**
|
|
1089
|
-
*
|
|
1090
|
-
* @param mapName The name of the map to read from
|
|
1091
|
-
* @param key The key within the map as either a Buffer with the bytes or a value
|
|
1092
|
-
* that will be converted to bytes by encoding it using the specified ABI key type
|
|
1093
|
-
* in the ARC-56 spec
|
|
1094
|
-
* @param appState
|
|
1095
|
-
*/
|
|
1096
|
-
getMap: async (mapName) => {
|
|
1097
|
-
const metadata = that._appSpec.state.maps.box[mapName];
|
|
1098
|
-
const prefix = buffer.Buffer.from(metadata.prefix ?? '', 'base64');
|
|
1099
|
-
const boxNames = await that.getBoxNames();
|
|
1100
|
-
return new Map(await Promise.all(boxNames
|
|
1101
|
-
.filter((b) => util.binaryStartsWith(b.nameRaw, prefix))
|
|
1102
|
-
.map(async (b) => {
|
|
1103
|
-
return [
|
|
1104
|
-
types_appArc56.getABIDecodedValue(b.nameRaw.slice(prefix.length), metadata.keyType, that._appSpec.structs),
|
|
1105
|
-
types_appArc56.getABIDecodedValue(await that.getBoxValue(b.nameRaw), metadata.valueType, that._appSpec.structs),
|
|
1106
|
-
];
|
|
1107
|
-
})));
|
|
1108
|
-
},
|
|
1109
|
-
};
|
|
1110
|
-
return stateMethods;
|
|
1111
|
-
}
|
|
1112
|
-
getStateMethods(stateGetter, keyGetter, mapGetter) {
|
|
1113
|
-
// eslint-disable-next-line @typescript-eslint/no-this-alias
|
|
1114
|
-
const that = this;
|
|
1115
|
-
const stateMethods = {
|
|
1116
|
-
/**
|
|
1117
|
-
* Returns all single-key state values in a record keyed by the key name and the value a decoded ABI value.
|
|
1118
|
-
*/
|
|
1119
|
-
getAll: async () => {
|
|
1120
|
-
const appState = await stateGetter();
|
|
1121
|
-
return Object.fromEntries(await Promise.all(Object.keys(keyGetter()).map(async (key) => [key, await stateMethods.getValue(key, appState)])));
|
|
1122
|
-
},
|
|
1123
|
-
/**
|
|
1124
|
-
* Returns a single state value for the current app with the value a decoded ABI value.
|
|
1125
|
-
* @param name The name of the state value to retrieve the value for
|
|
1126
|
-
* @param appState Optional cached value of the current state
|
|
1127
|
-
* @returns
|
|
1128
|
-
*/
|
|
1129
|
-
getValue: async (name, appState) => {
|
|
1130
|
-
const state = Object.values(appState ?? (await stateGetter()));
|
|
1131
|
-
const metadata = keyGetter()[name];
|
|
1132
|
-
if (metadata === undefined)
|
|
1133
|
-
throw new Error(`Attempted to get state value ${name}, but it does not exist`);
|
|
1134
|
-
const value = state.find((s) => s.keyBase64 === metadata.key);
|
|
1135
|
-
if (value && 'valueRaw' in value) {
|
|
1136
|
-
return types_appArc56.getABIDecodedValue(value.valueRaw, metadata.valueType, that._appSpec.structs);
|
|
1137
|
-
}
|
|
1138
|
-
return value?.value;
|
|
1139
|
-
},
|
|
1140
|
-
/**
|
|
1141
|
-
* Returns a single value from the given map for the current app with the value a decoded ABI value.
|
|
1142
|
-
* @param mapName The name of the map to read from
|
|
1143
|
-
* @param key The key within the map (without any map prefix) as either a Buffer with the bytes or a value
|
|
1144
|
-
* that will be converted to bytes by encoding it using the specified ABI key type
|
|
1145
|
-
* in the ARC-56 spec
|
|
1146
|
-
* @param appState Optional cached value of the current state
|
|
1147
|
-
*/
|
|
1148
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
1149
|
-
getMapValue: async (mapName, key, appState) => {
|
|
1150
|
-
const state = Object.values(appState ?? (await stateGetter()));
|
|
1151
|
-
const metadata = mapGetter()[mapName];
|
|
1152
|
-
const prefix = buffer.Buffer.from(metadata.prefix ?? '', 'base64');
|
|
1153
|
-
const encodedKey = buffer.Buffer.concat([prefix, types_appArc56.getABIEncodedValue(key, metadata.keyType, that._appSpec.structs)]);
|
|
1154
|
-
const base64Key = buffer.Buffer.from(encodedKey).toString('base64');
|
|
1155
|
-
const value = state.find((s) => s.keyBase64 === base64Key);
|
|
1156
|
-
if (value && 'valueRaw' in value) {
|
|
1157
|
-
return types_appArc56.getABIDecodedValue(value.valueRaw, metadata.valueType, that._appSpec.structs);
|
|
1158
|
-
}
|
|
1159
|
-
return value?.value;
|
|
1160
|
-
},
|
|
1161
|
-
/**
|
|
1162
|
-
* Returns all map values for the given map.
|
|
1163
|
-
* @param mapName The name of the map to read from
|
|
1164
|
-
* @param appState Optional cached value of the current state
|
|
1165
|
-
* @returns A map of all key-value pairs in the map as a `Record<string, ABIValue>`
|
|
1166
|
-
*/
|
|
1167
|
-
getMap: async (mapName) => {
|
|
1168
|
-
const state = Object.values(await stateGetter());
|
|
1169
|
-
const metadata = mapGetter()[mapName];
|
|
1170
|
-
const prefix = buffer.Buffer.from(metadata.prefix ?? '', 'base64');
|
|
1171
|
-
return new Map(state
|
|
1172
|
-
.filter((s) => util.binaryStartsWith(s.keyRaw, prefix))
|
|
1173
|
-
.map((s) => {
|
|
1174
|
-
const key = s.keyRaw.slice(prefix.length);
|
|
1175
|
-
return [
|
|
1176
|
-
types_appArc56.getABIDecodedValue(key, metadata.keyType, this._appSpec.structs),
|
|
1177
|
-
types_appArc56.getABIDecodedValue('valueRaw' in s ? s.valueRaw : s.value, metadata.valueType, this._appSpec.structs),
|
|
1178
|
-
];
|
|
1179
|
-
}));
|
|
1180
|
-
},
|
|
1181
|
-
};
|
|
1182
|
-
return stateMethods;
|
|
1183
|
-
}
|
|
1184
|
-
}
|
|
1185
|
-
/**
|
|
1186
|
-
* @deprecated Use `AppClient` instead e.g. via `algorand.client.getAppClientById` or
|
|
1187
|
-
* `algorand.client.getAppClientByCreatorAndName`.
|
|
1188
|
-
* If you want to `create` or `deploy` then use `AppFactory` e.g. via `algorand.client.getAppFactory`,
|
|
1189
|
-
* which will in turn give you an `AppClient` instance against the created/deployed app to make other calls.
|
|
1190
|
-
*
|
|
1191
|
-
* Application client - a class that wraps an ARC-0032 app spec and provides high productivity methods to deploy and call the app */
|
|
1192
|
-
class ApplicationClient {
|
|
1193
|
-
/**
|
|
1194
|
-
* @deprecated Use `AppClient` instead e.g. via `algorand.client.getAppClientById` or
|
|
1195
|
-
* `algorand.client.getAppClientByCreatorAndName`.
|
|
1196
|
-
* If you want to `create` or `deploy` then use `AppFactory` e.g. via `algorand.client.getAppFactory`,
|
|
1197
|
-
* which will in turn give you an `AppClient` instance against the created/deployed app to make other calls.
|
|
1198
|
-
*
|
|
1199
|
-
* Create a new ApplicationClient instance
|
|
1200
|
-
* @param appDetails The details of the app
|
|
1201
|
-
* @param algod An algod instance
|
|
1202
|
-
*/
|
|
1203
|
-
constructor(appDetails, algod) {
|
|
1204
|
-
const { app, sender, params, deployTimeParams, ...appIdentifier } = appDetails;
|
|
1205
|
-
this.algod = algod;
|
|
1206
|
-
this.appSpec = typeof app == 'string' ? JSON.parse(app) : app;
|
|
1207
|
-
this._appName = appIdentifier.name ?? this.appSpec.contract.name;
|
|
1208
|
-
this.deployTimeParams = deployTimeParams;
|
|
1209
|
-
if (appIdentifier.resolveBy === 'id') {
|
|
1210
|
-
if (appIdentifier.id < 0) {
|
|
1211
|
-
throw new Error(`Attempt to create application client with invalid app id of ${appIdentifier.id}`);
|
|
1212
|
-
}
|
|
1213
|
-
this._appId = appIdentifier.id;
|
|
1214
|
-
}
|
|
1215
|
-
else {
|
|
1216
|
-
this._appId = 0;
|
|
1217
|
-
this._creator = appIdentifier.creatorAddress?.toString();
|
|
1218
|
-
if (appIdentifier.findExistingUsing instanceof Indexer) {
|
|
1219
|
-
this.indexer = appIdentifier.findExistingUsing;
|
|
1220
|
-
}
|
|
1221
|
-
else {
|
|
1222
|
-
if (appIdentifier.findExistingUsing.creator !== this._creator) {
|
|
1223
|
-
throw new Error(`Attempt to create application client with invalid existingDeployments against a different creator (${appIdentifier.findExistingUsing.creator}) instead of expected creator ${this._creator}`);
|
|
1224
|
-
}
|
|
1225
|
-
this.existingDeployments = appIdentifier.findExistingUsing;
|
|
1226
|
-
}
|
|
1227
|
-
}
|
|
1228
|
-
this._appAddress = algosdk.getApplicationAddress(this._appId).toString();
|
|
1229
|
-
this.sender = sender;
|
|
1230
|
-
this.params = params;
|
|
1231
|
-
}
|
|
1232
|
-
/**
|
|
1233
|
-
* @deprecated Use `AppClient.compile()` instead.
|
|
1234
|
-
*
|
|
1235
|
-
* Compiles the approval and clear state programs and sets up the source map.
|
|
1236
|
-
* @param compilation The deploy-time parameters for the compilation
|
|
1237
|
-
* @returns The compiled approval and clear state programs
|
|
1238
|
-
*/
|
|
1239
|
-
async compile(compilation) {
|
|
1240
|
-
const { deployTimeParams, updatable, deletable } = compilation ?? {};
|
|
1241
|
-
const approvalTemplate = buffer.Buffer.from(this.appSpec.source.approval, 'base64').toString('utf-8');
|
|
1242
|
-
const approval = appDeploy.replaceDeployTimeControlParams(appDeploy.performTemplateSubstitution(approvalTemplate, deployTimeParams ?? this.deployTimeParams), {
|
|
1243
|
-
updatable,
|
|
1244
|
-
deletable,
|
|
1245
|
-
});
|
|
1246
|
-
const approvalCompiled = await app.compileTeal(approval, this.algod);
|
|
1247
|
-
this._approvalSourceMap = approvalCompiled?.sourceMap;
|
|
1248
|
-
const clearTemplate = buffer.Buffer.from(this.appSpec.source.clear, 'base64').toString('utf-8');
|
|
1249
|
-
const clear = appDeploy.performTemplateSubstitution(clearTemplate, deployTimeParams ?? this.deployTimeParams);
|
|
1250
|
-
const clearCompiled = await app.compileTeal(clear, this.algod);
|
|
1251
|
-
this._clearSourceMap = clearCompiled?.sourceMap;
|
|
1252
|
-
if (config.Config.debug) {
|
|
1253
|
-
await config.Config.events.emitAsync(types_lifecycleEvents.EventType.AppCompiled, {
|
|
1254
|
-
sources: [
|
|
1255
|
-
{ compiledTeal: approvalCompiled, appName: this._appName, fileName: 'approval' },
|
|
1256
|
-
{ compiledTeal: clearCompiled, appName: this._appName, fileName: 'clear' },
|
|
1257
|
-
],
|
|
1258
|
-
});
|
|
1259
|
-
}
|
|
1260
|
-
return { approvalCompiled, clearCompiled };
|
|
1261
|
-
}
|
|
1262
|
-
/**
|
|
1263
|
-
* Export the current source maps for the app.
|
|
1264
|
-
* @returns The source maps
|
|
1265
|
-
*/
|
|
1266
|
-
exportSourceMaps() {
|
|
1267
|
-
if (!this._approvalSourceMap || !this._clearSourceMap) {
|
|
1268
|
-
throw new Error("Unable to export source maps; they haven't been loaded into this client - you need to call create, update, or deploy first");
|
|
1269
|
-
}
|
|
1270
|
-
return {
|
|
1271
|
-
approvalSourceMap: this._approvalSourceMap,
|
|
1272
|
-
clearSourceMap: this._clearSourceMap,
|
|
1273
|
-
};
|
|
1274
|
-
}
|
|
1275
|
-
/**
|
|
1276
|
-
* Import source maps for the app.
|
|
1277
|
-
* @param sourceMaps The source maps to import
|
|
1278
|
-
*/
|
|
1279
|
-
importSourceMaps(sourceMaps) {
|
|
1280
|
-
this._approvalSourceMap = new SourceMap(sourceMaps.approvalSourceMap);
|
|
1281
|
-
this._clearSourceMap = new SourceMap(sourceMaps.clearSourceMap);
|
|
1282
|
-
}
|
|
1283
|
-
/**
|
|
1284
|
-
* @deprecated Use `deploy` from an `AppFactory` instance instead.
|
|
1285
|
-
*
|
|
1286
|
-
* Idempotently deploy (create, update/delete if changed) an app against the given name via the given creator account, including deploy-time template placeholder substitutions.
|
|
1287
|
-
*
|
|
1288
|
-
* To understand the architecture decisions behind this functionality please see https://github.com/algorandfoundation/algokit-cli/blob/main/docs/architecture-decisions/2023-01-12_smart-contract-deployment.md
|
|
1289
|
-
*
|
|
1290
|
-
* **Note:** if there is a breaking state schema change to an existing app (and `onSchemaBreak` is set to `'replace'`) the existing app will be deleted and re-created.
|
|
1291
|
-
*
|
|
1292
|
-
* **Note:** if there is an update (different TEAL code) to an existing app (and `onUpdate` is set to `'replace'`) the existing app will be deleted and re-created.
|
|
1293
|
-
* @param deploy Deployment details
|
|
1294
|
-
* @returns The metadata and transaction result(s) of the deployment, or just the metadata if it didn't need to issue transactions
|
|
1295
|
-
*/
|
|
1296
|
-
async deploy(deploy) {
|
|
1297
|
-
const { schema, sender: deploySender, version, allowUpdate, allowDelete, sendParams, createArgs, createOnCompleteAction, updateArgs, deleteArgs, ...deployArgs } = deploy ?? {};
|
|
1298
|
-
if (this._appId !== 0) {
|
|
1299
|
-
throw new Error(`Attempt to deploy app which already has an app id of ${this._appId}`);
|
|
1300
|
-
}
|
|
1301
|
-
const sender = deploySender ?? this.sender;
|
|
1302
|
-
if (!sender) {
|
|
1303
|
-
throw new Error('No sender provided, unable to deploy app');
|
|
1304
|
-
}
|
|
1305
|
-
const from = sender ?? this.sender;
|
|
1306
|
-
if (!this._creator) {
|
|
1307
|
-
throw new Error("Attempt to `deploy` a contract without specifying `resolveBy: 'creatorAndName'` in the constructor");
|
|
1308
|
-
}
|
|
1309
|
-
if (this._creator !== transaction.getSenderAddress(from)) {
|
|
1310
|
-
throw new Error(`Attempt to deploy contract with a sender address (${transaction.getSenderAddress(from)}) that differs from the given creator address for this application client: ${this._creator}`);
|
|
1311
|
-
}
|
|
1312
|
-
const approval = buffer.Buffer.from(this.appSpec.source.approval, 'base64').toString('utf-8');
|
|
1313
|
-
const compilation = {
|
|
1314
|
-
deployTimeParams: deployArgs.deployTimeParams,
|
|
1315
|
-
updatable: allowUpdate !== undefined
|
|
1316
|
-
? allowUpdate
|
|
1317
|
-
: getDeployTimeControl(approval, this.appSpec, types_app.UPDATABLE_TEMPLATE_NAME, 'update_application'),
|
|
1318
|
-
deletable: allowDelete !== undefined
|
|
1319
|
-
? allowDelete
|
|
1320
|
-
: getDeployTimeControl(approval, this.appSpec, types_app.DELETABLE_TEMPLATE_NAME, 'delete_application'),
|
|
1321
|
-
};
|
|
1322
|
-
const { approvalCompiled, clearCompiled } = await this.compile(compilation);
|
|
1323
|
-
try {
|
|
1324
|
-
await this.getAppReference();
|
|
1325
|
-
const result = await appDeploy.deployApp({
|
|
1326
|
-
from: sender,
|
|
1327
|
-
approvalProgram: approvalCompiled.compiledBase64ToBytes,
|
|
1328
|
-
clearStateProgram: clearCompiled.compiledBase64ToBytes,
|
|
1329
|
-
metadata: {
|
|
1330
|
-
name: this._appName,
|
|
1331
|
-
version: version ?? '1.0',
|
|
1332
|
-
updatable: compilation.updatable,
|
|
1333
|
-
deletable: compilation.deletable,
|
|
1334
|
-
},
|
|
1335
|
-
schema: {
|
|
1336
|
-
globalByteSlices: this.appSpec.state.global.num_byte_slices,
|
|
1337
|
-
globalInts: this.appSpec.state.global.num_uints,
|
|
1338
|
-
localByteSlices: this.appSpec.state.local.num_byte_slices,
|
|
1339
|
-
localInts: this.appSpec.state.local.num_uints,
|
|
1340
|
-
...schema,
|
|
1341
|
-
},
|
|
1342
|
-
transactionParams: this.params,
|
|
1343
|
-
...(sendParams ?? {}),
|
|
1344
|
-
existingDeployments: this.existingDeployments,
|
|
1345
|
-
createArgs: await this.getCallArgs(createArgs, sender),
|
|
1346
|
-
createOnCompleteAction: createOnCompleteAction,
|
|
1347
|
-
updateArgs: await this.getCallArgs(updateArgs, sender),
|
|
1348
|
-
deleteArgs: await this.getCallArgs(deleteArgs, sender),
|
|
1349
|
-
...deployArgs,
|
|
1350
|
-
}, this.algod, this.indexer);
|
|
1351
|
-
// Nothing needed to happen
|
|
1352
|
-
if (result.operationPerformed === 'nothing') {
|
|
1353
|
-
return result;
|
|
1354
|
-
}
|
|
1355
|
-
if (!this.existingDeployments) {
|
|
1356
|
-
throw new Error('Expected existingDeployments to be present');
|
|
1357
|
-
}
|
|
1358
|
-
const { transaction, confirmation, operationPerformed, ...appMetadata } = result;
|
|
1359
|
-
this.existingDeployments = {
|
|
1360
|
-
creator: this.existingDeployments.creator,
|
|
1361
|
-
apps: { ...this.existingDeployments.apps, [this._appName]: appMetadata },
|
|
1362
|
-
};
|
|
1363
|
-
return { ...result, ...{ compiledApproval: approvalCompiled, compiledClear: clearCompiled } };
|
|
1364
|
-
}
|
|
1365
|
-
catch (e) {
|
|
1366
|
-
throw this.exposeLogicError(e);
|
|
1367
|
-
}
|
|
1368
|
-
}
|
|
1369
|
-
/**
|
|
1370
|
-
* @deprecated Use `create` from an `AppFactory` instance instead.
|
|
1371
|
-
*
|
|
1372
|
-
* Creates a smart contract app, returns the details of the created app.
|
|
1373
|
-
* @param create The parameters to create the app with
|
|
1374
|
-
* @returns The details of the created app, or the transaction to create it if `skipSending` and the compilation result
|
|
1375
|
-
*/
|
|
1376
|
-
async create(create) {
|
|
1377
|
-
const { sender: createSender, note, sendParams, deployTimeParams, updatable, deletable, onCompleteAction, schema, ...args } = create ?? {};
|
|
1378
|
-
if (this._appId !== 0) {
|
|
1379
|
-
throw new Error(`Attempt to create app which already has an app id of ${this._appId}`);
|
|
1380
|
-
}
|
|
1381
|
-
const sender = createSender ?? this.sender;
|
|
1382
|
-
if (!sender) {
|
|
1383
|
-
throw new Error('No sender provided, unable to create app');
|
|
1384
|
-
}
|
|
1385
|
-
const { approvalCompiled, clearCompiled } = await this.compile(create);
|
|
1386
|
-
try {
|
|
1387
|
-
const result = await app.createApp({
|
|
1388
|
-
from: sender,
|
|
1389
|
-
approvalProgram: approvalCompiled.compiledBase64ToBytes,
|
|
1390
|
-
clearStateProgram: clearCompiled.compiledBase64ToBytes,
|
|
1391
|
-
schema: {
|
|
1392
|
-
globalByteSlices: this.appSpec.state.global.num_byte_slices,
|
|
1393
|
-
globalInts: this.appSpec.state.global.num_uints,
|
|
1394
|
-
localByteSlices: this.appSpec.state.local.num_byte_slices,
|
|
1395
|
-
localInts: this.appSpec.state.local.num_uints,
|
|
1396
|
-
...schema,
|
|
1397
|
-
},
|
|
1398
|
-
onCompleteAction,
|
|
1399
|
-
args: await this.getCallArgs(args, sender),
|
|
1400
|
-
note: note,
|
|
1401
|
-
transactionParams: this.params,
|
|
1402
|
-
...(sendParams ?? {}),
|
|
1403
|
-
}, this.algod);
|
|
1404
|
-
if (result.confirmation) {
|
|
1405
|
-
this._appId = result.confirmation.applicationIndex;
|
|
1406
|
-
this._appAddress = getApplicationAddress(this._appId).toString();
|
|
1407
|
-
}
|
|
1408
|
-
return { ...result, ...{ compiledApproval: approvalCompiled, compiledClear: clearCompiled } };
|
|
1409
|
-
}
|
|
1410
|
-
catch (e) {
|
|
1411
|
-
throw await this.exposeLogicError(e);
|
|
1412
|
-
}
|
|
1413
|
-
}
|
|
1414
|
-
/**
|
|
1415
|
-
* @deprecated Use `appClient.send.update` or `appClient.createTransaction.update` from an `AppClient` instance instead.
|
|
1416
|
-
*
|
|
1417
|
-
* Updates the smart contract app.
|
|
1418
|
-
* @param update The parameters to update the app with
|
|
1419
|
-
* @returns The transaction send result and the compilation result
|
|
1420
|
-
*/
|
|
1421
|
-
async update(update) {
|
|
1422
|
-
const { sender: updateSender, note, sendParams, deployTimeParams, updatable, deletable, ...args } = update ?? {};
|
|
1423
|
-
if (this._appId === 0) {
|
|
1424
|
-
throw new Error(`Attempt to update app which doesn't have an app id defined`);
|
|
1425
|
-
}
|
|
1426
|
-
const sender = updateSender ?? this.sender;
|
|
1427
|
-
if (!sender) {
|
|
1428
|
-
throw new Error('No sender provided, unable to create app');
|
|
1429
|
-
}
|
|
1430
|
-
const { approvalCompiled, clearCompiled } = await this.compile(update);
|
|
1431
|
-
try {
|
|
1432
|
-
const result = await app.updateApp({
|
|
1433
|
-
appId: this._appId,
|
|
1434
|
-
from: sender,
|
|
1435
|
-
approvalProgram: approvalCompiled.compiledBase64ToBytes,
|
|
1436
|
-
clearStateProgram: clearCompiled.compiledBase64ToBytes,
|
|
1437
|
-
args: await this.getCallArgs(args, sender),
|
|
1438
|
-
note: note,
|
|
1439
|
-
transactionParams: this.params,
|
|
1440
|
-
...(sendParams ?? {}),
|
|
1441
|
-
}, this.algod);
|
|
1442
|
-
return { ...result, ...{ compiledApproval: approvalCompiled, compiledClear: clearCompiled } };
|
|
1443
|
-
}
|
|
1444
|
-
catch (e) {
|
|
1445
|
-
throw await this.exposeLogicError(e);
|
|
1446
|
-
}
|
|
1447
|
-
}
|
|
1448
|
-
/**
|
|
1449
|
-
* @deprecated Use `appClient.send.call` or `appClient.createTransaction.call` from an `AppClient` instance instead.
|
|
1450
|
-
*
|
|
1451
|
-
* Issues a no_op (normal) call to the app.
|
|
1452
|
-
* @param call The call details.
|
|
1453
|
-
* @returns The result of the call
|
|
1454
|
-
*/
|
|
1455
|
-
async call(call) {
|
|
1456
|
-
if (
|
|
1457
|
-
// ABI call
|
|
1458
|
-
call?.method &&
|
|
1459
|
-
// We aren't skipping the send
|
|
1460
|
-
!call.sendParams?.skipSending &&
|
|
1461
|
-
// There isn't an ATC passed in
|
|
1462
|
-
!call.sendParams?.atc &&
|
|
1463
|
-
// The method is readonly
|
|
1464
|
-
this.appSpec.hints[this.getABIMethodSignature(this.getABIMethod(call.method))].read_only) {
|
|
1465
|
-
const atc = new AtomicTransactionComposer();
|
|
1466
|
-
await this.callOfType({ ...call, sendParams: { ...call.sendParams, atc } }, 'no_op');
|
|
1467
|
-
const result = await atc.simulate(this.algod);
|
|
1468
|
-
if (result.simulateResponse.txnGroups.some((group) => group.failureMessage)) {
|
|
1469
|
-
throw new Error(result.simulateResponse.txnGroups.find((x) => x.failureMessage)?.failureMessage);
|
|
1470
|
-
}
|
|
1471
|
-
const txns = atc.buildGroup();
|
|
1472
|
-
return {
|
|
1473
|
-
transaction: txns[txns.length - 1].txn,
|
|
1474
|
-
confirmation: result.simulateResponse.txnGroups[0].txnResults.at(-1)?.txnResult,
|
|
1475
|
-
confirmations: result.simulateResponse.txnGroups[0].txnResults.map((t) => t.txnResult),
|
|
1476
|
-
transactions: txns.map((t) => t.txn),
|
|
1477
|
-
return: (result.methodResults?.length ?? 0 > 0) ? result.methodResults[result.methodResults.length - 1] : undefined,
|
|
1478
|
-
};
|
|
1479
|
-
}
|
|
1480
|
-
return await this.callOfType(call, 'no_op');
|
|
1481
|
-
}
|
|
1482
|
-
/**
|
|
1483
|
-
* @deprecated Use `appClient.send.optIn` or `appClient.createTransaction.optIn` from an `AppClient` instance instead.
|
|
1484
|
-
*
|
|
1485
|
-
* Issues a opt_in call to the app.
|
|
1486
|
-
* @param call The call details.
|
|
1487
|
-
* @returns The result of the call
|
|
1488
|
-
*/
|
|
1489
|
-
async optIn(call) {
|
|
1490
|
-
return await this.callOfType(call, 'opt_in');
|
|
1491
|
-
}
|
|
1492
|
-
/**
|
|
1493
|
-
* @deprecated Use `appClient.send.closeOut` or `appClient.createTransaction.closeOut` from an `AppClient` instance instead.
|
|
1494
|
-
*
|
|
1495
|
-
* Issues a close_out call to the app.
|
|
1496
|
-
* @param call The call details.
|
|
1497
|
-
* @returns The result of the call
|
|
1498
|
-
*/
|
|
1499
|
-
async closeOut(call) {
|
|
1500
|
-
return await this.callOfType(call, 'close_out');
|
|
1501
|
-
}
|
|
1502
|
-
/**
|
|
1503
|
-
* @deprecated Use `appClient.send.clearState` or `appClient.createTransaction.clearState` from an `AppClient` instance instead.
|
|
1504
|
-
*
|
|
1505
|
-
* Issues a clear_state call to the app.
|
|
1506
|
-
* @param call The call details.
|
|
1507
|
-
* @returns The result of the call
|
|
1508
|
-
*/
|
|
1509
|
-
async clearState(call) {
|
|
1510
|
-
return await this.callOfType(call, 'clear_state');
|
|
1511
|
-
}
|
|
1512
|
-
/**
|
|
1513
|
-
* @deprecated Use `appClient.send.delete` or `appClient.createTransaction.delete` from an `AppClient` instance instead.
|
|
1514
|
-
*
|
|
1515
|
-
* Issues a delete_application call to the app.
|
|
1516
|
-
* @param call The call details.
|
|
1517
|
-
* @returns The result of the call
|
|
1518
|
-
*/
|
|
1519
|
-
async delete(call) {
|
|
1520
|
-
return await this.callOfType(call, 'delete_application');
|
|
1521
|
-
}
|
|
1522
|
-
/**
|
|
1523
|
-
* @deprecated Use `appClient.send.call` or `appClient.createTransaction.call` from an `AppClient` instance instead.
|
|
1524
|
-
*
|
|
1525
|
-
* Issues a call to the app with the given call type.
|
|
1526
|
-
* @param call The call details.
|
|
1527
|
-
* @param callType The call type
|
|
1528
|
-
* @returns The result of the call
|
|
1529
|
-
*/
|
|
1530
|
-
async callOfType(call = {}, callType) {
|
|
1531
|
-
const { sender: callSender, note, sendParams, ...args } = call;
|
|
1532
|
-
const sender = callSender ?? this.sender;
|
|
1533
|
-
if (!sender) {
|
|
1534
|
-
throw new Error('No sender provided, unable to call app');
|
|
1535
|
-
}
|
|
1536
|
-
const appMetadata = await this.getAppReference();
|
|
1537
|
-
if (appMetadata.appId === 0) {
|
|
1538
|
-
throw new Error(`Attempt to call an app that can't be found '${this._appName}' for creator '${this._creator}'.`);
|
|
1539
|
-
}
|
|
1540
|
-
try {
|
|
1541
|
-
return await app.callApp({
|
|
1542
|
-
appId: appMetadata.appId,
|
|
1543
|
-
callType: callType,
|
|
1544
|
-
from: sender,
|
|
1545
|
-
args: await this.getCallArgs(args, sender),
|
|
1546
|
-
note: note,
|
|
1547
|
-
transactionParams: this.params,
|
|
1548
|
-
...(sendParams ?? {}),
|
|
1549
|
-
}, this.algod);
|
|
1550
|
-
}
|
|
1551
|
-
catch (e) {
|
|
1552
|
-
throw this.exposeLogicError(e);
|
|
1553
|
-
}
|
|
1554
|
-
}
|
|
1555
|
-
/**
|
|
1556
|
-
* Funds Algo into the app account for this app.
|
|
1557
|
-
* @param fund The parameters for the funding or the funding amount
|
|
1558
|
-
* @returns The result of the funding
|
|
1559
|
-
*/
|
|
1560
|
-
async fundAppAccount(fund) {
|
|
1561
|
-
const { amount, sender, note, sendParams } = 'microAlgos' in fund ? { amount: fund } : fund;
|
|
1562
|
-
if (!sender && !this.sender) {
|
|
1563
|
-
throw new Error('No sender provided, unable to call app');
|
|
1564
|
-
}
|
|
1565
|
-
const ref = await this.getAppReference();
|
|
1566
|
-
return legacyBridge.legacySendTransactionBridge(this.algod, sender ?? this.sender, sendParams ?? {}, {
|
|
1567
|
-
receiver: ref.appAddress,
|
|
1568
|
-
sender: transaction.getSenderAddress(sender ?? this.sender),
|
|
1569
|
-
amount: amount,
|
|
1570
|
-
note: transaction.encodeTransactionNote(note),
|
|
1571
|
-
}, (c) => c.payment, (c) => c.payment, this.params);
|
|
1572
|
-
}
|
|
1573
|
-
/**
|
|
1574
|
-
* Returns global state for the current app.
|
|
1575
|
-
* @returns The global state
|
|
1576
|
-
*/
|
|
1577
|
-
async getGlobalState() {
|
|
1578
|
-
const appRef = await this.getAppReference();
|
|
1579
|
-
if (appRef.appId === 0) {
|
|
1580
|
-
throw new Error('No app has been created yet, unable to get global state');
|
|
1581
|
-
}
|
|
1582
|
-
return app.getAppGlobalState(appRef.appId, this.algod);
|
|
1583
|
-
}
|
|
1584
|
-
/**
|
|
1585
|
-
* Returns local state for the given account / account address.
|
|
1586
|
-
* @returns The global state
|
|
1587
|
-
*/
|
|
1588
|
-
async getLocalState(account) {
|
|
1589
|
-
const appRef = await this.getAppReference();
|
|
1590
|
-
if (appRef.appId === 0) {
|
|
1591
|
-
throw new Error('No app has been created yet, unable to get global state');
|
|
1592
|
-
}
|
|
1593
|
-
return app.getAppLocalState(appRef.appId, account, this.algod);
|
|
1594
|
-
}
|
|
1595
|
-
/**
|
|
1596
|
-
* Returns the names of all current boxes for the current app.
|
|
1597
|
-
* @returns The names of the boxes
|
|
1598
|
-
*/
|
|
1599
|
-
async getBoxNames() {
|
|
1600
|
-
const appRef = await this.getAppReference();
|
|
1601
|
-
if (appRef.appId === 0) {
|
|
1602
|
-
throw new Error('No app has been created yet, unable to get global state');
|
|
1603
|
-
}
|
|
1604
|
-
return await app.getAppBoxNames(appRef.appId, this.algod);
|
|
1605
|
-
}
|
|
1606
|
-
/**
|
|
1607
|
-
* Returns the value of the given box for the current app.
|
|
1608
|
-
* @param name The name of the box to return either as a string, binary array or `BoxName`
|
|
1609
|
-
* @returns The current box value as a byte array
|
|
1610
|
-
*/
|
|
1611
|
-
async getBoxValue(name) {
|
|
1612
|
-
const appRef = await this.getAppReference();
|
|
1613
|
-
if (appRef.appId === 0) {
|
|
1614
|
-
throw new Error('No app has been created yet, unable to get global state');
|
|
1615
|
-
}
|
|
1616
|
-
return await app.getAppBoxValue(appRef.appId, name, this.algod);
|
|
1617
|
-
}
|
|
1618
|
-
/**
|
|
1619
|
-
* Returns the value of the given box for the current app.
|
|
1620
|
-
* @param name The name of the box to return either as a string, binary array or `BoxName`
|
|
1621
|
-
* @param type
|
|
1622
|
-
* @returns The current box value as a byte array
|
|
1623
|
-
*/
|
|
1624
|
-
async getBoxValueFromABIType(name, type) {
|
|
1625
|
-
const appRef = await this.getAppReference();
|
|
1626
|
-
if (appRef.appId === 0) {
|
|
1627
|
-
throw new Error('No app has been created yet, unable to get global state');
|
|
1628
|
-
}
|
|
1629
|
-
return await app.getAppBoxValueFromABIType({ appId: appRef.appId, boxName: name, type }, this.algod);
|
|
1630
|
-
}
|
|
1631
|
-
/**
|
|
1632
|
-
* Returns the values of all current boxes for the current app.
|
|
1633
|
-
* Note: This will issue multiple HTTP requests (one per box) and it's not an atomic operation so values may be out of sync.
|
|
1634
|
-
* @param filter Optional filter to filter which boxes' values are returned
|
|
1635
|
-
* @returns The (name, value) pair of the boxes with values as raw byte arrays
|
|
1636
|
-
*/
|
|
1637
|
-
async getBoxValues(filter) {
|
|
1638
|
-
const appRef = await this.getAppReference();
|
|
1639
|
-
if (appRef.appId === 0) {
|
|
1640
|
-
throw new Error('No app has been created yet, unable to get global state');
|
|
1641
|
-
}
|
|
1642
|
-
const names = await this.getBoxNames();
|
|
1643
|
-
return await Promise.all(names
|
|
1644
|
-
.filter(filter ?? ((_) => true))
|
|
1645
|
-
.map(async (boxName) => ({ name: boxName, value: await app.getAppBoxValue(appRef.appId, boxName, this.algod) })));
|
|
1646
|
-
}
|
|
1647
|
-
/**
|
|
1648
|
-
* Returns the values of all current boxes for the current app decoded using an ABI Type.
|
|
1649
|
-
* Note: This will issue multiple HTTP requests (one per box) and it's not an atomic operation so values may be out of sync.
|
|
1650
|
-
* @param type The ABI type to decode the values with
|
|
1651
|
-
* @param filter Optional filter to filter which boxes' values are returned
|
|
1652
|
-
* @returns The (name, value) pair of the boxes with values as the ABI Value
|
|
1653
|
-
*/
|
|
1654
|
-
async getBoxValuesFromABIType(type, filter) {
|
|
1655
|
-
const appRef = await this.getAppReference();
|
|
1656
|
-
if (appRef.appId === 0) {
|
|
1657
|
-
throw new Error('No app has been created yet, unable to get global state');
|
|
1658
|
-
}
|
|
1659
|
-
const names = await this.getBoxNames();
|
|
1660
|
-
return await Promise.all(names.filter(filter ?? ((_) => true)).map(async (boxName) => ({
|
|
1661
|
-
name: boxName,
|
|
1662
|
-
value: await app.getAppBoxValueFromABIType({ appId: appRef.appId, boxName, type }, this.algod),
|
|
1663
|
-
})));
|
|
1664
|
-
}
|
|
1665
|
-
/**
|
|
1666
|
-
* @deprecated Use `appClient.params.*` from an `AppClient` instance instead.
|
|
1667
|
-
*
|
|
1668
|
-
* Returns the arguments for an app call for the given ABI method or raw method specification.
|
|
1669
|
-
* @param args The call args specific to this application client
|
|
1670
|
-
* @param sender The sender of this call. Will be used to fetch any default argument values if applicable
|
|
1671
|
-
* @returns The call args ready to pass into an app call
|
|
1672
|
-
*/
|
|
1673
|
-
async getCallArgs(args, sender) {
|
|
1674
|
-
if (!args) {
|
|
1675
|
-
return undefined;
|
|
1676
|
-
}
|
|
1677
|
-
if (args.method) {
|
|
1678
|
-
const abiMethod = this.getABIMethodParams(args.method);
|
|
1679
|
-
if (!abiMethod) {
|
|
1680
|
-
throw new Error(`Attempt to call ABI method ${args.method}, but it wasn't found`);
|
|
1681
|
-
}
|
|
1682
|
-
const methodSignature = this.getABIMethodSignature(abiMethod);
|
|
1683
|
-
return {
|
|
1684
|
-
...args,
|
|
1685
|
-
method: abiMethod,
|
|
1686
|
-
methodArgs: await Promise.all(args.methodArgs.map(async (arg, index) => {
|
|
1687
|
-
if (arg !== undefined)
|
|
1688
|
-
return arg;
|
|
1689
|
-
const argName = abiMethod.args[index].name;
|
|
1690
|
-
const defaultValueStrategy = argName && this.appSpec.hints?.[methodSignature]?.default_arguments?.[argName];
|
|
1691
|
-
if (!defaultValueStrategy)
|
|
1692
|
-
throw new Error(`Argument at position ${index} with the name ${argName} is undefined and does not have a default value strategy`);
|
|
1693
|
-
switch (defaultValueStrategy.source) {
|
|
1694
|
-
case 'constant':
|
|
1695
|
-
return defaultValueStrategy.data;
|
|
1696
|
-
case 'abi-method': {
|
|
1697
|
-
const method = defaultValueStrategy.data;
|
|
1698
|
-
const result = await this.callOfType({
|
|
1699
|
-
method: this.getABIMethodSignature(method),
|
|
1700
|
-
methodArgs: method.args.map(() => undefined),
|
|
1701
|
-
sender,
|
|
1702
|
-
}, 'no_op');
|
|
1703
|
-
return result.return?.returnValue;
|
|
1704
|
-
}
|
|
1705
|
-
case 'local-state':
|
|
1706
|
-
case 'global-state': {
|
|
1707
|
-
const state = defaultValueStrategy.source === 'global-state' ? await this.getGlobalState() : await this.getLocalState(sender);
|
|
1708
|
-
const key = defaultValueStrategy.data;
|
|
1709
|
-
if (key in state) {
|
|
1710
|
-
return state[key].value;
|
|
1711
|
-
}
|
|
1712
|
-
else {
|
|
1713
|
-
throw new Error(`Preparing default value for argument at position ${index} with the name ${argName} resulted in the failure: The key '${key}' could not be found in ${defaultValueStrategy.source}`);
|
|
1714
|
-
}
|
|
1715
|
-
}
|
|
1716
|
-
}
|
|
1717
|
-
})),
|
|
1718
|
-
};
|
|
1719
|
-
}
|
|
1720
|
-
else {
|
|
1721
|
-
return args;
|
|
1722
|
-
}
|
|
1723
|
-
}
|
|
1724
|
-
/**
|
|
1725
|
-
* @deprecated Use `appClient.getABIMethod` instead.
|
|
1726
|
-
*
|
|
1727
|
-
* Returns the ABI Method parameters for the given method name string for the app represented by this application client instance
|
|
1728
|
-
* @param method Either the name of the method or the ABI method spec definition string
|
|
1729
|
-
* @returns The ABI method params for the given method
|
|
1730
|
-
*/
|
|
1731
|
-
getABIMethodParams(method) {
|
|
1732
|
-
if (!method.includes('(')) {
|
|
1733
|
-
const methods = this.appSpec.contract.methods.filter((m) => m.name === method);
|
|
1734
|
-
if (methods.length > 1) {
|
|
1735
|
-
throw new Error(`Received a call to method ${method} in contract ${this._appName}, but this resolved to multiple methods; please pass in an ABI signature instead: ${methods
|
|
1736
|
-
.map(this.getABIMethodSignature)
|
|
1737
|
-
.join(', ')}`);
|
|
1738
|
-
}
|
|
1739
|
-
return methods[0];
|
|
1740
|
-
}
|
|
1741
|
-
return this.appSpec.contract.methods.find((m) => this.getABIMethodSignature(m) === method);
|
|
1742
|
-
}
|
|
1743
|
-
/**
|
|
1744
|
-
* Returns the ABI Method for the given method name string for the app represented by this application client instance
|
|
1745
|
-
* @param method Either the name of the method or the ABI method spec definition string
|
|
1746
|
-
* @returns The ABI method for the given method
|
|
1747
|
-
*/
|
|
1748
|
-
getABIMethod(method) {
|
|
1749
|
-
const methodParams = this.getABIMethodParams(method);
|
|
1750
|
-
return methodParams ? new ABIMethod(methodParams) : undefined;
|
|
1751
|
-
}
|
|
1752
|
-
/**
|
|
1753
|
-
* @deprecated Use `appClient.appId` and `appClient.appAddress` from an `AppClient` instance instead.
|
|
1754
|
-
*
|
|
1755
|
-
* Gets the reference information for the current application instance.
|
|
1756
|
-
* `appId` will be 0 if it can't find an app.
|
|
1757
|
-
* @returns The app reference, or if deployed using the `deploy` method, the app metadata too
|
|
1758
|
-
*/
|
|
1759
|
-
async getAppReference() {
|
|
1760
|
-
if (!this.existingDeployments && this._creator) {
|
|
1761
|
-
this.existingDeployments = await appDeploy.getCreatorAppsByName(this._creator, this.indexer);
|
|
1762
|
-
}
|
|
1763
|
-
if (this.existingDeployments && this._appId === 0) {
|
|
1764
|
-
const app = this.existingDeployments.apps[this._appName];
|
|
1765
|
-
if (!app) {
|
|
1766
|
-
return {
|
|
1767
|
-
appId: 0,
|
|
1768
|
-
appAddress: getApplicationAddress(0).toString(),
|
|
1769
|
-
};
|
|
1770
|
-
}
|
|
1771
|
-
return app;
|
|
1772
|
-
}
|
|
1773
|
-
return {
|
|
1774
|
-
appId: this._appId,
|
|
1775
|
-
appAddress: this._appAddress,
|
|
1776
|
-
};
|
|
1777
|
-
}
|
|
1778
|
-
/**
|
|
1779
|
-
* Takes an error that may include a logic error from a smart contract call and re-exposes the error to include source code information via the source map.
|
|
1780
|
-
* This is automatically used within `ApplicationClient` but if you pass `skipSending: true` e.g. if doing a group transaction
|
|
1781
|
-
* then you can use this in a try/catch block to get better debugging information.
|
|
1782
|
-
* @param e The error to parse
|
|
1783
|
-
* @param isClear Whether or not the code was running the clear state program
|
|
1784
|
-
* @returns The new error, or if there was no logic error or source map then the wrapped error with source details
|
|
1785
|
-
*/
|
|
1786
|
-
exposeLogicError(e, isClear) {
|
|
1787
|
-
if ((!isClear && this._approvalSourceMap == undefined) || (isClear && this._clearSourceMap == undefined))
|
|
1788
|
-
return e;
|
|
1789
|
-
const errorDetails = types_logicError.LogicError.parseLogicError(e);
|
|
1790
|
-
if (errorDetails !== undefined)
|
|
1791
|
-
return new types_logicError.LogicError(errorDetails, buffer.Buffer.from(isClear ? this.appSpec.source.clear : this.appSpec.source.approval, 'base64')
|
|
1792
|
-
.toString()
|
|
1793
|
-
.split('\n'), (pc) => (isClear ? this._clearSourceMap : this._approvalSourceMap)?.getLocationForPc(pc)?.line);
|
|
1794
|
-
else
|
|
1795
|
-
return e;
|
|
1796
|
-
}
|
|
1797
|
-
getABIMethodSignature(method) {
|
|
1798
|
-
return 'getSignature' in method ? method.getSignature() : new ABIMethod(method).getSignature();
|
|
1799
|
-
}
|
|
1800
|
-
}
|
|
55
|
+
* state for a specific deployed instance of an app (with a known app ID). */
|
|
56
|
+
var AppClient = class AppClient {
|
|
57
|
+
_appId;
|
|
58
|
+
_appAddress;
|
|
59
|
+
_appName;
|
|
60
|
+
_appSpec;
|
|
61
|
+
_algorand;
|
|
62
|
+
_defaultSender;
|
|
63
|
+
_defaultSigner;
|
|
64
|
+
_approvalSourceMap;
|
|
65
|
+
_clearSourceMap;
|
|
66
|
+
_localStateMethods;
|
|
67
|
+
_globalStateMethods;
|
|
68
|
+
_boxStateMethods;
|
|
69
|
+
_paramsMethods;
|
|
70
|
+
_createTransactionsMethods;
|
|
71
|
+
_sendMethods;
|
|
72
|
+
_lastCompiled;
|
|
73
|
+
/**
|
|
74
|
+
* Create a new app client.
|
|
75
|
+
* @param params The parameters to create the app client
|
|
76
|
+
* @returns The `AppClient` instance
|
|
77
|
+
* @example
|
|
78
|
+
* ```typescript
|
|
79
|
+
* const appClient = new AppClient({
|
|
80
|
+
* appId: 12345678n,
|
|
81
|
+
* appSpec: appSpec,
|
|
82
|
+
* algorand: AlgorandClient.mainNet(),
|
|
83
|
+
* })
|
|
84
|
+
*/
|
|
85
|
+
constructor(params) {
|
|
86
|
+
this._appId = params.appId;
|
|
87
|
+
this._appAddress = require_address.getApplicationAddress(this._appId);
|
|
88
|
+
this._appSpec = AppClient.normaliseAppSpec(params.appSpec);
|
|
89
|
+
this._appName = params.appName ?? this._appSpec.name;
|
|
90
|
+
this._algorand = params.algorand;
|
|
91
|
+
this._algorand.registerErrorTransformer(this.handleCallErrors);
|
|
92
|
+
this._defaultSender = require_address.getOptionalAddress(params.defaultSender);
|
|
93
|
+
this._defaultSigner = params.defaultSigner;
|
|
94
|
+
this._lastCompiled = {};
|
|
95
|
+
this._approvalSourceMap = params.approvalSourceMap;
|
|
96
|
+
this._clearSourceMap = params.clearSourceMap;
|
|
97
|
+
this._localStateMethods = (address) => this.getStateMethods(() => this.getLocalState(address), () => require_arc56_contract.getLocalABIStorageKeys(this._appSpec), () => require_arc56_contract.getLocalABIStorageMaps(this._appSpec));
|
|
98
|
+
this._globalStateMethods = this.getStateMethods(() => this.getGlobalState(), () => require_arc56_contract.getGlobalABIStorageKeys(this._appSpec), () => require_arc56_contract.getGlobalABIStorageMaps(this._appSpec));
|
|
99
|
+
this._boxStateMethods = this.getBoxMethods();
|
|
100
|
+
this._paramsMethods = {
|
|
101
|
+
...this.getMethodCallParamsMethods(),
|
|
102
|
+
bare: this.getBareParamsMethods()
|
|
103
|
+
};
|
|
104
|
+
this._createTransactionsMethods = {
|
|
105
|
+
...this.getMethodCallCreateTransactionMethods(),
|
|
106
|
+
bare: this.getBareCreateTransactionMethods()
|
|
107
|
+
};
|
|
108
|
+
this._sendMethods = {
|
|
109
|
+
...this.getMethodCallSendMethods(),
|
|
110
|
+
bare: this.getBareSendMethods()
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Clone this app client with different params
|
|
115
|
+
*
|
|
116
|
+
* @param params The params to use for the the cloned app client. Omit a param to keep the original value. Set a param to override the original value. Setting to undefined will clear the original value.
|
|
117
|
+
* @returns A new app client with the altered params
|
|
118
|
+
* @example
|
|
119
|
+
* ```typescript
|
|
120
|
+
* const appClient2 = appClient.clone({ defaultSender: 'NEW_SENDER_ADDRESS' })
|
|
121
|
+
* ```
|
|
122
|
+
*/
|
|
123
|
+
clone(params) {
|
|
124
|
+
return new AppClient({
|
|
125
|
+
appId: this._appId,
|
|
126
|
+
appSpec: this._appSpec,
|
|
127
|
+
algorand: this._algorand,
|
|
128
|
+
appName: this._appName,
|
|
129
|
+
defaultSender: this._defaultSender,
|
|
130
|
+
defaultSigner: this._defaultSigner,
|
|
131
|
+
approvalSourceMap: this._approvalSourceMap,
|
|
132
|
+
clearSourceMap: this._clearSourceMap,
|
|
133
|
+
...params
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Returns a new `AppClient` client, resolving the app by creator address and name
|
|
138
|
+
* using AlgoKit app deployment semantics (i.e. looking for the app creation transaction note).
|
|
139
|
+
* @param params The parameters to create the app client
|
|
140
|
+
* @returns The `AppClient` instance
|
|
141
|
+
* @example
|
|
142
|
+
* ```typescript
|
|
143
|
+
* const appClient = await AppClient.fromCreatorAndName({
|
|
144
|
+
* creatorAddress: 'CREATOR_ADDRESS',
|
|
145
|
+
* name: 'APP_NAME',
|
|
146
|
+
* appSpec: appSpec,
|
|
147
|
+
* algorand: AlgorandClient.mainNet(),
|
|
148
|
+
* })
|
|
149
|
+
*/
|
|
150
|
+
static async fromCreatorAndName(params) {
|
|
151
|
+
const appSpec = AppClient.normaliseAppSpec(params.appSpec);
|
|
152
|
+
const appMetadata = (params.appLookupCache ?? await params.algorand.appDeployer.getCreatorAppsByName(params.creatorAddress, params.ignoreCache)).apps[params.appName ?? appSpec.name];
|
|
153
|
+
if (!appMetadata) throw new Error(`App not found for creator ${params.creatorAddress} and name ${params.appName ?? appSpec.name}`);
|
|
154
|
+
return new AppClient({
|
|
155
|
+
...params,
|
|
156
|
+
algorand: params.algorand,
|
|
157
|
+
appId: appMetadata.appId
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Returns an `AppClient` instance for the current network based on
|
|
162
|
+
* pre-determined network-specific app IDs specified in the ARC-56 app spec.
|
|
163
|
+
*
|
|
164
|
+
* If no IDs are in the app spec or the network isn't recognised, an error is thrown.
|
|
165
|
+
* @param params The parameters to create the app client
|
|
166
|
+
* @returns The `AppClient` instance
|
|
167
|
+
* @example
|
|
168
|
+
* ```typescript
|
|
169
|
+
* const appClient = await AppClient.fromNetwork({
|
|
170
|
+
* appSpec: appSpec,
|
|
171
|
+
* algorand: AlgorandClient.mainNet(),
|
|
172
|
+
* })
|
|
173
|
+
*/
|
|
174
|
+
static async fromNetwork(params) {
|
|
175
|
+
const network = await params.algorand.client.network();
|
|
176
|
+
const appSpec = AppClient.normaliseAppSpec(params.appSpec);
|
|
177
|
+
const networkNames = [network.genesisHash];
|
|
178
|
+
if (network.isLocalNet) networkNames.push("localnet");
|
|
179
|
+
if (network.isTestNet) networkNames.push("testnet");
|
|
180
|
+
if (network.isMainNet) networkNames.push("mainnet");
|
|
181
|
+
const networkIndex = Object.keys(appSpec.networks ?? {}).findIndex((n) => networkNames.includes(n));
|
|
182
|
+
if (networkIndex === -1) throw new Error(`No app ID found for network ${require_util.asJson(networkNames)} in the app spec`);
|
|
183
|
+
const appId = BigInt(appSpec.networks[networkIndex].appID);
|
|
184
|
+
return new AppClient({
|
|
185
|
+
...params,
|
|
186
|
+
appId,
|
|
187
|
+
appSpec
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Takes a string or parsed JSON object that could be ARC-32 or ARC-56 format and
|
|
192
|
+
* normalises it into a parsed ARC-56 contract object.
|
|
193
|
+
* @param spec The spec to normalise
|
|
194
|
+
* @returns The normalised ARC-56 contract object
|
|
195
|
+
* @example
|
|
196
|
+
* ```typescript
|
|
197
|
+
* const arc56AppSpec = AppClient.normaliseAppSpec(appSpec)
|
|
198
|
+
* ```
|
|
199
|
+
*/
|
|
200
|
+
static normaliseAppSpec(spec) {
|
|
201
|
+
const parsedSpec = typeof spec === "string" ? JSON.parse(spec) : spec;
|
|
202
|
+
return "hints" in parsedSpec ? require_app_spec.arc32ToArc56(parsedSpec) : parsedSpec;
|
|
203
|
+
}
|
|
204
|
+
/** The ID of the app instance this client is linked to. */
|
|
205
|
+
get appId() {
|
|
206
|
+
return this._appId;
|
|
207
|
+
}
|
|
208
|
+
/** The app address of the app instance this client is linked to. */
|
|
209
|
+
get appAddress() {
|
|
210
|
+
return this._appAddress;
|
|
211
|
+
}
|
|
212
|
+
/** The name of the app (from the ARC-32 / ARC-56 app spec or override). */
|
|
213
|
+
get appName() {
|
|
214
|
+
return this._appName;
|
|
215
|
+
}
|
|
216
|
+
/** The ARC-56 app spec being used */
|
|
217
|
+
get appSpec() {
|
|
218
|
+
return this._appSpec;
|
|
219
|
+
}
|
|
220
|
+
/** A reference to the underlying `AlgorandClient` this app client is using. */
|
|
221
|
+
get algorand() {
|
|
222
|
+
return this._algorand;
|
|
223
|
+
}
|
|
224
|
+
/** Get parameters to create transactions for the current app.
|
|
225
|
+
*
|
|
226
|
+
* A good mental model for this is that these parameters represent a deferred transaction creation.
|
|
227
|
+
* @example Create a transaction in the future using Algorand Client
|
|
228
|
+
* ```typescript
|
|
229
|
+
* const myMethodCall = appClient.params.call({method: 'my_method', args: [123, 'hello']})
|
|
230
|
+
* // ...
|
|
231
|
+
* await algorand.send.AppMethodCall(myMethodCall)
|
|
232
|
+
* ```
|
|
233
|
+
* @example Define a nested transaction as an ABI argument
|
|
234
|
+
* ```typescript
|
|
235
|
+
* const myMethodCall = appClient.params.call({method: 'my_method', args: [123, 'hello']})
|
|
236
|
+
* await appClient.send.call({method: 'my_method2', args: [myMethodCall]})
|
|
237
|
+
* ```
|
|
238
|
+
*/
|
|
239
|
+
get params() {
|
|
240
|
+
return this._paramsMethods;
|
|
241
|
+
}
|
|
242
|
+
/** Create transactions for the current app */
|
|
243
|
+
get createTransaction() {
|
|
244
|
+
return this._createTransactionsMethods;
|
|
245
|
+
}
|
|
246
|
+
/** Send transactions to the current app */
|
|
247
|
+
get send() {
|
|
248
|
+
return this._sendMethods;
|
|
249
|
+
}
|
|
250
|
+
/** Get state (local, global, box) from the current app */
|
|
251
|
+
get state() {
|
|
252
|
+
return {
|
|
253
|
+
local: this._localStateMethods,
|
|
254
|
+
global: this._globalStateMethods,
|
|
255
|
+
box: this._boxStateMethods
|
|
256
|
+
};
|
|
257
|
+
}
|
|
258
|
+
/**
|
|
259
|
+
* Funds Algo into the app account for this app.
|
|
260
|
+
*
|
|
261
|
+
* An alias for `appClient.send.fundAppAccount(params)`.
|
|
262
|
+
* @param params The parameters for the funding transaction
|
|
263
|
+
* @returns The result of the funding
|
|
264
|
+
* @example
|
|
265
|
+
* ```typescript
|
|
266
|
+
* await appClient.fundAppAccount({ amount: algo(1) })
|
|
267
|
+
* ```
|
|
268
|
+
*/
|
|
269
|
+
async fundAppAccount(params) {
|
|
270
|
+
return this.send.fundAppAccount(params);
|
|
271
|
+
}
|
|
272
|
+
/**
|
|
273
|
+
* Returns raw global state for the current app.
|
|
274
|
+
* @returns The global state
|
|
275
|
+
* @example
|
|
276
|
+
* ```typescript
|
|
277
|
+
* const globalState = await appClient.getGlobalState()
|
|
278
|
+
* ```
|
|
279
|
+
*/
|
|
280
|
+
async getGlobalState() {
|
|
281
|
+
return await this._algorand.app.getGlobalState(this.appId);
|
|
282
|
+
}
|
|
283
|
+
/**
|
|
284
|
+
* Returns raw local state for the given account address.
|
|
285
|
+
* @param address The address of the account to get the local state for
|
|
286
|
+
* @returns The local state
|
|
287
|
+
* @example
|
|
288
|
+
* ```typescript
|
|
289
|
+
* const localState = await appClient.getLocalState('ACCOUNT_ADDRESS')
|
|
290
|
+
* ```
|
|
291
|
+
*/
|
|
292
|
+
async getLocalState(address) {
|
|
293
|
+
return await this._algorand.app.getLocalState(this.appId, require_address.getAddress(address));
|
|
294
|
+
}
|
|
295
|
+
/**
|
|
296
|
+
* Returns the names of all current boxes for the current app.
|
|
297
|
+
* @returns The names of the boxes
|
|
298
|
+
* @example
|
|
299
|
+
* ```typescript
|
|
300
|
+
* const boxNames = await appClient.getBoxNames()
|
|
301
|
+
* ```
|
|
302
|
+
*/
|
|
303
|
+
async getBoxNames() {
|
|
304
|
+
return await this._algorand.app.getBoxNames(this.appId);
|
|
305
|
+
}
|
|
306
|
+
/**
|
|
307
|
+
* Returns the value of the given box for the current app.
|
|
308
|
+
* @param name The identifier of the box to return
|
|
309
|
+
* @returns The current box value as a byte array
|
|
310
|
+
* @example
|
|
311
|
+
* ```typescript
|
|
312
|
+
* const boxValue = await appClient.getBoxValue('boxName')
|
|
313
|
+
* ```
|
|
314
|
+
*/
|
|
315
|
+
async getBoxValue(name) {
|
|
316
|
+
return await this._algorand.app.getBoxValue(this.appId, name);
|
|
317
|
+
}
|
|
318
|
+
/**
|
|
319
|
+
* Returns the value of the given box for the current app.
|
|
320
|
+
* @param name The identifier of the box to return
|
|
321
|
+
* @param type
|
|
322
|
+
* @returns The current box value as a byte array
|
|
323
|
+
* @example
|
|
324
|
+
* ```typescript
|
|
325
|
+
* const boxValue = await appClient.getBoxValueFromABIType('boxName', new ABIUintType(32))
|
|
326
|
+
* ```
|
|
327
|
+
*/
|
|
328
|
+
async getBoxValueFromABIType(name, type) {
|
|
329
|
+
return await this._algorand.app.getBoxValueFromABIType({
|
|
330
|
+
appId: this.appId,
|
|
331
|
+
boxName: name,
|
|
332
|
+
type
|
|
333
|
+
});
|
|
334
|
+
}
|
|
335
|
+
/**
|
|
336
|
+
* Returns the values of all current boxes for the current app.
|
|
337
|
+
* Note: This will issue multiple HTTP requests (one per box) and it's not an atomic operation so values may be out of sync.
|
|
338
|
+
* @param filter Optional filter to filter which boxes' values are returned
|
|
339
|
+
* @returns The (name, value) pair of the boxes with values as raw byte arrays
|
|
340
|
+
* @example
|
|
341
|
+
* ```typescript
|
|
342
|
+
* const boxValues = await appClient.getBoxValues()
|
|
343
|
+
* ```
|
|
344
|
+
*/
|
|
345
|
+
async getBoxValues(filter) {
|
|
346
|
+
const names = (await this.getBoxNames()).filter(filter ?? ((_) => true));
|
|
347
|
+
const values = await this._algorand.app.getBoxValues(this.appId, names.map((name) => name.nameRaw));
|
|
348
|
+
return names.map((name, i) => ({
|
|
349
|
+
name,
|
|
350
|
+
value: values[i]
|
|
351
|
+
}));
|
|
352
|
+
}
|
|
353
|
+
/**
|
|
354
|
+
* Returns the values of all current boxes for the current app decoded using an ABI Type.
|
|
355
|
+
* Note: This will issue multiple HTTP requests (one per box) and it's not an atomic operation so values may be out of sync.
|
|
356
|
+
* @param type The ABI type to decode the values with
|
|
357
|
+
* @param filter Optional filter to filter which boxes' values are returned
|
|
358
|
+
* @returns The (name, value) pair of the boxes with values as the ABI Value
|
|
359
|
+
* @example
|
|
360
|
+
* ```typescript
|
|
361
|
+
* const boxValues = await appClient.getBoxValuesFromABIType(new ABIUintType(32))
|
|
362
|
+
* ```
|
|
363
|
+
*/
|
|
364
|
+
async getBoxValuesFromABIType(type, filter) {
|
|
365
|
+
const names = (await this.getBoxNames()).filter(filter ?? ((_) => true));
|
|
366
|
+
const values = await this._algorand.app.getBoxValuesFromABIType({
|
|
367
|
+
appId: this.appId,
|
|
368
|
+
boxNames: names.map((name) => name.nameRaw),
|
|
369
|
+
type
|
|
370
|
+
});
|
|
371
|
+
return names.map((name, i) => ({
|
|
372
|
+
name,
|
|
373
|
+
value: values[i]
|
|
374
|
+
}));
|
|
375
|
+
}
|
|
376
|
+
/**
|
|
377
|
+
* Takes an error that may include a logic error from a call to the current app and re-exposes the
|
|
378
|
+
* error to include source code information via the source map and ARC-56 spec.
|
|
379
|
+
* @param e The error to parse
|
|
380
|
+
* @param isClearStateProgram Whether or not the code was running the clear state program (defaults to approval program)
|
|
381
|
+
* @returns The new error, or if there was no logic error or source map then the wrapped error with source details
|
|
382
|
+
*/
|
|
383
|
+
async exposeLogicError(e, isClearStateProgram) {
|
|
384
|
+
const pcOffsetMethod = this._appSpec.sourceInfo?.[isClearStateProgram ? "clear" : "approval"]?.pcOffsetMethod;
|
|
385
|
+
let program;
|
|
386
|
+
if (pcOffsetMethod === "cblocks") {
|
|
387
|
+
const appInfo = await this._algorand.app.getById(this.appId);
|
|
388
|
+
program = isClearStateProgram ? appInfo.clearStateProgram : appInfo.approvalProgram;
|
|
389
|
+
}
|
|
390
|
+
return AppClient.exposeLogicError(e, this._appSpec, {
|
|
391
|
+
isClearStateProgram,
|
|
392
|
+
approvalSourceMap: this._approvalSourceMap,
|
|
393
|
+
clearSourceMap: this._clearSourceMap,
|
|
394
|
+
program
|
|
395
|
+
});
|
|
396
|
+
}
|
|
397
|
+
/**
|
|
398
|
+
* Export the current source maps for the app.
|
|
399
|
+
* @returns The source maps
|
|
400
|
+
*/
|
|
401
|
+
exportSourceMaps() {
|
|
402
|
+
if (!this._approvalSourceMap || !this._clearSourceMap) throw new Error("Unable to export source maps; they haven't been loaded into this client - you need to call create, update, or deploy first");
|
|
403
|
+
return {
|
|
404
|
+
approvalSourceMap: this._approvalSourceMap,
|
|
405
|
+
clearSourceMap: this._clearSourceMap
|
|
406
|
+
};
|
|
407
|
+
}
|
|
408
|
+
/**
|
|
409
|
+
* Import source maps for the app.
|
|
410
|
+
* @param sourceMaps The source maps to import
|
|
411
|
+
*/
|
|
412
|
+
importSourceMaps(sourceMaps) {
|
|
413
|
+
this._approvalSourceMap = new require_sourcemap.ProgramSourceMap(sourceMaps.approvalSourceMap);
|
|
414
|
+
this._clearSourceMap = new require_sourcemap.ProgramSourceMap(sourceMaps.clearSourceMap);
|
|
415
|
+
}
|
|
416
|
+
/**
|
|
417
|
+
* Returns the ABI Method spec for the given method string for the app represented by this application client instance
|
|
418
|
+
* @param methodNameOrSignature The method name or method signature to call if an ABI call is being emitted.
|
|
419
|
+
* e.g. `my_method` or `my_method(unit64,string)bytes`
|
|
420
|
+
* @returns A tuple with: [ARC-56 `Method`, algosdk `ABIMethod`]
|
|
421
|
+
*/
|
|
422
|
+
getABIMethod(methodNameOrSignature) {
|
|
423
|
+
return require_abi_method.getABIMethod(methodNameOrSignature, this._appSpec);
|
|
424
|
+
}
|
|
425
|
+
/**
|
|
426
|
+
* Checks for decode errors on the SendAppTransactionResult and maps the return value to the specified type
|
|
427
|
+
* on the ARC-56 method, replacing the `return` property with the decoded type.
|
|
428
|
+
*
|
|
429
|
+
* If the return type is an ARC-56 struct then the struct will be returned.
|
|
430
|
+
*
|
|
431
|
+
* @param result The SendAppTransactionResult to be mapped
|
|
432
|
+
* @param method The method that was called
|
|
433
|
+
* @returns The smart contract response with an updated return value
|
|
434
|
+
*/
|
|
435
|
+
async processMethodCallReturn(result) {
|
|
436
|
+
const resultValue = await result;
|
|
437
|
+
return {
|
|
438
|
+
...resultValue,
|
|
439
|
+
return: resultValue.return?.returnValue
|
|
440
|
+
};
|
|
441
|
+
}
|
|
442
|
+
/**
|
|
443
|
+
* Compiles the approval and clear state programs (if TEAL templates provided),
|
|
444
|
+
* performing any provided deploy-time parameter replacement and stores
|
|
445
|
+
* the source maps.
|
|
446
|
+
*
|
|
447
|
+
* If no TEAL templates provided it will use any byte code provided in the app spec.
|
|
448
|
+
*
|
|
449
|
+
* Will store any generated source maps for later use in debugging.
|
|
450
|
+
* @param compilation Any compilation parameters to use
|
|
451
|
+
* @returns The compiled code and any compilation results (including source maps)
|
|
452
|
+
*/
|
|
453
|
+
async compile(compilation) {
|
|
454
|
+
const result = await AppClient.compile(this._appSpec, this._algorand.app, compilation);
|
|
455
|
+
if (result.compiledApproval) {
|
|
456
|
+
this._approvalSourceMap = result.compiledApproval.sourceMap;
|
|
457
|
+
this._lastCompiled.approval = result.compiledApproval.compiledBase64ToBytes;
|
|
458
|
+
}
|
|
459
|
+
if (result.compiledClear) {
|
|
460
|
+
this._clearSourceMap = result.compiledClear.sourceMap;
|
|
461
|
+
this._lastCompiled.clear = result.compiledClear.compiledBase64ToBytes;
|
|
462
|
+
}
|
|
463
|
+
return result;
|
|
464
|
+
}
|
|
465
|
+
/**
|
|
466
|
+
* Takes an error that may include a logic error from a call to the current app and re-exposes the
|
|
467
|
+
* error to include source code information via the source map and ARC-56 spec.
|
|
468
|
+
* @param e The error to parse
|
|
469
|
+
* @param appSpec The app spec for the app
|
|
470
|
+
* @param details Additional information to inform the error
|
|
471
|
+
* @returns The new error, or if there was no logic error or source map then the wrapped error with source details
|
|
472
|
+
*/
|
|
473
|
+
static exposeLogicError(e, appSpec, details) {
|
|
474
|
+
const { isClearStateProgram, approvalSourceMap, clearSourceMap, program } = details;
|
|
475
|
+
const sourceMap = isClearStateProgram ? clearSourceMap : approvalSourceMap;
|
|
476
|
+
const errorDetails = require_logic_error.LogicError.parseLogicError(e);
|
|
477
|
+
if (errorDetails === void 0 || errorDetails?.pc === void 0) return e;
|
|
478
|
+
/** The PC value to find in the ARC56 SourceInfo */
|
|
479
|
+
let arc56Pc = errorDetails?.pc;
|
|
480
|
+
const programSourceInfo = isClearStateProgram ? appSpec.sourceInfo?.clear : appSpec.sourceInfo?.approval;
|
|
481
|
+
/** The offset to apply to the PC if using the cblocks pc offset method */
|
|
482
|
+
let cblocksOffset = 0;
|
|
483
|
+
if (programSourceInfo?.pcOffsetMethod === "cblocks") {
|
|
484
|
+
if (program === void 0) throw new Error("Program bytes are required to calculate the ARC56 cblocks PC offset");
|
|
485
|
+
cblocksOffset = getConstantBlockOffset(program);
|
|
486
|
+
arc56Pc = errorDetails.pc - cblocksOffset;
|
|
487
|
+
}
|
|
488
|
+
const errorMessage = (programSourceInfo?.sourceInfo.find((s) => s.pc.includes(arc56Pc)))?.errorMessage;
|
|
489
|
+
if (appSpec.source) {
|
|
490
|
+
let getLineForPc = (inputPc) => sourceMap?.getLocationForPc?.(inputPc)?.line;
|
|
491
|
+
if (sourceMap === void 0) getLineForPc = (inputPc) => {
|
|
492
|
+
const teal = programSourceInfo?.sourceInfo.find((s) => s.pc.includes(inputPc - cblocksOffset))?.teal;
|
|
493
|
+
if (teal === void 0) return void 0;
|
|
494
|
+
return teal - 1;
|
|
495
|
+
};
|
|
496
|
+
e = new require_logic_error.LogicError(errorDetails, buffer.Buffer.from(isClearStateProgram ? appSpec.source.clear : appSpec.source.approval, "base64").toString().split("\n"), getLineForPc);
|
|
497
|
+
}
|
|
498
|
+
if (errorMessage) {
|
|
499
|
+
const appId = require_util.asJson(e).match(/(?<=app=)\d+/)?.[0] || "";
|
|
500
|
+
const txId = require_util.asJson(e).match(/(?<=transaction )\S+(?=:)/)?.[0];
|
|
501
|
+
const error = /* @__PURE__ */ new Error(`Runtime error when executing ${appSpec.name} (appId: ${appId}) in transaction ${txId}: ${errorMessage}`);
|
|
502
|
+
error.cause = e;
|
|
503
|
+
return error;
|
|
504
|
+
}
|
|
505
|
+
return e;
|
|
506
|
+
}
|
|
507
|
+
/**
|
|
508
|
+
* Compiles the approval and clear state programs (if TEAL templates provided),
|
|
509
|
+
* performing any provided deploy-time parameter replacement and returns
|
|
510
|
+
* the compiled code and any compilation results (including source maps).
|
|
511
|
+
*
|
|
512
|
+
* If no TEAL templates provided it will use any byte code provided in the app spec.
|
|
513
|
+
*
|
|
514
|
+
* Will store any generated source maps for later use in debugging.
|
|
515
|
+
* @param appSpec The app spec for the app
|
|
516
|
+
* @param appManager The app manager to use for compilation
|
|
517
|
+
* @param compilation Any compilation parameters to use
|
|
518
|
+
* @returns The compiled code and any compilation results (including source maps)
|
|
519
|
+
*/
|
|
520
|
+
static async compile(appSpec, appManager, compilation) {
|
|
521
|
+
const { deployTimeParams, updatable, deletable } = compilation ?? {};
|
|
522
|
+
if (!appSpec.source) {
|
|
523
|
+
if (!appSpec.byteCode?.approval || !appSpec.byteCode?.clear) throw new Error(`Attempt to compile app ${appSpec.name} without source or byteCode`);
|
|
524
|
+
return {
|
|
525
|
+
approvalProgram: buffer.Buffer.from(appSpec.byteCode.approval, "base64"),
|
|
526
|
+
clearStateProgram: buffer.Buffer.from(appSpec.byteCode.clear, "base64")
|
|
527
|
+
};
|
|
528
|
+
}
|
|
529
|
+
const approvalTemplate = buffer.Buffer.from(appSpec.source.approval, "base64").toString("utf-8");
|
|
530
|
+
const compiledApproval = await appManager.compileTealTemplate(approvalTemplate, deployTimeParams, {
|
|
531
|
+
updatable,
|
|
532
|
+
deletable
|
|
533
|
+
});
|
|
534
|
+
const clearTemplate = buffer.Buffer.from(appSpec.source.clear, "base64").toString("utf-8");
|
|
535
|
+
const compiledClear = await appManager.compileTealTemplate(clearTemplate, deployTimeParams);
|
|
536
|
+
if (require_config.Config.debug) await require_config.Config.events.emitAsync(require_lifecycle_events.EventType.AppCompiled, { sources: [{
|
|
537
|
+
compiledTeal: compiledApproval,
|
|
538
|
+
appName: appSpec.name,
|
|
539
|
+
fileName: "approval"
|
|
540
|
+
}, {
|
|
541
|
+
compiledTeal: compiledClear,
|
|
542
|
+
appName: appSpec.name,
|
|
543
|
+
fileName: "clear"
|
|
544
|
+
}] });
|
|
545
|
+
return {
|
|
546
|
+
approvalProgram: compiledApproval.compiledBase64ToBytes,
|
|
547
|
+
compiledApproval,
|
|
548
|
+
clearStateProgram: compiledClear.compiledBase64ToBytes,
|
|
549
|
+
compiledClear
|
|
550
|
+
};
|
|
551
|
+
}
|
|
552
|
+
/**
|
|
553
|
+
* Returns ABI method arguments ready for a method call params object with default values populated
|
|
554
|
+
* and structs replaced with tuples.
|
|
555
|
+
*
|
|
556
|
+
* It does this by replacing any `undefined` values with the equivalent default value from the given ARC-56 app spec.
|
|
557
|
+
* @param methodNameOrSignature The method name or method signature to call if an ABI call is being emitted.
|
|
558
|
+
* e.g. `my_method` or `my_method(unit64,string)bytes`
|
|
559
|
+
* @param args The arguments to the method with `undefined` for any that should be populated with a default value
|
|
560
|
+
*/
|
|
561
|
+
async getABIArgsWithDefaultValues(methodNameOrSignature, args, sender) {
|
|
562
|
+
const m = require_abi_method.getABIMethod(methodNameOrSignature, this._appSpec);
|
|
563
|
+
return await Promise.all(args?.map(async (arg, i) => {
|
|
564
|
+
const methodArg = m.args[i];
|
|
565
|
+
if (!methodArg) throw new Error(`Unexpected arg at position ${i}. ${m.name} only expects ${m.args.length} args`);
|
|
566
|
+
if (require_abi_method.argTypeIsTransaction(methodArg.type)) return arg;
|
|
567
|
+
if (arg !== void 0) return arg;
|
|
568
|
+
const defaultValue = methodArg.defaultValue;
|
|
569
|
+
if (defaultValue) switch (defaultValue.source) {
|
|
570
|
+
case "literal": {
|
|
571
|
+
const bytes = buffer.Buffer.from(defaultValue.data, "base64");
|
|
572
|
+
return require_abi_method.getABIDecodedValue(defaultValue.type ?? methodArg.type, bytes);
|
|
573
|
+
}
|
|
574
|
+
case "method": {
|
|
575
|
+
const method = this.getABIMethod(defaultValue.data);
|
|
576
|
+
const result = await this.send.call({
|
|
577
|
+
method: defaultValue.data,
|
|
578
|
+
args: method.args.map(() => void 0),
|
|
579
|
+
sender
|
|
580
|
+
});
|
|
581
|
+
if (result.return === void 0) throw new Error("Default value method call did not return a value");
|
|
582
|
+
return result.return;
|
|
583
|
+
}
|
|
584
|
+
case "local":
|
|
585
|
+
case "global":
|
|
586
|
+
case "box": return await this.getDefaultValueFromStorage({
|
|
587
|
+
data: defaultValue.data,
|
|
588
|
+
source: defaultValue.source
|
|
589
|
+
}, methodArg.name ?? `arg${i + 1}`, sender);
|
|
590
|
+
}
|
|
591
|
+
}) ?? []);
|
|
592
|
+
}
|
|
593
|
+
async getDefaultValueFromStorage(defaultValue, argName, sender) {
|
|
594
|
+
const keys = defaultValue.source === "box" ? require_arc56_contract.getBoxABIStorageKeys(this.appSpec) : defaultValue.source === "global" ? require_arc56_contract.getGlobalABIStorageKeys(this.appSpec) : require_arc56_contract.getLocalABIStorageKeys(this.appSpec);
|
|
595
|
+
const key = Object.values(keys).find((s) => s.key === defaultValue.data);
|
|
596
|
+
if (!key) throw new Error(`Unable to find default value for argument '${argName}': The storage key (base64: '${defaultValue.data}') is not defined in the contract's ${defaultValue.source} storage schema`);
|
|
597
|
+
if (defaultValue.source === "box") {
|
|
598
|
+
const value$1 = await this.getBoxValue(buffer.Buffer.from(defaultValue.data, "base64"));
|
|
599
|
+
return require_abi_method.getABIDecodedValue(key.valueType, value$1);
|
|
600
|
+
}
|
|
601
|
+
const state = defaultValue.source === "global" ? await this.getGlobalState() : await this.getLocalState(sender);
|
|
602
|
+
const value = Object.values(state).find((s) => s.keyBase64 === defaultValue.data);
|
|
603
|
+
if (!value) throw new Error(`Unable to find default value for argument '${argName}': No value exists in ${defaultValue.source} storage for key (base64: '${defaultValue.data}')`);
|
|
604
|
+
return "valueRaw" in value ? require_abi_method.getABIDecodedValue(key.valueType, value.valueRaw) : value.value;
|
|
605
|
+
}
|
|
606
|
+
getBareParamsMethods() {
|
|
607
|
+
return {
|
|
608
|
+
update: async (params) => {
|
|
609
|
+
return this.getBareParams({
|
|
610
|
+
...params,
|
|
611
|
+
...await this.compile(params)
|
|
612
|
+
}, require_app_call.OnApplicationComplete.UpdateApplication);
|
|
613
|
+
},
|
|
614
|
+
optIn: (params) => {
|
|
615
|
+
return this.getBareParams(params, require_app_call.OnApplicationComplete.OptIn);
|
|
616
|
+
},
|
|
617
|
+
delete: (params) => {
|
|
618
|
+
return this.getBareParams(params, require_app_call.OnApplicationComplete.DeleteApplication);
|
|
619
|
+
},
|
|
620
|
+
clearState: (params) => {
|
|
621
|
+
return this.getBareParams(params, require_app_call.OnApplicationComplete.ClearState);
|
|
622
|
+
},
|
|
623
|
+
closeOut: (params) => {
|
|
624
|
+
return this.getBareParams(params, require_app_call.OnApplicationComplete.CloseOut);
|
|
625
|
+
},
|
|
626
|
+
call: (params) => {
|
|
627
|
+
return this.getBareParams(params, params?.onComplete ?? require_app_call.OnApplicationComplete.NoOp);
|
|
628
|
+
}
|
|
629
|
+
};
|
|
630
|
+
}
|
|
631
|
+
getBareCreateTransactionMethods() {
|
|
632
|
+
return {
|
|
633
|
+
update: async (params) => {
|
|
634
|
+
return this._algorand.createTransaction.appUpdate(await this.params.bare.update(params));
|
|
635
|
+
},
|
|
636
|
+
optIn: (params) => {
|
|
637
|
+
return this._algorand.createTransaction.appCall(this.params.bare.optIn(params));
|
|
638
|
+
},
|
|
639
|
+
delete: (params) => {
|
|
640
|
+
return this._algorand.createTransaction.appDelete(this.params.bare.delete(params));
|
|
641
|
+
},
|
|
642
|
+
clearState: (params) => {
|
|
643
|
+
return this._algorand.createTransaction.appCall(this.params.bare.clearState(params));
|
|
644
|
+
},
|
|
645
|
+
closeOut: (params) => {
|
|
646
|
+
return this._algorand.createTransaction.appCall(this.params.bare.closeOut(params));
|
|
647
|
+
},
|
|
648
|
+
call: (params) => {
|
|
649
|
+
return this._algorand.createTransaction.appCall(this.params.bare.call(params));
|
|
650
|
+
}
|
|
651
|
+
};
|
|
652
|
+
}
|
|
653
|
+
getBareSendMethods() {
|
|
654
|
+
return {
|
|
655
|
+
update: async (params) => {
|
|
656
|
+
const compiled = await this.compile(params);
|
|
657
|
+
return {
|
|
658
|
+
...await this._algorand.send.appUpdate(await this.params.bare.update(params)),
|
|
659
|
+
...compiled
|
|
660
|
+
};
|
|
661
|
+
},
|
|
662
|
+
optIn: (params) => {
|
|
663
|
+
return this._algorand.send.appCall(this.params.bare.optIn(params));
|
|
664
|
+
},
|
|
665
|
+
delete: (params) => {
|
|
666
|
+
return this._algorand.send.appDelete(this.params.bare.delete(params));
|
|
667
|
+
},
|
|
668
|
+
clearState: (params) => {
|
|
669
|
+
return this._algorand.send.appCall(this.params.bare.clearState(params));
|
|
670
|
+
},
|
|
671
|
+
closeOut: (params) => {
|
|
672
|
+
return this._algorand.send.appCall(this.params.bare.closeOut(params));
|
|
673
|
+
},
|
|
674
|
+
call: (params) => {
|
|
675
|
+
return this._algorand.send.appCall(this.params.bare.call(params));
|
|
676
|
+
}
|
|
677
|
+
};
|
|
678
|
+
}
|
|
679
|
+
getMethodCallParamsMethods() {
|
|
680
|
+
return {
|
|
681
|
+
fundAppAccount: (params) => {
|
|
682
|
+
return {
|
|
683
|
+
...params,
|
|
684
|
+
sender: this.getSender(params.sender),
|
|
685
|
+
signer: this.getSigner(params.sender, params.signer),
|
|
686
|
+
receiver: this.appAddress
|
|
687
|
+
};
|
|
688
|
+
},
|
|
689
|
+
update: async (params) => {
|
|
690
|
+
return await this.getABIParams({
|
|
691
|
+
...params,
|
|
692
|
+
...await this.compile(params)
|
|
693
|
+
}, require_app_call.OnApplicationComplete.UpdateApplication);
|
|
694
|
+
},
|
|
695
|
+
optIn: async (params) => {
|
|
696
|
+
return await this.getABIParams(params, require_app_call.OnApplicationComplete.OptIn);
|
|
697
|
+
},
|
|
698
|
+
delete: async (params) => {
|
|
699
|
+
return await this.getABIParams(params, require_app_call.OnApplicationComplete.DeleteApplication);
|
|
700
|
+
},
|
|
701
|
+
closeOut: async (params) => {
|
|
702
|
+
return await this.getABIParams(params, require_app_call.OnApplicationComplete.CloseOut);
|
|
703
|
+
},
|
|
704
|
+
call: async (params) => {
|
|
705
|
+
return await this.getABIParams(params, params.onComplete ?? require_app_call.OnApplicationComplete.NoOp);
|
|
706
|
+
}
|
|
707
|
+
};
|
|
708
|
+
}
|
|
709
|
+
getMethodCallSendMethods() {
|
|
710
|
+
return {
|
|
711
|
+
fundAppAccount: (params) => {
|
|
712
|
+
return this._algorand.send.payment(this.params.fundAppAccount(params));
|
|
713
|
+
},
|
|
714
|
+
update: async (params) => {
|
|
715
|
+
const compiled = await this.compile(params);
|
|
716
|
+
return {
|
|
717
|
+
...await this.processMethodCallReturn(this._algorand.send.appUpdateMethodCall(await this.params.update({ ...params }))),
|
|
718
|
+
...compiled
|
|
719
|
+
};
|
|
720
|
+
},
|
|
721
|
+
optIn: async (params) => {
|
|
722
|
+
return this.processMethodCallReturn(this._algorand.send.appCallMethodCall(await this.params.optIn(params)));
|
|
723
|
+
},
|
|
724
|
+
delete: async (params) => {
|
|
725
|
+
return this.processMethodCallReturn(this._algorand.send.appDeleteMethodCall(await this.params.delete(params)));
|
|
726
|
+
},
|
|
727
|
+
closeOut: async (params) => {
|
|
728
|
+
return this.processMethodCallReturn(this._algorand.send.appCallMethodCall(await this.params.closeOut(params)));
|
|
729
|
+
},
|
|
730
|
+
call: async (params) => {
|
|
731
|
+
if ((params.onComplete === require_app_call.OnApplicationComplete.NoOp || !params.onComplete) && require_abi_method.getABIMethod(params.method, this._appSpec).readonly) {
|
|
732
|
+
const readonlyParams = { ...params };
|
|
733
|
+
if (params.coverAppCallInnerTransactionFees && params.maxFee) {
|
|
734
|
+
readonlyParams.staticFee = params.maxFee;
|
|
735
|
+
readonlyParams.extraFee = void 0;
|
|
736
|
+
}
|
|
737
|
+
try {
|
|
738
|
+
const result = await this._algorand.newGroup().addAppCallMethodCall(await this.params.call(readonlyParams)).simulate({
|
|
739
|
+
allowUnnamedResources: params.populateAppCallResources ?? true,
|
|
740
|
+
skipSignatures: true,
|
|
741
|
+
extraOpcodeBudget: MAX_SIMULATE_OPCODE_BUDGET
|
|
742
|
+
});
|
|
743
|
+
return this.processMethodCallReturn({
|
|
744
|
+
...result,
|
|
745
|
+
transaction: result.transactions.at(-1),
|
|
746
|
+
confirmation: result.confirmations.at(-1),
|
|
747
|
+
return: result.returns && result.returns.length > 0 ? result.returns.at(-1) : void 0
|
|
748
|
+
});
|
|
749
|
+
} catch (e) {
|
|
750
|
+
const error = e;
|
|
751
|
+
if (params.coverAppCallInnerTransactionFees && error && error.message && error.message.match(/fee too small/)) throw Error(`Fees were too small. You may need to increase the transaction maxFee.`);
|
|
752
|
+
throw e;
|
|
753
|
+
}
|
|
754
|
+
}
|
|
755
|
+
return this.processMethodCallReturn(this._algorand.send.appCallMethodCall(await this.params.call(params)));
|
|
756
|
+
}
|
|
757
|
+
};
|
|
758
|
+
}
|
|
759
|
+
getMethodCallCreateTransactionMethods() {
|
|
760
|
+
return {
|
|
761
|
+
fundAppAccount: (params) => {
|
|
762
|
+
return this._algorand.createTransaction.payment(this.params.fundAppAccount(params));
|
|
763
|
+
},
|
|
764
|
+
update: async (params) => {
|
|
765
|
+
return this._algorand.createTransaction.appUpdateMethodCall(await this.params.update(params));
|
|
766
|
+
},
|
|
767
|
+
optIn: async (params) => {
|
|
768
|
+
return this._algorand.createTransaction.appCallMethodCall(await this.params.optIn(params));
|
|
769
|
+
},
|
|
770
|
+
delete: async (params) => {
|
|
771
|
+
return this._algorand.createTransaction.appDeleteMethodCall(await this.params.delete(params));
|
|
772
|
+
},
|
|
773
|
+
closeOut: async (params) => {
|
|
774
|
+
return this._algorand.createTransaction.appCallMethodCall(await this.params.closeOut(params));
|
|
775
|
+
},
|
|
776
|
+
call: async (params) => {
|
|
777
|
+
return this._algorand.createTransaction.appCallMethodCall(await this.params.call(params));
|
|
778
|
+
}
|
|
779
|
+
};
|
|
780
|
+
}
|
|
781
|
+
/** Returns the sender for a call, using the provided sender or using the `defaultSender`
|
|
782
|
+
* if none provided and throws an error if neither provided */
|
|
783
|
+
getSender(sender) {
|
|
784
|
+
if (!sender && !this._defaultSender) throw new Error(`No sender provided and no default sender present in app client for call to app ${this._appName}`);
|
|
785
|
+
return require_address.getAddress(sender ?? this._defaultSender);
|
|
786
|
+
}
|
|
787
|
+
/** Returns the signer for a call, using the provided signer or the `defaultSigner`
|
|
788
|
+
* if no signer was provided and the sender resolves to the default sender, the call will use default signer
|
|
789
|
+
* or `undefined` otherwise (so the signer is resolved from `AlgorandClient`) */
|
|
790
|
+
getSigner(sender, signer) {
|
|
791
|
+
return signer ?? (!sender || sender === this._defaultSender ? this._defaultSigner : void 0);
|
|
792
|
+
}
|
|
793
|
+
getBareParams(params, onComplete) {
|
|
794
|
+
return {
|
|
795
|
+
...params,
|
|
796
|
+
appId: this._appId,
|
|
797
|
+
sender: this.getSender(params?.sender),
|
|
798
|
+
signer: this.getSigner(params?.sender, params?.signer),
|
|
799
|
+
onComplete
|
|
800
|
+
};
|
|
801
|
+
}
|
|
802
|
+
async getABIParams(params, onComplete) {
|
|
803
|
+
const sender = this.getSender(params.sender);
|
|
804
|
+
const method = require_abi_method.getABIMethod(params.method, this._appSpec);
|
|
805
|
+
const args = await this.getABIArgsWithDefaultValues(params.method, params.args, sender);
|
|
806
|
+
return {
|
|
807
|
+
...params,
|
|
808
|
+
appId: this._appId,
|
|
809
|
+
sender,
|
|
810
|
+
signer: this.getSigner(params.sender, params.signer),
|
|
811
|
+
method,
|
|
812
|
+
onComplete,
|
|
813
|
+
args
|
|
814
|
+
};
|
|
815
|
+
}
|
|
816
|
+
/** Make the given call and catch any errors, augmenting with debugging information before re-throwing. */
|
|
817
|
+
handleCallErrors = async (e) => {
|
|
818
|
+
if (this.appId === 0n) {
|
|
819
|
+
if (e.sentTransactions === void 0) return e;
|
|
820
|
+
const txn = e.sentTransactions.find((t) => e.message.includes(t.txId()));
|
|
821
|
+
const programsDefinedAndEqual = (a, b) => {
|
|
822
|
+
if (a === void 0 || b === void 0) return false;
|
|
823
|
+
if (a.length !== b.length) return false;
|
|
824
|
+
for (let i = 0; i < a.length; i++) if (a[i] !== b[i]) return false;
|
|
825
|
+
return true;
|
|
826
|
+
};
|
|
827
|
+
if (!programsDefinedAndEqual(txn?.appCall?.clearStateProgram, this._lastCompiled.clear) || !programsDefinedAndEqual(txn?.appCall?.approvalProgram, this._lastCompiled?.approval)) return e;
|
|
828
|
+
} else {
|
|
829
|
+
const appIdString = `app=${this._appId.toString()}`;
|
|
830
|
+
if (!e.message.includes(appIdString)) return e;
|
|
831
|
+
}
|
|
832
|
+
const logicError = await this.exposeLogicError(e);
|
|
833
|
+
if (logicError instanceof require_logic_error.LogicError) {
|
|
834
|
+
let currentLine = logicError.teal_line - logicError.lines - 1;
|
|
835
|
+
const stackWithLines = logicError.stack?.split("\n").map((line) => `${currentLine += 1}: ${line}`).join("\n");
|
|
836
|
+
require_config.Config.logger.error(`${logicError.message}\n\n${stackWithLines}`);
|
|
837
|
+
}
|
|
838
|
+
return logicError;
|
|
839
|
+
};
|
|
840
|
+
getBoxMethods() {
|
|
841
|
+
const that = this;
|
|
842
|
+
const stateMethods = {
|
|
843
|
+
getAll: async () => {
|
|
844
|
+
return Object.fromEntries(await Promise.all(Object.keys(that._appSpec.state.keys.box).map(async (key) => [key, await stateMethods.getValue(key)])));
|
|
845
|
+
},
|
|
846
|
+
getValue: async (name) => {
|
|
847
|
+
const metadata = require_arc56_contract.getBoxABIStorageKey(that._appSpec, name);
|
|
848
|
+
const value = await that.getBoxValue(buffer.Buffer.from(metadata.key, "base64"));
|
|
849
|
+
return require_abi_method.getABIDecodedValue(metadata.valueType, value);
|
|
850
|
+
},
|
|
851
|
+
getMapValue: async (mapName, key) => {
|
|
852
|
+
const metadata = require_arc56_contract.getBoxABIStorageMap(that._appSpec, mapName);
|
|
853
|
+
const prefix = buffer.Buffer.from(metadata.prefix ?? "", "base64");
|
|
854
|
+
const encodedKey = buffer.Buffer.concat([prefix, require_abi_method.getABIEncodedValue(metadata.keyType, key)]);
|
|
855
|
+
const base64Key = buffer.Buffer.from(encodedKey).toString("base64");
|
|
856
|
+
const value = await that.getBoxValue(buffer.Buffer.from(base64Key, "base64"));
|
|
857
|
+
return require_abi_method.getABIDecodedValue(metadata.valueType, value);
|
|
858
|
+
},
|
|
859
|
+
getMap: async (mapName) => {
|
|
860
|
+
const metadata = require_arc56_contract.getBoxABIStorageMap(that._appSpec, mapName);
|
|
861
|
+
const prefix = buffer.Buffer.from(metadata.prefix ?? "", "base64");
|
|
862
|
+
const boxNames = await that.getBoxNames();
|
|
863
|
+
return new Map(await Promise.all(boxNames.filter((b) => require_util.binaryStartsWith(b.nameRaw, prefix)).map(async (b) => {
|
|
864
|
+
return [require_abi_method.getABIDecodedValue(metadata.keyType, b.nameRaw.slice(prefix.length)), require_abi_method.getABIDecodedValue(metadata.valueType, await that.getBoxValue(b.nameRaw))];
|
|
865
|
+
})));
|
|
866
|
+
}
|
|
867
|
+
};
|
|
868
|
+
return stateMethods;
|
|
869
|
+
}
|
|
870
|
+
getStateMethods(stateGetter, keyGetter, mapGetter) {
|
|
871
|
+
const stateMethods = {
|
|
872
|
+
getAll: async () => {
|
|
873
|
+
const appState = await stateGetter();
|
|
874
|
+
return Object.fromEntries(await Promise.all(Object.keys(keyGetter()).map(async (key) => [key, await stateMethods.getValue(key, appState)])));
|
|
875
|
+
},
|
|
876
|
+
getValue: async (name, appState) => {
|
|
877
|
+
const state = Object.values(appState ?? await stateGetter());
|
|
878
|
+
const metadata = keyGetter()[name];
|
|
879
|
+
if (metadata === void 0) throw new Error(`Attempted to get state value ${name}, but it does not exist`);
|
|
880
|
+
const value = state.find((s) => s.keyBase64 === metadata.key);
|
|
881
|
+
if (value && "valueRaw" in value) return require_abi_method.getABIDecodedValue(metadata.valueType, value.valueRaw);
|
|
882
|
+
return value?.value;
|
|
883
|
+
},
|
|
884
|
+
getMapValue: async (mapName, key, appState) => {
|
|
885
|
+
const state = Object.values(appState ?? await stateGetter());
|
|
886
|
+
const metadata = mapGetter()[mapName];
|
|
887
|
+
const prefix = buffer.Buffer.from(metadata.prefix ?? "", "base64");
|
|
888
|
+
const encodedKey = buffer.Buffer.concat([prefix, require_abi_method.getABIEncodedValue(metadata.keyType, key)]);
|
|
889
|
+
const base64Key = buffer.Buffer.from(encodedKey).toString("base64");
|
|
890
|
+
const value = state.find((s) => s.keyBase64 === base64Key);
|
|
891
|
+
if (value && "valueRaw" in value) return require_abi_method.getABIDecodedValue(metadata.valueType, value.valueRaw);
|
|
892
|
+
return value?.value;
|
|
893
|
+
},
|
|
894
|
+
getMap: async (mapName) => {
|
|
895
|
+
const state = Object.values(await stateGetter());
|
|
896
|
+
const metadata = mapGetter()[mapName];
|
|
897
|
+
const prefix = buffer.Buffer.from(metadata.prefix ?? "", "base64");
|
|
898
|
+
return new Map(state.filter((s) => require_util.binaryStartsWith(s.keyRaw, prefix)).map((s) => {
|
|
899
|
+
const key = s.keyRaw.slice(prefix.length);
|
|
900
|
+
return [require_abi_method.getABIDecodedValue(metadata.keyType, key), "valueRaw" in s ? require_abi_method.getABIDecodedValue(metadata.valueType, s.valueRaw) : s.value];
|
|
901
|
+
}));
|
|
902
|
+
}
|
|
903
|
+
};
|
|
904
|
+
return stateMethods;
|
|
905
|
+
}
|
|
906
|
+
};
|
|
1801
907
|
|
|
908
|
+
//#endregion
|
|
1802
909
|
exports.AppClient = AppClient;
|
|
1803
|
-
|
|
1804
|
-
//# sourceMappingURL=app-client.js.map
|
|
910
|
+
//# sourceMappingURL=app-client.js.map
|