@sonarwatch/portfolio-plugins 0.11.194 → 0.11.196
Sign up to get free protection for your applications and to get access to all the features.
- package/CHANGELOG.md +1525 -1517
- package/README.md +3 -3
- package/package.json +2 -2
- package/src/index.js +8 -0
- package/src/index.js.map +1 -1
- package/src/plugins/balancer/helpers/pools.js +21 -21
- package/src/plugins/haedal/constants.d.ts +5 -0
- package/src/plugins/haedal/constants.js +15 -0
- package/src/plugins/haedal/constants.js.map +1 -0
- package/src/plugins/haedal/index.d.ts +6 -0
- package/src/plugins/haedal/index.js +12 -0
- package/src/plugins/haedal/index.js.map +1 -0
- package/src/plugins/haedal/types.d.ts +19 -0
- package/src/plugins/haedal/types.js +3 -0
- package/src/plugins/haedal/types.js.map +1 -0
- package/src/plugins/haedal/vaultFetcher.d.ts +3 -0
- package/src/plugins/haedal/vaultFetcher.js +58 -0
- package/src/plugins/haedal/vaultFetcher.js.map +1 -0
- package/src/plugins/kriya/constants.d.ts +13 -0
- package/src/plugins/kriya/constants.js +30 -0
- package/src/plugins/kriya/constants.js.map +1 -0
- package/src/plugins/kriya/farmsFetcher.d.ts +3 -0
- package/src/plugins/kriya/farmsFetcher.js +104 -0
- package/src/plugins/kriya/farmsFetcher.js.map +1 -0
- package/src/plugins/kriya/farmsJob.d.ts +3 -0
- package/src/plugins/kriya/farmsJob.js +47 -0
- package/src/plugins/kriya/farmsJob.js.map +1 -0
- package/src/plugins/kriya/index.d.ts +6 -0
- package/src/plugins/kriya/index.js +15 -0
- package/src/plugins/kriya/index.js.map +1 -0
- package/src/plugins/kriya/types.d.ts +155 -0
- package/src/plugins/kriya/types.js +16 -0
- package/src/plugins/kriya/types.js.map +1 -0
- package/src/plugins/kriya/vaultsFetcher.d.ts +3 -0
- package/src/plugins/kriya/vaultsFetcher.js +94 -0
- package/src/plugins/kriya/vaultsFetcher.js.map +1 -0
- package/src/plugins/kriya/vaultsJob.d.ts +3 -0
- package/src/plugins/kriya/vaultsJob.js +57 -0
- package/src/plugins/kriya/vaultsJob.js.map +1 -0
- package/src/plugins/sushiswap/helpers.js +24 -24
- package/src/plugins/uniswap-v2/helpers.js +22 -22
- package/src/utils/sei/constants.js +8 -8
- package/src/utils/sei/getQueryBalanceByOwner.js +4 -4
- package/src/utils/sui/mulitpleGetBalances.d.ts +3 -0
- package/src/utils/sui/mulitpleGetBalances.js +19 -0
- package/src/utils/sui/mulitpleGetBalances.js.map +1 -0
- package/src/utils/sui/multipleGetDynamicFieldsObjects.d.ts +4 -0
- package/src/utils/sui/multipleGetDynamicFieldsObjects.js +25 -0
- package/src/utils/sui/multipleGetDynamicFieldsObjects.js.map +1 -0
@@ -0,0 +1,155 @@
|
|
1
|
+
export type VaultInfo = {
|
2
|
+
id: string;
|
3
|
+
underlyingPool: string;
|
4
|
+
tokenType: string;
|
5
|
+
};
|
6
|
+
export type Vault = {
|
7
|
+
clmm_pool_id: string;
|
8
|
+
fee_a: string;
|
9
|
+
fee_b: string;
|
10
|
+
fee_val: string;
|
11
|
+
free_balance_a: string;
|
12
|
+
free_balance_b: string;
|
13
|
+
free_threshold_a: string;
|
14
|
+
free_threshold_b: string;
|
15
|
+
id: ID;
|
16
|
+
last_rebalance_sqrt_price: string;
|
17
|
+
last_rebalance_time: string;
|
18
|
+
lower_price_scalling: string;
|
19
|
+
lower_tick: number;
|
20
|
+
lower_trigger_price: string;
|
21
|
+
lower_trigger_price_scalling: string;
|
22
|
+
rewards_bag: RewardsBag;
|
23
|
+
seed_balance: string;
|
24
|
+
slippage_down: string;
|
25
|
+
slippage_up: string;
|
26
|
+
swap_routes: RewardsBag;
|
27
|
+
treasury_cap: TreasuryCap;
|
28
|
+
upper_price_scalling: string;
|
29
|
+
upper_tick: number;
|
30
|
+
upper_trigger_price: string;
|
31
|
+
upper_trigger_price_scalling: string;
|
32
|
+
};
|
33
|
+
export type ID = {
|
34
|
+
id: string;
|
35
|
+
};
|
36
|
+
export type RewardsBag = {
|
37
|
+
fields: RewardsBagFields;
|
38
|
+
type: string;
|
39
|
+
};
|
40
|
+
export type RewardsBagFields = {
|
41
|
+
id: ID;
|
42
|
+
size: string;
|
43
|
+
};
|
44
|
+
export type TreasuryCap = {
|
45
|
+
fields: TreasuryCapFields;
|
46
|
+
type: string;
|
47
|
+
};
|
48
|
+
export type TreasuryCapFields = {
|
49
|
+
id: ID;
|
50
|
+
total_supply: TotalSupply;
|
51
|
+
};
|
52
|
+
export type TotalSupply = {
|
53
|
+
fields: TotalSupplyFields;
|
54
|
+
type: string;
|
55
|
+
};
|
56
|
+
export type TotalSupplyFields = {
|
57
|
+
value: string;
|
58
|
+
};
|
59
|
+
export type VaultPositionInfo = {
|
60
|
+
id: string;
|
61
|
+
lowerTick: number;
|
62
|
+
upperTick: number;
|
63
|
+
liquidity: string;
|
64
|
+
totalSupply: string;
|
65
|
+
};
|
66
|
+
export type VaultPosition = {
|
67
|
+
id: ID;
|
68
|
+
name: number[];
|
69
|
+
value: Value;
|
70
|
+
};
|
71
|
+
export type Value = {
|
72
|
+
fields: ValueFields;
|
73
|
+
type: string;
|
74
|
+
};
|
75
|
+
export type ValueFields = {
|
76
|
+
coin_type_a: CoinType;
|
77
|
+
coin_type_b: CoinType;
|
78
|
+
description: string;
|
79
|
+
id: ID;
|
80
|
+
index: string;
|
81
|
+
liquidity: string;
|
82
|
+
name: string;
|
83
|
+
pool: string;
|
84
|
+
tick_lower_index: TickErIndex;
|
85
|
+
tick_upper_index: TickErIndex;
|
86
|
+
url: string;
|
87
|
+
};
|
88
|
+
export type CoinType = {
|
89
|
+
fields: CoinTypeAFields;
|
90
|
+
type: string;
|
91
|
+
};
|
92
|
+
export type CoinTypeAFields = {
|
93
|
+
name: string;
|
94
|
+
};
|
95
|
+
export type TickErIndex = {
|
96
|
+
fields: TickLowerIndexFields;
|
97
|
+
type: string;
|
98
|
+
};
|
99
|
+
export type TickLowerIndexFields = {
|
100
|
+
bits: number;
|
101
|
+
};
|
102
|
+
export type FarmInfo = {
|
103
|
+
tokenXReserve: string;
|
104
|
+
lspSupply: string;
|
105
|
+
protocolFeesPercent: string;
|
106
|
+
createdAt: Date;
|
107
|
+
farmSource: FarmSource;
|
108
|
+
volume: number;
|
109
|
+
packageId: string;
|
110
|
+
farmId: string;
|
111
|
+
objectId: string;
|
112
|
+
poolSource: PoolSource;
|
113
|
+
lspType: string;
|
114
|
+
lpFeesPercent: string;
|
115
|
+
tokenYType: string;
|
116
|
+
data: string;
|
117
|
+
updatedAt: Date;
|
118
|
+
isStable: boolean;
|
119
|
+
tokenXType: string;
|
120
|
+
tokenYReserve: string;
|
121
|
+
tokenX: Token;
|
122
|
+
tokenY: Token;
|
123
|
+
tvl: number;
|
124
|
+
apy: number;
|
125
|
+
feeApy: number;
|
126
|
+
};
|
127
|
+
export declare enum FarmSource {
|
128
|
+
Buck = "buck",
|
129
|
+
Empty = "",
|
130
|
+
Kriya = "kriya"
|
131
|
+
}
|
132
|
+
export declare enum PoolSource {
|
133
|
+
Deepbook = "deepbook",
|
134
|
+
DeepbookV2 = "deepbook_v2",
|
135
|
+
Kriya = "kriya"
|
136
|
+
}
|
137
|
+
export type Token = {
|
138
|
+
coinType: string;
|
139
|
+
ticker: string;
|
140
|
+
tokenName: string;
|
141
|
+
updatedAt: Date;
|
142
|
+
createdAt: Date;
|
143
|
+
decimals: number;
|
144
|
+
iconUrl: string;
|
145
|
+
description: string;
|
146
|
+
price: string;
|
147
|
+
};
|
148
|
+
export type LiquidityPosition = {
|
149
|
+
farm_id: string;
|
150
|
+
id: ID;
|
151
|
+
lock_until: string;
|
152
|
+
stake_amount: string;
|
153
|
+
stake_weight: string;
|
154
|
+
start_unit: string;
|
155
|
+
};
|
@@ -0,0 +1,16 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.PoolSource = exports.FarmSource = void 0;
|
4
|
+
var FarmSource;
|
5
|
+
(function (FarmSource) {
|
6
|
+
FarmSource["Buck"] = "buck";
|
7
|
+
FarmSource["Empty"] = "";
|
8
|
+
FarmSource["Kriya"] = "kriya";
|
9
|
+
})(FarmSource || (exports.FarmSource = FarmSource = {}));
|
10
|
+
var PoolSource;
|
11
|
+
(function (PoolSource) {
|
12
|
+
PoolSource["Deepbook"] = "deepbook";
|
13
|
+
PoolSource["DeepbookV2"] = "deepbook_v2";
|
14
|
+
PoolSource["Kriya"] = "kriya";
|
15
|
+
})(PoolSource || (exports.PoolSource = PoolSource = {}));
|
16
|
+
//# sourceMappingURL=types.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/kriya/types.ts"],"names":[],"mappings":";;;AAgJA,IAAY,UAIX;AAJD,WAAY,UAAU;IACpB,2BAAa,CAAA;IACb,wBAAU,CAAA;IACV,6BAAe,CAAA;AACjB,CAAC,EAJW,UAAU,0BAAV,UAAU,QAIrB;AAED,IAAY,UAIX;AAJD,WAAY,UAAU;IACpB,mCAAqB,CAAA;IACrB,wCAA0B,CAAA;IAC1B,6BAAe,CAAA;AACjB,CAAC,EAJW,UAAU,0BAAV,UAAU,QAIrB"}
|
@@ -0,0 +1,94 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
+
});
|
10
|
+
};
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
13
|
+
};
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
+
const portfolio_core_1 = require("@sonarwatch/portfolio-core");
|
16
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
17
|
+
const constants_1 = require("./constants");
|
18
|
+
const clients_1 = require("../../utils/clients");
|
19
|
+
const mulitpleGetBalances_1 = require("../../utils/sui/mulitpleGetBalances");
|
20
|
+
const constants_2 = require("../cetus/constants");
|
21
|
+
const tokenAmountFromLiquidity_1 = require("../../utils/clmm/tokenAmountFromLiquidity");
|
22
|
+
const tokenPriceToAssetToken_1 = __importDefault(require("../../utils/misc/tokenPriceToAssetToken"));
|
23
|
+
const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* () {
|
24
|
+
const client = (0, clients_1.getClientSui)();
|
25
|
+
const vaultsBalances = yield (0, mulitpleGetBalances_1.getMultipleBalances)(client, owner, constants_1.vaultsInfo.map((vault) => vault.tokenType));
|
26
|
+
if (!vaultsBalances.some((balance) => balance.totalBalance !== '0'))
|
27
|
+
return [];
|
28
|
+
const poolInfos = yield cache.getItems(constants_1.vaultsInfo.map((vault) => vault.underlyingPool), { prefix: constants_2.clmmPoolsPrefix, networkId: portfolio_core_1.NetworkId.sui });
|
29
|
+
const vaultsPositionInfo = yield cache.getItem(constants_1.vaultsInfoKey, {
|
30
|
+
prefix: constants_1.platformId,
|
31
|
+
networkId: portfolio_core_1.NetworkId.sui,
|
32
|
+
});
|
33
|
+
if (!vaultsPositionInfo)
|
34
|
+
return [];
|
35
|
+
const tokenPriceById = yield cache.getTokenPricesAsMap(poolInfos
|
36
|
+
.map((pool) => (pool ? [pool.coinTypeA, pool.coinTypeB] : []))
|
37
|
+
.flat(), portfolio_core_1.NetworkId.sui);
|
38
|
+
let totalValue = 0;
|
39
|
+
const liquidities = [];
|
40
|
+
for (let i = 0; i < vaultsBalances.length; i++) {
|
41
|
+
const balance = vaultsBalances[i];
|
42
|
+
const pool = poolInfos[i];
|
43
|
+
const vault = vaultsPositionInfo[i];
|
44
|
+
if (!pool || !vault)
|
45
|
+
continue;
|
46
|
+
const totalSupply = new bignumber_js_1.default(vault.totalSupply);
|
47
|
+
const { tokenAmountA, tokenAmountB } = (0, tokenAmountFromLiquidity_1.getTokenAmountsFromLiquidity)(new bignumber_js_1.default(vault.liquidity), pool.current_tick_index, vault.lowerTick, vault.upperTick, false);
|
48
|
+
const shares = new bignumber_js_1.default(balance.totalBalance).dividedBy(totalSupply);
|
49
|
+
const [tokenPriceA, tokenPriceB] = [
|
50
|
+
tokenPriceById.get((0, portfolio_core_1.formatMoveTokenAddress)(pool.coinTypeA)),
|
51
|
+
tokenPriceById.get((0, portfolio_core_1.formatMoveTokenAddress)(pool.coinTypeB)),
|
52
|
+
];
|
53
|
+
if (!tokenPriceA || !tokenPriceB)
|
54
|
+
continue;
|
55
|
+
const amountA = tokenAmountA
|
56
|
+
.times(shares)
|
57
|
+
.dividedBy(Math.pow(10, tokenPriceA.decimals));
|
58
|
+
const amountB = tokenAmountB
|
59
|
+
.times(shares)
|
60
|
+
.dividedBy(Math.pow(10, tokenPriceB.decimals));
|
61
|
+
const assetA = (0, tokenPriceToAssetToken_1.default)(tokenPriceA.address, amountA.toNumber(), portfolio_core_1.NetworkId.sui, tokenPriceA);
|
62
|
+
const assetB = (0, tokenPriceToAssetToken_1.default)(tokenPriceB.address, amountB.toNumber(), portfolio_core_1.NetworkId.sui, tokenPriceB);
|
63
|
+
const value = (0, portfolio_core_1.getUsdValueSum)([assetA.value, assetB.value]);
|
64
|
+
totalValue = (0, portfolio_core_1.getUsdValueSum)([totalValue, value]);
|
65
|
+
liquidities.push({
|
66
|
+
assets: [assetA, assetB],
|
67
|
+
assetsValue: value,
|
68
|
+
rewardAssets: [],
|
69
|
+
rewardAssetsValue: null,
|
70
|
+
value,
|
71
|
+
yields: [],
|
72
|
+
});
|
73
|
+
}
|
74
|
+
return [
|
75
|
+
{
|
76
|
+
type: 'liquidity',
|
77
|
+
data: {
|
78
|
+
liquidities,
|
79
|
+
},
|
80
|
+
label: 'LiquidityPool',
|
81
|
+
networkId: portfolio_core_1.NetworkId.sui,
|
82
|
+
platformId: constants_1.platformId,
|
83
|
+
value: totalValue,
|
84
|
+
name: 'Vaults',
|
85
|
+
},
|
86
|
+
];
|
87
|
+
});
|
88
|
+
const fetcher = {
|
89
|
+
id: `${constants_1.platformId}-vaults`,
|
90
|
+
networkId: portfolio_core_1.NetworkId.sui,
|
91
|
+
executor,
|
92
|
+
};
|
93
|
+
exports.default = fetcher;
|
94
|
+
//# sourceMappingURL=vaultsFetcher.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"vaultsFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/kriya/vaultsFetcher.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,57 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
+
});
|
10
|
+
};
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
12
|
+
const portfolio_core_1 = require("@sonarwatch/portfolio-core");
|
13
|
+
const clients_1 = require("../../utils/clients");
|
14
|
+
const multiGetObjects_1 = require("../../utils/sui/multiGetObjects");
|
15
|
+
const multipleGetDynamicFieldsObjects_1 = require("../../utils/sui/multipleGetDynamicFieldsObjects");
|
16
|
+
const constants_1 = require("./constants");
|
17
|
+
const executor = (cache) => __awaiter(void 0, void 0, void 0, function* () {
|
18
|
+
var _a, _b, _c, _d;
|
19
|
+
const client = (0, clients_1.getClientSui)();
|
20
|
+
const [vaultsObjects, vaultsDynamicFields] = yield Promise.all([
|
21
|
+
(0, multiGetObjects_1.multiGetObjects)(client, constants_1.vaultsInfo.map((vault) => vault.id)),
|
22
|
+
(0, multipleGetDynamicFieldsObjects_1.multipleGetDynamicFieldsObjects)(client, constants_1.vaultsInfo.map((vault) => vault.id)),
|
23
|
+
]);
|
24
|
+
const vaultsInfos = [];
|
25
|
+
for (let i = 0; i < vaultsObjects.length; i++) {
|
26
|
+
const vault = (_b = (_a = vaultsObjects[i].data) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.fields;
|
27
|
+
if (!vault)
|
28
|
+
continue;
|
29
|
+
const dynamicFields = vaultsDynamicFields[i];
|
30
|
+
let vaultPosition;
|
31
|
+
for (const fields of dynamicFields) {
|
32
|
+
if (((_c = fields.data) === null || _c === void 0 ? void 0 : _c.type) === constants_1.dynamicFieldPositionType)
|
33
|
+
vaultPosition = (_d = fields.data.content) === null || _d === void 0 ? void 0 : _d.fields;
|
34
|
+
}
|
35
|
+
if (!vaultPosition)
|
36
|
+
continue;
|
37
|
+
const vaultPositionInfo = {
|
38
|
+
id: vault.id.id,
|
39
|
+
liquidity: vaultPosition.value.fields.liquidity,
|
40
|
+
lowerTick: vault.lower_tick,
|
41
|
+
upperTick: vault.upper_tick,
|
42
|
+
totalSupply: vault.treasury_cap.fields.total_supply.fields.value,
|
43
|
+
};
|
44
|
+
vaultsInfos.push(vaultPositionInfo);
|
45
|
+
}
|
46
|
+
yield cache.setItem(constants_1.vaultsInfoKey, vaultsInfos, {
|
47
|
+
prefix: constants_1.platformId,
|
48
|
+
networkId: portfolio_core_1.NetworkId.sui,
|
49
|
+
});
|
50
|
+
});
|
51
|
+
const job = {
|
52
|
+
id: `${constants_1.platformId}-vaults`,
|
53
|
+
executor,
|
54
|
+
label: 'normal',
|
55
|
+
};
|
56
|
+
exports.default = job;
|
57
|
+
//# sourceMappingURL=vaultsJob.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"vaultsJob.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/kriya/vaultsJob.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,+DAAuD;AAGvD,iDAAmD;AACnD,qEAAkE;AAClE,qGAAkG;AAClG,2CAKqB;AAGrB,MAAM,QAAQ,GAAgB,CAAO,KAAY,EAAE,EAAE;;IACnD,MAAM,MAAM,GAAG,IAAA,sBAAY,GAAE,CAAC;IAE9B,MAAM,CAAC,aAAa,EAAE,mBAAmB,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QAC7D,IAAA,iCAAe,EACb,MAAM,EACN,sBAAU,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CACpC;QACD,IAAA,iEAA+B,EAC7B,MAAM,EACN,sBAAU,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CACpC;KACF,CAAC,CAAC;IAEH,MAAM,WAAW,GAAwB,EAAE,CAAC;IAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAC9C,MAAM,KAAK,GAAG,MAAA,MAAA,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,0CAAE,OAAO,0CAAE,MAAM,CAAC;QACrD,IAAI,CAAC,KAAK;YAAE,SAAS;QAErB,MAAM,aAAa,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAI,aAAa,CAAC;QAClB,KAAK,MAAM,MAAM,IAAI,aAAa,EAAE,CAAC;YACnC,IAAI,CAAA,MAAA,MAAM,CAAC,IAAI,0CAAE,IAAI,MAAK,oCAAwB;gBAChD,aAAa,GAAG,MAAA,MAAM,CAAC,IAAI,CAAC,OAAO,0CAAE,MAAuB,CAAC;QACjE,CAAC;QACD,IAAI,CAAC,aAAa;YAAE,SAAS;QAE7B,MAAM,iBAAiB,GAAsB;YAC3C,EAAE,EAAE,KAAK,CAAC,EAAE,CAAC,EAAE;YACf,SAAS,EAAE,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS;YAC/C,SAAS,EAAE,KAAK,CAAC,UAAU;YAC3B,SAAS,EAAE,KAAK,CAAC,UAAU;YAC3B,WAAW,EAAE,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK;SACjE,CAAC;QACF,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IACtC,CAAC;IACD,MAAM,KAAK,CAAC,OAAO,CAAC,yBAAa,EAAE,WAAW,EAAE;QAC9C,MAAM,EAAE,sBAAU;QAClB,SAAS,EAAE,0BAAS,CAAC,GAAG;KACzB,CAAC,CAAC;AACL,CAAC,CAAA,CAAC;AAEF,MAAM,GAAG,GAAQ;IACf,EAAE,EAAE,GAAG,sBAAU,SAAS;IAC1B,QAAQ;IACR,KAAK,EAAE,QAAQ;CAChB,CAAC;AACF,kBAAe,GAAG,CAAC"}
|
@@ -54,30 +54,30 @@ function sushiV3PairToUniV2(pair) {
|
|
54
54
|
}
|
55
55
|
function getV3PairsAddresses(url, length = 300) {
|
56
56
|
return __awaiter(this, void 0, void 0, function* () {
|
57
|
-
const query = (0, graphql_request_1.gql) `
|
58
|
-
{
|
59
|
-
pools(
|
60
|
-
orderBy: totalValueLockedUSD
|
61
|
-
first: ${length}
|
62
|
-
orderDirection: desc
|
63
|
-
where: { volumeUSD_not: "0", liquidity_not: "0" }
|
64
|
-
) {
|
65
|
-
id
|
66
|
-
token0Price
|
67
|
-
token1Price
|
68
|
-
liquidity
|
69
|
-
token0 {
|
70
|
-
id
|
71
|
-
totalSupply
|
72
|
-
decimals
|
73
|
-
}
|
74
|
-
token1 {
|
75
|
-
id
|
76
|
-
totalSupply
|
77
|
-
decimals
|
78
|
-
}
|
79
|
-
}
|
80
|
-
}
|
57
|
+
const query = (0, graphql_request_1.gql) `
|
58
|
+
{
|
59
|
+
pools(
|
60
|
+
orderBy: totalValueLockedUSD
|
61
|
+
first: ${length}
|
62
|
+
orderDirection: desc
|
63
|
+
where: { volumeUSD_not: "0", liquidity_not: "0" }
|
64
|
+
) {
|
65
|
+
id
|
66
|
+
token0Price
|
67
|
+
token1Price
|
68
|
+
liquidity
|
69
|
+
token0 {
|
70
|
+
id
|
71
|
+
totalSupply
|
72
|
+
decimals
|
73
|
+
}
|
74
|
+
token1 {
|
75
|
+
id
|
76
|
+
totalSupply
|
77
|
+
decimals
|
78
|
+
}
|
79
|
+
}
|
80
|
+
}
|
81
81
|
`;
|
82
82
|
const res = yield (0, graphql_request_1.default)(url, query);
|
83
83
|
const pools = res.pools;
|
@@ -40,28 +40,28 @@ function getPairKey(version) {
|
|
40
40
|
exports.getPairKey = getPairKey;
|
41
41
|
function getPairsV2FromTheGraph(url, length = 300) {
|
42
42
|
return __awaiter(this, void 0, void 0, function* () {
|
43
|
-
const query = (0, graphql_request_1.gql) `
|
44
|
-
{
|
45
|
-
pairs(
|
46
|
-
orderBy: reserveUSD
|
47
|
-
first: ${length}
|
48
|
-
orderDirection: desc
|
49
|
-
where: { trackedReserveETH_not: "0" }
|
50
|
-
) {
|
51
|
-
id
|
52
|
-
reserve0
|
53
|
-
reserve1
|
54
|
-
totalSupply
|
55
|
-
token0 {
|
56
|
-
id
|
57
|
-
decimals
|
58
|
-
}
|
59
|
-
token1 {
|
60
|
-
id
|
61
|
-
decimals
|
62
|
-
}
|
63
|
-
}
|
64
|
-
}
|
43
|
+
const query = (0, graphql_request_1.gql) `
|
44
|
+
{
|
45
|
+
pairs(
|
46
|
+
orderBy: reserveUSD
|
47
|
+
first: ${length}
|
48
|
+
orderDirection: desc
|
49
|
+
where: { trackedReserveETH_not: "0" }
|
50
|
+
) {
|
51
|
+
id
|
52
|
+
reserve0
|
53
|
+
reserve1
|
54
|
+
totalSupply
|
55
|
+
token0 {
|
56
|
+
id
|
57
|
+
decimals
|
58
|
+
}
|
59
|
+
token1 {
|
60
|
+
id
|
61
|
+
decimals
|
62
|
+
}
|
63
|
+
}
|
64
|
+
}
|
65
65
|
`;
|
66
66
|
const res = yield (0, graphql_request_1.default)(url, query);
|
67
67
|
const pairs = res.pairs;
|
@@ -1,16 +1,16 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.poolQueryMsg = exports.minterQueryMsg = exports.tokenInfoQueryMsg = exports.infoQueryMsg = void 0;
|
4
|
-
exports.infoQueryMsg = JSON.parse(`{
|
5
|
-
"info": {}
|
4
|
+
exports.infoQueryMsg = JSON.parse(`{
|
5
|
+
"info": {}
|
6
6
|
}`);
|
7
|
-
exports.tokenInfoQueryMsg = JSON.parse(`{
|
8
|
-
"token_info": {}
|
7
|
+
exports.tokenInfoQueryMsg = JSON.parse(`{
|
8
|
+
"token_info": {}
|
9
9
|
}`);
|
10
|
-
exports.minterQueryMsg = JSON.parse(`{
|
11
|
-
"minter": {}
|
10
|
+
exports.minterQueryMsg = JSON.parse(`{
|
11
|
+
"minter": {}
|
12
12
|
}`);
|
13
|
-
exports.poolQueryMsg = JSON.parse(`{
|
14
|
-
"pool": {}
|
13
|
+
exports.poolQueryMsg = JSON.parse(`{
|
14
|
+
"pool": {}
|
15
15
|
}`);
|
16
16
|
//# sourceMappingURL=constants.js.map
|
@@ -1,10 +1,10 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
function getQueryBalanceByOwner(owner) {
|
4
|
-
return JSON.parse(`{
|
5
|
-
"balance": {
|
6
|
-
"address": "${owner}"
|
7
|
-
}
|
4
|
+
return JSON.parse(`{
|
5
|
+
"balance": {
|
6
|
+
"address": "${owner}"
|
7
|
+
}
|
8
8
|
}`);
|
9
9
|
}
|
10
10
|
exports.default = getQueryBalanceByOwner;
|
@@ -0,0 +1,19 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
+
});
|
10
|
+
};
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
12
|
+
exports.getMultipleBalances = void 0;
|
13
|
+
function getMultipleBalances(client, owner, coinsTypes) {
|
14
|
+
return __awaiter(this, void 0, void 0, function* () {
|
15
|
+
return Promise.all(coinsTypes.map((coinType) => client.getBalance({ owner, coinType })));
|
16
|
+
});
|
17
|
+
}
|
18
|
+
exports.getMultipleBalances = getMultipleBalances;
|
19
|
+
//# sourceMappingURL=mulitpleGetBalances.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"mulitpleGetBalances.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/utils/sui/mulitpleGetBalances.ts"],"names":[],"mappings":";;;;;;;;;;;;AAGA,SAAsB,mBAAmB,CACvC,MAAiB,EACjB,KAAa,EACb,UAAoB;;QAEpB,OAAO,OAAO,CAAC,GAAG,CAChB,UAAU,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC,CACrE,CAAC;IACJ,CAAC;CAAA;AARD,kDAQC"}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import { SuiObjectDataOptions } from '@mysten/sui.js/dist/cjs/client';
|
2
|
+
import { SuiClient } from '../clients/types';
|
3
|
+
import { ObjectResponse } from './types';
|
4
|
+
export declare function multipleGetDynamicFieldsObjects<K>(client: SuiClient, parentIds: string[], options?: SuiObjectDataOptions): Promise<ObjectResponse<K>[][]>;
|
@@ -0,0 +1,25 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
+
});
|
10
|
+
};
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
13
|
+
};
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
+
exports.multipleGetDynamicFieldsObjects = void 0;
|
16
|
+
const runInBatch_1 = __importDefault(require("../misc/runInBatch"));
|
17
|
+
const getDynamicFieldObjects_1 = require("./getDynamicFieldObjects");
|
18
|
+
function multipleGetDynamicFieldsObjects(client, parentIds, options) {
|
19
|
+
return __awaiter(this, void 0, void 0, function* () {
|
20
|
+
const result = yield (0, runInBatch_1.default)(parentIds.map((parentId) => () => (0, getDynamicFieldObjects_1.getDynamicFieldObjects)(client, parentId, options)), 10);
|
21
|
+
return result.flatMap((r) => (r.status === 'fulfilled' ? [r.value] : []));
|
22
|
+
});
|
23
|
+
}
|
24
|
+
exports.multipleGetDynamicFieldsObjects = multipleGetDynamicFieldsObjects;
|
25
|
+
//# sourceMappingURL=multipleGetDynamicFieldsObjects.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"multipleGetDynamicFieldsObjects.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/utils/sui/multipleGetDynamicFieldsObjects.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAEA,oEAA4C;AAC5C,qEAAkE;AAGlE,SAAsB,+BAA+B,CACnD,MAAiB,EACjB,SAAmB,EACnB,OAA8B;;QAE9B,MAAM,MAAM,GAAG,MAAM,IAAA,oBAAU,EAC7B,SAAS,CAAC,GAAG,CACX,CAAC,QAAQ,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,IAAA,+CAAsB,EAAI,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CACzE,EACD,EAAE,CACH,CAAC;QAEF,OAAO,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;CAAA;AAbD,0EAaC"}
|