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