@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,254 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getParaBondingExtrinsic = getParaBondingExtrinsic;
|
|
7
|
+
exports.getParaCancelWithdrawalExtrinsic = getParaCancelWithdrawalExtrinsic;
|
|
8
|
+
exports.getParaChainNominatorMetadata = getParaChainNominatorMetadata;
|
|
9
|
+
exports.getParaChainStakingMetadata = getParaChainStakingMetadata;
|
|
10
|
+
exports.getParaUnbondingExtrinsic = getParaUnbondingExtrinsic;
|
|
11
|
+
exports.getParaWithdrawalExtrinsic = getParaWithdrawalExtrinsic;
|
|
12
|
+
exports.getParachainCollatorsInfo = getParachainCollatorsInfo;
|
|
13
|
+
exports.getTuringCancelCompoundingExtrinsic = getTuringCancelCompoundingExtrinsic;
|
|
14
|
+
exports.getTuringCompoundExtrinsic = getTuringCompoundExtrinsic;
|
|
15
|
+
var _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
|
|
16
|
+
var _utils = require("@subwallet/extension-base/koni/api/staking/bonding/utils");
|
|
17
|
+
var _constants = require("@subwallet/extension-base/services/chain-service/constants");
|
|
18
|
+
var _utils2 = require("@subwallet/extension-base/services/chain-service/utils");
|
|
19
|
+
var _utils3 = require("@subwallet/extension-base/utils");
|
|
20
|
+
var _util = require("@polkadot/util");
|
|
21
|
+
var _utilCrypto = require("@polkadot/util-crypto");
|
|
22
|
+
// Copyright 2019-2022 @subwallet/extension-koni authors & contributors
|
|
23
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
24
|
+
|
|
25
|
+
async function getParaChainStakingMetadata(chain, substrateApi) {
|
|
26
|
+
const chainApi = await substrateApi.isReady;
|
|
27
|
+
const _round = (await chainApi.api.query.parachainStaking.round()).toHuman();
|
|
28
|
+
const round = (0, _utils3.parseRawNumber)(_round.current);
|
|
29
|
+
const maxDelegations = chainApi.api.consts.parachainStaking.maxDelegationsPerDelegator.toString();
|
|
30
|
+
const unstakingDelay = chainApi.api.consts.parachainStaking.delegationBondLessDelay.toString();
|
|
31
|
+
let _unvestedAllocation;
|
|
32
|
+
if (chainApi.api.query.vesting && chainApi.api.query.vesting.totalUnvestedAllocation) {
|
|
33
|
+
_unvestedAllocation = await chainApi.api.query.vesting.totalUnvestedAllocation();
|
|
34
|
+
}
|
|
35
|
+
const [_totalStake, _totalIssuance, _inflation] = await Promise.all([chainApi.api.query.parachainStaking.staked(round), chainApi.api.query.balances.totalIssuance(), chainApi.api.query.parachainStaking.inflationConfig()]);
|
|
36
|
+
let unvestedAllocation;
|
|
37
|
+
if (_unvestedAllocation) {
|
|
38
|
+
const rawUnvestedAllocation = _unvestedAllocation.toString();
|
|
39
|
+
unvestedAllocation = new _util.BN(rawUnvestedAllocation);
|
|
40
|
+
}
|
|
41
|
+
const totalStake = _totalStake ? new _util.BN(_totalStake.toString()) : _util.BN_ZERO;
|
|
42
|
+
const totalIssuance = new _util.BN(_totalIssuance.toString());
|
|
43
|
+
if (unvestedAllocation) {
|
|
44
|
+
totalIssuance.add(unvestedAllocation); // for Turing network, read more at https://hackmd.io/@sbAqOuXkRvyiZPOB3Ryn6Q/Sypr3ZJh5
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const inflationConfig = _inflation.toHuman();
|
|
48
|
+
const inflation = (0, _utils.getParaCurrentInflation)((0, _utils3.parseRawNumber)(totalStake.toString()), inflationConfig);
|
|
49
|
+
const unstakingPeriod = parseInt(unstakingDelay) * _constants._STAKING_ERA_LENGTH_MAP[chain];
|
|
50
|
+
return {
|
|
51
|
+
chain,
|
|
52
|
+
type: _KoniTypes.StakingType.NOMINATED,
|
|
53
|
+
era: round,
|
|
54
|
+
inflation,
|
|
55
|
+
minStake: '0',
|
|
56
|
+
maxValidatorPerNominator: parseInt(maxDelegations),
|
|
57
|
+
maxWithdrawalRequestPerValidator: 1,
|
|
58
|
+
// by default
|
|
59
|
+
allowCancelUnstaking: true,
|
|
60
|
+
unstakingPeriod
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
async function getParaChainNominatorMetadata(chainInfo, address, substrateApi) {
|
|
64
|
+
if ((0, _utils2._isChainEvmCompatible)(chainInfo) && !(0, _utilCrypto.isEthereumAddress)(address)) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
const chain = chainInfo.slug;
|
|
68
|
+
const chainApi = await substrateApi.isReady;
|
|
69
|
+
const nominationList = [];
|
|
70
|
+
const unstakingMap = {};
|
|
71
|
+
const _delegatorState = await chainApi.api.query.parachainStaking.delegatorState(address);
|
|
72
|
+
const delegatorState = _delegatorState.toPrimitive();
|
|
73
|
+
if (!delegatorState) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
let bnTotalActiveStake = _util.BN_ZERO;
|
|
77
|
+
await Promise.all(delegatorState.delegations.map(async delegation => {
|
|
78
|
+
const [_delegationScheduledRequests, _identity, _roundInfo] = await Promise.all([chainApi.api.query.parachainStaking.delegationScheduledRequests(delegation.owner), chainApi.api.query.identity.identityOf(delegation.owner), chainApi.api.query.parachainStaking.round()]);
|
|
79
|
+
const identityInfo = _identity.toHuman();
|
|
80
|
+
const roundInfo = _roundInfo.toPrimitive();
|
|
81
|
+
const delegationScheduledRequests = _delegationScheduledRequests.toPrimitive();
|
|
82
|
+
const currentRound = roundInfo.current;
|
|
83
|
+
const identity = (0, _utils.parseIdentity)(identityInfo);
|
|
84
|
+
let hasUnstaking = false;
|
|
85
|
+
|
|
86
|
+
// parse unstaking info
|
|
87
|
+
if (delegationScheduledRequests) {
|
|
88
|
+
for (const scheduledRequest of delegationScheduledRequests) {
|
|
89
|
+
if ((0, _utils3.reformatAddress)(scheduledRequest.delegator, 0) === (0, _utils3.reformatAddress)(address, 0)) {
|
|
90
|
+
// add network prefix
|
|
91
|
+
const isClaimable = scheduledRequest.whenExecutable - currentRound <= 0;
|
|
92
|
+
const remainingEra = scheduledRequest.whenExecutable - (currentRound + 1);
|
|
93
|
+
const waitingTime = remainingEra * _constants._STAKING_ERA_LENGTH_MAP[chain];
|
|
94
|
+
const claimable = Object.values(scheduledRequest.action)[0];
|
|
95
|
+
unstakingMap[delegation.owner] = {
|
|
96
|
+
chain,
|
|
97
|
+
status: isClaimable ? _KoniTypes.UnstakingStatus.CLAIMABLE : _KoniTypes.UnstakingStatus.UNLOCKING,
|
|
98
|
+
validatorAddress: delegation.owner,
|
|
99
|
+
claimable: claimable.toString(),
|
|
100
|
+
waitingTime: waitingTime > 0 ? waitingTime : 0
|
|
101
|
+
};
|
|
102
|
+
hasUnstaking = true;
|
|
103
|
+
break; // only handle 1 scheduledRequest per collator
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const bnStake = new _util.BN(delegation.amount);
|
|
109
|
+
const bnUnstakeBalance = unstakingMap[delegation.owner] ? new _util.BN(unstakingMap[delegation.owner].claimable) : _util.BN_ZERO;
|
|
110
|
+
const bnActiveStake = bnStake.sub(bnUnstakeBalance);
|
|
111
|
+
bnTotalActiveStake = bnTotalActiveStake.add(bnActiveStake);
|
|
112
|
+
nominationList.push({
|
|
113
|
+
chain,
|
|
114
|
+
validatorAddress: delegation.owner,
|
|
115
|
+
validatorIdentity: identity,
|
|
116
|
+
activeStake: bnActiveStake.toString(),
|
|
117
|
+
hasUnstaking
|
|
118
|
+
});
|
|
119
|
+
}));
|
|
120
|
+
await Promise.all(nominationList.map(async nomination => {
|
|
121
|
+
const _collatorInfo = await chainApi.api.query.parachainStaking.candidateInfo(nomination.validatorAddress);
|
|
122
|
+
const collatorInfo = _collatorInfo.toPrimitive();
|
|
123
|
+
nomination.validatorMinStake = collatorInfo.lowestTopDelegationAmount.toString();
|
|
124
|
+
}));
|
|
125
|
+
return {
|
|
126
|
+
chain,
|
|
127
|
+
type: _KoniTypes.StakingType.NOMINATED,
|
|
128
|
+
address: address,
|
|
129
|
+
activeStake: bnTotalActiveStake.toString(),
|
|
130
|
+
nominations: nominationList,
|
|
131
|
+
unstakings: Object.values(unstakingMap)
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
async function getParachainCollatorsInfo(chain, substrateApi) {
|
|
135
|
+
const apiProps = await substrateApi.isReady;
|
|
136
|
+
const allValidators = [];
|
|
137
|
+
const [_allCollators, _collatorCommission] = await Promise.all([apiProps.api.query.parachainStaking.candidateInfo.entries(), apiProps.api.query.parachainStaking.collatorCommission()]);
|
|
138
|
+
const maxDelegationPerCollator = apiProps.api.consts.parachainStaking.maxTopDelegationsPerCandidate.toString();
|
|
139
|
+
const rawCollatorCommission = _collatorCommission.toHuman();
|
|
140
|
+
const collatorCommission = parseFloat(rawCollatorCommission.split('%')[0]);
|
|
141
|
+
for (const collator of _allCollators) {
|
|
142
|
+
const collatorAddress = collator[0].toPrimitive();
|
|
143
|
+
const collatorInfo = collator[1].toPrimitive();
|
|
144
|
+
allValidators.push({
|
|
145
|
+
commission: 0,
|
|
146
|
+
expectedReturn: 0,
|
|
147
|
+
address: collatorAddress,
|
|
148
|
+
totalStake: collatorInfo.totalCounted.toString(),
|
|
149
|
+
ownStake: collatorInfo.bond.toString(),
|
|
150
|
+
otherStake: (collatorInfo.totalCounted - collatorInfo.bond).toString(),
|
|
151
|
+
nominatorCount: collatorInfo.delegationCount,
|
|
152
|
+
blocked: false,
|
|
153
|
+
isVerified: false,
|
|
154
|
+
minBond: collatorInfo.lowestTopDelegationAmount.toString(),
|
|
155
|
+
chain,
|
|
156
|
+
isCrowded: parseInt(maxDelegationPerCollator) > 0
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
const extraInfoMap = {};
|
|
160
|
+
await Promise.all(allValidators.map(async validator => {
|
|
161
|
+
var _apiProps$api$query, _apiProps$api$query$i;
|
|
162
|
+
const [_info, _identity] = await Promise.all([apiProps.api.query.parachainStaking.candidateInfo(validator.address), (_apiProps$api$query = apiProps.api.query) === null || _apiProps$api$query === void 0 ? void 0 : (_apiProps$api$query$i = _apiProps$api$query.identity) === null || _apiProps$api$query$i === void 0 ? void 0 : _apiProps$api$query$i.identityOf(validator.address) // some chains might not have identity pallet
|
|
163
|
+
]);
|
|
164
|
+
const rawInfo = _info.toHuman();
|
|
165
|
+
const rawIdentity = _identity ? _identity.toHuman() : null;
|
|
166
|
+
const rawBond = rawInfo === null || rawInfo === void 0 ? void 0 : rawInfo.bond;
|
|
167
|
+
const bond = new _util.BN(rawBond.replaceAll(',', ''));
|
|
168
|
+
const delegationCount = (0, _utils3.parseRawNumber)(rawInfo === null || rawInfo === void 0 ? void 0 : rawInfo.delegationCount);
|
|
169
|
+
const minDelegation = (0, _utils3.parseRawNumber)(rawInfo === null || rawInfo === void 0 ? void 0 : rawInfo.lowestTopDelegationAmount);
|
|
170
|
+
const active = (rawInfo === null || rawInfo === void 0 ? void 0 : rawInfo.status) === 'Active';
|
|
171
|
+
let isReasonable = false;
|
|
172
|
+
let identity;
|
|
173
|
+
if (rawIdentity !== null) {
|
|
174
|
+
// Check if identity is eth address
|
|
175
|
+
isReasonable = rawIdentity.judgements.length > 0;
|
|
176
|
+
identity = (0, _utils.parseIdentity)(rawIdentity);
|
|
177
|
+
}
|
|
178
|
+
extraInfoMap[validator.address] = {
|
|
179
|
+
identity,
|
|
180
|
+
isVerified: isReasonable,
|
|
181
|
+
bond: bond.toString(),
|
|
182
|
+
minDelegation: minDelegation.toString(),
|
|
183
|
+
delegationCount,
|
|
184
|
+
active
|
|
185
|
+
};
|
|
186
|
+
}));
|
|
187
|
+
for (const validator of allValidators) {
|
|
188
|
+
validator.minBond = extraInfoMap[validator.address].minDelegation.toString();
|
|
189
|
+
validator.ownStake = extraInfoMap[validator.address].bond.toString();
|
|
190
|
+
validator.blocked = !extraInfoMap[validator.address].active;
|
|
191
|
+
validator.identity = extraInfoMap[validator.address].identity;
|
|
192
|
+
validator.isVerified = extraInfoMap[validator.address].isVerified;
|
|
193
|
+
// @ts-ignore
|
|
194
|
+
validator.otherStake = (validator.totalStake - validator.ownStake).toString();
|
|
195
|
+
validator.nominatorCount = extraInfoMap[validator.address].delegationCount;
|
|
196
|
+
validator.commission = collatorCommission;
|
|
197
|
+
}
|
|
198
|
+
return allValidators;
|
|
199
|
+
}
|
|
200
|
+
async function getParaBondingExtrinsic(nominatorMetadata, chainInfo, substrateApi, amount, selectedCollatorInfo) {
|
|
201
|
+
const apiPromise = await substrateApi.isReady;
|
|
202
|
+
const binaryAmount = new _util.BN(amount);
|
|
203
|
+
const {
|
|
204
|
+
bondedValidators,
|
|
205
|
+
nominationCount
|
|
206
|
+
} = (0, _utils.getBondedValidators)(nominatorMetadata.nominations);
|
|
207
|
+
if (!bondedValidators.includes((0, _utils3.reformatAddress)(selectedCollatorInfo.address, 0))) {
|
|
208
|
+
return apiPromise.api.tx.parachainStaking.delegate(selectedCollatorInfo.address, binaryAmount, new _util.BN(selectedCollatorInfo.nominatorCount), nominationCount);
|
|
209
|
+
} else {
|
|
210
|
+
return apiPromise.api.tx.parachainStaking.delegatorBondMore(selectedCollatorInfo.address, binaryAmount);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
async function getParaUnbondingExtrinsic(substrateApi, amount, nominatorMetadata, selectedValidator) {
|
|
214
|
+
const apiPromise = await substrateApi.isReady;
|
|
215
|
+
const binaryAmount = new _util.BN(amount);
|
|
216
|
+
const unstakeAll = (0, _utils.isUnstakeAll)(selectedValidator, nominatorMetadata.nominations, amount);
|
|
217
|
+
if (!unstakeAll) {
|
|
218
|
+
return apiPromise.api.tx.parachainStaking.scheduleDelegatorBondLess(selectedValidator, binaryAmount);
|
|
219
|
+
} else {
|
|
220
|
+
return apiPromise.api.tx.parachainStaking.scheduleRevokeDelegation(selectedValidator);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
async function getParaWithdrawalExtrinsic(substrateApi, address, collatorAddress) {
|
|
224
|
+
const chainApi = await substrateApi.isReady;
|
|
225
|
+
return chainApi.api.tx.parachainStaking.executeDelegationRequest(address, collatorAddress);
|
|
226
|
+
}
|
|
227
|
+
async function getTuringCompoundExtrinsic(substrateApi, address, collatorAddress, accountMinimum, bondedAmount) {
|
|
228
|
+
const apiPromise = await substrateApi.isReady;
|
|
229
|
+
|
|
230
|
+
// @ts-ignore
|
|
231
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
232
|
+
const _optimalCompounding = await apiPromise.api.rpc.automationTime.calculateOptimalAutostaking(bondedAmount, collatorAddress);
|
|
233
|
+
|
|
234
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
235
|
+
const optimalCompounding = _optimalCompounding.toHuman();
|
|
236
|
+
const compoundingPeriod = parseInt(optimalCompounding.period); // in days
|
|
237
|
+
|
|
238
|
+
const frequency = compoundingPeriod * 24 * 60 * 60; // in seconds
|
|
239
|
+
const timestamp = new Date();
|
|
240
|
+
timestamp.setDate(timestamp.getDate() + compoundingPeriod);
|
|
241
|
+
timestamp.setHours(timestamp.getHours() + Math.round(timestamp.getMinutes() / 60));
|
|
242
|
+
timestamp.setMinutes(0, 0, 0);
|
|
243
|
+
const startTime = Math.floor(timestamp.valueOf() / 1000); // must be in seconds
|
|
244
|
+
|
|
245
|
+
return apiPromise.api.tx.automationTime.scheduleAutoCompoundDelegatedStakeTask(startTime.toString(), frequency.toString(), collatorAddress, accountMinimum);
|
|
246
|
+
}
|
|
247
|
+
async function getTuringCancelCompoundingExtrinsic(substrateApi, taskId) {
|
|
248
|
+
const apiPromise = await substrateApi.isReady;
|
|
249
|
+
return apiPromise.api.tx.automationTime.cancelTask(taskId);
|
|
250
|
+
}
|
|
251
|
+
async function getParaCancelWithdrawalExtrinsic(substrateApi, selectedUnstaking) {
|
|
252
|
+
const chainApi = await substrateApi.isReady;
|
|
253
|
+
return chainApi.api.tx.parachainStaking.cancelDelegationRequest(selectedUnstaking.validatorAddress);
|
|
254
|
+
}
|
|
@@ -0,0 +1,350 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getPoolingBondingExtrinsic = getPoolingBondingExtrinsic;
|
|
7
|
+
exports.getPoolingClaimRewardExtrinsic = getPoolingClaimRewardExtrinsic;
|
|
8
|
+
exports.getPoolingUnbondingExtrinsic = getPoolingUnbondingExtrinsic;
|
|
9
|
+
exports.getPoolingWithdrawalExtrinsic = getPoolingWithdrawalExtrinsic;
|
|
10
|
+
exports.getRelayBondingExtrinsic = getRelayBondingExtrinsic;
|
|
11
|
+
exports.getRelayCancelWithdrawalExtrinsic = getRelayCancelWithdrawalExtrinsic;
|
|
12
|
+
exports.getRelayChainNominatorMetadata = getRelayChainNominatorMetadata;
|
|
13
|
+
exports.getRelayChainPoolMemberMetadata = getRelayChainPoolMemberMetadata;
|
|
14
|
+
exports.getRelayChainStakingMetadata = getRelayChainStakingMetadata;
|
|
15
|
+
exports.getRelayPoolsInfo = getRelayPoolsInfo;
|
|
16
|
+
exports.getRelayUnbondingExtrinsic = getRelayUnbondingExtrinsic;
|
|
17
|
+
exports.getRelayValidatorsInfo = getRelayValidatorsInfo;
|
|
18
|
+
exports.getRelayWithdrawalExtrinsic = getRelayWithdrawalExtrinsic;
|
|
19
|
+
var _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
|
|
20
|
+
var _utils = require("@subwallet/extension-base/koni/api/staking/bonding/utils");
|
|
21
|
+
var _constants = require("@subwallet/extension-base/services/chain-service/constants");
|
|
22
|
+
var _util = require("@polkadot/util");
|
|
23
|
+
var _utilCrypto = require("@polkadot/util-crypto");
|
|
24
|
+
// Copyright 2019-2022 @subwallet/extension-koni authors & contributors
|
|
25
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
26
|
+
|
|
27
|
+
async function getRelayChainStakingMetadata(chain, substrateApi) {
|
|
28
|
+
var _chainApi$api$query$a, _chainApi$api$query, _chainApi$api$query$n;
|
|
29
|
+
const chainApi = await substrateApi.isReady;
|
|
30
|
+
const _era = await chainApi.api.query.staking.currentEra();
|
|
31
|
+
const currentEra = _era.toString();
|
|
32
|
+
const maxNominations = chainApi.api.consts.staking.maxNominations.toString();
|
|
33
|
+
const maxUnlockingChunks = chainApi.api.consts.staking.maxUnlockingChunks.toString();
|
|
34
|
+
const unlockingEras = chainApi.api.consts.staking.bondingDuration.toString();
|
|
35
|
+
const [_totalEraStake, _totalIssuance, _auctionCounter, _minimumActiveStake, _minPoolJoin] = await Promise.all([chainApi.api.query.staking.erasTotalStake(parseInt(currentEra)), chainApi.api.query.balances.totalIssuance(), (_chainApi$api$query$a = chainApi.api.query.auctions) === null || _chainApi$api$query$a === void 0 ? void 0 : _chainApi$api$query$a.auctionCounter(), chainApi.api.query.staking.minimumActiveStake(), (_chainApi$api$query = chainApi.api.query) === null || _chainApi$api$query === void 0 ? void 0 : (_chainApi$api$query$n = _chainApi$api$query.nominationPools) === null || _chainApi$api$query$n === void 0 ? void 0 : _chainApi$api$query$n.minJoinBond()]);
|
|
36
|
+
const minStake = _minimumActiveStake.toString();
|
|
37
|
+
const minPoolJoin = (_minPoolJoin === null || _minPoolJoin === void 0 ? void 0 : _minPoolJoin.toString()) || undefined;
|
|
38
|
+
const rawTotalEraStake = _totalEraStake.toString();
|
|
39
|
+
const rawTotalIssuance = _totalIssuance.toString();
|
|
40
|
+
const numAuctions = _auctionCounter ? _auctionCounter.toHuman() : 0;
|
|
41
|
+
const bnTotalEraStake = new _util.BN(rawTotalEraStake);
|
|
42
|
+
const bnTotalIssuance = new _util.BN(rawTotalIssuance);
|
|
43
|
+
const inflation = (0, _utils.calculateInflation)(bnTotalEraStake, bnTotalIssuance, numAuctions, chain);
|
|
44
|
+
const expectedReturn = (0, _utils.calculateChainStakedReturn)(inflation, bnTotalEraStake, bnTotalIssuance, chain);
|
|
45
|
+
const unlockingPeriod = parseInt(unlockingEras) * _constants._STAKING_ERA_LENGTH_MAP[chain]; // in hours
|
|
46
|
+
|
|
47
|
+
return {
|
|
48
|
+
chain,
|
|
49
|
+
type: _KoniTypes.StakingType.NOMINATED,
|
|
50
|
+
era: parseInt(currentEra),
|
|
51
|
+
expectedReturn,
|
|
52
|
+
// in %, annually
|
|
53
|
+
inflation,
|
|
54
|
+
minStake,
|
|
55
|
+
maxValidatorPerNominator: parseInt(maxNominations),
|
|
56
|
+
maxWithdrawalRequestPerValidator: parseInt(maxUnlockingChunks),
|
|
57
|
+
allowCancelUnstaking: true,
|
|
58
|
+
unstakingPeriod: unlockingPeriod,
|
|
59
|
+
minJoinNominationPool: minPoolJoin
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
async function getRelayChainNominatorMetadata(chainInfo, address, substrateApi) {
|
|
63
|
+
if ((0, _utilCrypto.isEthereumAddress)(address)) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
const chain = chainInfo.slug;
|
|
67
|
+
const chainApi = await substrateApi.isReady;
|
|
68
|
+
const [_ledger, _nominations, _currentEra, _bonded] = await Promise.all([chainApi.api.query.staking.ledger(address), chainApi.api.query.staking.nominators(address), chainApi.api.query.staking.currentEra(), chainApi.api.query.staking.bonded(address)]);
|
|
69
|
+
const ledger = _ledger.toJSON();
|
|
70
|
+
const nominations = _nominations.toJSON();
|
|
71
|
+
const currentEra = _currentEra.toString();
|
|
72
|
+
const bonded = _bonded.toHuman();
|
|
73
|
+
if (!ledger) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
const activeStake = ledger.active.toString();
|
|
77
|
+
const nominationList = [];
|
|
78
|
+
const unstakingList = [];
|
|
79
|
+
if (nominations) {
|
|
80
|
+
const validatorList = nominations.targets;
|
|
81
|
+
await Promise.all(validatorList.map(async validatorAddress => {
|
|
82
|
+
const identityInfo = (await chainApi.api.query.identity.identityOf(validatorAddress)).toHuman();
|
|
83
|
+
const identity = (0, _utils.parseIdentity)(identityInfo);
|
|
84
|
+
nominationList.push({
|
|
85
|
+
chain,
|
|
86
|
+
validatorAddress,
|
|
87
|
+
validatorIdentity: identity,
|
|
88
|
+
activeStake: '0' // relaychain allocates stake accordingly
|
|
89
|
+
});
|
|
90
|
+
}));
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
ledger.unlocking.forEach(unlockingChunk => {
|
|
94
|
+
const isClaimable = unlockingChunk.era - parseInt(currentEra) <= 0;
|
|
95
|
+
const remainingEra = unlockingChunk.era - (parseInt(currentEra) + 1);
|
|
96
|
+
const waitingTime = remainingEra * _constants._STAKING_ERA_LENGTH_MAP[chain];
|
|
97
|
+
unstakingList.push({
|
|
98
|
+
chain,
|
|
99
|
+
status: isClaimable ? _KoniTypes.UnstakingStatus.CLAIMABLE : _KoniTypes.UnstakingStatus.UNLOCKING,
|
|
100
|
+
claimable: unlockingChunk.value.toString(),
|
|
101
|
+
waitingTime: waitingTime > 0 ? waitingTime : 0
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
return {
|
|
105
|
+
chain,
|
|
106
|
+
type: _KoniTypes.StakingType.NOMINATED,
|
|
107
|
+
address: address,
|
|
108
|
+
activeStake,
|
|
109
|
+
nominations: nominationList,
|
|
110
|
+
unstakings: unstakingList,
|
|
111
|
+
isBondedBefore: bonded !== null
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
async function getRelayChainPoolMemberMetadata(chainInfo, address, substrateApi) {
|
|
115
|
+
const chainApi = await substrateApi.isReady;
|
|
116
|
+
const [_poolMemberInfo, _currentEra] = await Promise.all([chainApi.api.query.nominationPools.poolMembers(address), chainApi.api.query.staking.currentEra()]);
|
|
117
|
+
const poolMemberInfo = _poolMemberInfo.toPrimitive();
|
|
118
|
+
const currentEra = _currentEra.toString();
|
|
119
|
+
if (!poolMemberInfo) {
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
const _poolMetadata = await chainApi.api.query.nominationPools.metadata(poolMemberInfo.poolId);
|
|
123
|
+
const poolMetadata = _poolMetadata.toPrimitive();
|
|
124
|
+
const poolName = (0, _utils.transformPoolName)(poolMetadata.isUtf8 ? poolMetadata.toUtf8() : poolMetadata.toString());
|
|
125
|
+
const joinedPoolInfo = {
|
|
126
|
+
activeStake: poolMemberInfo.points.toString(),
|
|
127
|
+
chain: chainInfo.slug,
|
|
128
|
+
validatorIdentity: poolName,
|
|
129
|
+
validatorAddress: poolMemberInfo.poolId.toString(),
|
|
130
|
+
// use poolId
|
|
131
|
+
hasUnstaking: poolMemberInfo.unbondingEras && Object.keys(poolMemberInfo.unbondingEras).length > 0
|
|
132
|
+
};
|
|
133
|
+
const unstakings = [];
|
|
134
|
+
Object.entries(poolMemberInfo.unbondingEras).forEach(_ref => {
|
|
135
|
+
let [unlockingEra, amount] = _ref;
|
|
136
|
+
const isClaimable = parseInt(unlockingEra) - parseInt(currentEra) <= 0;
|
|
137
|
+
const remainingEra = parseInt(unlockingEra) - (parseInt(currentEra) + 1);
|
|
138
|
+
const waitingTime = remainingEra * _constants._STAKING_ERA_LENGTH_MAP[chainInfo.slug];
|
|
139
|
+
unstakings.push({
|
|
140
|
+
chain: chainInfo.slug,
|
|
141
|
+
status: isClaimable ? _KoniTypes.UnstakingStatus.CLAIMABLE : _KoniTypes.UnstakingStatus.UNLOCKING,
|
|
142
|
+
claimable: amount.toString(),
|
|
143
|
+
waitingTime: waitingTime > 0 ? waitingTime : 0
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
return {
|
|
147
|
+
chain: chainInfo.slug,
|
|
148
|
+
type: _KoniTypes.StakingType.POOLED,
|
|
149
|
+
address,
|
|
150
|
+
activeStake: poolMemberInfo.points.toString(),
|
|
151
|
+
nominations: [joinedPoolInfo],
|
|
152
|
+
// can only join 1 pool at a time
|
|
153
|
+
unstakings
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
async function getRelayValidatorsInfo(chain, substrateApi, decimals, chainStakingMetadata) {
|
|
157
|
+
const chainApi = await substrateApi.isReady;
|
|
158
|
+
const _era = await chainApi.api.query.staking.currentEra();
|
|
159
|
+
const currentEra = _era.toString();
|
|
160
|
+
const allValidators = [];
|
|
161
|
+
const validatorInfoList = [];
|
|
162
|
+
const [_totalEraStake, _eraStakers, _minBond] = await Promise.all([chainApi.api.query.staking.erasTotalStake(parseInt(currentEra)), chainApi.api.query.staking.erasStakers.entries(parseInt(currentEra)), chainApi.api.query.staking.minNominatorBond()]);
|
|
163
|
+
const maxNominatorRewarded = chainApi.api.consts.staking.maxNominatorRewardedPerValidator.toString();
|
|
164
|
+
const bnTotalEraStake = new _util.BN(_totalEraStake.toString());
|
|
165
|
+
const eraStakers = _eraStakers;
|
|
166
|
+
const rawMinBond = _minBond.toHuman();
|
|
167
|
+
const minBond = rawMinBond.replaceAll(',', '');
|
|
168
|
+
const totalStakeMap = {};
|
|
169
|
+
const bnDecimals = new _util.BN((10 ** decimals).toString());
|
|
170
|
+
for (const item of eraStakers) {
|
|
171
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
172
|
+
const rawValidatorInfo = item[0].toHuman();
|
|
173
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
|
|
174
|
+
const rawValidatorStat = item[1].toHuman();
|
|
175
|
+
const validatorAddress = rawValidatorInfo[1];
|
|
176
|
+
const rawTotalStake = rawValidatorStat.total;
|
|
177
|
+
const rawOwnStake = rawValidatorStat.own;
|
|
178
|
+
const bnTotalStake = new _util.BN(rawTotalStake.replaceAll(',', ''));
|
|
179
|
+
const bnOwnStake = new _util.BN(rawOwnStake.replaceAll(',', ''));
|
|
180
|
+
const otherStake = bnTotalStake.sub(bnOwnStake);
|
|
181
|
+
totalStakeMap[validatorAddress] = bnTotalStake;
|
|
182
|
+
let nominatorCount = 0;
|
|
183
|
+
if ('others' in rawValidatorStat) {
|
|
184
|
+
const others = rawValidatorStat.others;
|
|
185
|
+
nominatorCount = others.length;
|
|
186
|
+
}
|
|
187
|
+
allValidators.push(validatorAddress);
|
|
188
|
+
validatorInfoList.push({
|
|
189
|
+
address: validatorAddress,
|
|
190
|
+
totalStake: bnTotalStake.toString(),
|
|
191
|
+
ownStake: bnOwnStake.toString(),
|
|
192
|
+
otherStake: otherStake.toString(),
|
|
193
|
+
nominatorCount,
|
|
194
|
+
// to be added later
|
|
195
|
+
commission: 0,
|
|
196
|
+
expectedReturn: 0,
|
|
197
|
+
blocked: false,
|
|
198
|
+
isVerified: false,
|
|
199
|
+
minBond,
|
|
200
|
+
isCrowded: nominatorCount > parseInt(maxNominatorRewarded)
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
const extraInfoMap = {};
|
|
204
|
+
await Promise.all(allValidators.map(async address => {
|
|
205
|
+
var _chainApi$api$query2, _chainApi$api$query2$, _identityInfo$judgeme;
|
|
206
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
207
|
+
const [_commissionInfo, _identityInfo] = await Promise.all([chainApi.api.query.staking.validators(address), (_chainApi$api$query2 = chainApi.api.query) === null || _chainApi$api$query2 === void 0 ? void 0 : (_chainApi$api$query2$ = _chainApi$api$query2.identity) === null || _chainApi$api$query2$ === void 0 ? void 0 : _chainApi$api$query2$.identityOf(address)]);
|
|
208
|
+
const commissionInfo = _commissionInfo.toHuman();
|
|
209
|
+
const identityInfo = _identityInfo ? _identityInfo.toHuman() : null;
|
|
210
|
+
let identity;
|
|
211
|
+
if (identityInfo !== null) {
|
|
212
|
+
identity = (0, _utils.parseIdentity)(identityInfo);
|
|
213
|
+
}
|
|
214
|
+
extraInfoMap[address] = {
|
|
215
|
+
commission: commissionInfo.commission,
|
|
216
|
+
blocked: commissionInfo.blocked,
|
|
217
|
+
identity,
|
|
218
|
+
isVerified: identityInfo && (identityInfo === null || identityInfo === void 0 ? void 0 : (_identityInfo$judgeme = identityInfo.judgements) === null || _identityInfo$judgeme === void 0 ? void 0 : _identityInfo$judgeme.length) > 0
|
|
219
|
+
};
|
|
220
|
+
}));
|
|
221
|
+
const bnAvgStake = bnTotalEraStake.divn(validatorInfoList.length).div(bnDecimals);
|
|
222
|
+
for (const validator of validatorInfoList) {
|
|
223
|
+
const commission = extraInfoMap[validator.address].commission;
|
|
224
|
+
const bnValidatorStake = totalStakeMap[validator.address].div(bnDecimals);
|
|
225
|
+
validator.expectedReturn = _constants._STAKING_CHAIN_GROUP.aleph.includes(chain) ? (0, _utils.calculateAlephZeroValidatorReturn)(chainStakingMetadata.expectedReturn, (0, _utils.getCommission)(commission)) : (0, _utils.calculateValidatorStakedReturn)(chainStakingMetadata.expectedReturn, bnValidatorStake, bnAvgStake, (0, _utils.getCommission)(commission));
|
|
226
|
+
validator.commission = parseFloat(commission.split('%')[0]);
|
|
227
|
+
validator.blocked = extraInfoMap[validator.address].blocked;
|
|
228
|
+
validator.identity = extraInfoMap[validator.address].identity;
|
|
229
|
+
validator.isVerified = extraInfoMap[validator.address].isVerified;
|
|
230
|
+
}
|
|
231
|
+
return validatorInfoList;
|
|
232
|
+
}
|
|
233
|
+
async function getRelayPoolsInfo(chain, substrateApi) {
|
|
234
|
+
const chainApi = await substrateApi.isReady;
|
|
235
|
+
const nominationPools = [];
|
|
236
|
+
const _allPoolsInfo = await chainApi.api.query.nominationPools.reversePoolIdLookup.entries();
|
|
237
|
+
await Promise.all(_allPoolsInfo.map(async _poolInfo => {
|
|
238
|
+
var _bondedPool$points;
|
|
239
|
+
const poolAddressList = _poolInfo[0].toHuman();
|
|
240
|
+
const poolAddress = poolAddressList[0];
|
|
241
|
+
const poolId = _poolInfo[1].toPrimitive();
|
|
242
|
+
const [_bondedPool, _metadata] = await Promise.all([chainApi.api.query.nominationPools.bondedPools(poolId), chainApi.api.query.nominationPools.metadata(poolId)]);
|
|
243
|
+
const poolMetadata = _metadata.toPrimitive();
|
|
244
|
+
const bondedPool = _bondedPool.toPrimitive();
|
|
245
|
+
const poolName = (0, _utils.transformPoolName)(poolMetadata.isUtf8 ? poolMetadata.toUtf8() : poolMetadata.toString());
|
|
246
|
+
nominationPools.push({
|
|
247
|
+
id: poolId,
|
|
248
|
+
address: poolAddress,
|
|
249
|
+
name: poolName,
|
|
250
|
+
bondedAmount: ((_bondedPool$points = bondedPool.points) === null || _bondedPool$points === void 0 ? void 0 : _bondedPool$points.toString()) || '0',
|
|
251
|
+
roles: bondedPool.roles,
|
|
252
|
+
memberCounter: bondedPool.memberCounter,
|
|
253
|
+
state: bondedPool.state
|
|
254
|
+
});
|
|
255
|
+
}));
|
|
256
|
+
return nominationPools;
|
|
257
|
+
}
|
|
258
|
+
async function getRelayBondingExtrinsic(substrateApi, amount, targetValidators, nominatorMetadata, chainInfo) {
|
|
259
|
+
let bondDest = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 'Staked';
|
|
260
|
+
const chainApi = await substrateApi.isReady;
|
|
261
|
+
const binaryAmount = new _util.BN(amount);
|
|
262
|
+
let bondTx;
|
|
263
|
+
let nominateTx;
|
|
264
|
+
if (!nominatorMetadata.isBondedBefore) {
|
|
265
|
+
// first time
|
|
266
|
+
bondTx = chainApi.api.tx.staking.bond(nominatorMetadata.address, binaryAmount, bondDest);
|
|
267
|
+
nominateTx = chainApi.api.tx.staking.nominate(targetValidators);
|
|
268
|
+
return chainApi.api.tx.utility.batchAll([bondTx, nominateTx]);
|
|
269
|
+
} else {
|
|
270
|
+
if (binaryAmount.gt(_util.BN_ZERO)) {
|
|
271
|
+
bondTx = chainApi.api.tx.staking.bondExtra(binaryAmount);
|
|
272
|
+
}
|
|
273
|
+
if (nominatorMetadata.isBondedBefore && targetValidators.length > 0) {
|
|
274
|
+
nominateTx = chainApi.api.tx.staking.nominate(targetValidators);
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
if (bondTx && !nominateTx) {
|
|
278
|
+
return bondTx;
|
|
279
|
+
} else if (nominateTx && !bondTx) {
|
|
280
|
+
return nominateTx;
|
|
281
|
+
}
|
|
282
|
+
return chainApi.api.tx.utility.batchAll([bondTx, nominateTx]);
|
|
283
|
+
}
|
|
284
|
+
async function getRelayUnbondingExtrinsic(substrateApi, amount, nominatorMetadata) {
|
|
285
|
+
const chainApi = await substrateApi.isReady;
|
|
286
|
+
const binaryAmount = new _util.BN(amount);
|
|
287
|
+
const isUnstakeAll = amount === nominatorMetadata.activeStake;
|
|
288
|
+
if (isUnstakeAll) {
|
|
289
|
+
const chillTx = chainApi.api.tx.staking.chill();
|
|
290
|
+
const unbondTx = chainApi.api.tx.staking.unbond(binaryAmount);
|
|
291
|
+
return chainApi.api.tx.utility.batchAll([chillTx, unbondTx]);
|
|
292
|
+
}
|
|
293
|
+
return chainApi.api.tx.staking.unbond(binaryAmount);
|
|
294
|
+
}
|
|
295
|
+
async function getRelayWithdrawalExtrinsic(substrateApi, address) {
|
|
296
|
+
const chainApi = await substrateApi.isReady;
|
|
297
|
+
if (chainApi.api.tx.staking.withdrawUnbonded.meta.args.length === 1) {
|
|
298
|
+
const _slashingSpans = (await chainApi.api.query.staking.slashingSpans(address)).toHuman();
|
|
299
|
+
const slashingSpanCount = _slashingSpans !== null ? _slashingSpans.spanIndex : '0';
|
|
300
|
+
return chainApi.api.tx.staking.withdrawUnbonded(slashingSpanCount);
|
|
301
|
+
} else {
|
|
302
|
+
return chainApi.api.tx.staking.withdrawUnbonded();
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
async function getRelayCancelWithdrawalExtrinsic(substrateApi, selectedUnstaking) {
|
|
306
|
+
const chainApi = await substrateApi.isReady;
|
|
307
|
+
return chainApi.api.tx.staking.rebond(selectedUnstaking.claimable);
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
// Pooling txs
|
|
311
|
+
|
|
312
|
+
async function getPoolingClaimRewardExtrinsic(substrateApi) {
|
|
313
|
+
let bondReward = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
|
|
314
|
+
const chainApi = await substrateApi.isReady;
|
|
315
|
+
if (bondReward) {
|
|
316
|
+
return chainApi.api.tx.nominationPools.bondExtra('Rewards');
|
|
317
|
+
}
|
|
318
|
+
return chainApi.api.tx.nominationPools.claimPayout();
|
|
319
|
+
}
|
|
320
|
+
async function getPoolingBondingExtrinsic(substrateApi, amount, selectedPoolId, nominatorMetadata) {
|
|
321
|
+
const chainApi = await substrateApi.isReady;
|
|
322
|
+
const bnActiveStake = new _util.BN((nominatorMetadata === null || nominatorMetadata === void 0 ? void 0 : nominatorMetadata.activeStake) || '0');
|
|
323
|
+
if (bnActiveStake.gt(_util.BN_ZERO)) {
|
|
324
|
+
// already joined a pool
|
|
325
|
+
return chainApi.api.tx.nominationPools.bondExtra({
|
|
326
|
+
FreeBalance: amount
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
return chainApi.api.tx.nominationPools.join(amount, selectedPoolId);
|
|
330
|
+
}
|
|
331
|
+
async function getPoolingUnbondingExtrinsic(substrateApi, amount, nominatorMetadata) {
|
|
332
|
+
const chainApi = await substrateApi.isReady;
|
|
333
|
+
return chainApi.api.tx.nominationPools.unbond({
|
|
334
|
+
Id: nominatorMetadata.address
|
|
335
|
+
}, amount);
|
|
336
|
+
}
|
|
337
|
+
async function getPoolingWithdrawalExtrinsic(substrateApi, nominatorMetadata) {
|
|
338
|
+
const chainApi = await substrateApi.isReady;
|
|
339
|
+
if (chainApi.api.tx.nominationPools.withdrawUnbonded.meta.args.length === 2) {
|
|
340
|
+
const _slashingSpans = (await chainApi.api.query.staking.slashingSpans(nominatorMetadata.address)).toHuman();
|
|
341
|
+
const slashingSpanCount = _slashingSpans !== null ? _slashingSpans.spanIndex : '0';
|
|
342
|
+
return chainApi.api.tx.nominationPools.withdrawUnbonded({
|
|
343
|
+
Id: nominatorMetadata.address
|
|
344
|
+
}, slashingSpanCount);
|
|
345
|
+
} else {
|
|
346
|
+
return chainApi.api.tx.nominationPools.withdrawUnbonded({
|
|
347
|
+
Id: nominatorMetadata.address
|
|
348
|
+
});
|
|
349
|
+
}
|
|
350
|
+
}
|