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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (100) hide show
  1. package/README.md +10 -10
  2. package/dist/esm/index.d.ts +86 -86
  3. package/dist/esm/index.js +145 -145
  4. package/dist/esm/index.js.map +1 -1
  5. package/dist/esm/stackswap/config.d.ts +117 -114
  6. package/dist/esm/stackswap/config.js +194 -188
  7. package/dist/esm/stackswap/config.js.map +1 -1
  8. package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
  9. package/dist/esm/stackswap/manager/farm.manager.js +293 -293
  10. package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
  11. package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
  12. package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
  13. package/dist/esm/stackswap/manager/governance.manager.js +53 -53
  14. package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
  15. package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
  16. package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
  17. package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
  18. package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
  19. package/dist/esm/stackswap/manager/lbtcstaking.manager.js +191 -191
  20. package/dist/esm/stackswap/manager/lbtcstaking.manager.js.map +1 -1
  21. package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
  22. package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
  23. package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
  24. package/dist/esm/stackswap/manager/nft.manager.js +243 -243
  25. package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
  26. package/dist/esm/stackswap/manager/operator.manager.js +85 -85
  27. package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
  28. package/dist/esm/stackswap/manager/other.manager.js +47 -47
  29. package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
  30. package/dist/esm/stackswap/manager/pool.manager.js +171 -171
  31. package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
  32. package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
  33. package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
  34. package/dist/esm/stackswap/manager/staking.manager.js +233 -233
  35. package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
  36. package/dist/esm/stackswap/manager/swap.manager.js +332 -332
  37. package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
  38. package/dist/esm/stackswap/manager/token.manager.js +133 -133
  39. package/dist/esm/stackswap/util.d.ts +35 -35
  40. package/dist/esm/stackswap/util.js +201 -201
  41. package/dist/esm/stackswap/util.js.map +1 -1
  42. package/dist/index.d.ts +86 -86
  43. package/dist/index.js +154 -154
  44. package/dist/index.js.map +1 -1
  45. package/dist/index.umd.js +1 -1
  46. package/dist/stackswap/config.d.ts +117 -114
  47. package/dist/stackswap/config.js +199 -193
  48. package/dist/stackswap/config.js.map +1 -1
  49. package/dist/stackswap/manager/farm.manager.d.ts +41 -41
  50. package/dist/stackswap/manager/farm.manager.js +301 -301
  51. package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
  52. package/dist/stackswap/manager/farm2.manager.js +410 -410
  53. package/dist/stackswap/manager/governance.manager.d.ts +9 -9
  54. package/dist/stackswap/manager/governance.manager.js +60 -60
  55. package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
  56. package/dist/stackswap/manager/launchpad.manager.js +151 -151
  57. package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
  58. package/dist/stackswap/manager/lbtc.manager.js +333 -333
  59. package/dist/stackswap/manager/lbtcstaking.manager.d.ts +51 -51
  60. package/dist/stackswap/manager/lbtcstaking.manager.js +198 -198
  61. package/dist/stackswap/manager/lbtcstaking.manager.js.map +1 -1
  62. package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
  63. package/dist/stackswap/manager/multisig.manager.js +55 -55
  64. package/dist/stackswap/manager/nft.manager.d.ts +52 -52
  65. package/dist/stackswap/manager/nft.manager.js +250 -250
  66. package/dist/stackswap/manager/operator.manager.d.ts +17 -17
  67. package/dist/stackswap/manager/operator.manager.js +92 -92
  68. package/dist/stackswap/manager/other.manager.d.ts +9 -9
  69. package/dist/stackswap/manager/other.manager.js +54 -54
  70. package/dist/stackswap/manager/pool.manager.d.ts +34 -34
  71. package/dist/stackswap/manager/pool.manager.js +179 -179
  72. package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
  73. package/dist/stackswap/manager/poxl.manager.js +78 -78
  74. package/dist/stackswap/manager/staking.manager.d.ts +25 -25
  75. package/dist/stackswap/manager/staking.manager.js +240 -240
  76. package/dist/stackswap/manager/swap.manager.d.ts +39 -39
  77. package/dist/stackswap/manager/swap.manager.js +339 -339
  78. package/dist/stackswap/manager/token.manager.d.ts +31 -31
  79. package/dist/stackswap/manager/token.manager.js +141 -141
  80. package/dist/stackswap/util.d.ts +35 -35
  81. package/dist/stackswap/util.js +218 -218
  82. package/dist/stackswap/util.js.map +1 -1
  83. package/package.json +43 -43
  84. package/src/index.ts +207 -207
  85. package/src/stackswap/config.ts +305 -297
  86. package/src/stackswap/manager/farm.manager.ts +399 -399
  87. package/src/stackswap/manager/farm2.manager.ts +463 -463
  88. package/src/stackswap/manager/governance.manager.ts +95 -95
  89. package/src/stackswap/manager/launchpad.manager.ts +190 -190
  90. package/src/stackswap/manager/lbtcstaking.manager.ts +277 -277
  91. package/src/stackswap/manager/multisig.manager.ts +87 -87
  92. package/src/stackswap/manager/nft.manager.ts +307 -307
  93. package/src/stackswap/manager/operator.manager.ts +123 -123
  94. package/src/stackswap/manager/other.manager.ts +71 -71
  95. package/src/stackswap/manager/pool.manager.ts +202 -202
  96. package/src/stackswap/manager/poxl.manager.ts +99 -99
  97. package/src/stackswap/manager/staking.manager.ts +321 -321
  98. package/src/stackswap/manager/swap.manager.ts +392 -392
  99. package/src/stackswap/manager/token.manager.ts +167 -167
  100. 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