stackswap-front-api-test-02 1.0.82 → 1.0.85

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 (93) hide show
  1. package/README.md +10 -10
  2. package/dist/esm/index.d.ts +84 -84
  3. package/dist/esm/index.js +143 -143
  4. package/dist/esm/stackswap/config.d.ts +112 -112
  5. package/dist/esm/stackswap/config.js +185 -185
  6. package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
  7. package/dist/esm/stackswap/manager/farm.manager.js +293 -293
  8. package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
  9. package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
  10. package/dist/esm/stackswap/manager/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/multisig.manager.d.ts +11 -11
  18. package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
  19. package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
  20. package/dist/esm/stackswap/manager/nft.manager.js +243 -243
  21. package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
  22. package/dist/esm/stackswap/manager/operator.manager.js +85 -85
  23. package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
  24. package/dist/esm/stackswap/manager/other.manager.js +47 -47
  25. package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
  26. package/dist/esm/stackswap/manager/pool.manager.js +171 -175
  27. package/dist/esm/stackswap/manager/pool.manager.js.map +1 -1
  28. package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
  29. package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
  30. package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
  31. package/dist/esm/stackswap/manager/staking.manager.js +233 -233
  32. package/dist/esm/stackswap/manager/swap.manager.d.ts +35 -35
  33. package/dist/esm/stackswap/manager/swap.manager.js +290 -290
  34. package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
  35. package/dist/esm/stackswap/manager/token.manager.js +133 -135
  36. package/dist/esm/stackswap/manager/token.manager.js.map +1 -1
  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 +84 -84
  40. package/dist/index.js +152 -152
  41. package/dist/index.umd.js +1 -1
  42. package/dist/stackswap/config.d.ts +112 -112
  43. package/dist/stackswap/config.js +190 -190
  44. package/dist/stackswap/manager/farm.manager.d.ts +41 -41
  45. package/dist/stackswap/manager/farm.manager.js +301 -301
  46. package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
  47. package/dist/stackswap/manager/farm2.manager.js +410 -410
  48. package/dist/stackswap/manager/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/multisig.manager.d.ts +11 -11
  56. package/dist/stackswap/manager/multisig.manager.js +55 -55
  57. package/dist/stackswap/manager/nft.manager.d.ts +52 -52
  58. package/dist/stackswap/manager/nft.manager.js +250 -250
  59. package/dist/stackswap/manager/operator.manager.d.ts +17 -17
  60. package/dist/stackswap/manager/operator.manager.js +92 -92
  61. package/dist/stackswap/manager/other.manager.d.ts +9 -9
  62. package/dist/stackswap/manager/other.manager.js +54 -54
  63. package/dist/stackswap/manager/pool.manager.d.ts +34 -34
  64. package/dist/stackswap/manager/pool.manager.js +179 -183
  65. package/dist/stackswap/manager/pool.manager.js.map +1 -1
  66. package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
  67. package/dist/stackswap/manager/poxl.manager.js +78 -78
  68. package/dist/stackswap/manager/staking.manager.d.ts +25 -25
  69. package/dist/stackswap/manager/staking.manager.js +240 -240
  70. package/dist/stackswap/manager/swap.manager.d.ts +35 -35
  71. package/dist/stackswap/manager/swap.manager.js +297 -297
  72. package/dist/stackswap/manager/token.manager.d.ts +31 -31
  73. package/dist/stackswap/manager/token.manager.js +141 -143
  74. package/dist/stackswap/manager/token.manager.js.map +1 -1
  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 +204 -204
  79. package/src/stackswap/config.ts +292 -292
  80. package/src/stackswap/manager/farm.manager.ts +399 -399
  81. package/src/stackswap/manager/farm2.manager.ts +463 -463
  82. package/src/stackswap/manager/governance.manager.ts +95 -95
  83. package/src/stackswap/manager/launchpad.manager.ts +190 -190
  84. package/src/stackswap/manager/multisig.manager.ts +87 -87
  85. package/src/stackswap/manager/nft.manager.ts +311 -311
  86. package/src/stackswap/manager/operator.manager.ts +123 -123
  87. package/src/stackswap/manager/other.manager.ts +71 -71
  88. package/src/stackswap/manager/pool.manager.ts +202 -202
  89. package/src/stackswap/manager/poxl.manager.ts +99 -99
  90. package/src/stackswap/manager/staking.manager.ts +321 -321
  91. package/src/stackswap/manager/swap.manager.ts +351 -351
  92. package/src/stackswap/manager/token.manager.ts +167 -167
  93. package/src/stackswap/util.ts +237 -237
@@ -1,327 +1,327 @@
1
- import { getPostConditionFromAsset, getReadOptions, getWriteOptions } from "../util";
2
- import BigNumber from "bignumber.js";
3
- import { callReadOnlyFunction, contractPrincipalCV, cvToValue, falseCV, FungibleConditionCode, standardPrincipalCV, stringAsciiCV, trueCV, uintCV } from "@stacks/transactions";
4
- import { openContractCall } from "@stacks/connect";
5
- export class LbtcManager {
6
- constructor(stackswap) {
7
- this.stackswap = stackswap;
8
- }
9
- async getPoxInfo() {
10
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_POX() + 'pox', 'get-pox-info', []);
11
- const result_raw = await callReadOnlyFunction(function_option);
12
- return cvToValue(result_raw);
13
- }
14
- async getVaultTypeInfo(coll_type) {
15
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES(), 'get-collateral-type-by-name', [stringAsciiCV(coll_type)]);
16
- const result_raw = await callReadOnlyFunction(function_option);
17
- return cvToValue(result_raw);
18
- }
19
- async getVaultIDFromUser() {
20
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_VAULT_DATA(), 'get-vaults', [standardPrincipalCV(this.stackswap.getSenderAddress())]);
21
- const result_raw = await callReadOnlyFunction(function_option);
22
- return cvToValue(result_raw);
23
- }
24
- async getVaultInfoFromID(vault_id) {
25
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_VAULT_DATA(), 'get-vault-by-id', [uintCV(vault_id)]);
26
- const result_raw = await callReadOnlyFunction(function_option);
27
- return cvToValue(result_raw);
28
- }
29
- async getVaultIDFromUser2() {
30
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_VAULT_DATA(), 'get-vault-entries', [standardPrincipalCV(this.stackswap.getSenderAddress())]);
31
- const result_raw = await callReadOnlyFunction(function_option);
32
- return cvToValue(result_raw);
33
- }
34
- async txCreateVaultWithSTX(coll_amt, debt_amt, coll_type, isStack, callback = null) {
35
- let IsStack = trueCV;
36
- if (isStack) {
37
- IsStack = trueCV;
38
- }
39
- else {
40
- IsStack = falseCV;
41
- }
42
- const post_condition = [];
43
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
44
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_MORTGAGER(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
45
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'collateralize-and-mint', [
46
- uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
47
- uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
48
- IsStack(),
49
- stringAsciiCV(coll_type),
50
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_STX_RESERVE()),
51
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
52
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
53
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
54
- ], post_condition, callback);
55
- openContractCall(function_option);
56
- }
57
- async txCreateVaultWithSTSW(coll_amt, debt_amt, coll_type, callback = null) {
58
- const post_condition = [];
59
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
60
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_MORTGAGER(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
61
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'collateralize-and-mint', [
62
- uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
63
- uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
64
- falseCV(),
65
- stringAsciiCV(coll_type),
66
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE()),
67
- contractPrincipalCV(this.stackswap.config.BASE_STSW_DATA().addr.split('.')[0], this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
68
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
69
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
70
- ], post_condition, callback);
71
- openContractCall(function_option);
72
- }
73
- async txDepositCollateral(vault_id, coll_amt, coll_token, callback = null) {
74
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
75
- if (coll_token === 'STX') {
76
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
77
- }
78
- const post_condition = [];
79
- if (coll_token === 'STX') {
80
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
81
- }
82
- else if (coll_token === 'STSW') {
83
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
84
- }
85
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'deposit', [
86
- uintCV(vault_id.toString()),
87
- uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
88
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
89
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
90
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
91
- ], post_condition, callback);
92
- openContractCall(function_option);
93
- }
94
- async txToggleStacking(vault_id, callback = null) {
95
- const post_condition = [];
96
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'toggle-stacking', [
97
- uintCV(vault_id.toString()),
98
- ], post_condition, callback);
99
- openContractCall(function_option);
100
- }
101
- async txStackCollateral(vault_id, callback = null) {
102
- const post_condition = [];
103
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'stack-collateral', [
104
- uintCV(vault_id.toString()),
105
- ], post_condition, callback);
106
- openContractCall(function_option);
107
- }
108
- resolveStacker(stacker_name) {
109
- switch (stacker_name) {
110
- case 'stacker':
111
- return this.stackswap.config.CONTRACT_NAME_STACKER1();
112
- case 'stacker-2':
113
- return this.stackswap.config.CONTRACT_NAME_STACKER2();
114
- case 'stacker-3':
115
- return this.stackswap.config.CONTRACT_NAME_STACKER3();
116
- case 'stacker-4':
117
- return this.stackswap.config.CONTRACT_NAME_STACKER4();
118
- default:
119
- return this.stackswap.config.CONTRACT_NAME_STACKER1();
120
- }
121
- }
122
- async txEnableWithdraw(vault_id, stacker_name, callback = null) {
123
- const post_condition = [];
124
- const function_option = getWriteOptions(this.stackswap, this.resolveStacker(stacker_name), 'enable-vault-withdrawals', [
125
- uintCV(vault_id.toString()),
126
- ], post_condition, callback);
127
- openContractCall(function_option);
128
- }
129
- async txWithdrawCollateral(vault_id, coll_amt, coll_token, callback = null) {
130
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
131
- if (coll_token === 'STX') {
132
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
133
- }
134
- const post_condition = [];
135
- if (coll_token === 'STX') {
136
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + reserve, this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
137
- }
138
- else if (coll_token === 'STSW') {
139
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + reserve, this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
140
- }
141
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'withdraw', [
142
- uintCV(vault_id.toString()),
143
- uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
144
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
145
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
146
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
147
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
148
- ], post_condition, callback);
149
- openContractCall(function_option);
150
- }
151
- async txMintDebt(vault_id, debt_amt, coll_token, callback = null) {
152
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
153
- if (coll_token === 'STX') {
154
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
155
- }
156
- const post_condition = [];
157
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + reserve, this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
158
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'mint', [
159
- uintCV(vault_id.toString()),
160
- uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
161
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
162
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
163
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
164
- ], post_condition, callback);
165
- openContractCall(function_option);
166
- }
167
- async txBurnDebt(vault_id, debt_amt, coll_token, callback = null) {
168
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
169
- if (coll_token === 'STX') {
170
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
171
- }
172
- const post_condition = [];
173
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.GreaterEqual));
174
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'burn', [
175
- uintCV(vault_id.toString()),
176
- uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
177
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
178
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
179
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
180
- ], post_condition, callback);
181
- openContractCall(function_option);
182
- }
183
- async txCloseVault(vault_id, coll_token, coll_amount, debt_amount, callback = null) {
184
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
185
- const post_condition = [];
186
- if (coll_token === 'STX') {
187
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
188
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STX_RESERVE(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amount, FungibleConditionCode.Equal));
189
- }
190
- else {
191
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amount, FungibleConditionCode.Equal));
192
- }
193
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, new BigNumber(debt_amount).multipliedBy(10 ** 8).multipliedBy(1.001).toFixed(0), FungibleConditionCode.LessEqual));
194
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'close-vault', [
195
- uintCV(vault_id.toString()),
196
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
197
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
198
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
199
- ], post_condition, callback);
200
- openContractCall(function_option);
201
- }
202
- async txFinalLiquidation(vault_id, callback = null) {
203
- const post_condition = [];
204
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'finalize-liquidation', [
205
- uintCV(vault_id.toString()),
206
- ], post_condition, callback);
207
- openContractCall(function_option);
208
- }
209
- async txUnliquidationDeposit(vault_id, coll_amt, coll_token, callback = null) {
210
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
211
- if (coll_token === 'STX') {
212
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
213
- }
214
- const post_condition = [];
215
- if (coll_token === 'STX') {
216
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
217
- }
218
- else if (coll_token === 'STSW') {
219
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
220
- }
221
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'deposit-to-unliquidate', [
222
- uintCV(vault_id.toString()),
223
- uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
224
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
225
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
226
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
227
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
228
- ], post_condition, callback);
229
- openContractCall(function_option);
230
- }
231
- async txUnliquidationBurn(vault_id, debt_amt, coll_token, callback = null) {
232
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
233
- if (coll_token === 'STX') {
234
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
235
- }
236
- const post_condition = [];
237
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.GreaterEqual));
238
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'burn-to-unliquidate', [
239
- uintCV(vault_id.toString()),
240
- uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
241
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
242
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
243
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
244
- ], post_condition, callback);
245
- openContractCall(function_option);
246
- }
247
- async txLiquidationWithdraw(vault_id, coll_amt, coll_token, callback = null) {
248
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
249
- if (coll_token === 'STX') {
250
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
251
- }
252
- const post_condition = [];
253
- if (coll_token === 'STX') {
254
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
255
- }
256
- else if (coll_token === 'STSW') {
257
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
258
- }
259
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'withdraw-liquidated', [
260
- uintCV(vault_id.toString()),
261
- uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
262
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
263
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
264
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
265
- ], post_condition, callback);
266
- openContractCall(function_option);
267
- }
268
- async txLiquidationBurn(vault_id, debt_amt, coll_token, callback = null) {
269
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
270
- if (coll_token === 'STX') {
271
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
272
- }
273
- const post_condition = [];
274
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
275
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'burn-liquidated', [
276
- uintCV(vault_id.toString()),
277
- uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
278
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
279
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
280
- ], post_condition, callback);
281
- openContractCall(function_option);
282
- }
283
- async txCloseVaultLiquidated(vault_id, coll_token, callback = null) {
284
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
285
- if (coll_token === 'STX') {
286
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
287
- }
288
- const post_condition = [];
289
- const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'close-vault-liquidated', [
290
- uintCV(vault_id.toString()),
291
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
292
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
293
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
294
- ], post_condition, callback);
295
- openContractCall(function_option);
296
- }
297
- async getDebtRatio(coll_amt, debt_amt, coll_token) {
298
- let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
299
- if (coll_token === 'STX') {
300
- reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
301
- }
302
- const function_option = getReadOptions(this.stackswap, reserve, 'calculate-current-collateral-to-debt-ratio', [
303
- stringAsciiCV(coll_token),
304
- uintCV(debt_amt.multipliedBy(10 ** 8).toFixed(0)),
305
- uintCV(coll_amt.multipliedBy(10 ** 6).toFixed(0)),
306
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
307
- ]);
308
- const result_raw = await callReadOnlyFunction(function_option);
309
- return cvToValue(result_raw);
310
- }
311
- async getPrice(token) {
312
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_ORACLE(), 'get-price', [
313
- stringAsciiCV(token)
314
- ]);
315
- const result_raw = await callReadOnlyFunction(function_option);
316
- return cvToValue(result_raw);
317
- }
318
- async getStabilityFee(vault_id) {
319
- const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'get-stability-fee-for-vault', [
320
- uintCV(vault_id),
321
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
322
- ]);
323
- const result_raw = await callReadOnlyFunction(function_option);
324
- return cvToValue(result_raw);
325
- }
326
- }
1
+ import { getPostConditionFromAsset, getReadOptions, getWriteOptions } from "../util";
2
+ import BigNumber from "bignumber.js";
3
+ import { callReadOnlyFunction, contractPrincipalCV, cvToValue, falseCV, FungibleConditionCode, standardPrincipalCV, stringAsciiCV, trueCV, uintCV } from "@stacks/transactions";
4
+ import { openContractCall } from "@stacks/connect";
5
+ export class LbtcManager {
6
+ constructor(stackswap) {
7
+ this.stackswap = stackswap;
8
+ }
9
+ async getPoxInfo() {
10
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_POX() + 'pox', 'get-pox-info', []);
11
+ const result_raw = await callReadOnlyFunction(function_option);
12
+ return cvToValue(result_raw);
13
+ }
14
+ async getVaultTypeInfo(coll_type) {
15
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES(), 'get-collateral-type-by-name', [stringAsciiCV(coll_type)]);
16
+ const result_raw = await callReadOnlyFunction(function_option);
17
+ return cvToValue(result_raw);
18
+ }
19
+ async getVaultIDFromUser() {
20
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_VAULT_DATA(), 'get-vaults', [standardPrincipalCV(this.stackswap.getSenderAddress())]);
21
+ const result_raw = await callReadOnlyFunction(function_option);
22
+ return cvToValue(result_raw);
23
+ }
24
+ async getVaultInfoFromID(vault_id) {
25
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_VAULT_DATA(), 'get-vault-by-id', [uintCV(vault_id)]);
26
+ const result_raw = await callReadOnlyFunction(function_option);
27
+ return cvToValue(result_raw);
28
+ }
29
+ async getVaultIDFromUser2() {
30
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_VAULT_DATA(), 'get-vault-entries', [standardPrincipalCV(this.stackswap.getSenderAddress())]);
31
+ const result_raw = await callReadOnlyFunction(function_option);
32
+ return cvToValue(result_raw);
33
+ }
34
+ async txCreateVaultWithSTX(coll_amt, debt_amt, coll_type, isStack, callback = null) {
35
+ let IsStack = trueCV;
36
+ if (isStack) {
37
+ IsStack = trueCV;
38
+ }
39
+ else {
40
+ IsStack = falseCV;
41
+ }
42
+ const post_condition = [];
43
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
44
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_MORTGAGER(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
45
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'collateralize-and-mint', [
46
+ uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
47
+ uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
48
+ IsStack(),
49
+ stringAsciiCV(coll_type),
50
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_STX_RESERVE()),
51
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
52
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
53
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
54
+ ], post_condition, callback);
55
+ openContractCall(function_option);
56
+ }
57
+ async txCreateVaultWithSTSW(coll_amt, debt_amt, coll_type, callback = null) {
58
+ const post_condition = [];
59
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
60
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_MORTGAGER(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
61
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'collateralize-and-mint', [
62
+ uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
63
+ uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
64
+ falseCV(),
65
+ stringAsciiCV(coll_type),
66
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE()),
67
+ contractPrincipalCV(this.stackswap.config.BASE_STSW_DATA().addr.split('.')[0], this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
68
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
69
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
70
+ ], post_condition, callback);
71
+ openContractCall(function_option);
72
+ }
73
+ async txDepositCollateral(vault_id, coll_amt, coll_token, callback = null) {
74
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
75
+ if (coll_token === 'STX') {
76
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
77
+ }
78
+ const post_condition = [];
79
+ if (coll_token === 'STX') {
80
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
81
+ }
82
+ else if (coll_token === 'STSW') {
83
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
84
+ }
85
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'deposit', [
86
+ uintCV(vault_id.toString()),
87
+ uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
88
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
89
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
90
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
91
+ ], post_condition, callback);
92
+ openContractCall(function_option);
93
+ }
94
+ async txToggleStacking(vault_id, callback = null) {
95
+ const post_condition = [];
96
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'toggle-stacking', [
97
+ uintCV(vault_id.toString()),
98
+ ], post_condition, callback);
99
+ openContractCall(function_option);
100
+ }
101
+ async txStackCollateral(vault_id, callback = null) {
102
+ const post_condition = [];
103
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'stack-collateral', [
104
+ uintCV(vault_id.toString()),
105
+ ], post_condition, callback);
106
+ openContractCall(function_option);
107
+ }
108
+ resolveStacker(stacker_name) {
109
+ switch (stacker_name) {
110
+ case 'stacker':
111
+ return this.stackswap.config.CONTRACT_NAME_STACKER1();
112
+ case 'stacker-2':
113
+ return this.stackswap.config.CONTRACT_NAME_STACKER2();
114
+ case 'stacker-3':
115
+ return this.stackswap.config.CONTRACT_NAME_STACKER3();
116
+ case 'stacker-4':
117
+ return this.stackswap.config.CONTRACT_NAME_STACKER4();
118
+ default:
119
+ return this.stackswap.config.CONTRACT_NAME_STACKER1();
120
+ }
121
+ }
122
+ async txEnableWithdraw(vault_id, stacker_name, callback = null) {
123
+ const post_condition = [];
124
+ const function_option = getWriteOptions(this.stackswap, this.resolveStacker(stacker_name), 'enable-vault-withdrawals', [
125
+ uintCV(vault_id.toString()),
126
+ ], post_condition, callback);
127
+ openContractCall(function_option);
128
+ }
129
+ async txWithdrawCollateral(vault_id, coll_amt, coll_token, callback = null) {
130
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
131
+ if (coll_token === 'STX') {
132
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
133
+ }
134
+ const post_condition = [];
135
+ if (coll_token === 'STX') {
136
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + reserve, this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
137
+ }
138
+ else if (coll_token === 'STSW') {
139
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + reserve, this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
140
+ }
141
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'withdraw', [
142
+ uintCV(vault_id.toString()),
143
+ uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
144
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
145
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
146
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
147
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
148
+ ], post_condition, callback);
149
+ openContractCall(function_option);
150
+ }
151
+ async txMintDebt(vault_id, debt_amt, coll_token, callback = null) {
152
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
153
+ if (coll_token === 'STX') {
154
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
155
+ }
156
+ const post_condition = [];
157
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + reserve, this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
158
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'mint', [
159
+ uintCV(vault_id.toString()),
160
+ uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
161
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
162
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
163
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
164
+ ], post_condition, callback);
165
+ openContractCall(function_option);
166
+ }
167
+ async txBurnDebt(vault_id, debt_amt, coll_token, callback = null) {
168
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
169
+ if (coll_token === 'STX') {
170
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
171
+ }
172
+ const post_condition = [];
173
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.GreaterEqual));
174
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'burn', [
175
+ uintCV(vault_id.toString()),
176
+ uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
177
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
178
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
179
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
180
+ ], post_condition, callback);
181
+ openContractCall(function_option);
182
+ }
183
+ async txCloseVault(vault_id, coll_token, coll_amount, debt_amount, callback = null) {
184
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
185
+ const post_condition = [];
186
+ if (coll_token === 'STX') {
187
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
188
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_STX_RESERVE(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amount, FungibleConditionCode.Equal));
189
+ }
190
+ else {
191
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amount, FungibleConditionCode.Equal));
192
+ }
193
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, new BigNumber(debt_amount).multipliedBy(10 ** 8).multipliedBy(1.001).toFixed(0), FungibleConditionCode.LessEqual));
194
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'close-vault', [
195
+ uintCV(vault_id.toString()),
196
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
197
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
198
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
199
+ ], post_condition, callback);
200
+ openContractCall(function_option);
201
+ }
202
+ async txFinalLiquidation(vault_id, callback = null) {
203
+ const post_condition = [];
204
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'finalize-liquidation', [
205
+ uintCV(vault_id.toString()),
206
+ ], post_condition, callback);
207
+ openContractCall(function_option);
208
+ }
209
+ async txUnliquidationDeposit(vault_id, coll_amt, coll_token, callback = null) {
210
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
211
+ if (coll_token === 'STX') {
212
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
213
+ }
214
+ const post_condition = [];
215
+ if (coll_token === 'STX') {
216
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
217
+ }
218
+ else if (coll_token === 'STSW') {
219
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, coll_amt.multipliedBy(10 ** 6).toString(), FungibleConditionCode.Equal));
220
+ }
221
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'deposit-to-unliquidate', [
222
+ uintCV(vault_id.toString()),
223
+ uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
224
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
225
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
226
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
227
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
228
+ ], post_condition, callback);
229
+ openContractCall(function_option);
230
+ }
231
+ async txUnliquidationBurn(vault_id, debt_amt, coll_token, callback = null) {
232
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
233
+ if (coll_token === 'STX') {
234
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
235
+ }
236
+ const post_condition = [];
237
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.GreaterEqual));
238
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'burn-to-unliquidate', [
239
+ uintCV(vault_id.toString()),
240
+ uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
241
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
242
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
243
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
244
+ ], post_condition, callback);
245
+ openContractCall(function_option);
246
+ }
247
+ async txLiquidationWithdraw(vault_id, coll_amt, coll_token, callback = null) {
248
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
249
+ if (coll_token === 'STX') {
250
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
251
+ }
252
+ const post_condition = [];
253
+ if (coll_token === 'STX') {
254
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
255
+ }
256
+ else if (coll_token === 'STSW') {
257
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
258
+ }
259
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'withdraw-liquidated', [
260
+ uintCV(vault_id.toString()),
261
+ uintCV(coll_amt.multipliedBy(10 ** 6).toString()),
262
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
263
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
264
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
265
+ ], post_condition, callback);
266
+ openContractCall(function_option);
267
+ }
268
+ async txLiquidationBurn(vault_id, debt_amt, coll_token, callback = null) {
269
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
270
+ if (coll_token === 'STX') {
271
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
272
+ }
273
+ const post_condition = [];
274
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_LBTC_DATA().addr, debt_amt.multipliedBy(10 ** 8).toString(), FungibleConditionCode.LessEqual));
275
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'burn-liquidated', [
276
+ uintCV(vault_id.toString()),
277
+ uintCV(debt_amt.multipliedBy(10 ** 8).toString()),
278
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
279
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
280
+ ], post_condition, callback);
281
+ openContractCall(function_option);
282
+ }
283
+ async txCloseVaultLiquidated(vault_id, coll_token, callback = null) {
284
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
285
+ if (coll_token === 'STX') {
286
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
287
+ }
288
+ const post_condition = [];
289
+ const function_option = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'close-vault-liquidated', [
290
+ uintCV(vault_id.toString()),
291
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), reserve),
292
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_STSW_DATA().addr.split('.')[1]),
293
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES())
294
+ ], post_condition, callback);
295
+ openContractCall(function_option);
296
+ }
297
+ async getDebtRatio(coll_amt, debt_amt, coll_token) {
298
+ let reserve = this.stackswap.config.CONTRACT_NAME_SIP10_RESERVE();
299
+ if (coll_token === 'STX') {
300
+ reserve = this.stackswap.config.CONTRACT_NAME_STX_RESERVE();
301
+ }
302
+ const function_option = getReadOptions(this.stackswap, reserve, 'calculate-current-collateral-to-debt-ratio', [
303
+ stringAsciiCV(coll_token),
304
+ uintCV(debt_amt.multipliedBy(10 ** 8).toFixed(0)),
305
+ uintCV(coll_amt.multipliedBy(10 ** 6).toFixed(0)),
306
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_ORACLE())
307
+ ]);
308
+ const result_raw = await callReadOnlyFunction(function_option);
309
+ return cvToValue(result_raw);
310
+ }
311
+ async getPrice(token) {
312
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_ORACLE(), 'get-price', [
313
+ stringAsciiCV(token)
314
+ ]);
315
+ const result_raw = await callReadOnlyFunction(function_option);
316
+ return cvToValue(result_raw);
317
+ }
318
+ async getStabilityFee(vault_id) {
319
+ const function_option = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_MORTGAGER(), 'get-stability-fee-for-vault', [
320
+ uintCV(vault_id),
321
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.CONTRACT_NAME_COLLATERAL_TYPES()),
322
+ ]);
323
+ const result_raw = await callReadOnlyFunction(function_option);
324
+ return cvToValue(result_raw);
325
+ }
326
+ }
327
327
  //# sourceMappingURL=lbtc.manager.js.map