stackswap-front-api-test-02 1.0.87 → 1.0.90
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/README.md +10 -10
- package/dist/esm/index.d.ts +84 -84
- package/dist/esm/index.js +143 -143
- package/dist/esm/stackswap/config.d.ts +114 -112
- package/dist/esm/stackswap/config.js +188 -185
- package/dist/esm/stackswap/config.js.map +1 -1
- package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/esm/stackswap/manager/farm.manager.js +293 -293
- package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
- package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/governance.manager.js +53 -53
- package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
- package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
- package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js +153 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
- package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/esm/stackswap/manager/nft.manager.js +243 -243
- package/dist/esm/stackswap/manager/nft.manager.js.map +1 -1
- package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/esm/stackswap/manager/operator.manager.js +85 -85
- package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/other.manager.js +47 -47
- package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/esm/stackswap/manager/pool.manager.js +171 -171
- package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
- package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/esm/stackswap/manager/staking.manager.js +233 -233
- package/dist/esm/stackswap/manager/staking.manager.js.map +1 -1
- package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/esm/stackswap/manager/swap.manager.js +332 -331
- package/dist/esm/stackswap/manager/swap.manager.js.map +1 -1
- package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
- package/dist/esm/stackswap/manager/token.manager.js +133 -133
- package/dist/esm/stackswap/util.d.ts +35 -35
- package/dist/esm/stackswap/util.js +201 -201
- package/dist/index.d.ts +84 -84
- package/dist/index.js +152 -152
- package/dist/index.umd.js +1 -1
- package/dist/stackswap/config.d.ts +114 -112
- package/dist/stackswap/config.js +193 -190
- package/dist/stackswap/config.js.map +1 -1
- package/dist/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/stackswap/manager/farm.manager.js +301 -301
- package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/stackswap/manager/farm2.manager.js +410 -410
- package/dist/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/stackswap/manager/governance.manager.js +60 -60
- package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/stackswap/manager/launchpad.manager.js +151 -151
- package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/stackswap/manager/lbtc.manager.js +333 -333
- package/dist/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js +160 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/stackswap/manager/multisig.manager.js +55 -55
- package/dist/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/stackswap/manager/nft.manager.js +250 -250
- package/dist/stackswap/manager/nft.manager.js.map +1 -1
- package/dist/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/stackswap/manager/operator.manager.js +92 -92
- package/dist/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/stackswap/manager/other.manager.js +54 -54
- package/dist/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/stackswap/manager/pool.manager.js +179 -179
- package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/stackswap/manager/poxl.manager.js +78 -78
- package/dist/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/stackswap/manager/staking.manager.js +240 -240
- package/dist/stackswap/manager/staking.manager.js.map +1 -1
- package/dist/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/stackswap/manager/swap.manager.js +339 -338
- package/dist/stackswap/manager/swap.manager.js.map +1 -1
- package/dist/stackswap/manager/token.manager.d.ts +31 -31
- package/dist/stackswap/manager/token.manager.js +141 -141
- package/dist/stackswap/util.d.ts +35 -35
- package/dist/stackswap/util.js +218 -218
- package/package.json +43 -43
- package/src/index.ts +204 -204
- package/src/stackswap/config.ts +297 -292
- package/src/stackswap/manager/farm.manager.ts +399 -399
- package/src/stackswap/manager/farm2.manager.ts +463 -463
- package/src/stackswap/manager/governance.manager.ts +95 -95
- package/src/stackswap/manager/launchpad.manager.ts +190 -190
- package/src/stackswap/manager/lbtcstaking.manager.ts +219 -0
- package/src/stackswap/manager/multisig.manager.ts +87 -87
- package/src/stackswap/manager/nft.manager.ts +307 -311
- package/src/stackswap/manager/operator.manager.ts +123 -123
- package/src/stackswap/manager/other.manager.ts +71 -71
- package/src/stackswap/manager/pool.manager.ts +202 -202
- package/src/stackswap/manager/poxl.manager.ts +99 -99
- package/src/stackswap/manager/staking.manager.ts +321 -321
- package/src/stackswap/manager/swap.manager.ts +392 -391
- package/src/stackswap/manager/token.manager.ts +167 -167
- package/src/stackswap/util.ts +237 -237
|
@@ -1,294 +1,294 @@
|
|
|
1
|
-
import { callReadOnlyFunction, contractPrincipalCV, cvToValue, FungibleConditionCode, listCV, standardPrincipalCV, uintCV } from '@stacks/transactions';
|
|
2
|
-
import BigNumber from 'bignumber.js';
|
|
3
|
-
import { openContractCall } from '@stacks/connect';
|
|
4
|
-
import { getPostConditionFromAsset, getReadOptions, getWriteOptions, num2decimal, numFormat_ } from "../util";
|
|
5
|
-
import { Mode } from "./farm2.manager";
|
|
6
|
-
export class Farm {
|
|
7
|
-
constructor(pool, locked_token, TVL, APR, in_contract, cur_round) {
|
|
8
|
-
this.pool = pool;
|
|
9
|
-
this.locked_token = locked_token;
|
|
10
|
-
this.TVL = TVL;
|
|
11
|
-
this.APR = APR;
|
|
12
|
-
this.in_contract = in_contract;
|
|
13
|
-
this.cur_round = cur_round;
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
export class FarmManager {
|
|
17
|
-
constructor(stackswap) {
|
|
18
|
-
this.stackswap = stackswap;
|
|
19
|
-
}
|
|
20
|
-
async getFarmingRound(bh) {
|
|
21
|
-
try {
|
|
22
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-reward-cycle', [
|
|
23
|
-
uintCV(bh)
|
|
24
|
-
]);
|
|
25
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
26
|
-
const result = cvToValue(result_raw);
|
|
27
|
-
return result.value;
|
|
28
|
-
}
|
|
29
|
-
catch (e) {
|
|
30
|
-
return 0;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
async getFarmingRoundFirstBlock(cycle) {
|
|
34
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-first-stacks-block-in-reward-cycle', [
|
|
35
|
-
uintCV(cycle)
|
|
36
|
-
]);
|
|
37
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
38
|
-
const result = cvToValue(result_raw);
|
|
39
|
-
return result;
|
|
40
|
-
}
|
|
41
|
-
async getFarmingStakerStatus(pool_address, cur_round) {
|
|
42
|
-
const address = pool_address.split('.');
|
|
43
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker', [
|
|
44
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
45
|
-
contractPrincipalCV(address[0], address[1]),
|
|
46
|
-
]);
|
|
47
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
48
|
-
const result = cvToValue(result_raw);
|
|
49
|
-
try {
|
|
50
|
-
const pooledToken = result.value.amountUstx.value;
|
|
51
|
-
const unclaimedList = [];
|
|
52
|
-
const stakedList = [];
|
|
53
|
-
for (const unclaimedElement of result.value.unclaimedList.value) {
|
|
54
|
-
if (unclaimedElement.value < cur_round && unclaimedElement.value <= this.stackswap.config.FARM_V1_END_CYCLE()) {
|
|
55
|
-
unclaimedList.push(unclaimedElement.value);
|
|
56
|
-
}
|
|
57
|
-
stakedList.push(unclaimedElement.value);
|
|
58
|
-
}
|
|
59
|
-
return { pooledToken, unclaimedList, stakedList };
|
|
60
|
-
}
|
|
61
|
-
catch (e) {
|
|
62
|
-
return { pooledToken: 0, unclaimedList: [], stakedList: [] };
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
async getFarmBalance(token) {
|
|
66
|
-
const pair_details_options = getReadOptions(this.stackswap, token.addr, 'get-balance', [contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING())]);
|
|
67
|
-
try {
|
|
68
|
-
const result = await callReadOnlyFunction(pair_details_options);
|
|
69
|
-
return cvToValue(result).value;
|
|
70
|
-
}
|
|
71
|
-
catch (e) {
|
|
72
|
-
return 0;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
async getPoolSTXPriceFarm(pair, token_x, token_y, farm_total) {
|
|
76
|
-
const x_token_addr = token_x.addr;
|
|
77
|
-
const y_token_addr = token_y.addr;
|
|
78
|
-
let total_balacne = new BigNumber(-1);
|
|
79
|
-
if (x_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr) {
|
|
80
|
-
total_balacne = (new BigNumber(pair.balance_x).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_x.decimal))).multipliedBy(2);
|
|
81
|
-
}
|
|
82
|
-
else if (y_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr) {
|
|
83
|
-
total_balacne = (new BigNumber(pair.balance_y).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_y.decimal))).multipliedBy(2);
|
|
84
|
-
}
|
|
85
|
-
return total_balacne;
|
|
86
|
-
}
|
|
87
|
-
async getFarmingTotalStatusCycle(cycle) {
|
|
88
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-stats-at-cycle', [
|
|
89
|
-
uintCV(cycle),
|
|
90
|
-
]);
|
|
91
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
92
|
-
const result = cvToValue(result_raw);
|
|
93
|
-
try {
|
|
94
|
-
return new BigNumber(result.value.amountUstx.value).multipliedBy(2).toFixed(0).toString();
|
|
95
|
-
}
|
|
96
|
-
catch (e) {
|
|
97
|
-
return '0';
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
async getFarmingTotalValue(pool_address) {
|
|
101
|
-
try {
|
|
102
|
-
const address = pool_address.split('.');
|
|
103
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farm-info', [
|
|
104
|
-
contractPrincipalCV(address[0], address[1]),
|
|
105
|
-
]);
|
|
106
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
107
|
-
const result = cvToValue(result_raw);
|
|
108
|
-
return result.value;
|
|
109
|
-
}
|
|
110
|
-
catch (e) {
|
|
111
|
-
return 0;
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
async getFarmingUserRewardPerCycle(pool_address, cycle) {
|
|
115
|
-
const address = pool_address.split('.');
|
|
116
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-reward-per-user', [
|
|
117
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
118
|
-
contractPrincipalCV(address[0], address[1]),
|
|
119
|
-
uintCV(cycle),
|
|
120
|
-
]);
|
|
121
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
122
|
-
const result = cvToValue(result_raw);
|
|
123
|
-
return result;
|
|
124
|
-
}
|
|
125
|
-
async getFarmingUserRewardTotal(pool_address) {
|
|
126
|
-
const address = pool_address.split('.');
|
|
127
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-total', [
|
|
128
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
129
|
-
contractPrincipalCV(address[0], address[1]),
|
|
130
|
-
]);
|
|
131
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
132
|
-
const result = cvToValue(result_raw);
|
|
133
|
-
return result;
|
|
134
|
-
}
|
|
135
|
-
async getFarmingUserRewardList(pool_address, unclaimed_list) {
|
|
136
|
-
const address = pool_address.split('.');
|
|
137
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-from-list', [
|
|
138
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
139
|
-
contractPrincipalCV(address[0], address[1]),
|
|
140
|
-
listCV(unclaimed_list),
|
|
141
|
-
]);
|
|
142
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
143
|
-
const result = cvToValue(result_raw);
|
|
144
|
-
return result;
|
|
145
|
-
}
|
|
146
|
-
async getFarmingRewardInfo(pool_address, cycle) {
|
|
147
|
-
const address = pool_address.split('.');
|
|
148
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker-at-cycle', [
|
|
149
|
-
uintCV(cycle),
|
|
150
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
151
|
-
contractPrincipalCV(address[0], address[1]),
|
|
152
|
-
]);
|
|
153
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
154
|
-
try {
|
|
155
|
-
const result = cvToValue(result_raw);
|
|
156
|
-
return result.value.toReturn.value;
|
|
157
|
-
}
|
|
158
|
-
catch (e) {
|
|
159
|
-
return '0';
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
async stakeFarmingContract(pool_address, amountTokens, lockPeriod, callback = null) {
|
|
163
|
-
const address = pool_address.split('.');
|
|
164
|
-
const amount = new BigNumber(amountTokens).multipliedBy(10 ** 6).toFixed(0).toString();
|
|
165
|
-
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'stake-tokens', [
|
|
166
|
-
uintCV(amount),
|
|
167
|
-
contractPrincipalCV(address[0], address[1]),
|
|
168
|
-
uintCV(lockPeriod),
|
|
169
|
-
], [await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), pool_address, amount, FungibleConditionCode.Equal)], callback);
|
|
170
|
-
await openContractCall(function_option);
|
|
171
|
-
}
|
|
172
|
-
async claimFarmingContract(pool_address, cycle, amount_STSW, amount_LP, callback = null) {
|
|
173
|
-
const address = pool_address.split('.');
|
|
174
|
-
const post_condition = [];
|
|
175
|
-
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), this.stackswap.config.BASE_STSW_DATA().addr, amount_STSW, FungibleConditionCode.Equal));
|
|
176
|
-
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), pool_address, amount_LP, FungibleConditionCode.Equal));
|
|
177
|
-
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'claim-staking-reward', [
|
|
178
|
-
uintCV(cycle),
|
|
179
|
-
contractPrincipalCV(address[0], address[1]),
|
|
180
|
-
], post_condition, callback);
|
|
181
|
-
await openContractCall(function_option);
|
|
182
|
-
}
|
|
183
|
-
async unstakeFarmingContract(pool_address, cycle, amount_LP, callback = null) {
|
|
184
|
-
const address = pool_address.split('.');
|
|
185
|
-
const post_condition = [];
|
|
186
|
-
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), pool_address, amount_LP, FungibleConditionCode.Equal));
|
|
187
|
-
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'unstake-from-farming', [
|
|
188
|
-
uintCV(cycle),
|
|
189
|
-
contractPrincipalCV(address[0], address[1]),
|
|
190
|
-
], post_condition, callback);
|
|
191
|
-
await openContractCall(function_option);
|
|
192
|
-
}
|
|
193
|
-
async getCurrentFarmingRound() {
|
|
194
|
-
const bh = await this.stackswap.getCurrentBlock();
|
|
195
|
-
return await this.getFarmingRound(bh);
|
|
196
|
-
}
|
|
197
|
-
async getRewardBalanceFromFarming(pool_addr, unclaimed_list) {
|
|
198
|
-
const num_list = [];
|
|
199
|
-
for (const unclaimed of unclaimed_list) {
|
|
200
|
-
num_list.push(uintCV(unclaimed));
|
|
201
|
-
}
|
|
202
|
-
const result = await this.getFarmingUserRewardList(pool_addr, num_list);
|
|
203
|
-
const reward = numFormat_(num2decimal(result.rewardSum.value, 6));
|
|
204
|
-
return reward;
|
|
205
|
-
}
|
|
206
|
-
getFarmingAPR(tvl, stsw_price) {
|
|
207
|
-
if (new BigNumber(tvl) <= new BigNumber(0)) {
|
|
208
|
-
const temp = new BigNumber(671731.200000).multipliedBy(52).multipliedBy(new BigNumber(stsw_price));
|
|
209
|
-
return temp.toFixed(3).toString();
|
|
210
|
-
}
|
|
211
|
-
else {
|
|
212
|
-
BigNumber.config({ DECIMAL_PLACES: 10 });
|
|
213
|
-
const tvl_bn = new BigNumber(tvl);
|
|
214
|
-
const reward_stx = new BigNumber(671731.2).multipliedBy(new BigNumber(stsw_price));
|
|
215
|
-
const new_reward = reward_stx.div(tvl_bn);
|
|
216
|
-
const new_reward_apr = new_reward.multipliedBy(5200);
|
|
217
|
-
return new_reward_apr.toFixed(3).toString();
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
async getEachFarmData(data, type, callback) {
|
|
221
|
-
const oracle_stsw = (await this.stackswap.lbtcManager.getPrice('STSW'))['last-price'].value;
|
|
222
|
-
const oracle_stx = (await this.stackswap.lbtcManager.getPrice('STX'))['last-price'].value;
|
|
223
|
-
const bh = await this.stackswap.getCurrentBlock();
|
|
224
|
-
const usd_stx = new BigNumber(oracle_stx).dividedBy(10 ** 6).toNumber();
|
|
225
|
-
const stsw_stx = new BigNumber(oracle_stsw).dividedBy(oracle_stx).toNumber();
|
|
226
|
-
const cur_round = await this.getFarmingRound(bh);
|
|
227
|
-
const farms = [];
|
|
228
|
-
data.forEach((farm) => {
|
|
229
|
-
if (farm.farm_group === 1) {
|
|
230
|
-
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_1();
|
|
231
|
-
}
|
|
232
|
-
else if (farm.farm_group === 5) {
|
|
233
|
-
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_5();
|
|
234
|
-
}
|
|
235
|
-
farm.round = cur_round;
|
|
236
|
-
this.getFarmData(farm, bh, type, usd_stx, stsw_stx).then((value) => {
|
|
237
|
-
farms.push(value);
|
|
238
|
-
if (farms.length == data.length) {
|
|
239
|
-
callback(farms);
|
|
240
|
-
}
|
|
241
|
-
});
|
|
242
|
-
});
|
|
243
|
-
}
|
|
244
|
-
async getFarmData(farm, bh, type, usd_stx, stsw_stx) {
|
|
245
|
-
farm.valid = false;
|
|
246
|
-
switch (type) {
|
|
247
|
-
case Mode.ONLY_BLOCKCHAIN:
|
|
248
|
-
farm.pair = (await this.stackswap.poolManager.getPairDataFromContract(farm.token_x, farm.token_y));
|
|
249
|
-
break;
|
|
250
|
-
case Mode.WITH_SERVER:
|
|
251
|
-
farm.pair = (await this.stackswap.swapManager.findRouter(farm.token_x, farm.token_y, Number(bh))).pair;
|
|
252
|
-
break;
|
|
253
|
-
}
|
|
254
|
-
this.getFarmBalance(farm.pair.token_lp).then(farm_total => {
|
|
255
|
-
this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm_total).then(tvl_stx => {
|
|
256
|
-
farm.tvl = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toNumber();
|
|
257
|
-
});
|
|
258
|
-
});
|
|
259
|
-
this.getFarmingTotalStatusCycle(Number(farm.round) + 1).then((value1) => {
|
|
260
|
-
const tvl = new BigNumber(num2decimal(value1, 6)).toFixed(3).toString();
|
|
261
|
-
if (farm.round > this.stackswap.config.FARM_V1_END_CYCLE()) {
|
|
262
|
-
farm.apr = '0';
|
|
263
|
-
}
|
|
264
|
-
else {
|
|
265
|
-
farm.apr = this.getFarmingAPR(tvl, stsw_stx);
|
|
266
|
-
}
|
|
267
|
-
});
|
|
268
|
-
return farm;
|
|
269
|
-
}
|
|
270
|
-
async getFarmUserData(farm, usd_stx) {
|
|
271
|
-
farm.migratable = false;
|
|
272
|
-
farm.isMigratable = await this.stackswap.farm2Manager.isUserMigratable2(farm.pair.token_lp.addr, farm.farm_contract);
|
|
273
|
-
const status = await this.getFarmingStakerStatus(farm.pair.token_lp.addr, Number(farm.round));
|
|
274
|
-
farm.claimable_list = status.unclaimedList;
|
|
275
|
-
farm.pooled_stsw = status.pooledToken;
|
|
276
|
-
farm.stakedList = status.stakedList;
|
|
277
|
-
for (const stakedListElement of status.stakedList) {
|
|
278
|
-
if (stakedListElement > this.stackswap.config.FARM_V1_END_CYCLE() && farm.isMigratable) {
|
|
279
|
-
farm.migratable = true;
|
|
280
|
-
}
|
|
281
|
-
if (farm.unstakedList) {
|
|
282
|
-
farm.unstakedList.push(stakedListElement);
|
|
283
|
-
}
|
|
284
|
-
else {
|
|
285
|
-
farm.unstakedList = [];
|
|
286
|
-
farm.unstakedList.push(stakedListElement);
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
const tvl_stx = await this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm.pooled_stsw);
|
|
290
|
-
farm.user_TVL = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toFixed(3).toString();
|
|
291
|
-
return farm;
|
|
292
|
-
}
|
|
293
|
-
}
|
|
1
|
+
import { callReadOnlyFunction, contractPrincipalCV, cvToValue, FungibleConditionCode, listCV, standardPrincipalCV, uintCV } from '@stacks/transactions';
|
|
2
|
+
import BigNumber from 'bignumber.js';
|
|
3
|
+
import { openContractCall } from '@stacks/connect';
|
|
4
|
+
import { getPostConditionFromAsset, getReadOptions, getWriteOptions, num2decimal, numFormat_ } from "../util";
|
|
5
|
+
import { Mode } from "./farm2.manager";
|
|
6
|
+
export class Farm {
|
|
7
|
+
constructor(pool, locked_token, TVL, APR, in_contract, cur_round) {
|
|
8
|
+
this.pool = pool;
|
|
9
|
+
this.locked_token = locked_token;
|
|
10
|
+
this.TVL = TVL;
|
|
11
|
+
this.APR = APR;
|
|
12
|
+
this.in_contract = in_contract;
|
|
13
|
+
this.cur_round = cur_round;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export class FarmManager {
|
|
17
|
+
constructor(stackswap) {
|
|
18
|
+
this.stackswap = stackswap;
|
|
19
|
+
}
|
|
20
|
+
async getFarmingRound(bh) {
|
|
21
|
+
try {
|
|
22
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-reward-cycle', [
|
|
23
|
+
uintCV(bh)
|
|
24
|
+
]);
|
|
25
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
26
|
+
const result = cvToValue(result_raw);
|
|
27
|
+
return result.value;
|
|
28
|
+
}
|
|
29
|
+
catch (e) {
|
|
30
|
+
return 0;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
async getFarmingRoundFirstBlock(cycle) {
|
|
34
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-first-stacks-block-in-reward-cycle', [
|
|
35
|
+
uintCV(cycle)
|
|
36
|
+
]);
|
|
37
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
38
|
+
const result = cvToValue(result_raw);
|
|
39
|
+
return result;
|
|
40
|
+
}
|
|
41
|
+
async getFarmingStakerStatus(pool_address, cur_round) {
|
|
42
|
+
const address = pool_address.split('.');
|
|
43
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker', [
|
|
44
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
45
|
+
contractPrincipalCV(address[0], address[1]),
|
|
46
|
+
]);
|
|
47
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
48
|
+
const result = cvToValue(result_raw);
|
|
49
|
+
try {
|
|
50
|
+
const pooledToken = result.value.amountUstx.value;
|
|
51
|
+
const unclaimedList = [];
|
|
52
|
+
const stakedList = [];
|
|
53
|
+
for (const unclaimedElement of result.value.unclaimedList.value) {
|
|
54
|
+
if (unclaimedElement.value < cur_round && unclaimedElement.value <= this.stackswap.config.FARM_V1_END_CYCLE()) {
|
|
55
|
+
unclaimedList.push(unclaimedElement.value);
|
|
56
|
+
}
|
|
57
|
+
stakedList.push(unclaimedElement.value);
|
|
58
|
+
}
|
|
59
|
+
return { pooledToken, unclaimedList, stakedList };
|
|
60
|
+
}
|
|
61
|
+
catch (e) {
|
|
62
|
+
return { pooledToken: 0, unclaimedList: [], stakedList: [] };
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
async getFarmBalance(token) {
|
|
66
|
+
const pair_details_options = getReadOptions(this.stackswap, token.addr, 'get-balance', [contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING())]);
|
|
67
|
+
try {
|
|
68
|
+
const result = await callReadOnlyFunction(pair_details_options);
|
|
69
|
+
return cvToValue(result).value;
|
|
70
|
+
}
|
|
71
|
+
catch (e) {
|
|
72
|
+
return 0;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
async getPoolSTXPriceFarm(pair, token_x, token_y, farm_total) {
|
|
76
|
+
const x_token_addr = token_x.addr;
|
|
77
|
+
const y_token_addr = token_y.addr;
|
|
78
|
+
let total_balacne = new BigNumber(-1);
|
|
79
|
+
if (x_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr) {
|
|
80
|
+
total_balacne = (new BigNumber(pair.balance_x).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_x.decimal))).multipliedBy(2);
|
|
81
|
+
}
|
|
82
|
+
else if (y_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr) {
|
|
83
|
+
total_balacne = (new BigNumber(pair.balance_y).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_y.decimal))).multipliedBy(2);
|
|
84
|
+
}
|
|
85
|
+
return total_balacne;
|
|
86
|
+
}
|
|
87
|
+
async getFarmingTotalStatusCycle(cycle) {
|
|
88
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-stats-at-cycle', [
|
|
89
|
+
uintCV(cycle),
|
|
90
|
+
]);
|
|
91
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
92
|
+
const result = cvToValue(result_raw);
|
|
93
|
+
try {
|
|
94
|
+
return new BigNumber(result.value.amountUstx.value).multipliedBy(2).toFixed(0).toString();
|
|
95
|
+
}
|
|
96
|
+
catch (e) {
|
|
97
|
+
return '0';
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
async getFarmingTotalValue(pool_address) {
|
|
101
|
+
try {
|
|
102
|
+
const address = pool_address.split('.');
|
|
103
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farm-info', [
|
|
104
|
+
contractPrincipalCV(address[0], address[1]),
|
|
105
|
+
]);
|
|
106
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
107
|
+
const result = cvToValue(result_raw);
|
|
108
|
+
return result.value;
|
|
109
|
+
}
|
|
110
|
+
catch (e) {
|
|
111
|
+
return 0;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
async getFarmingUserRewardPerCycle(pool_address, cycle) {
|
|
115
|
+
const address = pool_address.split('.');
|
|
116
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-reward-per-user', [
|
|
117
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
118
|
+
contractPrincipalCV(address[0], address[1]),
|
|
119
|
+
uintCV(cycle),
|
|
120
|
+
]);
|
|
121
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
122
|
+
const result = cvToValue(result_raw);
|
|
123
|
+
return result;
|
|
124
|
+
}
|
|
125
|
+
async getFarmingUserRewardTotal(pool_address) {
|
|
126
|
+
const address = pool_address.split('.');
|
|
127
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-total', [
|
|
128
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
129
|
+
contractPrincipalCV(address[0], address[1]),
|
|
130
|
+
]);
|
|
131
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
132
|
+
const result = cvToValue(result_raw);
|
|
133
|
+
return result;
|
|
134
|
+
}
|
|
135
|
+
async getFarmingUserRewardList(pool_address, unclaimed_list) {
|
|
136
|
+
const address = pool_address.split('.');
|
|
137
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-from-list', [
|
|
138
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
139
|
+
contractPrincipalCV(address[0], address[1]),
|
|
140
|
+
listCV(unclaimed_list),
|
|
141
|
+
]);
|
|
142
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
143
|
+
const result = cvToValue(result_raw);
|
|
144
|
+
return result;
|
|
145
|
+
}
|
|
146
|
+
async getFarmingRewardInfo(pool_address, cycle) {
|
|
147
|
+
const address = pool_address.split('.');
|
|
148
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker-at-cycle', [
|
|
149
|
+
uintCV(cycle),
|
|
150
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
151
|
+
contractPrincipalCV(address[0], address[1]),
|
|
152
|
+
]);
|
|
153
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
154
|
+
try {
|
|
155
|
+
const result = cvToValue(result_raw);
|
|
156
|
+
return result.value.toReturn.value;
|
|
157
|
+
}
|
|
158
|
+
catch (e) {
|
|
159
|
+
return '0';
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
async stakeFarmingContract(pool_address, amountTokens, lockPeriod, callback = null) {
|
|
163
|
+
const address = pool_address.split('.');
|
|
164
|
+
const amount = new BigNumber(amountTokens).multipliedBy(10 ** 6).toFixed(0).toString();
|
|
165
|
+
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'stake-tokens', [
|
|
166
|
+
uintCV(amount),
|
|
167
|
+
contractPrincipalCV(address[0], address[1]),
|
|
168
|
+
uintCV(lockPeriod),
|
|
169
|
+
], [await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), pool_address, amount, FungibleConditionCode.Equal)], callback);
|
|
170
|
+
await openContractCall(function_option);
|
|
171
|
+
}
|
|
172
|
+
async claimFarmingContract(pool_address, cycle, amount_STSW, amount_LP, callback = null) {
|
|
173
|
+
const address = pool_address.split('.');
|
|
174
|
+
const post_condition = [];
|
|
175
|
+
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), this.stackswap.config.BASE_STSW_DATA().addr, amount_STSW, FungibleConditionCode.Equal));
|
|
176
|
+
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), pool_address, amount_LP, FungibleConditionCode.Equal));
|
|
177
|
+
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'claim-staking-reward', [
|
|
178
|
+
uintCV(cycle),
|
|
179
|
+
contractPrincipalCV(address[0], address[1]),
|
|
180
|
+
], post_condition, callback);
|
|
181
|
+
await openContractCall(function_option);
|
|
182
|
+
}
|
|
183
|
+
async unstakeFarmingContract(pool_address, cycle, amount_LP, callback = null) {
|
|
184
|
+
const address = pool_address.split('.');
|
|
185
|
+
const post_condition = [];
|
|
186
|
+
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), pool_address, amount_LP, FungibleConditionCode.Equal));
|
|
187
|
+
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'unstake-from-farming', [
|
|
188
|
+
uintCV(cycle),
|
|
189
|
+
contractPrincipalCV(address[0], address[1]),
|
|
190
|
+
], post_condition, callback);
|
|
191
|
+
await openContractCall(function_option);
|
|
192
|
+
}
|
|
193
|
+
async getCurrentFarmingRound() {
|
|
194
|
+
const bh = await this.stackswap.getCurrentBlock();
|
|
195
|
+
return await this.getFarmingRound(bh);
|
|
196
|
+
}
|
|
197
|
+
async getRewardBalanceFromFarming(pool_addr, unclaimed_list) {
|
|
198
|
+
const num_list = [];
|
|
199
|
+
for (const unclaimed of unclaimed_list) {
|
|
200
|
+
num_list.push(uintCV(unclaimed));
|
|
201
|
+
}
|
|
202
|
+
const result = await this.getFarmingUserRewardList(pool_addr, num_list);
|
|
203
|
+
const reward = numFormat_(num2decimal(result.rewardSum.value, 6));
|
|
204
|
+
return reward;
|
|
205
|
+
}
|
|
206
|
+
getFarmingAPR(tvl, stsw_price) {
|
|
207
|
+
if (new BigNumber(tvl) <= new BigNumber(0)) {
|
|
208
|
+
const temp = new BigNumber(671731.200000).multipliedBy(52).multipliedBy(new BigNumber(stsw_price));
|
|
209
|
+
return temp.toFixed(3).toString();
|
|
210
|
+
}
|
|
211
|
+
else {
|
|
212
|
+
BigNumber.config({ DECIMAL_PLACES: 10 });
|
|
213
|
+
const tvl_bn = new BigNumber(tvl);
|
|
214
|
+
const reward_stx = new BigNumber(671731.2).multipliedBy(new BigNumber(stsw_price));
|
|
215
|
+
const new_reward = reward_stx.div(tvl_bn);
|
|
216
|
+
const new_reward_apr = new_reward.multipliedBy(5200);
|
|
217
|
+
return new_reward_apr.toFixed(3).toString();
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
async getEachFarmData(data, type, callback) {
|
|
221
|
+
const oracle_stsw = (await this.stackswap.lbtcManager.getPrice('STSW'))['last-price'].value;
|
|
222
|
+
const oracle_stx = (await this.stackswap.lbtcManager.getPrice('STX'))['last-price'].value;
|
|
223
|
+
const bh = await this.stackswap.getCurrentBlock();
|
|
224
|
+
const usd_stx = new BigNumber(oracle_stx).dividedBy(10 ** 6).toNumber();
|
|
225
|
+
const stsw_stx = new BigNumber(oracle_stsw).dividedBy(oracle_stx).toNumber();
|
|
226
|
+
const cur_round = await this.getFarmingRound(bh);
|
|
227
|
+
const farms = [];
|
|
228
|
+
data.forEach((farm) => {
|
|
229
|
+
if (farm.farm_group === 1) {
|
|
230
|
+
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_1();
|
|
231
|
+
}
|
|
232
|
+
else if (farm.farm_group === 5) {
|
|
233
|
+
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_5();
|
|
234
|
+
}
|
|
235
|
+
farm.round = cur_round;
|
|
236
|
+
this.getFarmData(farm, bh, type, usd_stx, stsw_stx).then((value) => {
|
|
237
|
+
farms.push(value);
|
|
238
|
+
if (farms.length == data.length) {
|
|
239
|
+
callback(farms);
|
|
240
|
+
}
|
|
241
|
+
});
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
async getFarmData(farm, bh, type, usd_stx, stsw_stx) {
|
|
245
|
+
farm.valid = false;
|
|
246
|
+
switch (type) {
|
|
247
|
+
case Mode.ONLY_BLOCKCHAIN:
|
|
248
|
+
farm.pair = (await this.stackswap.poolManager.getPairDataFromContract(farm.token_x, farm.token_y));
|
|
249
|
+
break;
|
|
250
|
+
case Mode.WITH_SERVER:
|
|
251
|
+
farm.pair = (await this.stackswap.swapManager.findRouter(farm.token_x, farm.token_y, Number(bh))).pair;
|
|
252
|
+
break;
|
|
253
|
+
}
|
|
254
|
+
this.getFarmBalance(farm.pair.token_lp).then(farm_total => {
|
|
255
|
+
this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm_total).then(tvl_stx => {
|
|
256
|
+
farm.tvl = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toNumber();
|
|
257
|
+
});
|
|
258
|
+
});
|
|
259
|
+
this.getFarmingTotalStatusCycle(Number(farm.round) + 1).then((value1) => {
|
|
260
|
+
const tvl = new BigNumber(num2decimal(value1, 6)).toFixed(3).toString();
|
|
261
|
+
if (farm.round > this.stackswap.config.FARM_V1_END_CYCLE()) {
|
|
262
|
+
farm.apr = '0';
|
|
263
|
+
}
|
|
264
|
+
else {
|
|
265
|
+
farm.apr = this.getFarmingAPR(tvl, stsw_stx);
|
|
266
|
+
}
|
|
267
|
+
});
|
|
268
|
+
return farm;
|
|
269
|
+
}
|
|
270
|
+
async getFarmUserData(farm, usd_stx) {
|
|
271
|
+
farm.migratable = false;
|
|
272
|
+
farm.isMigratable = await this.stackswap.farm2Manager.isUserMigratable2(farm.pair.token_lp.addr, farm.farm_contract);
|
|
273
|
+
const status = await this.getFarmingStakerStatus(farm.pair.token_lp.addr, Number(farm.round));
|
|
274
|
+
farm.claimable_list = status.unclaimedList;
|
|
275
|
+
farm.pooled_stsw = status.pooledToken;
|
|
276
|
+
farm.stakedList = status.stakedList;
|
|
277
|
+
for (const stakedListElement of status.stakedList) {
|
|
278
|
+
if (stakedListElement > this.stackswap.config.FARM_V1_END_CYCLE() && farm.isMigratable) {
|
|
279
|
+
farm.migratable = true;
|
|
280
|
+
}
|
|
281
|
+
if (farm.unstakedList) {
|
|
282
|
+
farm.unstakedList.push(stakedListElement);
|
|
283
|
+
}
|
|
284
|
+
else {
|
|
285
|
+
farm.unstakedList = [];
|
|
286
|
+
farm.unstakedList.push(stakedListElement);
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
const tvl_stx = await this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm.pooled_stsw);
|
|
290
|
+
farm.user_TVL = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toFixed(3).toString();
|
|
291
|
+
return farm;
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
294
|
//# sourceMappingURL=farm.manager.js.map
|