@subwallet/extension-base 1.0.9-2 → 1.0.11-0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/background/KoniTypes.d.ts +6 -0
- package/cjs/koni/api/dotsama/transfer.js +16 -7
- package/cjs/koni/api/nft/wasm_nft/index.js +4 -1
- package/cjs/koni/api/staking/bonding/index.js +3 -0
- package/cjs/koni/api/staking/bonding/paraChain.js +3 -2
- package/cjs/koni/api/staking/bonding/relayChain.js +3 -2
- package/cjs/koni/api/staking/bonding/utils.js +1 -1
- package/cjs/koni/api/xcm/polkadotXcm.js +5 -4
- package/cjs/koni/api/xcm/xTokens.js +1 -1
- package/cjs/koni/api/xcm/xcmPallet.js +1 -1
- package/cjs/koni/background/cron.js +4 -29
- package/cjs/koni/background/handlers/Extension.js +24 -12
- package/cjs/koni/background/handlers/State.js +74 -23
- package/cjs/koni/background/subscription.js +4 -2
- package/cjs/packageInfo.js +1 -1
- package/cjs/services/chain-service/constants.js +5 -2
- package/cjs/services/chain-service/handler/AbstractChainHandler.js +93 -0
- package/cjs/services/chain-service/handler/EvmApi.js +131 -0
- package/cjs/services/chain-service/handler/EvmChainHandler.js +55 -39
- package/cjs/services/chain-service/handler/SubstrateApi.js +212 -0
- package/cjs/services/chain-service/handler/SubstrateChainHandler.js +76 -199
- package/cjs/services/chain-service/helper/api-helper/spec/dataavail.js +152 -0
- package/cjs/services/chain-service/index.js +119 -141
- package/cjs/services/event-service/index.js +2 -0
- package/cjs/services/history-service/index.js +4 -0
- package/cjs/services/migration-service/index.js +0 -3
- package/cjs/services/migration-service/scripts/MigrateNetworkSettings.js +1 -1
- package/cjs/services/price-service/index.js +4 -1
- package/cjs/services/storage-service/DatabaseService.js +6 -1
- package/cjs/services/storage-service/databases/index.js +3 -0
- package/cjs/services/storage-service/db-stores/Metadata.js +26 -0
- package/cjs/services/storage-service/db-stores/index.js +7 -0
- package/koni/api/dotsama/transfer.js +16 -7
- package/koni/api/nft/wasm_nft/index.js +4 -1
- package/koni/api/staking/bonding/index.js +3 -0
- package/koni/api/staking/bonding/paraChain.js +3 -2
- package/koni/api/staking/bonding/relayChain.js +3 -2
- package/koni/api/staking/bonding/utils.js +1 -1
- package/koni/api/xcm/polkadotXcm.js +5 -4
- package/koni/api/xcm/xTokens.js +1 -1
- package/koni/api/xcm/xcmPallet.js +1 -1
- package/koni/background/cron.d.ts +2 -4
- package/koni/background/cron.js +5 -30
- package/koni/background/handlers/Extension.d.ts +0 -1
- package/koni/background/handlers/Extension.js +24 -12
- package/koni/background/handlers/State.d.ts +10 -8
- package/koni/background/handlers/State.js +73 -23
- package/koni/background/subscription.d.ts +2 -2
- package/koni/background/subscription.js +4 -2
- package/package.json +38 -668
- package/packageInfo.js +1 -1
- package/services/chain-service/constants.d.ts +2 -0
- package/services/chain-service/constants.js +3 -1
- package/services/chain-service/handler/AbstractChainHandler.d.ts +29 -0
- package/services/chain-service/handler/AbstractChainHandler.js +83 -0
- package/services/chain-service/handler/EvmApi.d.ts +36 -0
- package/services/chain-service/handler/EvmApi.js +122 -0
- package/services/chain-service/handler/EvmChainHandler.d.ts +15 -9
- package/services/chain-service/handler/EvmChainHandler.js +54 -38
- package/services/chain-service/handler/SubstrateApi.d.ts +48 -0
- package/services/chain-service/handler/SubstrateApi.js +204 -0
- package/services/chain-service/handler/SubstrateChainHandler.d.ts +14 -12
- package/services/chain-service/handler/SubstrateChainHandler.js +74 -198
- package/services/chain-service/handler/types.d.ts +6 -0
- package/services/chain-service/helper/api-helper/spec/dataavail.js +145 -0
- package/services/chain-service/index.d.ts +16 -16
- package/services/chain-service/index.js +109 -133
- package/services/chain-service/types.d.ts +8 -5
- package/services/event-service/index.d.ts +2 -0
- package/services/event-service/index.js +2 -0
- package/services/event-service/types.d.ts +4 -0
- package/services/history-service/index.js +4 -0
- package/services/migration-service/index.js +0 -3
- package/services/migration-service/scripts/MigrateNetworkSettings.js +1 -1
- package/services/price-service/index.js +4 -1
- package/services/storage-service/DatabaseService.d.ts +5 -2
- package/services/storage-service/DatabaseService.js +7 -2
- package/services/storage-service/databases/index.d.ts +4 -1
- package/services/storage-service/databases/index.js +3 -0
- package/services/storage-service/db-stores/Metadata.d.ts +8 -0
- package/services/storage-service/db-stores/Metadata.js +18 -0
- package/services/storage-service/db-stores/index.d.ts +1 -0
- package/services/storage-service/db-stores/index.js +1 -0
- package/cjs/services/chain-service/helper/api-helper/chain/crust-maxwell.js +0 -108
- package/cjs/services/chain-service/helper/api-helper/chain/index.js +0 -17
- package/cjs/services/chain-service/helper/api-helper/index.js +0 -35
- package/cjs/services/chain-service/helper/api-helper/spec/acala.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/ajuna.js +0 -22
- package/cjs/services/chain-service/helper/api-helper/spec/altair.js +0 -31
- package/cjs/services/chain-service/helper/api-helper/spec/apron.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/ares-gladios.js +0 -191
- package/cjs/services/chain-service/helper/api-helper/spec/ares-parachain.js +0 -192
- package/cjs/services/chain-service/helper/api-helper/spec/astar.js +0 -44
- package/cjs/services/chain-service/helper/api-helper/spec/automata.js +0 -43
- package/cjs/services/chain-service/helper/api-helper/spec/basilisk.js +0 -139
- package/cjs/services/chain-service/helper/api-helper/spec/beresheet.js +0 -12
- package/cjs/services/chain-service/helper/api-helper/spec/bifrost-asgard.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/bifrost-parachain.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/bifrost.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/bitcountry-pioneer.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/bitcountry-rococo.js +0 -122
- package/cjs/services/chain-service/helper/api-helper/spec/bitcountry.js +0 -84
- package/cjs/services/chain-service/helper/api-helper/spec/canvas.js +0 -31
- package/cjs/services/chain-service/helper/api-helper/spec/centrifuge-chain.js +0 -77
- package/cjs/services/chain-service/helper/api-helper/spec/centrifuge.js +0 -31
- package/cjs/services/chain-service/helper/api-helper/spec/chainx.js +0 -403
- package/cjs/services/chain-service/helper/api-helper/spec/clover-rococo.js +0 -68
- package/cjs/services/chain-service/helper/api-helper/spec/clover.js +0 -34
- package/cjs/services/chain-service/helper/api-helper/spec/coinversation.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/competitors-club.js +0 -84
- package/cjs/services/chain-service/helper/api-helper/spec/crab.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/crown-sterling.js +0 -55
- package/cjs/services/chain-service/helper/api-helper/spec/crust.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/cumulus-test-parachain.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/darwinia.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/datahighway.js +0 -240
- package/cjs/services/chain-service/helper/api-helper/spec/dock-mainnet.js +0 -16
- package/cjs/services/chain-service/helper/api-helper/spec/dock-testnet.js +0 -16
- package/cjs/services/chain-service/helper/api-helper/spec/dolphin.js +0 -29
- package/cjs/services/chain-service/helper/api-helper/spec/dotmog.js +0 -65
- package/cjs/services/chain-service/helper/api-helper/spec/eave.js +0 -416
- package/cjs/services/chain-service/helper/api-helper/spec/edgeware.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/encointer-node-notee.js +0 -75
- package/cjs/services/chain-service/helper/api-helper/spec/encointer-node-teeproxy.js +0 -52
- package/cjs/services/chain-service/helper/api-helper/spec/encointer-para.js +0 -79
- package/cjs/services/chain-service/helper/api-helper/spec/equilibrium.js +0 -109
- package/cjs/services/chain-service/helper/api-helper/spec/fantour.js +0 -70
- package/cjs/services/chain-service/helper/api-helper/spec/galital-parachain.js +0 -65
- package/cjs/services/chain-service/helper/api-helper/spec/galital.js +0 -70
- package/cjs/services/chain-service/helper/api-helper/spec/galois.js +0 -54
- package/cjs/services/chain-service/helper/api-helper/spec/gamepower.js +0 -71
- package/cjs/services/chain-service/helper/api-helper/spec/genshiro.js +0 -31
- package/cjs/services/chain-service/helper/api-helper/spec/hanonycash.js +0 -33
- package/cjs/services/chain-service/helper/api-helper/spec/hydrate.js +0 -59
- package/cjs/services/chain-service/helper/api-helper/spec/idavoll.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/index.js +0 -272
- package/cjs/services/chain-service/helper/api-helper/spec/integritee.js +0 -35
- package/cjs/services/chain-service/helper/api-helper/spec/interbtc.js +0 -60
- package/cjs/services/chain-service/helper/api-helper/spec/ipse.js +0 -113
- package/cjs/services/chain-service/helper/api-helper/spec/jupiter-rococo.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/jupiter.js +0 -70
- package/cjs/services/chain-service/helper/api-helper/spec/khala.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/kilt.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/konomi.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/kpron.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/kulupu.js +0 -64
- package/cjs/services/chain-service/helper/api-helper/spec/kusari.js +0 -45
- package/cjs/services/chain-service/helper/api-helper/spec/kylin.js +0 -36
- package/cjs/services/chain-service/helper/api-helper/spec/laminar.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/litentry.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/mangata.js +0 -20
- package/cjs/services/chain-service/helper/api-helper/spec/manta.js +0 -29
- package/cjs/services/chain-service/helper/api-helper/spec/mathchain.js +0 -54
- package/cjs/services/chain-service/helper/api-helper/spec/moonbeam.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/moonsama-development.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/mybank.js +0 -87
- package/cjs/services/chain-service/helper/api-helper/spec/neatcoin.js +0 -32
- package/cjs/services/chain-service/helper/api-helper/spec/neumann.js +0 -55
- package/cjs/services/chain-service/helper/api-helper/spec/nftmart.js +0 -134
- package/cjs/services/chain-service/helper/api-helper/spec/nodle.js +0 -53
- package/cjs/services/chain-service/helper/api-helper/spec/opal.js +0 -15
- package/cjs/services/chain-service/helper/api-helper/spec/opportunity.js +0 -12
- package/cjs/services/chain-service/helper/api-helper/spec/origintrail.js +0 -206
- package/cjs/services/chain-service/helper/api-helper/spec/pangolin.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/pangoro.js +0 -12
- package/cjs/services/chain-service/helper/api-helper/spec/parallel.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/parami.js +0 -21
- package/cjs/services/chain-service/helper/api-helper/spec/phoenix.js +0 -52
- package/cjs/services/chain-service/helper/api-helper/spec/pichiu.js +0 -36
- package/cjs/services/chain-service/helper/api-helper/spec/plasm.js +0 -54
- package/cjs/services/chain-service/helper/api-helper/spec/polkadex.js +0 -32
- package/cjs/services/chain-service/helper/api-helper/spec/polkafoundry.js +0 -43
- package/cjs/services/chain-service/helper/api-helper/spec/polymesh.js +0 -21
- package/cjs/services/chain-service/helper/api-helper/spec/pontem.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/prism.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/quartz.js +0 -15
- package/cjs/services/chain-service/helper/api-helper/spec/realis.js +0 -42
- package/cjs/services/chain-service/helper/api-helper/spec/riochain.js +0 -104
- package/cjs/services/chain-service/helper/api-helper/spec/robonomics.js +0 -41
- package/cjs/services/chain-service/helper/api-helper/spec/shibuya.js +0 -54
- package/cjs/services/chain-service/helper/api-helper/spec/shiden.js +0 -54
- package/cjs/services/chain-service/helper/api-helper/spec/snowbridge.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/soraSubstrate.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/spec/spanner.js +0 -501
- package/cjs/services/chain-service/helper/api-helper/spec/stafi.js +0 -25
- package/cjs/services/chain-service/helper/api-helper/spec/standard.js +0 -12
- package/cjs/services/chain-service/helper/api-helper/spec/subdao.js +0 -21
- package/cjs/services/chain-service/helper/api-helper/spec/subgame.js +0 -185
- package/cjs/services/chain-service/helper/api-helper/spec/subsocial.js +0 -15
- package/cjs/services/chain-service/helper/api-helper/spec/subspace.js +0 -127
- package/cjs/services/chain-service/helper/api-helper/spec/substrateContractsNode.js +0 -23
- package/cjs/services/chain-service/helper/api-helper/spec/swapdex.js +0 -45
- package/cjs/services/chain-service/helper/api-helper/spec/ternoa.js +0 -95
- package/cjs/services/chain-service/helper/api-helper/spec/trustbase.js +0 -24
- package/cjs/services/chain-service/helper/api-helper/spec/uart.js +0 -289
- package/cjs/services/chain-service/helper/api-helper/spec/unique.js +0 -124
- package/cjs/services/chain-service/helper/api-helper/spec/unitv.js +0 -25
- package/cjs/services/chain-service/helper/api-helper/spec/vln-rococo.js +0 -109
- package/cjs/services/chain-service/helper/api-helper/spec/vln.js +0 -45
- package/cjs/services/chain-service/helper/api-helper/spec/vodka.js +0 -22
- package/cjs/services/chain-service/helper/api-helper/spec/web3games.js +0 -43
- package/cjs/services/chain-service/helper/api-helper/spec/westlake.js +0 -305
- package/cjs/services/chain-service/helper/api-helper/spec/zCloak.js +0 -46
- package/cjs/services/chain-service/helper/api-helper/spec/zeitgeist.js +0 -33
- package/cjs/services/chain-service/helper/api-helper/spec/zenlink.js +0 -57
- package/cjs/services/chain-service/helper/api-helper/spec/zero.js +0 -11
- package/cjs/services/chain-service/helper/api-helper/util.js +0 -25
- package/services/chain-service/helper/api-helper/chain/crust-maxwell.d.ts +0 -98
- package/services/chain-service/helper/api-helper/chain/crust-maxwell.js +0 -103
- package/services/chain-service/helper/api-helper/chain/index.d.ts +0 -1943
- package/services/chain-service/helper/api-helper/chain/index.js +0 -11
- package/services/chain-service/helper/api-helper/index.d.ts +0 -7
- package/services/chain-service/helper/api-helper/index.js +0 -18
- package/services/chain-service/helper/api-helper/spec/acala.d.ts +0 -42
- package/services/chain-service/helper/api-helper/spec/acala.js +0 -5
- package/services/chain-service/helper/api-helper/spec/ajuna.js +0 -15
- package/services/chain-service/helper/api-helper/spec/altair.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/altair.js +0 -24
- package/services/chain-service/helper/api-helper/spec/apron.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/apron.js +0 -17
- package/services/chain-service/helper/api-helper/spec/ares-gladios.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/ares-gladios.js +0 -184
- package/services/chain-service/helper/api-helper/spec/ares-parachain.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/ares-parachain.js +0 -185
- package/services/chain-service/helper/api-helper/spec/astar.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/astar.js +0 -37
- package/services/chain-service/helper/api-helper/spec/automata.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/automata.js +0 -36
- package/services/chain-service/helper/api-helper/spec/basilisk.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/basilisk.js +0 -132
- package/services/chain-service/helper/api-helper/spec/beresheet.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/beresheet.js +0 -9
- package/services/chain-service/helper/api-helper/spec/bifrost-asgard.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/bifrost-asgard.js +0 -5
- package/services/chain-service/helper/api-helper/spec/bifrost-parachain.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/bifrost-parachain.js +0 -5
- package/services/chain-service/helper/api-helper/spec/bifrost.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/bifrost.js +0 -5
- package/services/chain-service/helper/api-helper/spec/bitcountry-pioneer.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/bitcountry-pioneer.js +0 -5
- package/services/chain-service/helper/api-helper/spec/bitcountry-rococo.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/bitcountry-rococo.js +0 -115
- package/services/chain-service/helper/api-helper/spec/bitcountry.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/bitcountry.js +0 -77
- package/services/chain-service/helper/api-helper/spec/canvas.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/canvas.js +0 -24
- package/services/chain-service/helper/api-helper/spec/centrifuge-chain.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/centrifuge-chain.js +0 -70
- package/services/chain-service/helper/api-helper/spec/centrifuge.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/centrifuge.js +0 -24
- package/services/chain-service/helper/api-helper/spec/chainx.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/chainx.js +0 -396
- package/services/chain-service/helper/api-helper/spec/clover-rococo.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/clover-rococo.js +0 -61
- package/services/chain-service/helper/api-helper/spec/clover.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/clover.js +0 -27
- package/services/chain-service/helper/api-helper/spec/coinversation.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/coinversation.js +0 -17
- package/services/chain-service/helper/api-helper/spec/competitors-club.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/competitors-club.js +0 -77
- package/services/chain-service/helper/api-helper/spec/crab.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/crab.js +0 -5
- package/services/chain-service/helper/api-helper/spec/crown-sterling.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/crown-sterling.js +0 -48
- package/services/chain-service/helper/api-helper/spec/crust.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/crust.js +0 -5
- package/services/chain-service/helper/api-helper/spec/cumulus-test-parachain.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/cumulus-test-parachain.js +0 -17
- package/services/chain-service/helper/api-helper/spec/darwinia.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/darwinia.js +0 -5
- package/services/chain-service/helper/api-helper/spec/datahighway.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/datahighway.js +0 -233
- package/services/chain-service/helper/api-helper/spec/dock-mainnet.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/dock-mainnet.js +0 -9
- package/services/chain-service/helper/api-helper/spec/dock-testnet.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/dock-testnet.js +0 -9
- package/services/chain-service/helper/api-helper/spec/dolphin.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/dolphin.js +0 -22
- package/services/chain-service/helper/api-helper/spec/dotmog.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/dotmog.js +0 -58
- package/services/chain-service/helper/api-helper/spec/eave.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/eave.js +0 -409
- package/services/chain-service/helper/api-helper/spec/edgeware.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/edgeware.js +0 -7
- package/services/chain-service/helper/api-helper/spec/encointer-node-notee.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/encointer-node-notee.js +0 -68
- package/services/chain-service/helper/api-helper/spec/encointer-node-teeproxy.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/encointer-node-teeproxy.js +0 -45
- package/services/chain-service/helper/api-helper/spec/encointer-para.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/encointer-para.js +0 -72
- package/services/chain-service/helper/api-helper/spec/equilibrium.d.ts +0 -8
- package/services/chain-service/helper/api-helper/spec/equilibrium.js +0 -97
- package/services/chain-service/helper/api-helper/spec/fantour.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/fantour.js +0 -63
- package/services/chain-service/helper/api-helper/spec/galital-parachain.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/galital-parachain.js +0 -58
- package/services/chain-service/helper/api-helper/spec/galital.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/galital.js +0 -63
- package/services/chain-service/helper/api-helper/spec/galois.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/galois.js +0 -47
- package/services/chain-service/helper/api-helper/spec/gamepower.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/gamepower.js +0 -64
- package/services/chain-service/helper/api-helper/spec/genshiro.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/genshiro.js +0 -24
- package/services/chain-service/helper/api-helper/spec/hanonycash.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/hanonycash.js +0 -26
- package/services/chain-service/helper/api-helper/spec/hydrate.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/hydrate.js +0 -52
- package/services/chain-service/helper/api-helper/spec/idavoll.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/idavoll.js +0 -17
- package/services/chain-service/helper/api-helper/spec/index.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/index.js +0 -264
- package/services/chain-service/helper/api-helper/spec/integritee.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/integritee.js +0 -28
- package/services/chain-service/helper/api-helper/spec/interbtc.d.ts +0 -7
- package/services/chain-service/helper/api-helper/spec/interbtc.js +0 -50
- package/services/chain-service/helper/api-helper/spec/ipse.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/ipse.js +0 -106
- package/services/chain-service/helper/api-helper/spec/jupiter-rococo.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/jupiter-rococo.js +0 -17
- package/services/chain-service/helper/api-helper/spec/jupiter.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/jupiter.js +0 -63
- package/services/chain-service/helper/api-helper/spec/khala.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/khala.js +0 -5
- package/services/chain-service/helper/api-helper/spec/kilt.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/kilt.js +0 -5
- package/services/chain-service/helper/api-helper/spec/konomi.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/konomi.js +0 -17
- package/services/chain-service/helper/api-helper/spec/kpron.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/kpron.js +0 -17
- package/services/chain-service/helper/api-helper/spec/kulupu.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/kulupu.js +0 -57
- package/services/chain-service/helper/api-helper/spec/kusari.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/kusari.js +0 -38
- package/services/chain-service/helper/api-helper/spec/kylin.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/kylin.js +0 -29
- package/services/chain-service/helper/api-helper/spec/laminar.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/laminar.js +0 -5
- package/services/chain-service/helper/api-helper/spec/litentry.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/litentry.js +0 -17
- package/services/chain-service/helper/api-helper/spec/mangata.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/mangata.js +0 -13
- package/services/chain-service/helper/api-helper/spec/manta.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/manta.js +0 -22
- package/services/chain-service/helper/api-helper/spec/mathchain.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/mathchain.js +0 -47
- package/services/chain-service/helper/api-helper/spec/moonbeam.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/moonbeam.js +0 -5
- package/services/chain-service/helper/api-helper/spec/moonsama-development.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/moonsama-development.js +0 -17
- package/services/chain-service/helper/api-helper/spec/mybank.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/mybank.js +0 -80
- package/services/chain-service/helper/api-helper/spec/neatcoin.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/neatcoin.js +0 -25
- package/services/chain-service/helper/api-helper/spec/neumann.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/neumann.js +0 -48
- package/services/chain-service/helper/api-helper/spec/nftmart.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/nftmart.js +0 -127
- package/services/chain-service/helper/api-helper/spec/nodle.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/nodle.js +0 -46
- package/services/chain-service/helper/api-helper/spec/opal.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/opal.js +0 -9
- package/services/chain-service/helper/api-helper/spec/opportunity.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/opportunity.js +0 -5
- package/services/chain-service/helper/api-helper/spec/origintrail.d.ts +0 -5
- package/services/chain-service/helper/api-helper/spec/origintrail.js +0 -198
- package/services/chain-service/helper/api-helper/spec/pangolin.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/pangolin.js +0 -5
- package/services/chain-service/helper/api-helper/spec/pangoro.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/pangoro.js +0 -7
- package/services/chain-service/helper/api-helper/spec/parallel.d.ts +0 -14
- package/services/chain-service/helper/api-helper/spec/parallel.js +0 -5
- package/services/chain-service/helper/api-helper/spec/parami.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/parami.js +0 -14
- package/services/chain-service/helper/api-helper/spec/phoenix.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/phoenix.js +0 -45
- package/services/chain-service/helper/api-helper/spec/pichiu.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/pichiu.js +0 -29
- package/services/chain-service/helper/api-helper/spec/plasm.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/plasm.js +0 -47
- package/services/chain-service/helper/api-helper/spec/polkadex.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/polkadex.js +0 -25
- package/services/chain-service/helper/api-helper/spec/polkafoundry.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/polkafoundry.js +0 -36
- package/services/chain-service/helper/api-helper/spec/polymesh.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/polymesh.js +0 -13
- package/services/chain-service/helper/api-helper/spec/pontem.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/pontem.js +0 -5
- package/services/chain-service/helper/api-helper/spec/prism.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/prism.js +0 -17
- package/services/chain-service/helper/api-helper/spec/quartz.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/quartz.js +0 -9
- package/services/chain-service/helper/api-helper/spec/realis.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/realis.js +0 -35
- package/services/chain-service/helper/api-helper/spec/riochain.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/riochain.js +0 -97
- package/services/chain-service/helper/api-helper/spec/robonomics.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/robonomics.js +0 -34
- package/services/chain-service/helper/api-helper/spec/shibuya.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/shibuya.js +0 -47
- package/services/chain-service/helper/api-helper/spec/shiden.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/shiden.js +0 -47
- package/services/chain-service/helper/api-helper/spec/snowbridge.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/snowbridge.js +0 -5
- package/services/chain-service/helper/api-helper/spec/soraSubstrate.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/soraSubstrate.js +0 -5
- package/services/chain-service/helper/api-helper/spec/spanner.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/spanner.js +0 -494
- package/services/chain-service/helper/api-helper/spec/stafi.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/stafi.js +0 -18
- package/services/chain-service/helper/api-helper/spec/standard.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/standard.js +0 -5
- package/services/chain-service/helper/api-helper/spec/subdao.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/subdao.js +0 -14
- package/services/chain-service/helper/api-helper/spec/subgame.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/subgame.js +0 -178
- package/services/chain-service/helper/api-helper/spec/subsocial.d.ts +0 -2
- package/services/chain-service/helper/api-helper/spec/subsocial.js +0 -8
- package/services/chain-service/helper/api-helper/spec/subspace.d.ts +0 -0
- package/services/chain-service/helper/api-helper/spec/subspace.js +0 -126
- package/services/chain-service/helper/api-helper/spec/substrateContractsNode.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/substrateContractsNode.js +0 -16
- package/services/chain-service/helper/api-helper/spec/swapdex.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/swapdex.js +0 -38
- package/services/chain-service/helper/api-helper/spec/ternoa.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/ternoa.js +0 -88
- package/services/chain-service/helper/api-helper/spec/trustbase.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/trustbase.js +0 -17
- package/services/chain-service/helper/api-helper/spec/uart.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/uart.js +0 -282
- package/services/chain-service/helper/api-helper/spec/unique.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/unique.js +0 -117
- package/services/chain-service/helper/api-helper/spec/unitv.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/unitv.js +0 -18
- package/services/chain-service/helper/api-helper/spec/vln-rococo.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/vln-rococo.js +0 -102
- package/services/chain-service/helper/api-helper/spec/vln.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/vln.js +0 -38
- package/services/chain-service/helper/api-helper/spec/vodka.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/vodka.js +0 -15
- package/services/chain-service/helper/api-helper/spec/web3games.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/web3games.js +0 -36
- package/services/chain-service/helper/api-helper/spec/westlake.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/westlake.js +0 -298
- package/services/chain-service/helper/api-helper/spec/zCloak.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/zCloak.js +0 -39
- package/services/chain-service/helper/api-helper/spec/zeitgeist.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/zeitgeist.js +0 -24
- package/services/chain-service/helper/api-helper/spec/zenlink.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/zenlink.js +0 -50
- package/services/chain-service/helper/api-helper/spec/zero.d.ts +0 -3
- package/services/chain-service/helper/api-helper/spec/zero.js +0 -5
- package/services/chain-service/helper/api-helper/util.d.ts +0 -5
- package/services/chain-service/helper/api-helper/util.js +0 -15
- /package/services/chain-service/helper/api-helper/spec/{ajuna.d.ts → dataavail.d.ts} +0 -0
|
@@ -42,14 +42,13 @@ class ChainService {
|
|
|
42
42
|
constructor(dbService, eventService) {
|
|
43
43
|
this.dbService = dbService;
|
|
44
44
|
this.eventService = eventService;
|
|
45
|
-
this.substrateChainHandler = new _SubstrateChainHandler.SubstrateChainHandler();
|
|
46
|
-
this.evmChainHandler = new _EvmChainHandler.EvmChainHandler();
|
|
47
|
-
this.chainInfoMapSubject.next(this.dataMap.chainInfoMap);
|
|
48
45
|
this.chainStateMapSubject.next(this.dataMap.chainStateMap);
|
|
46
|
+
this.chainInfoMapSubject.next(this.dataMap.chainInfoMap);
|
|
49
47
|
this.assetRegistrySubject.next(this.dataMap.assetRegistry);
|
|
50
48
|
this.xcmRefMapSubject.next(this.dataMap.assetRefMap);
|
|
49
|
+
this.substrateChainHandler = new _SubstrateChainHandler.SubstrateChainHandler(this);
|
|
50
|
+
this.evmChainHandler = new _EvmChainHandler.EvmChainHandler(this);
|
|
51
51
|
this.logger = (0, _logger.logger)('chain-service');
|
|
52
|
-
this.refreshChainStateInterval(3000, 6);
|
|
53
52
|
}
|
|
54
53
|
|
|
55
54
|
// Getter
|
|
@@ -179,6 +178,15 @@ class ChainService {
|
|
|
179
178
|
getChainStateByKey(key) {
|
|
180
179
|
return this.dataMap.chainStateMap[key];
|
|
181
180
|
}
|
|
181
|
+
getActiveChains() {
|
|
182
|
+
return Object.entries(this.dataMap.chainStateMap).filter(_ref => {
|
|
183
|
+
let [, chainState] = _ref;
|
|
184
|
+
return (0, _utils._isChainEnabled)(chainState);
|
|
185
|
+
}).map(_ref2 => {
|
|
186
|
+
let [key] = _ref2;
|
|
187
|
+
return key;
|
|
188
|
+
});
|
|
189
|
+
}
|
|
182
190
|
getSupportedSmartContractTypes() {
|
|
183
191
|
return [_types._AssetType.ERC20, _types._AssetType.ERC721, _types._AssetType.PSP22, _types._AssetType.PSP34];
|
|
184
192
|
}
|
|
@@ -360,6 +368,8 @@ class ChainService {
|
|
|
360
368
|
|
|
361
369
|
// Business logic
|
|
362
370
|
async init() {
|
|
371
|
+
await this.eventService.waitDatabaseReady;
|
|
372
|
+
|
|
363
373
|
// TODO: reconsider the flow of initiation
|
|
364
374
|
const [latestAssetRefMap, latestMultiChainAssetMap] = await Promise.all([this.fetchLatestData(_constants._ASSET_REF_SRC, _chainList.AssetRefMap), this.fetchLatestData(_constants._MULTI_CHAIN_ASSET_SRC, _chainList.MultiChainAssetMap)]);
|
|
365
375
|
this.multiChainAssetMapSubject.next(latestMultiChainAssetMap);
|
|
@@ -369,29 +379,53 @@ class ChainService {
|
|
|
369
379
|
this.chainStateMapSubject.next(this.getChainStateMap());
|
|
370
380
|
this.assetRegistrySubject.next(this.getAssetRegistry());
|
|
371
381
|
this.xcmRefMapSubject.next(this.dataMap.assetRefMap);
|
|
372
|
-
this.initApis();
|
|
382
|
+
await this.initApis();
|
|
373
383
|
await this.initAssetSettings();
|
|
374
384
|
}
|
|
375
|
-
initApis() {
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
385
|
+
async initApis() {
|
|
386
|
+
const chainInfoMap = this.getChainInfoMap();
|
|
387
|
+
const chainStateMap = this.getChainStateMap();
|
|
388
|
+
await Promise.all(Object.entries(chainInfoMap).filter(_ref3 => {
|
|
389
|
+
var _chainStateMap$slug;
|
|
390
|
+
let [slug] = _ref3;
|
|
391
|
+
return (_chainStateMap$slug = chainStateMap[slug]) === null || _chainStateMap$slug === void 0 ? void 0 : _chainStateMap$slug.active;
|
|
392
|
+
}).map(_ref4 => {
|
|
393
|
+
let [, chainInfo] = _ref4;
|
|
394
|
+
try {
|
|
395
|
+
return this.initApiForChain(chainInfo);
|
|
396
|
+
} catch (e) {
|
|
397
|
+
console.error(e);
|
|
398
|
+
return Promise.resolve();
|
|
381
399
|
}
|
|
382
|
-
});
|
|
400
|
+
}));
|
|
383
401
|
}
|
|
384
|
-
initApiForChain(chainInfo) {
|
|
402
|
+
async initApiForChain(chainInfo) {
|
|
385
403
|
const {
|
|
386
404
|
endpoint,
|
|
387
405
|
providerName
|
|
388
406
|
} = this.getChainCurrentProviderByKey(chainInfo.slug);
|
|
389
|
-
|
|
390
|
-
const
|
|
407
|
+
const onUpdateStatus = isConnected => {
|
|
408
|
+
const currentStatus = this.getChainStateByKey(chainInfo.slug).connectionStatus;
|
|
409
|
+
const newStatus = isConnected ? _types3._ChainConnectionStatus.CONNECTED : _types3._ChainConnectionStatus.DISCONNECTED;
|
|
410
|
+
|
|
411
|
+
// Avoid unnecessary update in case disable chain
|
|
412
|
+
if (currentStatus !== newStatus) {
|
|
413
|
+
this.setChainConnectionStatus(chainInfo.slug, newStatus);
|
|
414
|
+
this.chainStateMapSubject.next(this.getChainStateMap());
|
|
415
|
+
}
|
|
416
|
+
};
|
|
417
|
+
if (chainInfo.substrateInfo !== null && chainInfo.substrateInfo !== undefined) {
|
|
418
|
+
const chainApi = await this.substrateChainHandler.initApi(chainInfo.slug, endpoint, {
|
|
419
|
+
providerName,
|
|
420
|
+
onUpdateStatus
|
|
421
|
+
});
|
|
391
422
|
this.substrateChainHandler.setSubstrateApi(chainInfo.slug, chainApi);
|
|
392
423
|
}
|
|
393
|
-
if (chainInfo.evmInfo !== null) {
|
|
394
|
-
const chainApi = this.initApi(chainInfo.slug, endpoint,
|
|
424
|
+
if (chainInfo.evmInfo !== null && chainInfo.evmInfo !== undefined) {
|
|
425
|
+
const chainApi = await this.evmChainHandler.initApi(chainInfo.slug, endpoint, {
|
|
426
|
+
providerName,
|
|
427
|
+
onUpdateStatus
|
|
428
|
+
});
|
|
395
429
|
this.evmChainHandler.setEvmApi(chainInfo.slug, chainApi);
|
|
396
430
|
}
|
|
397
431
|
}
|
|
@@ -403,49 +437,53 @@ class ChainService {
|
|
|
403
437
|
this.evmChainHandler.destroyEvmApi(chainInfo.slug);
|
|
404
438
|
}
|
|
405
439
|
}
|
|
406
|
-
|
|
407
|
-
let type = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'substrate';
|
|
408
|
-
let providerName = arguments.length > 3 ? arguments[3] : undefined;
|
|
409
|
-
switch (type) {
|
|
410
|
-
case 'evm':
|
|
411
|
-
return this.evmChainHandler.initApi(slug, endpoint, providerName);
|
|
412
|
-
default:
|
|
413
|
-
// substrate by default
|
|
414
|
-
return this.substrateChainHandler.initApi(slug, endpoint, providerName);
|
|
415
|
-
}
|
|
416
|
-
}
|
|
417
|
-
_enableChain(chainSlug) {
|
|
440
|
+
async enableChain(chainSlug) {
|
|
418
441
|
const chainInfo = this.getChainInfoByKey(chainSlug);
|
|
419
442
|
const chainStateMap = this.getChainStateMap();
|
|
420
443
|
if (chainStateMap[chainSlug].active || this.lockChainInfoMap) {
|
|
421
444
|
return false;
|
|
422
445
|
}
|
|
423
446
|
this.lockChainInfoMap = true;
|
|
424
|
-
chainStateMap[chainSlug].active = true;
|
|
425
|
-
this.initApiForChain(chainInfo);
|
|
426
|
-
this.refreshChainStateInterval(3000, 6);
|
|
427
447
|
this.dbService.updateChainStore({
|
|
428
448
|
...chainInfo,
|
|
429
449
|
active: true,
|
|
430
450
|
currentProvider: chainStateMap[chainSlug].currentProvider
|
|
431
451
|
}).catch(console.error);
|
|
452
|
+
chainStateMap[chainSlug].active = true;
|
|
453
|
+
await this.initApiForChain(chainInfo);
|
|
432
454
|
this.lockChainInfoMap = false;
|
|
433
455
|
this.eventService.emit('chain.updateState', chainSlug);
|
|
456
|
+
this.updateChainStateMapSubscription();
|
|
434
457
|
return true;
|
|
435
458
|
}
|
|
436
|
-
|
|
437
|
-
const
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
}
|
|
443
|
-
enableChains(chainSlugs) {
|
|
444
|
-
const rs = chainSlugs.map(this._enableChain.bind(this));
|
|
445
|
-
if (rs.some(r => r)) {
|
|
446
|
-
this.updateChainStateMapSubscription();
|
|
459
|
+
async enableChains(chainSlugs) {
|
|
460
|
+
const chainInfoMap = this.getChainInfoMap();
|
|
461
|
+
const chainStateMap = this.getChainStateMap();
|
|
462
|
+
let needUpdate = false;
|
|
463
|
+
if (this.lockChainInfoMap) {
|
|
464
|
+
return false;
|
|
447
465
|
}
|
|
448
|
-
|
|
466
|
+
this.lockChainInfoMap = true;
|
|
467
|
+
const initPromises = chainSlugs.map(async chainSlug => {
|
|
468
|
+
var _chainStateMap$chainS;
|
|
469
|
+
const chainInfo = chainInfoMap[chainSlug];
|
|
470
|
+
const currentState = (_chainStateMap$chainS = chainStateMap[chainSlug]) === null || _chainStateMap$chainS === void 0 ? void 0 : _chainStateMap$chainS.active;
|
|
471
|
+
if (!currentState) {
|
|
472
|
+
this.dbService.updateChainStore({
|
|
473
|
+
...chainInfo,
|
|
474
|
+
active: true,
|
|
475
|
+
currentProvider: chainStateMap[chainSlug].currentProvider
|
|
476
|
+
}).catch(console.error);
|
|
477
|
+
chainStateMap[chainSlug].active = true;
|
|
478
|
+
await this.initApiForChain(chainInfo);
|
|
479
|
+
this.eventService.emit('chain.updateState', chainSlug);
|
|
480
|
+
needUpdate = true;
|
|
481
|
+
}
|
|
482
|
+
});
|
|
483
|
+
await Promise.all(initPromises);
|
|
484
|
+
this.lockChainInfoMap = false;
|
|
485
|
+
needUpdate && this.updateChainStateMapSubscription();
|
|
486
|
+
return needUpdate;
|
|
449
487
|
}
|
|
450
488
|
disableChain(chainSlug) {
|
|
451
489
|
const chainInfo = this.getChainInfoByKey(chainSlug);
|
|
@@ -621,8 +659,8 @@ class ChainService {
|
|
|
621
659
|
}
|
|
622
660
|
|
|
623
661
|
// Fill in the missing chainState and storageData (new chains never before seen)
|
|
624
|
-
Object.entries(mergedChainInfoMap).forEach(
|
|
625
|
-
let [slug, chainInfo] =
|
|
662
|
+
Object.entries(mergedChainInfoMap).forEach(_ref5 => {
|
|
663
|
+
let [slug, chainInfo] = _ref5;
|
|
626
664
|
if (!(slug in this.dataMap.chainStateMap)) {
|
|
627
665
|
this.dataMap.chainStateMap[slug] = {
|
|
628
666
|
currentProvider: Object.keys(chainInfo.providers)[0],
|
|
@@ -700,7 +738,7 @@ class ChainService {
|
|
|
700
738
|
}
|
|
701
739
|
|
|
702
740
|
// Can only update providers or block explorer, crowdloan url
|
|
703
|
-
updateChain(params) {
|
|
741
|
+
async updateChain(params) {
|
|
704
742
|
const chainSlug = params.chainEditInfo.slug;
|
|
705
743
|
const targetChainInfo = this.getChainInfoByKey(chainSlug);
|
|
706
744
|
const targetChainState = this.getChainStateByKey(chainSlug);
|
|
@@ -714,8 +752,8 @@ class ChainService {
|
|
|
714
752
|
targetChainState.active = true;
|
|
715
753
|
}
|
|
716
754
|
|
|
717
|
-
//
|
|
718
|
-
this.initApiForChain(targetChainInfo);
|
|
755
|
+
// It auto detects the change of api url to create new instance or reuse existed one
|
|
756
|
+
await this.initApiForChain(targetChainInfo);
|
|
719
757
|
this.updateChainStateMapSubscription();
|
|
720
758
|
}
|
|
721
759
|
if (targetChainInfo.substrateInfo) {
|
|
@@ -740,7 +778,7 @@ class ChainService {
|
|
|
740
778
|
this.eventService.emit('chain.updateState', chainSlug);
|
|
741
779
|
}).catch(e => this.logger.error(e));
|
|
742
780
|
}
|
|
743
|
-
insertChain(params) {
|
|
781
|
+
async insertChain(params) {
|
|
744
782
|
const chainInfoMap = this.getChainInfoMap();
|
|
745
783
|
if (!params.chainSpec) {
|
|
746
784
|
return;
|
|
@@ -798,7 +836,7 @@ class ChainService {
|
|
|
798
836
|
currentProvider: params.chainEditInfo.currentProvider,
|
|
799
837
|
slug: newChainSlug
|
|
800
838
|
};
|
|
801
|
-
this.initApiForChain(chainInfo);
|
|
839
|
+
await this.initApiForChain(chainInfo);
|
|
802
840
|
|
|
803
841
|
// create a record in assetRegistry for native token and update store/subscription
|
|
804
842
|
const nativeTokenSlug = this.upsertCustomToken({
|
|
@@ -829,7 +867,7 @@ class ChainService {
|
|
|
829
867
|
}).catch(e => this.logger.error(e));
|
|
830
868
|
return nativeTokenSlug;
|
|
831
869
|
}
|
|
832
|
-
upsertChain(params) {
|
|
870
|
+
async upsertChain(params) {
|
|
833
871
|
if (this.lockChainInfoMap) {
|
|
834
872
|
return;
|
|
835
873
|
}
|
|
@@ -837,10 +875,10 @@ class ChainService {
|
|
|
837
875
|
let result;
|
|
838
876
|
if (params.mode === 'update') {
|
|
839
877
|
// update existing chainInfo
|
|
840
|
-
this.updateChain(params);
|
|
878
|
+
await this.updateChain(params);
|
|
841
879
|
} else {
|
|
842
880
|
// insert custom network
|
|
843
|
-
result = this.insertChain(params);
|
|
881
|
+
result = await this.insertChain(params);
|
|
844
882
|
}
|
|
845
883
|
this.lockChainInfoMap = false;
|
|
846
884
|
return result;
|
|
@@ -882,9 +920,9 @@ class ChainService {
|
|
|
882
920
|
// TODO: EVM chain might have WS provider
|
|
883
921
|
if (provider.startsWith('http')) {
|
|
884
922
|
// HTTP provider is EVM by default
|
|
885
|
-
api = this.evmChainHandler.initApi('custom', provider);
|
|
923
|
+
api = await this.evmChainHandler.initApi('custom', provider);
|
|
886
924
|
} else {
|
|
887
|
-
api = this.substrateChainHandler.initApi('custom', provider);
|
|
925
|
+
api = await this.substrateChainHandler.initApi('custom', provider);
|
|
888
926
|
}
|
|
889
927
|
const connectionTimeout = new Promise(resolve => {
|
|
890
928
|
const id = setTimeout(() => {
|
|
@@ -1069,70 +1107,21 @@ class ChainService {
|
|
|
1069
1107
|
return `${originChain}-${assetType}-${symbol}`;
|
|
1070
1108
|
}
|
|
1071
1109
|
refreshSubstrateApi(slug) {
|
|
1072
|
-
this.substrateChainHandler.
|
|
1110
|
+
this.substrateChainHandler.recoverApi(slug).catch(console.error);
|
|
1073
1111
|
}
|
|
1074
1112
|
refreshEvmApi(slug) {
|
|
1075
|
-
|
|
1076
|
-
endpoint,
|
|
1077
|
-
providerName
|
|
1078
|
-
} = this.getChainCurrentProviderByKey(slug);
|
|
1079
|
-
this.evmChainHandler.refreshApi(slug, endpoint, providerName);
|
|
1080
|
-
}
|
|
1081
|
-
stopAllChainApis() {
|
|
1082
|
-
// TODO: add logic for EvmApi
|
|
1083
|
-
// Object.entries(this.apiMap.web3).forEach(([key, network]) => {
|
|
1084
|
-
// if (network.currentProvider instanceof Web3.providers.WebsocketProvider) {
|
|
1085
|
-
// if (network.currentProvider?.connected) {
|
|
1086
|
-
// console.log(`[Web3] ${key} is connected`);
|
|
1087
|
-
// network.currentProvider?.disconnect(code, reason);
|
|
1088
|
-
// console.log(`[Web3] ${key} is ${network.currentProvider.connected ? 'connected' : 'disconnected'} now`);
|
|
1089
|
-
// }
|
|
1090
|
-
// }
|
|
1091
|
-
// });
|
|
1092
|
-
|
|
1093
|
-
return this.substrateChainHandler.disconnectAllApis();
|
|
1113
|
+
this.evmChainHandler.recoverApi(slug).catch(console.error);
|
|
1094
1114
|
}
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
// console.log(`[Web3] ${key} is disconnected`);
|
|
1103
|
-
// currentProvider?.connect();
|
|
1104
|
-
// setTimeout(() => console.log(`[Web3] ${key} is ${currentProvider.connected ? 'connected' : 'disconnected'} now`), 500);
|
|
1105
|
-
// }
|
|
1106
|
-
// }
|
|
1107
|
-
// });
|
|
1108
|
-
|
|
1109
|
-
return this.substrateChainHandler.resumeAllApis();
|
|
1110
|
-
}
|
|
1111
|
-
refreshChainStateTimeout = undefined;
|
|
1112
|
-
refreshChainStateTimes = 0;
|
|
1113
|
-
refreshChainStateInterval() {
|
|
1114
|
-
let delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
|
|
1115
|
-
let times = arguments.length > 1 ? arguments[1] : undefined;
|
|
1116
|
-
clearTimeout(this.refreshChainStateTimeout);
|
|
1117
|
-
setTimeout(() => {
|
|
1118
|
-
if (times) {
|
|
1119
|
-
this.refreshChainStateTimes = times;
|
|
1120
|
-
}
|
|
1121
|
-
this.refreshChainStateTimes -= 1;
|
|
1122
|
-
if (this.refreshChainStateTimes < 0) {
|
|
1123
|
-
return;
|
|
1124
|
-
}
|
|
1125
|
-
this.updateApiMapStatus().catch(console.error);
|
|
1126
|
-
this.refreshChainStateTimeout = setTimeout(() => {
|
|
1127
|
-
this.updateApiMapStatus().catch(console.error);
|
|
1128
|
-
this.refreshChainStateInterval(0);
|
|
1129
|
-
}, 3000);
|
|
1130
|
-
}, delay);
|
|
1131
|
-
}
|
|
1132
|
-
async updateApiMapStatus() {
|
|
1115
|
+
async stopAllChainApis() {
|
|
1116
|
+
await Promise.all([this.substrateChainHandler.sleep(), this.evmChainHandler.sleep()]);
|
|
1117
|
+
}
|
|
1118
|
+
async resumeAllChainApis() {
|
|
1119
|
+
await Promise.all([this.substrateChainHandler.wakeUp(), this.evmChainHandler.wakeUp()]);
|
|
1120
|
+
}
|
|
1121
|
+
checkAndUpdateStatusMapForChain(chainSlug) {
|
|
1133
1122
|
const substrateApiMap = this.getSubstrateApiMap();
|
|
1134
1123
|
const evmApiMap = this.getEvmApiMap();
|
|
1135
|
-
const
|
|
1124
|
+
const chainState = this.getChainStateByKey(chainSlug);
|
|
1136
1125
|
let update = false;
|
|
1137
1126
|
function updateState(current, status) {
|
|
1138
1127
|
if (current.connectionStatus !== status) {
|
|
@@ -1140,33 +1129,16 @@ class ChainService {
|
|
|
1140
1129
|
update = true;
|
|
1141
1130
|
}
|
|
1142
1131
|
}
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
if (substrateApiMap[chain]) {
|
|
1148
|
-
const api = substrateApiMap[chain];
|
|
1149
|
-
if (api.isApiConnected) {
|
|
1150
|
-
updateState(chainState, _types3._ChainConnectionStatus.CONNECTED);
|
|
1151
|
-
return;
|
|
1152
|
-
}
|
|
1153
|
-
} else if (evmApiMap[chain]) {
|
|
1154
|
-
var _api$api;
|
|
1155
|
-
const api = evmApiMap[chain];
|
|
1156
|
-
if (await (api === null || api === void 0 ? void 0 : (_api$api = api.api) === null || _api$api === void 0 ? void 0 : _api$api.eth.net.isListening())) {
|
|
1157
|
-
updateState(chainState, _types3._ChainConnectionStatus.CONNECTED);
|
|
1158
|
-
return;
|
|
1159
|
-
}
|
|
1160
|
-
}
|
|
1161
|
-
}
|
|
1162
|
-
updateState(chainState, _types3._ChainConnectionStatus.DISCONNECTED);
|
|
1163
|
-
} catch (e) {
|
|
1164
|
-
updateState(chainState, _types3._ChainConnectionStatus.DISCONNECTED);
|
|
1132
|
+
if (chainState.active) {
|
|
1133
|
+
const api = substrateApiMap[chainSlug] || evmApiMap[chainSlug];
|
|
1134
|
+
if (api) {
|
|
1135
|
+
updateState(chainState, api.isApiConnected ? _types3._ChainConnectionStatus.CONNECTED : _types3._ChainConnectionStatus.DISCONNECTED);
|
|
1165
1136
|
}
|
|
1166
|
-
}
|
|
1167
|
-
|
|
1137
|
+
} else {
|
|
1138
|
+
updateState(chainState, _types3._ChainConnectionStatus.DISCONNECTED);
|
|
1139
|
+
}
|
|
1168
1140
|
if (update) {
|
|
1169
|
-
this.
|
|
1141
|
+
this.dataMap.chainStateMap[chainSlug] = chainState;
|
|
1170
1142
|
}
|
|
1171
1143
|
}
|
|
1172
1144
|
async initAssetSettings() {
|
|
@@ -1231,7 +1203,7 @@ class ChainService {
|
|
|
1231
1203
|
|
|
1232
1204
|
// if chain not enabled, then automatically enable
|
|
1233
1205
|
if (chainState && !chainState.active) {
|
|
1234
|
-
this.enableChain(chainState.slug);
|
|
1206
|
+
await this.enableChain(chainState.slug);
|
|
1235
1207
|
needUpdateSubject = true;
|
|
1236
1208
|
if (autoEnableNativeToken) {
|
|
1237
1209
|
const nativeAsset = this.getNativeTokenInfo(assetInfo.originChain);
|
|
@@ -1295,5 +1267,11 @@ class ChainService {
|
|
|
1295
1267
|
this.deleteCustomAssets(customToken);
|
|
1296
1268
|
}
|
|
1297
1269
|
}
|
|
1270
|
+
getMetadata(chain) {
|
|
1271
|
+
return this.dbService.stores.metadata.getMetadata(chain);
|
|
1272
|
+
}
|
|
1273
|
+
upsertMetadata(chain, metadata) {
|
|
1274
|
+
return this.dbService.stores.metadata.upsertMetadata(chain, metadata);
|
|
1275
|
+
}
|
|
1298
1276
|
}
|
|
1299
1277
|
exports.ChainService = ChainService;
|
|
@@ -21,6 +21,8 @@ class EventService extends _eventemitter.default {
|
|
|
21
21
|
super();
|
|
22
22
|
this.lazyTime = options.lazyTime;
|
|
23
23
|
this.timeoutId = null;
|
|
24
|
+
this.waitCryptoReady = this.generateWaitPromise('crypto.ready');
|
|
25
|
+
this.waitDatabaseReady = this.generateWaitPromise('database.ready');
|
|
24
26
|
this.waitKeyringReady = this.generateWaitPromise('keyring.ready');
|
|
25
27
|
this.waitAccountReady = this.generateWaitPromise('account.ready');
|
|
26
28
|
this.waitChainReady = this.generateWaitPromise('chain.ready');
|
|
@@ -208,7 +208,11 @@ class HistoryService {
|
|
|
208
208
|
this.startRecoverHistories().catch(console.error);
|
|
209
209
|
}
|
|
210
210
|
async start() {
|
|
211
|
+
if (this.status === _types.ServiceStatus.STARTED) {
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
211
214
|
try {
|
|
215
|
+
await Promise.all([this.eventService.waitKeyringReady, this.eventService.waitChainReady]);
|
|
212
216
|
this.startPromiseHandler = (0, _promise.createPromiseHandler)();
|
|
213
217
|
this.status = _types.ServiceStatus.STARTING;
|
|
214
218
|
await this.startCron();
|
|
@@ -18,9 +18,6 @@ class MigrationService {
|
|
|
18
18
|
}
|
|
19
19
|
async run() {
|
|
20
20
|
const keys = Object.keys(_scripts.default).sort((a, b) => a.localeCompare(b));
|
|
21
|
-
|
|
22
|
-
// Await timeout 1s
|
|
23
|
-
await new Promise(resolve => setTimeout(resolve, 1000));
|
|
24
21
|
for (let i = 0; i < keys.length; i++) {
|
|
25
22
|
try {
|
|
26
23
|
const JobClass = _scripts.default[keys[i]];
|
|
@@ -34,7 +34,7 @@ class MigrateNetworkSettings extends _Base.default {
|
|
|
34
34
|
}
|
|
35
35
|
});
|
|
36
36
|
if (enableList.length > 0) {
|
|
37
|
-
state.chainService.enableChains(enableList);
|
|
37
|
+
await state.chainService.enableChains(enableList);
|
|
38
38
|
|
|
39
39
|
// Enable native token of these chains
|
|
40
40
|
const currentAssetSettings = await state.chainService.getAssetSettings();
|
|
@@ -65,7 +65,6 @@ class PriceService {
|
|
|
65
65
|
this.refreshPriceData(this.priceIds);
|
|
66
66
|
}
|
|
67
67
|
};
|
|
68
|
-
await this.eventService.waitAssetReady;
|
|
69
68
|
this.status = _types.ServiceStatus.INITIALIZED;
|
|
70
69
|
this.eventService.on('asset.updateState', eventHandler);
|
|
71
70
|
}
|
|
@@ -78,7 +77,11 @@ class PriceService {
|
|
|
78
77
|
}
|
|
79
78
|
startPromiseHandler = (0, _promise.createPromiseHandler)();
|
|
80
79
|
async start() {
|
|
80
|
+
if (this.status === _types.ServiceStatus.STARTED) {
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
81
83
|
try {
|
|
84
|
+
await this.eventService.waitAssetReady;
|
|
82
85
|
this.startPromiseHandler = (0, _promise.createPromiseHandler)();
|
|
83
86
|
this.status = _types.ServiceStatus.STARTING;
|
|
84
87
|
await this.startCron();
|
|
@@ -18,9 +18,13 @@ var _util = require("@polkadot/util");
|
|
|
18
18
|
class DatabaseService {
|
|
19
19
|
// TODO: might remove this
|
|
20
20
|
|
|
21
|
-
constructor() {
|
|
21
|
+
constructor(eventService) {
|
|
22
|
+
this.eventService = eventService;
|
|
22
23
|
this.logger = (0, _util.logger)('DB-Service');
|
|
23
24
|
this._db = new _databases.default();
|
|
25
|
+
this._db.on('ready', () => {
|
|
26
|
+
this.eventService.emit('database.ready', true);
|
|
27
|
+
});
|
|
24
28
|
this.stores = {
|
|
25
29
|
price: new _dbStores.PriceStore(this._db.price),
|
|
26
30
|
balance: new _dbStores.BalanceStore(this._db.balances),
|
|
@@ -30,6 +34,7 @@ class DatabaseService {
|
|
|
30
34
|
staking: new _dbStores.StakingStore(this._db.stakings),
|
|
31
35
|
transaction: new _dbStores.TransactionStore(this._db.transactions),
|
|
32
36
|
migration: new _dbStores.MigrationStore(this._db.migrations),
|
|
37
|
+
metadata: new _dbStores.MetadataStore(this._db.metadata),
|
|
33
38
|
chain: new _dbStores.ChainStore(this._db.chain),
|
|
34
39
|
asset: new _dbStores.AssetStore(this._db.asset),
|
|
35
40
|
// staking
|
|
@@ -33,6 +33,9 @@ class KoniDatabase extends _dexie.default {
|
|
|
33
33
|
chainStakingMetadata: '[chain+type], chain, type',
|
|
34
34
|
nominatorMetadata: '[chain+address+type], [chain+address], chain, address, type'
|
|
35
35
|
});
|
|
36
|
+
this.conditionalVersion(2, {
|
|
37
|
+
metadata: 'genesisHash, chain'
|
|
38
|
+
});
|
|
36
39
|
}
|
|
37
40
|
conditionalVersion(version, schema, upgrade) {
|
|
38
41
|
if (this.schemaVersion != null && this.schemaVersion < version) {
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _BaseStoreWithChain = _interopRequireDefault(require("@subwallet/extension-base/services/storage-service/db-stores/BaseStoreWithChain"));
|
|
9
|
+
// Copyright 2019-2022 @subwallet/extension-base authors & contributors
|
|
10
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
11
|
+
|
|
12
|
+
class MetadataStore extends _BaseStoreWithChain.default {
|
|
13
|
+
getMetadata(chain) {
|
|
14
|
+
return this.table.where('chain').equals(chain).first();
|
|
15
|
+
}
|
|
16
|
+
upsertMetadata(chain, metadata) {
|
|
17
|
+
return this.table.put(metadata, chain);
|
|
18
|
+
}
|
|
19
|
+
getMetadataByGenesisHash(genesisHash) {
|
|
20
|
+
return this.table.where('[genesisHash]').equals([genesisHash]).first();
|
|
21
|
+
}
|
|
22
|
+
updateMetadataByGenesisHash(genesisHash, metadata) {
|
|
23
|
+
return this.table.put(metadata, genesisHash);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
exports.default = MetadataStore;
|
|
@@ -28,6 +28,12 @@ Object.defineProperty(exports, "CrowdloanStore", {
|
|
|
28
28
|
return _Crowdloan.default;
|
|
29
29
|
}
|
|
30
30
|
});
|
|
31
|
+
Object.defineProperty(exports, "MetadataStore", {
|
|
32
|
+
enumerable: true,
|
|
33
|
+
get: function () {
|
|
34
|
+
return _Metadata.default;
|
|
35
|
+
}
|
|
36
|
+
});
|
|
31
37
|
Object.defineProperty(exports, "MigrationStore", {
|
|
32
38
|
enumerable: true,
|
|
33
39
|
get: function () {
|
|
@@ -72,5 +78,6 @@ var _NftCollection = _interopRequireDefault(require("./NftCollection"));
|
|
|
72
78
|
var _Staking = _interopRequireDefault(require("./Staking"));
|
|
73
79
|
var _Transaction = _interopRequireDefault(require("./Transaction"));
|
|
74
80
|
var _Migration = _interopRequireDefault(require("./Migration"));
|
|
81
|
+
var _Metadata = _interopRequireDefault(require("./Metadata"));
|
|
75
82
|
var _Chain = _interopRequireDefault(require("./Chain"));
|
|
76
83
|
var _Asset = _interopRequireDefault(require("./Asset"));
|
|
@@ -67,9 +67,11 @@ export async function checkSupportTransfer(networkKey, tokenInfo, substrateApiMa
|
|
|
67
67
|
} else if (_TRANSFER_CHAIN_GROUP.kintsugi.includes(networkKey) && !_isNativeToken(tokenInfo) && isTxTokensSupported) {
|
|
68
68
|
result.supportTransfer = true;
|
|
69
69
|
result.supportTransferAll = true;
|
|
70
|
-
} else if (_TRANSFER_CHAIN_GROUP.genshiro.includes(networkKey)
|
|
71
|
-
|
|
72
|
-
|
|
70
|
+
} else if (_TRANSFER_CHAIN_GROUP.genshiro.includes(networkKey)
|
|
71
|
+
// && !_isNativeToken(tokenInfo) && isTxEqBalancesSupported
|
|
72
|
+
) {
|
|
73
|
+
result.supportTransfer = false;
|
|
74
|
+
result.supportTransferAll = false;
|
|
73
75
|
} else if (_TRANSFER_CHAIN_GROUP.crab.includes(networkKey) && _BALANCE_TOKEN_GROUP.crab.includes(tokenInfo.symbol)) {
|
|
74
76
|
result.supportTransfer = true;
|
|
75
77
|
result.supportTransferAll = true;
|
|
@@ -88,8 +90,10 @@ export async function checkSupportTransfer(networkKey, tokenInfo, substrateApiMa
|
|
|
88
90
|
// } else if (_TRANSFER_CHAIN_GROUP.riochain.includes(networkKey) && _isNativeToken(tokenInfo)) {
|
|
89
91
|
// result.supportTransfer = true;
|
|
90
92
|
// result.supportTransferAll = true;
|
|
93
|
+
} else if (_TRANSFER_CHAIN_GROUP.avail.includes(networkKey)) {
|
|
94
|
+
result.supportTransfer = false;
|
|
95
|
+
result.supportTransferAll = false;
|
|
91
96
|
}
|
|
92
|
-
|
|
93
97
|
return result;
|
|
94
98
|
}
|
|
95
99
|
export const createTransferExtrinsic = async ({
|
|
@@ -108,7 +112,7 @@ export const createTransferExtrinsic = async ({
|
|
|
108
112
|
const isTxCurrenciesSupported = !!api && !!api.tx && !!api.tx.currencies;
|
|
109
113
|
const isTxBalancesSupported = !!api && !!api.tx && !!api.tx.balances;
|
|
110
114
|
const isTxTokensSupported = !!api && !!api.tx && !!api.tx.tokens;
|
|
111
|
-
const isTxEqBalancesSupported = !!api && !!api.tx && !!api.tx.eqBalances;
|
|
115
|
+
// const isTxEqBalancesSupported = !!api && !!api.tx && !!api.tx.eqBalances;
|
|
112
116
|
const isTxAssetsSupported = !!api && !!api.tx && !!api.tx.assets;
|
|
113
117
|
let transferAmount; // for PSP-22 tokens, might be deprecated in the future
|
|
114
118
|
|
|
@@ -130,8 +134,11 @@ export const createTransferExtrinsic = async ({
|
|
|
130
134
|
} else if (value) {
|
|
131
135
|
transfer = api.tx.tokens.transfer(to, _getTokenOnChainInfo(tokenInfo) || _getTokenOnChainAssetId(tokenInfo), new BN(value));
|
|
132
136
|
}
|
|
133
|
-
} else if (_TRANSFER_CHAIN_GROUP.genshiro.includes(networkKey)
|
|
134
|
-
|
|
137
|
+
} else if (_TRANSFER_CHAIN_GROUP.genshiro.includes(networkKey)
|
|
138
|
+
// && isTxEqBalancesSupported
|
|
139
|
+
) {
|
|
140
|
+
// transfer = api.tx.eqBalances.transfer(_getTokenOnChainAssetId(tokenInfo), to, value);
|
|
141
|
+
/* empty */
|
|
135
142
|
} else if (!_isNativeToken(tokenInfo) && (_TRANSFER_CHAIN_GROUP.crab.includes(networkKey) || _BALANCE_TOKEN_GROUP.crab.includes(tokenInfo.symbol))) {
|
|
136
143
|
if (transferAll) {
|
|
137
144
|
transfer = api.tx.kton.transferAll(to, false);
|
|
@@ -148,6 +155,8 @@ export const createTransferExtrinsic = async ({
|
|
|
148
155
|
// }
|
|
149
156
|
} else if (_TRANSFER_CHAIN_GROUP.sora_substrate.includes(networkKey) && isTxAssetsSupported) {
|
|
150
157
|
transfer = api.tx.assets.transfer(_getTokenOnChainAssetId(tokenInfo), to, value);
|
|
158
|
+
} else if (_TRANSFER_CHAIN_GROUP.avail.includes(networkKey)) {
|
|
159
|
+
/* empty */
|
|
151
160
|
} else if (isTxBalancesSupported && _isNativeToken(tokenInfo)) {
|
|
152
161
|
if (transferAll) {
|
|
153
162
|
transfer = api.tx.balances.transferAll(to, false);
|
|
@@ -61,7 +61,10 @@ export class WasmNftApi extends BaseNftApi {
|
|
|
61
61
|
});
|
|
62
62
|
const _attributeCount = _onChainAttributeCount === null || _onChainAttributeCount === void 0 ? void 0 : (_onChainAttributeCoun = _onChainAttributeCount.output) === null || _onChainAttributeCoun === void 0 ? void 0 : _onChainAttributeCoun.toJSON();
|
|
63
63
|
const onChainAttributeCount = _onChainAttributeCount.output ? (_attributeCount === null || _attributeCount === void 0 ? void 0 : _attributeCount.ok) || (_attributeCount === null || _attributeCount === void 0 ? void 0 : _attributeCount.Ok) : '0';
|
|
64
|
-
|
|
64
|
+
if (!_onChainAttributeCount.result.isOk) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
return !!onChainAttributeCount && parseInt(onChainAttributeCount) !== 0;
|
|
65
68
|
}
|
|
66
69
|
parseFeaturedTokenUri(tokenUri) {
|
|
67
70
|
if (!tokenUri || tokenUri.length === 0) {
|
|
@@ -106,6 +106,9 @@ export function subscribeEssentialChainStakingMetadata(substrateApiMap, chainInf
|
|
|
106
106
|
|
|
107
107
|
// eslint-disable-next-line @typescript-eslint/no-misused-promises
|
|
108
108
|
Object.values(chainInfoMap).forEach(async chainInfo => {
|
|
109
|
+
if (!substrateApiMap[chainInfo.slug]) {
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
109
112
|
const substrateApi = await substrateApiMap[chainInfo.slug].isReady;
|
|
110
113
|
if (_STAKING_CHAIN_GROUP.astar.includes(chainInfo.slug)) {
|
|
111
114
|
const unsub = await subscribeAstarStakingMetadata(chainInfo.slug, substrateApi, callback);
|
|
@@ -147,10 +147,11 @@ export async function subscribeParaChainNominatorMetadata(chainInfo, address, su
|
|
|
147
147
|
const roundInfo = _roundInfo.toPrimitive();
|
|
148
148
|
const currentRound = roundInfo.current;
|
|
149
149
|
await Promise.all(delegatorState.delegations.map(async delegation => {
|
|
150
|
-
|
|
150
|
+
var _substrateApi$api$que;
|
|
151
|
+
const [_delegationScheduledRequests, _identity, _collatorInfo] = await Promise.all([substrateApi.api.query.parachainStaking.delegationScheduledRequests(delegation.owner), (_substrateApi$api$que = substrateApi.api.query.identity) === null || _substrateApi$api$que === void 0 ? void 0 : _substrateApi$api$que.identityOf(delegation.owner), substrateApi.api.query.parachainStaking.candidateInfo(delegation.owner)]);
|
|
151
152
|
const collatorInfo = _collatorInfo.toPrimitive();
|
|
152
153
|
const minDelegation = collatorInfo === null || collatorInfo === void 0 ? void 0 : collatorInfo.lowestTopDelegationAmount.toString();
|
|
153
|
-
const identityInfo = _identity.toHuman();
|
|
154
|
+
const identityInfo = _identity === null || _identity === void 0 ? void 0 : _identity.toHuman();
|
|
154
155
|
const delegationScheduledRequests = _delegationScheduledRequests.toPrimitive();
|
|
155
156
|
const identity = parseIdentity(identityInfo);
|
|
156
157
|
let hasUnstaking = false;
|