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