stackswap-front-api-test-02 1.0.89 → 1.0.92
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +10 -10
- package/dist/esm/index.d.ts +86 -84
- package/dist/esm/index.js +145 -143
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/stackswap/config.d.ts +114 -112
- package/dist/esm/stackswap/config.js +188 -185
- package/dist/esm/stackswap/config.js.map +1 -1
- package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/esm/stackswap/manager/farm.manager.js +293 -293
- package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
- package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/governance.manager.js +53 -53
- package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
- package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
- package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js +153 -0
- package/dist/esm/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
- package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/esm/stackswap/manager/nft.manager.js +243 -243
- package/dist/esm/stackswap/manager/nft.manager.js.map +1 -1
- package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/esm/stackswap/manager/operator.manager.js +85 -85
- package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/esm/stackswap/manager/other.manager.js +47 -47
- package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/esm/stackswap/manager/pool.manager.js +171 -171
- package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
- package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/esm/stackswap/manager/staking.manager.js +233 -233
- package/dist/esm/stackswap/manager/staking.manager.js.map +1 -1
- package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/esm/stackswap/manager/swap.manager.js +332 -332
- package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
- package/dist/esm/stackswap/manager/token.manager.js +133 -133
- package/dist/esm/stackswap/util.d.ts +35 -35
- package/dist/esm/stackswap/util.js +201 -201
- package/dist/index.d.ts +86 -84
- package/dist/index.js +154 -152
- package/dist/index.js.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/stackswap/config.d.ts +114 -112
- package/dist/stackswap/config.js +193 -190
- package/dist/stackswap/config.js.map +1 -1
- package/dist/stackswap/manager/farm.manager.d.ts +41 -41
- package/dist/stackswap/manager/farm.manager.js +301 -301
- package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
- package/dist/stackswap/manager/farm2.manager.js +410 -410
- package/dist/stackswap/manager/governance.manager.d.ts +9 -9
- package/dist/stackswap/manager/governance.manager.js +60 -60
- package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
- package/dist/stackswap/manager/launchpad.manager.js +151 -151
- package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
- package/dist/stackswap/manager/lbtc.manager.js +333 -333
- package/dist/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js +160 -0
- package/dist/stackswap/manager/lbtcstaking.manager.js.map +1 -0
- package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
- package/dist/stackswap/manager/multisig.manager.js +55 -55
- package/dist/stackswap/manager/nft.manager.d.ts +52 -52
- package/dist/stackswap/manager/nft.manager.js +250 -250
- package/dist/stackswap/manager/nft.manager.js.map +1 -1
- package/dist/stackswap/manager/operator.manager.d.ts +17 -17
- package/dist/stackswap/manager/operator.manager.js +92 -92
- package/dist/stackswap/manager/other.manager.d.ts +9 -9
- package/dist/stackswap/manager/other.manager.js +54 -54
- package/dist/stackswap/manager/pool.manager.d.ts +34 -34
- package/dist/stackswap/manager/pool.manager.js +179 -179
- package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
- package/dist/stackswap/manager/poxl.manager.js +78 -78
- package/dist/stackswap/manager/staking.manager.d.ts +25 -25
- package/dist/stackswap/manager/staking.manager.js +240 -240
- package/dist/stackswap/manager/staking.manager.js.map +1 -1
- package/dist/stackswap/manager/swap.manager.d.ts +39 -39
- package/dist/stackswap/manager/swap.manager.js +339 -339
- package/dist/stackswap/manager/token.manager.d.ts +31 -31
- package/dist/stackswap/manager/token.manager.js +141 -141
- package/dist/stackswap/util.d.ts +35 -35
- package/dist/stackswap/util.js +218 -218
- package/package.json +43 -43
- package/src/index.ts +207 -204
- package/src/stackswap/config.ts +297 -292
- package/src/stackswap/manager/farm.manager.ts +399 -399
- package/src/stackswap/manager/farm2.manager.ts +463 -463
- package/src/stackswap/manager/governance.manager.ts +95 -95
- package/src/stackswap/manager/launchpad.manager.ts +190 -190
- package/src/stackswap/manager/lbtcstaking.manager.ts +219 -0
- package/src/stackswap/manager/multisig.manager.ts +87 -87
- package/src/stackswap/manager/nft.manager.ts +307 -311
- package/src/stackswap/manager/operator.manager.ts +123 -123
- package/src/stackswap/manager/other.manager.ts +71 -71
- package/src/stackswap/manager/pool.manager.ts +202 -202
- package/src/stackswap/manager/poxl.manager.ts +99 -99
- package/src/stackswap/manager/staking.manager.ts +321 -321
- package/src/stackswap/manager/swap.manager.ts +392 -392
- package/src/stackswap/manager/token.manager.ts +167 -167
- package/src/stackswap/util.ts +237 -237
|
@@ -1,172 +1,172 @@
|
|
|
1
|
-
import { callReadOnlyFunction, cvToValue } from "@stacks/transactions";
|
|
2
|
-
import BigNumber from "bignumber.js";
|
|
3
|
-
import axios from "axios";
|
|
4
|
-
import { decimal2integer, getPriceAndDY, getReadOptions, parseAddressToCV } from "../util";
|
|
5
|
-
import { Token } from "./token.manager";
|
|
6
|
-
export class LiquidityPool {
|
|
7
|
-
constructor(name, token_x, token_y, token_lp, balance_x = '0', balance_y = '0', share_total = '0') {
|
|
8
|
-
this.loaded = false;
|
|
9
|
-
this.balance_x = '0';
|
|
10
|
-
this.balance_y = '0';
|
|
11
|
-
this.share_total = '0';
|
|
12
|
-
this.name = name;
|
|
13
|
-
this.token_x = token_x;
|
|
14
|
-
this.token_y = token_y;
|
|
15
|
-
this.token_lp = token_lp;
|
|
16
|
-
this.balance_x = balance_x;
|
|
17
|
-
this.balance_y = balance_y;
|
|
18
|
-
this.share_total = share_total;
|
|
19
|
-
}
|
|
20
|
-
getTokenX(direction = true) {
|
|
21
|
-
return direction ? this.token_x : this.token_y;
|
|
22
|
-
}
|
|
23
|
-
getTokenY(direction = true) {
|
|
24
|
-
return direction ? this.token_y : this.token_x;
|
|
25
|
-
}
|
|
26
|
-
toString() {
|
|
27
|
-
return '' + { name: this.name, token_x: this.token_x.toString(), token_y: this.token_y.toString(), token_lp: this.token_lp.toString(), balance_x: this.balance_x, balance_y: this.balance_y, share_total: this.share_total, loaded: this.loaded };
|
|
28
|
-
}
|
|
29
|
-
static parsePoolFromJson(data) {
|
|
30
|
-
if (data.share_total != null) {
|
|
31
|
-
return new LiquidityPool(data.name, Token.parseTokenFromJson(data.token_x), Token.parseTokenFromJson(data.token_y), Token.parseTokenFromJson(data.token_lp), data.balance_x, data.balance_y, data.share_total);
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
return new LiquidityPool(data.name, Token.parseTokenFromJson(data.token_x), Token.parseTokenFromJson(data.token_y), new Token(data.name, 6, '', data.token_swapr, data.name));
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
static parsePoolsFromJsonList(datas) {
|
|
38
|
-
const temp_list = [];
|
|
39
|
-
for (const data of datas) {
|
|
40
|
-
temp_list.push(LiquidityPool.parsePoolFromJson(data));
|
|
41
|
-
}
|
|
42
|
-
return temp_list;
|
|
43
|
-
}
|
|
44
|
-
static parsePoolsFromServerData(pair, token_x, token_y, direction = true) {
|
|
45
|
-
if (direction) {
|
|
46
|
-
const temp = new LiquidityPool(pair.name.value, token_x, token_y, new Token(pair.name.value, 6, '', pair['liquidity-token'].value, pair.name.value), pair['balance-x'].value, pair['balance-y'].value, pair['shares-total'].value);
|
|
47
|
-
temp.loaded = true;
|
|
48
|
-
return temp;
|
|
49
|
-
}
|
|
50
|
-
else {
|
|
51
|
-
const temp = new LiquidityPool(pair.name.value, token_y, token_x, new Token(pair.name.value, 6, '', pair['liquidity-token'].value, pair.name.value), pair['balance-x'].value, pair['balance-y'].value, pair['shares-total'].value);
|
|
52
|
-
temp.loaded = true;
|
|
53
|
-
return temp;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
static parsePoolsFromServerData2(pair, token_x, token_y, direction = true) {
|
|
57
|
-
if (direction) {
|
|
58
|
-
const temp = new LiquidityPool(pair.name, token_x, token_y, new Token(pair.name, 6, '', pair['liquidity-token'], pair.name), pair['balance-x'], pair['balance-y'], pair['shares-total']);
|
|
59
|
-
temp.loaded = true;
|
|
60
|
-
return temp;
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
const temp = new LiquidityPool(pair.name, token_y, token_x, new Token(pair.name, 6, '', pair['liquidity-token'], pair.name), pair['balance-x'], pair['balance-y'], pair['shares-total']);
|
|
64
|
-
temp.loaded = true;
|
|
65
|
-
return temp;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
static parsePoolsFromDBData(data) {
|
|
69
|
-
const temp = new LiquidityPool(data.pair_name, Token.parseTokenFromJson(data.token_x), Token.parseTokenFromJson(data.token_y), new Token(data.pair_name, 6, '', data.pair_addr, data.pair_name), decimal2integer(data.balance_token_x, data.token_x.decimal), decimal2integer(data.balance_token_y, data.token_y.decimal), data.total_lp_amt);
|
|
70
|
-
temp.loaded = true;
|
|
71
|
-
return temp;
|
|
72
|
-
}
|
|
73
|
-
getPoolPrice(inverted = false, amount = '-1') {
|
|
74
|
-
if (this.share_total === '0') {
|
|
75
|
-
return { dy: '0', output_price: '0' };
|
|
76
|
-
}
|
|
77
|
-
if (inverted) {
|
|
78
|
-
return getPriceAndDY(this, amount, false);
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
return getPriceAndDY(this, amount, true);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
getPoolTVL(stackswap, pool, stx_usd, stsw_usd, btc_usd) {
|
|
85
|
-
const x_token_addr = pool.token_x.addr;
|
|
86
|
-
const y_token_addr = pool.token_y.addr;
|
|
87
|
-
let total_balance = new BigNumber(-1);
|
|
88
|
-
let total_price = -1;
|
|
89
|
-
if (x_token_addr === stackswap.config.BASE_WSTX_DATA().addr) {
|
|
90
|
-
total_balance = (new BigNumber(pool.balance_x).dividedBy(new BigNumber(10 ** pool.token_x.decimal))).multipliedBy(2);
|
|
91
|
-
total_price = total_balance.multipliedBy(stx_usd).toNumber();
|
|
92
|
-
}
|
|
93
|
-
else if (y_token_addr === stackswap.config.BASE_WSTX_DATA().addr) {
|
|
94
|
-
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_y.decimal))).multipliedBy(2);
|
|
95
|
-
total_price = total_balance.multipliedBy(stx_usd).toNumber();
|
|
96
|
-
}
|
|
97
|
-
else if (x_token_addr === stackswap.config.BASE_STSW_DATA().addr) {
|
|
98
|
-
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_x.decimal))).multipliedBy(2);
|
|
99
|
-
total_price = total_balance.multipliedBy(stsw_usd).toNumber();
|
|
100
|
-
}
|
|
101
|
-
else if (y_token_addr === stackswap.config.BASE_STSW_DATA().addr) {
|
|
102
|
-
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_y.decimal))).multipliedBy(2);
|
|
103
|
-
total_price = total_balance.multipliedBy(stsw_usd).toNumber();
|
|
104
|
-
}
|
|
105
|
-
else if (x_token_addr === stackswap.config.BASE_LBTC_DATA().addr) {
|
|
106
|
-
total_balance = (new BigNumber(pool.balance_x).dividedBy(new BigNumber(10 ** pool.token_x.decimal))).multipliedBy(2);
|
|
107
|
-
total_price = total_balance.multipliedBy(btc_usd).toNumber();
|
|
108
|
-
}
|
|
109
|
-
else if (y_token_addr === stackswap.config.BASE_LBTC_DATA().addr) {
|
|
110
|
-
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_y.decimal))).multipliedBy(2);
|
|
111
|
-
total_price = total_balance.multipliedBy(btc_usd).toNumber();
|
|
112
|
-
}
|
|
113
|
-
return total_price;
|
|
114
|
-
}
|
|
115
|
-
getNewPoolShareRatio(token_amount, inversed) {
|
|
116
|
-
if (this.loaded) {
|
|
117
|
-
try {
|
|
118
|
-
const token_input = new BigNumber(token_amount);
|
|
119
|
-
const token_in_pool = new BigNumber(inversed ? this.balance_x : this.balance_y);
|
|
120
|
-
const token_in_pool_new = token_input.plus(token_in_pool);
|
|
121
|
-
const temp = (token_input.dividedBy(token_in_pool_new).multipliedBy(100)).toNumber();
|
|
122
|
-
if (!isNaN(temp)) {
|
|
123
|
-
return temp;
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
return 0;
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
catch (e) {
|
|
130
|
-
return 0;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
else {
|
|
134
|
-
return 0;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
export class PoolManager {
|
|
139
|
-
constructor(stackswap) {
|
|
140
|
-
this.stackswap = stackswap;
|
|
141
|
-
}
|
|
142
|
-
async getPoolLists() {
|
|
143
|
-
const url1 = this.stackswap.config.STACKS_BACKEND_URL() + '/stacks/pair/' + this.stackswap.config.STACKS_BACKEND_PARAM();
|
|
144
|
-
const res1 = await axios.get(url1, {
|
|
145
|
-
timeout: 30000,
|
|
146
|
-
});
|
|
147
|
-
return LiquidityPool.parsePoolsFromJsonList(res1.data);
|
|
148
|
-
}
|
|
149
|
-
async getPairDataFromContract(token_x, token_y) {
|
|
150
|
-
const pair_details_options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_SWAP(), 'get-pair-details', [parseAddressToCV(token_x.addr), parseAddressToCV(token_y.addr)]);
|
|
151
|
-
try {
|
|
152
|
-
const result = await callReadOnlyFunction(pair_details_options);
|
|
153
|
-
const result2 = await callReadOnlyFunction(getReadOptions(this.stackswap, cvToValue(result)['liquidity-token'].value, 'get-lp-data', []));
|
|
154
|
-
return LiquidityPool.parsePoolsFromServerData(cvToValue(result2).value, token_x, token_y, true);
|
|
155
|
-
}
|
|
156
|
-
catch (e) {
|
|
157
|
-
return null;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
async getPoolDatasLegacy(token_x, token_y, swap_contract) {
|
|
161
|
-
const pair_details_options = getReadOptions(this.stackswap, swap_contract, 'get-pair-details', [parseAddressToCV(token_x.addr), parseAddressToCV(token_y.addr)]);
|
|
162
|
-
try {
|
|
163
|
-
const result = await callReadOnlyFunction(pair_details_options);
|
|
164
|
-
const result2 = await callReadOnlyFunction(getReadOptions(this.stackswap, cvToValue(result)['liquidity-token'].value, 'get-lp-data', []));
|
|
165
|
-
return LiquidityPool.parsePoolsFromServerData(cvToValue(result2).value, token_x, token_y, true);
|
|
166
|
-
}
|
|
167
|
-
catch (e) {
|
|
168
|
-
return null;
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
}
|
|
1
|
+
import { callReadOnlyFunction, cvToValue } from "@stacks/transactions";
|
|
2
|
+
import BigNumber from "bignumber.js";
|
|
3
|
+
import axios from "axios";
|
|
4
|
+
import { decimal2integer, getPriceAndDY, getReadOptions, parseAddressToCV } from "../util";
|
|
5
|
+
import { Token } from "./token.manager";
|
|
6
|
+
export class LiquidityPool {
|
|
7
|
+
constructor(name, token_x, token_y, token_lp, balance_x = '0', balance_y = '0', share_total = '0') {
|
|
8
|
+
this.loaded = false;
|
|
9
|
+
this.balance_x = '0';
|
|
10
|
+
this.balance_y = '0';
|
|
11
|
+
this.share_total = '0';
|
|
12
|
+
this.name = name;
|
|
13
|
+
this.token_x = token_x;
|
|
14
|
+
this.token_y = token_y;
|
|
15
|
+
this.token_lp = token_lp;
|
|
16
|
+
this.balance_x = balance_x;
|
|
17
|
+
this.balance_y = balance_y;
|
|
18
|
+
this.share_total = share_total;
|
|
19
|
+
}
|
|
20
|
+
getTokenX(direction = true) {
|
|
21
|
+
return direction ? this.token_x : this.token_y;
|
|
22
|
+
}
|
|
23
|
+
getTokenY(direction = true) {
|
|
24
|
+
return direction ? this.token_y : this.token_x;
|
|
25
|
+
}
|
|
26
|
+
toString() {
|
|
27
|
+
return '' + { name: this.name, token_x: this.token_x.toString(), token_y: this.token_y.toString(), token_lp: this.token_lp.toString(), balance_x: this.balance_x, balance_y: this.balance_y, share_total: this.share_total, loaded: this.loaded };
|
|
28
|
+
}
|
|
29
|
+
static parsePoolFromJson(data) {
|
|
30
|
+
if (data.share_total != null) {
|
|
31
|
+
return new LiquidityPool(data.name, Token.parseTokenFromJson(data.token_x), Token.parseTokenFromJson(data.token_y), Token.parseTokenFromJson(data.token_lp), data.balance_x, data.balance_y, data.share_total);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
return new LiquidityPool(data.name, Token.parseTokenFromJson(data.token_x), Token.parseTokenFromJson(data.token_y), new Token(data.name, 6, '', data.token_swapr, data.name));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
static parsePoolsFromJsonList(datas) {
|
|
38
|
+
const temp_list = [];
|
|
39
|
+
for (const data of datas) {
|
|
40
|
+
temp_list.push(LiquidityPool.parsePoolFromJson(data));
|
|
41
|
+
}
|
|
42
|
+
return temp_list;
|
|
43
|
+
}
|
|
44
|
+
static parsePoolsFromServerData(pair, token_x, token_y, direction = true) {
|
|
45
|
+
if (direction) {
|
|
46
|
+
const temp = new LiquidityPool(pair.name.value, token_x, token_y, new Token(pair.name.value, 6, '', pair['liquidity-token'].value, pair.name.value), pair['balance-x'].value, pair['balance-y'].value, pair['shares-total'].value);
|
|
47
|
+
temp.loaded = true;
|
|
48
|
+
return temp;
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
const temp = new LiquidityPool(pair.name.value, token_y, token_x, new Token(pair.name.value, 6, '', pair['liquidity-token'].value, pair.name.value), pair['balance-x'].value, pair['balance-y'].value, pair['shares-total'].value);
|
|
52
|
+
temp.loaded = true;
|
|
53
|
+
return temp;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
static parsePoolsFromServerData2(pair, token_x, token_y, direction = true) {
|
|
57
|
+
if (direction) {
|
|
58
|
+
const temp = new LiquidityPool(pair.name, token_x, token_y, new Token(pair.name, 6, '', pair['liquidity-token'], pair.name), pair['balance-x'], pair['balance-y'], pair['shares-total']);
|
|
59
|
+
temp.loaded = true;
|
|
60
|
+
return temp;
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
const temp = new LiquidityPool(pair.name, token_y, token_x, new Token(pair.name, 6, '', pair['liquidity-token'], pair.name), pair['balance-x'], pair['balance-y'], pair['shares-total']);
|
|
64
|
+
temp.loaded = true;
|
|
65
|
+
return temp;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
static parsePoolsFromDBData(data) {
|
|
69
|
+
const temp = new LiquidityPool(data.pair_name, Token.parseTokenFromJson(data.token_x), Token.parseTokenFromJson(data.token_y), new Token(data.pair_name, 6, '', data.pair_addr, data.pair_name), decimal2integer(data.balance_token_x, data.token_x.decimal), decimal2integer(data.balance_token_y, data.token_y.decimal), data.total_lp_amt);
|
|
70
|
+
temp.loaded = true;
|
|
71
|
+
return temp;
|
|
72
|
+
}
|
|
73
|
+
getPoolPrice(inverted = false, amount = '-1') {
|
|
74
|
+
if (this.share_total === '0') {
|
|
75
|
+
return { dy: '0', output_price: '0' };
|
|
76
|
+
}
|
|
77
|
+
if (inverted) {
|
|
78
|
+
return getPriceAndDY(this, amount, false);
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
return getPriceAndDY(this, amount, true);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
getPoolTVL(stackswap, pool, stx_usd, stsw_usd, btc_usd) {
|
|
85
|
+
const x_token_addr = pool.token_x.addr;
|
|
86
|
+
const y_token_addr = pool.token_y.addr;
|
|
87
|
+
let total_balance = new BigNumber(-1);
|
|
88
|
+
let total_price = -1;
|
|
89
|
+
if (x_token_addr === stackswap.config.BASE_WSTX_DATA().addr) {
|
|
90
|
+
total_balance = (new BigNumber(pool.balance_x).dividedBy(new BigNumber(10 ** pool.token_x.decimal))).multipliedBy(2);
|
|
91
|
+
total_price = total_balance.multipliedBy(stx_usd).toNumber();
|
|
92
|
+
}
|
|
93
|
+
else if (y_token_addr === stackswap.config.BASE_WSTX_DATA().addr) {
|
|
94
|
+
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_y.decimal))).multipliedBy(2);
|
|
95
|
+
total_price = total_balance.multipliedBy(stx_usd).toNumber();
|
|
96
|
+
}
|
|
97
|
+
else if (x_token_addr === stackswap.config.BASE_STSW_DATA().addr) {
|
|
98
|
+
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_x.decimal))).multipliedBy(2);
|
|
99
|
+
total_price = total_balance.multipliedBy(stsw_usd).toNumber();
|
|
100
|
+
}
|
|
101
|
+
else if (y_token_addr === stackswap.config.BASE_STSW_DATA().addr) {
|
|
102
|
+
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_y.decimal))).multipliedBy(2);
|
|
103
|
+
total_price = total_balance.multipliedBy(stsw_usd).toNumber();
|
|
104
|
+
}
|
|
105
|
+
else if (x_token_addr === stackswap.config.BASE_LBTC_DATA().addr) {
|
|
106
|
+
total_balance = (new BigNumber(pool.balance_x).dividedBy(new BigNumber(10 ** pool.token_x.decimal))).multipliedBy(2);
|
|
107
|
+
total_price = total_balance.multipliedBy(btc_usd).toNumber();
|
|
108
|
+
}
|
|
109
|
+
else if (y_token_addr === stackswap.config.BASE_LBTC_DATA().addr) {
|
|
110
|
+
total_balance = (new BigNumber(pool.balance_y).dividedBy(new BigNumber(10 ** pool.token_y.decimal))).multipliedBy(2);
|
|
111
|
+
total_price = total_balance.multipliedBy(btc_usd).toNumber();
|
|
112
|
+
}
|
|
113
|
+
return total_price;
|
|
114
|
+
}
|
|
115
|
+
getNewPoolShareRatio(token_amount, inversed) {
|
|
116
|
+
if (this.loaded) {
|
|
117
|
+
try {
|
|
118
|
+
const token_input = new BigNumber(token_amount);
|
|
119
|
+
const token_in_pool = new BigNumber(inversed ? this.balance_x : this.balance_y);
|
|
120
|
+
const token_in_pool_new = token_input.plus(token_in_pool);
|
|
121
|
+
const temp = (token_input.dividedBy(token_in_pool_new).multipliedBy(100)).toNumber();
|
|
122
|
+
if (!isNaN(temp)) {
|
|
123
|
+
return temp;
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
return 0;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
catch (e) {
|
|
130
|
+
return 0;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
return 0;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
export class PoolManager {
|
|
139
|
+
constructor(stackswap) {
|
|
140
|
+
this.stackswap = stackswap;
|
|
141
|
+
}
|
|
142
|
+
async getPoolLists() {
|
|
143
|
+
const url1 = this.stackswap.config.STACKS_BACKEND_URL() + '/stacks/pair/' + this.stackswap.config.STACKS_BACKEND_PARAM();
|
|
144
|
+
const res1 = await axios.get(url1, {
|
|
145
|
+
timeout: 30000,
|
|
146
|
+
});
|
|
147
|
+
return LiquidityPool.parsePoolsFromJsonList(res1.data);
|
|
148
|
+
}
|
|
149
|
+
async getPairDataFromContract(token_x, token_y) {
|
|
150
|
+
const pair_details_options = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_STACKSWAP_SWAP(), 'get-pair-details', [parseAddressToCV(token_x.addr), parseAddressToCV(token_y.addr)]);
|
|
151
|
+
try {
|
|
152
|
+
const result = await callReadOnlyFunction(pair_details_options);
|
|
153
|
+
const result2 = await callReadOnlyFunction(getReadOptions(this.stackswap, cvToValue(result)['liquidity-token'].value, 'get-lp-data', []));
|
|
154
|
+
return LiquidityPool.parsePoolsFromServerData(cvToValue(result2).value, token_x, token_y, true);
|
|
155
|
+
}
|
|
156
|
+
catch (e) {
|
|
157
|
+
return null;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
async getPoolDatasLegacy(token_x, token_y, swap_contract) {
|
|
161
|
+
const pair_details_options = getReadOptions(this.stackswap, swap_contract, 'get-pair-details', [parseAddressToCV(token_x.addr), parseAddressToCV(token_y.addr)]);
|
|
162
|
+
try {
|
|
163
|
+
const result = await callReadOnlyFunction(pair_details_options);
|
|
164
|
+
const result2 = await callReadOnlyFunction(getReadOptions(this.stackswap, cvToValue(result)['liquidity-token'].value, 'get-lp-data', []));
|
|
165
|
+
return LiquidityPool.parsePoolsFromServerData(cvToValue(result2).value, token_x, token_y, true);
|
|
166
|
+
}
|
|
167
|
+
catch (e) {
|
|
168
|
+
return null;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
172
|
//# sourceMappingURL=pool.manager.js.map
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { StackswapAPI } from "../../index";
|
|
2
|
-
import { Token } from "./token.manager";
|
|
3
|
-
export declare class PoxlManager {
|
|
4
|
-
stackswap: StackswapAPI;
|
|
5
|
-
constructor(stackswap: StackswapAPI);
|
|
6
|
-
minePOXLToken(token: Token, mine_amount: string, callback?: any): Promise<void>;
|
|
7
|
-
stackPOXLToken(token: Token, stack_amount: string, stack_lock_period: string, callback?: any): Promise<void>;
|
|
8
|
-
claimMiningReward(token: Token, mined_blocknum: string, callback?: any): Promise<void>;
|
|
9
|
-
claimStackingReward(token: Token, target_reward_cycle: string, callback?: any): Promise<void>;
|
|
10
|
-
getRandomInt(contract_address: string, input: number): Promise<void>;
|
|
11
|
-
getMinedBlock(contract_address: string, offset: number): Promise<{
|
|
12
|
-
total: any;
|
|
13
|
-
mined_block: number[];
|
|
14
|
-
}>;
|
|
15
|
-
canClaimCall(contract_address: string, block: number): Promise<any>;
|
|
16
|
-
}
|
|
1
|
+
import { StackswapAPI } from "../../index";
|
|
2
|
+
import { Token } from "./token.manager";
|
|
3
|
+
export declare class PoxlManager {
|
|
4
|
+
stackswap: StackswapAPI;
|
|
5
|
+
constructor(stackswap: StackswapAPI);
|
|
6
|
+
minePOXLToken(token: Token, mine_amount: string, callback?: any): Promise<void>;
|
|
7
|
+
stackPOXLToken(token: Token, stack_amount: string, stack_lock_period: string, callback?: any): Promise<void>;
|
|
8
|
+
claimMiningReward(token: Token, mined_blocknum: string, callback?: any): Promise<void>;
|
|
9
|
+
claimStackingReward(token: Token, target_reward_cycle: string, callback?: any): Promise<void>;
|
|
10
|
+
getRandomInt(contract_address: string, input: number): Promise<void>;
|
|
11
|
+
getMinedBlock(contract_address: string, offset: number): Promise<{
|
|
12
|
+
total: any;
|
|
13
|
+
mined_block: number[];
|
|
14
|
+
}>;
|
|
15
|
+
canClaimCall(contract_address: string, block: number): Promise<any>;
|
|
16
|
+
}
|
|
@@ -1,72 +1,72 @@
|
|
|
1
|
-
import axios from "axios";
|
|
2
|
-
import { openContractCall } from "@stacks/connect";
|
|
3
|
-
import { decimal2integer, getPostConditionFromAsset, getReadOptions, getWriteOptions } from "../util";
|
|
4
|
-
import { callReadOnlyFunction, cvToValue, FungibleConditionCode, noneCV, standardPrincipalCV, uintCV } from "@stacks/transactions";
|
|
5
|
-
import { BaseToken, Token } from "./token.manager";
|
|
6
|
-
export class PoxlManager {
|
|
7
|
-
constructor(stackswap) {
|
|
8
|
-
this.stackswap = stackswap;
|
|
9
|
-
}
|
|
10
|
-
async minePOXLToken(token, mine_amount, callback = null) {
|
|
11
|
-
const post_condition = [];
|
|
12
|
-
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), Token.getBaseTokens(this.stackswap, BaseToken.STX).addr, decimal2integer(mine_amount, 6), FungibleConditionCode.Equal));
|
|
13
|
-
const options = getWriteOptions(this.stackswap, token.addr, 'mine-tokens', [
|
|
14
|
-
uintCV(decimal2integer(mine_amount, 6)), noneCV()
|
|
15
|
-
], post_condition, callback);
|
|
16
|
-
await openContractCall(options);
|
|
17
|
-
}
|
|
18
|
-
async stackPOXLToken(token, stack_amount, stack_lock_period, callback = null) {
|
|
19
|
-
const post_condition = [];
|
|
20
|
-
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), token.addr, decimal2integer(stack_amount, token.decimal), FungibleConditionCode.Equal));
|
|
21
|
-
const options = getWriteOptions(this.stackswap, token.addr, 'stack-tokens', [uintCV(stack_amount), uintCV(stack_lock_period)], post_condition, callback);
|
|
22
|
-
await openContractCall(options);
|
|
23
|
-
}
|
|
24
|
-
async claimMiningReward(token, mined_blocknum, callback = null) {
|
|
25
|
-
const options = getWriteOptions(this.stackswap, token.addr, 'claim-token-reward', [
|
|
26
|
-
uintCV(mined_blocknum)
|
|
27
|
-
], [], callback);
|
|
28
|
-
await openContractCall(options);
|
|
29
|
-
}
|
|
30
|
-
async claimStackingReward(token, target_reward_cycle, callback = null) {
|
|
31
|
-
const options = getWriteOptions(this.stackswap, token.addr, 'claim-stacking-reward', [
|
|
32
|
-
uintCV(target_reward_cycle)
|
|
33
|
-
], [], callback, true);
|
|
34
|
-
await openContractCall(options);
|
|
35
|
-
}
|
|
36
|
-
async getRandomInt(contract_address, input) {
|
|
37
|
-
await callReadOnlyFunction(getReadOptions(this.stackswap, contract_address, 'get-random-uint-at-block', [uintCV(input)]));
|
|
38
|
-
}
|
|
39
|
-
async getMinedBlock(contract_address, offset) {
|
|
40
|
-
const get_result = await axios.get(this.stackswap.config.STACKS_API_URL() + '/extended/v1/address/' + this.stackswap.getSenderAddress() + '/transactions', {
|
|
41
|
-
params: {
|
|
42
|
-
limit: 40,
|
|
43
|
-
offset,
|
|
44
|
-
},
|
|
45
|
-
});
|
|
46
|
-
const total = get_result.data.total;
|
|
47
|
-
const results = get_result.data.results;
|
|
48
|
-
const mined_block = [];
|
|
49
|
-
for (const item of results) {
|
|
50
|
-
try {
|
|
51
|
-
if (contract_address === item.contract_call.contract_id && item.contract_call.function_name === 'mine-tokens') {
|
|
52
|
-
const temp = await this.canClaimCall(contract_address, item.block_height);
|
|
53
|
-
if (temp) {
|
|
54
|
-
mined_block.push(item.block_height);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
catch (e) {
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return { total, mined_block };
|
|
62
|
-
}
|
|
63
|
-
async canClaimCall(contract_address, block) {
|
|
64
|
-
const options = getReadOptions(this.stackswap, contract_address, 'can-claim-mining-reward', [
|
|
65
|
-
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
66
|
-
uintCV(block),
|
|
67
|
-
]);
|
|
68
|
-
const result = await callReadOnlyFunction(options);
|
|
69
|
-
return cvToValue(result);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
1
|
+
import axios from "axios";
|
|
2
|
+
import { openContractCall } from "@stacks/connect";
|
|
3
|
+
import { decimal2integer, getPostConditionFromAsset, getReadOptions, getWriteOptions } from "../util";
|
|
4
|
+
import { callReadOnlyFunction, cvToValue, FungibleConditionCode, noneCV, standardPrincipalCV, uintCV } from "@stacks/transactions";
|
|
5
|
+
import { BaseToken, Token } from "./token.manager";
|
|
6
|
+
export class PoxlManager {
|
|
7
|
+
constructor(stackswap) {
|
|
8
|
+
this.stackswap = stackswap;
|
|
9
|
+
}
|
|
10
|
+
async minePOXLToken(token, mine_amount, callback = null) {
|
|
11
|
+
const post_condition = [];
|
|
12
|
+
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), Token.getBaseTokens(this.stackswap, BaseToken.STX).addr, decimal2integer(mine_amount, 6), FungibleConditionCode.Equal));
|
|
13
|
+
const options = getWriteOptions(this.stackswap, token.addr, 'mine-tokens', [
|
|
14
|
+
uintCV(decimal2integer(mine_amount, 6)), noneCV()
|
|
15
|
+
], post_condition, callback);
|
|
16
|
+
await openContractCall(options);
|
|
17
|
+
}
|
|
18
|
+
async stackPOXLToken(token, stack_amount, stack_lock_period, callback = null) {
|
|
19
|
+
const post_condition = [];
|
|
20
|
+
post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), token.addr, decimal2integer(stack_amount, token.decimal), FungibleConditionCode.Equal));
|
|
21
|
+
const options = getWriteOptions(this.stackswap, token.addr, 'stack-tokens', [uintCV(stack_amount), uintCV(stack_lock_period)], post_condition, callback);
|
|
22
|
+
await openContractCall(options);
|
|
23
|
+
}
|
|
24
|
+
async claimMiningReward(token, mined_blocknum, callback = null) {
|
|
25
|
+
const options = getWriteOptions(this.stackswap, token.addr, 'claim-token-reward', [
|
|
26
|
+
uintCV(mined_blocknum)
|
|
27
|
+
], [], callback);
|
|
28
|
+
await openContractCall(options);
|
|
29
|
+
}
|
|
30
|
+
async claimStackingReward(token, target_reward_cycle, callback = null) {
|
|
31
|
+
const options = getWriteOptions(this.stackswap, token.addr, 'claim-stacking-reward', [
|
|
32
|
+
uintCV(target_reward_cycle)
|
|
33
|
+
], [], callback, true);
|
|
34
|
+
await openContractCall(options);
|
|
35
|
+
}
|
|
36
|
+
async getRandomInt(contract_address, input) {
|
|
37
|
+
await callReadOnlyFunction(getReadOptions(this.stackswap, contract_address, 'get-random-uint-at-block', [uintCV(input)]));
|
|
38
|
+
}
|
|
39
|
+
async getMinedBlock(contract_address, offset) {
|
|
40
|
+
const get_result = await axios.get(this.stackswap.config.STACKS_API_URL() + '/extended/v1/address/' + this.stackswap.getSenderAddress() + '/transactions', {
|
|
41
|
+
params: {
|
|
42
|
+
limit: 40,
|
|
43
|
+
offset,
|
|
44
|
+
},
|
|
45
|
+
});
|
|
46
|
+
const total = get_result.data.total;
|
|
47
|
+
const results = get_result.data.results;
|
|
48
|
+
const mined_block = [];
|
|
49
|
+
for (const item of results) {
|
|
50
|
+
try {
|
|
51
|
+
if (contract_address === item.contract_call.contract_id && item.contract_call.function_name === 'mine-tokens') {
|
|
52
|
+
const temp = await this.canClaimCall(contract_address, item.block_height);
|
|
53
|
+
if (temp) {
|
|
54
|
+
mined_block.push(item.block_height);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
catch (e) {
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return { total, mined_block };
|
|
62
|
+
}
|
|
63
|
+
async canClaimCall(contract_address, block) {
|
|
64
|
+
const options = getReadOptions(this.stackswap, contract_address, 'can-claim-mining-reward', [
|
|
65
|
+
standardPrincipalCV(this.stackswap.getSenderAddress()),
|
|
66
|
+
uintCV(block),
|
|
67
|
+
]);
|
|
68
|
+
const result = await callReadOnlyFunction(options);
|
|
69
|
+
return cvToValue(result);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
72
|
//# sourceMappingURL=poxl.manager.js.map
|
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
import BigNumber from "bignumber.js";
|
|
2
|
-
import { StackswapAPI } from "../../index";
|
|
3
|
-
export declare class StakingManager {
|
|
4
|
-
stackswap: StackswapAPI;
|
|
5
|
-
constructor(stackswap: StackswapAPI);
|
|
6
|
-
getStackingRoundFirstBlock(cycle: number): Promise<any>;
|
|
7
|
-
getStakingSTSWBalance(source: any): Promise<any>;
|
|
8
|
-
getRewardRoundID_V2(source: any): Promise<any[]>;
|
|
9
|
-
getStakingRound(contract_address: string, block: number | string): Promise<any>;
|
|
10
|
-
getCurrentStakingRound(contract_address: string): Promise<any>;
|
|
11
|
-
getRewardRoundID(offset: number): Promise<number[]>;
|
|
12
|
-
range_number(start: number, end: number): number[];
|
|
13
|
-
getReward(contract_addr: string, round_id: number): Promise<number>;
|
|
14
|
-
txClaimReward(round_id: number, stsw_amount: string, callback?: any): Promise<void>;
|
|
15
|
-
getUserCountFromVSTSW(): Promise<number>;
|
|
16
|
-
getStakingBalanceFromVSTSW_V2(): Promise<BigNumber | 0>;
|
|
17
|
-
getClaimRewardListFromVSTSW(): Promise<any[]>;
|
|
18
|
-
getStakingBalanceFromVSTSW(): Promise<number>;
|
|
19
|
-
txStakeFromStaking(invest_amt: number, period_month: number, callback?: any): Promise<void>;
|
|
20
|
-
txCooldownFromVSTSW(index: number, callback?: any): Promise<void>;
|
|
21
|
-
txUnstakingFromVSTSW(index: number, amountSTX: string, amountvSTX: string, callback?: any): Promise<void>;
|
|
22
|
-
getRewardBalanceFromStaking(): Promise<number>;
|
|
23
|
-
getRewardBalanceFromStakingFromList(unclaimed_list: any): Promise<number>;
|
|
24
|
-
getRewardTotal(reward_list: any): Promise<any>;
|
|
25
|
-
}
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { StackswapAPI } from "../../index";
|
|
3
|
+
export declare class StakingManager {
|
|
4
|
+
stackswap: StackswapAPI;
|
|
5
|
+
constructor(stackswap: StackswapAPI);
|
|
6
|
+
getStackingRoundFirstBlock(cycle: number): Promise<any>;
|
|
7
|
+
getStakingSTSWBalance(source: any): Promise<any>;
|
|
8
|
+
getRewardRoundID_V2(source: any): Promise<any[]>;
|
|
9
|
+
getStakingRound(contract_address: string, block: number | string): Promise<any>;
|
|
10
|
+
getCurrentStakingRound(contract_address: string): Promise<any>;
|
|
11
|
+
getRewardRoundID(offset: number): Promise<number[]>;
|
|
12
|
+
range_number(start: number, end: number): number[];
|
|
13
|
+
getReward(contract_addr: string, round_id: number): Promise<number>;
|
|
14
|
+
txClaimReward(round_id: number, stsw_amount: string, callback?: any): Promise<void>;
|
|
15
|
+
getUserCountFromVSTSW(): Promise<number>;
|
|
16
|
+
getStakingBalanceFromVSTSW_V2(): Promise<BigNumber | 0>;
|
|
17
|
+
getClaimRewardListFromVSTSW(): Promise<any[]>;
|
|
18
|
+
getStakingBalanceFromVSTSW(): Promise<number>;
|
|
19
|
+
txStakeFromStaking(invest_amt: number, period_month: number, callback?: any): Promise<void>;
|
|
20
|
+
txCooldownFromVSTSW(index: number, callback?: any): Promise<void>;
|
|
21
|
+
txUnstakingFromVSTSW(index: number, amountSTX: string, amountvSTX: string, callback?: any): Promise<void>;
|
|
22
|
+
getRewardBalanceFromStaking(): Promise<number>;
|
|
23
|
+
getRewardBalanceFromStakingFromList(unclaimed_list: any): Promise<number>;
|
|
24
|
+
getRewardTotal(reward_list: any): Promise<any>;
|
|
25
|
+
}
|