@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,81 +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 _types = require("@subwallet/extension-base/types");
|
|
11
|
-
var _utils = require("@subwallet/extension-base/utils");
|
|
12
|
-
var _bignumber = _interopRequireDefault(require("bignumber.js"));
|
|
13
|
-
var _i18next = require("i18next");
|
|
14
|
-
var _special = _interopRequireDefault(require("../special"));
|
|
15
|
-
// Copyright 2019-2022 @subwallet/extension-base
|
|
16
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
17
|
-
|
|
18
|
-
class BaseLendingPoolHandler extends _special.default {
|
|
19
|
-
type = _types.YieldPoolType.LENDING;
|
|
20
|
-
|
|
21
|
-
/* Subscribe pool info */
|
|
22
|
-
|
|
23
|
-
/* Subscribe pool info */
|
|
24
|
-
|
|
25
|
-
/* Leave pool action */
|
|
26
|
-
|
|
27
|
-
async validateYieldLeave(amount, address, fastLeave, selectedTarget) {
|
|
28
|
-
const poolInfo = await this.getPoolInfo();
|
|
29
|
-
const poolPosition = await this.getPoolPosition(address);
|
|
30
|
-
if (!poolInfo || !poolInfo.statistic || !poolPosition) {
|
|
31
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
32
|
-
}
|
|
33
|
-
if (!this.availableMethod.defaultUnstake && !fastLeave) {
|
|
34
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
35
|
-
}
|
|
36
|
-
if (!this.availableMethod.fastUnstake && fastLeave) {
|
|
37
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
38
|
-
}
|
|
39
|
-
const errors = [];
|
|
40
|
-
const bnActiveStake = new _bignumber.default(poolPosition.activeStake).multipliedBy(poolInfo.statistic.assetEarning[0].exchangeRate || 1);
|
|
41
|
-
const bnAmount = new _bignumber.default(amount);
|
|
42
|
-
const bnRemainingStake = bnActiveStake.minus(bnAmount);
|
|
43
|
-
const minStake = new _bignumber.default(poolInfo.statistic.earningThreshold.join || '0');
|
|
44
|
-
const minUnstake = new _bignumber.default((fastLeave ? poolInfo.statistic.earningThreshold.fastUnstake : poolInfo.statistic.earningThreshold.defaultUnstake) || '0');
|
|
45
|
-
const maxUnstakeRequest = poolInfo.statistic.maxWithdrawalRequestPerFarmer;
|
|
46
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(this.derivativeAssets[0]);
|
|
47
|
-
if (bnAmount.lte(_utils.BN_ZERO)) {
|
|
48
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS, (0, _i18next.t)('Amount must be greater than 0'))];
|
|
49
|
-
}
|
|
50
|
-
if (bnAmount.lt(minUnstake)) {
|
|
51
|
-
const minUnstakeStr = (0, _utils.formatNumber)(minUnstake.toString(), derivativeTokenInfo.decimals || 0);
|
|
52
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.NOT_ENOUGH_MIN_UNSTAKE, (0, _i18next.t)('You need to unstake at least {{amount}} {{token}}', {
|
|
53
|
-
replace: {
|
|
54
|
-
amount: minUnstakeStr,
|
|
55
|
-
token: derivativeTokenInfo.symbol
|
|
56
|
-
}
|
|
57
|
-
})));
|
|
58
|
-
}
|
|
59
|
-
if (!fastLeave) {
|
|
60
|
-
if (!(bnRemainingStake.isZero() || bnRemainingStake.gte(minStake))) {
|
|
61
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.INVALID_ACTIVE_STAKE)); // TODO
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
if (poolPosition.unstakings.length > maxUnstakeRequest) {
|
|
65
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.EXCEED_MAX_UNSTAKING, (0, _i18next.t)('You cannot unstake more than {{number}} times', {
|
|
66
|
-
replace: {
|
|
67
|
-
number: maxUnstakeRequest
|
|
68
|
-
}
|
|
69
|
-
})));
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
if (bnRemainingStake.lt(0)) {
|
|
73
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.INVALID_ACTIVE_STAKE)); // TODO
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
return Promise.resolve(errors);
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/* Leave pool action */
|
|
80
|
-
}
|
|
81
|
-
exports.default = BaseLendingPoolHandler;
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
Object.defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
Object.defineProperty(exports, "InterlayLendingPoolHandler", {
|
|
8
|
-
enumerable: true,
|
|
9
|
-
get: function () {
|
|
10
|
-
return _interlay.default;
|
|
11
|
-
}
|
|
12
|
-
});
|
|
13
|
-
var _interlay = _interopRequireDefault(require("./interlay"));
|
|
@@ -1,192 +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/services/chain-service/utils");
|
|
11
|
-
var _types = require("@subwallet/extension-base/types");
|
|
12
|
-
var _util = require("@polkadot/util");
|
|
13
|
-
var _constants = require("../../constants");
|
|
14
|
-
var _base = _interopRequireDefault(require("./base"));
|
|
15
|
-
// Copyright 2019-2022 @subwallet/extension-base
|
|
16
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
17
|
-
|
|
18
|
-
class InterlayLendingPoolHandler extends _base.default {
|
|
19
|
-
altInputAsset = 'polkadot-NATIVE-DOT';
|
|
20
|
-
derivativeAssets = ['interlay-LOCAL-qDOT'];
|
|
21
|
-
inputAsset = 'interlay-LOCAL-DOT';
|
|
22
|
-
rewardAssets = ['interlay-LOCAL-DOT'];
|
|
23
|
-
feeAssets = ['interlay-NATIVE-INTR', 'interlay-LOCAL-DOT'];
|
|
24
|
-
availableMethod = {
|
|
25
|
-
join: true,
|
|
26
|
-
defaultUnstake: false,
|
|
27
|
-
fastUnstake: true,
|
|
28
|
-
cancelUnstake: false,
|
|
29
|
-
withdraw: false,
|
|
30
|
-
claimReward: false
|
|
31
|
-
};
|
|
32
|
-
rateDecimals = 18;
|
|
33
|
-
constructor(state, chain) {
|
|
34
|
-
super(state, chain);
|
|
35
|
-
const chainInfo = this.chainInfo;
|
|
36
|
-
this.slug = `DOT___lending___${chain}`;
|
|
37
|
-
this.name = `${chainInfo.name} Lending`;
|
|
38
|
-
this.shortName = chainInfo.name.replaceAll(' Relay Chain', '');
|
|
39
|
-
}
|
|
40
|
-
getDescription() {
|
|
41
|
-
return 'Earn rewards by lending DOT';
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
/* Subscribe pool info */
|
|
45
|
-
|
|
46
|
-
async getPoolStat() {
|
|
47
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
48
|
-
const inputTokenSlug = this.inputAsset;
|
|
49
|
-
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
50
|
-
const _exchangeRate = await substrateApi.api.query.loans.exchangeRate((0, _utils._getTokenOnChainInfo)(inputTokenInfo));
|
|
51
|
-
const exchangeRate = _exchangeRate.toPrimitive();
|
|
52
|
-
const decimals = 10 ** this.rateDecimals;
|
|
53
|
-
this.updateExchangeRate(exchangeRate);
|
|
54
|
-
return {
|
|
55
|
-
...this.baseInfo,
|
|
56
|
-
type: this.type,
|
|
57
|
-
metadata: {
|
|
58
|
-
...this.metadataInfo,
|
|
59
|
-
description: this.getDescription()
|
|
60
|
-
},
|
|
61
|
-
statistic: {
|
|
62
|
-
assetEarning: [{
|
|
63
|
-
slug: this.rewardAssets[0],
|
|
64
|
-
apr: 1.29,
|
|
65
|
-
exchangeRate: exchangeRate / decimals
|
|
66
|
-
}],
|
|
67
|
-
maxCandidatePerFarmer: 1,
|
|
68
|
-
maxWithdrawalRequestPerFarmer: 1,
|
|
69
|
-
earningThreshold: {
|
|
70
|
-
join: '10000000000',
|
|
71
|
-
defaultUnstake: '0',
|
|
72
|
-
fastUnstake: '0'
|
|
73
|
-
},
|
|
74
|
-
totalApr: 1.29,
|
|
75
|
-
tvl: '291890000000000'
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
/* Subscribe pool info */
|
|
81
|
-
|
|
82
|
-
/* Subscribe pool position */
|
|
83
|
-
|
|
84
|
-
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
85
|
-
let cancel = false;
|
|
86
|
-
const substrateApi = this.substrateApi;
|
|
87
|
-
await substrateApi.isReady;
|
|
88
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
89
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
90
|
-
const unsub = await substrateApi.api.query.tokens.accounts.multi(useAddresses.map(address => [address, (0, _utils._getTokenOnChainInfo)(derivativeTokenInfo)]), async _balances => {
|
|
91
|
-
if (cancel) {
|
|
92
|
-
unsub();
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
const exchangeRate = await this.getExchangeRate();
|
|
96
|
-
const decimals = _util.BN_TEN.pow(new _util.BN(this.rateDecimals));
|
|
97
|
-
const balances = _balances;
|
|
98
|
-
for (let i = 0; i < balances.length; i++) {
|
|
99
|
-
const balanceItem = balances[i];
|
|
100
|
-
const address = useAddresses[i];
|
|
101
|
-
const bnActiveBalance = balanceItem.free || _util.BN_ZERO;
|
|
102
|
-
const bnTotalBalance = bnActiveBalance.mul(new _util.BN(exchangeRate)).div(decimals);
|
|
103
|
-
const result = {
|
|
104
|
-
...this.baseInfo,
|
|
105
|
-
type: this.type,
|
|
106
|
-
address,
|
|
107
|
-
balanceToken: this.inputAsset,
|
|
108
|
-
totalStake: bnTotalBalance.toString(),
|
|
109
|
-
activeStake: bnActiveBalance.toString(),
|
|
110
|
-
unstakeBalance: '0',
|
|
111
|
-
status: bnActiveBalance.gt(_util.BN_ZERO) ? _types.EarningStatus.EARNING_REWARD : _types.EarningStatus.NOT_EARNING,
|
|
112
|
-
derivativeToken: derivativeTokenSlug,
|
|
113
|
-
isBondedBefore: bnTotalBalance.gt(_util.BN_ZERO),
|
|
114
|
-
nominations: [],
|
|
115
|
-
unstakings: []
|
|
116
|
-
};
|
|
117
|
-
resultCallback(result);
|
|
118
|
-
}
|
|
119
|
-
});
|
|
120
|
-
return () => {
|
|
121
|
-
cancel = true;
|
|
122
|
-
unsub();
|
|
123
|
-
};
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
/* Subscribe pool position */
|
|
127
|
-
|
|
128
|
-
/* Join pool action */
|
|
129
|
-
|
|
130
|
-
get submitJoinStepInfo() {
|
|
131
|
-
return {
|
|
132
|
-
name: 'Mint qDOT',
|
|
133
|
-
type: _types.YieldStepType.MINT_QDOT
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
async getSubmitStepFee(params) {
|
|
137
|
-
const poolOriginSubstrateApi = await this.substrateApi.isReady;
|
|
138
|
-
const inputTokenSlug = this.inputAsset;
|
|
139
|
-
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
140
|
-
const defaultFeeTokenSlug = this.feeAssets[0];
|
|
141
|
-
if (new _util.BN(params.amount).gt(_util.BN_ZERO)) {
|
|
142
|
-
const _mintFeeInfo = await poolOriginSubstrateApi.api.tx.loans.mint((0, _utils._getTokenOnChainInfo)(inputTokenInfo), params.amount).paymentInfo(_constants.fakeAddress);
|
|
143
|
-
const mintFeeInfo = _mintFeeInfo.toPrimitive();
|
|
144
|
-
return {
|
|
145
|
-
amount: mintFeeInfo.partialFee.toString(),
|
|
146
|
-
slug: defaultFeeTokenSlug
|
|
147
|
-
};
|
|
148
|
-
} else {
|
|
149
|
-
return {
|
|
150
|
-
amount: '0',
|
|
151
|
-
slug: defaultFeeTokenSlug
|
|
152
|
-
};
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
async handleSubmitStep(data, path) {
|
|
156
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
157
|
-
const inputTokenSlug = this.inputAsset;
|
|
158
|
-
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
159
|
-
const extrinsic = substrateApi.api.tx.loans.mint((0, _utils._getTokenOnChainInfo)(inputTokenInfo), data.amount);
|
|
160
|
-
return {
|
|
161
|
-
txChain: this.chain,
|
|
162
|
-
extrinsicType: _KoniTypes.ExtrinsicType.MINT_QDOT,
|
|
163
|
-
extrinsic,
|
|
164
|
-
txData: data,
|
|
165
|
-
transferNativeAmount: '0',
|
|
166
|
-
chainType: _KoniTypes.ChainType.SUBSTRATE
|
|
167
|
-
};
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
/* Join pool action */
|
|
171
|
-
|
|
172
|
-
/* Leave pool action */
|
|
173
|
-
|
|
174
|
-
async handleYieldRedeem(amount, address, selectedTarget) {
|
|
175
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
176
|
-
// @ts-ignore
|
|
177
|
-
const inputTokenSlug = this.inputAsset;
|
|
178
|
-
const inputTokenInfo = this.state.getAssetBySlug(inputTokenSlug);
|
|
179
|
-
const yieldPositionInfo = await this.getPoolPosition(address);
|
|
180
|
-
if (!yieldPositionInfo) {
|
|
181
|
-
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS));
|
|
182
|
-
}
|
|
183
|
-
const bnAmount = new _util.BN(amount);
|
|
184
|
-
const bnActiveBalance = new _util.BN(yieldPositionInfo.activeStake);
|
|
185
|
-
const redeemAll = bnAmount.eq(bnActiveBalance);
|
|
186
|
-
const extrinsic = !redeemAll ? substrateApi.api.tx.loans.redeem((0, _utils._getTokenOnChainInfo)(inputTokenInfo), amount) : substrateApi.api.tx.loans.redeemAll((0, _utils._getTokenOnChainInfo)(inputTokenInfo));
|
|
187
|
-
return [_KoniTypes.ExtrinsicType.REDEEM_QDOT, extrinsic];
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
/* Leave pool action */
|
|
191
|
-
}
|
|
192
|
-
exports.default = InterlayLendingPoolHandler;
|
|
@@ -1,240 +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 _KoniTypes = require("@subwallet/extension-base/background/KoniTypes");
|
|
9
|
-
var _utils = require("@subwallet/extension-base/services/chain-service/utils");
|
|
10
|
-
var _constants = require("@subwallet/extension-base/services/earning-service/constants");
|
|
11
|
-
var _types = require("@subwallet/extension-base/types");
|
|
12
|
-
var _crossFetch = _interopRequireDefault(require("cross-fetch"));
|
|
13
|
-
var _util = require("@polkadot/util");
|
|
14
|
-
var _base = _interopRequireDefault(require("./base"));
|
|
15
|
-
// Copyright 2019-2022 @subwallet/extension-base
|
|
16
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
17
|
-
|
|
18
|
-
const GRAPHQL_API = 'https://api.polkawallet.io/acala-liquid-staking-subql';
|
|
19
|
-
const EXCHANGE_RATE_REQUEST = 'query { dailySummaries(first:30, orderBy:TIMESTAMP_DESC) {nodes { exchangeRate timestamp }}}';
|
|
20
|
-
class AcalaLiquidStakingPoolHandler extends _base.default {
|
|
21
|
-
altInputAsset = 'polkadot-NATIVE-DOT';
|
|
22
|
-
derivativeAssets = ['acala-LOCAL-LDOT'];
|
|
23
|
-
inputAsset = 'acala-LOCAL-DOT';
|
|
24
|
-
rewardAssets = ['acala-LOCAL-DOT'];
|
|
25
|
-
feeAssets = ['acala-NATIVE-ACA', 'acala-LOCAL-DOT'];
|
|
26
|
-
minAmountPercent = 0.98;
|
|
27
|
-
rateDecimals = 10;
|
|
28
|
-
availableMethod = {
|
|
29
|
-
join: true,
|
|
30
|
-
defaultUnstake: true,
|
|
31
|
-
fastUnstake: true,
|
|
32
|
-
cancelUnstake: false,
|
|
33
|
-
withdraw: true,
|
|
34
|
-
claimReward: false
|
|
35
|
-
};
|
|
36
|
-
constructor(state, chain) {
|
|
37
|
-
super(state, chain);
|
|
38
|
-
const chainInfo = this.chainInfo;
|
|
39
|
-
this.slug = `DOT___liquid_staking___${chain}`;
|
|
40
|
-
this.name = `${chainInfo.name} Liquid Staking`;
|
|
41
|
-
this.shortName = chainInfo.name.replaceAll(' Relay Chain', '');
|
|
42
|
-
}
|
|
43
|
-
getDescription() {
|
|
44
|
-
return 'Stake DOT to earn yield on LDOT';
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/* Subscribe pool info */
|
|
48
|
-
|
|
49
|
-
async getPoolStat() {
|
|
50
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
51
|
-
const stakingMetaPromise = new Promise(function (resolve) {
|
|
52
|
-
(0, _crossFetch.default)(GRAPHQL_API, {
|
|
53
|
-
method: 'POST',
|
|
54
|
-
headers: {
|
|
55
|
-
'Content-Type': 'application/json'
|
|
56
|
-
},
|
|
57
|
-
body: JSON.stringify({
|
|
58
|
-
query: EXCHANGE_RATE_REQUEST
|
|
59
|
-
})
|
|
60
|
-
}).then(res => {
|
|
61
|
-
resolve(res.json());
|
|
62
|
-
}).catch(console.error);
|
|
63
|
-
});
|
|
64
|
-
const [_toBondPool, _totalStakingBonded, _stakingMeta] = await Promise.all([substrateApi.api.query.homa.toBondPool(), substrateApi.api.query.homa.totalStakingBonded(), stakingMetaPromise]);
|
|
65
|
-
const mintThreshold = substrateApi.api.consts.homa.mintThreshold.toString();
|
|
66
|
-
const redeemThreshold = substrateApi.api.consts.homa.redeemThreshold.toString();
|
|
67
|
-
const stakingMeta = _stakingMeta;
|
|
68
|
-
const stakingMetaList = stakingMeta.data.dailySummaries.nodes;
|
|
69
|
-
const latestExchangeRate = parseInt(stakingMetaList[0].exchangeRate);
|
|
70
|
-
const decimals = 10 ** this.rateDecimals;
|
|
71
|
-
this.updateExchangeRate(latestExchangeRate);
|
|
72
|
-
const endingBalance = parseInt(stakingMetaList[0].exchangeRate);
|
|
73
|
-
const beginBalance = parseInt(stakingMetaList[29].exchangeRate);
|
|
74
|
-
const diff = endingBalance / beginBalance;
|
|
75
|
-
const apy = diff ** (365 / 30) - 1;
|
|
76
|
-
const toBondPool = new _util.BN(_toBondPool.toString());
|
|
77
|
-
const totalStakingBonded = new _util.BN(_totalStakingBonded.toString());
|
|
78
|
-
return {
|
|
79
|
-
...this.baseInfo,
|
|
80
|
-
type: this.type,
|
|
81
|
-
metadata: {
|
|
82
|
-
...this.metadataInfo,
|
|
83
|
-
description: this.getDescription()
|
|
84
|
-
},
|
|
85
|
-
statistic: {
|
|
86
|
-
assetEarning: [{
|
|
87
|
-
slug: this.rewardAssets[0],
|
|
88
|
-
apy: apy * 100,
|
|
89
|
-
exchangeRate: latestExchangeRate / decimals
|
|
90
|
-
}],
|
|
91
|
-
unstakingPeriod: 24 * 28,
|
|
92
|
-
maxCandidatePerFarmer: 1,
|
|
93
|
-
maxWithdrawalRequestPerFarmer: 1,
|
|
94
|
-
earningThreshold: {
|
|
95
|
-
join: mintThreshold,
|
|
96
|
-
defaultUnstake: redeemThreshold,
|
|
97
|
-
fastUnstake: '0'
|
|
98
|
-
},
|
|
99
|
-
totalApy: apy * 100,
|
|
100
|
-
tvl: totalStakingBonded.add(toBondPool).toString()
|
|
101
|
-
}
|
|
102
|
-
};
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
/* Subscribe pool info */
|
|
106
|
-
|
|
107
|
-
/* Subscribe pool position */
|
|
108
|
-
|
|
109
|
-
async subscribePoolPosition(useAddresses, resultCallback) {
|
|
110
|
-
let cancel = false;
|
|
111
|
-
const substrateApi = this.substrateApi;
|
|
112
|
-
await substrateApi.isReady;
|
|
113
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
114
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
115
|
-
const unsub = await substrateApi.api.query.tokens.accounts.multi(useAddresses.map(address => [address, (0, _utils._getTokenOnChainInfo)(derivativeTokenInfo)]), async _balances => {
|
|
116
|
-
if (cancel) {
|
|
117
|
-
unsub();
|
|
118
|
-
return;
|
|
119
|
-
}
|
|
120
|
-
const balances = _balances;
|
|
121
|
-
const redeemRequests = await substrateApi.api.query.homa.redeemRequests.multi(useAddresses);
|
|
122
|
-
const exchangeRate = await this.getExchangeRate();
|
|
123
|
-
const decimals = _util.BN_TEN.pow(new _util.BN(this.rateDecimals));
|
|
124
|
-
for (let i = 0; i < balances.length; i++) {
|
|
125
|
-
const balanceItem = balances[i];
|
|
126
|
-
const address = useAddresses[i];
|
|
127
|
-
const activeTotalBalance = balanceItem.free || _util.BN_ZERO;
|
|
128
|
-
let totalBalance = activeTotalBalance.mul(new _util.BN(exchangeRate)).div(decimals);
|
|
129
|
-
let unlockingBalance = _util.BN_ZERO;
|
|
130
|
-
const unstakings = [];
|
|
131
|
-
const redeemRequest = redeemRequests[i].toPrimitive();
|
|
132
|
-
if (redeemRequest) {
|
|
133
|
-
const [redeemAmount, withdrawable] = redeemRequest;
|
|
134
|
-
const amount = new _util.BN(redeemAmount);
|
|
135
|
-
totalBalance = totalBalance.add(amount);
|
|
136
|
-
unlockingBalance = unlockingBalance.add(amount);
|
|
137
|
-
unstakings.push({
|
|
138
|
-
chain: this.chain,
|
|
139
|
-
status: withdrawable ? _types.UnstakingStatus.CLAIMABLE : _types.UnstakingStatus.UNLOCKING,
|
|
140
|
-
claimable: redeemAmount.toString()
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
const result = {
|
|
144
|
-
...this.baseInfo,
|
|
145
|
-
type: this.type,
|
|
146
|
-
address,
|
|
147
|
-
balanceToken: this.inputAsset,
|
|
148
|
-
totalStake: totalBalance.toString(),
|
|
149
|
-
activeStake: activeTotalBalance.toString(),
|
|
150
|
-
unstakeBalance: unlockingBalance.toString(),
|
|
151
|
-
status: activeTotalBalance.gt(_util.BN_ZERO) ? _types.EarningStatus.EARNING_REWARD : _types.EarningStatus.NOT_EARNING,
|
|
152
|
-
derivativeToken: derivativeTokenSlug,
|
|
153
|
-
isBondedBefore: totalBalance.gt(_util.BN_ZERO),
|
|
154
|
-
nominations: [],
|
|
155
|
-
unstakings: unstakings
|
|
156
|
-
};
|
|
157
|
-
resultCallback(result);
|
|
158
|
-
}
|
|
159
|
-
});
|
|
160
|
-
return () => {
|
|
161
|
-
cancel = true;
|
|
162
|
-
unsub();
|
|
163
|
-
};
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
/* Subscribe pool position */
|
|
167
|
-
|
|
168
|
-
/* Join pool action */
|
|
169
|
-
|
|
170
|
-
get submitJoinStepInfo() {
|
|
171
|
-
return {
|
|
172
|
-
name: 'Mint LDOT',
|
|
173
|
-
type: _types.YieldStepType.MINT_LDOT
|
|
174
|
-
};
|
|
175
|
-
}
|
|
176
|
-
async getSubmitStepFee(params) {
|
|
177
|
-
const poolOriginSubstrateApi = await this.substrateApi.isReady;
|
|
178
|
-
const defaultFeeTokenSlug = this.feeAssets[0];
|
|
179
|
-
if (new _util.BN(params.amount).gt(_util.BN_ZERO)) {
|
|
180
|
-
const _mintFeeInfo = await poolOriginSubstrateApi.api.tx.homa.mint(params.amount).paymentInfo(_constants.fakeAddress);
|
|
181
|
-
const mintFeeInfo = _mintFeeInfo.toPrimitive();
|
|
182
|
-
return {
|
|
183
|
-
amount: mintFeeInfo.partialFee.toString(),
|
|
184
|
-
slug: defaultFeeTokenSlug
|
|
185
|
-
};
|
|
186
|
-
} else {
|
|
187
|
-
return {
|
|
188
|
-
amount: '0',
|
|
189
|
-
slug: defaultFeeTokenSlug
|
|
190
|
-
};
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
async handleSubmitStep(data, path) {
|
|
194
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
195
|
-
const extrinsic = substrateApi.api.tx.homa.mint(data.amount);
|
|
196
|
-
return {
|
|
197
|
-
txChain: this.chain,
|
|
198
|
-
extrinsicType: _KoniTypes.ExtrinsicType.MINT_LDOT,
|
|
199
|
-
extrinsic,
|
|
200
|
-
txData: data,
|
|
201
|
-
transferNativeAmount: '0',
|
|
202
|
-
chainType: _KoniTypes.ChainType.SUBSTRATE
|
|
203
|
-
};
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
/* Join pool action */
|
|
207
|
-
|
|
208
|
-
/* Leave pool action */
|
|
209
|
-
|
|
210
|
-
async handleYieldRedeem(amount, address, selectedTarget) {
|
|
211
|
-
const substrateApi = await this.substrateApi.isReady;
|
|
212
|
-
const weightedMinAmount = await this.createParamToRedeem(amount, address);
|
|
213
|
-
const extrinsic = substrateApi.api.tx.aggregatedDex.swapWithExactSupply(
|
|
214
|
-
// Swap path
|
|
215
|
-
[{
|
|
216
|
-
Taiga: [0, /* pool id */
|
|
217
|
-
1, /* supply asset */
|
|
218
|
-
0 /* target asset */]
|
|
219
|
-
}],
|
|
220
|
-
// Supply amount
|
|
221
|
-
amount,
|
|
222
|
-
// Min target amount
|
|
223
|
-
weightedMinAmount // should always set a min target to prevent unexpected result
|
|
224
|
-
);
|
|
225
|
-
|
|
226
|
-
return [_KoniTypes.ExtrinsicType.REDEEM_LDOT, extrinsic];
|
|
227
|
-
}
|
|
228
|
-
async handleYieldUnstake(amount, address, selectedTarget) {
|
|
229
|
-
const chainApi = await this.substrateApi.isReady;
|
|
230
|
-
const extrinsic = chainApi.api.tx.homa.requestRedeem(amount, false);
|
|
231
|
-
return [_KoniTypes.ExtrinsicType.UNSTAKE_LDOT, extrinsic];
|
|
232
|
-
}
|
|
233
|
-
async handleYieldWithdraw(address, unstakingInfo) {
|
|
234
|
-
const chainApi = await this.substrateApi.isReady;
|
|
235
|
-
return chainApi.api.tx.homa.claimRedemption(address);
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
/* Leave pool action */
|
|
239
|
-
}
|
|
240
|
-
exports.default = AcalaLiquidStakingPoolHandler;
|
|
@@ -1,98 +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/yield/helper/utils");
|
|
11
|
-
var _types = require("@subwallet/extension-base/types");
|
|
12
|
-
var _utils2 = require("@subwallet/extension-base/utils");
|
|
13
|
-
var _bignumber = _interopRequireDefault(require("bignumber.js"));
|
|
14
|
-
var _i18next = require("i18next");
|
|
15
|
-
var _util = require("@polkadot/util");
|
|
16
|
-
var _special = _interopRequireDefault(require("../special"));
|
|
17
|
-
// Copyright 2019-2022 @subwallet/extension-base
|
|
18
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
19
|
-
|
|
20
|
-
const DEFAULT_MIN_AMOUNT_PERCENT = 0.98;
|
|
21
|
-
class BaseLiquidStakingPoolHandler extends _special.default {
|
|
22
|
-
type = _types.YieldPoolType.LIQUID_STAKING;
|
|
23
|
-
/** Rate convert token when redeem */
|
|
24
|
-
minAmountPercent = DEFAULT_MIN_AMOUNT_PERCENT;
|
|
25
|
-
static get defaultMinAmountPercent() {
|
|
26
|
-
return DEFAULT_MIN_AMOUNT_PERCENT;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
/* Leave pool action */
|
|
30
|
-
|
|
31
|
-
async createParamToRedeem(amount, address) {
|
|
32
|
-
const yieldPositionInfo = await this.getPoolPosition(address);
|
|
33
|
-
const poolInfo = await this.getPoolInfo();
|
|
34
|
-
const originTokenSlug = this.inputAsset;
|
|
35
|
-
const derivativeTokenSlug = this.derivativeAssets[0];
|
|
36
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(derivativeTokenSlug);
|
|
37
|
-
const originTokenInfo = this.state.getAssetBySlug(originTokenSlug);
|
|
38
|
-
if (!yieldPositionInfo || !poolInfo) {
|
|
39
|
-
return Promise.reject(new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS));
|
|
40
|
-
}
|
|
41
|
-
const formattedMinAmount = (0, _utils.convertDerivativeToOriginToken)(amount, poolInfo, derivativeTokenInfo, originTokenInfo);
|
|
42
|
-
return new _bignumber.default(formattedMinAmount).multipliedBy(this.minAmountPercent).toFixed(0);
|
|
43
|
-
}
|
|
44
|
-
async validateYieldLeave(amount, address, fastLeave, selectedTarget) {
|
|
45
|
-
const poolInfo = await this.getPoolInfo();
|
|
46
|
-
const poolPosition = await this.getPoolPosition(address);
|
|
47
|
-
if (!poolInfo || !poolInfo.statistic || !poolPosition) {
|
|
48
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
49
|
-
}
|
|
50
|
-
if (!this.availableMethod.defaultUnstake && !fastLeave) {
|
|
51
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
52
|
-
}
|
|
53
|
-
if (!this.availableMethod.fastUnstake && fastLeave) {
|
|
54
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INTERNAL_ERROR)];
|
|
55
|
-
}
|
|
56
|
-
const errors = [];
|
|
57
|
-
const bnActiveStake = new _util.BN(poolPosition.activeStake);
|
|
58
|
-
const bnAmount = new _util.BN(amount);
|
|
59
|
-
const bnRemainingStake = bnActiveStake.sub(bnAmount);
|
|
60
|
-
const minStake = new _util.BN(poolInfo.statistic.earningThreshold.join || '0');
|
|
61
|
-
const minUnstake = new _util.BN((fastLeave ? poolInfo.statistic.earningThreshold.fastUnstake : poolInfo.statistic.earningThreshold.defaultUnstake) || '0');
|
|
62
|
-
const maxUnstakeRequest = poolInfo.statistic.maxWithdrawalRequestPerFarmer;
|
|
63
|
-
const derivativeTokenInfo = this.state.getAssetBySlug(this.derivativeAssets[0]);
|
|
64
|
-
if (bnAmount.lte(_util.BN_ZERO)) {
|
|
65
|
-
return [new _TransactionError.TransactionError(_KoniTypes.BasicTxErrorType.INVALID_PARAMS, (0, _i18next.t)('Amount must be greater than 0'))];
|
|
66
|
-
}
|
|
67
|
-
if (bnAmount.lt(minUnstake)) {
|
|
68
|
-
const minUnstakeStr = (0, _utils2.formatNumber)(minUnstake.toString(), derivativeTokenInfo.decimals || 0);
|
|
69
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.NOT_ENOUGH_MIN_UNSTAKE, (0, _i18next.t)('You need to unstake at least {{amount}} {{token}}', {
|
|
70
|
-
replace: {
|
|
71
|
-
amount: minUnstakeStr,
|
|
72
|
-
token: derivativeTokenInfo.symbol
|
|
73
|
-
}
|
|
74
|
-
})));
|
|
75
|
-
}
|
|
76
|
-
if (!fastLeave) {
|
|
77
|
-
if (!(bnRemainingStake.isZero() || bnRemainingStake.gte(minStake))) {
|
|
78
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.INVALID_ACTIVE_STAKE)); // TODO
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
if (poolPosition.unstakings.length > maxUnstakeRequest) {
|
|
82
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.EXCEED_MAX_UNSTAKING, (0, _i18next.t)('You cannot unstake more than {{number}} times', {
|
|
83
|
-
replace: {
|
|
84
|
-
number: maxUnstakeRequest
|
|
85
|
-
}
|
|
86
|
-
})));
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
if (bnRemainingStake.lt(_util.BN_ZERO)) {
|
|
90
|
-
errors.push(new _TransactionError.TransactionError(_KoniTypes.StakingTxErrorType.INVALID_ACTIVE_STAKE)); // TODO
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
return Promise.resolve(errors);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
/* Leave pool action */
|
|
97
|
-
}
|
|
98
|
-
exports.default = BaseLiquidStakingPoolHandler;
|