@subwallet/extension-base 0.8.3-2 → 1.0.1
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 +696 -506
- package/background/KoniTypes.js +149 -51
- package/background/RequestBytesSign.d.ts +1 -1
- package/background/RequestExtrinsicSign.d.ts +1 -1
- package/background/errors/BalanceError.d.ts +6 -0
- package/background/errors/BalanceError.js +33 -0
- package/background/errors/EvmProviderError.d.ts +6 -0
- package/background/errors/EvmProviderError.js +45 -0
- package/background/errors/ProviderError.d.ts +6 -0
- package/background/errors/ProviderError.js +32 -0
- package/background/errors/SWError.d.ts +12 -0
- package/background/errors/SWError.js +18 -0
- package/background/errors/TransactionError.d.ts +6 -0
- package/background/errors/TransactionError.js +61 -0
- package/background/handlers/Extension.d.ts +3 -1
- package/background/handlers/Extension.js +7 -11
- package/background/handlers/State.d.ts +5 -1
- package/background/handlers/State.js +54 -30
- package/background/handlers/Tabs.js +2 -2
- package/background/types.d.ts +20 -13
- package/background/warnings/SWWarning.d.ts +7 -0
- package/{errors/SubWalletProviderError.js → background/warnings/SWWarning.js} +4 -3
- package/background/warnings/TransactionWarning.d.ts +6 -0
- package/background/warnings/TransactionWarning.js +19 -0
- package/cjs/background/KoniTypes.js +151 -58
- package/cjs/background/errors/BalanceError.js +39 -0
- package/cjs/background/errors/EvmProviderError.js +52 -0
- package/cjs/background/errors/EvmRpcError.js +21 -0
- package/cjs/background/errors/ProviderError.js +39 -0
- package/cjs/background/errors/SWError.js +25 -0
- package/cjs/background/errors/SubWalletProviderError.js +17 -0
- package/cjs/background/errors/TransactionError.js +67 -0
- package/cjs/background/handlers/Extension.js +7 -10
- package/cjs/background/handlers/State.js +57 -32
- package/cjs/background/handlers/Tabs.js +2 -2
- package/cjs/background/warnings/SWWarning.js +18 -0
- package/cjs/background/warnings/TransactionWarning.js +26 -0
- package/cjs/constants/ethereum.js +19 -0
- package/cjs/constants/i18n.js +32 -0
- package/cjs/constants/index.js +95 -0
- package/cjs/constants/staking.js +14 -0
- package/cjs/defaults.js +4 -2
- package/cjs/koni/api/coingecko.js +46 -0
- package/cjs/koni/api/donate.js +20 -0
- package/cjs/koni/api/dotsama/balance.js +568 -0
- package/cjs/koni/api/dotsama/crowdloan.js +145 -0
- package/cjs/koni/api/dotsama/parseTransaction.js +100 -0
- package/cjs/koni/api/dotsama/transfer.js +164 -0
- package/cjs/koni/api/dotsama/typeRegistry.js +13 -0
- package/cjs/koni/api/nft/acala_nft/index.js +153 -0
- package/cjs/koni/api/nft/bit.country/index.js +127 -0
- package/cjs/koni/api/nft/config.js +144 -0
- package/cjs/koni/api/nft/evm_nft/index.js +169 -0
- package/cjs/koni/api/nft/index.js +150 -0
- package/cjs/koni/api/nft/karura_nft/index.js +157 -0
- package/cjs/koni/api/nft/nft.js +96 -0
- package/cjs/koni/api/nft/quartz_nft/index.js +207 -0
- package/cjs/koni/api/nft/quartz_nft/protobuf.js +85 -0
- package/cjs/koni/api/nft/rmrk_nft/index.js +260 -0
- package/cjs/koni/api/nft/statemine_nft/index.js +144 -0
- package/cjs/koni/api/nft/transfer.js +102 -0
- package/cjs/koni/api/nft/unique_nft/index.js +198 -0
- package/cjs/koni/api/nft/unique_nft/protobuf.js +93 -0
- package/cjs/koni/api/nft/unique_nft/runtime_types.js +122 -0
- package/cjs/koni/api/nft/unique_nft/uniqueNftV2.js +70 -0
- package/cjs/koni/api/nft/wasm_nft/index.js +295 -0
- package/cjs/koni/api/nft/wasm_nft/utils.js +19 -0
- package/cjs/koni/api/staking/bonding/amplitude.js +183 -0
- package/cjs/koni/api/staking/bonding/astar.js +458 -0
- package/cjs/koni/api/staking/bonding/index.js +108 -0
- package/cjs/koni/api/staking/bonding/paraChain.js +254 -0
- package/cjs/koni/api/staking/bonding/relayChain.js +350 -0
- package/cjs/koni/api/staking/bonding/utils.js +222 -0
- package/cjs/koni/api/staking/config.js +47 -0
- package/cjs/koni/api/staking/index.js +77 -0
- package/cjs/koni/api/staking/paraChain.js +226 -0
- package/cjs/koni/api/staking/relayChain.js +171 -0
- package/cjs/koni/api/staking/subsquidStaking.js +109 -0
- package/cjs/koni/api/staking/utils.js +17 -0
- package/cjs/koni/api/subquery/__generated__/DotSamaHistory.js +1 -0
- package/cjs/koni/api/subquery/subquery.js +21 -0
- package/cjs/koni/api/tokens/evm/balance.js +15 -0
- package/cjs/koni/api/tokens/evm/transfer.js +112 -0
- package/cjs/koni/api/tokens/evm/web3.js +17 -0
- package/cjs/koni/api/tokens/index.js +17 -0
- package/cjs/koni/api/tokens/wasm/index.js +36 -0
- package/cjs/koni/api/xcm/astar.js +160 -0
- package/cjs/koni/api/xcm/index.js +149 -0
- package/cjs/koni/api/xcm/moonbeamXcm.js +80 -0
- package/cjs/koni/api/xcm/polkadotXcm.js +58 -0
- package/cjs/koni/api/xcm/statemintXcm.js +197 -0
- package/cjs/koni/api/xcm/substrateXcm.js +213 -0
- package/cjs/koni/api/xcm/utils.js +63 -0
- package/cjs/koni/api/xcm/xTokens.js +61 -0
- package/cjs/koni/api/xcm/xcmPallet.js +52 -0
- package/cjs/koni/background/cron.js +208 -0
- package/cjs/koni/background/events.js +14 -0
- package/cjs/koni/background/handlers/Extension.js +3092 -0
- package/cjs/koni/background/handlers/Mobile.js +138 -0
- package/cjs/koni/background/handlers/State.js +1405 -0
- package/cjs/koni/background/handlers/Tabs.js +797 -0
- package/cjs/koni/background/handlers/index.js +90 -0
- package/cjs/koni/background/subscription.js +281 -0
- package/cjs/koni/migration/Base.js +20 -0
- package/cjs/koni/migration/index.js +45 -0
- package/cjs/koni/migration/scripts/ChangeRouteToHome.js +22 -0
- package/cjs/koni/migration/scripts/ClearOldStorage.js +24 -0
- package/cjs/koni/migration/scripts/RemoveWrongCrowdloan.js +19 -0
- package/cjs/koni/migration/scripts/RemoveWrongTransactionHistoriesFromStore.js +36 -0
- package/cjs/koni/migration/scripts/ResetTransactionHistoryEventIdx.js +21 -0
- package/cjs/koni/migration/scripts/index.js +22 -0
- package/cjs/koni/page/SubWalleEvmProvider.js +142 -0
- package/cjs/koni/page/index.js +16 -0
- package/cjs/packageInfo.js +1 -1
- package/cjs/page/index.js +3 -2
- package/cjs/services/asset-service/index.js +91 -0
- package/cjs/services/balance-service/index.js +108 -0
- package/cjs/services/chain-service/constants.js +231 -0
- package/cjs/services/chain-service/handler/EvmChainHandler.js +144 -0
- package/cjs/services/chain-service/handler/SubstrateChainHandler.js +348 -0
- package/cjs/services/chain-service/handler/light-client/index.js +120 -0
- package/cjs/services/chain-service/handler/types.js +20 -0
- package/cjs/services/chain-service/heath-check/index.js +60 -0
- package/cjs/services/chain-service/helper/api-helper/chain/crust-maxwell.js +108 -0
- package/cjs/services/chain-service/helper/api-helper/chain/index.js +17 -0
- package/cjs/services/chain-service/helper/api-helper/index.js +35 -0
- package/cjs/services/chain-service/helper/api-helper/spec/acala.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/ajuna.js +22 -0
- package/cjs/services/chain-service/helper/api-helper/spec/altair.js +31 -0
- package/cjs/services/chain-service/helper/api-helper/spec/apron.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/ares-gladios.js +191 -0
- package/cjs/services/chain-service/helper/api-helper/spec/ares-parachain.js +192 -0
- package/cjs/services/chain-service/helper/api-helper/spec/astar.js +44 -0
- package/cjs/services/chain-service/helper/api-helper/spec/automata.js +43 -0
- package/cjs/services/chain-service/helper/api-helper/spec/basilisk.js +139 -0
- package/cjs/services/chain-service/helper/api-helper/spec/beresheet.js +12 -0
- package/cjs/services/chain-service/helper/api-helper/spec/bifrost-asgard.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/bifrost-parachain.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/bifrost.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/bitcountry-pioneer.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/bitcountry-rococo.js +122 -0
- package/cjs/services/chain-service/helper/api-helper/spec/bitcountry.js +84 -0
- package/cjs/services/chain-service/helper/api-helper/spec/canvas.js +31 -0
- package/cjs/services/chain-service/helper/api-helper/spec/centrifuge-chain.js +77 -0
- package/cjs/services/chain-service/helper/api-helper/spec/centrifuge.js +31 -0
- package/cjs/services/chain-service/helper/api-helper/spec/chainx.js +403 -0
- package/cjs/services/chain-service/helper/api-helper/spec/clover-rococo.js +68 -0
- package/cjs/services/chain-service/helper/api-helper/spec/clover.js +34 -0
- package/cjs/services/chain-service/helper/api-helper/spec/coinversation.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/competitors-club.js +84 -0
- package/cjs/services/chain-service/helper/api-helper/spec/crab.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/crown-sterling.js +55 -0
- package/cjs/services/chain-service/helper/api-helper/spec/crust.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/cumulus-test-parachain.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/darwinia.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/datahighway.js +240 -0
- package/cjs/services/chain-service/helper/api-helper/spec/dock-mainnet.js +16 -0
- package/cjs/services/chain-service/helper/api-helper/spec/dock-testnet.js +16 -0
- package/cjs/services/chain-service/helper/api-helper/spec/dolphin.js +29 -0
- package/cjs/services/chain-service/helper/api-helper/spec/dotmog.js +65 -0
- package/cjs/services/chain-service/helper/api-helper/spec/eave.js +416 -0
- package/cjs/services/chain-service/helper/api-helper/spec/edgeware.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/encointer-node-notee.js +75 -0
- package/cjs/services/chain-service/helper/api-helper/spec/encointer-node-teeproxy.js +52 -0
- package/cjs/services/chain-service/helper/api-helper/spec/encointer-para.js +79 -0
- package/cjs/services/chain-service/helper/api-helper/spec/equilibrium.js +109 -0
- package/cjs/services/chain-service/helper/api-helper/spec/fantour.js +70 -0
- package/cjs/services/chain-service/helper/api-helper/spec/galital-parachain.js +65 -0
- package/cjs/services/chain-service/helper/api-helper/spec/galital.js +70 -0
- package/cjs/services/chain-service/helper/api-helper/spec/galois.js +54 -0
- package/cjs/services/chain-service/helper/api-helper/spec/gamepower.js +71 -0
- package/cjs/services/chain-service/helper/api-helper/spec/genshiro.js +31 -0
- package/cjs/services/chain-service/helper/api-helper/spec/hanonycash.js +33 -0
- package/cjs/services/chain-service/helper/api-helper/spec/hydrate.js +59 -0
- package/cjs/services/chain-service/helper/api-helper/spec/idavoll.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/index.js +272 -0
- package/cjs/services/chain-service/helper/api-helper/spec/integritee.js +35 -0
- package/cjs/services/chain-service/helper/api-helper/spec/interbtc.js +60 -0
- package/cjs/services/chain-service/helper/api-helper/spec/ipse.js +113 -0
- package/cjs/services/chain-service/helper/api-helper/spec/jupiter-rococo.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/jupiter.js +70 -0
- package/cjs/services/chain-service/helper/api-helper/spec/khala.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/kilt.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/konomi.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/kpron.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/kulupu.js +64 -0
- package/cjs/services/chain-service/helper/api-helper/spec/kusari.js +45 -0
- package/cjs/services/chain-service/helper/api-helper/spec/kylin.js +36 -0
- package/cjs/services/chain-service/helper/api-helper/spec/laminar.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/litentry.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/mangata.js +20 -0
- package/cjs/services/chain-service/helper/api-helper/spec/manta.js +29 -0
- package/cjs/services/chain-service/helper/api-helper/spec/mathchain.js +54 -0
- package/cjs/services/chain-service/helper/api-helper/spec/moonbeam.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/moonsama-development.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/mybank.js +87 -0
- package/cjs/services/chain-service/helper/api-helper/spec/neatcoin.js +32 -0
- package/cjs/services/chain-service/helper/api-helper/spec/neumann.js +55 -0
- package/cjs/services/chain-service/helper/api-helper/spec/nftmart.js +134 -0
- package/cjs/services/chain-service/helper/api-helper/spec/nodle.js +53 -0
- package/cjs/services/chain-service/helper/api-helper/spec/opal.js +15 -0
- package/cjs/services/chain-service/helper/api-helper/spec/opportunity.js +12 -0
- package/cjs/services/chain-service/helper/api-helper/spec/origintrail.js +206 -0
- package/cjs/services/chain-service/helper/api-helper/spec/pangolin.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/pangoro.js +12 -0
- package/cjs/services/chain-service/helper/api-helper/spec/parallel.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/parami.js +21 -0
- package/cjs/services/chain-service/helper/api-helper/spec/phoenix.js +52 -0
- package/cjs/services/chain-service/helper/api-helper/spec/pichiu.js +36 -0
- package/cjs/services/chain-service/helper/api-helper/spec/plasm.js +54 -0
- package/cjs/services/chain-service/helper/api-helper/spec/polkadex.js +32 -0
- package/cjs/services/chain-service/helper/api-helper/spec/polkafoundry.js +43 -0
- package/cjs/services/chain-service/helper/api-helper/spec/polymesh.js +21 -0
- package/cjs/services/chain-service/helper/api-helper/spec/pontem.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/prism.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/quartz.js +15 -0
- package/cjs/services/chain-service/helper/api-helper/spec/realis.js +42 -0
- package/cjs/services/chain-service/helper/api-helper/spec/riochain.js +104 -0
- package/cjs/services/chain-service/helper/api-helper/spec/robonomics.js +41 -0
- package/cjs/services/chain-service/helper/api-helper/spec/shibuya.js +54 -0
- package/cjs/services/chain-service/helper/api-helper/spec/shiden.js +54 -0
- package/cjs/services/chain-service/helper/api-helper/spec/snowbridge.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/soraSubstrate.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/spec/spanner.js +501 -0
- package/cjs/services/chain-service/helper/api-helper/spec/stafi.js +25 -0
- package/cjs/services/chain-service/helper/api-helper/spec/standard.js +12 -0
- package/cjs/services/chain-service/helper/api-helper/spec/subdao.js +21 -0
- package/cjs/services/chain-service/helper/api-helper/spec/subgame.js +185 -0
- package/cjs/services/chain-service/helper/api-helper/spec/subsocial.js +15 -0
- package/cjs/services/chain-service/helper/api-helper/spec/subspace.js +127 -0
- package/cjs/services/chain-service/helper/api-helper/spec/substrateContractsNode.js +23 -0
- package/cjs/services/chain-service/helper/api-helper/spec/swapdex.js +45 -0
- package/cjs/services/chain-service/helper/api-helper/spec/ternoa.js +95 -0
- package/cjs/services/chain-service/helper/api-helper/spec/trustbase.js +24 -0
- package/cjs/services/chain-service/helper/api-helper/spec/uart.js +289 -0
- package/cjs/services/chain-service/helper/api-helper/spec/unique.js +124 -0
- package/cjs/services/chain-service/helper/api-helper/spec/unitv.js +25 -0
- package/cjs/services/chain-service/helper/api-helper/spec/vln-rococo.js +109 -0
- package/cjs/services/chain-service/helper/api-helper/spec/vln.js +45 -0
- package/cjs/services/chain-service/helper/api-helper/spec/vodka.js +22 -0
- package/cjs/services/chain-service/helper/api-helper/spec/web3games.js +43 -0
- package/cjs/services/chain-service/helper/api-helper/spec/westlake.js +305 -0
- package/cjs/services/chain-service/helper/api-helper/spec/zCloak.js +46 -0
- package/cjs/services/chain-service/helper/api-helper/spec/zeitgeist.js +33 -0
- package/cjs/services/chain-service/helper/api-helper/spec/zenlink.js +57 -0
- package/cjs/services/chain-service/helper/api-helper/spec/zero.js +11 -0
- package/cjs/services/chain-service/helper/api-helper/util.js +25 -0
- package/cjs/services/chain-service/helper/index.js +24 -0
- package/cjs/services/chain-service/index.js +1154 -0
- package/cjs/services/chain-service/types.js +26 -0
- package/cjs/services/chain-service/utils.js +387 -0
- package/cjs/services/history-service/index.js +110 -0
- package/cjs/services/history-service/subsquid-multi-chain-history.js +263 -0
- package/cjs/services/migration-service/Base.js +20 -0
- package/cjs/services/migration-service/index.js +45 -0
- package/cjs/services/migration-service/scripts/ClearOldStorage.js +19 -0
- package/cjs/services/migration-service/scripts/MigrateImportedToken.js +49 -0
- package/cjs/services/migration-service/scripts/MigrateNetworkSettings.js +39 -0
- package/cjs/services/migration-service/scripts/index.js +17 -0
- package/cjs/services/notification-service/NotificationService.js +53 -0
- package/cjs/services/price-service/coingecko.js +40 -0
- package/cjs/services/price-service/index.js +78 -0
- package/cjs/services/request-service/constants.js +11 -0
- package/cjs/services/request-service/handler/AuthRequestHandler.js +269 -0
- package/cjs/services/request-service/handler/EvmRequestHandler.js +217 -0
- package/cjs/services/request-service/handler/MetadataRequestHandler.js +85 -0
- package/cjs/services/request-service/handler/PopupHandler.js +86 -0
- package/cjs/services/request-service/handler/SubstrateRequestHandler.js +105 -0
- package/cjs/services/request-service/helper/index.js +82 -0
- package/cjs/services/request-service/index.js +158 -0
- package/cjs/services/request-service/types.js +1 -0
- package/cjs/services/setting-service/SettingService.js +39 -0
- package/cjs/services/setting-service/constants.js +14 -0
- package/cjs/services/storage-service/DatabaseService.js +228 -0
- package/cjs/services/storage-service/databases/index.js +47 -0
- package/cjs/services/storage-service/db-stores/Asset.js +20 -0
- package/cjs/services/storage-service/db-stores/Balance.js +32 -0
- package/cjs/services/storage-service/db-stores/BaseStore.js +29 -0
- package/cjs/services/storage-service/db-stores/BaseStoreWithAddress.js +28 -0
- package/cjs/services/storage-service/db-stores/BaseStoreWithAddressAndChain.js +33 -0
- package/cjs/services/storage-service/db-stores/BaseStoreWithChain.js +20 -0
- package/cjs/services/storage-service/db-stores/Chain.js +20 -0
- package/cjs/services/storage-service/db-stores/ChainStakingMetadata.js +38 -0
- package/cjs/services/storage-service/db-stores/Crowdloan.js +23 -0
- package/cjs/services/storage-service/db-stores/ExtraDelegationInfo.js +17 -0
- package/cjs/services/storage-service/db-stores/Migration.js +13 -0
- package/cjs/services/storage-service/db-stores/Nft.js +72 -0
- package/cjs/services/storage-service/db-stores/NftCollection.js +30 -0
- package/cjs/services/storage-service/db-stores/NominatorMetadata.js +30 -0
- package/cjs/services/storage-service/db-stores/Price.js +13 -0
- package/cjs/services/storage-service/db-stores/Staking.js +40 -0
- package/cjs/services/storage-service/db-stores/Transaction.js +49 -0
- package/cjs/services/storage-service/db-stores/index.js +76 -0
- package/cjs/services/transaction-service/event-parser/index.js +103 -0
- package/cjs/services/transaction-service/helpers/index.js +23 -0
- package/cjs/services/transaction-service/index.js +711 -0
- package/cjs/services/transaction-service/types.js +1 -0
- package/cjs/services/transaction-service/utils.js +32 -0
- package/cjs/stores/AccountRef.js +18 -0
- package/cjs/stores/Application.js +28 -0
- package/cjs/stores/AssetSetting.js +19 -0
- package/cjs/stores/Authorize.js +18 -0
- package/cjs/stores/Balance.js +18 -0
- package/cjs/stores/Crowdloan.js +18 -0
- package/cjs/stores/CurrentAccountStore.js +18 -0
- package/cjs/stores/CustomEvmToken.js +18 -0
- package/cjs/stores/Keyring.js +39 -0
- package/cjs/stores/NetworkMap.js +18 -0
- package/cjs/stores/Nft.js +18 -0
- package/cjs/stores/NftCollection.js +18 -0
- package/cjs/stores/Price.js +18 -0
- package/cjs/stores/Settings.js +18 -0
- package/cjs/stores/Staking.js +18 -0
- package/cjs/stores/StakingReward.js +18 -0
- package/cjs/stores/SubscribableStore.js +33 -0
- package/cjs/stores/TransactionHistory.js +37 -0
- package/cjs/stores/TransactionHistoryV2.js +18 -0
- package/cjs/stores/TransactionHistoryV3.js +18 -0
- package/cjs/stores/index.js +8 -1
- package/cjs/utils/address.js +17 -0
- package/cjs/utils/eth/mergeTransactionAndSignature.js +22 -0
- package/cjs/utils/eth/parseTransaction/base.js +282 -0
- package/cjs/utils/eth/parseTransaction/index.js +229 -0
- package/cjs/utils/eth/parseTransactionData.js +284 -0
- package/cjs/utils/eth.js +76 -0
- package/cjs/utils/index.js +313 -1
- package/cjs/utils/keyring.js +57 -0
- package/cjs/utils/request.js +13 -0
- package/constants/i18n.d.ts +2 -0
- package/constants/i18n.js +25 -0
- package/constants/index.d.ts +25 -0
- package/constants/index.js +28 -0
- package/constants/staking.d.ts +1 -0
- package/constants/staking.js +7 -0
- package/defaults.d.ts +3 -2
- package/defaults.js +3 -2
- package/koni/api/coingecko.d.ts +2 -0
- package/koni/api/coingecko.js +37 -0
- package/koni/api/donate.d.ts +3 -0
- package/koni/api/donate.js +13 -0
- package/koni/api/dotsama/balance.d.ts +7 -0
- package/koni/api/dotsama/balance.js +556 -0
- package/koni/api/dotsama/crowdloan.d.ts +7 -0
- package/koni/api/dotsama/crowdloan.js +130 -0
- package/koni/api/dotsama/parseTransaction.d.ts +3 -0
- package/koni/api/dotsama/parseTransaction.js +93 -0
- package/koni/api/dotsama/transfer.d.ts +17 -0
- package/koni/api/dotsama/transfer.js +154 -0
- package/koni/api/dotsama/typeRegistry.d.ts +3 -0
- package/koni/api/dotsama/typeRegistry.js +6 -0
- package/koni/api/nft/acala_nft/index.d.ts +18 -0
- package/koni/api/nft/acala_nft/index.js +145 -0
- package/koni/api/nft/bit.country/index.d.ts +12 -0
- package/koni/api/nft/bit.country/index.js +119 -0
- package/koni/api/nft/config.d.ts +57 -0
- package/koni/api/nft/config.js +110 -0
- package/koni/api/nft/evm_nft/index.d.ts +13 -0
- package/koni/api/nft/evm_nft/index.js +161 -0
- package/koni/api/nft/index.d.ts +22 -0
- package/koni/api/nft/index.js +141 -0
- package/koni/api/nft/karura_nft/index.d.ts +18 -0
- package/koni/api/nft/karura_nft/index.js +148 -0
- package/koni/api/nft/nft.d.ts +29 -0
- package/koni/api/nft/nft.js +89 -0
- package/koni/api/nft/quartz_nft/index.d.ts +62 -0
- package/koni/api/nft/quartz_nft/index.js +199 -0
- package/koni/api/nft/quartz_nft/protobuf.d.ts +3 -0
- package/koni/api/nft/quartz_nft/protobuf.js +78 -0
- package/koni/api/nft/rmrk_nft/index.d.ts +10 -0
- package/koni/api/nft/rmrk_nft/index.js +252 -0
- package/koni/api/nft/statemine_nft/index.d.ts +18 -0
- package/koni/api/nft/statemine_nft/index.js +136 -0
- package/koni/api/nft/transfer.d.ts +8 -0
- package/koni/api/nft/transfer.js +90 -0
- package/koni/api/nft/unique_nft/index.d.ts +54 -0
- package/koni/api/nft/unique_nft/index.js +189 -0
- package/koni/api/nft/unique_nft/protobuf.d.ts +3 -0
- package/koni/api/nft/unique_nft/protobuf.js +86 -0
- package/koni/api/nft/unique_nft/runtime_types.d.ts +3 -0
- package/koni/api/nft/unique_nft/runtime_types.js +115 -0
- package/koni/api/nft/unique_nft/uniqueNftV2.d.ts +9 -0
- package/koni/api/nft/unique_nft/uniqueNftV2.js +62 -0
- package/koni/api/nft/wasm_nft/index.d.ts +17 -0
- package/koni/api/nft/wasm_nft/index.js +287 -0
- package/koni/api/nft/wasm_nft/utils.d.ts +5 -0
- package/koni/api/nft/wasm_nft/utils.js +8 -0
- package/koni/api/staking/bonding/amplitude.d.ts +11 -0
- package/koni/api/staking/bonding/amplitude.js +170 -0
- package/koni/api/staking/bonding/astar.d.ts +19 -0
- package/koni/api/staking/bonding/astar.js +436 -0
- package/koni/api/staking/bonding/index.d.ts +12 -0
- package/koni/api/staking/bonding/index.js +93 -0
- package/koni/api/staking/bonding/paraChain.d.ts +12 -0
- package/koni/api/staking/bonding/paraChain.js +240 -0
- package/koni/api/staking/bonding/relayChain.d.ts +32 -0
- package/koni/api/staking/bonding/relayChain.js +329 -0
- package/koni/api/staking/bonding/utils.d.ts +142 -0
- package/koni/api/staking/bonding/utils.js +198 -0
- package/koni/api/staking/config.d.ts +3 -0
- package/koni/api/staking/config.js +38 -0
- package/koni/api/staking/index.d.ts +6 -0
- package/koni/api/staking/index.js +67 -0
- package/koni/api/staking/paraChain.d.ts +7 -0
- package/koni/api/staking/paraChain.js +216 -0
- package/koni/api/staking/relayChain.d.ts +6 -0
- package/koni/api/staking/relayChain.js +161 -0
- package/koni/api/staking/subsquidStaking.d.ts +3 -0
- package/koni/api/staking/subsquidStaking.js +101 -0
- package/koni/api/staking/utils.d.ts +2 -0
- package/koni/api/staking/utils.js +11 -0
- package/koni/api/subquery/__generated__/DotSamaHistory.d.ts +58 -0
- package/koni/api/subquery/__generated__/DotSamaHistory.js +1 -0
- package/koni/api/subquery/subquery.d.ts +2 -0
- package/koni/api/subquery/subquery.js +14 -0
- package/koni/api/tokens/evm/balance.d.ts +2 -0
- package/koni/api/tokens/evm/balance.js +9 -0
- package/koni/api/tokens/evm/transfer.d.ts +17 -0
- package/koni/api/tokens/evm/transfer.js +101 -0
- package/koni/api/tokens/evm/web3.d.ts +3 -0
- package/koni/api/tokens/evm/web3.js +9 -0
- package/koni/api/tokens/index.d.ts +1 -0
- package/koni/api/tokens/index.js +11 -0
- package/koni/api/tokens/wasm/index.d.ts +6 -0
- package/koni/api/tokens/wasm/index.js +28 -0
- package/koni/api/xcm/index.d.ts +13 -0
- package/koni/api/xcm/index.js +141 -0
- package/koni/api/xcm/polkadotXcm.d.ts +3 -0
- package/koni/api/xcm/polkadotXcm.js +52 -0
- package/koni/api/xcm/utils.d.ts +16 -0
- package/koni/api/xcm/utils.js +52 -0
- package/koni/api/xcm/xTokens.d.ts +3 -0
- package/koni/api/xcm/xTokens.js +55 -0
- package/koni/api/xcm/xcmPallet.d.ts +3 -0
- package/koni/api/xcm/xcmPallet.js +46 -0
- package/koni/background/cron.d.ts +37 -0
- package/koni/background/cron.js +195 -0
- package/koni/background/events.d.ts +1 -0
- package/koni/background/events.js +7 -0
- package/koni/background/handlers/Extension.d.ts +183 -0
- package/koni/background/handlers/Extension.js +3016 -0
- package/koni/background/handlers/Mobile.d.ts +21 -0
- package/koni/background/handlers/Mobile.js +127 -0
- package/koni/background/handlers/State.d.ts +224 -0
- package/koni/background/handlers/State.js +1377 -0
- package/koni/background/handlers/Tabs.d.ts +47 -0
- package/koni/background/handlers/Tabs.js +746 -0
- package/koni/background/handlers/index.d.ts +13 -0
- package/koni/background/handlers/index.js +76 -0
- package/koni/background/subscription.d.ts +32 -0
- package/koni/background/subscription.js +267 -0
- package/koni/page/SubWalleEvmProvider.d.ts +27 -0
- package/koni/page/SubWalleEvmProvider.js +132 -0
- package/koni/page/index.d.ts +2 -0
- package/koni/page/index.js +9 -0
- package/package.json +1423 -10
- package/packageInfo.js +1 -1
- package/page/index.js +3 -2
- package/services/balance-service/index.d.ts +9 -0
- package/services/balance-service/index.js +101 -0
- package/services/chain-service/constants.d.ts +78 -0
- package/services/chain-service/constants.js +213 -0
- package/services/chain-service/handler/EvmChainHandler.d.ts +16 -0
- package/services/chain-service/handler/EvmChainHandler.js +136 -0
- package/services/chain-service/handler/SubstrateChainHandler.d.ts +21 -0
- package/services/chain-service/handler/SubstrateChainHandler.js +340 -0
- package/services/chain-service/handler/light-client/index.d.ts +4 -0
- package/services/chain-service/handler/light-client/index.js +111 -0
- package/services/chain-service/handler/types.d.ts +26 -0
- package/services/chain-service/handler/types.js +14 -0
- package/services/chain-service/heath-check/index.d.ts +3 -0
- package/services/chain-service/heath-check/index.js +50 -0
- package/services/chain-service/helper/api-helper/chain/crust-maxwell.d.ts +98 -0
- package/services/chain-service/helper/api-helper/chain/crust-maxwell.js +103 -0
- package/services/chain-service/helper/api-helper/chain/index.d.ts +1943 -0
- package/services/chain-service/helper/api-helper/chain/index.js +11 -0
- package/services/chain-service/helper/api-helper/index.d.ts +7 -0
- package/services/chain-service/helper/api-helper/index.js +18 -0
- package/services/chain-service/helper/api-helper/spec/acala.d.ts +42 -0
- package/services/chain-service/helper/api-helper/spec/acala.js +5 -0
- package/services/chain-service/helper/api-helper/spec/ajuna.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/ajuna.js +15 -0
- package/services/chain-service/helper/api-helper/spec/altair.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/altair.js +24 -0
- package/services/chain-service/helper/api-helper/spec/apron.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/apron.js +17 -0
- package/services/chain-service/helper/api-helper/spec/ares-gladios.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/ares-gladios.js +184 -0
- package/services/chain-service/helper/api-helper/spec/ares-parachain.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/ares-parachain.js +185 -0
- package/services/chain-service/helper/api-helper/spec/astar.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/astar.js +37 -0
- package/services/chain-service/helper/api-helper/spec/automata.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/automata.js +36 -0
- package/services/chain-service/helper/api-helper/spec/basilisk.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/basilisk.js +132 -0
- package/services/chain-service/helper/api-helper/spec/beresheet.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/beresheet.js +9 -0
- package/services/chain-service/helper/api-helper/spec/bifrost-asgard.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/bifrost-asgard.js +5 -0
- package/services/chain-service/helper/api-helper/spec/bifrost-parachain.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/bifrost-parachain.js +5 -0
- package/services/chain-service/helper/api-helper/spec/bifrost.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/bifrost.js +5 -0
- package/services/chain-service/helper/api-helper/spec/bitcountry-pioneer.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/bitcountry-pioneer.js +5 -0
- package/services/chain-service/helper/api-helper/spec/bitcountry-rococo.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/bitcountry-rococo.js +115 -0
- package/services/chain-service/helper/api-helper/spec/bitcountry.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/bitcountry.js +77 -0
- package/services/chain-service/helper/api-helper/spec/canvas.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/canvas.js +24 -0
- package/services/chain-service/helper/api-helper/spec/centrifuge-chain.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/centrifuge-chain.js +70 -0
- package/services/chain-service/helper/api-helper/spec/centrifuge.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/centrifuge.js +24 -0
- package/services/chain-service/helper/api-helper/spec/chainx.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/chainx.js +396 -0
- package/services/chain-service/helper/api-helper/spec/clover-rococo.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/clover-rococo.js +61 -0
- package/services/chain-service/helper/api-helper/spec/clover.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/clover.js +27 -0
- package/services/chain-service/helper/api-helper/spec/coinversation.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/coinversation.js +17 -0
- package/services/chain-service/helper/api-helper/spec/competitors-club.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/competitors-club.js +77 -0
- package/services/chain-service/helper/api-helper/spec/crab.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/crab.js +5 -0
- package/services/chain-service/helper/api-helper/spec/crown-sterling.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/crown-sterling.js +48 -0
- package/services/chain-service/helper/api-helper/spec/crust.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/crust.js +5 -0
- package/services/chain-service/helper/api-helper/spec/cumulus-test-parachain.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/cumulus-test-parachain.js +17 -0
- package/services/chain-service/helper/api-helper/spec/darwinia.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/darwinia.js +5 -0
- package/services/chain-service/helper/api-helper/spec/datahighway.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/datahighway.js +233 -0
- package/services/chain-service/helper/api-helper/spec/dock-mainnet.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/dock-mainnet.js +9 -0
- package/services/chain-service/helper/api-helper/spec/dock-testnet.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/dock-testnet.js +9 -0
- package/services/chain-service/helper/api-helper/spec/dolphin.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/dolphin.js +22 -0
- package/services/chain-service/helper/api-helper/spec/dotmog.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/dotmog.js +58 -0
- package/services/chain-service/helper/api-helper/spec/eave.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/eave.js +409 -0
- package/services/chain-service/helper/api-helper/spec/edgeware.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/edgeware.js +7 -0
- package/services/chain-service/helper/api-helper/spec/encointer-node-notee.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/encointer-node-notee.js +68 -0
- package/services/chain-service/helper/api-helper/spec/encointer-node-teeproxy.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/encointer-node-teeproxy.js +45 -0
- package/services/chain-service/helper/api-helper/spec/encointer-para.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/encointer-para.js +72 -0
- package/services/chain-service/helper/api-helper/spec/equilibrium.d.ts +8 -0
- package/services/chain-service/helper/api-helper/spec/equilibrium.js +97 -0
- package/services/chain-service/helper/api-helper/spec/fantour.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/fantour.js +63 -0
- package/services/chain-service/helper/api-helper/spec/galital-parachain.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/galital-parachain.js +58 -0
- package/services/chain-service/helper/api-helper/spec/galital.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/galital.js +63 -0
- package/services/chain-service/helper/api-helper/spec/galois.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/galois.js +47 -0
- package/services/chain-service/helper/api-helper/spec/gamepower.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/gamepower.js +64 -0
- package/services/chain-service/helper/api-helper/spec/genshiro.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/genshiro.js +24 -0
- package/services/chain-service/helper/api-helper/spec/hanonycash.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/hanonycash.js +26 -0
- package/services/chain-service/helper/api-helper/spec/hydrate.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/hydrate.js +52 -0
- package/services/chain-service/helper/api-helper/spec/idavoll.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/idavoll.js +17 -0
- package/services/chain-service/helper/api-helper/spec/index.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/index.js +264 -0
- package/services/chain-service/helper/api-helper/spec/integritee.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/integritee.js +28 -0
- package/services/chain-service/helper/api-helper/spec/interbtc.d.ts +7 -0
- package/services/chain-service/helper/api-helper/spec/interbtc.js +50 -0
- package/services/chain-service/helper/api-helper/spec/ipse.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/ipse.js +106 -0
- package/services/chain-service/helper/api-helper/spec/jupiter-rococo.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/jupiter-rococo.js +17 -0
- package/services/chain-service/helper/api-helper/spec/jupiter.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/jupiter.js +63 -0
- package/services/chain-service/helper/api-helper/spec/khala.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/khala.js +5 -0
- package/services/chain-service/helper/api-helper/spec/kilt.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/kilt.js +5 -0
- package/services/chain-service/helper/api-helper/spec/konomi.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/konomi.js +17 -0
- package/services/chain-service/helper/api-helper/spec/kpron.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/kpron.js +17 -0
- package/services/chain-service/helper/api-helper/spec/kulupu.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/kulupu.js +57 -0
- package/services/chain-service/helper/api-helper/spec/kusari.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/kusari.js +38 -0
- package/services/chain-service/helper/api-helper/spec/kylin.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/kylin.js +29 -0
- package/services/chain-service/helper/api-helper/spec/laminar.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/laminar.js +5 -0
- package/services/chain-service/helper/api-helper/spec/litentry.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/litentry.js +17 -0
- package/services/chain-service/helper/api-helper/spec/mangata.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/mangata.js +13 -0
- package/services/chain-service/helper/api-helper/spec/manta.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/manta.js +22 -0
- package/services/chain-service/helper/api-helper/spec/mathchain.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/mathchain.js +47 -0
- package/services/chain-service/helper/api-helper/spec/moonbeam.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/moonbeam.js +5 -0
- package/services/chain-service/helper/api-helper/spec/moonsama-development.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/moonsama-development.js +17 -0
- package/services/chain-service/helper/api-helper/spec/mybank.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/mybank.js +80 -0
- package/services/chain-service/helper/api-helper/spec/neatcoin.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/neatcoin.js +25 -0
- package/services/chain-service/helper/api-helper/spec/neumann.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/neumann.js +48 -0
- package/services/chain-service/helper/api-helper/spec/nftmart.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/nftmart.js +127 -0
- package/services/chain-service/helper/api-helper/spec/nodle.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/nodle.js +46 -0
- package/services/chain-service/helper/api-helper/spec/opal.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/opal.js +9 -0
- package/services/chain-service/helper/api-helper/spec/opportunity.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/opportunity.js +5 -0
- package/services/chain-service/helper/api-helper/spec/origintrail.d.ts +5 -0
- package/services/chain-service/helper/api-helper/spec/origintrail.js +198 -0
- package/services/chain-service/helper/api-helper/spec/pangolin.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/pangolin.js +5 -0
- package/services/chain-service/helper/api-helper/spec/pangoro.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/pangoro.js +7 -0
- package/services/chain-service/helper/api-helper/spec/parallel.d.ts +14 -0
- package/services/chain-service/helper/api-helper/spec/parallel.js +5 -0
- package/services/chain-service/helper/api-helper/spec/parami.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/parami.js +14 -0
- package/services/chain-service/helper/api-helper/spec/phoenix.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/phoenix.js +45 -0
- package/services/chain-service/helper/api-helper/spec/pichiu.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/pichiu.js +29 -0
- package/services/chain-service/helper/api-helper/spec/plasm.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/plasm.js +47 -0
- package/services/chain-service/helper/api-helper/spec/polkadex.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/polkadex.js +25 -0
- package/services/chain-service/helper/api-helper/spec/polkafoundry.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/polkafoundry.js +36 -0
- package/services/chain-service/helper/api-helper/spec/polymesh.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/polymesh.js +13 -0
- package/services/chain-service/helper/api-helper/spec/pontem.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/pontem.js +5 -0
- package/services/chain-service/helper/api-helper/spec/prism.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/prism.js +17 -0
- package/services/chain-service/helper/api-helper/spec/quartz.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/quartz.js +9 -0
- package/services/chain-service/helper/api-helper/spec/realis.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/realis.js +35 -0
- package/services/chain-service/helper/api-helper/spec/riochain.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/riochain.js +97 -0
- package/services/chain-service/helper/api-helper/spec/robonomics.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/robonomics.js +34 -0
- package/services/chain-service/helper/api-helper/spec/shibuya.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/shibuya.js +47 -0
- package/services/chain-service/helper/api-helper/spec/shiden.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/shiden.js +47 -0
- package/services/chain-service/helper/api-helper/spec/snowbridge.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/snowbridge.js +5 -0
- package/services/chain-service/helper/api-helper/spec/soraSubstrate.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/soraSubstrate.js +5 -0
- package/services/chain-service/helper/api-helper/spec/spanner.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/spanner.js +494 -0
- package/services/chain-service/helper/api-helper/spec/stafi.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/stafi.js +18 -0
- package/services/chain-service/helper/api-helper/spec/standard.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/standard.js +5 -0
- package/services/chain-service/helper/api-helper/spec/subdao.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/subdao.js +14 -0
- package/services/chain-service/helper/api-helper/spec/subgame.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/subgame.js +178 -0
- package/services/chain-service/helper/api-helper/spec/subsocial.d.ts +2 -0
- package/services/chain-service/helper/api-helper/spec/subsocial.js +8 -0
- package/services/chain-service/helper/api-helper/spec/subspace.d.ts +0 -0
- package/services/chain-service/helper/api-helper/spec/subspace.js +126 -0
- package/services/chain-service/helper/api-helper/spec/substrateContractsNode.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/substrateContractsNode.js +16 -0
- package/services/chain-service/helper/api-helper/spec/swapdex.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/swapdex.js +38 -0
- package/services/chain-service/helper/api-helper/spec/ternoa.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/ternoa.js +88 -0
- package/services/chain-service/helper/api-helper/spec/trustbase.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/trustbase.js +17 -0
- package/services/chain-service/helper/api-helper/spec/uart.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/uart.js +282 -0
- package/services/chain-service/helper/api-helper/spec/unique.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/unique.js +117 -0
- package/services/chain-service/helper/api-helper/spec/unitv.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/unitv.js +18 -0
- package/services/chain-service/helper/api-helper/spec/vln-rococo.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/vln-rococo.js +102 -0
- package/services/chain-service/helper/api-helper/spec/vln.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/vln.js +38 -0
- package/services/chain-service/helper/api-helper/spec/vodka.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/vodka.js +15 -0
- package/services/chain-service/helper/api-helper/spec/web3games.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/web3games.js +36 -0
- package/services/chain-service/helper/api-helper/spec/westlake.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/westlake.js +298 -0
- package/services/chain-service/helper/api-helper/spec/zCloak.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/zCloak.js +39 -0
- package/services/chain-service/helper/api-helper/spec/zeitgeist.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/zeitgeist.js +24 -0
- package/services/chain-service/helper/api-helper/spec/zenlink.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/zenlink.js +50 -0
- package/services/chain-service/helper/api-helper/spec/zero.d.ts +3 -0
- package/services/chain-service/helper/api-helper/spec/zero.js +5 -0
- package/services/chain-service/helper/api-helper/util.d.ts +5 -0
- package/services/chain-service/helper/api-helper/util.js +15 -0
- package/services/chain-service/helper/erc20_abi.json +224 -0
- package/services/chain-service/helper/erc721_abi.json +384 -0
- package/services/chain-service/helper/index.d.ts +5 -0
- package/services/chain-service/helper/index.js +13 -0
- package/services/chain-service/helper/psp22_abi.json +967 -0
- package/services/chain-service/helper/psp34_abi.json +1988 -0
- package/services/chain-service/helper/test_erc721_abi.json +393 -0
- package/services/chain-service/index.d.ts +102 -0
- package/services/chain-service/index.js +1139 -0
- package/services/chain-service/types.d.ts +110 -0
- package/services/chain-service/types.js +17 -0
- package/services/chain-service/utils.d.ts +64 -0
- package/services/chain-service/utils.js +321 -0
- package/services/history-service/index.d.ts +22 -0
- package/services/history-service/index.js +102 -0
- package/services/history-service/subsquid-multi-chain-history.d.ts +30 -0
- package/services/history-service/subsquid-multi-chain-history.js +251 -0
- package/services/migration-service/Base.d.ts +8 -0
- package/services/migration-service/Base.js +13 -0
- package/services/migration-service/index.d.ts +7 -0
- package/services/migration-service/index.js +37 -0
- package/services/migration-service/scripts/ClearOldStorage.d.ts +4 -0
- package/services/migration-service/scripts/ClearOldStorage.js +11 -0
- package/services/migration-service/scripts/MigrateImportedToken.d.ts +4 -0
- package/services/migration-service/scripts/MigrateImportedToken.js +40 -0
- package/services/migration-service/scripts/MigrateNetworkSettings.d.ts +4 -0
- package/services/migration-service/scripts/MigrateNetworkSettings.js +30 -0
- package/services/migration-service/scripts/index.d.ts +3 -0
- package/services/migration-service/scripts/index.js +10 -0
- package/services/notification-service/NotificationService.d.ts +8 -0
- package/services/notification-service/NotificationService.js +46 -0
- package/services/price-service/coingecko.d.ts +2 -0
- package/services/price-service/coingecko.js +31 -0
- package/services/price-service/index.d.ts +16 -0
- package/services/price-service/index.js +71 -0
- package/services/request-service/constants.d.ts +1 -0
- package/services/request-service/constants.js +4 -0
- package/services/request-service/handler/AuthRequestHandler.d.ts +29 -0
- package/services/request-service/handler/AuthRequestHandler.js +253 -0
- package/services/request-service/handler/EvmRequestHandler.d.ts +19 -0
- package/services/request-service/handler/EvmRequestHandler.js +207 -0
- package/services/request-service/handler/MetadataRequestHandler.d.ts +18 -0
- package/services/request-service/handler/MetadataRequestHandler.js +75 -0
- package/services/request-service/handler/PopupHandler.d.ts +9 -0
- package/services/request-service/handler/PopupHandler.js +79 -0
- package/services/request-service/handler/SubstrateRequestHandler.d.ts +17 -0
- package/services/request-service/handler/SubstrateRequestHandler.js +94 -0
- package/services/request-service/helper/index.d.ts +4 -0
- package/services/request-service/helper/index.js +67 -0
- package/services/request-service/index.d.ts +46 -0
- package/services/request-service/index.js +147 -0
- package/services/request-service/types.d.ts +25 -0
- package/services/request-service/types.js +1 -0
- package/services/setting-service/SettingService.d.ts +8 -0
- package/services/setting-service/SettingService.js +31 -0
- package/services/setting-service/constants.d.ts +3 -0
- package/services/setting-service/constants.js +6 -0
- package/services/storage-service/DatabaseService.d.ts +64 -0
- package/services/storage-service/DatabaseService.js +219 -0
- package/services/storage-service/databases/index.d.ts +45 -0
- package/services/storage-service/databases/index.js +37 -0
- package/services/storage-service/db-stores/Asset.d.ts +6 -0
- package/services/storage-service/db-stores/Asset.js +12 -0
- package/services/storage-service/db-stores/Balance.d.ts +7 -0
- package/services/storage-service/db-stores/Balance.js +24 -0
- package/services/storage-service/db-stores/BaseStore.d.ts +11 -0
- package/services/storage-service/db-stores/BaseStore.js +22 -0
- package/services/storage-service/db-stores/BaseStoreWithAddress.d.ts +5 -0
- package/services/storage-service/db-stores/BaseStoreWithAddress.js +20 -0
- package/services/storage-service/db-stores/BaseStoreWithAddressAndChain.d.ts +7 -0
- package/services/storage-service/db-stores/BaseStoreWithAddressAndChain.js +25 -0
- package/services/storage-service/db-stores/BaseStoreWithChain.d.ts +5 -0
- package/services/storage-service/db-stores/BaseStoreWithChain.js +12 -0
- package/services/storage-service/db-stores/Chain.d.ts +6 -0
- package/services/storage-service/db-stores/Chain.js +12 -0
- package/services/storage-service/db-stores/ChainStakingMetadata.d.ts +9 -0
- package/services/storage-service/db-stores/ChainStakingMetadata.js +29 -0
- package/services/storage-service/db-stores/Crowdloan.d.ts +6 -0
- package/services/storage-service/db-stores/Crowdloan.js +15 -0
- package/services/storage-service/db-stores/Migration.d.ts +4 -0
- package/services/storage-service/db-stores/Migration.js +5 -0
- package/services/storage-service/db-stores/Nft.d.ts +12 -0
- package/services/storage-service/db-stores/Nft.js +61 -0
- package/services/storage-service/db-stores/NftCollection.d.ts +7 -0
- package/services/storage-service/db-stores/NftCollection.js +22 -0
- package/services/storage-service/db-stores/NominatorMetadata.d.ts +9 -0
- package/services/storage-service/db-stores/NominatorMetadata.js +22 -0
- package/services/storage-service/db-stores/Price.d.ts +4 -0
- package/services/storage-service/db-stores/Price.js +5 -0
- package/services/storage-service/db-stores/Staking.d.ts +9 -0
- package/services/storage-service/db-stores/Staking.js +29 -0
- package/services/storage-service/db-stores/Transaction.d.ts +12 -0
- package/services/storage-service/db-stores/Transaction.js +41 -0
- package/services/storage-service/db-stores/index.d.ts +10 -0
- package/services/storage-service/db-stores/index.js +13 -0
- package/services/transaction-service/event-parser/index.d.ts +5 -0
- package/services/transaction-service/event-parser/index.js +96 -0
- package/services/transaction-service/helpers/index.d.ts +5 -0
- package/services/transaction-service/helpers/index.js +14 -0
- package/services/transaction-service/index.d.ts +44 -0
- package/services/transaction-service/index.js +693 -0
- package/services/transaction-service/types.d.ts +48 -0
- package/services/transaction-service/types.js +1 -0
- package/services/transaction-service/utils.d.ts +4 -0
- package/services/transaction-service/utils.js +25 -0
- package/signers/substrates/KeyringSigner.d.ts +1 -1
- package/stores/AccountRef.d.ts +5 -0
- package/stores/AccountRef.js +10 -0
- package/stores/Accounts.d.ts +1 -1
- package/stores/Application.d.ts +7 -0
- package/stores/Application.js +20 -0
- package/stores/AssetSetting.d.ts +5 -0
- package/stores/AssetSetting.js +12 -0
- package/stores/Authorize.d.ts +5 -0
- package/stores/Authorize.js +10 -0
- package/stores/CurrentAccountStore.d.ts +5 -0
- package/stores/CurrentAccountStore.js +10 -0
- package/stores/Keyring.d.ts +7 -0
- package/stores/Keyring.js +32 -0
- package/stores/Settings.d.ts +5 -0
- package/stores/Settings.js +10 -0
- package/stores/SubscribableStore.d.ts +9 -0
- package/stores/SubscribableStore.js +25 -0
- package/stores/TransactionHistory.d.ts +6 -0
- package/stores/TransactionHistory.js +29 -0
- package/stores/TransactionHistoryV2.d.ts +5 -0
- package/stores/TransactionHistoryV2.js +10 -0
- package/stores/TransactionHistoryV3.d.ts +5 -0
- package/stores/TransactionHistoryV3.js +10 -0
- package/stores/index.d.ts +1 -0
- package/stores/index.js +2 -1
- package/utils/address.d.ts +1 -0
- package/utils/address.js +10 -0
- package/utils/eth/mergeTransactionAndSignature.d.ts +2 -0
- package/utils/eth/mergeTransactionAndSignature.js +14 -0
- package/utils/eth/parseTransaction/base.d.ts +17 -0
- package/utils/eth/parseTransaction/base.js +273 -0
- package/utils/eth/parseTransaction/index.d.ts +6 -0
- package/utils/eth/parseTransaction/index.js +220 -0
- package/utils/eth.d.ts +18 -0
- package/utils/eth.js +64 -0
- package/utils/index.d.ts +37 -0
- package/utils/index.js +273 -2
- package/utils/keyring.d.ts +4 -0
- package/utils/keyring.js +49 -0
- package/utils/request.d.ts +1 -0
- package/utils/request.js +7 -0
- package/errors/SubWalletProviderError.d.ts +0 -6
|
@@ -0,0 +1,1377 @@
|
|
|
1
|
+
// Copyright 2019-2022 @subwallet/extension-koni authors & contributors
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
|
|
4
|
+
import { ChainInfoMap } from '@subwallet/chain-list';
|
|
5
|
+
import { EvmProviderError } from '@subwallet/extension-base/background/errors/EvmProviderError';
|
|
6
|
+
import { withErrorLog } from '@subwallet/extension-base/background/handlers/helpers';
|
|
7
|
+
import { isSubscriptionRunning, unsubscribe } from '@subwallet/extension-base/background/handlers/subscriptions';
|
|
8
|
+
import { APIItemState, BasicTxErrorType, ChainType, EvmProviderErrorType, ExternalRequestPromiseStatus, ExtrinsicType } from '@subwallet/extension-base/background/KoniTypes';
|
|
9
|
+
import { ALL_ACCOUNT_KEY, ALL_GENESIS_HASH } from '@subwallet/extension-base/constants';
|
|
10
|
+
import { BalanceService } from '@subwallet/extension-base/services/balance-service';
|
|
11
|
+
import { ChainService } from '@subwallet/extension-base/services/chain-service';
|
|
12
|
+
import { _PREDEFINED_SINGLE_MODES } from '@subwallet/extension-base/services/chain-service/constants';
|
|
13
|
+
import { _getEvmChainId, _getSubstrateGenesisHash, _isAssetFungibleToken, _isChainEnabled, _isChainTestNet, _isSubstrateParachain, _parseMetadataForSmartContractAsset } from '@subwallet/extension-base/services/chain-service/utils';
|
|
14
|
+
import { HistoryService } from '@subwallet/extension-base/services/history-service';
|
|
15
|
+
import MigrationService from '@subwallet/extension-base/services/migration-service';
|
|
16
|
+
import NotificationService from '@subwallet/extension-base/services/notification-service/NotificationService';
|
|
17
|
+
import { PriceService } from '@subwallet/extension-base/services/price-service';
|
|
18
|
+
import RequestService from '@subwallet/extension-base/services/request-service';
|
|
19
|
+
import SettingService from '@subwallet/extension-base/services/setting-service/SettingService';
|
|
20
|
+
import DatabaseService from '@subwallet/extension-base/services/storage-service/DatabaseService';
|
|
21
|
+
import TransactionService from '@subwallet/extension-base/services/transaction-service';
|
|
22
|
+
import { CurrentAccountStore } from '@subwallet/extension-base/stores';
|
|
23
|
+
import AccountRefStore from '@subwallet/extension-base/stores/AccountRef';
|
|
24
|
+
import { isContractAddress, parseContractInput } from '@subwallet/extension-base/utils/eth/parseTransaction';
|
|
25
|
+
import { decodePair } from '@subwallet/keyring/pair/decode';
|
|
26
|
+
import { keyring } from '@subwallet/ui-keyring';
|
|
27
|
+
import { accounts } from '@subwallet/ui-keyring/observable/accounts';
|
|
28
|
+
import SimpleKeyring from 'eth-simple-keyring';
|
|
29
|
+
import { Subject } from 'rxjs';
|
|
30
|
+
import { assert, BN, hexStripPrefix, hexToU8a, isHex, logger as createLogger, u8aToHex } from '@polkadot/util';
|
|
31
|
+
import { base64Decode, isEthereumAddress, keyExtractSuri } from '@polkadot/util-crypto';
|
|
32
|
+
import { KoniCron } from "../cron.js";
|
|
33
|
+
import { KoniSubscription } from "../subscription.js";
|
|
34
|
+
const ETH_DERIVE_DEFAULT = '/m/44\'/60\'/0\'/0/0';
|
|
35
|
+
|
|
36
|
+
// List of providers passed into constructor. This is the list of providers
|
|
37
|
+
// exposed by the extension.
|
|
38
|
+
|
|
39
|
+
const getSuri = (seed, type) => {
|
|
40
|
+
return type === 'ethereum' ? `${seed}${ETH_DERIVE_DEFAULT}` : seed;
|
|
41
|
+
};
|
|
42
|
+
const generateDefaultCrowdloanMap = () => {
|
|
43
|
+
const crowdloanMap = {};
|
|
44
|
+
Object.entries(ChainInfoMap).forEach(([networkKey, chainInfo]) => {
|
|
45
|
+
if (_isSubstrateParachain(chainInfo)) {
|
|
46
|
+
crowdloanMap[networkKey] = {
|
|
47
|
+
state: APIItemState.PENDING,
|
|
48
|
+
contribute: '0'
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
return crowdloanMap;
|
|
53
|
+
};
|
|
54
|
+
export default class KoniState {
|
|
55
|
+
injectedProviders = new Map();
|
|
56
|
+
unsubscriptionMap = {};
|
|
57
|
+
currentAccountStore = new CurrentAccountStore();
|
|
58
|
+
accountRefStore = new AccountRefStore();
|
|
59
|
+
keyringStateSubject = new Subject();
|
|
60
|
+
externalRequest = {};
|
|
61
|
+
keyringState = {
|
|
62
|
+
isReady: false,
|
|
63
|
+
isLocked: true,
|
|
64
|
+
hasMasterPassword: false
|
|
65
|
+
};
|
|
66
|
+
serviceInfoSubject = new Subject();
|
|
67
|
+
balanceMap = {};
|
|
68
|
+
balanceSubject = new Subject();
|
|
69
|
+
crowdloanMap = generateDefaultCrowdloanMap();
|
|
70
|
+
crowdloanSubject = new Subject();
|
|
71
|
+
nftSubject = new Subject();
|
|
72
|
+
stakingSubject = new Subject();
|
|
73
|
+
chainStakingMetadataSubject = new Subject();
|
|
74
|
+
stakingNominatorMetadataSubject = new Subject();
|
|
75
|
+
stakingRewardSubject = new Subject();
|
|
76
|
+
stakingRewardState = {
|
|
77
|
+
ready: false,
|
|
78
|
+
slowInterval: [],
|
|
79
|
+
fastInterval: []
|
|
80
|
+
};
|
|
81
|
+
lazyMap = {};
|
|
82
|
+
ready = false;
|
|
83
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
84
|
+
constructor(providers = {}) {
|
|
85
|
+
this.providers = providers;
|
|
86
|
+
this.dbService = new DatabaseService();
|
|
87
|
+
this.notificationService = new NotificationService();
|
|
88
|
+
this.chainService = new ChainService(this.dbService);
|
|
89
|
+
this.settingService = new SettingService();
|
|
90
|
+
this.requestService = new RequestService(this.chainService, this.settingService);
|
|
91
|
+
this.priceService = new PriceService(this.serviceInfoSubject, this.dbService, this.chainService);
|
|
92
|
+
this.balanceService = new BalanceService(this.chainService);
|
|
93
|
+
this.historyService = new HistoryService(this.dbService, this.chainService);
|
|
94
|
+
this.transactionService = new TransactionService(this.chainService, this.requestService, this.balanceService, this.historyService, this.notificationService, this.dbService);
|
|
95
|
+
this.migrationService = new MigrationService(this);
|
|
96
|
+
this.subscription = new KoniSubscription(this, this.dbService);
|
|
97
|
+
this.cron = new KoniCron(this, this.subscription, this.dbService);
|
|
98
|
+
this.logger = createLogger('State');
|
|
99
|
+
|
|
100
|
+
// Init state
|
|
101
|
+
this.init().catch(console.error);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// Clone from polkadot.js
|
|
105
|
+
get knownMetadata() {
|
|
106
|
+
return this.requestService.knownMetadata;
|
|
107
|
+
}
|
|
108
|
+
injectMetadata(url, request) {
|
|
109
|
+
return this.requestService.injectMetadata(url, request);
|
|
110
|
+
}
|
|
111
|
+
getMetaRequest(id) {
|
|
112
|
+
return this.requestService.getMetaRequest(id);
|
|
113
|
+
}
|
|
114
|
+
getSignRequest(id) {
|
|
115
|
+
return this.requestService.getSignRequest(id);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// List all providers the extension is exposing
|
|
119
|
+
rpcListProviders() {
|
|
120
|
+
return Promise.resolve(Object.keys(this.providers).reduce((acc, key) => {
|
|
121
|
+
acc[key] = this.providers[key].meta;
|
|
122
|
+
return acc;
|
|
123
|
+
}, {}));
|
|
124
|
+
}
|
|
125
|
+
rpcSend(request, port) {
|
|
126
|
+
const provider = this.injectedProviders.get(port);
|
|
127
|
+
assert(provider, 'Cannot call pub(rpc.subscribe) before provider is set');
|
|
128
|
+
return provider.send(request.method, request.params);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
// Start a provider, return its meta
|
|
132
|
+
rpcStartProvider(key, port) {
|
|
133
|
+
assert(Object.keys(this.providers).includes(key), `Provider ${key} is not exposed by extension`);
|
|
134
|
+
if (this.injectedProviders.get(port)) {
|
|
135
|
+
return Promise.resolve(this.providers[key].meta);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
// Instantiate the provider
|
|
139
|
+
this.injectedProviders.set(port, this.providers[key].start());
|
|
140
|
+
|
|
141
|
+
// Close provider connection when page is closed
|
|
142
|
+
port.onDisconnect.addListener(() => {
|
|
143
|
+
const provider = this.injectedProviders.get(port);
|
|
144
|
+
if (provider) {
|
|
145
|
+
withErrorLog(() => provider.disconnect());
|
|
146
|
+
}
|
|
147
|
+
this.injectedProviders.delete(port);
|
|
148
|
+
});
|
|
149
|
+
return Promise.resolve(this.providers[key].meta);
|
|
150
|
+
}
|
|
151
|
+
rpcSubscribe({
|
|
152
|
+
method,
|
|
153
|
+
params,
|
|
154
|
+
type
|
|
155
|
+
}, cb, port) {
|
|
156
|
+
const provider = this.injectedProviders.get(port);
|
|
157
|
+
assert(provider, 'Cannot call pub(rpc.subscribe) before provider is set');
|
|
158
|
+
return provider.subscribe(type, method, params, cb);
|
|
159
|
+
}
|
|
160
|
+
rpcSubscribeConnected(_request, cb, port) {
|
|
161
|
+
const provider = this.injectedProviders.get(port);
|
|
162
|
+
assert(provider, 'Cannot call pub(rpc.subscribeConnected) before provider is set');
|
|
163
|
+
cb(null, provider.isConnected); // Immediately send back current isConnected
|
|
164
|
+
provider.on('connected', () => cb(null, true));
|
|
165
|
+
provider.on('disconnected', () => cb(null, false));
|
|
166
|
+
}
|
|
167
|
+
rpcUnsubscribe(request, port) {
|
|
168
|
+
const provider = this.injectedProviders.get(port);
|
|
169
|
+
assert(provider, 'Cannot call pub(rpc.unsubscribe) before provider is set');
|
|
170
|
+
return provider.unsubscribe(request.type, request.method, request.subscriptionId);
|
|
171
|
+
}
|
|
172
|
+
saveMetadata(meta) {
|
|
173
|
+
this.requestService.saveMetadata(meta);
|
|
174
|
+
}
|
|
175
|
+
sign(url, request, account) {
|
|
176
|
+
return this.requestService.sign(url, request, account);
|
|
177
|
+
}
|
|
178
|
+
get authSubjectV2() {
|
|
179
|
+
return this.requestService.authSubjectV2;
|
|
180
|
+
}
|
|
181
|
+
generateDefaultBalanceMap() {
|
|
182
|
+
const balanceMap = {};
|
|
183
|
+
const activeChains = this.chainService.getActiveChainInfoMap();
|
|
184
|
+
Object.values(activeChains).forEach(chainInfo => {
|
|
185
|
+
const chainAssetMap = this.chainService.getFungibleTokensByChain(chainInfo.slug);
|
|
186
|
+
Object.keys(chainAssetMap).forEach(assetSlug => {
|
|
187
|
+
balanceMap[assetSlug] = {
|
|
188
|
+
tokenSlug: assetSlug,
|
|
189
|
+
free: '',
|
|
190
|
+
locked: '',
|
|
191
|
+
state: APIItemState.PENDING
|
|
192
|
+
};
|
|
193
|
+
});
|
|
194
|
+
});
|
|
195
|
+
return balanceMap;
|
|
196
|
+
}
|
|
197
|
+
async init() {
|
|
198
|
+
await this.chainService.init();
|
|
199
|
+
await this.migrationService.run();
|
|
200
|
+
this.startSubscription();
|
|
201
|
+
this.updateServiceInfo();
|
|
202
|
+
this.onReady();
|
|
203
|
+
this.logger.log('Done init state');
|
|
204
|
+
}
|
|
205
|
+
startSubscription() {
|
|
206
|
+
this.dbService.subscribeChainStakingMetadata([], data => {
|
|
207
|
+
this.chainStakingMetadataSubject.next(data);
|
|
208
|
+
});
|
|
209
|
+
this.dbService.subscribeNominatorMetadata(data => {
|
|
210
|
+
this.stakingNominatorMetadataSubject.next(data);
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
onReady() {
|
|
214
|
+
this.subscription.start();
|
|
215
|
+
this.cron.start();
|
|
216
|
+
this.ready = true;
|
|
217
|
+
this.logger.log('State is ready');
|
|
218
|
+
}
|
|
219
|
+
isReady() {
|
|
220
|
+
return this.ready;
|
|
221
|
+
}
|
|
222
|
+
getKeyringState() {
|
|
223
|
+
return this.keyringState;
|
|
224
|
+
}
|
|
225
|
+
subscribeKeyringState() {
|
|
226
|
+
return this.keyringStateSubject;
|
|
227
|
+
}
|
|
228
|
+
setKeyringState(data, callback) {
|
|
229
|
+
this.keyringStateSubject.next(data);
|
|
230
|
+
this.keyringState = data;
|
|
231
|
+
callback && callback();
|
|
232
|
+
}
|
|
233
|
+
lazyNext = (key, callback) => {
|
|
234
|
+
if (this.lazyMap[key]) {
|
|
235
|
+
// @ts-ignore
|
|
236
|
+
clearTimeout(this.lazyMap[key]);
|
|
237
|
+
}
|
|
238
|
+
const lazy = setTimeout(() => {
|
|
239
|
+
callback();
|
|
240
|
+
clearTimeout(lazy);
|
|
241
|
+
}, 300);
|
|
242
|
+
this.lazyMap[key] = lazy;
|
|
243
|
+
};
|
|
244
|
+
getAuthRequestV2(id) {
|
|
245
|
+
return this.requestService.getAuthRequestV2(id);
|
|
246
|
+
}
|
|
247
|
+
setAuthorize(data, callback) {
|
|
248
|
+
this.requestService.setAuthorize(data, callback);
|
|
249
|
+
}
|
|
250
|
+
getAuthorize(update) {
|
|
251
|
+
this.requestService.getAuthorize(update);
|
|
252
|
+
}
|
|
253
|
+
subscribeEvmChainChange() {
|
|
254
|
+
return this.requestService.subscribeEvmChainChange;
|
|
255
|
+
}
|
|
256
|
+
subscribeAuthorizeUrlSubject() {
|
|
257
|
+
return this.requestService.subscribeAuthorizeUrlSubject;
|
|
258
|
+
}
|
|
259
|
+
getAuthList() {
|
|
260
|
+
return this.requestService.getAuthList();
|
|
261
|
+
}
|
|
262
|
+
getAddressList(value = false) {
|
|
263
|
+
const addressList = Object.keys(accounts.subject.value);
|
|
264
|
+
return addressList.reduce((addressList, v) => ({
|
|
265
|
+
...addressList,
|
|
266
|
+
[v]: value
|
|
267
|
+
}), {});
|
|
268
|
+
}
|
|
269
|
+
async authorizeUrlV2(url, request) {
|
|
270
|
+
return this.requestService.authorizeUrlV2(url, request);
|
|
271
|
+
}
|
|
272
|
+
getNativeTokenInfo(networkKey) {
|
|
273
|
+
return this.chainService.getNativeTokenInfo(networkKey);
|
|
274
|
+
}
|
|
275
|
+
getChainInfo(networkKey) {
|
|
276
|
+
return this.chainService.getChainInfoByKey(networkKey);
|
|
277
|
+
}
|
|
278
|
+
async getChainStakingMetadata() {
|
|
279
|
+
return this.dbService.getChainStakingMetadata();
|
|
280
|
+
}
|
|
281
|
+
async getStakingMetadataByChain(chain, type) {
|
|
282
|
+
return this.dbService.getStakingMetadataByChain(chain, type);
|
|
283
|
+
}
|
|
284
|
+
async getNominatorMetadata() {
|
|
285
|
+
return this.dbService.getNominatorMetadata();
|
|
286
|
+
}
|
|
287
|
+
async getStaking() {
|
|
288
|
+
const addresses = await this.getDecodedAddresses();
|
|
289
|
+
const stakings = await this.dbService.getStakings(addresses, this.activeChainSlugs);
|
|
290
|
+
return {
|
|
291
|
+
ready: true,
|
|
292
|
+
details: stakings
|
|
293
|
+
};
|
|
294
|
+
}
|
|
295
|
+
async getStakingOwnersByChains(chains) {
|
|
296
|
+
const stakings = await this.dbService.getStakingsByChains(chains);
|
|
297
|
+
const addresses = [];
|
|
298
|
+
stakings.forEach(staking => {
|
|
299
|
+
if (!addresses.includes(staking.address)) {
|
|
300
|
+
addresses.push(staking.address);
|
|
301
|
+
}
|
|
302
|
+
});
|
|
303
|
+
return addresses;
|
|
304
|
+
}
|
|
305
|
+
async getPooledStakingRecordsByAddress(addresses) {
|
|
306
|
+
return await this.dbService.getPooledStakings(addresses, this.activeChainSlugs);
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
// TODO: delete later
|
|
310
|
+
// public async getStoredStaking (address: string) {
|
|
311
|
+
// const items = await this.dbService.stores.staking.getDataByAddressAsObject(address);
|
|
312
|
+
//
|
|
313
|
+
// return items || {};
|
|
314
|
+
// }
|
|
315
|
+
|
|
316
|
+
subscribeStaking() {
|
|
317
|
+
return this.stakingSubject;
|
|
318
|
+
}
|
|
319
|
+
subscribeChainStakingMetadata() {
|
|
320
|
+
return this.chainStakingMetadataSubject;
|
|
321
|
+
}
|
|
322
|
+
subscribeNominatorMetadata() {
|
|
323
|
+
return this.stakingNominatorMetadataSubject;
|
|
324
|
+
}
|
|
325
|
+
ensureUrlAuthorizedV2(url) {
|
|
326
|
+
return this.requestService.ensureUrlAuthorizedV2(url);
|
|
327
|
+
}
|
|
328
|
+
setStakingItem(networkKey, item) {
|
|
329
|
+
this.dbService.updateStaking(networkKey, item.address, item).catch(e => this.logger.warn(e));
|
|
330
|
+
}
|
|
331
|
+
updateChainStakingMetadata(item) {
|
|
332
|
+
this.dbService.updateChainStakingMetadata(item).catch(e => this.logger.warn(e));
|
|
333
|
+
}
|
|
334
|
+
updateStakingNominatorMetadata(item) {
|
|
335
|
+
this.dbService.updateNominatorMetadata(item).catch(e => this.logger.warn(e));
|
|
336
|
+
}
|
|
337
|
+
setNftCollection(network, data, callback) {
|
|
338
|
+
this.dbService.addNftCollection(data).catch(e => this.logger.warn(e));
|
|
339
|
+
callback && callback(data);
|
|
340
|
+
}
|
|
341
|
+
getNftCollection() {
|
|
342
|
+
return this.dbService.getAllNftCollection(this.activeChainSlugs);
|
|
343
|
+
}
|
|
344
|
+
subscribeNftCollection() {
|
|
345
|
+
return this.dbService.stores.nftCollection.subscribeNftCollection(this.activeChainSlugs);
|
|
346
|
+
}
|
|
347
|
+
async resetNft(newAddress) {
|
|
348
|
+
this.getNft().then(data => this.nftSubject.next(data || {
|
|
349
|
+
nftList: [],
|
|
350
|
+
total: 0
|
|
351
|
+
})).catch(e => this.logger.warn(e));
|
|
352
|
+
const addresses = await this.getDecodedAddresses(newAddress);
|
|
353
|
+
this.dbService.subscribeNft(addresses, this.activeChainSlugs, nfts => {
|
|
354
|
+
this.nftSubject.next({
|
|
355
|
+
nftList: nfts,
|
|
356
|
+
total: nfts.length
|
|
357
|
+
});
|
|
358
|
+
});
|
|
359
|
+
}
|
|
360
|
+
updateNftData(network, nftData, address, callback) {
|
|
361
|
+
this.dbService.addNft(address, nftData).catch(e => this.logger.warn(e));
|
|
362
|
+
callback && callback(nftData);
|
|
363
|
+
}
|
|
364
|
+
removeNfts(chain, address, collectionId, nftIds) {
|
|
365
|
+
return this.dbService.removeNfts(chain, address, collectionId, nftIds);
|
|
366
|
+
}
|
|
367
|
+
deleteNftCollection(chain, collectionId) {
|
|
368
|
+
return this.dbService.deleteNftCollection(chain, collectionId);
|
|
369
|
+
}
|
|
370
|
+
async getNft() {
|
|
371
|
+
const addresses = await this.getDecodedAddresses();
|
|
372
|
+
if (!addresses.length) {
|
|
373
|
+
return;
|
|
374
|
+
}
|
|
375
|
+
const nfts = await this.dbService.getNft(addresses, this.activeChainSlugs);
|
|
376
|
+
return {
|
|
377
|
+
nftList: nfts,
|
|
378
|
+
total: nfts.length
|
|
379
|
+
};
|
|
380
|
+
}
|
|
381
|
+
subscribeNft() {
|
|
382
|
+
return this.nftSubject;
|
|
383
|
+
}
|
|
384
|
+
resetStakingReward() {
|
|
385
|
+
this.stakingRewardState.slowInterval = [];
|
|
386
|
+
this.stakingRewardSubject.next(this.stakingRewardState);
|
|
387
|
+
}
|
|
388
|
+
updateStakingReward(stakingRewardData, type, callback) {
|
|
389
|
+
this.stakingRewardState.ready = true;
|
|
390
|
+
this.stakingRewardState[type] = stakingRewardData;
|
|
391
|
+
if (callback) {
|
|
392
|
+
callback(this.stakingRewardState);
|
|
393
|
+
}
|
|
394
|
+
this.stakingRewardSubject.next(this.stakingRewardState);
|
|
395
|
+
}
|
|
396
|
+
updateStakingRewardReady(ready) {
|
|
397
|
+
this.stakingRewardState.ready = ready;
|
|
398
|
+
this.stakingRewardSubject.next(this.stakingRewardState);
|
|
399
|
+
}
|
|
400
|
+
getAccountRefMap(callback) {
|
|
401
|
+
const refMap = {};
|
|
402
|
+
this.accountRefStore.get('refList', refList => {
|
|
403
|
+
if (refList) {
|
|
404
|
+
refList.forEach(accRef => {
|
|
405
|
+
accRef.forEach(acc => {
|
|
406
|
+
refMap[acc] = [...accRef].filter(r => !(r === acc));
|
|
407
|
+
});
|
|
408
|
+
});
|
|
409
|
+
}
|
|
410
|
+
callback(refMap);
|
|
411
|
+
});
|
|
412
|
+
}
|
|
413
|
+
addAccountRef(addresses, callback) {
|
|
414
|
+
this.accountRefStore.get('refList', refList => {
|
|
415
|
+
const newList = refList ? [...refList] : [];
|
|
416
|
+
newList.push(addresses);
|
|
417
|
+
this.accountRefStore.set('refList', newList, callback);
|
|
418
|
+
});
|
|
419
|
+
}
|
|
420
|
+
removeAccountRef(address, callback) {
|
|
421
|
+
this.accountRefStore.get('refList', refList => {
|
|
422
|
+
if (refList) {
|
|
423
|
+
refList.forEach(accRef => {
|
|
424
|
+
if (accRef.indexOf(address) > -1) {
|
|
425
|
+
accRef.splice(accRef.indexOf(address), 1);
|
|
426
|
+
}
|
|
427
|
+
if (accRef.length < 2) {
|
|
428
|
+
refList.splice(refList.indexOf(accRef), 1);
|
|
429
|
+
}
|
|
430
|
+
});
|
|
431
|
+
this.accountRefStore.set('refList', refList, () => {
|
|
432
|
+
callback();
|
|
433
|
+
});
|
|
434
|
+
} else {
|
|
435
|
+
callback();
|
|
436
|
+
}
|
|
437
|
+
});
|
|
438
|
+
}
|
|
439
|
+
getStakingReward(update) {
|
|
440
|
+
update(this.stakingRewardState);
|
|
441
|
+
}
|
|
442
|
+
subscribeStakingReward() {
|
|
443
|
+
return this.stakingRewardSubject;
|
|
444
|
+
}
|
|
445
|
+
getCurrentAccount(update) {
|
|
446
|
+
this.currentAccountStore.get('CurrentAccountInfo', update);
|
|
447
|
+
}
|
|
448
|
+
setCurrentAccount(data, callback) {
|
|
449
|
+
const {
|
|
450
|
+
address,
|
|
451
|
+
currentGenesisHash
|
|
452
|
+
} = data;
|
|
453
|
+
const result = {
|
|
454
|
+
...data
|
|
455
|
+
};
|
|
456
|
+
if (address === ALL_ACCOUNT_KEY) {
|
|
457
|
+
const pairs = keyring.getPairs();
|
|
458
|
+
const pair = pairs[0];
|
|
459
|
+
const pairGenesisHash = pair.meta.genesisHash;
|
|
460
|
+
if (pairs.length > 1 || !pair) {
|
|
461
|
+
result.allGenesisHash = currentGenesisHash || undefined;
|
|
462
|
+
} else {
|
|
463
|
+
result.address = pair.address;
|
|
464
|
+
result.currentGenesisHash = pairGenesisHash || '';
|
|
465
|
+
result.allGenesisHash = pairGenesisHash || undefined;
|
|
466
|
+
}
|
|
467
|
+
}
|
|
468
|
+
this.currentAccountStore.set('CurrentAccountInfo', result, () => {
|
|
469
|
+
this.updateServiceInfo();
|
|
470
|
+
callback && callback();
|
|
471
|
+
});
|
|
472
|
+
}
|
|
473
|
+
setAccountTie(address, genesisHash) {
|
|
474
|
+
if (address !== ALL_ACCOUNT_KEY) {
|
|
475
|
+
const pair = keyring.getPair(address);
|
|
476
|
+
assert(pair, 'Unable to find pair');
|
|
477
|
+
keyring.saveAccountMeta(pair, {
|
|
478
|
+
...pair.meta,
|
|
479
|
+
genesisHash
|
|
480
|
+
});
|
|
481
|
+
}
|
|
482
|
+
this.getCurrentAccount(accountInfo => {
|
|
483
|
+
if (address === accountInfo.address) {
|
|
484
|
+
accountInfo.currentGenesisHash = genesisHash || ALL_GENESIS_HASH;
|
|
485
|
+
this.setCurrentAccount(accountInfo);
|
|
486
|
+
}
|
|
487
|
+
});
|
|
488
|
+
return true;
|
|
489
|
+
}
|
|
490
|
+
async switchEvmNetworkByUrl(shortenUrl, networkKey) {
|
|
491
|
+
const authUrls = await this.getAuthList();
|
|
492
|
+
const chainInfo = this.chainService.getChainInfoByKey(networkKey);
|
|
493
|
+
const chainState = this.chainService.getChainStateByKey(networkKey);
|
|
494
|
+
if (authUrls[shortenUrl]) {
|
|
495
|
+
if (chainInfo && !_isChainEnabled(chainState)) {
|
|
496
|
+
await this.enableChain(networkKey);
|
|
497
|
+
}
|
|
498
|
+
authUrls[shortenUrl].currentEvmNetworkKey = networkKey;
|
|
499
|
+
this.setAuthorize(authUrls);
|
|
500
|
+
} else {
|
|
501
|
+
throw new EvmProviderError(EvmProviderErrorType.INTERNAL_ERROR, `Not found ${shortenUrl} in auth list`);
|
|
502
|
+
}
|
|
503
|
+
}
|
|
504
|
+
async switchNetworkAccount(id, url, networkKey, changeAddress) {
|
|
505
|
+
const chainInfo = this.chainService.getChainInfoByKey(networkKey);
|
|
506
|
+
const chainState = this.chainService.getChainStateByKey(networkKey);
|
|
507
|
+
const {
|
|
508
|
+
address,
|
|
509
|
+
currentGenesisHash
|
|
510
|
+
} = await new Promise(resolve => {
|
|
511
|
+
this.getCurrentAccount(resolve);
|
|
512
|
+
});
|
|
513
|
+
return this.requestService.addConfirmation(id, url, 'switchNetworkRequest', {
|
|
514
|
+
networkKey,
|
|
515
|
+
address: changeAddress
|
|
516
|
+
}, {
|
|
517
|
+
address: changeAddress
|
|
518
|
+
}).then(({
|
|
519
|
+
isApproved
|
|
520
|
+
}) => {
|
|
521
|
+
if (isApproved) {
|
|
522
|
+
const useAddress = changeAddress || address;
|
|
523
|
+
if (chainInfo && !_isChainEnabled(chainState)) {
|
|
524
|
+
this.enableChain(networkKey).catch(console.error);
|
|
525
|
+
}
|
|
526
|
+
if (useAddress !== ALL_ACCOUNT_KEY) {
|
|
527
|
+
const pair = keyring.getPair(useAddress);
|
|
528
|
+
assert(pair, 'Unable to find pair');
|
|
529
|
+
keyring.saveAccountMeta(pair, {
|
|
530
|
+
...pair.meta,
|
|
531
|
+
genesisHash: _getSubstrateGenesisHash(chainInfo)
|
|
532
|
+
});
|
|
533
|
+
}
|
|
534
|
+
if (address !== changeAddress || _getSubstrateGenesisHash(chainInfo) !== currentGenesisHash || isApproved) {
|
|
535
|
+
this.setCurrentAccount({
|
|
536
|
+
address: useAddress,
|
|
537
|
+
currentGenesisHash: _getSubstrateGenesisHash(chainInfo)
|
|
538
|
+
});
|
|
539
|
+
}
|
|
540
|
+
}
|
|
541
|
+
return isApproved;
|
|
542
|
+
});
|
|
543
|
+
}
|
|
544
|
+
async addNetworkConfirm(id, url, networkData) {
|
|
545
|
+
return this.requestService.addConfirmation(id, url, 'addNetworkRequest', networkData).then(async ({
|
|
546
|
+
isApproved
|
|
547
|
+
}) => {
|
|
548
|
+
if (isApproved) {
|
|
549
|
+
await this.upsertChainInfo(networkData);
|
|
550
|
+
return null;
|
|
551
|
+
} else {
|
|
552
|
+
throw new EvmProviderError(EvmProviderErrorType.USER_REJECTED_REQUEST);
|
|
553
|
+
}
|
|
554
|
+
});
|
|
555
|
+
}
|
|
556
|
+
async addTokenConfirm(id, url, tokenInfo) {
|
|
557
|
+
return this.requestService.addConfirmation(id, url, 'addTokenRequest', tokenInfo).then(async ({
|
|
558
|
+
isApproved
|
|
559
|
+
}) => {
|
|
560
|
+
if (isApproved) {
|
|
561
|
+
await this.upsertCustomToken({
|
|
562
|
+
originChain: tokenInfo.originChain,
|
|
563
|
+
slug: '',
|
|
564
|
+
name: tokenInfo.name,
|
|
565
|
+
symbol: tokenInfo.symbol,
|
|
566
|
+
decimals: tokenInfo.decimals,
|
|
567
|
+
priceId: null,
|
|
568
|
+
minAmount: null,
|
|
569
|
+
assetType: tokenInfo.type,
|
|
570
|
+
metadata: _parseMetadataForSmartContractAsset(tokenInfo.contractAddress),
|
|
571
|
+
multiChainAsset: null,
|
|
572
|
+
hasValue: _isChainTestNet(this.chainService.getChainInfoByKey(tokenInfo.originChain))
|
|
573
|
+
});
|
|
574
|
+
return isApproved;
|
|
575
|
+
} else {
|
|
576
|
+
throw new EvmProviderError(EvmProviderErrorType.USER_REJECTED_REQUEST);
|
|
577
|
+
}
|
|
578
|
+
});
|
|
579
|
+
}
|
|
580
|
+
get metaSubject() {
|
|
581
|
+
return this.requestService.metaSubject;
|
|
582
|
+
}
|
|
583
|
+
get signSubject() {
|
|
584
|
+
return this.requestService.signSubject;
|
|
585
|
+
}
|
|
586
|
+
getSettings(callback) {
|
|
587
|
+
this.settingService.getSettings(callback);
|
|
588
|
+
}
|
|
589
|
+
setSettings(settings, callback) {
|
|
590
|
+
this.settingService.setSettings(settings, callback);
|
|
591
|
+
}
|
|
592
|
+
setTheme(theme, callback) {
|
|
593
|
+
this.settingService.getSettings(settings => {
|
|
594
|
+
const newSettings = {
|
|
595
|
+
...settings,
|
|
596
|
+
theme
|
|
597
|
+
};
|
|
598
|
+
this.settingService.setSettings(newSettings, () => {
|
|
599
|
+
callback && callback(newSettings);
|
|
600
|
+
});
|
|
601
|
+
});
|
|
602
|
+
}
|
|
603
|
+
setBrowserConfirmationType(browserConfirmationType, callback) {
|
|
604
|
+
this.settingService.getSettings(settings => {
|
|
605
|
+
const newSettings = {
|
|
606
|
+
...settings,
|
|
607
|
+
browserConfirmationType
|
|
608
|
+
};
|
|
609
|
+
this.settingService.setSettings(newSettings, () => {
|
|
610
|
+
callback && callback(newSettings);
|
|
611
|
+
});
|
|
612
|
+
});
|
|
613
|
+
}
|
|
614
|
+
setCamera(value) {
|
|
615
|
+
this.settingService.getSettings(settings => {
|
|
616
|
+
const newSettings = {
|
|
617
|
+
...settings,
|
|
618
|
+
camera: value
|
|
619
|
+
};
|
|
620
|
+
console.log(newSettings, value);
|
|
621
|
+
this.settingService.setSettings(newSettings);
|
|
622
|
+
});
|
|
623
|
+
}
|
|
624
|
+
subscribeSettingsSubject() {
|
|
625
|
+
return this.settingService.getSubject();
|
|
626
|
+
}
|
|
627
|
+
subscribeCurrentAccount() {
|
|
628
|
+
return this.currentAccountStore.getSubject();
|
|
629
|
+
}
|
|
630
|
+
getAccountAddress() {
|
|
631
|
+
return new Promise((resolve, reject) => {
|
|
632
|
+
this.getCurrentAccount(account => {
|
|
633
|
+
if (account) {
|
|
634
|
+
resolve(account.address);
|
|
635
|
+
} else {
|
|
636
|
+
resolve(null);
|
|
637
|
+
}
|
|
638
|
+
});
|
|
639
|
+
});
|
|
640
|
+
}
|
|
641
|
+
async getDecodedAddresses(address) {
|
|
642
|
+
let checkingAddress = address;
|
|
643
|
+
if (!address) {
|
|
644
|
+
checkingAddress = await this.getAccountAddress();
|
|
645
|
+
}
|
|
646
|
+
if (!checkingAddress) {
|
|
647
|
+
return [];
|
|
648
|
+
}
|
|
649
|
+
if (checkingAddress === ALL_ACCOUNT_KEY) {
|
|
650
|
+
return Object.keys(accounts.subject.value);
|
|
651
|
+
}
|
|
652
|
+
return [checkingAddress];
|
|
653
|
+
}
|
|
654
|
+
getAllAddresses() {
|
|
655
|
+
return Object.keys(accounts.subject.value);
|
|
656
|
+
}
|
|
657
|
+
removeInactiveChainBalances(balanceMap) {
|
|
658
|
+
const activeBalanceMap = {};
|
|
659
|
+
Object.entries(balanceMap).forEach(([tokenSlug, balanceItem]) => {
|
|
660
|
+
const tokenInfo = this.chainService.getAssetBySlug(tokenSlug);
|
|
661
|
+
if (tokenInfo) {
|
|
662
|
+
const chainInfo = this.chainService.getChainInfoByKey(tokenInfo.originChain);
|
|
663
|
+
if (chainInfo && this.getChainStateByKey(chainInfo.slug).active) {
|
|
664
|
+
activeBalanceMap[tokenSlug] = balanceItem;
|
|
665
|
+
}
|
|
666
|
+
}
|
|
667
|
+
});
|
|
668
|
+
return activeBalanceMap;
|
|
669
|
+
}
|
|
670
|
+
getBalance(reset) {
|
|
671
|
+
const activeData = this.removeInactiveChainBalances(this.balanceMap);
|
|
672
|
+
return {
|
|
673
|
+
details: activeData,
|
|
674
|
+
reset
|
|
675
|
+
};
|
|
676
|
+
}
|
|
677
|
+
async getStoredBalance(address) {
|
|
678
|
+
const items = await this.dbService.stores.balance.getBalanceMapByAddress(address);
|
|
679
|
+
return items || {};
|
|
680
|
+
}
|
|
681
|
+
async switchAccount(newAddress) {
|
|
682
|
+
await Promise.all([this.resetBalanceMap(newAddress), this.resetCrowdloanMap(newAddress)]);
|
|
683
|
+
}
|
|
684
|
+
async resetBalanceMap(newAddress) {
|
|
685
|
+
const defaultData = this.generateDefaultBalanceMap();
|
|
686
|
+
let storedData = await this.getStoredBalance(newAddress);
|
|
687
|
+
storedData = this.removeInactiveChainBalances(storedData);
|
|
688
|
+
this.balanceMap = {
|
|
689
|
+
...defaultData,
|
|
690
|
+
...storedData
|
|
691
|
+
};
|
|
692
|
+
this.publishBalance(true);
|
|
693
|
+
}
|
|
694
|
+
async resetCrowdloanMap(newAddress) {
|
|
695
|
+
const defaultData = generateDefaultCrowdloanMap();
|
|
696
|
+
const storedData = await this.getStoredCrowdloan(newAddress);
|
|
697
|
+
this.crowdloanMap = {
|
|
698
|
+
...defaultData,
|
|
699
|
+
...storedData
|
|
700
|
+
};
|
|
701
|
+
this.publishCrowdloan(true);
|
|
702
|
+
}
|
|
703
|
+
async resetStaking(newAddress) {
|
|
704
|
+
this.getStaking().then(data => {
|
|
705
|
+
this.stakingSubject.next(data);
|
|
706
|
+
}).catch(e => this.logger.warn(e));
|
|
707
|
+
const addresses = await this.getDecodedAddresses(newAddress);
|
|
708
|
+
this.dbService.subscribeStaking(addresses, this.activeChainSlugs, stakings => {
|
|
709
|
+
this.stakingSubject.next({
|
|
710
|
+
ready: true,
|
|
711
|
+
details: stakings
|
|
712
|
+
});
|
|
713
|
+
});
|
|
714
|
+
}
|
|
715
|
+
setBalanceItem(tokenSlug, item) {
|
|
716
|
+
this.balanceMap[tokenSlug] = {
|
|
717
|
+
timestamp: +new Date(),
|
|
718
|
+
...item
|
|
719
|
+
};
|
|
720
|
+
this.updateBalanceStore(item);
|
|
721
|
+
this.lazyNext('setBalanceItem', () => {
|
|
722
|
+
this.publishBalance();
|
|
723
|
+
});
|
|
724
|
+
}
|
|
725
|
+
updateBalanceStore(item) {
|
|
726
|
+
this.getCurrentAccount(currentAccountInfo => {
|
|
727
|
+
this.dbService.updateBalanceStore(currentAccountInfo.address, item).catch(e => this.logger.warn(e));
|
|
728
|
+
});
|
|
729
|
+
}
|
|
730
|
+
subscribeBalance() {
|
|
731
|
+
return this.balanceSubject;
|
|
732
|
+
}
|
|
733
|
+
getCrowdloan(reset) {
|
|
734
|
+
return {
|
|
735
|
+
details: this.crowdloanMap,
|
|
736
|
+
reset
|
|
737
|
+
};
|
|
738
|
+
}
|
|
739
|
+
async getStoredCrowdloan(address) {
|
|
740
|
+
const items = await this.dbService.stores.crowdloan.getDataByAddressAsObject(address);
|
|
741
|
+
return items || {};
|
|
742
|
+
}
|
|
743
|
+
setCrowdloanItem(networkKey, item) {
|
|
744
|
+
const itemData = {
|
|
745
|
+
...item,
|
|
746
|
+
timestamp: +new Date()
|
|
747
|
+
};
|
|
748
|
+
|
|
749
|
+
// Update crowdloan map
|
|
750
|
+
this.crowdloanMap[networkKey] = itemData;
|
|
751
|
+
this.updateCrowdloanStore(networkKey, itemData);
|
|
752
|
+
this.lazyNext('setCrowdloanItem', () => {
|
|
753
|
+
this.publishCrowdloan();
|
|
754
|
+
});
|
|
755
|
+
}
|
|
756
|
+
updateCrowdloanStore(networkKey, item) {
|
|
757
|
+
this.getCurrentAccount(currentAccountInfo => {
|
|
758
|
+
this.dbService.updateCrowdloanStore(networkKey, currentAccountInfo.address, item).catch(e => this.logger.warn(e));
|
|
759
|
+
});
|
|
760
|
+
}
|
|
761
|
+
subscribeCrowdloan() {
|
|
762
|
+
return this.crowdloanSubject;
|
|
763
|
+
}
|
|
764
|
+
getAllPriceIds() {
|
|
765
|
+
return this.chainService.getAllPriceIds();
|
|
766
|
+
}
|
|
767
|
+
getSmartContractNfts() {
|
|
768
|
+
return this.chainService.getSmartContractNfts();
|
|
769
|
+
}
|
|
770
|
+
|
|
771
|
+
// ChainService ------------------------------------------------
|
|
772
|
+
|
|
773
|
+
getChainInfoMap() {
|
|
774
|
+
return this.chainService.getChainInfoMap();
|
|
775
|
+
}
|
|
776
|
+
getChainStateMap() {
|
|
777
|
+
return this.chainService.getChainStateMap();
|
|
778
|
+
}
|
|
779
|
+
getAssetRefMap() {
|
|
780
|
+
return this.chainService.getAssetRefMap();
|
|
781
|
+
}
|
|
782
|
+
getChainStateByKey(key) {
|
|
783
|
+
return this.chainService.getChainStateByKey(key);
|
|
784
|
+
}
|
|
785
|
+
getAssetRegistry() {
|
|
786
|
+
return this.chainService.getAssetRegistry();
|
|
787
|
+
}
|
|
788
|
+
getMultiChainAssetMap() {
|
|
789
|
+
return this.chainService.getMultiChainAssetMap();
|
|
790
|
+
}
|
|
791
|
+
getXcmRefMap() {
|
|
792
|
+
return this.chainService.getXcmRefMap();
|
|
793
|
+
}
|
|
794
|
+
getAssetByChainAndAsset(chain, assetTypes) {
|
|
795
|
+
return this.chainService.getAssetByChainAndType(chain, assetTypes);
|
|
796
|
+
}
|
|
797
|
+
getAssetBySlug(slug) {
|
|
798
|
+
return this.chainService.getAssetBySlug(slug);
|
|
799
|
+
}
|
|
800
|
+
getXcmEqualAssetByChain(destinationChain, originTokenSlug) {
|
|
801
|
+
return this.chainService.getXcmEqualAssetByChain(destinationChain, originTokenSlug);
|
|
802
|
+
}
|
|
803
|
+
subscribeChainInfoMap() {
|
|
804
|
+
return this.chainService.subscribeChainInfoMap();
|
|
805
|
+
}
|
|
806
|
+
subscribeChainStateMap() {
|
|
807
|
+
return this.chainService.subscribeChainStateMap();
|
|
808
|
+
}
|
|
809
|
+
subscribeAssetRegistry() {
|
|
810
|
+
return this.chainService.subscribeAssetRegistry();
|
|
811
|
+
}
|
|
812
|
+
subscribeMultiChainAssetMap() {
|
|
813
|
+
return this.chainService.subscribeMultiChainAssetMap();
|
|
814
|
+
}
|
|
815
|
+
subscribeXcmRefMap() {
|
|
816
|
+
return this.chainService.subscribeXcmRefMap();
|
|
817
|
+
}
|
|
818
|
+
async upsertCustomToken(data) {
|
|
819
|
+
const tokenSlug = this.chainService.upsertCustomToken(data);
|
|
820
|
+
if (_isAssetFungibleToken(data)) {
|
|
821
|
+
await this.chainService.updateAssetSetting(tokenSlug, {
|
|
822
|
+
visible: true
|
|
823
|
+
});
|
|
824
|
+
}
|
|
825
|
+
this.updateServiceInfo();
|
|
826
|
+
}
|
|
827
|
+
deleteCustomAssets(targetTokens) {
|
|
828
|
+
this.chainService.deleteCustomAssets(targetTokens);
|
|
829
|
+
this.updateServiceInfo();
|
|
830
|
+
}
|
|
831
|
+
async validateCustomChain(provider, existedChainSlug) {
|
|
832
|
+
return await this.chainService.validateCustomChain(provider, existedChainSlug);
|
|
833
|
+
}
|
|
834
|
+
getSupportedSmartContractTypes() {
|
|
835
|
+
return this.chainService.getSupportedSmartContractTypes();
|
|
836
|
+
}
|
|
837
|
+
async validateCustomAsset(data) {
|
|
838
|
+
return await this.chainService.validateCustomToken(data);
|
|
839
|
+
}
|
|
840
|
+
|
|
841
|
+
// ------------------------------------------------
|
|
842
|
+
|
|
843
|
+
getActiveChainInfoMap() {
|
|
844
|
+
return this.chainService.getActiveChainInfoMap();
|
|
845
|
+
}
|
|
846
|
+
async upsertChainInfo(data) {
|
|
847
|
+
const newNativeTokenSlug = this.chainService.upsertChain(data);
|
|
848
|
+
if (newNativeTokenSlug) {
|
|
849
|
+
await this.chainService.updateAssetSetting(newNativeTokenSlug, {
|
|
850
|
+
visible: true
|
|
851
|
+
});
|
|
852
|
+
}
|
|
853
|
+
this.updateServiceInfo();
|
|
854
|
+
return true;
|
|
855
|
+
}
|
|
856
|
+
removeCustomChain(networkKey) {
|
|
857
|
+
const result = this.chainService.removeCustomChain(networkKey);
|
|
858
|
+
this.updateServiceInfo();
|
|
859
|
+
return result;
|
|
860
|
+
}
|
|
861
|
+
|
|
862
|
+
// TODO: avoids turning off chains related to ledger account
|
|
863
|
+
getDefaultNetworkKeys = () => {
|
|
864
|
+
const genesisHashes = {};
|
|
865
|
+
const pairs = keyring.getPairs();
|
|
866
|
+
pairs.forEach(pair => {
|
|
867
|
+
const originGenesisHash = pair.meta.originGenesisHash;
|
|
868
|
+
if (originGenesisHash && typeof originGenesisHash === 'string') {
|
|
869
|
+
genesisHashes[originGenesisHash] = originGenesisHash;
|
|
870
|
+
}
|
|
871
|
+
});
|
|
872
|
+
const hashes = Object.keys(genesisHashes);
|
|
873
|
+
const result = [];
|
|
874
|
+
for (const [key, network] of Object.entries(this.chainService.getChainInfoMap())) {
|
|
875
|
+
const condition = hashes.includes(_getSubstrateGenesisHash(network) || '');
|
|
876
|
+
if (condition) {
|
|
877
|
+
result.push(key);
|
|
878
|
+
}
|
|
879
|
+
}
|
|
880
|
+
return result;
|
|
881
|
+
};
|
|
882
|
+
async disableChain(chainSlug) {
|
|
883
|
+
// const defaultChains = this.getDefaultNetworkKeys();
|
|
884
|
+
await this.chainService.updateAssetSettingByChain(chainSlug, false);
|
|
885
|
+
const result = this.chainService.disableChain(chainSlug);
|
|
886
|
+
this.updateServiceInfo();
|
|
887
|
+
return result;
|
|
888
|
+
}
|
|
889
|
+
async enableChain(chainSlug, enableTokens = true) {
|
|
890
|
+
if (enableTokens) {
|
|
891
|
+
await this.chainService.updateAssetSettingByChain(chainSlug, true);
|
|
892
|
+
}
|
|
893
|
+
const result = this.chainService.enableChain(chainSlug);
|
|
894
|
+
this.updateServiceInfo();
|
|
895
|
+
return result;
|
|
896
|
+
}
|
|
897
|
+
resetDefaultChains() {
|
|
898
|
+
const defaultChains = this.getDefaultNetworkKeys();
|
|
899
|
+
return this.chainService.resetChainInfoMap(defaultChains);
|
|
900
|
+
}
|
|
901
|
+
updateNetworkStatus(networkKey, status) {
|
|
902
|
+
const chainState = this.chainService.getChainStateByKey(networkKey);
|
|
903
|
+
if (chainState.connectionStatus === status) {
|
|
904
|
+
return;
|
|
905
|
+
}
|
|
906
|
+
this.chainService.setChainConnectionStatus(networkKey, status);
|
|
907
|
+
}
|
|
908
|
+
getSubstrateApiMap() {
|
|
909
|
+
return this.chainService.getSubstrateApiMap();
|
|
910
|
+
}
|
|
911
|
+
getSubstrateApi(networkKey) {
|
|
912
|
+
return this.chainService.getSubstrateApi(networkKey);
|
|
913
|
+
}
|
|
914
|
+
getEvmApiMap() {
|
|
915
|
+
return this.chainService.getEvmApiMap();
|
|
916
|
+
}
|
|
917
|
+
getEvmApi(networkKey) {
|
|
918
|
+
return this.chainService.getEvmApi(networkKey);
|
|
919
|
+
}
|
|
920
|
+
getApiMap() {
|
|
921
|
+
return {
|
|
922
|
+
substrate: this.chainService.getSubstrateApiMap(),
|
|
923
|
+
evm: this.chainService.getEvmApiMap()
|
|
924
|
+
};
|
|
925
|
+
}
|
|
926
|
+
refreshSubstrateApi(key) {
|
|
927
|
+
this.chainService.refreshSubstrateApi(key);
|
|
928
|
+
return true;
|
|
929
|
+
}
|
|
930
|
+
refreshWeb3Api(key) {
|
|
931
|
+
this.chainService.refreshEvmApi(key);
|
|
932
|
+
}
|
|
933
|
+
subscribeServiceInfo() {
|
|
934
|
+
return this.serviceInfoSubject;
|
|
935
|
+
}
|
|
936
|
+
updateServiceInfo() {
|
|
937
|
+
this.logger.log('<---Update serviceInfo--->');
|
|
938
|
+
this.getCurrentAccount(value => {
|
|
939
|
+
this.serviceInfoSubject.next({
|
|
940
|
+
chainInfoMap: this.chainService.getChainInfoMap(),
|
|
941
|
+
chainApiMap: this.getApiMap(),
|
|
942
|
+
currentAccountInfo: value,
|
|
943
|
+
assetRegistry: this.chainService.getAssetRegistry(),
|
|
944
|
+
chainStateMap: this.chainService.getChainStateMap()
|
|
945
|
+
});
|
|
946
|
+
});
|
|
947
|
+
}
|
|
948
|
+
getExternalRequestMap() {
|
|
949
|
+
return this.externalRequest;
|
|
950
|
+
}
|
|
951
|
+
setExternalRequestMap(id, value) {
|
|
952
|
+
this.externalRequest[id] = value;
|
|
953
|
+
}
|
|
954
|
+
getExternalRequest(id) {
|
|
955
|
+
return this.externalRequest[id];
|
|
956
|
+
}
|
|
957
|
+
updateExternalRequest(id, value) {
|
|
958
|
+
const rs = this.externalRequest[id];
|
|
959
|
+
if (rs) {
|
|
960
|
+
for (const [_key, _value] of Object.entries(value)) {
|
|
961
|
+
// @ts-ignore
|
|
962
|
+
rs[_key] = _value;
|
|
963
|
+
}
|
|
964
|
+
}
|
|
965
|
+
}
|
|
966
|
+
cleanExternalRequest() {
|
|
967
|
+
const now = new Date().getTime();
|
|
968
|
+
const map = this.externalRequest;
|
|
969
|
+
const arr = [];
|
|
970
|
+
const handlerPushToDelete = (key, value) => {
|
|
971
|
+
arr.push(key);
|
|
972
|
+
value.resolve = undefined;
|
|
973
|
+
value.reject = undefined;
|
|
974
|
+
};
|
|
975
|
+
for (const [key, value] of Object.entries(map)) {
|
|
976
|
+
if (value.status === ExternalRequestPromiseStatus.COMPLETED || value.status === ExternalRequestPromiseStatus.REJECTED) {
|
|
977
|
+
handlerPushToDelete(key, value);
|
|
978
|
+
} else {
|
|
979
|
+
if (now - value.createdAt > 15 * 60 * 60) {
|
|
980
|
+
handlerPushToDelete(key, value);
|
|
981
|
+
}
|
|
982
|
+
}
|
|
983
|
+
}
|
|
984
|
+
for (const key of arr) {
|
|
985
|
+
delete map[key];
|
|
986
|
+
}
|
|
987
|
+
}
|
|
988
|
+
pauseAllNetworks(code, reason) {
|
|
989
|
+
return this.chainService.stopAllChainApis();
|
|
990
|
+
}
|
|
991
|
+
async resumeAllNetworks() {
|
|
992
|
+
return this.chainService.resumeAllChainApis();
|
|
993
|
+
}
|
|
994
|
+
publishBalance(reset) {
|
|
995
|
+
this.balanceSubject.next(this.getBalance(reset));
|
|
996
|
+
}
|
|
997
|
+
publishCrowdloan(reset) {
|
|
998
|
+
this.crowdloanSubject.next(this.getCrowdloan(reset));
|
|
999
|
+
}
|
|
1000
|
+
|
|
1001
|
+
// private publishHistory () {
|
|
1002
|
+
// this.historySubject.next(this.getHistoryMap());
|
|
1003
|
+
// }
|
|
1004
|
+
|
|
1005
|
+
// private removeInactiveDataByChain<T> (data: Record<string, T>) {
|
|
1006
|
+
// const activeData: Record<string, T> = {};
|
|
1007
|
+
//
|
|
1008
|
+
// Object.entries(data).forEach(([networkKey, items]) => {
|
|
1009
|
+
// if (this.chainService.getChainStateByKey(networkKey).active) {
|
|
1010
|
+
// activeData[networkKey] = items;
|
|
1011
|
+
// }
|
|
1012
|
+
// });
|
|
1013
|
+
//
|
|
1014
|
+
// return activeData;
|
|
1015
|
+
// }
|
|
1016
|
+
|
|
1017
|
+
findNetworkKeyByGenesisHash(genesisHash) {
|
|
1018
|
+
if (!genesisHash) {
|
|
1019
|
+
return [undefined, undefined];
|
|
1020
|
+
}
|
|
1021
|
+
const rs = Object.entries(this.chainService.getChainInfoMap()).find(([networkKey, chainInfo]) => _getSubstrateGenesisHash(chainInfo) === genesisHash);
|
|
1022
|
+
if (rs) {
|
|
1023
|
+
return rs;
|
|
1024
|
+
} else {
|
|
1025
|
+
return [undefined, undefined];
|
|
1026
|
+
}
|
|
1027
|
+
}
|
|
1028
|
+
findChainIdGenesisHash(genesisHash) {
|
|
1029
|
+
const chainInfo = this.findNetworkKeyByGenesisHash(genesisHash)[1];
|
|
1030
|
+
return chainInfo ? _getEvmChainId(chainInfo) : undefined;
|
|
1031
|
+
}
|
|
1032
|
+
findNetworkKeyByChainId(chainId) {
|
|
1033
|
+
if (!chainId) {
|
|
1034
|
+
return [undefined, undefined];
|
|
1035
|
+
}
|
|
1036
|
+
const rs = Object.entries(this.chainService.getChainInfoMap()).find(([networkKey, chainInfo]) => _getEvmChainId(chainInfo) === chainId);
|
|
1037
|
+
if (rs) {
|
|
1038
|
+
return rs;
|
|
1039
|
+
} else {
|
|
1040
|
+
return [undefined, undefined];
|
|
1041
|
+
}
|
|
1042
|
+
}
|
|
1043
|
+
findSingleMode(genesisHash) {
|
|
1044
|
+
const [networkKey] = this.findNetworkKeyByGenesisHash(genesisHash);
|
|
1045
|
+
if (!networkKey) {
|
|
1046
|
+
return undefined;
|
|
1047
|
+
}
|
|
1048
|
+
return Object.values(_PREDEFINED_SINGLE_MODES).find(item => item.networkKeys.includes(networkKey));
|
|
1049
|
+
}
|
|
1050
|
+
accountExportPrivateKey({
|
|
1051
|
+
address,
|
|
1052
|
+
password
|
|
1053
|
+
}) {
|
|
1054
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
|
|
1055
|
+
const exportedJson = keyring.backupAccount(keyring.getPair(address), password);
|
|
1056
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
|
|
1057
|
+
const decoded = decodePair(password, base64Decode(exportedJson.encoded), exportedJson.encoding.type);
|
|
1058
|
+
return {
|
|
1059
|
+
privateKey: u8aToHex(decoded.secretKey),
|
|
1060
|
+
publicKey: u8aToHex(decoded.publicKey)
|
|
1061
|
+
};
|
|
1062
|
+
}
|
|
1063
|
+
checkPublicAndSecretKey({
|
|
1064
|
+
publicKey,
|
|
1065
|
+
secretKey
|
|
1066
|
+
}) {
|
|
1067
|
+
try {
|
|
1068
|
+
const _secret = hexStripPrefix(secretKey);
|
|
1069
|
+
if (_secret.length === 64) {
|
|
1070
|
+
const suri = `0x${_secret}`;
|
|
1071
|
+
const {
|
|
1072
|
+
phrase
|
|
1073
|
+
} = keyExtractSuri(suri);
|
|
1074
|
+
if (isHex(phrase) && isHex(phrase, 256)) {
|
|
1075
|
+
const type = 'ethereum';
|
|
1076
|
+
const address = keyring.createFromUri(getSuri(suri, type), {}, type).address;
|
|
1077
|
+
return {
|
|
1078
|
+
address: address,
|
|
1079
|
+
isValid: true,
|
|
1080
|
+
isEthereum: true
|
|
1081
|
+
};
|
|
1082
|
+
} else {
|
|
1083
|
+
return {
|
|
1084
|
+
address: '',
|
|
1085
|
+
isValid: false,
|
|
1086
|
+
isEthereum: true
|
|
1087
|
+
};
|
|
1088
|
+
}
|
|
1089
|
+
}
|
|
1090
|
+
const keyPair = keyring.keyring.addFromPair({
|
|
1091
|
+
publicKey: hexToU8a(publicKey),
|
|
1092
|
+
secretKey: hexToU8a(secretKey)
|
|
1093
|
+
});
|
|
1094
|
+
return {
|
|
1095
|
+
address: keyPair.address,
|
|
1096
|
+
isValid: true,
|
|
1097
|
+
isEthereum: false
|
|
1098
|
+
};
|
|
1099
|
+
} catch (e) {
|
|
1100
|
+
console.error(e);
|
|
1101
|
+
return {
|
|
1102
|
+
address: '',
|
|
1103
|
+
isValid: false,
|
|
1104
|
+
isEthereum: false
|
|
1105
|
+
};
|
|
1106
|
+
}
|
|
1107
|
+
}
|
|
1108
|
+
getEthKeyring(address, password) {
|
|
1109
|
+
return new Promise(resolve => {
|
|
1110
|
+
const {
|
|
1111
|
+
privateKey
|
|
1112
|
+
} = this.accountExportPrivateKey({
|
|
1113
|
+
address,
|
|
1114
|
+
password: password
|
|
1115
|
+
});
|
|
1116
|
+
const ethKeyring = new SimpleKeyring([privateKey]);
|
|
1117
|
+
resolve(ethKeyring);
|
|
1118
|
+
});
|
|
1119
|
+
}
|
|
1120
|
+
async evmSign(id, url, method, params, allowedAccounts) {
|
|
1121
|
+
let address = '';
|
|
1122
|
+
let payload;
|
|
1123
|
+
const [p1, p2] = params;
|
|
1124
|
+
if (typeof p1 === 'string' && isEthereumAddress(p1)) {
|
|
1125
|
+
address = p1;
|
|
1126
|
+
payload = p2;
|
|
1127
|
+
} else if (typeof p2 === 'string' && isEthereumAddress(p2)) {
|
|
1128
|
+
address = p2;
|
|
1129
|
+
payload = p1;
|
|
1130
|
+
}
|
|
1131
|
+
if (address === '' || !payload) {
|
|
1132
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Not found address or payload to sign');
|
|
1133
|
+
}
|
|
1134
|
+
if (['eth_sign', 'personal_sign', 'eth_signTypedData', 'eth_signTypedData_v1', 'eth_signTypedData_v3', 'eth_signTypedData_v4'].indexOf(method) < 0) {
|
|
1135
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Not found sign method');
|
|
1136
|
+
}
|
|
1137
|
+
if (['eth_signTypedData_v3', 'eth_signTypedData_v4'].indexOf(method) > -1) {
|
|
1138
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-assignment
|
|
1139
|
+
payload = JSON.parse(payload);
|
|
1140
|
+
}
|
|
1141
|
+
|
|
1142
|
+
// Check sign abiblity
|
|
1143
|
+
if (!allowedAccounts.find(acc => acc.toLowerCase() === address.toLowerCase())) {
|
|
1144
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Account ' + address + ' not in allowed list');
|
|
1145
|
+
}
|
|
1146
|
+
const pair = keyring.getPair(address);
|
|
1147
|
+
if (!pair) {
|
|
1148
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Cannot find pair with address: ' + address);
|
|
1149
|
+
}
|
|
1150
|
+
const account = {
|
|
1151
|
+
address: pair.address,
|
|
1152
|
+
...pair.meta
|
|
1153
|
+
};
|
|
1154
|
+
let qrPayload = '';
|
|
1155
|
+
let canSign = false;
|
|
1156
|
+
switch (method) {
|
|
1157
|
+
case 'personal_sign':
|
|
1158
|
+
canSign = true;
|
|
1159
|
+
qrPayload = payload;
|
|
1160
|
+
break;
|
|
1161
|
+
case 'eth_sign':
|
|
1162
|
+
case 'eth_signTypedData':
|
|
1163
|
+
case 'eth_signTypedData_v1':
|
|
1164
|
+
case 'eth_signTypedData_v3':
|
|
1165
|
+
case 'eth_signTypedData_v4':
|
|
1166
|
+
if (!account.isExternal) {
|
|
1167
|
+
canSign = true;
|
|
1168
|
+
}
|
|
1169
|
+
break;
|
|
1170
|
+
default:
|
|
1171
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Not found sign method');
|
|
1172
|
+
}
|
|
1173
|
+
const signPayload = {
|
|
1174
|
+
account: account,
|
|
1175
|
+
type: method,
|
|
1176
|
+
payload: payload,
|
|
1177
|
+
hashPayload: qrPayload,
|
|
1178
|
+
canSign: canSign,
|
|
1179
|
+
id
|
|
1180
|
+
};
|
|
1181
|
+
return this.requestService.addConfirmation(id, url, 'evmSignatureRequest', signPayload, {
|
|
1182
|
+
requiredPassword: false,
|
|
1183
|
+
address
|
|
1184
|
+
}).then(({
|
|
1185
|
+
isApproved,
|
|
1186
|
+
payload
|
|
1187
|
+
}) => {
|
|
1188
|
+
if (isApproved) {
|
|
1189
|
+
if (payload) {
|
|
1190
|
+
return payload;
|
|
1191
|
+
} else {
|
|
1192
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Not found signature');
|
|
1193
|
+
}
|
|
1194
|
+
} else {
|
|
1195
|
+
throw new EvmProviderError(EvmProviderErrorType.USER_REJECTED_REQUEST);
|
|
1196
|
+
}
|
|
1197
|
+
});
|
|
1198
|
+
}
|
|
1199
|
+
async evmSendTransaction(id, url, networkKey, allowedAccounts, transactionParams) {
|
|
1200
|
+
const evmApi = this.getEvmApi(networkKey);
|
|
1201
|
+
const evmNetwork = this.getChainInfo(networkKey);
|
|
1202
|
+
const web3 = evmApi.api;
|
|
1203
|
+
const autoFormatNumber = val => {
|
|
1204
|
+
if (typeof val === 'string' && val.startsWith('0x')) {
|
|
1205
|
+
return new BN(val.replace('0x', ''), 16).toString();
|
|
1206
|
+
} else if (typeof val === 'number') {
|
|
1207
|
+
return val.toString();
|
|
1208
|
+
}
|
|
1209
|
+
return val;
|
|
1210
|
+
};
|
|
1211
|
+
if (transactionParams.from === transactionParams.to) {
|
|
1212
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'From address and to address must not be the same');
|
|
1213
|
+
}
|
|
1214
|
+
const transaction = {
|
|
1215
|
+
from: transactionParams.from,
|
|
1216
|
+
to: transactionParams.to,
|
|
1217
|
+
value: autoFormatNumber(transactionParams.value),
|
|
1218
|
+
gasPrice: autoFormatNumber(transactionParams.gasPrice),
|
|
1219
|
+
maxPriorityFeePerGas: autoFormatNumber(transactionParams.maxPriorityFeePerGas),
|
|
1220
|
+
maxFeePerGas: autoFormatNumber(transactionParams.maxFeePerGas),
|
|
1221
|
+
data: transactionParams.data
|
|
1222
|
+
};
|
|
1223
|
+
|
|
1224
|
+
// Calculate transaction data
|
|
1225
|
+
try {
|
|
1226
|
+
transaction.gas = await web3.eth.estimateGas({
|
|
1227
|
+
...transaction
|
|
1228
|
+
});
|
|
1229
|
+
} catch (e) {
|
|
1230
|
+
// @ts-ignore
|
|
1231
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
|
|
1232
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, e === null || e === void 0 ? void 0 : e.message);
|
|
1233
|
+
}
|
|
1234
|
+
const gasPrice = await web3.eth.getGasPrice();
|
|
1235
|
+
transaction.gasPrice = gasPrice;
|
|
1236
|
+
const estimateGas = new BN(gasPrice.toString()).mul(new BN(transaction.gas)).toString();
|
|
1237
|
+
|
|
1238
|
+
// Address is validated in before step
|
|
1239
|
+
const fromAddress = allowedAccounts.find(account => account.toLowerCase() === transaction.from.toLowerCase());
|
|
1240
|
+
if (!fromAddress) {
|
|
1241
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'From address is not in available for ' + url);
|
|
1242
|
+
}
|
|
1243
|
+
const pair = keyring.getPair(fromAddress);
|
|
1244
|
+
if (!pair) {
|
|
1245
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Cannot find pair with address: ' + fromAddress);
|
|
1246
|
+
}
|
|
1247
|
+
const account = {
|
|
1248
|
+
address: pair.address,
|
|
1249
|
+
...pair.meta
|
|
1250
|
+
};
|
|
1251
|
+
|
|
1252
|
+
// Validate balance
|
|
1253
|
+
const balance = new BN((await web3.eth.getBalance(fromAddress)) || 0);
|
|
1254
|
+
if (balance.lt(new BN(gasPrice.toString()).mul(new BN(transaction.gas)).add(new BN(autoFormatNumber(transactionParams.value) || '0')))) {
|
|
1255
|
+
throw new EvmProviderError(EvmProviderErrorType.INVALID_PARAMS, 'Balance can be not enough to send transaction');
|
|
1256
|
+
}
|
|
1257
|
+
transaction.nonce = await web3.eth.getTransactionCount(fromAddress);
|
|
1258
|
+
const hashPayload = this.transactionService.generateHashPayload(networkKey, transaction);
|
|
1259
|
+
const isToContract = await isContractAddress(transaction.to || '', evmApi);
|
|
1260
|
+
const parseData = isToContract ? transaction.data ? (await parseContractInput(transaction.data, transaction.to || '', evmNetwork)).result : '' : transaction.data || '';
|
|
1261
|
+
const requestPayload = {
|
|
1262
|
+
...transaction,
|
|
1263
|
+
estimateGas,
|
|
1264
|
+
hashPayload,
|
|
1265
|
+
isToContract,
|
|
1266
|
+
parseData: parseData,
|
|
1267
|
+
account: account,
|
|
1268
|
+
canSign: true
|
|
1269
|
+
};
|
|
1270
|
+
|
|
1271
|
+
// Todo: Convert this to handle transaction
|
|
1272
|
+
const transactionEmitter = await this.transactionService.addTransaction({
|
|
1273
|
+
transaction: requestPayload,
|
|
1274
|
+
address: requestPayload.from,
|
|
1275
|
+
chain: networkKey,
|
|
1276
|
+
url,
|
|
1277
|
+
data: {
|
|
1278
|
+
...transaction
|
|
1279
|
+
},
|
|
1280
|
+
extrinsicType: transaction.value ? ExtrinsicType.TRANSFER_BALANCE : ExtrinsicType.EVM_EXECUTE,
|
|
1281
|
+
chainType: ChainType.EVM
|
|
1282
|
+
});
|
|
1283
|
+
|
|
1284
|
+
// Wait extrinsic hash
|
|
1285
|
+
return new Promise((resolve, reject) => {
|
|
1286
|
+
transactionEmitter.on('extrinsicHash', rs => {
|
|
1287
|
+
resolve(rs.extrinsicHash);
|
|
1288
|
+
});
|
|
1289
|
+
|
|
1290
|
+
// Mapping error for evmProvider
|
|
1291
|
+
transactionEmitter.on('error', rs => {
|
|
1292
|
+
var _rs$errors$;
|
|
1293
|
+
let evmProviderError = new EvmProviderError(EvmProviderErrorType.INTERNAL_ERROR);
|
|
1294
|
+
const errorType = ((_rs$errors$ = rs.errors[0]) === null || _rs$errors$ === void 0 ? void 0 : _rs$errors$.errorType) || BasicTxErrorType.INTERNAL_ERROR;
|
|
1295
|
+
if (errorType === BasicTxErrorType.USER_REJECT_REQUEST || errorType === BasicTxErrorType.UNABLE_TO_SIGN) {
|
|
1296
|
+
evmProviderError = new EvmProviderError(EvmProviderErrorType.USER_REJECTED_REQUEST);
|
|
1297
|
+
} else if (errorType === BasicTxErrorType.UNABLE_TO_SEND) {
|
|
1298
|
+
var _rs$errors$2;
|
|
1299
|
+
evmProviderError = new EvmProviderError(EvmProviderErrorType.INTERNAL_ERROR, (_rs$errors$2 = rs.errors[0]) === null || _rs$errors$2 === void 0 ? void 0 : _rs$errors$2.message);
|
|
1300
|
+
}
|
|
1301
|
+
reject(evmProviderError);
|
|
1302
|
+
});
|
|
1303
|
+
});
|
|
1304
|
+
}
|
|
1305
|
+
getConfirmationsQueueSubject() {
|
|
1306
|
+
return this.requestService.confirmationsQueueSubject;
|
|
1307
|
+
}
|
|
1308
|
+
async completeConfirmation(request) {
|
|
1309
|
+
return await this.requestService.completeConfirmation(request);
|
|
1310
|
+
}
|
|
1311
|
+
onInstall() {
|
|
1312
|
+
const singleModes = Object.values(_PREDEFINED_SINGLE_MODES);
|
|
1313
|
+
const setUpSingleMode = ({
|
|
1314
|
+
networkKeys,
|
|
1315
|
+
theme
|
|
1316
|
+
}) => {
|
|
1317
|
+
networkKeys.forEach(key => {
|
|
1318
|
+
this.enableChain(key).catch(console.error);
|
|
1319
|
+
});
|
|
1320
|
+
const chainInfo = this.chainService.getChainInfoByKey(networkKeys[0]);
|
|
1321
|
+
const genesisHash = _getSubstrateGenesisHash(chainInfo);
|
|
1322
|
+
this.setCurrentAccount({
|
|
1323
|
+
address: ALL_ACCOUNT_KEY,
|
|
1324
|
+
currentGenesisHash: genesisHash.length > 0 ? genesisHash : null
|
|
1325
|
+
});
|
|
1326
|
+
this.setTheme(theme);
|
|
1327
|
+
};
|
|
1328
|
+
chrome.tabs.query({}, function (tabs) {
|
|
1329
|
+
const openingUrls = tabs.map(t => t.url);
|
|
1330
|
+
const singleMode = singleModes.find(({
|
|
1331
|
+
autoTriggerDomain
|
|
1332
|
+
}) => {
|
|
1333
|
+
const urlRegex = new RegExp(autoTriggerDomain);
|
|
1334
|
+
return Boolean(openingUrls.find(url => {
|
|
1335
|
+
return url && urlRegex.test(url);
|
|
1336
|
+
}));
|
|
1337
|
+
});
|
|
1338
|
+
if (singleMode) {
|
|
1339
|
+
// Wait for everything is ready before enable single mode
|
|
1340
|
+
setTimeout(() => {
|
|
1341
|
+
setUpSingleMode(singleMode);
|
|
1342
|
+
}, 999);
|
|
1343
|
+
}
|
|
1344
|
+
});
|
|
1345
|
+
}
|
|
1346
|
+
get activeNetworks() {
|
|
1347
|
+
return this.chainService.getActiveChainInfos();
|
|
1348
|
+
}
|
|
1349
|
+
get activeChainSlugs() {
|
|
1350
|
+
return Object.values(this.activeNetworks).map(chainInfo => {
|
|
1351
|
+
return chainInfo.slug;
|
|
1352
|
+
});
|
|
1353
|
+
}
|
|
1354
|
+
async sleep() {
|
|
1355
|
+
this.cron.stop();
|
|
1356
|
+
this.subscription.stop();
|
|
1357
|
+
await this.pauseAllNetworks(undefined, 'IDLE mode');
|
|
1358
|
+
}
|
|
1359
|
+
async wakeup() {
|
|
1360
|
+
await this.resumeAllNetworks();
|
|
1361
|
+
this.cron.start();
|
|
1362
|
+
this.subscription.start();
|
|
1363
|
+
}
|
|
1364
|
+
cancelSubscription(id) {
|
|
1365
|
+
if (isSubscriptionRunning(id)) {
|
|
1366
|
+
unsubscribe(id);
|
|
1367
|
+
}
|
|
1368
|
+
if (this.unsubscriptionMap[id]) {
|
|
1369
|
+
this.unsubscriptionMap[id]();
|
|
1370
|
+
delete this.unsubscriptionMap[id];
|
|
1371
|
+
}
|
|
1372
|
+
return true;
|
|
1373
|
+
}
|
|
1374
|
+
createUnsubscriptionHandle(id, unsubscribe) {
|
|
1375
|
+
this.unsubscriptionMap[id] = unsubscribe;
|
|
1376
|
+
}
|
|
1377
|
+
}
|