stackswap-front-api-test-02 1.0.104 → 1.0.105
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 +86 -86
- package/dist/esm/index.js +145 -145
- package/dist/esm/stackswap/config.d.ts +117 -117
- package/dist/esm/stackswap/config.js +194 -194
- 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 +51 -51
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js +191 -191
- 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/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/swap.manager.d.ts +39 -39
- package/dist/esm/stackswap/manager/swap.manager.js +332 -332
- 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/esm/stackswap/util.js.map +1 -1
- package/dist/index.d.ts +86 -86
- package/dist/index.js +154 -154
- package/dist/index.umd.js +1 -1
- package/dist/stackswap/config.d.ts +117 -117
- package/dist/stackswap/config.js +199 -199
- 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 +51 -51
- package/dist/stackswap/manager/lbtcstaking.manager.js +198 -198
- 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/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/swap.manager.d.ts +39 -39
- package/dist/stackswap/manager/swap.manager.js +339 -339
- 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/dist/stackswap/util.js.map +1 -1
- package/package.json +43 -43
- package/src/index.ts +207 -207
- package/src/stackswap/config.ts +305 -305
- 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 +277 -277
- package/src/stackswap/manager/multisig.manager.ts +87 -87
- package/src/stackswap/manager/nft.manager.ts +307 -307
- 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 -392
- package/src/stackswap/manager/token.manager.ts +167 -167
- package/src/stackswap/util.ts +237 -237
|
@@ -1,399 +1,399 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
callReadOnlyFunction,
|
|
4
|
-
contractPrincipalCV,
|
|
5
|
-
cvToValue, FungibleConditionCode,
|
|
6
|
-
listCV,
|
|
7
|
-
standardPrincipalCV,
|
|
8
|
-
uintCV
|
|
9
|
-
} from '@stacks/transactions';
|
|
10
|
-
import BigNumber from 'bignumber.js';
|
|
11
|
-
import {openContractCall} from '@stacks/connect';
|
|
12
|
-
import {getPostConditionFromAsset, getReadOptions, getWriteOptions, num2decimal, numFormat_} from "../util";
|
|
13
|
-
import {StackswapAPI} from "../../index";
|
|
14
|
-
import {LiquidityPool} from "./pool.manager";
|
|
15
|
-
import {Mode} from "./farm2.manager";
|
|
16
|
-
|
|
17
|
-
export class Farm {
|
|
18
|
-
pool : LiquidityPool;
|
|
19
|
-
locked_token : string;
|
|
20
|
-
TVL : string;
|
|
21
|
-
APR : string;
|
|
22
|
-
in_contract : string;
|
|
23
|
-
cur_round: number;
|
|
24
|
-
|
|
25
|
-
constructor(pool: LiquidityPool, locked_token: string, TVL : string, APR: string, in_contract : string, cur_round : number) {
|
|
26
|
-
this.pool = pool;
|
|
27
|
-
this.locked_token = locked_token;
|
|
28
|
-
this.TVL = TVL;
|
|
29
|
-
this.APR = APR;
|
|
30
|
-
this.in_contract = in_contract;
|
|
31
|
-
this.cur_round = cur_round;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
export class FarmManager {
|
|
38
|
-
stackswap: StackswapAPI;
|
|
39
|
-
|
|
40
|
-
constructor(stackswap: StackswapAPI) {
|
|
41
|
-
this.stackswap = stackswap;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
async getFarmingRound(bh: number | string){
|
|
46
|
-
try{
|
|
47
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-reward-cycle', [
|
|
48
|
-
uintCV(bh)
|
|
49
|
-
]);
|
|
50
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
51
|
-
const result = cvToValue(result_raw);
|
|
52
|
-
return result.value;
|
|
53
|
-
} catch (e) {
|
|
54
|
-
return 0;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
async getFarmingRoundFirstBlock( cycle: number){
|
|
59
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-first-stacks-block-in-reward-cycle', [
|
|
60
|
-
uintCV(cycle)
|
|
61
|
-
]);
|
|
62
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
63
|
-
const result = cvToValue(result_raw);
|
|
64
|
-
// console.log(result);
|
|
65
|
-
return result;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
async getFarmingStakerStatus( pool_address: string, cur_round: number){
|
|
69
|
-
const address = pool_address.split('.');
|
|
70
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker', [
|
|
71
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
72
|
-
contractPrincipalCV(address[0],address[1]),
|
|
73
|
-
]);
|
|
74
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
75
|
-
const result = cvToValue(result_raw);
|
|
76
|
-
try{
|
|
77
|
-
// console.log('getFarmingStakerStatus', result);
|
|
78
|
-
const pooledToken = result.value.amountUstx.value;
|
|
79
|
-
const unclaimedList = [];
|
|
80
|
-
const stakedList = []
|
|
81
|
-
for (const unclaimedElement of result.value.unclaimedList.value) {
|
|
82
|
-
if( unclaimedElement.value < cur_round && unclaimedElement.value <= this.stackswap.config.FARM_V1_END_CYCLE()){
|
|
83
|
-
unclaimedList.push(unclaimedElement.value);
|
|
84
|
-
}
|
|
85
|
-
stakedList.push(unclaimedElement.value);
|
|
86
|
-
}
|
|
87
|
-
return {pooledToken, unclaimedList, stakedList}
|
|
88
|
-
} catch (e) {
|
|
89
|
-
// console.log(e);
|
|
90
|
-
return {pooledToken: 0, unclaimedList: [], stakedList: []}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
async getFarmBalance( token: any) {
|
|
96
|
-
// console.log("getBalance", token)
|
|
97
|
-
const pair_details_options : any = getReadOptions(this.stackswap, token.addr, 'get-balance',
|
|
98
|
-
[contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING()) ]);
|
|
99
|
-
try {
|
|
100
|
-
const result = await callReadOnlyFunction(pair_details_options);
|
|
101
|
-
return cvToValue(result).value;
|
|
102
|
-
} catch (e) {
|
|
103
|
-
return 0;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
async getPoolSTXPriceFarm(pair: any ,token_x: any, token_y: any, farm_total: any){
|
|
108
|
-
// BigNumber.config({ DECIMAL_PLACES: 6});
|
|
109
|
-
const x_token_addr = token_x.addr;
|
|
110
|
-
// console.log(token_x.addr);
|
|
111
|
-
const y_token_addr = token_y.addr;
|
|
112
|
-
// console.log(token_y.addr);
|
|
113
|
-
let total_balacne = new BigNumber(-1);
|
|
114
|
-
if(x_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr){
|
|
115
|
-
total_balacne = (new BigNumber(pair.balance_x).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_x.decimal))).multipliedBy(2);
|
|
116
|
-
}else if(y_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr){
|
|
117
|
-
total_balacne = (new BigNumber(pair.balance_y).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_y.decimal))).multipliedBy(2);
|
|
118
|
-
}
|
|
119
|
-
// console.log('pool_stx_price', token_x.addr, token_y.addr,token_x.balance, token_y.balance,total_balacne.toNumber());
|
|
120
|
-
// console.log(pair["balance-x"].value, pair["balance-y"].value, total_balacne.toNumber());
|
|
121
|
-
return total_balacne;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
async getFarmingTotalStatusCycle( cycle: number){
|
|
125
|
-
// console.log(cycle);
|
|
126
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-stats-at-cycle', [
|
|
127
|
-
uintCV(cycle),
|
|
128
|
-
]);
|
|
129
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
130
|
-
const result = cvToValue(result_raw);
|
|
131
|
-
// console.log(result.value.amountUstx.value);
|
|
132
|
-
try{
|
|
133
|
-
return new BigNumber(result.value.amountUstx.value).multipliedBy(2).toFixed(0).toString();
|
|
134
|
-
} catch (e) {
|
|
135
|
-
return '0';
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
async getFarmingTotalValue( pool_address: string){
|
|
140
|
-
try{
|
|
141
|
-
const address = pool_address.split('.');
|
|
142
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farm-info', [
|
|
143
|
-
contractPrincipalCV(address[0],address[1]),
|
|
144
|
-
]);
|
|
145
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
146
|
-
const result = cvToValue(result_raw);
|
|
147
|
-
// console.log('get_farming_total',result.value);
|
|
148
|
-
return result.value;
|
|
149
|
-
} catch (e) {
|
|
150
|
-
return 0;
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
async getFarmingUserRewardPerCycle( pool_address: string, cycle: number){
|
|
156
|
-
const address = pool_address.split('.');
|
|
157
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-reward-per-user', [
|
|
158
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
159
|
-
contractPrincipalCV(address[0],address[1]),
|
|
160
|
-
uintCV(cycle),
|
|
161
|
-
]);
|
|
162
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
163
|
-
const result = cvToValue(result_raw);
|
|
164
|
-
// console.log(result_raw);
|
|
165
|
-
return result;
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
async getFarmingUserRewardTotal( pool_address: string){
|
|
169
|
-
const address = pool_address.split('.');
|
|
170
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-total', [
|
|
171
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
172
|
-
contractPrincipalCV(address[0],address[1]),
|
|
173
|
-
]);
|
|
174
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
175
|
-
const result = cvToValue(result_raw);
|
|
176
|
-
// console.log('getFarmingUserRewardTotal', result);
|
|
177
|
-
return result;
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
async getFarmingUserRewardList( pool_address: string, unclaimed_list: any){
|
|
182
|
-
const address = pool_address.split('.');
|
|
183
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-from-list', [
|
|
184
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
185
|
-
contractPrincipalCV(address[0],address[1]),
|
|
186
|
-
listCV(unclaimed_list),
|
|
187
|
-
]);
|
|
188
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
189
|
-
const result = cvToValue(result_raw);
|
|
190
|
-
// console.log('getFarmingUserRewardTotal', result);
|
|
191
|
-
return result;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
async getFarmingRewardInfo( pool_address: string, cycle: number){
|
|
195
|
-
const address = pool_address.split('.');
|
|
196
|
-
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker-at-cycle', [
|
|
197
|
-
uintCV(cycle),
|
|
198
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
199
|
-
contractPrincipalCV(address[0],address[1]),
|
|
200
|
-
]);
|
|
201
|
-
const result_raw = await callReadOnlyFunction(function_option);
|
|
202
|
-
try{
|
|
203
|
-
const result = cvToValue(result_raw);
|
|
204
|
-
// console.log(result);
|
|
205
|
-
return result.value.toReturn.value;
|
|
206
|
-
} catch (e) {
|
|
207
|
-
return '0';
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
async stakeFarmingContract( pool_address: string, amountTokens: string, lockPeriod: number, callback: any = null){
|
|
213
|
-
const address = pool_address.split('.');
|
|
214
|
-
// console.log(amountTokens);
|
|
215
|
-
const amount = new BigNumber(amountTokens).multipliedBy(10 ** 6).toFixed(0).toString();
|
|
216
|
-
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'stake-tokens', [
|
|
217
|
-
uintCV(amount),
|
|
218
|
-
contractPrincipalCV(address[0],address[1]),
|
|
219
|
-
uintCV(lockPeriod),
|
|
220
|
-
],[await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), pool_address, amount, FungibleConditionCode.Equal)], callback);
|
|
221
|
-
await openContractCall(function_option);
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
async claimFarmingContract( pool_address: string, cycle: number, amount_STSW: string, amount_LP: string, callback: any = null){
|
|
225
|
-
const address = pool_address.split('.');
|
|
226
|
-
const post_condition = [];
|
|
227
|
-
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));
|
|
228
|
-
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));
|
|
229
|
-
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'claim-staking-reward', [
|
|
230
|
-
uintCV(cycle),
|
|
231
|
-
contractPrincipalCV(address[0],address[1]),
|
|
232
|
-
], post_condition, callback);
|
|
233
|
-
await openContractCall(function_option);
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
async unstakeFarmingContract( pool_address: string, cycle: number, amount_LP: string, callback: any = null){
|
|
238
|
-
const address = pool_address.split('.');
|
|
239
|
-
const post_condition = [];
|
|
240
|
-
// post_condition.push(await getPostConditionFromAsset(STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), BASE_STSW_DATA().addr, amount_STSW, FungibleConditionCode.Equal));
|
|
241
|
-
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));
|
|
242
|
-
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'unstake-from-farming', [
|
|
243
|
-
uintCV(cycle),
|
|
244
|
-
contractPrincipalCV(address[0],address[1]),
|
|
245
|
-
], post_condition, callback);
|
|
246
|
-
await openContractCall(function_option);
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
async getCurrentFarmingRound() {
|
|
251
|
-
const bh = await this.stackswap.getCurrentBlock();
|
|
252
|
-
return await this.getFarmingRound(bh);
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
async getRewardBalanceFromFarming( pool_addr: string, unclaimed_list: any){
|
|
257
|
-
// let reward_balance = new BigNumber(0);
|
|
258
|
-
const num_list = [];
|
|
259
|
-
for (const unclaimed of unclaimed_list) {
|
|
260
|
-
num_list.push(uintCV(unclaimed));
|
|
261
|
-
}
|
|
262
|
-
const result = await this.getFarmingUserRewardList(pool_addr, num_list)
|
|
263
|
-
// rewardSum.value;
|
|
264
|
-
// console.log(result);
|
|
265
|
-
const reward = numFormat_(num2decimal(result.rewardSum.value, 6));
|
|
266
|
-
// console.log({reward, reward_list, reward_balance});
|
|
267
|
-
return reward;
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
// async getRewardBalanceFromFarming( pool_addr: string, unclaimed_list: any) {
|
|
271
|
-
// // let reward_balance = new BigNumber(0);
|
|
272
|
-
// const num_list = [];
|
|
273
|
-
// for (const unclaimed of unclaimed_list) {
|
|
274
|
-
// num_list.push(uintCV(unclaimed));
|
|
275
|
-
// }
|
|
276
|
-
// let reward_num = new BigNumber(0);
|
|
277
|
-
//
|
|
278
|
-
// try {
|
|
279
|
-
// for (let i = 0; i < num_list.length; i += 8) {
|
|
280
|
-
// // console.log(i, num_list.slice(i, i+4 < num_list.length ? i + 4 : num_list.length));
|
|
281
|
-
// const result = await this.getFarmingUserRewardList(pool_addr, num_list.slice(i, i + 8 < num_list.length ? i + 8 : num_list.length));
|
|
282
|
-
// // rewardSum.value;
|
|
283
|
-
// // console.log('temp result', result);
|
|
284
|
-
// reward_num = reward_num.plus(new BigNumber(result.rewardSum.value));
|
|
285
|
-
// }
|
|
286
|
-
// return numFormat_(num2decimal(reward_num.toString(), 6));
|
|
287
|
-
// } catch (e) {
|
|
288
|
-
// // console.log(e);
|
|
289
|
-
// return numFormat_(num2decimal(reward_num.toString(), 6));
|
|
290
|
-
// }
|
|
291
|
-
// }
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
getFarmingAPR(tvl : string, stsw_price : string){
|
|
295
|
-
if( new BigNumber(tvl) <= new BigNumber(0) ){
|
|
296
|
-
const temp = new BigNumber(671731.200000).multipliedBy(52).multipliedBy(new BigNumber(stsw_price));
|
|
297
|
-
return temp.toFixed(3).toString();
|
|
298
|
-
}else{
|
|
299
|
-
BigNumber.config({ DECIMAL_PLACES: 10});
|
|
300
|
-
// const temp = new BigNumber(671731.200000).multipliedBy(52).div(tvl).multipliedBy(new BigNumber(stsw_price));
|
|
301
|
-
// const my_invest = new BigNumber(1);
|
|
302
|
-
const tvl_bn = new BigNumber(tvl);
|
|
303
|
-
const reward_stx = new BigNumber(671731.2).multipliedBy(new BigNumber(stsw_price));
|
|
304
|
-
// const new_invest = tvl_bn.plus(my_invest);
|
|
305
|
-
const new_reward = reward_stx.div(tvl_bn);
|
|
306
|
-
const new_reward_apr = new_reward.multipliedBy(5200);
|
|
307
|
-
return new_reward_apr.toFixed(3).toString();
|
|
308
|
-
}
|
|
309
|
-
}
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
async getEachFarmData(data: any, type : Mode, callback: any) {
|
|
314
|
-
|
|
315
|
-
const oracle_stsw = (await this.stackswap.lbtcManager.getPrice('STSW'))['last-price'].value;
|
|
316
|
-
const oracle_stx = (await this.stackswap.lbtcManager.getPrice('STX'))['last-price'].value;
|
|
317
|
-
// const oracle_lbtc = (await this.stackswap.lbtcManager.getPrice('lBTC'))['last-price'].value;
|
|
318
|
-
const bh = await this.stackswap.getCurrentBlock();
|
|
319
|
-
|
|
320
|
-
const usd_stx = new BigNumber(oracle_stx).dividedBy(10**6).toNumber();
|
|
321
|
-
const stsw_stx = new BigNumber(oracle_stsw).dividedBy(oracle_stx).toNumber();
|
|
322
|
-
const cur_round = await this.getFarmingRound(bh);
|
|
323
|
-
const farms: any[] = [];
|
|
324
|
-
data.forEach((farm: any) => {
|
|
325
|
-
if (farm.farm_group === 1) {
|
|
326
|
-
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_1();
|
|
327
|
-
} else if (farm.farm_group === 5) {
|
|
328
|
-
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_5();
|
|
329
|
-
}
|
|
330
|
-
farm.round = cur_round;
|
|
331
|
-
this.getFarmData(farm, bh, type, usd_stx, stsw_stx).then(
|
|
332
|
-
(value) => {
|
|
333
|
-
farms.push(value)
|
|
334
|
-
if (farms.length == data.length){
|
|
335
|
-
callback(farms);
|
|
336
|
-
}
|
|
337
|
-
});
|
|
338
|
-
});
|
|
339
|
-
}
|
|
340
|
-
async getFarmData( farm: any, bh: any, type : Mode, usd_stx: any, stsw_stx: any ) {
|
|
341
|
-
farm.valid = false;
|
|
342
|
-
switch (type) {
|
|
343
|
-
case Mode.ONLY_BLOCKCHAIN:
|
|
344
|
-
farm.pair = (await this.stackswap.poolManager.getPairDataFromContract(farm.token_x, farm.token_y));
|
|
345
|
-
break;
|
|
346
|
-
case Mode.WITH_SERVER:
|
|
347
|
-
farm.pair = (await this.stackswap.swapManager.findRouter(farm.token_x, farm.token_y, Number(bh))).pair;
|
|
348
|
-
break;
|
|
349
|
-
}
|
|
350
|
-
// console.log(isMigratable);
|
|
351
|
-
this.getFarmBalance(farm.pair.token_lp).then(farm_total => {
|
|
352
|
-
this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm_total).then(tvl_stx => {
|
|
353
|
-
farm.tvl = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toNumber();
|
|
354
|
-
}
|
|
355
|
-
);
|
|
356
|
-
});
|
|
357
|
-
|
|
358
|
-
this.getFarmingTotalStatusCycle(Number(farm.round)+1).then((value1) =>
|
|
359
|
-
{
|
|
360
|
-
const tvl = new BigNumber(num2decimal(value1,6)).toFixed(3).toString();
|
|
361
|
-
// console.log({tvl});
|
|
362
|
-
if (farm.round > this.stackswap.config.FARM_V1_END_CYCLE()){
|
|
363
|
-
farm.apr = '0'
|
|
364
|
-
} else {
|
|
365
|
-
farm.apr = this.getFarmingAPR(tvl, stsw_stx);
|
|
366
|
-
}
|
|
367
|
-
});
|
|
368
|
-
|
|
369
|
-
return farm;
|
|
370
|
-
// farm.id += 10000;
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
async getFarmUserData(farm : any, usd_stx: any) {
|
|
375
|
-
farm.migratable = false; // migratable true V1 staking 했지만 Migration을 해야함
|
|
376
|
-
farm.isMigratable = await this.stackswap.farm2Manager.isUserMigratable2(farm.pair.token_lp.addr, farm.farm_contract); // 신규는 무조건 true
|
|
377
|
-
const status = await this.getFarmingStakerStatus(farm.pair.token_lp.addr, Number(farm.round))
|
|
378
|
-
// console.log('get farming staker status', status);
|
|
379
|
-
farm.claimable_list = status.unclaimedList;
|
|
380
|
-
farm.pooled_stsw = status.pooledToken;
|
|
381
|
-
farm.stakedList = status.stakedList;
|
|
382
|
-
for (const stakedListElement of status.stakedList) {
|
|
383
|
-
// console.log(stakedListElement);
|
|
384
|
-
if (stakedListElement > this.stackswap.config.FARM_V1_END_CYCLE() && farm.isMigratable) {
|
|
385
|
-
farm.migratable = true;
|
|
386
|
-
}
|
|
387
|
-
// unstakedList is for unstake from ended farm
|
|
388
|
-
if (farm.unstakedList) {
|
|
389
|
-
farm.unstakedList.push(stakedListElement);
|
|
390
|
-
} else {
|
|
391
|
-
farm.unstakedList = [];
|
|
392
|
-
farm.unstakedList.push(stakedListElement);
|
|
393
|
-
}
|
|
394
|
-
}
|
|
395
|
-
const tvl_stx = await this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm.pooled_stsw);
|
|
396
|
-
farm.user_TVL = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toFixed(3).toString();
|
|
397
|
-
return farm;
|
|
398
|
-
}
|
|
399
|
-
}
|
|
1
|
+
|
|
2
|
+
import {
|
|
3
|
+
callReadOnlyFunction,
|
|
4
|
+
contractPrincipalCV,
|
|
5
|
+
cvToValue, FungibleConditionCode,
|
|
6
|
+
listCV,
|
|
7
|
+
standardPrincipalCV,
|
|
8
|
+
uintCV
|
|
9
|
+
} from '@stacks/transactions';
|
|
10
|
+
import BigNumber from 'bignumber.js';
|
|
11
|
+
import {openContractCall} from '@stacks/connect';
|
|
12
|
+
import {getPostConditionFromAsset, getReadOptions, getWriteOptions, num2decimal, numFormat_} from "../util";
|
|
13
|
+
import {StackswapAPI} from "../../index";
|
|
14
|
+
import {LiquidityPool} from "./pool.manager";
|
|
15
|
+
import {Mode} from "./farm2.manager";
|
|
16
|
+
|
|
17
|
+
export class Farm {
|
|
18
|
+
pool : LiquidityPool;
|
|
19
|
+
locked_token : string;
|
|
20
|
+
TVL : string;
|
|
21
|
+
APR : string;
|
|
22
|
+
in_contract : string;
|
|
23
|
+
cur_round: number;
|
|
24
|
+
|
|
25
|
+
constructor(pool: LiquidityPool, locked_token: string, TVL : string, APR: string, in_contract : string, cur_round : number) {
|
|
26
|
+
this.pool = pool;
|
|
27
|
+
this.locked_token = locked_token;
|
|
28
|
+
this.TVL = TVL;
|
|
29
|
+
this.APR = APR;
|
|
30
|
+
this.in_contract = in_contract;
|
|
31
|
+
this.cur_round = cur_round;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
export class FarmManager {
|
|
38
|
+
stackswap: StackswapAPI;
|
|
39
|
+
|
|
40
|
+
constructor(stackswap: StackswapAPI) {
|
|
41
|
+
this.stackswap = stackswap;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
async getFarmingRound(bh: number | string){
|
|
46
|
+
try{
|
|
47
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-reward-cycle', [
|
|
48
|
+
uintCV(bh)
|
|
49
|
+
]);
|
|
50
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
51
|
+
const result = cvToValue(result_raw);
|
|
52
|
+
return result.value;
|
|
53
|
+
} catch (e) {
|
|
54
|
+
return 0;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
async getFarmingRoundFirstBlock( cycle: number){
|
|
59
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-first-stacks-block-in-reward-cycle', [
|
|
60
|
+
uintCV(cycle)
|
|
61
|
+
]);
|
|
62
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
63
|
+
const result = cvToValue(result_raw);
|
|
64
|
+
// console.log(result);
|
|
65
|
+
return result;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
async getFarmingStakerStatus( pool_address: string, cur_round: number){
|
|
69
|
+
const address = pool_address.split('.');
|
|
70
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker', [
|
|
71
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
72
|
+
contractPrincipalCV(address[0],address[1]),
|
|
73
|
+
]);
|
|
74
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
75
|
+
const result = cvToValue(result_raw);
|
|
76
|
+
try{
|
|
77
|
+
// console.log('getFarmingStakerStatus', result);
|
|
78
|
+
const pooledToken = result.value.amountUstx.value;
|
|
79
|
+
const unclaimedList = [];
|
|
80
|
+
const stakedList = []
|
|
81
|
+
for (const unclaimedElement of result.value.unclaimedList.value) {
|
|
82
|
+
if( unclaimedElement.value < cur_round && unclaimedElement.value <= this.stackswap.config.FARM_V1_END_CYCLE()){
|
|
83
|
+
unclaimedList.push(unclaimedElement.value);
|
|
84
|
+
}
|
|
85
|
+
stakedList.push(unclaimedElement.value);
|
|
86
|
+
}
|
|
87
|
+
return {pooledToken, unclaimedList, stakedList}
|
|
88
|
+
} catch (e) {
|
|
89
|
+
// console.log(e);
|
|
90
|
+
return {pooledToken: 0, unclaimedList: [], stakedList: []}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
async getFarmBalance( token: any) {
|
|
96
|
+
// console.log("getBalance", token)
|
|
97
|
+
const pair_details_options : any = getReadOptions(this.stackswap, token.addr, 'get-balance',
|
|
98
|
+
[contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING()) ]);
|
|
99
|
+
try {
|
|
100
|
+
const result = await callReadOnlyFunction(pair_details_options);
|
|
101
|
+
return cvToValue(result).value;
|
|
102
|
+
} catch (e) {
|
|
103
|
+
return 0;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
async getPoolSTXPriceFarm(pair: any ,token_x: any, token_y: any, farm_total: any){
|
|
108
|
+
// BigNumber.config({ DECIMAL_PLACES: 6});
|
|
109
|
+
const x_token_addr = token_x.addr;
|
|
110
|
+
// console.log(token_x.addr);
|
|
111
|
+
const y_token_addr = token_y.addr;
|
|
112
|
+
// console.log(token_y.addr);
|
|
113
|
+
let total_balacne = new BigNumber(-1);
|
|
114
|
+
if(x_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr){
|
|
115
|
+
total_balacne = (new BigNumber(pair.balance_x).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_x.decimal))).multipliedBy(2);
|
|
116
|
+
}else if(y_token_addr === this.stackswap.config.BASE_WSTX_DATA().addr){
|
|
117
|
+
total_balacne = (new BigNumber(pair.balance_y).multipliedBy(farm_total).dividedBy(pair.share_total).dividedBy(new BigNumber(10 ** token_y.decimal))).multipliedBy(2);
|
|
118
|
+
}
|
|
119
|
+
// console.log('pool_stx_price', token_x.addr, token_y.addr,token_x.balance, token_y.balance,total_balacne.toNumber());
|
|
120
|
+
// console.log(pair["balance-x"].value, pair["balance-y"].value, total_balacne.toNumber());
|
|
121
|
+
return total_balacne;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
async getFarmingTotalStatusCycle( cycle: number){
|
|
125
|
+
// console.log(cycle);
|
|
126
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-stats-at-cycle', [
|
|
127
|
+
uintCV(cycle),
|
|
128
|
+
]);
|
|
129
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
130
|
+
const result = cvToValue(result_raw);
|
|
131
|
+
// console.log(result.value.amountUstx.value);
|
|
132
|
+
try{
|
|
133
|
+
return new BigNumber(result.value.amountUstx.value).multipliedBy(2).toFixed(0).toString();
|
|
134
|
+
} catch (e) {
|
|
135
|
+
return '0';
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
async getFarmingTotalValue( pool_address: string){
|
|
140
|
+
try{
|
|
141
|
+
const address = pool_address.split('.');
|
|
142
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farm-info', [
|
|
143
|
+
contractPrincipalCV(address[0],address[1]),
|
|
144
|
+
]);
|
|
145
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
146
|
+
const result = cvToValue(result_raw);
|
|
147
|
+
// console.log('get_farming_total',result.value);
|
|
148
|
+
return result.value;
|
|
149
|
+
} catch (e) {
|
|
150
|
+
return 0;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
|
|
155
|
+
async getFarmingUserRewardPerCycle( pool_address: string, cycle: number){
|
|
156
|
+
const address = pool_address.split('.');
|
|
157
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staking-reward-per-user', [
|
|
158
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
159
|
+
contractPrincipalCV(address[0],address[1]),
|
|
160
|
+
uintCV(cycle),
|
|
161
|
+
]);
|
|
162
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
163
|
+
const result = cvToValue(result_raw);
|
|
164
|
+
// console.log(result_raw);
|
|
165
|
+
return result;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
async getFarmingUserRewardTotal( pool_address: string){
|
|
169
|
+
const address = pool_address.split('.');
|
|
170
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-total', [
|
|
171
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
172
|
+
contractPrincipalCV(address[0],address[1]),
|
|
173
|
+
]);
|
|
174
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
175
|
+
const result = cvToValue(result_raw);
|
|
176
|
+
// console.log('getFarmingUserRewardTotal', result);
|
|
177
|
+
return result;
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
|
|
181
|
+
async getFarmingUserRewardList( pool_address: string, unclaimed_list: any){
|
|
182
|
+
const address = pool_address.split('.');
|
|
183
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-farming-reward-from-list', [
|
|
184
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
185
|
+
contractPrincipalCV(address[0],address[1]),
|
|
186
|
+
listCV(unclaimed_list),
|
|
187
|
+
]);
|
|
188
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
189
|
+
const result = cvToValue(result_raw);
|
|
190
|
+
// console.log('getFarmingUserRewardTotal', result);
|
|
191
|
+
return result;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
async getFarmingRewardInfo( pool_address: string, cycle: number){
|
|
195
|
+
const address = pool_address.split('.');
|
|
196
|
+
const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'get-staker-at-cycle', [
|
|
197
|
+
uintCV(cycle),
|
|
198
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
199
|
+
contractPrincipalCV(address[0],address[1]),
|
|
200
|
+
]);
|
|
201
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
202
|
+
try{
|
|
203
|
+
const result = cvToValue(result_raw);
|
|
204
|
+
// console.log(result);
|
|
205
|
+
return result.value.toReturn.value;
|
|
206
|
+
} catch (e) {
|
|
207
|
+
return '0';
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
|
|
212
|
+
async stakeFarmingContract( pool_address: string, amountTokens: string, lockPeriod: number, callback: any = null){
|
|
213
|
+
const address = pool_address.split('.');
|
|
214
|
+
// console.log(amountTokens);
|
|
215
|
+
const amount = new BigNumber(amountTokens).multipliedBy(10 ** 6).toFixed(0).toString();
|
|
216
|
+
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'stake-tokens', [
|
|
217
|
+
uintCV(amount),
|
|
218
|
+
contractPrincipalCV(address[0],address[1]),
|
|
219
|
+
uintCV(lockPeriod),
|
|
220
|
+
],[await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), pool_address, amount, FungibleConditionCode.Equal)], callback);
|
|
221
|
+
await openContractCall(function_option);
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
async claimFarmingContract( pool_address: string, cycle: number, amount_STSW: string, amount_LP: string, callback: any = null){
|
|
225
|
+
const address = pool_address.split('.');
|
|
226
|
+
const post_condition = [];
|
|
227
|
+
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));
|
|
228
|
+
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));
|
|
229
|
+
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'claim-staking-reward', [
|
|
230
|
+
uintCV(cycle),
|
|
231
|
+
contractPrincipalCV(address[0],address[1]),
|
|
232
|
+
], post_condition, callback);
|
|
233
|
+
await openContractCall(function_option);
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
|
|
237
|
+
async unstakeFarmingContract( pool_address: string, cycle: number, amount_LP: string, callback: any = null){
|
|
238
|
+
const address = pool_address.split('.');
|
|
239
|
+
const post_condition = [];
|
|
240
|
+
// post_condition.push(await getPostConditionFromAsset(STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), BASE_STSW_DATA().addr, amount_STSW, FungibleConditionCode.Equal));
|
|
241
|
+
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));
|
|
242
|
+
const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING(), 'unstake-from-farming', [
|
|
243
|
+
uintCV(cycle),
|
|
244
|
+
contractPrincipalCV(address[0],address[1]),
|
|
245
|
+
], post_condition, callback);
|
|
246
|
+
await openContractCall(function_option);
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
|
|
250
|
+
async getCurrentFarmingRound() {
|
|
251
|
+
const bh = await this.stackswap.getCurrentBlock();
|
|
252
|
+
return await this.getFarmingRound(bh);
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
|
|
256
|
+
async getRewardBalanceFromFarming( pool_addr: string, unclaimed_list: any){
|
|
257
|
+
// let reward_balance = new BigNumber(0);
|
|
258
|
+
const num_list = [];
|
|
259
|
+
for (const unclaimed of unclaimed_list) {
|
|
260
|
+
num_list.push(uintCV(unclaimed));
|
|
261
|
+
}
|
|
262
|
+
const result = await this.getFarmingUserRewardList(pool_addr, num_list)
|
|
263
|
+
// rewardSum.value;
|
|
264
|
+
// console.log(result);
|
|
265
|
+
const reward = numFormat_(num2decimal(result.rewardSum.value, 6));
|
|
266
|
+
// console.log({reward, reward_list, reward_balance});
|
|
267
|
+
return reward;
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
// async getRewardBalanceFromFarming( pool_addr: string, unclaimed_list: any) {
|
|
271
|
+
// // let reward_balance = new BigNumber(0);
|
|
272
|
+
// const num_list = [];
|
|
273
|
+
// for (const unclaimed of unclaimed_list) {
|
|
274
|
+
// num_list.push(uintCV(unclaimed));
|
|
275
|
+
// }
|
|
276
|
+
// let reward_num = new BigNumber(0);
|
|
277
|
+
//
|
|
278
|
+
// try {
|
|
279
|
+
// for (let i = 0; i < num_list.length; i += 8) {
|
|
280
|
+
// // console.log(i, num_list.slice(i, i+4 < num_list.length ? i + 4 : num_list.length));
|
|
281
|
+
// const result = await this.getFarmingUserRewardList(pool_addr, num_list.slice(i, i + 8 < num_list.length ? i + 8 : num_list.length));
|
|
282
|
+
// // rewardSum.value;
|
|
283
|
+
// // console.log('temp result', result);
|
|
284
|
+
// reward_num = reward_num.plus(new BigNumber(result.rewardSum.value));
|
|
285
|
+
// }
|
|
286
|
+
// return numFormat_(num2decimal(reward_num.toString(), 6));
|
|
287
|
+
// } catch (e) {
|
|
288
|
+
// // console.log(e);
|
|
289
|
+
// return numFormat_(num2decimal(reward_num.toString(), 6));
|
|
290
|
+
// }
|
|
291
|
+
// }
|
|
292
|
+
|
|
293
|
+
|
|
294
|
+
getFarmingAPR(tvl : string, stsw_price : string){
|
|
295
|
+
if( new BigNumber(tvl) <= new BigNumber(0) ){
|
|
296
|
+
const temp = new BigNumber(671731.200000).multipliedBy(52).multipliedBy(new BigNumber(stsw_price));
|
|
297
|
+
return temp.toFixed(3).toString();
|
|
298
|
+
}else{
|
|
299
|
+
BigNumber.config({ DECIMAL_PLACES: 10});
|
|
300
|
+
// const temp = new BigNumber(671731.200000).multipliedBy(52).div(tvl).multipliedBy(new BigNumber(stsw_price));
|
|
301
|
+
// const my_invest = new BigNumber(1);
|
|
302
|
+
const tvl_bn = new BigNumber(tvl);
|
|
303
|
+
const reward_stx = new BigNumber(671731.2).multipliedBy(new BigNumber(stsw_price));
|
|
304
|
+
// const new_invest = tvl_bn.plus(my_invest);
|
|
305
|
+
const new_reward = reward_stx.div(tvl_bn);
|
|
306
|
+
const new_reward_apr = new_reward.multipliedBy(5200);
|
|
307
|
+
return new_reward_apr.toFixed(3).toString();
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
|
|
312
|
+
|
|
313
|
+
async getEachFarmData(data: any, type : Mode, callback: any) {
|
|
314
|
+
|
|
315
|
+
const oracle_stsw = (await this.stackswap.lbtcManager.getPrice('STSW'))['last-price'].value;
|
|
316
|
+
const oracle_stx = (await this.stackswap.lbtcManager.getPrice('STX'))['last-price'].value;
|
|
317
|
+
// const oracle_lbtc = (await this.stackswap.lbtcManager.getPrice('lBTC'))['last-price'].value;
|
|
318
|
+
const bh = await this.stackswap.getCurrentBlock();
|
|
319
|
+
|
|
320
|
+
const usd_stx = new BigNumber(oracle_stx).dividedBy(10**6).toNumber();
|
|
321
|
+
const stsw_stx = new BigNumber(oracle_stsw).dividedBy(oracle_stx).toNumber();
|
|
322
|
+
const cur_round = await this.getFarmingRound(bh);
|
|
323
|
+
const farms: any[] = [];
|
|
324
|
+
data.forEach((farm: any) => {
|
|
325
|
+
if (farm.farm_group === 1) {
|
|
326
|
+
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_1();
|
|
327
|
+
} else if (farm.farm_group === 5) {
|
|
328
|
+
farm.farm_contract = this.stackswap.config.CONTRACT_NAME_STACKSWAP_FARMING2_5();
|
|
329
|
+
}
|
|
330
|
+
farm.round = cur_round;
|
|
331
|
+
this.getFarmData(farm, bh, type, usd_stx, stsw_stx).then(
|
|
332
|
+
(value) => {
|
|
333
|
+
farms.push(value)
|
|
334
|
+
if (farms.length == data.length){
|
|
335
|
+
callback(farms);
|
|
336
|
+
}
|
|
337
|
+
});
|
|
338
|
+
});
|
|
339
|
+
}
|
|
340
|
+
async getFarmData( farm: any, bh: any, type : Mode, usd_stx: any, stsw_stx: any ) {
|
|
341
|
+
farm.valid = false;
|
|
342
|
+
switch (type) {
|
|
343
|
+
case Mode.ONLY_BLOCKCHAIN:
|
|
344
|
+
farm.pair = (await this.stackswap.poolManager.getPairDataFromContract(farm.token_x, farm.token_y));
|
|
345
|
+
break;
|
|
346
|
+
case Mode.WITH_SERVER:
|
|
347
|
+
farm.pair = (await this.stackswap.swapManager.findRouter(farm.token_x, farm.token_y, Number(bh))).pair;
|
|
348
|
+
break;
|
|
349
|
+
}
|
|
350
|
+
// console.log(isMigratable);
|
|
351
|
+
this.getFarmBalance(farm.pair.token_lp).then(farm_total => {
|
|
352
|
+
this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm_total).then(tvl_stx => {
|
|
353
|
+
farm.tvl = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toNumber();
|
|
354
|
+
}
|
|
355
|
+
);
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
this.getFarmingTotalStatusCycle(Number(farm.round)+1).then((value1) =>
|
|
359
|
+
{
|
|
360
|
+
const tvl = new BigNumber(num2decimal(value1,6)).toFixed(3).toString();
|
|
361
|
+
// console.log({tvl});
|
|
362
|
+
if (farm.round > this.stackswap.config.FARM_V1_END_CYCLE()){
|
|
363
|
+
farm.apr = '0'
|
|
364
|
+
} else {
|
|
365
|
+
farm.apr = this.getFarmingAPR(tvl, stsw_stx);
|
|
366
|
+
}
|
|
367
|
+
});
|
|
368
|
+
|
|
369
|
+
return farm;
|
|
370
|
+
// farm.id += 10000;
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
|
|
374
|
+
async getFarmUserData(farm : any, usd_stx: any) {
|
|
375
|
+
farm.migratable = false; // migratable true V1 staking 했지만 Migration을 해야함
|
|
376
|
+
farm.isMigratable = await this.stackswap.farm2Manager.isUserMigratable2(farm.pair.token_lp.addr, farm.farm_contract); // 신규는 무조건 true
|
|
377
|
+
const status = await this.getFarmingStakerStatus(farm.pair.token_lp.addr, Number(farm.round))
|
|
378
|
+
// console.log('get farming staker status', status);
|
|
379
|
+
farm.claimable_list = status.unclaimedList;
|
|
380
|
+
farm.pooled_stsw = status.pooledToken;
|
|
381
|
+
farm.stakedList = status.stakedList;
|
|
382
|
+
for (const stakedListElement of status.stakedList) {
|
|
383
|
+
// console.log(stakedListElement);
|
|
384
|
+
if (stakedListElement > this.stackswap.config.FARM_V1_END_CYCLE() && farm.isMigratable) {
|
|
385
|
+
farm.migratable = true;
|
|
386
|
+
}
|
|
387
|
+
// unstakedList is for unstake from ended farm
|
|
388
|
+
if (farm.unstakedList) {
|
|
389
|
+
farm.unstakedList.push(stakedListElement);
|
|
390
|
+
} else {
|
|
391
|
+
farm.unstakedList = [];
|
|
392
|
+
farm.unstakedList.push(stakedListElement);
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
const tvl_stx = await this.getPoolSTXPriceFarm(farm.pair, farm.token_x, farm.token_y, farm.pooled_stsw);
|
|
396
|
+
farm.user_TVL = tvl_stx.multipliedBy(new BigNumber(usd_stx)).toFixed(3).toString();
|
|
397
|
+
return farm;
|
|
398
|
+
}
|
|
399
|
+
}
|