@subwallet/extension-base 1.1.35-0 → 1.1.35-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/background/KoniTypes.d.ts +111 -69
- package/background/KoniTypes.js +19 -13
- package/background/errors/TransactionError.js +9 -0
- package/cjs/background/KoniTypes.js +20 -16
- package/cjs/background/errors/TransactionError.js +9 -0
- package/cjs/constants/index.js +19 -4
- package/cjs/koni/api/dotsama/balance.js +464 -0
- package/cjs/koni/api/nft/config.js +33 -23
- package/cjs/koni/api/nft/index.js +14 -0
- package/cjs/koni/api/nft/nft.js +1 -22
- package/cjs/koni/api/nft/ordinal_nft/constants.js +21 -0
- package/cjs/koni/api/nft/ordinal_nft/index.js +121 -0
- package/cjs/koni/api/nft/ordinal_nft/utils.js +41 -0
- package/cjs/koni/api/staking/bonding/amplitude.js +19 -16
- package/cjs/koni/api/staking/bonding/astar.js +11 -10
- package/cjs/koni/api/staking/bonding/index.js +4 -1
- package/cjs/koni/api/staking/bonding/paraChain.js +25 -23
- package/cjs/koni/api/staking/bonding/relayChain.js +48 -45
- package/cjs/koni/api/staking/bonding/utils.js +104 -86
- package/cjs/koni/api/staking/index.js +6 -5
- package/cjs/koni/api/staking/paraChain.js +6 -5
- package/cjs/koni/api/staking/relayChain.js +3 -2
- package/cjs/koni/api/yield/helper/utils.js +46 -0
- package/cjs/koni/background/cron.js +3 -21
- package/cjs/koni/background/handlers/Extension.js +368 -69
- package/cjs/koni/background/handlers/State.js +18 -12
- package/cjs/koni/background/handlers/index.js +4 -2
- package/cjs/koni/background/subscription.js +7 -104
- package/cjs/services/campaign-service/index.js +9 -6
- package/cjs/services/chain-service/constants.js +1 -16
- package/cjs/services/chain-service/index.js +6 -2
- package/cjs/services/chain-service/utils.js +7 -1
- package/cjs/services/earning-service/constants/chains.js +30 -0
- package/cjs/services/earning-service/constants/index.js +27 -0
- package/cjs/services/earning-service/constants/step.js +18 -0
- package/cjs/services/earning-service/handlers/base.js +262 -0
- package/cjs/services/earning-service/handlers/index.js +60 -0
- package/cjs/services/earning-service/handlers/lending/base.js +81 -0
- package/cjs/services/earning-service/handlers/lending/index.js +13 -0
- package/cjs/services/earning-service/handlers/lending/interlay.js +192 -0
- package/cjs/services/earning-service/handlers/liquid-staking/acala.js +240 -0
- package/cjs/services/earning-service/handlers/liquid-staking/base.js +97 -0
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost-manta.js +140 -0
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost.js +298 -0
- package/cjs/services/earning-service/handlers/liquid-staking/index.js +34 -0
- package/cjs/services/earning-service/handlers/liquid-staking/parallel.js +227 -0
- package/cjs/services/earning-service/handlers/liquid-staking/stella-swap.js +404 -0
- package/cjs/services/earning-service/handlers/native-staking/amplitude.js +434 -0
- package/cjs/services/earning-service/handlers/native-staking/astar.js +466 -0
- package/cjs/services/earning-service/handlers/native-staking/base-para.js +146 -0
- package/cjs/services/earning-service/handlers/native-staking/base.js +161 -0
- package/cjs/services/earning-service/handlers/native-staking/index.js +34 -0
- package/cjs/services/earning-service/handlers/native-staking/para-chain.js +390 -0
- package/cjs/services/earning-service/handlers/native-staking/relay-chain.js +567 -0
- package/cjs/services/earning-service/handlers/nomination-pool/index.js +566 -0
- package/cjs/services/earning-service/handlers/special.js +493 -0
- package/cjs/services/earning-service/service.js +733 -0
- package/cjs/services/earning-service/utils/index.js +128 -0
- package/cjs/services/event-service/index.js +5 -0
- package/cjs/services/keyring-service/index.js +14 -2
- package/cjs/services/migration-service/scripts/DeleteEarningData.js +21 -0
- package/cjs/services/migration-service/scripts/EnableEarningChains.js +21 -0
- package/cjs/services/migration-service/scripts/MigrateEthProvider.js +17 -0
- package/cjs/services/migration-service/scripts/MigrateLedgerAccount.js +1 -1
- package/cjs/services/migration-service/scripts/MigratePioneerProvider.js +17 -0
- package/cjs/services/migration-service/scripts/MigrateProvider.js +29 -0
- package/cjs/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
- package/cjs/services/migration-service/scripts/databases/MigrateEarningHistory.js +21 -0
- package/cjs/services/migration-service/scripts/databases/MigrateEarningVersion.js +21 -0
- package/cjs/services/migration-service/scripts/index.js +6 -1
- package/cjs/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +149 -0
- package/cjs/services/mint-campaign-service/campaigns/index.js +13 -0
- package/cjs/services/mint-campaign-service/constants.js +11 -0
- package/cjs/services/mint-campaign-service/index.js +18 -0
- package/cjs/services/notification-service/NotificationService.js +3 -2
- package/cjs/services/request-service/handler/PopupHandler.js +2 -3
- package/cjs/services/storage-service/DatabaseService.js +63 -0
- package/cjs/services/storage-service/databases/index.js +4 -0
- package/cjs/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/cjs/services/storage-service/db-stores/YieldPoolStore.js +36 -0
- package/cjs/services/storage-service/db-stores/YieldPositionStore.js +71 -0
- package/cjs/services/storage-service/index.js +241 -0
- package/cjs/services/subscan-service/index.js +16 -0
- package/cjs/services/transaction-service/event-parser/index.js +58 -0
- package/cjs/services/transaction-service/helpers/index.js +3 -1
- package/cjs/services/transaction-service/index.js +249 -75
- package/cjs/services/transaction-service/utils.js +1 -0
- package/cjs/types/campaigns/index.js +16 -0
- package/cjs/types/campaigns/unlock-dot.js +1 -0
- package/cjs/types/index.js +44 -0
- package/cjs/types/ordinal.js +1 -0
- package/cjs/types/transaction.js +1 -0
- package/cjs/types/yield/actions/index.js +27 -0
- package/cjs/types/yield/actions/join/index.js +38 -0
- package/cjs/types/yield/actions/join/step.js +47 -0
- package/cjs/types/yield/actions/join/submit.js +1 -0
- package/cjs/types/yield/actions/join/validate.js +16 -0
- package/cjs/types/yield/actions/others.js +1 -0
- package/cjs/types/yield/index.js +27 -0
- package/cjs/types/yield/info/account/index.js +49 -0
- package/cjs/types/yield/info/account/info.js +1 -0
- package/cjs/types/yield/info/account/reward.js +1 -0
- package/cjs/types/yield/info/account/target.js +32 -0
- package/cjs/types/yield/info/account/unstake.js +27 -0
- package/cjs/types/yield/info/base.js +41 -0
- package/cjs/types/yield/info/chain/index.js +27 -0
- package/cjs/types/yield/info/chain/info.js +1 -0
- package/cjs/types/yield/info/chain/target.js +1 -0
- package/cjs/types/yield/info/index.js +49 -0
- package/cjs/types/yield/info/pallet.js +15 -0
- package/cjs/types.js +1 -0
- package/cjs/utils/address.js +34 -0
- package/cjs/utils/environment.js +23 -28
- package/cjs/utils/fetchStaticCache.js +22 -0
- package/cjs/utils/fetchStaticData.js +2 -1
- package/cjs/utils/index.js +94 -10
- package/cjs/utils/keyring.js +57 -0
- package/cjs/utils/mv3.js +14 -0
- package/cjs/utils/number.js +6 -2
- package/cjs/utils/object.js +12 -0
- package/constants/index.d.ts +6 -1
- package/constants/index.js +6 -1
- package/koni/api/nft/config.js +33 -23
- package/koni/api/nft/index.js +15 -1
- package/koni/api/nft/nft.js +2 -23
- package/koni/api/nft/ordinal_nft/constants.d.ts +9 -0
- package/koni/api/nft/ordinal_nft/constants.js +12 -0
- package/koni/api/nft/ordinal_nft/index.d.ts +8 -0
- package/koni/api/nft/ordinal_nft/index.js +114 -0
- package/koni/api/nft/ordinal_nft/utils.d.ts +2 -0
- package/koni/api/nft/ordinal_nft/utils.js +33 -0
- package/koni/api/staking/bonding/amplitude.js +13 -10
- package/koni/api/staking/bonding/astar.js +9 -8
- package/koni/api/staking/bonding/index.d.ts +1 -1
- package/koni/api/staking/bonding/index.js +5 -1
- package/koni/api/staking/bonding/paraChain.js +12 -10
- package/koni/api/staking/bonding/relayChain.d.ts +2 -2
- package/koni/api/staking/bonding/relayChain.js +33 -30
- package/koni/api/staking/bonding/utils.d.ts +15 -38
- package/koni/api/staking/bonding/utils.js +85 -69
- package/koni/api/staking/index.js +2 -1
- package/koni/api/staking/paraChain.js +7 -6
- package/koni/api/staking/relayChain.js +4 -3
- package/koni/api/yield/helper/utils.d.ts +10 -0
- package/koni/api/yield/helper/utils.js +32 -0
- package/koni/background/cron.d.ts +0 -4
- package/koni/background/cron.js +4 -22
- package/koni/background/handlers/Extension.d.ts +17 -1
- package/koni/background/handlers/Extension.js +327 -30
- package/koni/background/handlers/State.d.ts +6 -1
- package/koni/background/handlers/State.js +17 -12
- package/koni/background/handlers/index.js +4 -2
- package/koni/background/subscription.d.ts +1 -6
- package/koni/background/subscription.js +8 -104
- package/package.json +326 -3
- package/services/campaign-service/index.js +9 -6
- package/services/chain-service/constants.d.ts +0 -12
- package/services/chain-service/constants.js +0 -14
- package/services/chain-service/index.js +6 -2
- package/services/chain-service/utils.d.ts +1 -0
- package/services/chain-service/utils.js +5 -1
- package/services/earning-service/constants/abis/compound_finance_v2_abi.json +1235 -0
- package/services/earning-service/constants/abis/st_liquid_token_abi.json +1355 -0
- package/services/earning-service/constants/chains.d.ts +15 -0
- package/services/earning-service/constants/chains.js +22 -0
- package/services/earning-service/constants/index.d.ts +2 -0
- package/services/earning-service/constants/index.js +5 -0
- package/services/earning-service/constants/step.d.ts +3 -0
- package/services/earning-service/constants/step.js +10 -0
- package/services/earning-service/handlers/base.d.ts +113 -0
- package/services/earning-service/handlers/base.js +256 -0
- package/services/earning-service/handlers/index.d.ts +5 -0
- package/services/earning-service/handlers/index.js +8 -0
- package/services/earning-service/handlers/lending/base.d.ts +8 -0
- package/services/earning-service/handlers/lending/base.js +73 -0
- package/services/earning-service/handlers/lending/index.d.ts +1 -0
- package/services/earning-service/handlers/lending/index.js +4 -0
- package/services/earning-service/handlers/lending/interlay.d.ts +24 -0
- package/services/earning-service/handlers/lending/interlay.js +184 -0
- package/services/earning-service/handlers/liquid-staking/acala.d.ts +27 -0
- package/services/earning-service/handlers/liquid-staking/acala.js +232 -0
- package/services/earning-service/handlers/liquid-staking/base.d.ts +11 -0
- package/services/earning-service/handlers/liquid-staking/base.js +89 -0
- package/services/earning-service/handlers/liquid-staking/bifrost.d.ts +46 -0
- package/services/earning-service/handlers/liquid-staking/bifrost.js +287 -0
- package/services/earning-service/handlers/liquid-staking/index.d.ts +4 -0
- package/services/earning-service/handlers/liquid-staking/index.js +7 -0
- package/services/earning-service/handlers/liquid-staking/parallel.d.ts +26 -0
- package/services/earning-service/handlers/liquid-staking/parallel.js +219 -0
- package/services/earning-service/handlers/liquid-staking/stella-swap.d.ts +34 -0
- package/services/earning-service/handlers/liquid-staking/stella-swap.js +394 -0
- package/services/earning-service/handlers/native-staking/amplitude.d.ts +22 -0
- package/services/earning-service/handlers/native-staking/amplitude.js +425 -0
- package/services/earning-service/handlers/native-staking/astar.d.ts +19 -0
- package/services/earning-service/handlers/native-staking/astar.js +456 -0
- package/services/earning-service/handlers/native-staking/base-para.d.ts +11 -0
- package/services/earning-service/handlers/native-staking/base-para.js +138 -0
- package/services/earning-service/handlers/native-staking/base.d.ts +21 -0
- package/services/earning-service/handlers/native-staking/base.js +152 -0
- package/services/earning-service/handlers/native-staking/index.d.ts +4 -0
- package/services/earning-service/handlers/native-staking/index.js +7 -0
- package/services/earning-service/handlers/native-staking/para-chain.d.ts +15 -0
- package/services/earning-service/handlers/native-staking/para-chain.js +382 -0
- package/services/earning-service/handlers/native-staking/relay-chain.d.ts +21 -0
- package/services/earning-service/handlers/native-staking/relay-chain.js +558 -0
- package/services/earning-service/handlers/nomination-pool/index.d.ts +36 -0
- package/services/earning-service/handlers/nomination-pool/index.js +556 -0
- package/services/earning-service/handlers/special.d.ts +64 -0
- package/services/earning-service/handlers/special.js +485 -0
- package/services/earning-service/service.d.ts +94 -0
- package/services/earning-service/service.js +722 -0
- package/services/earning-service/utils/index.d.ts +18 -0
- package/services/earning-service/utils/index.js +112 -0
- package/services/event-service/index.d.ts +2 -0
- package/services/event-service/index.js +5 -0
- package/services/event-service/types.d.ts +9 -0
- package/services/keyring-service/index.d.ts +2 -1
- package/services/keyring-service/index.js +14 -2
- package/services/migration-service/scripts/DeleteEarningData.d.ts +4 -0
- package/services/migration-service/scripts/DeleteEarningData.js +13 -0
- package/services/migration-service/scripts/EnableEarningChains.d.ts +4 -0
- package/services/migration-service/scripts/EnableEarningChains.js +13 -0
- package/services/migration-service/scripts/MigrateLedgerAccount.js +1 -1
- package/services/migration-service/scripts/MigrateTransactionHistory.js +1 -1
- package/services/migration-service/scripts/databases/MigrateEarningHistory.d.ts +4 -0
- package/services/migration-service/scripts/databases/MigrateEarningHistory.js +13 -0
- package/services/migration-service/scripts/databases/MigrateEarningVersion.d.ts +4 -0
- package/services/migration-service/scripts/databases/MigrateEarningVersion.js +13 -0
- package/services/migration-service/scripts/index.js +6 -1
- package/services/mint-campaign-service/campaigns/UnlockDotCampaign.d.ts +13 -0
- package/services/mint-campaign-service/campaigns/UnlockDotCampaign.js +139 -0
- package/services/mint-campaign-service/campaigns/index.d.ts +1 -0
- package/services/mint-campaign-service/campaigns/index.js +4 -0
- package/services/mint-campaign-service/constants.d.ts +1 -0
- package/services/mint-campaign-service/constants.js +4 -0
- package/services/mint-campaign-service/index.d.ts +7 -0
- package/services/mint-campaign-service/index.js +11 -0
- package/services/notification-service/NotificationService.js +3 -2
- package/services/request-service/handler/PopupHandler.js +3 -4
- package/services/storage-service/DatabaseService.d.ts +22 -1
- package/services/storage-service/DatabaseService.js +63 -0
- package/services/storage-service/databases/index.d.ts +3 -1
- package/services/storage-service/databases/index.js +4 -0
- package/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/services/storage-service/db-stores/YieldPoolStore.d.ts +10 -0
- package/services/storage-service/db-stores/YieldPoolStore.js +28 -0
- package/services/storage-service/db-stores/YieldPositionStore.d.ts +11 -0
- package/services/storage-service/db-stores/YieldPositionStore.js +63 -0
- package/services/subscan-service/index.d.ts +3 -2
- package/services/subscan-service/index.js +15 -0
- package/services/subscan-service/types.d.ts +20 -0
- package/services/transaction-service/event-parser/index.d.ts +3 -1
- package/services/transaction-service/event-parser/index.js +57 -1
- package/services/transaction-service/helpers/index.js +3 -1
- package/services/transaction-service/index.d.ts +6 -13
- package/services/transaction-service/index.js +247 -73
- package/services/transaction-service/types.d.ts +2 -0
- package/services/transaction-service/utils.js +1 -0
- package/types/campaigns/index.d.ts +1 -0
- package/types/campaigns/index.js +4 -0
- package/types/campaigns/unlock-dot.d.ts +71 -0
- package/types/campaigns/unlock-dot.js +1 -0
- package/types/index.d.ts +5 -0
- package/types/index.js +5 -1
- package/types/ordinal.d.ts +69 -0
- package/types/ordinal.js +1 -0
- package/types/transaction.d.ts +3 -0
- package/types/transaction.js +1 -0
- package/types/yield/actions/index.d.ts +2 -0
- package/types/yield/actions/index.js +5 -0
- package/types/yield/actions/join/index.d.ts +3 -0
- package/types/yield/actions/join/index.js +6 -0
- package/types/yield/actions/join/step.d.ts +95 -0
- package/types/yield/actions/join/step.js +46 -0
- package/types/yield/actions/join/submit.d.ts +58 -0
- package/types/yield/actions/join/submit.js +1 -0
- package/types/yield/actions/join/validate.d.ts +18 -0
- package/types/yield/actions/join/validate.js +10 -0
- package/types/yield/actions/others.d.ts +85 -0
- package/types/yield/actions/others.js +1 -0
- package/types/yield/index.d.ts +2 -0
- package/types/yield/index.js +5 -0
- package/types/yield/info/account/index.d.ts +4 -0
- package/types/yield/info/account/index.js +7 -0
- package/types/yield/info/account/info.d.ts +92 -0
- package/types/yield/info/account/info.js +1 -0
- package/types/yield/info/account/reward.d.ts +47 -0
- package/types/yield/info/account/reward.js +1 -0
- package/types/yield/info/account/target.d.ts +43 -0
- package/types/yield/info/account/target.js +27 -0
- package/types/yield/info/account/unstake.d.ts +31 -0
- package/types/yield/info/account/unstake.js +22 -0
- package/types/yield/info/base.d.ts +45 -0
- package/types/yield/info/base.js +36 -0
- package/types/yield/info/chain/index.d.ts +2 -0
- package/types/yield/info/chain/index.js +5 -0
- package/types/yield/info/chain/info.d.ts +252 -0
- package/types/yield/info/chain/info.js +1 -0
- package/types/yield/info/chain/target.d.ts +37 -0
- package/types/yield/info/chain/target.js +1 -0
- package/types/yield/info/index.d.ts +4 -0
- package/types/yield/info/index.js +7 -0
- package/types/yield/info/pallet.d.ts +143 -0
- package/types/yield/info/pallet.js +9 -0
- package/utils/environment.d.ts +9 -2
- package/utils/environment.js +14 -26
- package/utils/fetchStaticCache.d.ts +1 -0
- package/utils/fetchStaticCache.js +14 -0
- package/utils/fetchStaticData.js +2 -1
- package/utils/index.d.ts +5 -1
- package/utils/index.js +53 -3
- package/utils/mv3.d.ts +2 -0
- package/utils/mv3.js +6 -0
- package/utils/number.d.ts +2 -1
- package/utils/number.js +2 -1
- package/utils/object.d.ts +1 -0
- package/utils/object.js +6 -0
|
@@ -0,0 +1,566 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _TransactionError = require("@subwallet/extension-base/background/errors/TransactionError");
|
|
9
|
+
var _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
|
|
10
|
+
var _utils = require("@subwallet/extension-base/koni/api/staking/bonding/utils");
|
|
11
|
+
var _constants = require("@subwallet/extension-base/services/chain-service/constants");
|
|
12
|
+
var _utils2 = require("@subwallet/extension-base/services/chain-service/utils");
|
|
13
|
+
var _types = require("@subwallet/extension-base/types");
|
|
14
|
+
var _utils3 = require("@subwallet/extension-base/utils");
|
|
15
|
+
var _bignumber = _interopRequireDefault(require("bignumber.js"));
|
|
16
|
+
var _i18next = require("i18next");
|
|
17
|
+
var _util = require("@polkadot/util");
|
|
18
|
+
var _base = _interopRequireDefault(require("../base"));
|
|
19
|
+
// Copyright 2019-2022 @subwallet/extension-base
|
|
20
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
21
|
+
|
|
22
|
+
class NominationPoolHandler extends _base.default {
|
|
23
|
+
type = _types.YieldPoolType.NOMINATION_POOL;
|
|
24
|
+
availableMethod = {
|
|
25
|
+
join: true,
|
|
26
|
+
defaultUnstake: true,
|
|
27
|
+
fastUnstake: false,
|
|
28
|
+
cancelUnstake: false,
|
|
29
|
+
withdraw: true,
|
|
30
|
+
claimReward: true
|
|
31
|
+
};
|
|
32
|
+
constructor(state, chain) {
|
|
33
|
+
super(state, chain);
|
|
34
|
+
const _chainAsset = this.nativeToken;
|
|
35
|
+
const _chainInfo = this.chainInfo;
|
|
36
|
+
const symbol = _chainAsset.symbol;
|
|
37
|
+
const tokenName = _chainAsset.name;
|
|
38
|
+
this.slug = `${symbol}___nomination_pool___${_chainInfo.slug}`;
|
|
39
|
+
this.name = `${tokenName} Nomination Pool`;
|
|
40
|
+
this.shortName = _chainInfo.name.replaceAll(' Relay Chain', '');
|
|
41
|
+
}
|
|
42
|
+
getDescription() {
|
|
43
|
+
let amount = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '0';
|
|
44
|
+
const _chainAsset = this.nativeToken;
|
|
45
|
+
const symbol = _chainAsset.symbol;
|
|
46
|
+
return `Start staking with just {{amount}} ${symbol}`.replace('{{amount}}', amount);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
/* Subscribe pool info */
|
|
50
|
+
|
|
51
|
+
async subscribePoolInfo(callback) {
|
|
52
|
+
var _substrateApi$api$que;
|
|
53
|
+
let cancel = false;
|
|
54
|
+
const substrateApi = this.substrateApi;
|
|
55
|
+
const chainInfo = this.chainInfo;
|
|
56
|
+
const nativeToken = this.nativeToken;
|
|
57
|
+
const defaultCallback = async () => {
|
|
58
|
+
const data = {
|
|
59
|
+
...this.baseInfo,
|
|
60
|
+
type: this.type,
|
|
61
|
+
metadata: {
|
|
62
|
+
...this.metadataInfo,
|
|
63
|
+
description: this.getDescription()
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
const poolInfo = await this.getPoolInfo();
|
|
67
|
+
!poolInfo && callback(data);
|
|
68
|
+
};
|
|
69
|
+
if (!this.isActive) {
|
|
70
|
+
await defaultCallback();
|
|
71
|
+
return () => {
|
|
72
|
+
cancel = true;
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
await defaultCallback();
|
|
76
|
+
await substrateApi.isReady;
|
|
77
|
+
const unsub = await ((_substrateApi$api$que = substrateApi.api.query.staking) === null || _substrateApi$api$que === void 0 ? void 0 : _substrateApi$api$que.currentEra(async _currentEra => {
|
|
78
|
+
var _substrateApi$api$que2, _substrateApi$api$que3, _substrateApi$api$que4;
|
|
79
|
+
if (cancel) {
|
|
80
|
+
unsub();
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
if (!substrateApi.api.query.nominationPools) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
const currentEra = _currentEra.toString();
|
|
87
|
+
const maxUnlockingChunks = substrateApi.api.consts.staking.maxUnlockingChunks.toString();
|
|
88
|
+
const unlockingEras = substrateApi.api.consts.staking.bondingDuration.toString();
|
|
89
|
+
const [_totalEraStake, _totalIssuance, _auctionCounter, _minPoolJoin] = await Promise.all([substrateApi.api.query.staking.erasTotalStake(parseInt(currentEra)), substrateApi.api.query.balances.totalIssuance(), (_substrateApi$api$que2 = substrateApi.api.query.auctions) === null || _substrateApi$api$que2 === void 0 ? void 0 : _substrateApi$api$que2.auctionCounter(), (_substrateApi$api$que3 = substrateApi.api.query) === null || _substrateApi$api$que3 === void 0 ? void 0 : (_substrateApi$api$que4 = _substrateApi$api$que3.nominationPools) === null || _substrateApi$api$que4 === void 0 ? void 0 : _substrateApi$api$que4.minJoinBond()]);
|
|
90
|
+
const rawTotalEraStake = _totalEraStake.toString();
|
|
91
|
+
const rawTotalIssuance = _totalIssuance.toString();
|
|
92
|
+
const numAuctions = _auctionCounter ? _auctionCounter.toHuman() : 0;
|
|
93
|
+
const bnTotalEraStake = new _util.BN(rawTotalEraStake);
|
|
94
|
+
const bnTotalIssuance = new _util.BN(rawTotalIssuance);
|
|
95
|
+
const inflation = (0, _utils.calculateInflation)(bnTotalEraStake, bnTotalIssuance, numAuctions, chainInfo.slug);
|
|
96
|
+
const minPoolJoin = (_minPoolJoin === null || _minPoolJoin === void 0 ? void 0 : _minPoolJoin.toString()) || undefined;
|
|
97
|
+
const expectedReturn = (0, _utils.calculateChainStakedReturn)(inflation, bnTotalEraStake, bnTotalIssuance, chainInfo.slug);
|
|
98
|
+
const eraTime = _constants._STAKING_ERA_LENGTH_MAP[this.chain] || _constants._STAKING_ERA_LENGTH_MAP.default; // in hours
|
|
99
|
+
const unlockingPeriod = parseInt(unlockingEras) * eraTime; // in hours
|
|
100
|
+
|
|
101
|
+
const minToHuman = (0, _utils3.formatNumber)(minPoolJoin || '0', nativeToken.decimals || 0, _utils3.balanceFormatter);
|
|
102
|
+
const data = {
|
|
103
|
+
...this.baseInfo,
|
|
104
|
+
type: this.type,
|
|
105
|
+
metadata: {
|
|
106
|
+
...this.metadataInfo,
|
|
107
|
+
description: this.getDescription(minToHuman)
|
|
108
|
+
},
|
|
109
|
+
statistic: {
|
|
110
|
+
assetEarning: [{
|
|
111
|
+
slug: this.nativeToken.slug,
|
|
112
|
+
apy: expectedReturn
|
|
113
|
+
}],
|
|
114
|
+
maxCandidatePerFarmer: 1,
|
|
115
|
+
maxWithdrawalRequestPerFarmer: parseInt(maxUnlockingChunks),
|
|
116
|
+
// TODO recheck
|
|
117
|
+
earningThreshold: {
|
|
118
|
+
join: minPoolJoin || '0',
|
|
119
|
+
defaultUnstake: '0',
|
|
120
|
+
fastUnstake: '0'
|
|
121
|
+
},
|
|
122
|
+
farmerCount: 0,
|
|
123
|
+
// TODO recheck
|
|
124
|
+
era: parseInt(currentEra),
|
|
125
|
+
eraTime,
|
|
126
|
+
tvl: bnTotalEraStake.toString(),
|
|
127
|
+
// TODO recheck
|
|
128
|
+
totalApy: expectedReturn,
|
|
129
|
+
// TODO recheck
|
|
130
|
+
unstakingPeriod: unlockingPeriod,
|
|
131
|
+
inflation: inflation
|
|
132
|
+
}
|
|
133
|
+
};
|
|
134
|
+
callback(data);
|
|
135
|
+
}));
|
|
136
|
+
return () => {
|
|
137
|
+
cancel = true;
|
|
138
|
+
unsub();
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
/* Subscribe pool info */
|
|
143
|
+
|
|
144
|
+
/* Subscribe pool position */
|
|
145
|
+
|
|
146
|
+
async parsePoolMemberMetadata(substrateApi, poolMemberInfo, currentEra, _deriveSessionProgress) {
|
|
147
|
+
const chainInfo = this.chainInfo;
|
|
148
|
+
const unlimitedNominatorRewarded = substrateApi.api.consts.staking.maxExposurePageSize !== undefined;
|
|
149
|
+
const _maxNominatorRewardedPerValidator = (substrateApi.api.consts.staking.maxNominatorRewardedPerValidator || 0).toString();
|
|
150
|
+
const maxNominatorRewardedPerValidator = parseInt(_maxNominatorRewardedPerValidator);
|
|
151
|
+
const poolsPalletId = substrateApi.api.consts.nominationPools.palletId.toString();
|
|
152
|
+
const poolStashAccount = (0, _utils.parsePoolStashAddress)(substrateApi.api, 0, poolMemberInfo.poolId, poolsPalletId);
|
|
153
|
+
const [_nominations, _poolMetadata] = await Promise.all([substrateApi.api.query.staking.nominators(poolStashAccount), substrateApi.api.query.nominationPools.metadata(poolMemberInfo.poolId)]);
|
|
154
|
+
const poolMetadata = _poolMetadata.toPrimitive();
|
|
155
|
+
const nominations = _nominations.toJSON();
|
|
156
|
+
const poolName = (0, _util.isHex)(poolMetadata) ? (0, _util.hexToString)(poolMetadata) : poolMetadata;
|
|
157
|
+
let stakingStatus = _types.EarningStatus.NOT_EARNING;
|
|
158
|
+
if (nominations) {
|
|
159
|
+
const validatorList = nominations.targets;
|
|
160
|
+
await Promise.all(validatorList.map(async validatorAddress => {
|
|
161
|
+
const _eraStaker = await substrateApi.api.query.staking.erasStakers(currentEra, validatorAddress);
|
|
162
|
+
const eraStaker = _eraStaker.toPrimitive();
|
|
163
|
+
const sortedNominators = eraStaker.others.sort((a, b) => {
|
|
164
|
+
return new _bignumber.default(b.value).minus(a.value).toNumber();
|
|
165
|
+
});
|
|
166
|
+
const topNominators = sortedNominators.map(nominator => {
|
|
167
|
+
return nominator.who;
|
|
168
|
+
}).slice(0, unlimitedNominatorRewarded ? undefined : maxNominatorRewardedPerValidator);
|
|
169
|
+
if (topNominators.includes((0, _utils3.reformatAddress)(poolStashAccount, (0, _utils2._getChainSubstrateAddressPrefix)(chainInfo)))) {
|
|
170
|
+
// if address in top nominators
|
|
171
|
+
stakingStatus = _types.EarningStatus.EARNING_REWARD;
|
|
172
|
+
}
|
|
173
|
+
}));
|
|
174
|
+
}
|
|
175
|
+
const joinedPoolInfo = {
|
|
176
|
+
activeStake: poolMemberInfo.points.toString(),
|
|
177
|
+
chain: chainInfo.slug,
|
|
178
|
+
status: stakingStatus,
|
|
179
|
+
validatorIdentity: poolName,
|
|
180
|
+
validatorAddress: poolMemberInfo.poolId.toString(),
|
|
181
|
+
// use poolId
|
|
182
|
+
hasUnstaking: poolMemberInfo.unbondingEras && Object.keys(poolMemberInfo.unbondingEras).length > 0
|
|
183
|
+
};
|
|
184
|
+
const unstakings = [];
|
|
185
|
+
let unstakingBalance = _util.BN_ZERO;
|
|
186
|
+
Object.entries(poolMemberInfo.unbondingEras).forEach(_ref => {
|
|
187
|
+
let [unlockingEra, amount] = _ref;
|
|
188
|
+
// Calculate the remaining time for current era ending
|
|
189
|
+
const isClaimable = parseInt(unlockingEra) - parseInt(currentEra) < 0;
|
|
190
|
+
const remainingEra = parseInt(unlockingEra) - parseInt(currentEra);
|
|
191
|
+
const expectedBlockTime = _constants._EXPECTED_BLOCK_TIME[this.chain];
|
|
192
|
+
const eraLength = _deriveSessionProgress.eraLength.toNumber();
|
|
193
|
+
const eraProgress = _deriveSessionProgress.eraProgress.toNumber();
|
|
194
|
+
const remainingSlots = eraLength - eraProgress;
|
|
195
|
+
const remainingHours = expectedBlockTime * remainingSlots / 60 / 60;
|
|
196
|
+
const eraTime = _constants._STAKING_ERA_LENGTH_MAP[chainInfo.slug] || _constants._STAKING_ERA_LENGTH_MAP.default; // in hours
|
|
197
|
+
const waitingTime = remainingEra * eraTime + remainingHours;
|
|
198
|
+
unstakingBalance = unstakingBalance.add(new _util.BN(amount));
|
|
199
|
+
unstakings.push({
|
|
200
|
+
chain: chainInfo.slug,
|
|
201
|
+
status: isClaimable ? _types.UnstakingStatus.CLAIMABLE : _types.UnstakingStatus.UNLOCKING,
|
|
202
|
+
claimable: amount.toString(),
|
|
203
|
+
waitingTime: waitingTime
|
|
204
|
+
});
|
|
205
|
+
});
|
|
206
|
+
const bnActiveStake = new _util.BN(poolMemberInfo.points.toString());
|
|
207
|
+
const bnTotalStake = bnActiveStake.add(unstakingBalance);
|
|
208
|
+
if (!bnActiveStake.gt(_util.BN_ZERO)) {
|
|
209
|
+
stakingStatus = _types.EarningStatus.NOT_EARNING;
|
|
210
|
+
}
|
|
211
|
+
return {
|
|
212
|
+
status: stakingStatus,
|
|
213
|
+
balanceToken: this.nativeToken.slug,
|
|
214
|
+
totalStake: bnTotalStake.toString(),
|
|
215
|
+
activeStake: bnActiveStake.toString(),
|
|
216
|
+
unstakeBalance: unstakingBalance.toString(),
|
|
217
|
+
isBondedBefore: bnTotalStake.gt(_util.BN_ZERO),
|
|
218
|
+
nominations: [joinedPoolInfo],
|
|
219
|
+
// can only join 1 pool at a time
|
|
220
|
+
unstakings
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
224
|
+
var _substrateApi$api$que5, _substrateApi$api$que6;
|
|
225
|
+
let cancel = false;
|
|
226
|
+
const substrateApi = this.substrateApi;
|
|
227
|
+
const defaultInfo = this.baseInfo;
|
|
228
|
+
await substrateApi.isReady;
|
|
229
|
+
const unsub = await ((_substrateApi$api$que5 = substrateApi.api.query) === null || _substrateApi$api$que5 === void 0 ? void 0 : (_substrateApi$api$que6 = _substrateApi$api$que5.nominationPools) === null || _substrateApi$api$que6 === void 0 ? void 0 : _substrateApi$api$que6.poolMembers.multi(useAddresses, async ledgers => {
|
|
230
|
+
if (cancel) {
|
|
231
|
+
unsub();
|
|
232
|
+
return;
|
|
233
|
+
}
|
|
234
|
+
if (ledgers) {
|
|
235
|
+
var _substrateApi$api$der, _substrateApi$api$der2;
|
|
236
|
+
const [_currentEra, _deriveSessionProgress] = await Promise.all([substrateApi.api.query.staking.currentEra(), (_substrateApi$api$der = substrateApi.api.derive) === null || _substrateApi$api$der === void 0 ? void 0 : (_substrateApi$api$der2 = _substrateApi$api$der.session) === null || _substrateApi$api$der2 === void 0 ? void 0 : _substrateApi$api$der2.progress()]);
|
|
237
|
+
const currentEra = _currentEra.toString();
|
|
238
|
+
await Promise.all(ledgers.map(async (_poolMemberInfo, i) => {
|
|
239
|
+
const poolMemberInfo = _poolMemberInfo.toPrimitive();
|
|
240
|
+
const owner = (0, _utils3.reformatAddress)(useAddresses[i], 42);
|
|
241
|
+
if (poolMemberInfo) {
|
|
242
|
+
const nominatorMetadata = await this.parsePoolMemberMetadata(substrateApi, poolMemberInfo, currentEra, _deriveSessionProgress);
|
|
243
|
+
resultCallback({
|
|
244
|
+
...defaultInfo,
|
|
245
|
+
...nominatorMetadata,
|
|
246
|
+
address: owner,
|
|
247
|
+
type: this.type
|
|
248
|
+
});
|
|
249
|
+
} else {
|
|
250
|
+
resultCallback({
|
|
251
|
+
...defaultInfo,
|
|
252
|
+
type: this.type,
|
|
253
|
+
address: owner,
|
|
254
|
+
balanceToken: this.nativeToken.slug,
|
|
255
|
+
totalStake: '0',
|
|
256
|
+
activeStake: '0',
|
|
257
|
+
unstakeBalance: '0',
|
|
258
|
+
isBondedBefore: false,
|
|
259
|
+
status: _types.EarningStatus.NOT_STAKING,
|
|
260
|
+
nominations: [],
|
|
261
|
+
// can only join 1 pool at a time
|
|
262
|
+
unstakings: []
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
}));
|
|
266
|
+
}
|
|
267
|
+
}));
|
|
268
|
+
return () => {
|
|
269
|
+
cancel = true;
|
|
270
|
+
unsub();
|
|
271
|
+
};
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
/* Subscribe pool position */
|
|
275
|
+
|
|
276
|
+
/* Get pool reward */
|
|
277
|
+
|
|
278
|
+
async getPoolReward(useAddresses, callBack) {
|
|
279
|
+
let cancel = false;
|
|
280
|
+
const substrateApi = this.substrateApi;
|
|
281
|
+
await substrateApi.isReady;
|
|
282
|
+
if (substrateApi.api.call.nominationPoolsApi) {
|
|
283
|
+
for (const address of useAddresses) {
|
|
284
|
+
if (!cancel) {
|
|
285
|
+
var _substrateApi$api$cal, _substrateApi$api$cal2;
|
|
286
|
+
const _unclaimedReward = await ((_substrateApi$api$cal = substrateApi.api.call) === null || _substrateApi$api$cal === void 0 ? void 0 : (_substrateApi$api$cal2 = _substrateApi$api$cal.nominationPoolsApi) === null || _substrateApi$api$cal2 === void 0 ? void 0 : _substrateApi$api$cal2.pendingRewards(address));
|
|
287
|
+
if (_unclaimedReward) {
|
|
288
|
+
callBack({
|
|
289
|
+
...this.baseInfo,
|
|
290
|
+
address: address,
|
|
291
|
+
type: this.type,
|
|
292
|
+
unclaimedReward: _unclaimedReward.toString(),
|
|
293
|
+
state: _KoniTypes.APIItemState.READY
|
|
294
|
+
});
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
return () => {
|
|
300
|
+
cancel = false;
|
|
301
|
+
};
|
|
302
|
+
}
|
|
303
|
+
async getPoolRewardHistory(useAddresses, callBack) {
|
|
304
|
+
return new Promise(resolve => resolve(_util.noop));
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
/* Get pool reward */
|
|
308
|
+
|
|
309
|
+
/* Get pool targets */
|
|
310
|
+
|
|
311
|
+
async getPoolTargets() {
|
|
312
|
+
const substrateApi = await this.substrateApi.isReady;
|
|
313
|
+
const nominationPools = [];
|
|
314
|
+
const _allPoolsInfo = await substrateApi.api.query.nominationPools.reversePoolIdLookup.entries();
|
|
315
|
+
await Promise.all(_allPoolsInfo.map(async _poolInfo => {
|
|
316
|
+
var _bondedPool$points;
|
|
317
|
+
const poolAddressList = _poolInfo[0].toHuman();
|
|
318
|
+
const poolAddress = poolAddressList[0];
|
|
319
|
+
const poolId = _poolInfo[1].toPrimitive();
|
|
320
|
+
const poolsPalletId = substrateApi.api.consts.nominationPools.palletId.toString();
|
|
321
|
+
const poolStashAccount = (0, _utils.parsePoolStashAddress)(substrateApi.api, 0, poolId, poolsPalletId);
|
|
322
|
+
const [_nominations, _bondedPool, _metadata, _minimumActiveStake] = await Promise.all([substrateApi.api.query.staking.nominators(poolStashAccount), substrateApi.api.query.nominationPools.bondedPools(poolId), substrateApi.api.query.nominationPools.metadata(poolId), substrateApi.api.query.staking.minimumActiveStake()]);
|
|
323
|
+
const minimumActiveStake = _minimumActiveStake.toPrimitive();
|
|
324
|
+
const nominations = _nominations.toJSON();
|
|
325
|
+
const poolMetadata = _metadata.toPrimitive();
|
|
326
|
+
const bondedPool = _bondedPool.toPrimitive();
|
|
327
|
+
const poolName = (0, _util.isHex)(poolMetadata) ? (0, _util.hexToString)(poolMetadata) : poolMetadata;
|
|
328
|
+
const isPoolOpen = bondedPool.state === 'Open';
|
|
329
|
+
const isPoolNominating = !!nominations && nominations.targets.length > 0;
|
|
330
|
+
const isPoolEarningReward = bondedPool.points > minimumActiveStake;
|
|
331
|
+
nominationPools.push({
|
|
332
|
+
id: poolId,
|
|
333
|
+
address: poolAddress,
|
|
334
|
+
name: poolName,
|
|
335
|
+
bondedAmount: ((_bondedPool$points = bondedPool.points) === null || _bondedPool$points === void 0 ? void 0 : _bondedPool$points.toString()) || '0',
|
|
336
|
+
roles: bondedPool.roles,
|
|
337
|
+
memberCounter: bondedPool.memberCounter,
|
|
338
|
+
state: bondedPool.state,
|
|
339
|
+
isProfitable: isPoolOpen && isPoolNominating && isPoolEarningReward
|
|
340
|
+
});
|
|
341
|
+
}));
|
|
342
|
+
return nominationPools;
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
/* Get pool targets */
|
|
346
|
+
|
|
347
|
+
/* Join pool action */
|
|
348
|
+
|
|
349
|
+
get defaultSubmitStep() {
|
|
350
|
+
return [{
|
|
351
|
+
name: 'Join nomination pool',
|
|
352
|
+
type: _types.YieldStepType.JOIN_NOMINATION_POOL
|
|
353
|
+
}, {
|
|
354
|
+
slug: this.nativeToken.slug,
|
|
355
|
+
amount: '0'
|
|
356
|
+
}];
|
|
357
|
+
}
|
|
358
|
+
async getSubmitStep(params) {
|
|
359
|
+
const {
|
|
360
|
+
address,
|
|
361
|
+
amount,
|
|
362
|
+
slug,
|
|
363
|
+
targets
|
|
364
|
+
} = params;
|
|
365
|
+
if (!targets || !targets.length) {
|
|
366
|
+
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS));
|
|
367
|
+
}
|
|
368
|
+
const data = {
|
|
369
|
+
amount,
|
|
370
|
+
address,
|
|
371
|
+
slug,
|
|
372
|
+
selectedPool: targets[0]
|
|
373
|
+
};
|
|
374
|
+
const positionInfo = await this.getPoolPosition(address);
|
|
375
|
+
const [, fee] = await this.createJoinExtrinsic(data, positionInfo);
|
|
376
|
+
return [{
|
|
377
|
+
name: 'Join nomination pool',
|
|
378
|
+
type: _types.YieldStepType.JOIN_NOMINATION_POOL,
|
|
379
|
+
metadata: {
|
|
380
|
+
amount: amount
|
|
381
|
+
}
|
|
382
|
+
}, fee];
|
|
383
|
+
}
|
|
384
|
+
async validateYieldJoin(data, path) {
|
|
385
|
+
var _poolInfo$statistic;
|
|
386
|
+
const {
|
|
387
|
+
address,
|
|
388
|
+
amount,
|
|
389
|
+
selectedPool
|
|
390
|
+
} = data;
|
|
391
|
+
const _poolInfo = await this.getPoolInfo();
|
|
392
|
+
const bnAmount = new _util.BN(amount);
|
|
393
|
+
if (bnAmount.lte(_util.BN_ZERO)) {
|
|
394
|
+
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS, 'Amount must be greater than 0')];
|
|
395
|
+
}
|
|
396
|
+
if (!_poolInfo || !_poolInfo.statistic) {
|
|
397
|
+
return Promise.resolve([new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)]);
|
|
398
|
+
}
|
|
399
|
+
const poolInfo = _poolInfo;
|
|
400
|
+
const chainInfo = this.chainInfo;
|
|
401
|
+
const positionInfo = await this.getPoolPosition(address);
|
|
402
|
+
|
|
403
|
+
// cannot stake when unstake all
|
|
404
|
+
// amount >= min stake
|
|
405
|
+
const errors = [];
|
|
406
|
+
let bnTotalStake = new _util.BN(amount);
|
|
407
|
+
const bnMinStake = new _util.BN(((_poolInfo$statistic = poolInfo.statistic) === null || _poolInfo$statistic === void 0 ? void 0 : _poolInfo$statistic.earningThreshold.join) || '0');
|
|
408
|
+
const minStakeErrorMessage = (0, _utils.getMinStakeErrorMessage)(chainInfo, bnMinStake);
|
|
409
|
+
const existUnstakeErrorMessage = (0, _utils.getExistUnstakeErrorMessage)(chainInfo.slug, _KoniTypes.StakingType.POOLED, true);
|
|
410
|
+
if (selectedPool.state !== 'Open') {
|
|
411
|
+
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.INACTIVE_NOMINATION_POOL));
|
|
412
|
+
}
|
|
413
|
+
if (positionInfo) {
|
|
414
|
+
const bnCurrentActiveStake = new _util.BN(positionInfo.activeStake);
|
|
415
|
+
bnTotalStake = bnTotalStake.add(bnCurrentActiveStake);
|
|
416
|
+
if (positionInfo.unstakings.length > 0 && bnCurrentActiveStake.isZero()) {
|
|
417
|
+
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.EXIST_UNSTAKING_REQUEST, existUnstakeErrorMessage));
|
|
418
|
+
}
|
|
419
|
+
}
|
|
420
|
+
if (!bnTotalStake.gte(bnMinStake)) {
|
|
421
|
+
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.NOT_ENOUGH_MIN_STAKE, minStakeErrorMessage));
|
|
422
|
+
}
|
|
423
|
+
return errors;
|
|
424
|
+
}
|
|
425
|
+
async createJoinExtrinsic(data, positionInfo) {
|
|
426
|
+
const {
|
|
427
|
+
amount,
|
|
428
|
+
selectedPool: {
|
|
429
|
+
id: selectedPoolId
|
|
430
|
+
}
|
|
431
|
+
} = data;
|
|
432
|
+
const chainApi = await this.substrateApi.isReady;
|
|
433
|
+
const bnActiveStake = new _util.BN((positionInfo === null || positionInfo === void 0 ? void 0 : positionInfo.activeStake) || '0');
|
|
434
|
+
|
|
435
|
+
// eslint-disable-next-line @typescript-eslint/require-await
|
|
436
|
+
const compoundResult = async extrinsic => {
|
|
437
|
+
const tokenSlug = this.nativeToken.slug;
|
|
438
|
+
// const feeInfo = await extrinsic.paymentInfo(address);
|
|
439
|
+
// const fee = feeInfo.toPrimitive() as unknown as RuntimeDispatchInfo;
|
|
440
|
+
|
|
441
|
+
// Not use the fee to validate and to display on UI
|
|
442
|
+
return [extrinsic, {
|
|
443
|
+
slug: tokenSlug,
|
|
444
|
+
amount: '0'
|
|
445
|
+
}];
|
|
446
|
+
};
|
|
447
|
+
if (bnActiveStake.gt(_util.BN_ZERO)) {
|
|
448
|
+
// already joined a pool
|
|
449
|
+
const extrinsic = chainApi.api.tx.nominationPools.bondExtra({
|
|
450
|
+
FreeBalance: amount
|
|
451
|
+
});
|
|
452
|
+
return compoundResult(extrinsic);
|
|
453
|
+
}
|
|
454
|
+
const extrinsic = chainApi.api.tx.nominationPools.join(amount, selectedPoolId);
|
|
455
|
+
return compoundResult(extrinsic);
|
|
456
|
+
}
|
|
457
|
+
async handleYieldJoin(_data, path, currentStep) {
|
|
458
|
+
const data = _data;
|
|
459
|
+
const {
|
|
460
|
+
address,
|
|
461
|
+
amount,
|
|
462
|
+
selectedPool
|
|
463
|
+
} = data;
|
|
464
|
+
const positionInfo = await this.getPoolPosition(address);
|
|
465
|
+
const [extrinsic] = await this.createJoinExtrinsic(data, positionInfo);
|
|
466
|
+
const joinPoolData = {
|
|
467
|
+
poolPosition: positionInfo,
|
|
468
|
+
slug: this.slug,
|
|
469
|
+
selectedPool,
|
|
470
|
+
amount,
|
|
471
|
+
address
|
|
472
|
+
};
|
|
473
|
+
return {
|
|
474
|
+
txChain: this.chain,
|
|
475
|
+
extrinsicType: _KoniTypes.ExtrinsicType.STAKING_JOIN_POOL,
|
|
476
|
+
extrinsic,
|
|
477
|
+
txData: joinPoolData,
|
|
478
|
+
transferNativeAmount: amount,
|
|
479
|
+
chainType: _KoniTypes.ChainType.SUBSTRATE
|
|
480
|
+
};
|
|
481
|
+
}
|
|
482
|
+
|
|
483
|
+
/* Join pool action */
|
|
484
|
+
|
|
485
|
+
/* Leave pool action */
|
|
486
|
+
|
|
487
|
+
/**
|
|
488
|
+
* @todo Recheck
|
|
489
|
+
* */
|
|
490
|
+
async validateYieldLeave(amount, address, fastLeave, selectedTarget) {
|
|
491
|
+
const errors = [];
|
|
492
|
+
const poolInfo = await this.getPoolInfo();
|
|
493
|
+
const poolPosition = await this.getPoolPosition(address);
|
|
494
|
+
if (!poolInfo || !poolPosition || fastLeave || !poolInfo.statistic) {
|
|
495
|
+
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
496
|
+
}
|
|
497
|
+
if (fastLeave) {
|
|
498
|
+
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS)];
|
|
499
|
+
}
|
|
500
|
+
const bnAmount = new _util.BN(amount);
|
|
501
|
+
if (bnAmount.lte(_util.BN_ZERO)) {
|
|
502
|
+
errors.push(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS, (0, _i18next.t)('Amount must be greater than 0')));
|
|
503
|
+
}
|
|
504
|
+
const bnActiveStake = new _util.BN(poolPosition.activeStake);
|
|
505
|
+
const bnRemainingStake = bnActiveStake.sub(new _util.BN(amount));
|
|
506
|
+
const minStake = new _util.BN(poolInfo.statistic.earningThreshold.join || '0');
|
|
507
|
+
const maxUnstake = poolInfo.statistic.maxWithdrawalRequestPerFarmer;
|
|
508
|
+
if (!(bnRemainingStake.isZero() || bnRemainingStake.gte(minStake))) {
|
|
509
|
+
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.INVALID_ACTIVE_STAKE));
|
|
510
|
+
}
|
|
511
|
+
if (poolPosition.unstakings.length > maxUnstake) {
|
|
512
|
+
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.EXCEED_MAX_UNSTAKING, (0, _i18next.t)('You cannot unstake more than {{number}} times', {
|
|
513
|
+
replace: {
|
|
514
|
+
number: maxUnstake
|
|
515
|
+
}
|
|
516
|
+
})));
|
|
517
|
+
}
|
|
518
|
+
return Promise.resolve(errors);
|
|
519
|
+
}
|
|
520
|
+
async handleYieldRedeem(amount, address, selectedTarget) {
|
|
521
|
+
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.UNSUPPORTED));
|
|
522
|
+
}
|
|
523
|
+
async handleYieldUnstake(amount, address, selectedTarget) {
|
|
524
|
+
const chainApi = await this.substrateApi.isReady;
|
|
525
|
+
const poolPosition = await this.getPoolPosition(address);
|
|
526
|
+
if (!poolPosition) {
|
|
527
|
+
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR));
|
|
528
|
+
}
|
|
529
|
+
const extrinsic = chainApi.api.tx.nominationPools.unbond({
|
|
530
|
+
Id: poolPosition.address
|
|
531
|
+
}, amount);
|
|
532
|
+
return [_KoniTypes.ExtrinsicType.STAKING_LEAVE_POOL, extrinsic];
|
|
533
|
+
}
|
|
534
|
+
|
|
535
|
+
/* Leave pool action */
|
|
536
|
+
|
|
537
|
+
/* Other action */
|
|
538
|
+
|
|
539
|
+
handleYieldCancelUnstake(params) {
|
|
540
|
+
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.UNSUPPORTED));
|
|
541
|
+
}
|
|
542
|
+
async handleYieldClaimReward(address, bondReward) {
|
|
543
|
+
const chainApi = await this.substrateApi.isReady;
|
|
544
|
+
if (bondReward) {
|
|
545
|
+
return chainApi.api.tx.nominationPools.bondExtra('Rewards');
|
|
546
|
+
}
|
|
547
|
+
return chainApi.api.tx.nominationPools.claimPayout();
|
|
548
|
+
}
|
|
549
|
+
async handleYieldWithdraw(address, unstakingInfo) {
|
|
550
|
+
const chainApi = await this.substrateApi.isReady;
|
|
551
|
+
if (chainApi.api.tx.nominationPools.withdrawUnbonded.meta.args.length === 2) {
|
|
552
|
+
const _slashingSpans = (await chainApi.api.query.staking.slashingSpans(address)).toHuman();
|
|
553
|
+
const slashingSpanCount = _slashingSpans !== null ? _slashingSpans.spanIndex : '0';
|
|
554
|
+
return chainApi.api.tx.nominationPools.withdrawUnbonded({
|
|
555
|
+
Id: address
|
|
556
|
+
}, slashingSpanCount);
|
|
557
|
+
} else {
|
|
558
|
+
return chainApi.api.tx.nominationPools.withdrawUnbonded({
|
|
559
|
+
Id: address
|
|
560
|
+
});
|
|
561
|
+
}
|
|
562
|
+
}
|
|
563
|
+
|
|
564
|
+
/* Other actions */
|
|
565
|
+
}
|
|
566
|
+
exports.default = NominationPoolHandler;
|