stackswap-front-api-test-02 1.0.89 → 1.0.92
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 -84
- package/dist/esm/index.js +145 -143
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/stackswap/config.d.ts +114 -112
- package/dist/esm/stackswap/config.js +188 -185
- package/dist/esm/stackswap/config.js.map +1 -1
- package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/esm/stackswap/manager/farm.manager.js +293 -293
- package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
- package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/governance.manager.js +53 -53
- package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
- package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
- package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js +153 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
- package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/esm/stackswap/manager/nft.manager.js +243 -243
- package/dist/esm/stackswap/manager/nft.manager.js.map +1 -1
- package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/esm/stackswap/manager/operator.manager.js +85 -85
- package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/other.manager.js +47 -47
- package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/esm/stackswap/manager/pool.manager.js +171 -171
- package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
- package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/esm/stackswap/manager/staking.manager.js +233 -233
- package/dist/esm/stackswap/manager/staking.manager.js.map +1 -1
- package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/esm/stackswap/manager/swap.manager.js +332 -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/index.d.ts +86 -84
- package/dist/index.js +154 -152
- package/dist/index.js.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/stackswap/config.d.ts +114 -112
- package/dist/stackswap/config.js +193 -190
- package/dist/stackswap/config.js.map +1 -1
- package/dist/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/stackswap/manager/farm.manager.js +301 -301
- package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/stackswap/manager/farm2.manager.js +410 -410
- package/dist/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/stackswap/manager/governance.manager.js +60 -60
- package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/stackswap/manager/launchpad.manager.js +151 -151
- package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/stackswap/manager/lbtc.manager.js +333 -333
- package/dist/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js +160 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/stackswap/manager/multisig.manager.js +55 -55
- package/dist/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/stackswap/manager/nft.manager.js +250 -250
- package/dist/stackswap/manager/nft.manager.js.map +1 -1
- package/dist/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/stackswap/manager/operator.manager.js +92 -92
- package/dist/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/stackswap/manager/other.manager.js +54 -54
- package/dist/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/stackswap/manager/pool.manager.js +179 -179
- package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/stackswap/manager/poxl.manager.js +78 -78
- package/dist/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/stackswap/manager/staking.manager.js +240 -240
- package/dist/stackswap/manager/staking.manager.js.map +1 -1
- package/dist/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/stackswap/manager/swap.manager.js +339 -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/package.json +43 -43
- package/src/index.ts +207 -204
- package/src/stackswap/config.ts +297 -292
- package/src/stackswap/manager/farm.manager.ts +399 -399
- package/src/stackswap/manager/farm2.manager.ts +463 -463
- package/src/stackswap/manager/governance.manager.ts +95 -95
- package/src/stackswap/manager/launchpad.manager.ts +190 -190
- package/src/stackswap/manager/lbtcstaking.manager.ts +219 -0
- package/src/stackswap/manager/multisig.manager.ts +87 -87
- package/src/stackswap/manager/nft.manager.ts +307 -311
- package/src/stackswap/manager/operator.manager.ts +123 -123
- package/src/stackswap/manager/other.manager.ts +71 -71
- package/src/stackswap/manager/pool.manager.ts +202 -202
- package/src/stackswap/manager/poxl.manager.ts +99 -99
- package/src/stackswap/manager/staking.manager.ts +321 -321
- package/src/stackswap/manager/swap.manager.ts +392 -392
- package/src/stackswap/manager/token.manager.ts +167 -167
- package/src/stackswap/util.ts +237 -237
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
|
|
2
|
+
import {
|
|
3
|
+
callReadOnlyFunction,
|
|
4
|
+
cvToValue,
|
|
5
|
+
FungibleConditionCode, listCV, makeStandardNonFungiblePostCondition, NonFungibleConditionCode,
|
|
6
|
+
standardPrincipalCV,
|
|
7
|
+
uintCV
|
|
8
|
+
} from "@stacks/transactions";
|
|
9
|
+
import axios from "axios";
|
|
10
|
+
import {openContractCall} from "@stacks/connect";
|
|
11
|
+
import BigNumber from "bignumber.js";
|
|
12
|
+
import {getPostConditionFromAsset, getReadOptions, getWriteOptions} from "../util";
|
|
13
|
+
import {StackswapAPI} from "../../index";
|
|
14
|
+
|
|
15
|
+
export class LBTCStakingManager {
|
|
16
|
+
stackswap: StackswapAPI;
|
|
17
|
+
|
|
18
|
+
constructor(stackswap: StackswapAPI) {
|
|
19
|
+
this.stackswap = stackswap;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
async getStackingRoundFirstBlock(cycle: number){
|
|
23
|
+
const function_option = getReadOptions(this.stackswap,
|
|
24
|
+
this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
25
|
+
'get-first-stacks-block-in-reward-cycle', [
|
|
26
|
+
uintCV(cycle)
|
|
27
|
+
]);
|
|
28
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
29
|
+
const result = cvToValue(result_raw);
|
|
30
|
+
return result;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
async getStakingRound(block: number | string) {
|
|
34
|
+
try{
|
|
35
|
+
// const poxl_token = contract_address.split('.');
|
|
36
|
+
const options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-reward-cycle', [
|
|
37
|
+
uintCV(block),
|
|
38
|
+
]);
|
|
39
|
+
const result = await callReadOnlyFunction(options);
|
|
40
|
+
// console.log(cvToValue(result));
|
|
41
|
+
return cvToValue(result).value;
|
|
42
|
+
} catch (e) {
|
|
43
|
+
return 0;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
async getCurrentStakingRound() {
|
|
48
|
+
const bh = await this.stackswap.getCurrentBlock();
|
|
49
|
+
return await this.getStakingRound(bh);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
async getStaker() : Promise<{ unclaimedList: string[], amount: string, stakedList: string[] }> {
|
|
53
|
+
try{
|
|
54
|
+
const round = Number(await this.getCurrentStakingRound());
|
|
55
|
+
const options : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staker', [
|
|
56
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
57
|
+
]);
|
|
58
|
+
const result = await callReadOnlyFunction(options);
|
|
59
|
+
// console.log('reward', round, cvToValue(result));
|
|
60
|
+
const res = cvToValue(result).value;
|
|
61
|
+
console.log('getStaker', res);
|
|
62
|
+
const unclaimedList = [];
|
|
63
|
+
const stakedList = [];
|
|
64
|
+
for (const unclaimedElement of res.staked_list.value) {
|
|
65
|
+
// console.log('reward',unclaimedElement.value);
|
|
66
|
+
if (Number(unclaimedElement.value) < Number(round)) {
|
|
67
|
+
unclaimedList.push(unclaimedElement.value);
|
|
68
|
+
}
|
|
69
|
+
stakedList.push(unclaimedElement.value);
|
|
70
|
+
}
|
|
71
|
+
return {unclaimedList, amount: res.amountReturn.value, stakedList};
|
|
72
|
+
} catch (e) {
|
|
73
|
+
return {unclaimedList: [], amount: '0', stakedList: []};
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
async getRoundData(round: number) {
|
|
78
|
+
try{
|
|
79
|
+
// const round = Number(await this.getCurrentStakingRound());
|
|
80
|
+
const options : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), 'get-staking-stats-at-cycle', [
|
|
81
|
+
uintCV(round),
|
|
82
|
+
]);
|
|
83
|
+
const result = await callReadOnlyFunction(options);
|
|
84
|
+
// console.log('reward', round, cvToValue(result));
|
|
85
|
+
const res = cvToValue(result).value;
|
|
86
|
+
console.log('getRoundData', res);
|
|
87
|
+
return {rewardBase: res.amountRewardBase.value, amount: res.amountReturn.value, value: res.amountlBTC.value};
|
|
88
|
+
} catch (e) {
|
|
89
|
+
return {rewardBase: '0', amount: '0', value: '0'};
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
async getLBTCNFT() : Promise<string[]>{
|
|
94
|
+
// console.log(tokenStr);
|
|
95
|
+
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`
|
|
96
|
+
|
|
97
|
+
const result = await axios.get(url);
|
|
98
|
+
// console.log(tokenStr,result);
|
|
99
|
+
const nfts = [];
|
|
100
|
+
try{
|
|
101
|
+
for (const resultElement of result.data.results) {
|
|
102
|
+
nfts.push(resultElement.value.repr);
|
|
103
|
+
}
|
|
104
|
+
return nfts;
|
|
105
|
+
} catch (e) {
|
|
106
|
+
return [];
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
async getReward(round_id:number): Promise<string>{
|
|
111
|
+
const function_option : any = getReadOptions(this.stackswap,
|
|
112
|
+
this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
113
|
+
'get-staking-reward-per-user', [
|
|
114
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
115
|
+
uintCV(round_id)
|
|
116
|
+
]);
|
|
117
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
118
|
+
const result = cvToValue(result_raw);
|
|
119
|
+
// console.log("reward", round_id, result, result_raw)
|
|
120
|
+
return result;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
async getClaimRewardList(){
|
|
124
|
+
// tslint:disable-next-line:prefer-const
|
|
125
|
+
let res_dict : any = {};
|
|
126
|
+
|
|
127
|
+
// tslint:disable-next-line:prefer-const
|
|
128
|
+
let id_list: any = [];
|
|
129
|
+
|
|
130
|
+
const nfts = await this.getLBTCNFT();
|
|
131
|
+
for (const nft of nfts) {
|
|
132
|
+
const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
133
|
+
'get-staking-vault',[
|
|
134
|
+
uintCV(nft)]
|
|
135
|
+
);
|
|
136
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
137
|
+
const result = cvToValue(result_raw);
|
|
138
|
+
res_dict[nft] = result;
|
|
139
|
+
id_list.push(nft);
|
|
140
|
+
}
|
|
141
|
+
return [id_list, res_dict];
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
async txStake(invest_amt:number, period_month:number, callback : any = null){
|
|
145
|
+
const invest_amt_bn = new BigNumber(10**6).multipliedBy(invest_amt).toFixed(0).toString();
|
|
146
|
+
const postConditions = [];
|
|
147
|
+
postConditions.push(await getPostConditionFromAsset( this.stackswap,
|
|
148
|
+
this.stackswap.getSenderAddress(),
|
|
149
|
+
this.stackswap.config.BASE_LBTC_DATA().addr,
|
|
150
|
+
invest_amt_bn,
|
|
151
|
+
FungibleConditionCode.Equal)
|
|
152
|
+
);
|
|
153
|
+
|
|
154
|
+
const function_option : any = getWriteOptions(this.stackswap,
|
|
155
|
+
this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
156
|
+
'stake-tokens',[
|
|
157
|
+
uintCV(invest_amt_bn),uintCV(period_month)],
|
|
158
|
+
postConditions, callback
|
|
159
|
+
);
|
|
160
|
+
await openContractCall(function_option);
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
async txClaim(round_id: number, stsw_amount: string, callback : any = null){
|
|
164
|
+
const post_condition = [ await getPostConditionFromAsset(this.stackswap,
|
|
165
|
+
this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
166
|
+
this.stackswap.config.BASE_STSW_DATA().addr, stsw_amount, FungibleConditionCode.Equal)];
|
|
167
|
+
const function_option : any = getWriteOptions(
|
|
168
|
+
this.stackswap,
|
|
169
|
+
this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
170
|
+
'claim-staking-reward',
|
|
171
|
+
[uintCV(round_id)], post_condition, callback);
|
|
172
|
+
await openContractCall(function_option);
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
async txUnstake(index:number, callback : any = null){
|
|
177
|
+
const function_option : any = getWriteOptions(this.stackswap,
|
|
178
|
+
this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
179
|
+
'unstake-tokens', [uintCV(index)], [], callback);
|
|
180
|
+
await openContractCall(function_option);
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
async txReclaim(index:number, amountSTX:string, callback : any = null){
|
|
184
|
+
// console.log("Unstaking", amountSTX)
|
|
185
|
+
const post_conditions = [];
|
|
186
|
+
const assetString = `${this.stackswap.config.STACKSWAP_ADDRESS()}.${this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING()}::lBTC-staking-vault`
|
|
187
|
+
post_conditions.push(await makeStandardNonFungiblePostCondition(this.stackswap.getSenderAddress(), NonFungibleConditionCode.DoesNotOwn, assetString, uintCV(index)))
|
|
188
|
+
post_conditions.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(), this.stackswap.config.BASE_STSW_DATA().addr, amountSTX, FungibleConditionCode.Equal))
|
|
189
|
+
const function_option : any = getWriteOptions(
|
|
190
|
+
this.stackswap,
|
|
191
|
+
this.stackswap.config.CONTRACT_NAME_STACKSWAP_LBTC_STACKING(),
|
|
192
|
+
'reclaim-tokens',
|
|
193
|
+
[uintCV(index)], post_conditions, callback
|
|
194
|
+
);
|
|
195
|
+
await openContractCall(function_option);
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
async getRewardTotal(reward_list: any){
|
|
199
|
+
const contract_addr = this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_STACKSWAP_STACKING();
|
|
200
|
+
if (reward_list.length === 0){
|
|
201
|
+
return 0;
|
|
202
|
+
}
|
|
203
|
+
const temp_list = [];
|
|
204
|
+
for (const rewardListElement of reward_list) {
|
|
205
|
+
temp_list.push(uintCV(rewardListElement));
|
|
206
|
+
}
|
|
207
|
+
const function_option : any = getReadOptions(this.stackswap,
|
|
208
|
+
contract_addr,
|
|
209
|
+
'get-staking-reward-from-list', [
|
|
210
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
211
|
+
listCV(temp_list),
|
|
212
|
+
]);
|
|
213
|
+
const result_raw = await callReadOnlyFunction(function_option);
|
|
214
|
+
const result = cvToValue(result_raw);
|
|
215
|
+
// console.log("reward", result.rewardSum.value, result_raw)
|
|
216
|
+
return result.rewardSum.value;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
}
|
|
@@ -1,87 +1,87 @@
|
|
|
1
|
-
import {openContractCall} from "@stacks/connect";
|
|
2
|
-
import {
|
|
3
|
-
callReadOnlyFunction,
|
|
4
|
-
cvToValue,
|
|
5
|
-
falseCV,
|
|
6
|
-
FungibleConditionCode,
|
|
7
|
-
trueCV,
|
|
8
|
-
uintCV
|
|
9
|
-
} from "@stacks/transactions";
|
|
10
|
-
import {StackswapAPI} from "../../index";
|
|
11
|
-
import {getPostConditionFromAsset, getReadOptions, getWriteOptions, parseAddressToCV} from "../util";
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
export class MultisigManager {
|
|
15
|
-
stackswap: StackswapAPI;
|
|
16
|
-
|
|
17
|
-
constructor(stackswap: StackswapAPI) {
|
|
18
|
-
this.stackswap = stackswap;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
async deposit_vote_multisig(vote: boolean){
|
|
22
|
-
|
|
23
|
-
// console.log({amount});
|
|
24
|
-
const function_option : any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit-vote', [
|
|
25
|
-
vote? trueCV() : falseCV()
|
|
26
|
-
], []);
|
|
27
|
-
await openContractCall(function_option);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
async withdraw_vote_multisig(vote: boolean){
|
|
31
|
-
|
|
32
|
-
// console.log({amount});
|
|
33
|
-
const function_option : any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw-vote', [
|
|
34
|
-
vote? trueCV() : falseCV()
|
|
35
|
-
], []);
|
|
36
|
-
await openContractCall(function_option);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
async deposit_multisig(amount: string){
|
|
40
|
-
|
|
41
|
-
// console.log({amount});
|
|
42
|
-
const post_condition = [await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
|
|
43
|
-
const function_option : any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit', [
|
|
44
|
-
uintCV(amount)
|
|
45
|
-
], post_condition);
|
|
46
|
-
await openContractCall(function_option);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
async withdraw_multisig(addr: string, amount: string){
|
|
50
|
-
|
|
51
|
-
// console.log({amount});
|
|
52
|
-
const post_condition = [await getPostConditionFromAsset(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
|
|
53
|
-
|
|
54
|
-
const function_option: any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw', [
|
|
55
|
-
parseAddressToCV(addr), uintCV(amount)
|
|
56
|
-
], post_condition);
|
|
57
|
-
await openContractCall(function_option);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
async getMultisigSTSWAmount() {
|
|
61
|
-
// console.log('getStakingSTSWBalance');
|
|
62
|
-
const pair_details_options : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_STSW_DATA().addr, 'get-balance',
|
|
63
|
-
[parseAddressToCV('SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01')]);
|
|
64
|
-
try {
|
|
65
|
-
const result = await callReadOnlyFunction(pair_details_options);
|
|
66
|
-
console.log('get-balance', cvToValue(result));
|
|
67
|
-
return cvToValue(result).value;
|
|
68
|
-
} catch (e) {
|
|
69
|
-
// console.log(e);
|
|
70
|
-
return '0';
|
|
71
|
-
}
|
|
72
|
-
// console.log(pair_details_result)
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
async getMultisigResult(functionName: string) {
|
|
76
|
-
const pair_details_options : any = getReadOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', functionName,
|
|
77
|
-
[]);
|
|
78
|
-
const result = await callReadOnlyFunction(pair_details_options);
|
|
79
|
-
console.log(functionName, cvToValue(result));
|
|
80
|
-
return cvToValue(result);
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
1
|
+
import {openContractCall} from "@stacks/connect";
|
|
2
|
+
import {
|
|
3
|
+
callReadOnlyFunction,
|
|
4
|
+
cvToValue,
|
|
5
|
+
falseCV,
|
|
6
|
+
FungibleConditionCode,
|
|
7
|
+
trueCV,
|
|
8
|
+
uintCV
|
|
9
|
+
} from "@stacks/transactions";
|
|
10
|
+
import {StackswapAPI} from "../../index";
|
|
11
|
+
import {getPostConditionFromAsset, getReadOptions, getWriteOptions, parseAddressToCV} from "../util";
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
export class MultisigManager {
|
|
15
|
+
stackswap: StackswapAPI;
|
|
16
|
+
|
|
17
|
+
constructor(stackswap: StackswapAPI) {
|
|
18
|
+
this.stackswap = stackswap;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
async deposit_vote_multisig(vote: boolean){
|
|
22
|
+
|
|
23
|
+
// console.log({amount});
|
|
24
|
+
const function_option : any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit-vote', [
|
|
25
|
+
vote? trueCV() : falseCV()
|
|
26
|
+
], []);
|
|
27
|
+
await openContractCall(function_option);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
async withdraw_vote_multisig(vote: boolean){
|
|
31
|
+
|
|
32
|
+
// console.log({amount});
|
|
33
|
+
const function_option : any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw-vote', [
|
|
34
|
+
vote? trueCV() : falseCV()
|
|
35
|
+
], []);
|
|
36
|
+
await openContractCall(function_option);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
async deposit_multisig(amount: string){
|
|
40
|
+
|
|
41
|
+
// console.log({amount});
|
|
42
|
+
const post_condition = [await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
|
|
43
|
+
const function_option : any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'deposit', [
|
|
44
|
+
uintCV(amount)
|
|
45
|
+
], post_condition);
|
|
46
|
+
await openContractCall(function_option);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
async withdraw_multisig(addr: string, amount: string){
|
|
50
|
+
|
|
51
|
+
// console.log({amount});
|
|
52
|
+
const post_condition = [await getPostConditionFromAsset(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', this.stackswap.config.BASE_STSW_DATA().addr, amount, FungibleConditionCode.Equal)];
|
|
53
|
+
|
|
54
|
+
const function_option: any = getWriteOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', 'withdraw', [
|
|
55
|
+
parseAddressToCV(addr), uintCV(amount)
|
|
56
|
+
], post_condition);
|
|
57
|
+
await openContractCall(function_option);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
async getMultisigSTSWAmount() {
|
|
61
|
+
// console.log('getStakingSTSWBalance');
|
|
62
|
+
const pair_details_options : any = getReadOptions(this.stackswap, this.stackswap.config.BASE_STSW_DATA().addr, 'get-balance',
|
|
63
|
+
[parseAddressToCV('SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01')]);
|
|
64
|
+
try {
|
|
65
|
+
const result = await callReadOnlyFunction(pair_details_options);
|
|
66
|
+
console.log('get-balance', cvToValue(result));
|
|
67
|
+
return cvToValue(result).value;
|
|
68
|
+
} catch (e) {
|
|
69
|
+
// console.log(e);
|
|
70
|
+
return '0';
|
|
71
|
+
}
|
|
72
|
+
// console.log(pair_details_result)
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
async getMultisigResult(functionName: string) {
|
|
76
|
+
const pair_details_options : any = getReadOptions(this.stackswap, 'SPVRC3RHFD58B2PY1HZD2V71THPW7G445WBRCQYW.octopus_v01', functionName,
|
|
77
|
+
[]);
|
|
78
|
+
const result = await callReadOnlyFunction(pair_details_options);
|
|
79
|
+
console.log(functionName, cvToValue(result));
|
|
80
|
+
return cvToValue(result);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
|