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.
Files changed (94) hide show
  1. package/README.md +10 -10
  2. package/dist/esm/index.d.ts +86 -86
  3. package/dist/esm/index.js +145 -145
  4. package/dist/esm/stackswap/config.d.ts +117 -117
  5. package/dist/esm/stackswap/config.js +194 -194
  6. package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
  7. package/dist/esm/stackswap/manager/farm.manager.js +293 -293
  8. package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
  9. package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
  10. package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
  11. package/dist/esm/stackswap/manager/governance.manager.js +53 -53
  12. package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
  13. package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
  14. package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
  15. package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
  16. package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
  17. package/dist/esm/stackswap/manager/lbtcstaking.manager.js +191 -191
  18. package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
  19. package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
  20. package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
  21. package/dist/esm/stackswap/manager/nft.manager.js +243 -243
  22. package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
  23. package/dist/esm/stackswap/manager/operator.manager.js +85 -85
  24. package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
  25. package/dist/esm/stackswap/manager/other.manager.js +47 -47
  26. package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
  27. package/dist/esm/stackswap/manager/pool.manager.js +171 -171
  28. package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
  29. package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
  30. package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
  31. package/dist/esm/stackswap/manager/staking.manager.js +233 -233
  32. package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
  33. package/dist/esm/stackswap/manager/swap.manager.js +332 -332
  34. package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
  35. package/dist/esm/stackswap/manager/token.manager.js +133 -133
  36. package/dist/esm/stackswap/util.d.ts +35 -35
  37. package/dist/esm/stackswap/util.js +201 -201
  38. package/dist/esm/stackswap/util.js.map +1 -1
  39. package/dist/index.d.ts +86 -86
  40. package/dist/index.js +154 -154
  41. package/dist/index.umd.js +1 -1
  42. package/dist/stackswap/config.d.ts +117 -117
  43. package/dist/stackswap/config.js +199 -199
  44. package/dist/stackswap/manager/farm.manager.d.ts +41 -41
  45. package/dist/stackswap/manager/farm.manager.js +301 -301
  46. package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
  47. package/dist/stackswap/manager/farm2.manager.js +410 -410
  48. package/dist/stackswap/manager/governance.manager.d.ts +9 -9
  49. package/dist/stackswap/manager/governance.manager.js +60 -60
  50. package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
  51. package/dist/stackswap/manager/launchpad.manager.js +151 -151
  52. package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
  53. package/dist/stackswap/manager/lbtc.manager.js +333 -333
  54. package/dist/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
  55. package/dist/stackswap/manager/lbtcstaking.manager.js +198 -198
  56. package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
  57. package/dist/stackswap/manager/multisig.manager.js +55 -55
  58. package/dist/stackswap/manager/nft.manager.d.ts +52 -52
  59. package/dist/stackswap/manager/nft.manager.js +250 -250
  60. package/dist/stackswap/manager/operator.manager.d.ts +17 -17
  61. package/dist/stackswap/manager/operator.manager.js +92 -92
  62. package/dist/stackswap/manager/other.manager.d.ts +9 -9
  63. package/dist/stackswap/manager/other.manager.js +54 -54
  64. package/dist/stackswap/manager/pool.manager.d.ts +34 -34
  65. package/dist/stackswap/manager/pool.manager.js +179 -179
  66. package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
  67. package/dist/stackswap/manager/poxl.manager.js +78 -78
  68. package/dist/stackswap/manager/staking.manager.d.ts +25 -25
  69. package/dist/stackswap/manager/staking.manager.js +240 -240
  70. package/dist/stackswap/manager/swap.manager.d.ts +39 -39
  71. package/dist/stackswap/manager/swap.manager.js +339 -339
  72. package/dist/stackswap/manager/token.manager.d.ts +31 -31
  73. package/dist/stackswap/manager/token.manager.js +141 -141
  74. package/dist/stackswap/util.d.ts +35 -35
  75. package/dist/stackswap/util.js +218 -218
  76. package/dist/stackswap/util.js.map +1 -1
  77. package/package.json +43 -43
  78. package/src/index.ts +207 -207
  79. package/src/stackswap/config.ts +305 -305
  80. package/src/stackswap/manager/farm.manager.ts +399 -399
  81. package/src/stackswap/manager/farm2.manager.ts +463 -463
  82. package/src/stackswap/manager/governance.manager.ts +95 -95
  83. package/src/stackswap/manager/launchpad.manager.ts +190 -190
  84. package/src/stackswap/manager/lbtcstaking.manager.ts +277 -277
  85. package/src/stackswap/manager/multisig.manager.ts +87 -87
  86. package/src/stackswap/manager/nft.manager.ts +307 -307
  87. package/src/stackswap/manager/operator.manager.ts +123 -123
  88. package/src/stackswap/manager/other.manager.ts +71 -71
  89. package/src/stackswap/manager/pool.manager.ts +202 -202
  90. package/src/stackswap/manager/poxl.manager.ts +99 -99
  91. package/src/stackswap/manager/staking.manager.ts +321 -321
  92. package/src/stackswap/manager/swap.manager.ts +392 -392
  93. package/src/stackswap/manager/token.manager.ts +167 -167
  94. package/src/stackswap/util.ts +237 -237
@@ -1,321 +1,321 @@
1
-
2
- import {
3
- callReadOnlyFunction,
4
- contractPrincipalCV,
5
- cvToValue,
6
- FungibleConditionCode, listCV,
7
- standardPrincipalCV,
8
- uintCV
9
- } from "@stacks/transactions";
10
- import axios from "axios";
11
- import {openContractCall} from "@stacks/connect";
12
- import BigNumber from "bignumber.js";
13
- import {getPostConditionFromAsset, getReadOptions, getWriteOptions} from "../util";
14
- import {StackswapAPI} from "../../index";
15
-
16
- export class StakingManager {
17
- stackswap: StackswapAPI;
18
-
19
- constructor(stackswap: StackswapAPI) {
20
- this.stackswap = stackswap;
21
- }
22
-
23
- async getStackingRoundFirstBlock(cycle: number){
24
- const function_option = getReadOptions(this.stackswap,
25
- this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
26
- 'get-first-stacks-block-in-reward-cycle', [
27
- uintCV(cycle)
28
- ]);
29
- const result_raw = await callReadOnlyFunction(function_option);
30
- const result = cvToValue(result_raw);
31
- return result;
32
- }
33
-
34
- async getStakingSTSWBalance(source: any) {
35
- // console.log('getStakingSTSWBalance');
36
- const pair_details_options : any = getReadOptions(source, this.stackswap.config.BASE_STSW_DATA().addr, 'get-balance',
37
- [contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(),this.stackswap.config.BASE_vSTSW_DATA().addr.split('.')[1])]);
38
- try {
39
- const result = await callReadOnlyFunction(pair_details_options);
40
- // console.log(cvToValue(result));
41
- return cvToValue(result).value;
42
- } catch (e) {
43
- // console.log(e);
44
- return 0;
45
- }
46
- // console.log(pair_details_result)
47
- }
48
-
49
- async getRewardRoundID_V2(source: any) {
50
- try{
51
- const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
52
- const round = Number(await this.getCurrentStakingRound(ADDR));
53
- const options : any = getReadOptions(source, this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(), 'get-staker', [
54
- standardPrincipalCV(this.stackswap.getSenderAddress()),
55
- ]);
56
- const result = await callReadOnlyFunction(options);
57
- // console.log('reward', round, cvToValue(result));
58
-
59
- const unclaimedList = [];
60
- for (const unclaimedElement of cvToValue(result).value) {
61
- // console.log('reward',unclaimedElement.value);
62
- if (unclaimedElement.value < round) {
63
- unclaimedList.push(unclaimedElement.value);
64
- }
65
- }
66
- // console.log('reward',unclaimedList);
67
-
68
- return unclaimedList;
69
- } catch (e) {
70
- return [];
71
- }
72
- }
73
-
74
- async getStakingRound(contract_address: string, block: number | string) {
75
- try{
76
- // const poxl_token = contract_address.split('.');
77
- const options = getReadOptions(this.stackswap, contract_address, 'get-reward-cycle', [
78
- uintCV(block),
79
- ]);
80
- const result = await callReadOnlyFunction(options);
81
- // console.log(cvToValue(result));
82
- return cvToValue(result).value;
83
- } catch (e) {
84
- return 0;
85
- }
86
- }
87
-
88
- async getCurrentStakingRound(contract_address: string) {
89
- const bh = await this.stackswap.getCurrentBlock();
90
- return await this.getStakingRound(contract_address, bh);
91
- }
92
-
93
- async getRewardRoundID(offset: number) {
94
- const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
95
- const get_result = await axios.get(this.stackswap.config.STACKS_API_URL() + '/extended/v1/address/' + this.stackswap.getSenderAddress() + '/transactions', {
96
- params: {
97
- limit: 50,
98
- offset,
99
- },
100
- });
101
-
102
- // const total = get_result.data.total;
103
- const results = get_result.data.results;
104
-
105
- const reward_id: number[] = [];
106
- for (const item of results) {
107
- if ('contract_call' in item) {
108
- if (ADDR === item.contract_call.contract_id &&
109
- item.contract_call.function_name === 'stake-tokens' &&
110
- item.tx_status === 'success') {
111
- const tx_block_number = item.block_height;
112
- let start_round = await this.getStakingRound(ADDR, tx_block_number);
113
- // tslint:disable-next-line:radix
114
- start_round = parseInt(start_round) + 1;
115
- const end_round = start_round + Number(item.contract_call.function_args[1].repr.replace('u','')) - 1;
116
- const round_list = this.range_number(start_round, end_round)
117
- reward_id.push(...round_list)
118
- }
119
- }
120
- }
121
- return Array.from(new Set(reward_id)).sort((a, b) => { return a - b;});
122
- }
123
-
124
-
125
- range_number(start:number, end:number) {
126
- // tslint:disable-next-line:prefer-const
127
- let ans: number[] = [];
128
- for (let i = start; i <= end; i++) {
129
- ans.push(i);
130
- }
131
- return ans;
132
- }
133
-
134
- async getReward(contract_addr:string, round_id:number){
135
- contract_addr = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
136
- const function_option : any = getReadOptions(this.stackswap,
137
- contract_addr,
138
- 'get-staking-reward-per-user', [
139
- standardPrincipalCV(this.stackswap.getSenderAddress()),
140
- uintCV(round_id)
141
- ]);
142
- const result_raw = await callReadOnlyFunction(function_option);
143
- const result = cvToValue(result_raw);
144
- // console.log("reward", round_id, result, result_raw)
145
- return Number(result);
146
- }
147
-
148
- async txClaimReward(round_id: number, stsw_amount: string, callback : any = null){
149
- const post_condition = [ await getPostConditionFromAsset(this.stackswap,
150
- this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
151
- this.stackswap.config.BASE_STSW_DATA().addr, stsw_amount, FungibleConditionCode.Equal)];
152
- const function_option : any = getWriteOptions(
153
- this.stackswap,
154
- this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
155
- 'claim-staking-reward',
156
- [uintCV(round_id)], post_condition, callback);
157
- await openContractCall(function_option);
158
- }
159
-
160
-
161
- async getUserCountFromVSTSW(){
162
- const address = this.stackswap.config.BASE_vSTSW_DATA().addr.split('.');
163
- address[0], address[1];
164
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr,
165
- 'get-user-count',[standardPrincipalCV(this.stackswap.getSenderAddress()) ]);
166
- const result_raw = await callReadOnlyFunction(function_option);
167
- const result = cvToValue(result_raw);
168
- if(result == null){return 0}
169
- // tslint:disable-next-line:radix
170
- else{return parseInt(result.value.idx.value)}
171
- }
172
-
173
- async getStakingBalanceFromVSTSW_V2(){
174
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr,'get-user-count',[standardPrincipalCV(this.stackswap.getSenderAddress()) ]);
175
- const result_raw = await callReadOnlyFunction(function_option);
176
- const result = cvToValue(result_raw);
177
- // console.log("V2", result)
178
- if(result == null){return 0}
179
- else{return new BigNumber(result.value.stakedSTX.value).dividedBy(new BigNumber(10).exponentiatedBy(this.stackswap.config.BASE_vSTSW_DATA().decimal))}
180
- }
181
-
182
- async getClaimRewardListFromVSTSW(){
183
- // tslint:disable-next-line:prefer-const
184
- let res_dict : any = {};
185
-
186
- // tslint:disable-next-line:prefer-const
187
- let id_list: any = [];
188
-
189
- const count = await this.getUserCountFromVSTSW();
190
- for (let i = 1; i <= count; i++) {
191
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr,
192
- 'get-user-info',[
193
- standardPrincipalCV(this.stackswap.getSenderAddress()),
194
- uintCV(i)]
195
- );
196
- const result_raw = await callReadOnlyFunction(function_option);
197
- const result = cvToValue(result_raw);
198
- if ( !result.value.returned.value ){
199
- res_dict[i] = result;
200
- id_list.push(i);
201
- // console.log(result);
202
- }
203
- }
204
- return [id_list, res_dict];
205
- }
206
- // get-user-count () user address
207
- async getStakingBalanceFromVSTSW(){
208
- let staking_balance = 0;
209
- const count = await this.getUserCountFromVSTSW();
210
- for (let i = 1; i <= count; i++) {
211
- const function_option : any = getReadOptions( this.stackswap,
212
- this.stackswap.config.BASE_vSTSW_DATA().addr,'get-user-info',[
213
- standardPrincipalCV(this.stackswap.getSenderAddress()),
214
- uintCV(i)]
215
- );
216
- const result_raw = await callReadOnlyFunction(function_option);
217
- const result = cvToValue(result_raw);
218
- if(result.value.returned.value === false){
219
- // tslint:disable-next-line:radix
220
- staking_balance += parseInt(result.value.amountSTSW.value)
221
- }
222
- }
223
- return staking_balance;
224
- }
225
-
226
-
227
- async txStakeFromStaking(invest_amt:number, period_month:number, callback : any = null){
228
- const invest_amt_bn = new BigNumber(10**6).multipliedBy(invest_amt).toFixed(0).toString();
229
- const postConditions = [];
230
- postConditions.push(await getPostConditionFromAsset( this.stackswap,
231
- this.stackswap.getSenderAddress(),
232
- this.stackswap.config.BASE_STSW_DATA().addr,
233
- invest_amt_bn,
234
- FungibleConditionCode.Equal)
235
- );
236
-
237
- const function_option : any = getWriteOptions(this.stackswap,
238
- this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
239
- 'stake-tokens',[
240
- uintCV(invest_amt_bn),uintCV(period_month)],
241
- postConditions, callback
242
- );
243
- await openContractCall(function_option);
244
- }
245
-
246
- async txCooldownFromVSTSW(index:number, callback : any = null){
247
- const function_option : any = getWriteOptions(this.stackswap,
248
- this.stackswap.config.BASE_vSTSW_DATA().addr,
249
- 'unstake-tokens', [uintCV(index)], [], callback);
250
- await openContractCall(function_option);
251
- }
252
-
253
-
254
- async txUnstakingFromVSTSW(index:number, amountSTX:string, amountvSTX:string, callback : any = null){
255
- // console.log("Unstaking", amountSTX)
256
- const post_conditions = [];
257
- post_conditions.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_vSTSW_DATA().addr,amountvSTX, FungibleConditionCode.Equal))
258
- post_conditions.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr, this.stackswap.config.BASE_STSW_DATA().addr, amountSTX, FungibleConditionCode.Equal))
259
- const function_option : any = getWriteOptions(
260
- this.stackswap,
261
- this.stackswap.config.BASE_vSTSW_DATA().addr,
262
- 'reclaim-tokens',
263
- [uintCV(index)], post_conditions, callback
264
- );
265
- await openContractCall(function_option);
266
- }
267
-
268
- async getRewardBalanceFromStaking(){
269
- const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
270
- let reward_balance = 0;
271
- const current_round = await this.getCurrentStakingRound(ADDR);
272
- // console.log(current_round)
273
- for (let i = 0; i <= current_round; i++) {
274
-
275
- const result = await this.getReward( ADDR, i);
276
- reward_balance += result;
277
- // return result;
278
- }
279
- return reward_balance;
280
- }
281
- async getRewardBalanceFromStakingFromList(unclaimed_list: any){
282
- const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
283
- let reward_balance = 0;
284
- const current_round = await this.getCurrentStakingRound(ADDR);
285
- // console.log(current_round)
286
- const temp = [];
287
- for (const unclaimed of unclaimed_list) {
288
- if ( unclaimed < Number(current_round) ) {
289
- temp.push(uintCV(unclaimed));
290
- }
291
- }
292
- for (let i = 0; i <= current_round; i++) {
293
-
294
- const result = await this.getReward(ADDR, i);
295
- reward_balance += result;
296
- // return result;
297
- }
298
- return reward_balance;
299
- }
300
- async getRewardTotal(reward_list: any){
301
- const contract_addr = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
302
- if (reward_list.length === 0){
303
- return 0;
304
- }
305
- const temp_list = [];
306
- for (const rewardListElement of reward_list) {
307
- temp_list.push(uintCV(rewardListElement));
308
- }
309
- const function_option : any = getReadOptions(this.stackswap,
310
- contract_addr,
311
- 'get-staking-reward-from-list', [
312
- standardPrincipalCV(this.stackswap.getSenderAddress()),
313
- listCV(temp_list),
314
- ]);
315
- const result_raw = await callReadOnlyFunction(function_option);
316
- const result = cvToValue(result_raw);
317
- // console.log("reward", result.rewardSum.value, result_raw)
318
- return result.rewardSum.value;
319
- }
320
-
321
- }
1
+
2
+ import {
3
+ callReadOnlyFunction,
4
+ contractPrincipalCV,
5
+ cvToValue,
6
+ FungibleConditionCode, listCV,
7
+ standardPrincipalCV,
8
+ uintCV
9
+ } from "@stacks/transactions";
10
+ import axios from "axios";
11
+ import {openContractCall} from "@stacks/connect";
12
+ import BigNumber from "bignumber.js";
13
+ import {getPostConditionFromAsset, getReadOptions, getWriteOptions} from "../util";
14
+ import {StackswapAPI} from "../../index";
15
+
16
+ export class StakingManager {
17
+ stackswap: StackswapAPI;
18
+
19
+ constructor(stackswap: StackswapAPI) {
20
+ this.stackswap = stackswap;
21
+ }
22
+
23
+ async getStackingRoundFirstBlock(cycle: number){
24
+ const function_option = getReadOptions(this.stackswap,
25
+ this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
26
+ 'get-first-stacks-block-in-reward-cycle', [
27
+ uintCV(cycle)
28
+ ]);
29
+ const result_raw = await callReadOnlyFunction(function_option);
30
+ const result = cvToValue(result_raw);
31
+ return result;
32
+ }
33
+
34
+ async getStakingSTSWBalance(source: any) {
35
+ // console.log('getStakingSTSWBalance');
36
+ const pair_details_options : any = getReadOptions(source, this.stackswap.config.BASE_STSW_DATA().addr, 'get-balance',
37
+ [contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(),this.stackswap.config.BASE_vSTSW_DATA().addr.split('.')[1])]);
38
+ try {
39
+ const result = await callReadOnlyFunction(pair_details_options);
40
+ // console.log(cvToValue(result));
41
+ return cvToValue(result).value;
42
+ } catch (e) {
43
+ // console.log(e);
44
+ return 0;
45
+ }
46
+ // console.log(pair_details_result)
47
+ }
48
+
49
+ async getRewardRoundID_V2(source: any) {
50
+ try{
51
+ const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
52
+ const round = Number(await this.getCurrentStakingRound(ADDR));
53
+ const options : any = getReadOptions(source, this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(), 'get-staker', [
54
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
55
+ ]);
56
+ const result = await callReadOnlyFunction(options);
57
+ // console.log('reward', round, cvToValue(result));
58
+
59
+ const unclaimedList = [];
60
+ for (const unclaimedElement of cvToValue(result).value) {
61
+ // console.log('reward',unclaimedElement.value);
62
+ if (unclaimedElement.value < round) {
63
+ unclaimedList.push(unclaimedElement.value);
64
+ }
65
+ }
66
+ // console.log('reward',unclaimedList);
67
+
68
+ return unclaimedList;
69
+ } catch (e) {
70
+ return [];
71
+ }
72
+ }
73
+
74
+ async getStakingRound(contract_address: string, block: number | string) {
75
+ try{
76
+ // const poxl_token = contract_address.split('.');
77
+ const options = getReadOptions(this.stackswap, contract_address, 'get-reward-cycle', [
78
+ uintCV(block),
79
+ ]);
80
+ const result = await callReadOnlyFunction(options);
81
+ // console.log(cvToValue(result));
82
+ return cvToValue(result).value;
83
+ } catch (e) {
84
+ return 0;
85
+ }
86
+ }
87
+
88
+ async getCurrentStakingRound(contract_address: string) {
89
+ const bh = await this.stackswap.getCurrentBlock();
90
+ return await this.getStakingRound(contract_address, bh);
91
+ }
92
+
93
+ async getRewardRoundID(offset: number) {
94
+ const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
95
+ const get_result = await axios.get(this.stackswap.config.STACKS_API_URL() + '/extended/v1/address/' + this.stackswap.getSenderAddress() + '/transactions', {
96
+ params: {
97
+ limit: 50,
98
+ offset,
99
+ },
100
+ });
101
+
102
+ // const total = get_result.data.total;
103
+ const results = get_result.data.results;
104
+
105
+ const reward_id: number[] = [];
106
+ for (const item of results) {
107
+ if ('contract_call' in item) {
108
+ if (ADDR === item.contract_call.contract_id &&
109
+ item.contract_call.function_name === 'stake-tokens' &&
110
+ item.tx_status === 'success') {
111
+ const tx_block_number = item.block_height;
112
+ let start_round = await this.getStakingRound(ADDR, tx_block_number);
113
+ // tslint:disable-next-line:radix
114
+ start_round = parseInt(start_round) + 1;
115
+ const end_round = start_round + Number(item.contract_call.function_args[1].repr.replace('u','')) - 1;
116
+ const round_list = this.range_number(start_round, end_round)
117
+ reward_id.push(...round_list)
118
+ }
119
+ }
120
+ }
121
+ return Array.from(new Set(reward_id)).sort((a, b) => { return a - b;});
122
+ }
123
+
124
+
125
+ range_number(start:number, end:number) {
126
+ // tslint:disable-next-line:prefer-const
127
+ let ans: number[] = [];
128
+ for (let i = start; i <= end; i++) {
129
+ ans.push(i);
130
+ }
131
+ return ans;
132
+ }
133
+
134
+ async getReward(contract_addr:string, round_id:number){
135
+ contract_addr = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
136
+ const function_option : any = getReadOptions(this.stackswap,
137
+ contract_addr,
138
+ 'get-staking-reward-per-user', [
139
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
140
+ uintCV(round_id)
141
+ ]);
142
+ const result_raw = await callReadOnlyFunction(function_option);
143
+ const result = cvToValue(result_raw);
144
+ // console.log("reward", round_id, result, result_raw)
145
+ return Number(result);
146
+ }
147
+
148
+ async txClaimReward(round_id: number, stsw_amount: string, callback : any = null){
149
+ const post_condition = [ await getPostConditionFromAsset(this.stackswap,
150
+ this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
151
+ this.stackswap.config.BASE_STSW_DATA().addr, stsw_amount, FungibleConditionCode.Equal)];
152
+ const function_option : any = getWriteOptions(
153
+ this.stackswap,
154
+ this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
155
+ 'claim-staking-reward',
156
+ [uintCV(round_id)], post_condition, callback);
157
+ await openContractCall(function_option);
158
+ }
159
+
160
+
161
+ async getUserCountFromVSTSW(){
162
+ const address = this.stackswap.config.BASE_vSTSW_DATA().addr.split('.');
163
+ address[0], address[1];
164
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr,
165
+ 'get-user-count',[standardPrincipalCV(this.stackswap.getSenderAddress()) ]);
166
+ const result_raw = await callReadOnlyFunction(function_option);
167
+ const result = cvToValue(result_raw);
168
+ if(result == null){return 0}
169
+ // tslint:disable-next-line:radix
170
+ else{return parseInt(result.value.idx.value)}
171
+ }
172
+
173
+ async getStakingBalanceFromVSTSW_V2(){
174
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr,'get-user-count',[standardPrincipalCV(this.stackswap.getSenderAddress()) ]);
175
+ const result_raw = await callReadOnlyFunction(function_option);
176
+ const result = cvToValue(result_raw);
177
+ // console.log("V2", result)
178
+ if(result == null){return 0}
179
+ else{return new BigNumber(result.value.stakedSTX.value).dividedBy(new BigNumber(10).exponentiatedBy(this.stackswap.config.BASE_vSTSW_DATA().decimal))}
180
+ }
181
+
182
+ async getClaimRewardListFromVSTSW(){
183
+ // tslint:disable-next-line:prefer-const
184
+ let res_dict : any = {};
185
+
186
+ // tslint:disable-next-line:prefer-const
187
+ let id_list: any = [];
188
+
189
+ const count = await this.getUserCountFromVSTSW();
190
+ for (let i = 1; i <= count; i++) {
191
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr,
192
+ 'get-user-info',[
193
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
194
+ uintCV(i)]
195
+ );
196
+ const result_raw = await callReadOnlyFunction(function_option);
197
+ const result = cvToValue(result_raw);
198
+ if ( !result.value.returned.value ){
199
+ res_dict[i] = result;
200
+ id_list.push(i);
201
+ // console.log(result);
202
+ }
203
+ }
204
+ return [id_list, res_dict];
205
+ }
206
+ // get-user-count () user address
207
+ async getStakingBalanceFromVSTSW(){
208
+ let staking_balance = 0;
209
+ const count = await this.getUserCountFromVSTSW();
210
+ for (let i = 1; i <= count; i++) {
211
+ const function_option : any = getReadOptions( this.stackswap,
212
+ this.stackswap.config.BASE_vSTSW_DATA().addr,'get-user-info',[
213
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
214
+ uintCV(i)]
215
+ );
216
+ const result_raw = await callReadOnlyFunction(function_option);
217
+ const result = cvToValue(result_raw);
218
+ if(result.value.returned.value === false){
219
+ // tslint:disable-next-line:radix
220
+ staking_balance += parseInt(result.value.amountSTSW.value)
221
+ }
222
+ }
223
+ return staking_balance;
224
+ }
225
+
226
+
227
+ async txStakeFromStaking(invest_amt:number, period_month:number, callback : any = null){
228
+ const invest_amt_bn = new BigNumber(10**6).multipliedBy(invest_amt).toFixed(0).toString();
229
+ const postConditions = [];
230
+ postConditions.push(await getPostConditionFromAsset( this.stackswap,
231
+ this.stackswap.getSenderAddress(),
232
+ this.stackswap.config.BASE_STSW_DATA().addr,
233
+ invest_amt_bn,
234
+ FungibleConditionCode.Equal)
235
+ );
236
+
237
+ const function_option : any = getWriteOptions(this.stackswap,
238
+ this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING(),
239
+ 'stake-tokens',[
240
+ uintCV(invest_amt_bn),uintCV(period_month)],
241
+ postConditions, callback
242
+ );
243
+ await openContractCall(function_option);
244
+ }
245
+
246
+ async txCooldownFromVSTSW(index:number, callback : any = null){
247
+ const function_option : any = getWriteOptions(this.stackswap,
248
+ this.stackswap.config.BASE_vSTSW_DATA().addr,
249
+ 'unstake-tokens', [uintCV(index)], [], callback);
250
+ await openContractCall(function_option);
251
+ }
252
+
253
+
254
+ async txUnstakingFromVSTSW(index:number, amountSTX:string, amountvSTX:string, callback : any = null){
255
+ // console.log("Unstaking", amountSTX)
256
+ const post_conditions = [];
257
+ post_conditions.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_vSTSW_DATA().addr,amountvSTX, FungibleConditionCode.Equal))
258
+ post_conditions.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.BASE_vSTSW_DATA().addr, this.stackswap.config.BASE_STSW_DATA().addr, amountSTX, FungibleConditionCode.Equal))
259
+ const function_option : any = getWriteOptions(
260
+ this.stackswap,
261
+ this.stackswap.config.BASE_vSTSW_DATA().addr,
262
+ 'reclaim-tokens',
263
+ [uintCV(index)], post_conditions, callback
264
+ );
265
+ await openContractCall(function_option);
266
+ }
267
+
268
+ async getRewardBalanceFromStaking(){
269
+ const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
270
+ let reward_balance = 0;
271
+ const current_round = await this.getCurrentStakingRound(ADDR);
272
+ // console.log(current_round)
273
+ for (let i = 0; i <= current_round; i++) {
274
+
275
+ const result = await this.getReward( ADDR, i);
276
+ reward_balance += result;
277
+ // return result;
278
+ }
279
+ return reward_balance;
280
+ }
281
+ async getRewardBalanceFromStakingFromList(unclaimed_list: any){
282
+ const ADDR = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
283
+ let reward_balance = 0;
284
+ const current_round = await this.getCurrentStakingRound(ADDR);
285
+ // console.log(current_round)
286
+ const temp = [];
287
+ for (const unclaimed of unclaimed_list) {
288
+ if ( unclaimed < Number(current_round) ) {
289
+ temp.push(uintCV(unclaimed));
290
+ }
291
+ }
292
+ for (let i = 0; i <= current_round; i++) {
293
+
294
+ const result = await this.getReward(ADDR, i);
295
+ reward_balance += result;
296
+ // return result;
297
+ }
298
+ return reward_balance;
299
+ }
300
+ async getRewardTotal(reward_list: any){
301
+ const contract_addr = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
302
+ if (reward_list.length === 0){
303
+ return 0;
304
+ }
305
+ const temp_list = [];
306
+ for (const rewardListElement of reward_list) {
307
+ temp_list.push(uintCV(rewardListElement));
308
+ }
309
+ const function_option : any = getReadOptions(this.stackswap,
310
+ contract_addr,
311
+ 'get-staking-reward-from-list', [
312
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
313
+ listCV(temp_list),
314
+ ]);
315
+ const result_raw = await callReadOnlyFunction(function_option);
316
+ const result = cvToValue(result_raw);
317
+ // console.log("reward", result.rewardSum.value, result_raw)
318
+ return result.rewardSum.value;
319
+ }
320
+
321
+ }