@subwallet/extension-base 1.1.33-beta.1 → 1.1.34-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 +69 -120
- package/background/KoniTypes.js +13 -22
- package/background/errors/TransactionError.js +0 -9
- package/cjs/background/KoniTypes.js +16 -23
- package/cjs/background/errors/TransactionError.js +0 -9
- package/cjs/constants/index.js +4 -19
- 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 +16 -19
- 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 +17 -10
- package/cjs/koni/api/staking/relayChain.js +2 -3
- package/cjs/koni/background/cron.js +21 -3
- package/cjs/koni/background/handlers/Extension.js +69 -368
- package/cjs/koni/background/handlers/State.js +12 -18
- package/cjs/koni/background/handlers/index.js +2 -4
- package/cjs/koni/background/subscription.js +104 -7
- package/cjs/packageInfo.js +1 -1
- package/cjs/services/balance-service/helpers/subscribe/substrate/index.js +1 -3
- package/cjs/services/campaign-service/index.js +6 -9
- package/cjs/services/chain-service/constants.js +17 -2
- package/cjs/services/chain-service/index.js +3 -25
- package/cjs/services/chain-service/utils.js +1 -7
- package/cjs/services/event-service/index.js +0 -5
- 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 +1 -6
- package/cjs/services/notification-service/NotificationService.js +1 -1
- package/cjs/services/storage-service/DatabaseService.js +1 -92
- package/cjs/services/storage-service/databases/index.js +0 -7
- package/cjs/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/cjs/services/subscan-service/index.js +0 -16
- 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 +75 -252
- 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/cjs/utils/number.js +2 -6
- package/constants/index.d.ts +1 -6
- package/constants/index.js +1 -6
- 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 +10 -13
- 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 +18 -11
- package/koni/api/staking/relayChain.js +3 -4
- package/koni/background/cron.d.ts +4 -0
- package/koni/background/cron.js +22 -4
- package/koni/background/handlers/Extension.d.ts +1 -17
- package/koni/background/handlers/Extension.js +30 -327
- package/koni/background/handlers/State.d.ts +1 -6
- package/koni/background/handlers/State.js +12 -17
- package/koni/background/handlers/index.js +2 -4
- package/koni/background/subscription.d.ts +6 -1
- package/koni/background/subscription.js +104 -8
- package/package.json +8 -331
- package/packageInfo.js +1 -1
- package/services/balance-service/helpers/subscribe/substrate/index.js +2 -4
- package/services/campaign-service/index.js +6 -9
- package/services/chain-service/constants.d.ts +13 -1
- package/services/chain-service/constants.js +15 -1
- package/services/chain-service/index.d.ts +0 -2
- package/services/chain-service/index.js +3 -25
- 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 -2
- package/services/event-service/index.js +0 -5
- package/services/event-service/types.d.ts +0 -9
- 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 +1 -6
- package/services/notification-service/NotificationService.js +1 -1
- package/services/storage-service/DatabaseService.d.ts +3 -30
- package/services/storage-service/DatabaseService.js +1 -91
- package/services/storage-service/databases/index.d.ts +2 -8
- package/services/storage-service/databases/index.js +0 -7
- package/services/storage-service/db-stores/NominatorMetadata.js +3 -3
- package/services/subscan-service/index.d.ts +2 -3
- package/services/subscan-service/index.js +0 -15
- package/services/subscan-service/types.d.ts +0 -20
- 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 +13 -6
- package/services/transaction-service/index.js +73 -250
- 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 +0 -52
- package/utils/number.d.ts +1 -2
- package/utils/number.js +1 -2
- 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 -49
- package/cjs/services/earning-service/constants/chains.js +0 -30
- 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 -262
- package/cjs/services/earning-service/handlers/index.js +0 -60
- package/cjs/services/earning-service/handlers/lending/base.js +0 -81
- package/cjs/services/earning-service/handlers/lending/index.js +0 -13
- package/cjs/services/earning-service/handlers/lending/interlay.js +0 -192
- package/cjs/services/earning-service/handlers/liquid-staking/acala.js +0 -240
- package/cjs/services/earning-service/handlers/liquid-staking/base.js +0 -98
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost-manta.js +0 -140
- package/cjs/services/earning-service/handlers/liquid-staking/bifrost.js +0 -299
- package/cjs/services/earning-service/handlers/liquid-staking/index.js +0 -41
- package/cjs/services/earning-service/handlers/liquid-staking/parallel.js +0 -227
- package/cjs/services/earning-service/handlers/liquid-staking/stella-swap.js +0 -404
- package/cjs/services/earning-service/handlers/native-staking/amplitude.js +0 -434
- package/cjs/services/earning-service/handlers/native-staking/astar.js +0 -466
- package/cjs/services/earning-service/handlers/native-staking/base-para.js +0 -146
- package/cjs/services/earning-service/handlers/native-staking/base.js +0 -161
- package/cjs/services/earning-service/handlers/native-staking/index.js +0 -34
- package/cjs/services/earning-service/handlers/native-staking/para-chain.js +0 -390
- package/cjs/services/earning-service/handlers/native-staking/relay-chain.js +0 -567
- package/cjs/services/earning-service/handlers/nomination-pool/index.js +0 -566
- package/cjs/services/earning-service/handlers/special.js +0 -497
- package/cjs/services/earning-service/service.js +0 -741
- package/cjs/services/earning-service/utils/index.js +0 -128
- 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/migration-service/scripts/databases/MigrateEarningHistory.js +0 -21
- package/cjs/services/migration-service/scripts/databases/MigrateEarningVersion.js +0 -21
- 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/AssetRef.js +0 -24
- package/cjs/services/storage-service/db-stores/YieldPoolStore.js +0 -36
- package/cjs/services/storage-service/db-stores/YieldPositionStore.js +0 -71
- 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 -48
- 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 -41
- 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 -34
- 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 -15
- package/services/earning-service/constants/chains.js +0 -22
- 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 -113
- package/services/earning-service/handlers/base.js +0 -256
- 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 -8
- package/services/earning-service/handlers/lending/base.js +0 -73
- 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 -24
- package/services/earning-service/handlers/lending/interlay.js +0 -184
- package/services/earning-service/handlers/liquid-staking/acala.d.ts +0 -27
- package/services/earning-service/handlers/liquid-staking/acala.js +0 -232
- package/services/earning-service/handlers/liquid-staking/base.d.ts +0 -11
- package/services/earning-service/handlers/liquid-staking/base.js +0 -90
- package/services/earning-service/handlers/liquid-staking/bifrost-manta.d.ts +0 -37
- package/services/earning-service/handlers/liquid-staking/bifrost-manta.js +0 -132
- package/services/earning-service/handlers/liquid-staking/bifrost.d.ts +0 -46
- package/services/earning-service/handlers/liquid-staking/bifrost.js +0 -288
- package/services/earning-service/handlers/liquid-staking/index.d.ts +0 -5
- package/services/earning-service/handlers/liquid-staking/index.js +0 -8
- package/services/earning-service/handlers/liquid-staking/parallel.d.ts +0 -26
- package/services/earning-service/handlers/liquid-staking/parallel.js +0 -219
- package/services/earning-service/handlers/liquid-staking/stella-swap.d.ts +0 -34
- package/services/earning-service/handlers/liquid-staking/stella-swap.js +0 -394
- package/services/earning-service/handlers/native-staking/amplitude.d.ts +0 -22
- package/services/earning-service/handlers/native-staking/amplitude.js +0 -425
- package/services/earning-service/handlers/native-staking/astar.d.ts +0 -19
- package/services/earning-service/handlers/native-staking/astar.js +0 -456
- package/services/earning-service/handlers/native-staking/base-para.d.ts +0 -11
- package/services/earning-service/handlers/native-staking/base-para.js +0 -138
- package/services/earning-service/handlers/native-staking/base.d.ts +0 -21
- package/services/earning-service/handlers/native-staking/base.js +0 -152
- 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 -382
- package/services/earning-service/handlers/native-staking/relay-chain.d.ts +0 -21
- package/services/earning-service/handlers/native-staking/relay-chain.js +0 -558
- package/services/earning-service/handlers/nomination-pool/index.d.ts +0 -36
- package/services/earning-service/handlers/nomination-pool/index.js +0 -556
- package/services/earning-service/handlers/special.d.ts +0 -64
- package/services/earning-service/handlers/special.js +0 -489
- package/services/earning-service/service.d.ts +0 -94
- package/services/earning-service/service.js +0 -730
- package/services/earning-service/utils/index.d.ts +0 -18
- package/services/earning-service/utils/index.js +0 -112
- 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/migration-service/scripts/databases/MigrateEarningHistory.d.ts +0 -4
- package/services/migration-service/scripts/databases/MigrateEarningHistory.js +0 -13
- package/services/migration-service/scripts/databases/MigrateEarningVersion.d.ts +0 -4
- package/services/migration-service/scripts/databases/MigrateEarningVersion.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/AssetRef.d.ts +0 -7
- package/services/storage-service/db-stores/AssetRef.js +0 -16
- 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 -11
- package/services/storage-service/db-stores/YieldPositionStore.js +0 -63
- 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 -96
- package/types/yield/actions/join/step.js +0 -47
- package/types/yield/actions/join/submit.d.ts +0 -58
- 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 -85
- 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 -92
- package/types/yield/info/account/info.js +0 -1
- package/types/yield/info/account/reward.d.ts +0 -47
- 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 -45
- package/types/yield/info/base.js +0 -36
- 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 -252
- package/types/yield/info/chain/info.js +0 -1
- package/types/yield/info/chain/target.d.ts +0 -37
- 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,466 +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
|
-
exports.getAstarWithdrawable = getAstarWithdrawable;
|
|
9
|
-
var _TransactionError = require("@subwallet/extension-base/background/errors/TransactionError");
|
|
10
|
-
var _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
|
|
11
|
-
var _utils = require("@subwallet/extension-base/koni/api/staking/bonding/utils");
|
|
12
|
-
var _constants = require("@subwallet/extension-base/services/chain-service/constants");
|
|
13
|
-
var _types = require("@subwallet/extension-base/types");
|
|
14
|
-
var _utils2 = require("@subwallet/extension-base/utils");
|
|
15
|
-
var _crossFetch = _interopRequireDefault(require("cross-fetch"));
|
|
16
|
-
var _util = require("@polkadot/util");
|
|
17
|
-
var _utilCrypto = require("@polkadot/util-crypto");
|
|
18
|
-
var _basePara = _interopRequireDefault(require("./base-para"));
|
|
19
|
-
// Copyright 2019-2022 @subwallet/extension-base
|
|
20
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
21
|
-
|
|
22
|
-
const convertAddress = address => {
|
|
23
|
-
return (0, _utilCrypto.isEthereumAddress)(address) ? address.toLowerCase() : address;
|
|
24
|
-
};
|
|
25
|
-
function getAstarWithdrawable(yieldPosition) {
|
|
26
|
-
const unstakingInfo = {
|
|
27
|
-
chain: yieldPosition.chain,
|
|
28
|
-
status: _types.UnstakingStatus.CLAIMABLE,
|
|
29
|
-
claimable: '0',
|
|
30
|
-
waitingTime: 0
|
|
31
|
-
};
|
|
32
|
-
let bnWithdrawable = _util.BN_ZERO;
|
|
33
|
-
for (const unstaking of yieldPosition.unstakings) {
|
|
34
|
-
if (unstaking.status === _types.UnstakingStatus.CLAIMABLE) {
|
|
35
|
-
bnWithdrawable = bnWithdrawable.add(new _util.BN(unstaking.claimable));
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
if (bnWithdrawable.gt(_util.BN_ZERO)) {
|
|
39
|
-
unstakingInfo.claimable = bnWithdrawable.toString();
|
|
40
|
-
return unstakingInfo;
|
|
41
|
-
} else {
|
|
42
|
-
return undefined;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
class AstarNativeStakingPoolHandler extends _basePara.default {
|
|
46
|
-
availableMethod = {
|
|
47
|
-
join: true,
|
|
48
|
-
defaultUnstake: true,
|
|
49
|
-
fastUnstake: false,
|
|
50
|
-
cancelUnstake: false,
|
|
51
|
-
withdraw: true,
|
|
52
|
-
claimReward: true
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
/* Subscribe pool info */
|
|
56
|
-
|
|
57
|
-
async subscribePoolInfo(callback) {
|
|
58
|
-
let cancel = false;
|
|
59
|
-
const nativeToken = this.nativeToken;
|
|
60
|
-
const defaultCallback = async () => {
|
|
61
|
-
const data = {
|
|
62
|
-
...this.baseInfo,
|
|
63
|
-
type: this.type,
|
|
64
|
-
metadata: {
|
|
65
|
-
...this.metadataInfo,
|
|
66
|
-
description: this.getDescription()
|
|
67
|
-
}
|
|
68
|
-
};
|
|
69
|
-
const poolInfo = await this.getPoolInfo();
|
|
70
|
-
!poolInfo && callback(data);
|
|
71
|
-
};
|
|
72
|
-
if (!this.isActive) {
|
|
73
|
-
await defaultCallback();
|
|
74
|
-
return () => {
|
|
75
|
-
cancel = true;
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
await defaultCallback();
|
|
79
|
-
const apyPromise = new Promise(resolve => {
|
|
80
|
-
(0, _crossFetch.default)(`https://api.astar.network/api/v1/${this.chain}/dapps-staking/apy`, {
|
|
81
|
-
method: 'GET'
|
|
82
|
-
}).then(resp => {
|
|
83
|
-
resolve(resp.json());
|
|
84
|
-
}).catch(e => {
|
|
85
|
-
console.error(e);
|
|
86
|
-
resolve(null);
|
|
87
|
-
});
|
|
88
|
-
});
|
|
89
|
-
const timeout = new Promise(resolve => {
|
|
90
|
-
const id = setTimeout(() => {
|
|
91
|
-
clearTimeout(id);
|
|
92
|
-
resolve(null);
|
|
93
|
-
}, 8000);
|
|
94
|
-
});
|
|
95
|
-
const apyRacePromise = Promise.race([timeout, apyPromise]); // need race because API often timeout
|
|
96
|
-
|
|
97
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
98
|
-
let apyInfo;
|
|
99
|
-
try {
|
|
100
|
-
apyInfo = await apyRacePromise;
|
|
101
|
-
} catch (e) {
|
|
102
|
-
apyInfo = null;
|
|
103
|
-
}
|
|
104
|
-
const unsub = await substrateApi.api.query.dappsStaking.currentEra(_currentEra => {
|
|
105
|
-
if (cancel) {
|
|
106
|
-
unsub();
|
|
107
|
-
return;
|
|
108
|
-
}
|
|
109
|
-
const era = _currentEra.toString();
|
|
110
|
-
const minDelegatorStake = substrateApi.api.consts.dappsStaking.minimumStakingAmount.toString();
|
|
111
|
-
const unstakingDelay = substrateApi.api.consts.dappsStaking.unbondingPeriod.toString();
|
|
112
|
-
const eraTime = _constants._STAKING_ERA_LENGTH_MAP[this.chain] || _constants._STAKING_ERA_LENGTH_MAP.default; // in hours
|
|
113
|
-
const unstakingPeriod = parseInt(unstakingDelay) * eraTime;
|
|
114
|
-
const minToHuman = (0, _utils2.formatNumber)(minDelegatorStake, nativeToken.decimals || 0, _utils2.balanceFormatter);
|
|
115
|
-
const data = {
|
|
116
|
-
...this.baseInfo,
|
|
117
|
-
type: this.type,
|
|
118
|
-
metadata: {
|
|
119
|
-
...this.metadataInfo,
|
|
120
|
-
description: this.getDescription(minToHuman)
|
|
121
|
-
},
|
|
122
|
-
statistic: {
|
|
123
|
-
assetEarning: [{
|
|
124
|
-
slug: this.nativeToken.slug,
|
|
125
|
-
apy: apyInfo !== null ? apyInfo : undefined
|
|
126
|
-
}],
|
|
127
|
-
maxCandidatePerFarmer: 100,
|
|
128
|
-
// temporary fix for Astar, there's no limit for now
|
|
129
|
-
maxWithdrawalRequestPerFarmer: 1,
|
|
130
|
-
// by default
|
|
131
|
-
earningThreshold: {
|
|
132
|
-
join: minDelegatorStake,
|
|
133
|
-
defaultUnstake: '0',
|
|
134
|
-
fastUnstake: '0'
|
|
135
|
-
},
|
|
136
|
-
farmerCount: 0,
|
|
137
|
-
// TODO recheck
|
|
138
|
-
era: parseInt(era),
|
|
139
|
-
eraTime,
|
|
140
|
-
tvl: undefined,
|
|
141
|
-
// TODO recheck
|
|
142
|
-
totalApy: apyInfo !== null ? apyInfo : undefined,
|
|
143
|
-
// TODO recheck
|
|
144
|
-
unstakingPeriod
|
|
145
|
-
}
|
|
146
|
-
};
|
|
147
|
-
callback(data);
|
|
148
|
-
});
|
|
149
|
-
return () => {
|
|
150
|
-
cancel = true;
|
|
151
|
-
unsub();
|
|
152
|
-
};
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
/* Subscribe pool info */
|
|
156
|
-
|
|
157
|
-
/* Subscribe pool position */
|
|
158
|
-
|
|
159
|
-
async parseNominatorMetadata(chainInfo, address, substrateApi, ledger) {
|
|
160
|
-
const nominationList = [];
|
|
161
|
-
const unstakingList = [];
|
|
162
|
-
const allDappsReq = new Promise(resolve => {
|
|
163
|
-
(0, _crossFetch.default)(`https://api.astar.network/api/v1/${chainInfo.slug}/dapps-staking/dapps`, {
|
|
164
|
-
method: 'GET'
|
|
165
|
-
}).then(resp => {
|
|
166
|
-
resolve(resp.json());
|
|
167
|
-
}).catch(console.error);
|
|
168
|
-
});
|
|
169
|
-
const [_allDapps, _era, _stakerInfo] = await Promise.all([allDappsReq, substrateApi.api.query.dappsStaking.currentEra(), substrateApi.api.query.dappsStaking.generalStakerInfo.entries(address)]);
|
|
170
|
-
const currentEra = _era.toString();
|
|
171
|
-
const minDelegatorStake = substrateApi.api.consts.dappsStaking.minimumStakingAmount.toString();
|
|
172
|
-
const allDapps = _allDapps;
|
|
173
|
-
let bnTotalActiveStake = _util.BN_ZERO;
|
|
174
|
-
if (_stakerInfo.length > 0) {
|
|
175
|
-
const dAppInfoMap = {};
|
|
176
|
-
allDapps.forEach(dappInfo => {
|
|
177
|
-
dAppInfoMap[convertAddress(dappInfo.address)] = dappInfo;
|
|
178
|
-
});
|
|
179
|
-
for (const item of _stakerInfo) {
|
|
180
|
-
const data = item[0].toHuman();
|
|
181
|
-
const stakedDapp = data[1];
|
|
182
|
-
const stakeData = item[1].toPrimitive();
|
|
183
|
-
const stakeList = stakeData.stakes;
|
|
184
|
-
const _dappAddress = stakedDapp.Evm ? stakedDapp.Evm.toLowerCase() : stakedDapp.Wasm;
|
|
185
|
-
const dappAddress = convertAddress(_dappAddress);
|
|
186
|
-
const currentStake = stakeList.slice(-1)[0].staked.toString() || '0';
|
|
187
|
-
const bnCurrentStake = new _util.BN(currentStake);
|
|
188
|
-
if (bnCurrentStake.gt(_util.BN_ZERO)) {
|
|
189
|
-
const dappEarningStatus = bnCurrentStake.gt(_util.BN_ZERO) && bnCurrentStake.gte(new _util.BN(minDelegatorStake)) ? _types.EarningStatus.EARNING_REWARD : _types.EarningStatus.NOT_EARNING;
|
|
190
|
-
bnTotalActiveStake = bnTotalActiveStake.add(bnCurrentStake);
|
|
191
|
-
const dappInfo = dAppInfoMap[dappAddress];
|
|
192
|
-
nominationList.push({
|
|
193
|
-
status: dappEarningStatus,
|
|
194
|
-
chain: chainInfo.slug,
|
|
195
|
-
validatorAddress: dappAddress,
|
|
196
|
-
activeStake: currentStake,
|
|
197
|
-
validatorMinStake: '0',
|
|
198
|
-
validatorIdentity: dappInfo === null || dappInfo === void 0 ? void 0 : dappInfo.name,
|
|
199
|
-
hasUnstaking: false // cannot get unstaking info by dapp
|
|
200
|
-
});
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
const unlockingChunks = ledger.unbondingInfo.unlockingChunks;
|
|
206
|
-
if (unlockingChunks.length > 0) {
|
|
207
|
-
for (const unlockingChunk of unlockingChunks) {
|
|
208
|
-
const isClaimable = unlockingChunk.unlockEra - parseInt(currentEra) < 0;
|
|
209
|
-
const remainingEra = unlockingChunk.unlockEra - parseInt(currentEra);
|
|
210
|
-
const waitingTime = remainingEra * _constants._STAKING_ERA_LENGTH_MAP[chainInfo.slug];
|
|
211
|
-
unstakingList.push({
|
|
212
|
-
chain: chainInfo.slug,
|
|
213
|
-
status: isClaimable ? _types.UnstakingStatus.CLAIMABLE : _types.UnstakingStatus.UNLOCKING,
|
|
214
|
-
claimable: unlockingChunk.amount.toString(),
|
|
215
|
-
waitingTime
|
|
216
|
-
});
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
if (nominationList.length === 0 && unstakingList.length === 0) {
|
|
220
|
-
return {
|
|
221
|
-
balanceToken: this.nativeToken.slug,
|
|
222
|
-
totalStake: '0',
|
|
223
|
-
unstakeBalance: '0',
|
|
224
|
-
status: _types.EarningStatus.NOT_STAKING,
|
|
225
|
-
isBondedBefore: false,
|
|
226
|
-
activeStake: '0',
|
|
227
|
-
nominations: [],
|
|
228
|
-
unstakings: []
|
|
229
|
-
};
|
|
230
|
-
}
|
|
231
|
-
const stakingStatus = (0, _utils.getEarningStatusByNominations)(bnTotalActiveStake, nominationList);
|
|
232
|
-
const activeStake = bnTotalActiveStake.toString();
|
|
233
|
-
const unstakeBalance = unstakingList.reduce((old, currentValue) => {
|
|
234
|
-
return old.add(new _util.BN(currentValue.claimable));
|
|
235
|
-
}, _util.BN_ZERO);
|
|
236
|
-
const totalStake = unstakeBalance.add(bnTotalActiveStake);
|
|
237
|
-
return {
|
|
238
|
-
status: stakingStatus,
|
|
239
|
-
balanceToken: this.nativeToken.slug,
|
|
240
|
-
totalStake: totalStake.toString(),
|
|
241
|
-
activeStake: activeStake,
|
|
242
|
-
unstakeBalance: unstakeBalance.toString(),
|
|
243
|
-
isBondedBefore: totalStake.gt(_util.BN_ZERO),
|
|
244
|
-
nominations: nominationList,
|
|
245
|
-
unstakings: unstakingList
|
|
246
|
-
};
|
|
247
|
-
}
|
|
248
|
-
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
249
|
-
let cancel = false;
|
|
250
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
251
|
-
const defaultInfo = this.baseInfo;
|
|
252
|
-
const chainInfo = this.chainInfo;
|
|
253
|
-
const unsub = await substrateApi.api.query.dappsStaking.ledger.multi(useAddresses, async ledgers => {
|
|
254
|
-
if (cancel) {
|
|
255
|
-
unsub();
|
|
256
|
-
return;
|
|
257
|
-
}
|
|
258
|
-
if (ledgers) {
|
|
259
|
-
await Promise.all(ledgers.map(async (_ledger, i) => {
|
|
260
|
-
const owner = (0, _utils2.reformatAddress)(useAddresses[i], 42);
|
|
261
|
-
const ledger = _ledger.toPrimitive();
|
|
262
|
-
if (ledger && ledger.locked > 0) {
|
|
263
|
-
const nominatorMetadata = await this.parseNominatorMetadata(chainInfo, owner, substrateApi, ledger);
|
|
264
|
-
resultCallback({
|
|
265
|
-
...defaultInfo,
|
|
266
|
-
...nominatorMetadata,
|
|
267
|
-
address: owner,
|
|
268
|
-
type: this.type
|
|
269
|
-
});
|
|
270
|
-
} else {
|
|
271
|
-
resultCallback({
|
|
272
|
-
...defaultInfo,
|
|
273
|
-
type: this.type,
|
|
274
|
-
address: owner,
|
|
275
|
-
balanceToken: this.nativeToken.slug,
|
|
276
|
-
totalStake: '0',
|
|
277
|
-
activeStake: '0',
|
|
278
|
-
unstakeBalance: '0',
|
|
279
|
-
isBondedBefore: false,
|
|
280
|
-
status: _types.EarningStatus.NOT_STAKING,
|
|
281
|
-
nominations: [],
|
|
282
|
-
unstakings: []
|
|
283
|
-
});
|
|
284
|
-
}
|
|
285
|
-
}));
|
|
286
|
-
}
|
|
287
|
-
});
|
|
288
|
-
return () => {
|
|
289
|
-
cancel = true;
|
|
290
|
-
unsub();
|
|
291
|
-
};
|
|
292
|
-
}
|
|
293
|
-
|
|
294
|
-
/* Subscribe pool position */
|
|
295
|
-
|
|
296
|
-
/* Get pool targets */
|
|
297
|
-
|
|
298
|
-
async getPoolTargets() {
|
|
299
|
-
const chainApi = await this.substrateApi.isReady;
|
|
300
|
-
const rawMaxStakerPerContract = chainApi.api.consts.dappsStaking.maxNumberOfStakersPerContract.toHuman();
|
|
301
|
-
const allDappsInfo = [];
|
|
302
|
-
const maxStakerPerContract = (0, _utils2.parseRawNumber)(rawMaxStakerPerContract);
|
|
303
|
-
const allDappsReq = new Promise(resolve => {
|
|
304
|
-
(0, _crossFetch.default)(`https://api.astar.network/api/v1/${this.chain}/dapps-staking/dapps`, {
|
|
305
|
-
method: 'GET'
|
|
306
|
-
}).then(resp => {
|
|
307
|
-
resolve(resp.json());
|
|
308
|
-
}).catch(console.error);
|
|
309
|
-
});
|
|
310
|
-
const [_era, _allDapps] = await Promise.all([chainApi.api.query.dappsStaking.currentEra(), allDappsReq]);
|
|
311
|
-
const era = (0, _utils2.parseRawNumber)(_era.toHuman());
|
|
312
|
-
const allDapps = _allDapps;
|
|
313
|
-
await Promise.all(allDapps.map(async dapp => {
|
|
314
|
-
const dappName = dapp.name;
|
|
315
|
-
const dappAddress = dapp.address;
|
|
316
|
-
const dappIcon = (0, _utils2.isUrl)(dapp.iconUrl) ? dapp.iconUrl : undefined;
|
|
317
|
-
const contractParam = (0, _utilCrypto.isEthereumAddress)(dappAddress) ? {
|
|
318
|
-
Evm: dappAddress
|
|
319
|
-
} : {
|
|
320
|
-
Wasm: dappAddress
|
|
321
|
-
};
|
|
322
|
-
const _contractInfo = await chainApi.api.query.dappsStaking.contractEraStake(contractParam, era);
|
|
323
|
-
const contractInfo = _contractInfo.toPrimitive();
|
|
324
|
-
let totalStake = '0';
|
|
325
|
-
let stakerCount = 0;
|
|
326
|
-
if (contractInfo !== null) {
|
|
327
|
-
var _contractInfo$total;
|
|
328
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment
|
|
329
|
-
totalStake = contractInfo === null || contractInfo === void 0 ? void 0 : (_contractInfo$total = contractInfo.total) === null || _contractInfo$total === void 0 ? void 0 : _contractInfo$total.toString();
|
|
330
|
-
stakerCount = contractInfo.numberOfStakers;
|
|
331
|
-
}
|
|
332
|
-
allDappsInfo.push({
|
|
333
|
-
commission: 0,
|
|
334
|
-
expectedReturn: 0,
|
|
335
|
-
address: convertAddress(dappAddress),
|
|
336
|
-
totalStake: totalStake,
|
|
337
|
-
ownStake: '0',
|
|
338
|
-
otherStake: totalStake.toString(),
|
|
339
|
-
nominatorCount: stakerCount,
|
|
340
|
-
blocked: false,
|
|
341
|
-
isVerified: false,
|
|
342
|
-
minBond: '0',
|
|
343
|
-
icon: dappIcon,
|
|
344
|
-
identity: dappName,
|
|
345
|
-
chain: this.chain,
|
|
346
|
-
isCrowded: stakerCount >= maxStakerPerContract
|
|
347
|
-
});
|
|
348
|
-
}));
|
|
349
|
-
return allDappsInfo;
|
|
350
|
-
}
|
|
351
|
-
|
|
352
|
-
/* Get pool targets */
|
|
353
|
-
|
|
354
|
-
/* Join pool action */
|
|
355
|
-
|
|
356
|
-
get defaultSubmitStep() {
|
|
357
|
-
return [{
|
|
358
|
-
name: 'Nominate dApps',
|
|
359
|
-
type: _types.YieldStepType.NOMINATE
|
|
360
|
-
}, {
|
|
361
|
-
slug: this.nativeToken.slug,
|
|
362
|
-
amount: '0'
|
|
363
|
-
}];
|
|
364
|
-
}
|
|
365
|
-
async createJoinExtrinsic(data, positionInfo) {
|
|
366
|
-
let bondDest = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'Staked';
|
|
367
|
-
const {
|
|
368
|
-
amount,
|
|
369
|
-
selectedValidators: targetValidators
|
|
370
|
-
} = data;
|
|
371
|
-
const chainApi = await this.substrateApi.isReady;
|
|
372
|
-
const binaryAmount = new _util.BN(amount);
|
|
373
|
-
const dappInfo = targetValidators[0];
|
|
374
|
-
const dappParam = (0, _utilCrypto.isEthereumAddress)(dappInfo.address) ? {
|
|
375
|
-
Evm: dappInfo.address
|
|
376
|
-
} : {
|
|
377
|
-
Wasm: dappInfo.address
|
|
378
|
-
};
|
|
379
|
-
const extrinsic = chainApi.api.tx.dappsStaking.bondAndStake(dappParam, binaryAmount);
|
|
380
|
-
const tokenSlug = this.nativeToken.slug;
|
|
381
|
-
// const feeInfo = await extrinsic.paymentInfo(address);
|
|
382
|
-
// const fee = feeInfo.toPrimitive() as unknown as RuntimeDispatchInfo;
|
|
383
|
-
|
|
384
|
-
// Not use the fee to validate and to display on UI
|
|
385
|
-
return [extrinsic, {
|
|
386
|
-
slug: tokenSlug,
|
|
387
|
-
amount: '0'
|
|
388
|
-
}];
|
|
389
|
-
}
|
|
390
|
-
|
|
391
|
-
/* Join pool action */
|
|
392
|
-
|
|
393
|
-
/* Leave pool action */
|
|
394
|
-
|
|
395
|
-
async handleYieldUnstake(amount, address, selectedTarget) {
|
|
396
|
-
const chainApi = await this.substrateApi.isReady;
|
|
397
|
-
const binaryAmount = new _util.BN(amount);
|
|
398
|
-
if (!selectedTarget) {
|
|
399
|
-
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS));
|
|
400
|
-
}
|
|
401
|
-
const dappParam = (0, _utilCrypto.isEthereumAddress)(selectedTarget) ? {
|
|
402
|
-
Evm: selectedTarget
|
|
403
|
-
} : {
|
|
404
|
-
Wasm: selectedTarget
|
|
405
|
-
};
|
|
406
|
-
const extrinsic = chainApi.api.tx.dappsStaking.unbondAndUnstake(dappParam, binaryAmount);
|
|
407
|
-
return [_KoniTypes.ExtrinsicType.STAKING_LEAVE_POOL, extrinsic];
|
|
408
|
-
}
|
|
409
|
-
|
|
410
|
-
/* Leave pool action */
|
|
411
|
-
|
|
412
|
-
/* Other action */
|
|
413
|
-
|
|
414
|
-
async handleYieldCancelUnstake(params) {
|
|
415
|
-
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.UNSUPPORTED));
|
|
416
|
-
}
|
|
417
|
-
async handleYieldWithdraw(address, unstakingInfo) {
|
|
418
|
-
const chainApi = await this.substrateApi.isReady;
|
|
419
|
-
return chainApi.api.tx.dappsStaking.withdrawUnbonded();
|
|
420
|
-
}
|
|
421
|
-
async handleYieldClaimReward(address, bondReward) {
|
|
422
|
-
const apiPromise = await this.substrateApi.isReady;
|
|
423
|
-
const [_stakedDapps, _currentEra] = await Promise.all([apiPromise.api.query.dappsStaking.generalStakerInfo.entries(address), apiPromise.api.query.dappsStaking.currentEra()]);
|
|
424
|
-
const currentEra = (0, _utils2.parseRawNumber)(_currentEra.toHuman());
|
|
425
|
-
const transactions = [];
|
|
426
|
-
for (const item of _stakedDapps) {
|
|
427
|
-
const data = item[0].toHuman();
|
|
428
|
-
const stakedDapp = data[1];
|
|
429
|
-
const stakeData = item[1].toHuman();
|
|
430
|
-
const stakes = stakeData.stakes;
|
|
431
|
-
const dappAddress = (0, _utilCrypto.isEthereumAddress)(stakedDapp.Evm) ? stakedDapp.Evm.toLowerCase() : stakedDapp.Evm;
|
|
432
|
-
let numberOfUnclaimedEra = 0;
|
|
433
|
-
const maxTx = 50;
|
|
434
|
-
for (let i = 0; i < stakes.length; i++) {
|
|
435
|
-
var _stakes;
|
|
436
|
-
const {
|
|
437
|
-
era,
|
|
438
|
-
staked
|
|
439
|
-
} = stakes[i];
|
|
440
|
-
const bnStaked = new _util.BN(staked.replaceAll(',', ''));
|
|
441
|
-
const parsedEra = (0, _utils2.parseRawNumber)(era);
|
|
442
|
-
if (bnStaked.eq(new _util.BN(0))) {
|
|
443
|
-
continue;
|
|
444
|
-
}
|
|
445
|
-
const nextEraData = (_stakes = stakes[i + 1]) !== null && _stakes !== void 0 ? _stakes : null;
|
|
446
|
-
const nextEra = nextEraData && (0, _utils2.parseRawNumber)(nextEraData.era);
|
|
447
|
-
const isLastEra = i === stakes.length - 1;
|
|
448
|
-
const eraToClaim = isLastEra ? currentEra - parsedEra : nextEra - parsedEra;
|
|
449
|
-
numberOfUnclaimedEra += eraToClaim;
|
|
450
|
-
}
|
|
451
|
-
const dappParam = (0, _utilCrypto.isEthereumAddress)(dappAddress) ? {
|
|
452
|
-
Evm: dappAddress
|
|
453
|
-
} : {
|
|
454
|
-
Wasm: dappAddress
|
|
455
|
-
};
|
|
456
|
-
for (let i = 0; i < Math.min(numberOfUnclaimedEra, maxTx); i++) {
|
|
457
|
-
const tx = apiPromise.api.tx.dappsStaking.claimStaker(dappParam);
|
|
458
|
-
transactions.push(tx);
|
|
459
|
-
}
|
|
460
|
-
}
|
|
461
|
-
return apiPromise.api.tx.utility.batch(transactions);
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
/* Other actions */
|
|
465
|
-
}
|
|
466
|
-
exports.default = AstarNativeStakingPoolHandler;
|
|
@@ -1,146 +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 _base = _interopRequireDefault(require("@subwallet/extension-base/services/earning-service/handlers/native-staking/base"));
|
|
12
|
-
var _types = require("@subwallet/extension-base/types");
|
|
13
|
-
var _utils2 = require("@subwallet/extension-base/utils");
|
|
14
|
-
var _i18next = require("i18next");
|
|
15
|
-
var _util = require("@polkadot/util");
|
|
16
|
-
// Copyright 2019-2022 @subwallet/extension-base
|
|
17
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
18
|
-
|
|
19
|
-
class BaseParaNativeStakingPoolHandler extends _base.default {
|
|
20
|
-
/* Join pool action */
|
|
21
|
-
|
|
22
|
-
get defaultSubmitStep() {
|
|
23
|
-
return [{
|
|
24
|
-
name: 'Nominate collators',
|
|
25
|
-
type: _types.YieldStepType.NOMINATE
|
|
26
|
-
}, {
|
|
27
|
-
slug: this.nativeToken.slug,
|
|
28
|
-
amount: '0'
|
|
29
|
-
}];
|
|
30
|
-
}
|
|
31
|
-
async validateYieldJoin(data, path) {
|
|
32
|
-
const {
|
|
33
|
-
address,
|
|
34
|
-
amount,
|
|
35
|
-
selectedValidators
|
|
36
|
-
} = data;
|
|
37
|
-
const poolInfo = await this.getPoolInfo();
|
|
38
|
-
const poolPosition = await this.getPoolPosition(address);
|
|
39
|
-
const chainInfo = this.chainInfo;
|
|
40
|
-
const bnAmount = new _util.BN(amount);
|
|
41
|
-
if (bnAmount.lte(_util.BN_ZERO)) {
|
|
42
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS, 'Amount must be greater than 0')];
|
|
43
|
-
}
|
|
44
|
-
if (!poolInfo || !poolInfo.statistic) {
|
|
45
|
-
return Promise.resolve([new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)]);
|
|
46
|
-
}
|
|
47
|
-
const errors = [];
|
|
48
|
-
const selectedCollator = selectedValidators[0];
|
|
49
|
-
let bnTotalStake = new _util.BN(amount);
|
|
50
|
-
const bnChainMinStake = new _util.BN(poolInfo.statistic.earningThreshold.join || '0');
|
|
51
|
-
const bnCollatorMinStake = new _util.BN(selectedCollator.minBond || '0');
|
|
52
|
-
const bnMinStake = bnCollatorMinStake > bnChainMinStake ? bnCollatorMinStake : bnChainMinStake;
|
|
53
|
-
const minStakeErrorMessage = (0, _utils.getMinStakeErrorMessage)(chainInfo, bnMinStake);
|
|
54
|
-
const maxValidator = poolInfo.statistic.maxCandidatePerFarmer;
|
|
55
|
-
const maxValidatorErrorMessage = (0, _utils.getMaxValidatorErrorMessage)(chainInfo, maxValidator);
|
|
56
|
-
const existUnstakeErrorMessage = (0, _utils.getExistUnstakeErrorMessage)(chainInfo.slug, _KoniTypes.StakingType.NOMINATED, true);
|
|
57
|
-
if (!poolPosition || poolPosition.status === _types.EarningStatus.NOT_STAKING) {
|
|
58
|
-
if (!bnTotalStake.gte(bnMinStake)) {
|
|
59
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.NOT_ENOUGH_MIN_STAKE, minStakeErrorMessage));
|
|
60
|
-
}
|
|
61
|
-
return errors;
|
|
62
|
-
}
|
|
63
|
-
const {
|
|
64
|
-
bondedValidators
|
|
65
|
-
} = (0, _utils.getBondedValidators)(poolPosition.nominations);
|
|
66
|
-
const parsedSelectedCollatorAddress = (0, _utils2.reformatAddress)(selectedCollator.address, 0);
|
|
67
|
-
if (!bondedValidators.includes(parsedSelectedCollatorAddress)) {
|
|
68
|
-
// new delegation
|
|
69
|
-
if (!bnTotalStake.gte(bnMinStake)) {
|
|
70
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.NOT_ENOUGH_MIN_STAKE, minStakeErrorMessage));
|
|
71
|
-
}
|
|
72
|
-
const delegationCount = poolPosition.nominations.length + 1;
|
|
73
|
-
if (delegationCount > maxValidator) {
|
|
74
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.EXCEED_MAX_NOMINATIONS, maxValidatorErrorMessage));
|
|
75
|
-
}
|
|
76
|
-
} else {
|
|
77
|
-
let currentDelegationAmount = '0';
|
|
78
|
-
let hasUnstaking = false;
|
|
79
|
-
for (const delegation of poolPosition.nominations) {
|
|
80
|
-
if ((0, _utils2.reformatAddress)(delegation.validatorAddress, 0) === parsedSelectedCollatorAddress) {
|
|
81
|
-
currentDelegationAmount = delegation.activeStake;
|
|
82
|
-
hasUnstaking = !!delegation.hasUnstaking && delegation.hasUnstaking;
|
|
83
|
-
break;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
bnTotalStake = bnTotalStake.add(new _util.BN(currentDelegationAmount));
|
|
87
|
-
if (!bnTotalStake.gte(bnMinStake)) {
|
|
88
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.NOT_ENOUGH_MIN_STAKE, minStakeErrorMessage));
|
|
89
|
-
}
|
|
90
|
-
if (hasUnstaking) {
|
|
91
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.EXIST_UNSTAKING_REQUEST, existUnstakeErrorMessage));
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
return errors;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
/* Join pool action */
|
|
98
|
-
|
|
99
|
-
/* Leave pool action */
|
|
100
|
-
|
|
101
|
-
/**
|
|
102
|
-
* @todo Recheck
|
|
103
|
-
* */
|
|
104
|
-
async validateYieldLeave(amount, address, fastLeave, selectedTarget) {
|
|
105
|
-
const errors = [];
|
|
106
|
-
const poolInfo = await this.getPoolInfo();
|
|
107
|
-
const poolPosition = await this.getPoolPosition(address);
|
|
108
|
-
if (!poolInfo || !poolInfo.statistic || !poolPosition || fastLeave || !selectedTarget) {
|
|
109
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
110
|
-
}
|
|
111
|
-
if (fastLeave) {
|
|
112
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS)];
|
|
113
|
-
}
|
|
114
|
-
const bnAmount = new _util.BN(amount);
|
|
115
|
-
if (bnAmount.lte(_util.BN_ZERO)) {
|
|
116
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS, (0, _i18next.t)('Amount must be greater than 0')));
|
|
117
|
-
}
|
|
118
|
-
let targetNomination;
|
|
119
|
-
for (const nomination of poolPosition.nominations) {
|
|
120
|
-
if ((0, _utils2.isSameAddress)(nomination.validatorAddress, selectedTarget)) {
|
|
121
|
-
targetNomination = nomination;
|
|
122
|
-
break;
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
if (!targetNomination) {
|
|
126
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR));
|
|
127
|
-
return errors;
|
|
128
|
-
}
|
|
129
|
-
const bnActiveStake = new _util.BN(targetNomination.activeStake);
|
|
130
|
-
const bnRemainingStake = bnActiveStake.sub(new _util.BN(amount));
|
|
131
|
-
const bnChainMinStake = new _util.BN(poolInfo.statistic.earningThreshold.join || '0');
|
|
132
|
-
const bnCollatorMinStake = new _util.BN(targetNomination.validatorMinStake || '0');
|
|
133
|
-
const bnMinStake = _util.BN.max(bnCollatorMinStake, bnChainMinStake);
|
|
134
|
-
const existUnstakeErrorMessage = (0, _utils.getExistUnstakeErrorMessage)(this.chain, _KoniTypes.StakingType.NOMINATED);
|
|
135
|
-
if (targetNomination.hasUnstaking) {
|
|
136
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.EXIST_UNSTAKING_REQUEST, existUnstakeErrorMessage));
|
|
137
|
-
}
|
|
138
|
-
if (!(bnRemainingStake.isZero() || bnRemainingStake.gte(bnMinStake))) {
|
|
139
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.INVALID_ACTIVE_STAKE));
|
|
140
|
-
}
|
|
141
|
-
return errors;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
/* Leave pool action */
|
|
145
|
-
}
|
|
146
|
-
exports.default = BaseParaNativeStakingPoolHandler;
|