stackswap-front-api-test-02 1.0.105 → 1.0.106

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 +74 -60
  9. package/dist/esm/stackswap/manager/farm2.manager.js +428 -403
  10. package/dist/esm/stackswap/manager/farm2.manager.js.map +1 -1
  11. package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
  12. package/dist/esm/stackswap/manager/governance.manager.js +53 -53
  13. package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
  14. package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
  15. package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
  16. package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
  17. package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
  18. package/dist/esm/stackswap/manager/lbtcstaking.manager.js +191 -191
  19. package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
  20. package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
  21. package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
  22. package/dist/esm/stackswap/manager/nft.manager.js +243 -243
  23. package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
  24. package/dist/esm/stackswap/manager/operator.manager.js +85 -85
  25. package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
  26. package/dist/esm/stackswap/manager/other.manager.js +47 -47
  27. package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
  28. package/dist/esm/stackswap/manager/pool.manager.js +171 -171
  29. package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
  30. package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
  31. package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
  32. package/dist/esm/stackswap/manager/staking.manager.js +233 -233
  33. package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
  34. package/dist/esm/stackswap/manager/swap.manager.js +332 -332
  35. package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
  36. package/dist/esm/stackswap/manager/token.manager.js +133 -133
  37. package/dist/esm/stackswap/util.d.ts +35 -35
  38. package/dist/esm/stackswap/util.js +201 -201
  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 +74 -60
  47. package/dist/stackswap/manager/farm2.manager.js +435 -410
  48. package/dist/stackswap/manager/farm2.manager.js.map +1 -1
  49. package/dist/stackswap/manager/governance.manager.d.ts +9 -9
  50. package/dist/stackswap/manager/governance.manager.js +60 -60
  51. package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
  52. package/dist/stackswap/manager/launchpad.manager.js +151 -151
  53. package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
  54. package/dist/stackswap/manager/lbtc.manager.js +333 -333
  55. package/dist/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
  56. package/dist/stackswap/manager/lbtcstaking.manager.js +198 -198
  57. package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
  58. package/dist/stackswap/manager/multisig.manager.js +55 -55
  59. package/dist/stackswap/manager/nft.manager.d.ts +52 -52
  60. package/dist/stackswap/manager/nft.manager.js +250 -250
  61. package/dist/stackswap/manager/operator.manager.d.ts +17 -17
  62. package/dist/stackswap/manager/operator.manager.js +92 -92
  63. package/dist/stackswap/manager/other.manager.d.ts +9 -9
  64. package/dist/stackswap/manager/other.manager.js +54 -54
  65. package/dist/stackswap/manager/pool.manager.d.ts +34 -34
  66. package/dist/stackswap/manager/pool.manager.js +179 -179
  67. package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
  68. package/dist/stackswap/manager/poxl.manager.js +78 -78
  69. package/dist/stackswap/manager/staking.manager.d.ts +25 -25
  70. package/dist/stackswap/manager/staking.manager.js +240 -240
  71. package/dist/stackswap/manager/swap.manager.d.ts +39 -39
  72. package/dist/stackswap/manager/swap.manager.js +339 -339
  73. package/dist/stackswap/manager/token.manager.d.ts +31 -31
  74. package/dist/stackswap/manager/token.manager.js +141 -141
  75. package/dist/stackswap/util.d.ts +35 -35
  76. package/dist/stackswap/util.js +218 -218
  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 +491 -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,51 +1,51 @@
1
- import BigNumber from "bignumber.js";
2
- import { StackswapAPI } from "../../index";
3
- export declare class LBTCStakingManager {
4
- stackswap: StackswapAPI;
5
- constructor(stackswap: StackswapAPI);
6
- getStackingRoundFirstBlock(cycle: number): Promise<any>;
7
- getStakingRound(block: number | string): Promise<any>;
8
- getCurrentStakingRound(): Promise<any>;
9
- getStaker(): Promise<{
10
- unclaimedList: string[];
11
- amount: string;
12
- stakedList: string[];
13
- }>;
14
- getRoundData(round: number): Promise<{
15
- rewardBase: any;
16
- amount: any;
17
- value: any;
18
- }>;
19
- getLBTCNFT(): Promise<string[]>;
20
- getReward(round_id: number): Promise<string>;
21
- getClaimRewardList(nfts: any): Promise<any[]>;
22
- txStake(invest_amt: number, period_month: number, callback?: any): Promise<void>;
23
- txClaim(round_id: number, stsw_amount: string, callback?: any): Promise<void>;
24
- txUnstake(index: number, callback?: any): Promise<void>;
25
- txReclaim(index: number, amountSTX: string, callback?: any): Promise<void>;
26
- getRewardFromList(reward_list: any[]): Promise<any>;
27
- getRewardTotal(unclaimed_list: string[]): Promise<BigNumber>;
28
- getlbtcStakingData(): Promise<{
29
- bh: string;
30
- round: any;
31
- round_data: {
32
- rewardBase: any;
33
- amount: any;
34
- value: any;
35
- };
36
- tvl_apr: any;
37
- round_reward: any;
38
- this_round_start_block: number;
39
- next_round_start_block: number;
40
- next_round_end_block: number;
41
- max_apr: string;
42
- min_apr: string;
43
- tvl_usd: string;
44
- tvl_lbtc: string;
45
- }>;
46
- getUserStakingData(): Promise<{
47
- user_staked_amount: string;
48
- stake_lbtc_claim_round_list: string[];
49
- total_reward: BigNumber;
50
- }>;
51
- }
1
+ import BigNumber from "bignumber.js";
2
+ import { StackswapAPI } from "../../index";
3
+ export declare class LBTCStakingManager {
4
+ stackswap: StackswapAPI;
5
+ constructor(stackswap: StackswapAPI);
6
+ getStackingRoundFirstBlock(cycle: number): Promise<any>;
7
+ getStakingRound(block: number | string): Promise<any>;
8
+ getCurrentStakingRound(): Promise<any>;
9
+ getStaker(): Promise<{
10
+ unclaimedList: string[];
11
+ amount: string;
12
+ stakedList: string[];
13
+ }>;
14
+ getRoundData(round: number): Promise<{
15
+ rewardBase: any;
16
+ amount: any;
17
+ value: any;
18
+ }>;
19
+ getLBTCNFT(): Promise<string[]>;
20
+ getReward(round_id: number): Promise<string>;
21
+ getClaimRewardList(nfts: any): Promise<any[]>;
22
+ txStake(invest_amt: number, period_month: number, callback?: any): Promise<void>;
23
+ txClaim(round_id: number, stsw_amount: string, callback?: any): Promise<void>;
24
+ txUnstake(index: number, callback?: any): Promise<void>;
25
+ txReclaim(index: number, amountSTX: string, callback?: any): Promise<void>;
26
+ getRewardFromList(reward_list: any[]): Promise<any>;
27
+ getRewardTotal(unclaimed_list: string[]): Promise<BigNumber>;
28
+ getlbtcStakingData(): Promise<{
29
+ bh: string;
30
+ round: any;
31
+ round_data: {
32
+ rewardBase: any;
33
+ amount: any;
34
+ value: any;
35
+ };
36
+ tvl_apr: any;
37
+ round_reward: any;
38
+ this_round_start_block: number;
39
+ next_round_start_block: number;
40
+ next_round_end_block: number;
41
+ max_apr: string;
42
+ min_apr: string;
43
+ tvl_usd: string;
44
+ tvl_lbtc: string;
45
+ }>;
46
+ getUserStakingData(): Promise<{
47
+ user_staked_amount: string;
48
+ stake_lbtc_claim_round_list: string[];
49
+ total_reward: BigNumber;
50
+ }>;
51
+ }
@@ -1,192 +1,192 @@
1
- import { callReadOnlyFunction, cvToValue, FungibleConditionCode, listCV, makeStandardNonFungiblePostCondition, NonFungibleConditionCode, standardPrincipalCV, uintCV } from "@stacks/transactions";
2
- import axios from "axios";
3
- import { openContractCall } from "@stacks/connect";
4
- import BigNumber from "bignumber.js";
5
- import { getPostConditionFromAsset, getReadOptions, getWriteOptions, num2decimal, numFormat_ } from "../util";
6
- import { BaseToken, Token } from "./token.manager";
7
- export class LBTCStakingManager {
8
- constructor(stackswap) {
9
- this.stackswap = stackswap;
10
- }
11
- async getStackingRoundFirstBlock(cycle) {
12
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-first-stacks-block-in-reward-cycle', [
13
- uintCV(cycle)
14
- ]);
15
- const result_raw = await callReadOnlyFunction(function_option);
16
- const result = cvToValue(result_raw);
17
- return result;
18
- }
19
- async getStakingRound(block) {
20
- try {
21
- const options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-reward-cycle', [
22
- uintCV(block),
23
- ]);
24
- const result = await callReadOnlyFunction(options);
25
- return cvToValue(result).value;
26
- }
27
- catch (e) {
28
- return 0;
29
- }
30
- }
31
- async getCurrentStakingRound() {
32
- const bh = await this.stackswap.getCurrentBlock();
33
- return await this.getStakingRound(bh);
34
- }
35
- async getStaker() {
36
- try {
37
- const round = Number(await this.getCurrentStakingRound());
38
- const options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staker', [
39
- standardPrincipalCV(this.stackswap.getSenderAddress()),
40
- ]);
41
- const result = await callReadOnlyFunction(options);
42
- const res = cvToValue(result).value;
43
- console.log('getStaker', res);
44
- const unclaimedList = [];
45
- const stakedList = [];
46
- for (const unclaimedElement of res.staked_list.value) {
47
- if (Number(unclaimedElement.value) < Number(round)) {
48
- unclaimedList.push(unclaimedElement.value);
49
- }
50
- stakedList.push(unclaimedElement.value);
51
- }
52
- return { unclaimedList, amount: res.amountReturn.value, stakedList };
53
- }
54
- catch (e) {
55
- return { unclaimedList: [], amount: '0', stakedList: [] };
56
- }
57
- }
58
- async getRoundData(round) {
59
- try {
60
- const options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-stats-at-cycle', [
61
- uintCV(round),
62
- ]);
63
- const result = await callReadOnlyFunction(options);
64
- const res = cvToValue(result).value;
65
- console.log('getRoundData', res);
66
- return { rewardBase: res.amountRewardBase.value, amount: res.amountReturn.value, value: res.amountlBTC.value };
67
- }
68
- catch (e) {
69
- return { rewardBase: '0', amount: '0', value: '0' };
70
- }
71
- }
72
- async getLBTCNFT() {
73
- const url = this.stackswap.config.STACKS_API_URL() + `/extended/v1/tokens/nft/holdings?principal=${this.stackswap.getSenderAddress()}&asset_identifiers=${this.stackswap.config.STACKSWAP_ADDRESS()}.${this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING()}::lBTC-staking-vault`;
74
- const result = await axios.get(url);
75
- const nfts = [];
76
- try {
77
- for (const resultElement of result.data.results) {
78
- nfts.push(resultElement.value.repr);
79
- }
80
- return nfts;
81
- }
82
- catch (e) {
83
- return [];
84
- }
85
- }
86
- async getReward(round_id) {
87
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-reward-per-user', [
88
- standardPrincipalCV(this.stackswap.getSenderAddress()),
89
- uintCV(round_id)
90
- ]);
91
- const result_raw = await callReadOnlyFunction(function_option);
92
- const result = cvToValue(result_raw);
93
- return result;
94
- }
95
- async getClaimRewardList(nfts) {
96
- let res_dict = {};
97
- let id_list = [];
98
- for (const nft of nfts) {
99
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-vault', [
100
- uintCV(nft)
101
- ]);
102
- const result_raw = await callReadOnlyFunction(function_option);
103
- const result = cvToValue(result_raw);
104
- res_dict[nft] = result;
105
- id_list.push(nft);
106
- }
107
- return [id_list, res_dict];
108
- }
109
- async txStake(invest_amt, period_month, callback = null) {
110
- const invest_amt_bn = new BigNumber(10 ** 8).multipliedBy(invest_amt).toFixed(0).toString();
111
- const postConditions = [];
112
- postConditions.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, invest_amt_bn, FungibleConditionCode.Equal));
113
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'stake-tokens', [
114
- uintCV(invest_amt_bn), uintCV(period_month)
115
- ], postConditions, callback);
116
- await openContractCall(function_option);
117
- }
118
- async txClaim(round_id, stsw_amount, callback = null) {
119
- const post_condition = [await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), this.stackswap.config.BASE_STSW_DATA().addr, stsw_amount, FungibleConditionCode.Equal)];
120
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'claim-staking-reward', [uintCV(round_id)], post_condition, callback);
121
- await openContractCall(function_option);
122
- }
123
- async txUnstake(index, callback = null) {
124
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'unstake-tokens', [uintCV(index)], [], callback);
125
- await openContractCall(function_option);
126
- }
127
- async txReclaim(index, amountSTX, callback = null) {
128
- const post_conditions = [];
129
- const assetString = `${this.stackswap.config.STACKSWAP_ADDRESS()}.${this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING()}::lBTC-staking-vault`;
130
- post_conditions.push(await makeStandardNonFungiblePostCondition(this.stackswap.getSenderAddress(), NonFungibleConditionCode.DoesNotOwn, assetString, uintCV(index)));
131
- post_conditions.push(await getPostConditionFromAsset(this.stackswap, `${this.stackswap.config.STACKSWAP_ADDRESS()}.${this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING()}`, this.stackswap.config.BASE_LBTC_DATA().addr, amountSTX, FungibleConditionCode.Equal));
132
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'reclaim-tokens', [uintCV(index)], post_conditions, callback);
133
- await openContractCall(function_option);
134
- }
135
- async getRewardFromList(reward_list) {
136
- if (reward_list.length === 0) {
137
- return 0;
138
- }
139
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-reward-from-list', [
140
- standardPrincipalCV(this.stackswap.getSenderAddress()),
141
- listCV(reward_list),
142
- ]);
143
- const result_raw = await callReadOnlyFunction(function_option);
144
- const result = cvToValue(result_raw);
145
- return result.rewardSum.value;
146
- }
147
- async getRewardTotal(unclaimed_list) {
148
- const num_list = [];
149
- for (const unclaimed of unclaimed_list) {
150
- num_list.push(uintCV(unclaimed));
151
- }
152
- let reward_num = new BigNumber(0);
153
- try {
154
- for (let i = 0; i < num_list.length; i += 4) {
155
- const result = await this.getRewardFromList(num_list.slice(i, i + 4 < num_list.length ? i + 4 : num_list.length));
156
- reward_num = reward_num.plus(result);
157
- }
158
- return num2decimal(reward_num.toString(), 6);
159
- }
160
- catch (e) {
161
- return num2decimal(reward_num.toString(), 6);
162
- }
163
- }
164
- async getlbtcStakingData() {
165
- const bh = await this.stackswap.getCurrentBlock();
166
- const round = await this.getStakingRound(bh);
167
- const round_data = await this.getRoundData(Number(round) + 1);
168
- const tvl_apr = round_data.value;
169
- const round_reward = round_data.rewardBase;
170
- const this_round_start_block = Number(await this.getStackingRoundFirstBlock(Number(round)));
171
- const next_round_start_block = Number(await this.getStackingRoundFirstBlock(Number(round) + 1));
172
- const next_round_end_block = Number(await this.getStackingRoundFirstBlock(Number(round) + 2)) - 1;
173
- const oracle_stsw = num2decimal((await this.stackswap.lbtcManager.getPrice('STSW'))['last-price'].value, 6);
174
- const oracle_lbtc = num2decimal((await this.stackswap.lbtcManager.getPrice('lBTC'))['last-price'].value, 6);
175
- const tvl_lbtc = await this.stackswap.tokenManager.getBalanceOf(Token.getBaseTokens(this.stackswap, BaseToken.lBTC), this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING());
176
- const apr_bn = new BigNumber(1).dividedBy(new BigNumber(tvl_apr).plus(1)).multipliedBy(round_reward).multipliedBy(10 ** 4).multipliedBy(oracle_stsw).dividedBy(oracle_lbtc);
177
- const max_apr = numFormat_(apr_bn.multipliedBy(8).toString(), 3);
178
- const min_apr = numFormat_(apr_bn.toString(), 3);
179
- const tvl_usd = numFormat_(new BigNumber(tvl_lbtc).multipliedBy(oracle_lbtc).div(10 ** 8).toString(), 2);
180
- return { bh, round, round_data, tvl_apr, round_reward, this_round_start_block, next_round_start_block, next_round_end_block, max_apr, min_apr, tvl_usd, tvl_lbtc };
181
- }
182
- async getUserStakingData() {
183
- const staker_info = await this.getStaker();
184
- console.log('get staker', staker_info);
185
- const user_staked_amount = staker_info.amount;
186
- const stake_lbtc_claim_round_list = staker_info.unclaimedList;
187
- const total_reward = await this.getRewardTotal(staker_info.unclaimedList);
188
- console.log('total reward', total_reward);
189
- return { user_staked_amount, stake_lbtc_claim_round_list, total_reward };
190
- }
191
- }
1
+ import { callReadOnlyFunction, cvToValue, FungibleConditionCode, listCV, makeStandardNonFungiblePostCondition, NonFungibleConditionCode, standardPrincipalCV, uintCV } from "@stacks/transactions";
2
+ import axios from "axios";
3
+ import { openContractCall } from "@stacks/connect";
4
+ import BigNumber from "bignumber.js";
5
+ import { getPostConditionFromAsset, getReadOptions, getWriteOptions, num2decimal, numFormat_ } from "../util";
6
+ import { BaseToken, Token } from "./token.manager";
7
+ export class LBTCStakingManager {
8
+ constructor(stackswap) {
9
+ this.stackswap = stackswap;
10
+ }
11
+ async getStackingRoundFirstBlock(cycle) {
12
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-first-stacks-block-in-reward-cycle', [
13
+ uintCV(cycle)
14
+ ]);
15
+ const result_raw = await callReadOnlyFunction(function_option);
16
+ const result = cvToValue(result_raw);
17
+ return result;
18
+ }
19
+ async getStakingRound(block) {
20
+ try {
21
+ const options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-reward-cycle', [
22
+ uintCV(block),
23
+ ]);
24
+ const result = await callReadOnlyFunction(options);
25
+ return cvToValue(result).value;
26
+ }
27
+ catch (e) {
28
+ return 0;
29
+ }
30
+ }
31
+ async getCurrentStakingRound() {
32
+ const bh = await this.stackswap.getCurrentBlock();
33
+ return await this.getStakingRound(bh);
34
+ }
35
+ async getStaker() {
36
+ try {
37
+ const round = Number(await this.getCurrentStakingRound());
38
+ const options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staker', [
39
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
40
+ ]);
41
+ const result = await callReadOnlyFunction(options);
42
+ const res = cvToValue(result).value;
43
+ console.log('getStaker', res);
44
+ const unclaimedList = [];
45
+ const stakedList = [];
46
+ for (const unclaimedElement of res.staked_list.value) {
47
+ if (Number(unclaimedElement.value) < Number(round)) {
48
+ unclaimedList.push(unclaimedElement.value);
49
+ }
50
+ stakedList.push(unclaimedElement.value);
51
+ }
52
+ return { unclaimedList, amount: res.amountReturn.value, stakedList };
53
+ }
54
+ catch (e) {
55
+ return { unclaimedList: [], amount: '0', stakedList: [] };
56
+ }
57
+ }
58
+ async getRoundData(round) {
59
+ try {
60
+ const options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-stats-at-cycle', [
61
+ uintCV(round),
62
+ ]);
63
+ const result = await callReadOnlyFunction(options);
64
+ const res = cvToValue(result).value;
65
+ console.log('getRoundData', res);
66
+ return { rewardBase: res.amountRewardBase.value, amount: res.amountReturn.value, value: res.amountlBTC.value };
67
+ }
68
+ catch (e) {
69
+ return { rewardBase: '0', amount: '0', value: '0' };
70
+ }
71
+ }
72
+ async getLBTCNFT() {
73
+ const url = this.stackswap.config.STACKS_API_URL() + `/extended/v1/tokens/nft/holdings?principal=${this.stackswap.getSenderAddress()}&asset_identifiers=${this.stackswap.config.STACKSWAP_ADDRESS()}.${this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING()}::lBTC-staking-vault`;
74
+ const result = await axios.get(url);
75
+ const nfts = [];
76
+ try {
77
+ for (const resultElement of result.data.results) {
78
+ nfts.push(resultElement.value.repr);
79
+ }
80
+ return nfts;
81
+ }
82
+ catch (e) {
83
+ return [];
84
+ }
85
+ }
86
+ async getReward(round_id) {
87
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-reward-per-user', [
88
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
89
+ uintCV(round_id)
90
+ ]);
91
+ const result_raw = await callReadOnlyFunction(function_option);
92
+ const result = cvToValue(result_raw);
93
+ return result;
94
+ }
95
+ async getClaimRewardList(nfts) {
96
+ let res_dict = {};
97
+ let id_list = [];
98
+ for (const nft of nfts) {
99
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-vault', [
100
+ uintCV(nft)
101
+ ]);
102
+ const result_raw = await callReadOnlyFunction(function_option);
103
+ const result = cvToValue(result_raw);
104
+ res_dict[nft] = result;
105
+ id_list.push(nft);
106
+ }
107
+ return [id_list, res_dict];
108
+ }
109
+ async txStake(invest_amt, period_month, callback = null) {
110
+ const invest_amt_bn = new BigNumber(10 ** 8).multipliedBy(invest_amt).toFixed(0).toString();
111
+ const postConditions = [];
112
+ postConditions.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, invest_amt_bn, FungibleConditionCode.Equal));
113
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'stake-tokens', [
114
+ uintCV(invest_amt_bn), uintCV(period_month)
115
+ ], postConditions, callback);
116
+ await openContractCall(function_option);
117
+ }
118
+ async txClaim(round_id, stsw_amount, callback = null) {
119
+ const post_condition = [await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), this.stackswap.config.BASE_STSW_DATA().addr, stsw_amount, FungibleConditionCode.Equal)];
120
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'claim-staking-reward', [uintCV(round_id)], post_condition, callback);
121
+ await openContractCall(function_option);
122
+ }
123
+ async txUnstake(index, callback = null) {
124
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'unstake-tokens', [uintCV(index)], [], callback);
125
+ await openContractCall(function_option);
126
+ }
127
+ async txReclaim(index, amountSTX, callback = null) {
128
+ const post_conditions = [];
129
+ const assetString = `${this.stackswap.config.STACKSWAP_ADDRESS()}.${this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING()}::lBTC-staking-vault`;
130
+ post_conditions.push(await makeStandardNonFungiblePostCondition(this.stackswap.getSenderAddress(), NonFungibleConditionCode.DoesNotOwn, assetString, uintCV(index)));
131
+ post_conditions.push(await getPostConditionFromAsset(this.stackswap, `${this.stackswap.config.STACKSWAP_ADDRESS()}.${this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING()}`, this.stackswap.config.BASE_LBTC_DATA().addr, amountSTX, FungibleConditionCode.Equal));
132
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'reclaim-tokens', [uintCV(index)], post_conditions, callback);
133
+ await openContractCall(function_option);
134
+ }
135
+ async getRewardFromList(reward_list) {
136
+ if (reward_list.length === 0) {
137
+ return 0;
138
+ }
139
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-reward-from-list', [
140
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
141
+ listCV(reward_list),
142
+ ]);
143
+ const result_raw = await callReadOnlyFunction(function_option);
144
+ const result = cvToValue(result_raw);
145
+ return result.rewardSum.value;
146
+ }
147
+ async getRewardTotal(unclaimed_list) {
148
+ const num_list = [];
149
+ for (const unclaimed of unclaimed_list) {
150
+ num_list.push(uintCV(unclaimed));
151
+ }
152
+ let reward_num = new BigNumber(0);
153
+ try {
154
+ for (let i = 0; i < num_list.length; i += 4) {
155
+ const result = await this.getRewardFromList(num_list.slice(i, i + 4 < num_list.length ? i + 4 : num_list.length));
156
+ reward_num = reward_num.plus(result);
157
+ }
158
+ return num2decimal(reward_num.toString(), 6);
159
+ }
160
+ catch (e) {
161
+ return num2decimal(reward_num.toString(), 6);
162
+ }
163
+ }
164
+ async getlbtcStakingData() {
165
+ const bh = await this.stackswap.getCurrentBlock();
166
+ const round = await this.getStakingRound(bh);
167
+ const round_data = await this.getRoundData(Number(round) + 1);
168
+ const tvl_apr = round_data.value;
169
+ const round_reward = round_data.rewardBase;
170
+ const this_round_start_block = Number(await this.getStackingRoundFirstBlock(Number(round)));
171
+ const next_round_start_block = Number(await this.getStackingRoundFirstBlock(Number(round) + 1));
172
+ const next_round_end_block = Number(await this.getStackingRoundFirstBlock(Number(round) + 2)) - 1;
173
+ const oracle_stsw = num2decimal((await this.stackswap.lbtcManager.getPrice('STSW'))['last-price'].value, 6);
174
+ const oracle_lbtc = num2decimal((await this.stackswap.lbtcManager.getPrice('lBTC'))['last-price'].value, 6);
175
+ const tvl_lbtc = await this.stackswap.tokenManager.getBalanceOf(Token.getBaseTokens(this.stackswap, BaseToken.lBTC), this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING());
176
+ const apr_bn = new BigNumber(1).dividedBy(new BigNumber(tvl_apr).plus(1)).multipliedBy(round_reward).multipliedBy(10 ** 4).multipliedBy(oracle_stsw).dividedBy(oracle_lbtc);
177
+ const max_apr = numFormat_(apr_bn.multipliedBy(8).toString(), 3);
178
+ const min_apr = numFormat_(apr_bn.toString(), 3);
179
+ const tvl_usd = numFormat_(new BigNumber(tvl_lbtc).multipliedBy(oracle_lbtc).div(10 ** 8).toString(), 2);
180
+ return { bh, round, round_data, tvl_apr, round_reward, this_round_start_block, next_round_start_block, next_round_end_block, max_apr, min_apr, tvl_usd, tvl_lbtc };
181
+ }
182
+ async getUserStakingData() {
183
+ const staker_info = await this.getStaker();
184
+ console.log('get staker', staker_info);
185
+ const user_staked_amount = staker_info.amount;
186
+ const stake_lbtc_claim_round_list = staker_info.unclaimedList;
187
+ const total_reward = await this.getRewardTotal(staker_info.unclaimedList);
188
+ console.log('total reward', total_reward);
189
+ return { user_staked_amount, stake_lbtc_claim_round_list, total_reward };
190
+ }
191
+ }
192
192
  //# sourceMappingURL=lbtcstaking.manager.js.map
@@ -1,11 +1,11 @@
1
- import { StackswapAPI } from "../../index";
2
- export declare class MultisigManager {
3
- stackswap: StackswapAPI;
4
- constructor(stackswap: StackswapAPI);
5
- deposit_vote_multisig(vote: boolean): Promise<void>;
6
- withdraw_vote_multisig(vote: boolean): Promise<void>;
7
- deposit_multisig(amount: string): Promise<void>;
8
- withdraw_multisig(addr: string, amount: string): Promise<void>;
9
- getMultisigSTSWAmount(): Promise<any>;
10
- getMultisigResult(functionName: string): Promise<any>;
11
- }
1
+ import { StackswapAPI } from "../../index";
2
+ export declare class MultisigManager {
3
+ stackswap: StackswapAPI;
4
+ constructor(stackswap: StackswapAPI);
5
+ deposit_vote_multisig(vote: boolean): Promise<void>;
6
+ withdraw_vote_multisig(vote: boolean): Promise<void>;
7
+ deposit_multisig(amount: string): Promise<void>;
8
+ withdraw_multisig(addr: string, amount: string): Promise<void>;
9
+ getMultisigSTSWAmount(): Promise<any>;
10
+ getMultisigResult(functionName: string): Promise<any>;
11
+ }
@@ -1,52 +1,52 @@
1
- import { openContractCall } from "@stacks/connect";
2
- import { callReadOnlyFunction, cvToValue, falseCV, FungibleConditionCode, trueCV, uintCV } from "@stacks/transactions";
3
- import { getPostConditionFromAsset, getReadOptions, getWriteOptions, parseAddressToCV } from "../util";
4
- export class MultisigManager {
5
- constructor(stackswap) {
6
- this.stackswap = stackswap;
7
- }
8
- async deposit_vote_multisig(vote) {
9
- const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit-vote', [
10
- vote ? trueCV() : falseCV()
11
- ], []);
12
- await openContractCall(function_option);
13
- }
14
- async withdraw_vote_multisig(vote) {
15
- const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw-vote', [
16
- vote ? trueCV() : falseCV()
17
- ], []);
18
- await openContractCall(function_option);
19
- }
20
- async deposit_multisig(amount) {
21
- const post_condition = [await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
22
- const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit', [
23
- uintCV(amount)
24
- ], post_condition);
25
- await openContractCall(function_option);
26
- }
27
- async withdraw_multisig(addr, amount) {
28
- const post_condition = [await getPostConditionFromAsset(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
29
- const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw', [
30
- parseAddressToCV(addr), uintCV(amount)
31
- ], post_condition);
32
- await openContractCall(function_option);
33
- }
34
- async getMultisigSTSWAmount() {
35
- const pair_details_options = getReadOptions(this.stackswap, this.stackswap.config.BASE_STSW_DATA().addr, 'get-balance', [parseAddressToCV('SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01')]);
36
- try {
37
- const result = await callReadOnlyFunction(pair_details_options);
38
- console.log('get-balance', cvToValue(result));
39
- return cvToValue(result).value;
40
- }
41
- catch (e) {
42
- return '0';
43
- }
44
- }
45
- async getMultisigResult(functionName) {
46
- const pair_details_options = getReadOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', functionName, []);
47
- const result = await callReadOnlyFunction(pair_details_options);
48
- console.log(functionName, cvToValue(result));
49
- return cvToValue(result);
50
- }
51
- }
1
+ import { openContractCall } from "@stacks/connect";
2
+ import { callReadOnlyFunction, cvToValue, falseCV, FungibleConditionCode, trueCV, uintCV } from "@stacks/transactions";
3
+ import { getPostConditionFromAsset, getReadOptions, getWriteOptions, parseAddressToCV } from "../util";
4
+ export class MultisigManager {
5
+ constructor(stackswap) {
6
+ this.stackswap = stackswap;
7
+ }
8
+ async deposit_vote_multisig(vote) {
9
+ const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit-vote', [
10
+ vote ? trueCV() : falseCV()
11
+ ], []);
12
+ await openContractCall(function_option);
13
+ }
14
+ async withdraw_vote_multisig(vote) {
15
+ const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw-vote', [
16
+ vote ? trueCV() : falseCV()
17
+ ], []);
18
+ await openContractCall(function_option);
19
+ }
20
+ async deposit_multisig(amount) {
21
+ const post_condition = [await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
22
+ const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit', [
23
+ uintCV(amount)
24
+ ], post_condition);
25
+ await openContractCall(function_option);
26
+ }
27
+ async withdraw_multisig(addr, amount) {
28
+ const post_condition = [await getPostConditionFromAsset(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
29
+ const function_option = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw', [
30
+ parseAddressToCV(addr), uintCV(amount)
31
+ ], post_condition);
32
+ await openContractCall(function_option);
33
+ }
34
+ async getMultisigSTSWAmount() {
35
+ const pair_details_options = getReadOptions(this.stackswap, this.stackswap.config.BASE_STSW_DATA().addr, 'get-balance', [parseAddressToCV('SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01')]);
36
+ try {
37
+ const result = await callReadOnlyFunction(pair_details_options);
38
+ console.log('get-balance', cvToValue(result));
39
+ return cvToValue(result).value;
40
+ }
41
+ catch (e) {
42
+ return '0';
43
+ }
44
+ }
45
+ async getMultisigResult(functionName) {
46
+ const pair_details_options = getReadOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', functionName, []);
47
+ const result = await callReadOnlyFunction(pair_details_options);
48
+ console.log(functionName, cvToValue(result));
49
+ return cvToValue(result);
50
+ }
51
+ }
52
52
  //# sourceMappingURL=multisig.manager.js.map