@pezkuwi/api-contract 16.5.6 → 16.5.8
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/build/Abi/index.d.ts +31 -0
- package/build/Abi/index.js +359 -0
- package/build/Abi/toLatestCompatible.d.ts +15 -0
- package/build/Abi/toLatestCompatible.js +30 -0
- package/build/Abi/toV1.d.ts +3 -0
- package/build/Abi/toV1.js +21 -0
- package/build/Abi/toV2.d.ts +3 -0
- package/build/Abi/toV2.js +27 -0
- package/build/Abi/toV3.d.ts +3 -0
- package/build/Abi/toV3.js +10 -0
- package/build/Abi/toV4.d.ts +3 -0
- package/build/Abi/toV4.js +10 -0
- package/build/LICENSE +201 -0
- package/build/README.md +3 -0
- package/build/augment.d.ts +1 -0
- package/build/augment.js +1 -0
- package/build/base/Base.d.ts +13 -0
- package/build/base/Base.js +40 -0
- package/build/base/Blueprint.d.ts +24 -0
- package/build/base/Blueprint.js +51 -0
- package/build/base/Code.d.ts +22 -0
- package/build/base/Code.js +74 -0
- package/build/base/Contract.d.ts +25 -0
- package/build/base/Contract.js +127 -0
- package/build/base/index.d.ts +3 -0
- package/build/base/index.js +3 -0
- package/build/base/mock.d.ts +3 -0
- package/build/base/mock.js +38 -0
- package/build/base/types.d.ts +25 -0
- package/build/base/types.js +1 -0
- package/build/base/util.d.ts +16 -0
- package/build/base/util.js +33 -0
- package/build/bundle-pezkuwi-api-contract.js +1238 -0
- package/build/bundle.d.ts +4 -0
- package/build/bundle.js +4 -0
- package/build/cjs/Abi/index.d.ts +31 -0
- package/build/cjs/Abi/index.js +363 -0
- package/build/cjs/Abi/toLatestCompatible.d.ts +15 -0
- package/build/cjs/Abi/toLatestCompatible.js +36 -0
- package/build/cjs/Abi/toV1.d.ts +3 -0
- package/build/cjs/Abi/toV1.js +24 -0
- package/build/cjs/Abi/toV2.d.ts +3 -0
- package/build/cjs/Abi/toV2.js +30 -0
- package/build/cjs/Abi/toV3.d.ts +3 -0
- package/build/cjs/Abi/toV3.js +13 -0
- package/build/cjs/Abi/toV4.d.ts +3 -0
- package/build/cjs/Abi/toV4.js +13 -0
- package/build/cjs/augment.d.ts +1 -0
- package/build/cjs/augment.js +3 -0
- package/build/cjs/base/Base.d.ts +13 -0
- package/build/cjs/base/Base.js +44 -0
- package/build/cjs/base/Blueprint.d.ts +24 -0
- package/build/cjs/base/Blueprint.js +57 -0
- package/build/cjs/base/Code.d.ts +22 -0
- package/build/cjs/base/Code.js +80 -0
- package/build/cjs/base/Contract.d.ts +25 -0
- package/build/cjs/base/Contract.js +133 -0
- package/build/cjs/base/index.d.ts +3 -0
- package/build/cjs/base/index.js +14 -0
- package/build/cjs/base/mock.d.ts +3 -0
- package/build/cjs/base/mock.js +41 -0
- package/build/cjs/base/types.d.ts +25 -0
- package/build/cjs/base/types.js +2 -0
- package/build/cjs/base/util.d.ts +16 -0
- package/build/cjs/base/util.js +42 -0
- package/build/cjs/bundle.d.ts +4 -0
- package/build/cjs/bundle.js +10 -0
- package/build/cjs/index.d.ts +2 -0
- package/build/cjs/index.js +5 -0
- package/build/cjs/package.json +3 -0
- package/build/cjs/packageDetect.d.ts +1 -0
- package/build/cjs/packageDetect.js +7 -0
- package/build/cjs/packageInfo.d.ts +6 -0
- package/build/cjs/packageInfo.js +4 -0
- package/build/cjs/promise/index.d.ts +13 -0
- package/build/cjs/promise/index.js +23 -0
- package/build/cjs/promise/types.d.ts +3 -0
- package/build/cjs/promise/types.js +2 -0
- package/build/cjs/rx/index.d.ts +13 -0
- package/build/cjs/rx/index.js +23 -0
- package/build/cjs/rx/types.d.ts +3 -0
- package/build/cjs/rx/types.js +2 -0
- package/build/cjs/types.d.ts +79 -0
- package/build/cjs/types.js +2 -0
- package/build/cjs/util.d.ts +5 -0
- package/build/cjs/util.js +13 -0
- package/build/index.d.ts +2 -0
- package/build/index.js +2 -0
- package/build/package.json +408 -0
- package/build/packageDetect.d.ts +1 -0
- package/build/packageDetect.js +5 -0
- package/build/packageInfo.d.ts +6 -0
- package/build/packageInfo.js +1 -0
- package/build/promise/index.d.ts +13 -0
- package/build/promise/index.js +17 -0
- package/build/promise/types.d.ts +3 -0
- package/build/promise/types.js +1 -0
- package/build/rx/index.d.ts +13 -0
- package/build/rx/index.js +17 -0
- package/build/rx/types.d.ts +3 -0
- package/build/rx/types.js +1 -0
- package/build/types.d.ts +79 -0
- package/build/types.js +1 -0
- package/build/util.d.ts +5 -0
- package/build/util.js +10 -0
- package/build-deno/Abi/index.ts +475 -0
- package/build-deno/Abi/toLatestCompatible.ts +47 -0
- package/build-deno/Abi/toV1.ts +33 -0
- package/build-deno/Abi/toV2.ts +56 -0
- package/build-deno/Abi/toV3.ts +16 -0
- package/build-deno/Abi/toV4.ts +19 -0
- package/build-deno/README.md +3 -0
- package/build-deno/augment.ts +2 -0
- package/build-deno/base/Base.ts +50 -0
- package/build-deno/base/Blueprint.ts +88 -0
- package/build-deno/base/Code.ts +140 -0
- package/build-deno/base/Contract.ts +194 -0
- package/build-deno/base/index.ts +4 -0
- package/build-deno/base/mock.ts +46 -0
- package/build-deno/base/types.ts +38 -0
- package/build-deno/base/util.ts +54 -0
- package/build-deno/bundle.ts +6 -0
- package/build-deno/checkTypes.manual.ts +42 -0
- package/build-deno/index.ts +4 -0
- package/build-deno/mod.ts +2 -0
- package/build-deno/packageDetect.ts +9 -0
- package/build-deno/packageInfo.ts +3 -0
- package/build-deno/promise/index.ts +28 -0
- package/build-deno/promise/types.ts +5 -0
- package/build-deno/rx/index.ts +28 -0
- package/build-deno/rx/types.ts +5 -0
- package/build-deno/test/contracts/index.ts +18 -0
- package/build-deno/test/contracts/ink/index.ts +11 -0
- package/build-deno/test/contracts/ink/v0/accumulator.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/adder.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/delegator.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/dns.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/erc20.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/erc721.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/flipper.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/incrementer.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/index.ts +9 -0
- package/build-deno/test/contracts/ink/v0/multisig_plain.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/subber.wasm +0 -0
- package/build-deno/test/contracts/ink/v0/trait-flipper.wasm +0 -0
- package/build-deno/test/contracts/ink/v1/index.ts +3 -0
- package/build-deno/test/contracts/ink/v2/index.ts +3 -0
- package/build-deno/test/contracts/ink/v3/index.ts +3 -0
- package/build-deno/test/contracts/ink/v4/erc20.wasm +0 -0
- package/build-deno/test/contracts/ink/v4/flipper.wasm +0 -0
- package/build-deno/test/contracts/ink/v4/index.ts +5 -0
- package/build-deno/test/contracts/ink/v5/erc20.wasm +0 -0
- package/build-deno/test/contracts/ink/v5/flipper.wasm +0 -0
- package/build-deno/test/contracts/ink/v5/index.ts +6 -0
- package/build-deno/test/contracts/ink/v6/erc20.polkavm +0 -0
- package/build-deno/test/contracts/ink/v6/index.ts +3 -0
- package/build-deno/test/contracts/solang/index.ts +5 -0
- package/build-deno/test/contracts/solang/v0/index.ts +2 -0
- package/build-deno/test/contracts/solang/v0/ints256.sol +13 -0
- package/build-deno/test/contracts/solang/v0/ints256.wasm +0 -0
- package/build-deno/test/contracts/user/index.ts +7 -0
- package/build-deno/test/contracts/user/v0/assetTransfer.wasm +0 -0
- package/build-deno/test/contracts/user/v0/enumExample.wasm +0 -0
- package/build-deno/test/contracts/user/v0/index.ts +5 -0
- package/build-deno/test/contracts/user/v3/index.ts +2 -0
- package/build-deno/test/contracts/user/v4/index.ts +2 -0
- package/build-deno/test/contracts/util.ts +12 -0
- package/build-deno/types.ts +95 -0
- package/build-deno/util.ts +18 -0
- package/build-tsc/Abi/index.d.ts +31 -0
- package/build-tsc/Abi/toLatestCompatible.d.ts +15 -0
- package/build-tsc/Abi/toV1.d.ts +3 -0
- package/build-tsc/Abi/toV2.d.ts +3 -0
- package/build-tsc/Abi/toV3.d.ts +3 -0
- package/build-tsc/Abi/toV4.d.ts +3 -0
- package/build-tsc/augment.d.ts +1 -0
- package/build-tsc/base/Base.d.ts +13 -0
- package/build-tsc/base/Blueprint.d.ts +24 -0
- package/build-tsc/base/Code.d.ts +22 -0
- package/build-tsc/base/Contract.d.ts +25 -0
- package/build-tsc/base/index.d.ts +3 -0
- package/build-tsc/base/mock.d.ts +3 -0
- package/build-tsc/base/types.d.ts +25 -0
- package/build-tsc/base/util.d.ts +16 -0
- package/build-tsc/bundle.d.ts +4 -0
- package/build-tsc/index.d.ts +2 -0
- package/build-tsc/packageDetect.d.ts +1 -0
- package/build-tsc/packageInfo.d.ts +6 -0
- package/build-tsc/promise/index.d.ts +13 -0
- package/build-tsc/promise/types.d.ts +3 -0
- package/build-tsc/rx/index.d.ts +13 -0
- package/build-tsc/rx/types.d.ts +3 -0
- package/build-tsc/types.d.ts +79 -0
- package/build-tsc/util.d.ts +5 -0
- package/build-tsc-cjs/Abi/index.js +363 -0
- package/build-tsc-cjs/Abi/toLatestCompatible.js +36 -0
- package/build-tsc-cjs/Abi/toV1.js +24 -0
- package/build-tsc-cjs/Abi/toV2.js +30 -0
- package/build-tsc-cjs/Abi/toV3.js +13 -0
- package/build-tsc-cjs/Abi/toV4.js +13 -0
- package/build-tsc-cjs/augment.js +3 -0
- package/build-tsc-cjs/base/Base.js +44 -0
- package/build-tsc-cjs/base/Blueprint.js +57 -0
- package/build-tsc-cjs/base/Code.js +80 -0
- package/build-tsc-cjs/base/Contract.js +133 -0
- package/build-tsc-cjs/base/index.js +14 -0
- package/build-tsc-cjs/base/mock.js +41 -0
- package/build-tsc-cjs/base/types.js +2 -0
- package/build-tsc-cjs/base/util.js +42 -0
- package/build-tsc-cjs/bundle.js +10 -0
- package/build-tsc-cjs/index.js +5 -0
- package/build-tsc-cjs/packageDetect.js +7 -0
- package/build-tsc-cjs/packageInfo.js +4 -0
- package/build-tsc-cjs/promise/index.js +23 -0
- package/build-tsc-cjs/promise/types.js +2 -0
- package/build-tsc-cjs/rx/index.js +23 -0
- package/build-tsc-cjs/rx/types.js +2 -0
- package/build-tsc-cjs/types.js +2 -0
- package/build-tsc-cjs/util.js +13 -0
- package/build-tsc-esm/Abi/index.js +359 -0
- package/build-tsc-esm/Abi/toLatestCompatible.js +30 -0
- package/build-tsc-esm/Abi/toV1.js +21 -0
- package/build-tsc-esm/Abi/toV2.js +27 -0
- package/build-tsc-esm/Abi/toV3.js +10 -0
- package/build-tsc-esm/Abi/toV4.js +10 -0
- package/build-tsc-esm/augment.js +1 -0
- package/build-tsc-esm/base/Base.js +40 -0
- package/build-tsc-esm/base/Blueprint.js +51 -0
- package/build-tsc-esm/base/Code.js +74 -0
- package/build-tsc-esm/base/Contract.js +127 -0
- package/build-tsc-esm/base/index.js +3 -0
- package/build-tsc-esm/base/mock.js +38 -0
- package/build-tsc-esm/base/types.js +1 -0
- package/build-tsc-esm/base/util.js +33 -0
- package/build-tsc-esm/bundle.js +4 -0
- package/build-tsc-esm/index.js +2 -0
- package/build-tsc-esm/packageDetect.js +5 -0
- package/build-tsc-esm/packageInfo.js +1 -0
- package/build-tsc-esm/promise/index.js +17 -0
- package/build-tsc-esm/promise/types.js +1 -0
- package/build-tsc-esm/rx/index.js +17 -0
- package/build-tsc-esm/rx/types.js +1 -0
- package/build-tsc-esm/types.js +1 -0
- package/build-tsc-esm/util.js +10 -0
- package/bundle-pezkuwi-api-contract.js +1 -1
- package/cjs/packageInfo.js +1 -1
- package/package.json +6 -6
- package/packageInfo.js +1 -1
- package/src/Abi/Abi.spec.ts +235 -0
- package/src/Abi/index.ts +477 -0
- package/src/Abi/toLatestCompatible.spec.ts +219 -0
- package/src/Abi/toLatestCompatible.ts +52 -0
- package/src/Abi/toV1.ts +35 -0
- package/src/Abi/toV2.ts +58 -0
- package/src/Abi/toV3.ts +18 -0
- package/src/Abi/toV4.ts +21 -0
- package/src/augment.ts +4 -0
- package/src/base/Base.ts +52 -0
- package/src/base/Blueprint.ts +90 -0
- package/src/base/Code.spec.ts +47 -0
- package/src/base/Code.ts +142 -0
- package/src/base/Contract.ts +197 -0
- package/src/base/index.ts +6 -0
- package/src/base/mock.ts +48 -0
- package/src/base/types.ts +40 -0
- package/src/base/util.ts +56 -0
- package/src/bundle.ts +10 -0
- package/src/checkTypes.manual.ts +45 -0
- package/src/index.ts +6 -0
- package/src/mod.ts +4 -0
- package/src/packageDetect.ts +13 -0
- package/src/packageInfo.ts +6 -0
- package/src/promise/index.ts +28 -0
- package/src/promise/types.ts +7 -0
- package/src/rx/index.ts +28 -0
- package/src/rx/types.ts +7 -0
- package/src/test/compare/ink_v0_delegator.test.json +47 -0
- package/src/test/compare/ink_v0_dns.test.json +232 -0
- package/src/test/compare/ink_v0_erc20.test.json +253 -0
- package/src/test/compare/ink_v0_erc721.test.json +415 -0
- package/src/test/compare/ink_v0_flipper.test.json +9 -0
- package/src/test/compare/ink_v0_flipperBundle.test.json +9 -0
- package/src/test/compare/ink_v0_incrementer.test.json +9 -0
- package/src/test/compare/ink_v0_multisigPlain.test.json +562 -0
- package/src/test/compare/ink_v1_flipper.test.json +9 -0
- package/src/test/compare/ink_v1_psp22.test.json +531 -0
- package/src/test/compare/ink_v2_erc20.test.json +205 -0
- package/src/test/compare/ink_v2_flipper.test.json +9 -0
- package/src/test/compare/ink_v3_flipper.test.json +9 -0
- package/src/test/compare/ink_v3_traitErc20.test.json +205 -0
- package/src/test/compare/ink_v4_erc20Contract.test.json +253 -0
- package/src/test/compare/ink_v4_erc20Metadata.test.json +253 -0
- package/src/test/compare/ink_v4_flipperContract.test.json +155 -0
- package/src/test/compare/ink_v4_flipperMetadata.test.json +155 -0
- package/src/test/compare/ink_v5_erc20.test.json +370 -0
- package/src/test/compare/ink_v5_erc20AnonymousTransferMetadata.test.json +370 -0
- package/src/test/compare/ink_v5_erc20Contract.test.json +370 -0
- package/src/test/compare/ink_v5_erc20Metadata.test.json +370 -0
- package/src/test/compare/ink_v5_flipperContract.test.json +174 -0
- package/src/test/compare/ink_v5_flipperMetadata.test.json +174 -0
- package/src/test/compare/ink_v6_erc20Contract.test.json +418 -0
- package/src/test/compare/ink_v6_erc20Metadata.test.json +418 -0
- package/src/test/compare/solang_v0_ints256.test.json +9 -0
- package/src/test/compare/user_v0_assetTransfer.test.json +54 -0
- package/src/test/compare/user_v0_enumExample.test.json +303 -0
- package/src/test/compare/user_v0_recursive.test.json +27 -0
- package/src/test/compare/user_v0_withString.test.json +260 -0
- package/src/test/compare/user_v3_ask.test.json +71 -0
- package/src/test/compare/user_v4_events.test.json +1328 -0
- package/src/test/contracts/index.ts +20 -0
- package/src/test/contracts/ink/index.ts +13 -0
- package/src/test/contracts/ink/v0/accumulator.wasm +0 -0
- package/src/test/contracts/ink/v0/adder.wasm +0 -0
- package/src/test/contracts/ink/v0/delegator.json +252 -0
- package/src/test/contracts/ink/v0/delegator.wasm +0 -0
- package/src/test/contracts/ink/v0/dns.json +713 -0
- package/src/test/contracts/ink/v0/dns.wasm +0 -0
- package/src/test/contracts/ink/v0/erc20.json +704 -0
- package/src/test/contracts/ink/v0/erc20.wasm +0 -0
- package/src/test/contracts/ink/v0/erc721.json +1197 -0
- package/src/test/contracts/ink/v0/erc721.wasm +0 -0
- package/src/test/contracts/ink/v0/flipper.contract.json +107 -0
- package/src/test/contracts/ink/v0/flipper.json +106 -0
- package/src/test/contracts/ink/v0/flipper.wasm +0 -0
- package/src/test/contracts/ink/v0/incrementer.json +108 -0
- package/src/test/contracts/ink/v0/incrementer.wasm +0 -0
- package/src/test/contracts/ink/v0/index.ts +11 -0
- package/src/test/contracts/ink/v0/multisig_plain.json +1466 -0
- package/src/test/contracts/ink/v0/multisig_plain.wasm +0 -0
- package/src/test/contracts/ink/v0/subber.wasm +0 -0
- package/src/test/contracts/ink/v0/trait-flipper.json +103 -0
- package/src/test/contracts/ink/v0/trait-flipper.wasm +0 -0
- package/src/test/contracts/ink/v1/flipper.contract.json +111 -0
- package/src/test/contracts/ink/v1/index.ts +6 -0
- package/src/test/contracts/ink/v1/psp22_minter_pauser.contract.json +1722 -0
- package/src/test/contracts/ink/v2/erc20.contract.json +630 -0
- package/src/test/contracts/ink/v2/flipper.contract.json +103 -0
- package/src/test/contracts/ink/v2/index.ts +5 -0
- package/src/test/contracts/ink/v3/flipper.contract.json +105 -0
- package/src/test/contracts/ink/v3/index.ts +6 -0
- package/src/test/contracts/ink/v3/trait_erc20.contract.json +631 -0
- package/src/test/contracts/ink/v4/erc20.contract.json +1 -0
- package/src/test/contracts/ink/v4/erc20.json +821 -0
- package/src/test/contracts/ink/v4/erc20.wasm +0 -0
- package/src/test/contracts/ink/v4/flipper.contract.json +1 -0
- package/src/test/contracts/ink/v4/flipper.json +396 -0
- package/src/test/contracts/ink/v4/flipper.wasm +0 -0
- package/src/test/contracts/ink/v4/index.ts +7 -0
- package/src/test/contracts/ink/v5/erc20.contract.json +1 -0
- package/src/test/contracts/ink/v5/erc20.json +1025 -0
- package/src/test/contracts/ink/v5/erc20.wasm +0 -0
- package/src/test/contracts/ink/v5/erc20_anonymous_transfer.json +1025 -0
- package/src/test/contracts/ink/v5/flipper.contract.json +1 -0
- package/src/test/contracts/ink/v5/flipper.json +420 -0
- package/src/test/contracts/ink/v5/flipper.wasm +0 -0
- package/src/test/contracts/ink/v5/index.ts +8 -0
- package/src/test/contracts/ink/v6/erc20.contract.json +1 -0
- package/src/test/contracts/ink/v6/erc20.json +1081 -0
- package/src/test/contracts/ink/v6/erc20.polkavm +0 -0
- package/src/test/contracts/ink/v6/index.ts +5 -0
- package/src/test/contracts/solang/index.ts +7 -0
- package/src/test/contracts/solang/v0/index.ts +4 -0
- package/src/test/contracts/solang/v0/ints256.json +113 -0
- package/src/test/contracts/solang/v0/ints256.sol +13 -0
- package/src/test/contracts/solang/v0/ints256.wasm +0 -0
- package/src/test/contracts/user/index.ts +9 -0
- package/src/test/contracts/user/v0/assetTransfer.json +299 -0
- package/src/test/contracts/user/v0/assetTransfer.wasm +0 -0
- package/src/test/contracts/user/v0/enumExample.json +528 -0
- package/src/test/contracts/user/v0/enumExample.wasm +0 -0
- package/src/test/contracts/user/v0/index.ts +7 -0
- package/src/test/contracts/user/v0/recursive.contract.json +1 -0
- package/src/test/contracts/user/v0/withString.json +777 -0
- package/src/test/contracts/user/v3/ask.json +550 -0
- package/src/test/contracts/user/v3/index.ts +4 -0
- package/src/test/contracts/user/v4/events.contract.json +2990 -0
- package/src/test/contracts/user/v4/index.ts +4 -0
- package/src/test/contracts/util.ts +14 -0
- package/src/types.ts +98 -0
- package/src/util.ts +20 -0
- package/tsconfig.build.json +22 -0
- package/tsconfig.build.tsbuildinfo +1 -0
- package/tsconfig.spec.json +26 -0
- package/tsconfig.spec.tsbuildinfo +1 -0
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { ChainProperties, ContractMetadataV4, ContractMetadataV5, ContractMetadataV6, ContractProjectInfo, EventRecord } from '@pezkuwi/types/interfaces';
|
|
2
|
+
import type { Codec, Registry, TypeDef } from '@pezkuwi/types/types';
|
|
3
|
+
import type { AbiConstructor, AbiEvent, AbiMessage, DecodedEvent, DecodedMessage } from '../types.js';
|
|
4
|
+
export type ContractMetadataSupported = ContractMetadataV4 | ContractMetadataV5 | ContractMetadataV6;
|
|
5
|
+
export declare class Abi {
|
|
6
|
+
#private;
|
|
7
|
+
readonly events: AbiEvent[];
|
|
8
|
+
readonly constructors: AbiConstructor[];
|
|
9
|
+
readonly info: ContractProjectInfo;
|
|
10
|
+
readonly json: Record<string, unknown>;
|
|
11
|
+
readonly messages: AbiMessage[];
|
|
12
|
+
readonly metadata: ContractMetadataSupported;
|
|
13
|
+
readonly registry: Registry;
|
|
14
|
+
readonly environment: Map<string, TypeDef | Codec>;
|
|
15
|
+
readonly isRevive: boolean;
|
|
16
|
+
constructor(abiJson: Record<string, unknown> | string, chainProperties?: ChainProperties);
|
|
17
|
+
/**
|
|
18
|
+
* Warning: Unstable API, bound to change
|
|
19
|
+
*/
|
|
20
|
+
decodeEvent(record: EventRecord): DecodedEvent;
|
|
21
|
+
/**
|
|
22
|
+
* Warning: Unstable API, bound to change
|
|
23
|
+
*/
|
|
24
|
+
decodeConstructor(data: Uint8Array): DecodedMessage;
|
|
25
|
+
/**
|
|
26
|
+
* Warning: Unstable API, bound to change
|
|
27
|
+
*/
|
|
28
|
+
decodeMessage(data: Uint8Array): DecodedMessage;
|
|
29
|
+
findConstructor(constructorOrId: AbiConstructor | string | number): AbiConstructor;
|
|
30
|
+
findMessage(messageOrId: AbiMessage | string | number): AbiMessage;
|
|
31
|
+
}
|
|
@@ -0,0 +1,359 @@
|
|
|
1
|
+
import { Option, TypeRegistry } from '@pezkuwi/types';
|
|
2
|
+
import { TypeDefInfo } from '@pezkuwi/types-create';
|
|
3
|
+
import { assertReturn, compactAddLength, compactStripLength, isBn, isNumber, isObject, isString, isUndefined, logger, stringCamelCase, stringify, u8aConcat, u8aToHex } from '@pezkuwi/util';
|
|
4
|
+
import { convertVersions, enumVersions } from './toLatestCompatible.js';
|
|
5
|
+
const l = logger('Abi');
|
|
6
|
+
const PRIMITIVE_ALWAYS = ['AccountId', 'AccountId20', 'AccountIndex', 'Address', 'Balance'];
|
|
7
|
+
function findMessage(list, messageOrId) {
|
|
8
|
+
const message = isNumber(messageOrId)
|
|
9
|
+
? list[messageOrId]
|
|
10
|
+
: isString(messageOrId)
|
|
11
|
+
? list.find(({ identifier }) => [identifier, stringCamelCase(identifier)].includes(messageOrId.toString()))
|
|
12
|
+
: messageOrId;
|
|
13
|
+
return assertReturn(message, () => `Attempted to call an invalid contract interface, ${stringify(messageOrId)}`);
|
|
14
|
+
}
|
|
15
|
+
function getMetadata(registry, json) {
|
|
16
|
+
// this is for V1, V2, V3
|
|
17
|
+
const vx = enumVersions.find((v) => isObject(json[v]));
|
|
18
|
+
// this was added in V4
|
|
19
|
+
const jsonVersion = json.version;
|
|
20
|
+
if (!vx && jsonVersion && !enumVersions.find((v) => v === `V${jsonVersion}`)) {
|
|
21
|
+
throw new Error(`Unable to handle version ${jsonVersion}`);
|
|
22
|
+
}
|
|
23
|
+
const metadata = registry.createType('ContractMetadata', vx
|
|
24
|
+
? { [vx]: json[vx] }
|
|
25
|
+
: jsonVersion
|
|
26
|
+
? { [`V${jsonVersion}`]: json }
|
|
27
|
+
: { V0: json });
|
|
28
|
+
const converter = convertVersions.find(([v]) => metadata[`is${v}`]);
|
|
29
|
+
if (!converter) {
|
|
30
|
+
throw new Error(`Unable to convert ABI with version ${metadata.type} to a supported version`);
|
|
31
|
+
}
|
|
32
|
+
const upgradedMetadata = converter[1](registry, metadata[`as${converter[0]}`]);
|
|
33
|
+
return upgradedMetadata;
|
|
34
|
+
}
|
|
35
|
+
function isRevive(json) {
|
|
36
|
+
const source = json['source'];
|
|
37
|
+
const version = json['version'];
|
|
38
|
+
const hasContractBinary = typeof source === 'object' &&
|
|
39
|
+
source !== null &&
|
|
40
|
+
'contract_binary' in source;
|
|
41
|
+
const hasVersion = typeof version === 'number' && version >= 6;
|
|
42
|
+
return hasContractBinary || hasVersion;
|
|
43
|
+
}
|
|
44
|
+
function parseJson(json, chainProperties) {
|
|
45
|
+
const registry = new TypeRegistry();
|
|
46
|
+
const revive = isRevive(json);
|
|
47
|
+
const typeName = revive ? 'ContractReviveProjectInfo' : 'ContractProjectInfo';
|
|
48
|
+
const info = registry.createType(typeName, json);
|
|
49
|
+
const metadata = getMetadata(registry, json);
|
|
50
|
+
const lookup = registry.createType('PortableRegistry', { types: metadata.types }, true);
|
|
51
|
+
// attach the lookup to the registry - now the types are known
|
|
52
|
+
registry.setLookup(lookup);
|
|
53
|
+
if (chainProperties) {
|
|
54
|
+
registry.setChainProperties(chainProperties);
|
|
55
|
+
}
|
|
56
|
+
// warm-up the actual type, pre-use
|
|
57
|
+
lookup.types.forEach(({ id }) => lookup.getTypeDef(id));
|
|
58
|
+
return [json, registry, metadata, info, revive];
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* @internal
|
|
62
|
+
* Determines if the given input value is a ContractTypeSpec
|
|
63
|
+
*/
|
|
64
|
+
function isTypeSpec(value) {
|
|
65
|
+
return !!value && value instanceof Map && !isUndefined(value.type) && !isUndefined(value.displayName);
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* @internal
|
|
69
|
+
* Determines if the given input value is an Option
|
|
70
|
+
*/
|
|
71
|
+
function isOption(value) {
|
|
72
|
+
return !!value && value instanceof Option;
|
|
73
|
+
}
|
|
74
|
+
export class Abi {
|
|
75
|
+
events;
|
|
76
|
+
constructors;
|
|
77
|
+
info;
|
|
78
|
+
json;
|
|
79
|
+
messages;
|
|
80
|
+
metadata;
|
|
81
|
+
registry;
|
|
82
|
+
environment = new Map();
|
|
83
|
+
isRevive;
|
|
84
|
+
constructor(abiJson, chainProperties) {
|
|
85
|
+
[this.json, this.registry, this.metadata, this.info, this.isRevive] = parseJson(isString(abiJson)
|
|
86
|
+
? JSON.parse(abiJson)
|
|
87
|
+
: abiJson, chainProperties);
|
|
88
|
+
this.constructors = this.metadata.spec.constructors.map((spec, index) => this.#createMessage(spec, index, {
|
|
89
|
+
isConstructor: true,
|
|
90
|
+
isDefault: spec.default.isTrue,
|
|
91
|
+
isPayable: spec.payable.isTrue,
|
|
92
|
+
returnType: spec.returnType.isSome
|
|
93
|
+
? this.registry.lookup.getTypeDef(spec.returnType.unwrap().type)
|
|
94
|
+
: null
|
|
95
|
+
}));
|
|
96
|
+
this.events = this.metadata.spec.events.map((_, index) => this.#createEvent(index));
|
|
97
|
+
this.messages = this.metadata.spec.messages.map((spec, index) => this.#createMessage(spec, index, {
|
|
98
|
+
isDefault: spec.default.isTrue,
|
|
99
|
+
isMutating: spec.mutates.isTrue,
|
|
100
|
+
isPayable: spec.payable.isTrue,
|
|
101
|
+
returnType: spec.returnType.isSome
|
|
102
|
+
? this.registry.lookup.getTypeDef(spec.returnType.unwrap().type)
|
|
103
|
+
: null
|
|
104
|
+
}));
|
|
105
|
+
// NOTE See the rationale for having Option<...> values in the actual
|
|
106
|
+
// ContractEnvironmentV4 structure definition in interfaces/contractsAbi
|
|
107
|
+
// (Due to conversions, the fields may not exist)
|
|
108
|
+
for (const [key, opt] of this.metadata.spec.environment.entries()) {
|
|
109
|
+
if (isOption(opt)) {
|
|
110
|
+
if (opt.isSome) {
|
|
111
|
+
const value = opt.unwrap();
|
|
112
|
+
if (isBn(value)) {
|
|
113
|
+
this.environment.set(key, value);
|
|
114
|
+
}
|
|
115
|
+
else if (isTypeSpec(value)) {
|
|
116
|
+
this.environment.set(key, this.registry.lookup.getTypeDef(value.type));
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
throw new Error(`Invalid environment definition for ${key}:: Expected either Number or ContractTypeSpec`);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
throw new Error(`Expected Option<*> definition for ${key} in ContractEnvironment`);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Warning: Unstable API, bound to change
|
|
130
|
+
*/
|
|
131
|
+
decodeEvent(record) {
|
|
132
|
+
switch (this.metadata.version.toString()) {
|
|
133
|
+
// earlier version are hoisted to v4
|
|
134
|
+
case '4':
|
|
135
|
+
return this.#decodeEventV4(record);
|
|
136
|
+
case '5':
|
|
137
|
+
return this.#decodeEventV5(record);
|
|
138
|
+
// Latest
|
|
139
|
+
default:
|
|
140
|
+
return this.#decodeEventV6(record);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
#decodeEventV6 = (record) => {
|
|
144
|
+
const topics = record.event.data[2];
|
|
145
|
+
// Try to match by signature topic (first topic)
|
|
146
|
+
const signatureTopic = topics[0];
|
|
147
|
+
const data = record.event.data[1];
|
|
148
|
+
if (signatureTopic) {
|
|
149
|
+
const event = this.events.find((e) => e.signatureTopic !== undefined && e.signatureTopic !== null && e.signatureTopic === signatureTopic.toHex());
|
|
150
|
+
// Early return if event found by signature topic
|
|
151
|
+
if (event) {
|
|
152
|
+
return event.fromU8a(data);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
// If no event returned yet, it might be anonymous
|
|
156
|
+
const amountOfTopics = topics.length;
|
|
157
|
+
const potentialEvents = this.events.filter((e) => {
|
|
158
|
+
// event can't have a signature topic
|
|
159
|
+
if (e.signatureTopic !== null && e.signatureTopic !== undefined) {
|
|
160
|
+
return false;
|
|
161
|
+
}
|
|
162
|
+
// event should have same amount of indexed fields as emitted topics
|
|
163
|
+
const amountIndexed = e.args.filter((a) => a.indexed).length;
|
|
164
|
+
if (amountIndexed !== amountOfTopics) {
|
|
165
|
+
return false;
|
|
166
|
+
}
|
|
167
|
+
// If all conditions met, it's a potential event
|
|
168
|
+
return true;
|
|
169
|
+
});
|
|
170
|
+
if (potentialEvents.length === 1) {
|
|
171
|
+
return potentialEvents[0].fromU8a(data);
|
|
172
|
+
}
|
|
173
|
+
throw new Error('Unable to determine event');
|
|
174
|
+
};
|
|
175
|
+
#decodeEventV5 = (record) => {
|
|
176
|
+
// Find event by first topic, which potentially is the signature_topic
|
|
177
|
+
const signatureTopic = record.topics[0];
|
|
178
|
+
const data = record.event.data[1];
|
|
179
|
+
if (signatureTopic) {
|
|
180
|
+
const event = this.events.find((e) => e.signatureTopic !== undefined && e.signatureTopic !== null && e.signatureTopic === signatureTopic.toHex());
|
|
181
|
+
// Early return if event found by signature topic
|
|
182
|
+
if (event) {
|
|
183
|
+
return event.fromU8a(data);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
// If no event returned yet, it might be anonymous
|
|
187
|
+
const amountOfTopics = record.topics.length;
|
|
188
|
+
const potentialEvents = this.events.filter((e) => {
|
|
189
|
+
// event can't have a signature topic
|
|
190
|
+
if (e.signatureTopic !== null && e.signatureTopic !== undefined) {
|
|
191
|
+
return false;
|
|
192
|
+
}
|
|
193
|
+
// event should have same amount of indexed fields as emitted topics
|
|
194
|
+
const amountIndexed = e.args.filter((a) => a.indexed).length;
|
|
195
|
+
if (amountIndexed !== amountOfTopics) {
|
|
196
|
+
return false;
|
|
197
|
+
}
|
|
198
|
+
// If all conditions met, it's a potential event
|
|
199
|
+
return true;
|
|
200
|
+
});
|
|
201
|
+
if (potentialEvents.length === 1) {
|
|
202
|
+
return potentialEvents[0].fromU8a(data);
|
|
203
|
+
}
|
|
204
|
+
throw new Error('Unable to determine event');
|
|
205
|
+
};
|
|
206
|
+
#decodeEventV4 = (record) => {
|
|
207
|
+
const data = record.event.data[1];
|
|
208
|
+
const index = data[0];
|
|
209
|
+
const event = this.events[index];
|
|
210
|
+
if (!event) {
|
|
211
|
+
throw new Error(`Unable to find event with index ${index}`);
|
|
212
|
+
}
|
|
213
|
+
return event.fromU8a(data.subarray(1));
|
|
214
|
+
};
|
|
215
|
+
/**
|
|
216
|
+
* Warning: Unstable API, bound to change
|
|
217
|
+
*/
|
|
218
|
+
decodeConstructor(data) {
|
|
219
|
+
return this.#decodeMessage('message', this.constructors, data);
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Warning: Unstable API, bound to change
|
|
223
|
+
*/
|
|
224
|
+
decodeMessage(data) {
|
|
225
|
+
return this.#decodeMessage('message', this.messages, data);
|
|
226
|
+
}
|
|
227
|
+
findConstructor(constructorOrId) {
|
|
228
|
+
return findMessage(this.constructors, constructorOrId);
|
|
229
|
+
}
|
|
230
|
+
findMessage(messageOrId) {
|
|
231
|
+
return findMessage(this.messages, messageOrId);
|
|
232
|
+
}
|
|
233
|
+
#createArgs = (args, spec) => {
|
|
234
|
+
return args.map(({ label, type }, index) => {
|
|
235
|
+
try {
|
|
236
|
+
if (!isObject(type)) {
|
|
237
|
+
throw new Error('Invalid type definition found');
|
|
238
|
+
}
|
|
239
|
+
const displayName = type.displayName.length
|
|
240
|
+
? type.displayName[type.displayName.length - 1].toString()
|
|
241
|
+
: undefined;
|
|
242
|
+
const camelName = stringCamelCase(label);
|
|
243
|
+
if (displayName && PRIMITIVE_ALWAYS.includes(displayName)) {
|
|
244
|
+
return {
|
|
245
|
+
name: camelName,
|
|
246
|
+
type: {
|
|
247
|
+
info: TypeDefInfo.Plain,
|
|
248
|
+
type: displayName
|
|
249
|
+
}
|
|
250
|
+
};
|
|
251
|
+
}
|
|
252
|
+
const typeDef = this.registry.lookup.getTypeDef(type.type);
|
|
253
|
+
return {
|
|
254
|
+
name: camelName,
|
|
255
|
+
type: displayName && !typeDef.type.startsWith(displayName)
|
|
256
|
+
? { displayName, ...typeDef }
|
|
257
|
+
: typeDef
|
|
258
|
+
};
|
|
259
|
+
}
|
|
260
|
+
catch (error) {
|
|
261
|
+
l.error(`Error expanding argument ${index} in ${stringify(spec)}`);
|
|
262
|
+
throw error;
|
|
263
|
+
}
|
|
264
|
+
});
|
|
265
|
+
};
|
|
266
|
+
#createMessageParams = (args, spec) => {
|
|
267
|
+
return this.#createArgs(args, spec);
|
|
268
|
+
};
|
|
269
|
+
#createEventParams = (args, spec) => {
|
|
270
|
+
const params = this.#createArgs(args, spec);
|
|
271
|
+
return params.map((p, index) => ({ ...p, indexed: args[index].indexed.toPrimitive() }));
|
|
272
|
+
};
|
|
273
|
+
#createEvent = (index) => {
|
|
274
|
+
// TODO TypeScript would narrow this type to the correct version,
|
|
275
|
+
// but version is `Text` so I need to call `toString()` here,
|
|
276
|
+
// which breaks the type inference.
|
|
277
|
+
switch (this.metadata.version.toString()) {
|
|
278
|
+
case '4':
|
|
279
|
+
return this.#createEventV4(this.metadata.spec.events[index], index);
|
|
280
|
+
default:
|
|
281
|
+
return this.#createEventV5(this.metadata.spec.events[index], index);
|
|
282
|
+
}
|
|
283
|
+
};
|
|
284
|
+
#createEventV5 = (spec, index) => {
|
|
285
|
+
const args = this.#createEventParams(spec.args, spec);
|
|
286
|
+
const event = {
|
|
287
|
+
args,
|
|
288
|
+
docs: spec.docs.map((d) => d.toString()),
|
|
289
|
+
fromU8a: (data) => ({
|
|
290
|
+
args: this.#decodeArgs(args, data),
|
|
291
|
+
event
|
|
292
|
+
}),
|
|
293
|
+
identifier: [spec.module_path, spec.label].join('::'),
|
|
294
|
+
index,
|
|
295
|
+
signatureTopic: spec.signature_topic.isSome ? spec.signature_topic.unwrap().toHex() : null
|
|
296
|
+
};
|
|
297
|
+
return event;
|
|
298
|
+
};
|
|
299
|
+
#createEventV4 = (spec, index) => {
|
|
300
|
+
const args = this.#createEventParams(spec.args, spec);
|
|
301
|
+
const event = {
|
|
302
|
+
args,
|
|
303
|
+
docs: spec.docs.map((d) => d.toString()),
|
|
304
|
+
fromU8a: (data) => ({
|
|
305
|
+
args: this.#decodeArgs(args, data),
|
|
306
|
+
event
|
|
307
|
+
}),
|
|
308
|
+
identifier: spec.label.toString(),
|
|
309
|
+
index
|
|
310
|
+
};
|
|
311
|
+
return event;
|
|
312
|
+
};
|
|
313
|
+
#createMessage = (spec, index, add = {}) => {
|
|
314
|
+
const args = this.#createMessageParams(spec.args, spec);
|
|
315
|
+
const identifier = spec.label.toString();
|
|
316
|
+
const message = {
|
|
317
|
+
...add,
|
|
318
|
+
args,
|
|
319
|
+
docs: spec.docs.map((d) => d.toString()),
|
|
320
|
+
fromU8a: (data) => ({
|
|
321
|
+
args: this.#decodeArgs(args, data),
|
|
322
|
+
message
|
|
323
|
+
}),
|
|
324
|
+
identifier,
|
|
325
|
+
index,
|
|
326
|
+
isDefault: spec.default.isTrue,
|
|
327
|
+
method: stringCamelCase(identifier),
|
|
328
|
+
path: identifier.split('::').map((s) => stringCamelCase(s)),
|
|
329
|
+
selector: spec.selector,
|
|
330
|
+
toU8a: (params) => this.#encodeMessageArgs(spec, args, params)
|
|
331
|
+
};
|
|
332
|
+
return message;
|
|
333
|
+
};
|
|
334
|
+
#decodeArgs = (args, data) => {
|
|
335
|
+
// for decoding we expect the input to be just the arg data, no selectors
|
|
336
|
+
// no length added (this allows use with events as well)
|
|
337
|
+
let offset = 0;
|
|
338
|
+
return args.map(({ type: { lookupName, type } }) => {
|
|
339
|
+
const value = this.registry.createType(lookupName || type, data.subarray(offset));
|
|
340
|
+
offset += value.encodedLength;
|
|
341
|
+
return value;
|
|
342
|
+
});
|
|
343
|
+
};
|
|
344
|
+
#decodeMessage = (type, list, data) => {
|
|
345
|
+
const [, trimmed] = compactStripLength(data);
|
|
346
|
+
const selector = trimmed.subarray(0, 4);
|
|
347
|
+
const message = list.find((m) => m.selector.eq(selector));
|
|
348
|
+
if (!message) {
|
|
349
|
+
throw new Error(`Unable to find ${type} with selector ${u8aToHex(selector)}`);
|
|
350
|
+
}
|
|
351
|
+
return message.fromU8a(trimmed.subarray(4));
|
|
352
|
+
};
|
|
353
|
+
#encodeMessageArgs = ({ label, selector }, args, data) => {
|
|
354
|
+
if (data.length !== args.length) {
|
|
355
|
+
throw new Error(`Expected ${args.length} arguments to contract message '${label.toString()}', found ${data.length}`);
|
|
356
|
+
}
|
|
357
|
+
return compactAddLength(u8aConcat(this.registry.createType('ContractSelector', selector).toU8a(), ...args.map(({ type: { lookupName, type } }, index) => this.registry.createType(lookupName || type, data[index]).toU8a())));
|
|
358
|
+
};
|
|
359
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ContractMetadataV4, ContractMetadataV5, ContractMetadataV6 } from '@pezkuwi/types/interfaces';
|
|
2
|
+
import type { Registry } from '@pezkuwi/types/types';
|
|
3
|
+
import type { ContractMetadataSupported } from './index.js';
|
|
4
|
+
export declare const enumVersions: readonly ["V6", "V5", "V4", "V3", "V2", "V1"];
|
|
5
|
+
type Versions = typeof enumVersions[number] | 'V0';
|
|
6
|
+
type Converter = (registry: Registry, vx: any) => ContractMetadataSupported;
|
|
7
|
+
export declare function v6ToLatestCompatible(_registry: Registry, v6: ContractMetadataV6): ContractMetadataV6;
|
|
8
|
+
export declare function v5ToLatestCompatible(_registry: Registry, v5: ContractMetadataV5): ContractMetadataV5;
|
|
9
|
+
export declare function v4ToLatestCompatible(_registry: Registry, v4: ContractMetadataV4): ContractMetadataV4;
|
|
10
|
+
export declare const v3ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV3) => ContractMetadataSupported;
|
|
11
|
+
export declare const v2ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV2) => ContractMetadataSupported;
|
|
12
|
+
export declare const v1ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV1) => ContractMetadataSupported;
|
|
13
|
+
export declare const v0ToLatestCompatible: (registry: Registry, input: import("@pezkuwi/types/interfaces").ContractMetadataV0) => ContractMetadataSupported;
|
|
14
|
+
export declare const convertVersions: [Versions, Converter][];
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { v0ToV1 } from './toV1.js';
|
|
2
|
+
import { v1ToV2 } from './toV2.js';
|
|
3
|
+
import { v2ToV3 } from './toV3.js';
|
|
4
|
+
import { v3ToV4 } from './toV4.js';
|
|
5
|
+
export const enumVersions = ['V6', 'V5', 'V4', 'V3', 'V2', 'V1'];
|
|
6
|
+
function createConverter(next, step) {
|
|
7
|
+
return (registry, input) => next(registry, step(registry, input));
|
|
8
|
+
}
|
|
9
|
+
export function v6ToLatestCompatible(_registry, v6) {
|
|
10
|
+
return v6;
|
|
11
|
+
}
|
|
12
|
+
export function v5ToLatestCompatible(_registry, v5) {
|
|
13
|
+
return v5;
|
|
14
|
+
}
|
|
15
|
+
export function v4ToLatestCompatible(_registry, v4) {
|
|
16
|
+
return v4;
|
|
17
|
+
}
|
|
18
|
+
export const v3ToLatestCompatible = /*#__PURE__*/ createConverter(v4ToLatestCompatible, v3ToV4);
|
|
19
|
+
export const v2ToLatestCompatible = /*#__PURE__*/ createConverter(v3ToLatestCompatible, v2ToV3);
|
|
20
|
+
export const v1ToLatestCompatible = /*#__PURE__*/ createConverter(v2ToLatestCompatible, v1ToV2);
|
|
21
|
+
export const v0ToLatestCompatible = /*#__PURE__*/ createConverter(v1ToLatestCompatible, v0ToV1);
|
|
22
|
+
export const convertVersions = [
|
|
23
|
+
['V6', v6ToLatestCompatible],
|
|
24
|
+
['V5', v5ToLatestCompatible],
|
|
25
|
+
['V4', v4ToLatestCompatible],
|
|
26
|
+
['V3', v3ToLatestCompatible],
|
|
27
|
+
['V2', v2ToLatestCompatible],
|
|
28
|
+
['V1', v1ToLatestCompatible],
|
|
29
|
+
['V0', v0ToLatestCompatible]
|
|
30
|
+
];
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { convertSiV0toV1 } from '@pezkuwi/types';
|
|
2
|
+
import { objectSpread } from '@pezkuwi/util';
|
|
3
|
+
function v0ToV1Names(all) {
|
|
4
|
+
return all.map((e) => objectSpread({}, e, {
|
|
5
|
+
name: Array.isArray(e.name)
|
|
6
|
+
? e.name
|
|
7
|
+
: [e.name]
|
|
8
|
+
}));
|
|
9
|
+
}
|
|
10
|
+
export function v0ToV1(registry, v0) {
|
|
11
|
+
if (!v0.metadataVersion.length) {
|
|
12
|
+
throw new Error('Invalid format for V0 (detected) contract metadata');
|
|
13
|
+
}
|
|
14
|
+
return registry.createType('ContractMetadataV1', objectSpread({}, v0, {
|
|
15
|
+
spec: objectSpread({}, v0.spec, {
|
|
16
|
+
constructors: v0ToV1Names(v0.spec.constructors),
|
|
17
|
+
messages: v0ToV1Names(v0.spec.messages)
|
|
18
|
+
}),
|
|
19
|
+
types: convertSiV0toV1(registry, v0.types)
|
|
20
|
+
}));
|
|
21
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { objectSpread } from '@pezkuwi/util';
|
|
2
|
+
const ARG_TYPES = {
|
|
3
|
+
ContractConstructorSpec: 'ContractMessageParamSpecV2',
|
|
4
|
+
ContractEventSpec: 'ContractEventParamSpecV2',
|
|
5
|
+
ContractMessageSpec: 'ContractMessageParamSpecV2'
|
|
6
|
+
};
|
|
7
|
+
function v1ToV2Label(entry) {
|
|
8
|
+
return objectSpread({}, entry, {
|
|
9
|
+
label: Array.isArray(entry.name)
|
|
10
|
+
? entry.name.join('::')
|
|
11
|
+
: entry.name
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
function v1ToV2Labels(registry, outType, all) {
|
|
15
|
+
return all.map((e) => registry.createType(`${outType}V2`, objectSpread(v1ToV2Label(e), {
|
|
16
|
+
args: e.args.map((a) => registry.createType(ARG_TYPES[outType], v1ToV2Label(a)))
|
|
17
|
+
})));
|
|
18
|
+
}
|
|
19
|
+
export function v1ToV2(registry, v1) {
|
|
20
|
+
return registry.createType('ContractMetadataV2', objectSpread({}, v1, {
|
|
21
|
+
spec: objectSpread({}, v1.spec, {
|
|
22
|
+
constructors: v1ToV2Labels(registry, 'ContractConstructorSpec', v1.spec.constructors),
|
|
23
|
+
events: v1ToV2Labels(registry, 'ContractEventSpec', v1.spec.events),
|
|
24
|
+
messages: v1ToV2Labels(registry, 'ContractMessageSpec', v1.spec.messages)
|
|
25
|
+
})
|
|
26
|
+
}));
|
|
27
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { objectSpread } from '@pezkuwi/util';
|
|
2
|
+
export function v2ToV3(registry, v2) {
|
|
3
|
+
return registry.createType('ContractMetadataV3', objectSpread({}, v2, {
|
|
4
|
+
spec: objectSpread({}, v2.spec, {
|
|
5
|
+
constructors: v2.spec.constructors.map((c) =>
|
|
6
|
+
// V3 introduces the payable flag on constructors, for <V3, it is always true
|
|
7
|
+
registry.createType('ContractConstructorSpecV3', objectSpread({}, c, { payable: true })))
|
|
8
|
+
})
|
|
9
|
+
}));
|
|
10
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { objectSpread } from '@pezkuwi/util';
|
|
2
|
+
export function v3ToV4(registry, v3) {
|
|
3
|
+
return registry.createType('ContractMetadataV4', objectSpread({}, v3, {
|
|
4
|
+
spec: objectSpread({}, v3.spec, {
|
|
5
|
+
constructors: v3.spec.constructors.map((c) => registry.createType('ContractConstructorSpecV4', objectSpread({}, c))),
|
|
6
|
+
messages: v3.spec.messages.map((m) => registry.createType('ContractMessageSpecV3', objectSpread({}, m)))
|
|
7
|
+
}),
|
|
8
|
+
version: registry.createType('Text', '4')
|
|
9
|
+
}));
|
|
10
|
+
}
|