@augustdigital/sdk 4.4.7 → 4.5.1-octavfi
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 +1 -1
- package/lib/__tests__/adapter.e2e.test.d.ts +1 -0
- package/lib/__tests__/adapter.e2e.test.js +94 -0
- package/lib/__tests__/adapter.e2e.test.js.map +1 -0
- package/lib/abis/TokenizedVaultV2.d.ts +10 -0
- package/lib/abis/TokenizedVaultV2.js +13 -0
- package/lib/abis/TokenizedVaultV2.js.map +1 -1
- package/lib/adapters/evm/getters.js +1 -0
- package/lib/adapters/evm/getters.js.map +1 -1
- package/lib/adapters/evm/index.d.ts +1 -1
- package/lib/adapters/evm/index.js +2 -2
- package/lib/adapters/evm/index.js.map +1 -1
- package/lib/adapters/evm/utils.js +2 -1
- package/lib/adapters/evm/utils.js.map +1 -1
- package/lib/adapters/solana/getters.js +1 -0
- package/lib/adapters/solana/getters.js.map +1 -1
- package/lib/core/auth/verify.js +2 -2
- package/lib/core/auth/verify.js.map +1 -1
- package/lib/core/base.class.d.ts +1 -0
- package/lib/core/base.class.js.map +1 -1
- package/lib/core/constants/adapters.d.ts +88 -0
- package/lib/core/constants/adapters.js +160 -0
- package/lib/core/constants/adapters.js.map +1 -0
- package/lib/core/constants/core.d.ts +71 -0
- package/lib/core/constants/core.js +75 -0
- package/lib/core/constants/core.js.map +1 -0
- package/lib/core/constants/vaults.d.ts +19 -0
- package/lib/core/constants/vaults.js +156 -0
- package/lib/core/constants/vaults.js.map +1 -0
- package/lib/core/constants/web3.d.ts +30 -0
- package/lib/core/constants/web3.js +100 -0
- package/lib/core/constants/web3.js.map +1 -0
- package/lib/core/constants.d.ts +88 -0
- package/lib/core/constants.js +148 -0
- package/lib/core/constants.js.map +1 -0
- package/lib/core/core.helpers.d.ts +23 -0
- package/lib/core/core.helpers.js +210 -0
- package/lib/core/core.helpers.js.map +1 -0
- package/lib/core/fetcher.d.ts +1 -1
- package/lib/core/fetcher.js +27 -27
- package/lib/core/fetcher.js.map +1 -1
- package/lib/core/helpers/adapters.d.ts +4 -0
- package/lib/core/helpers/adapters.js +28 -0
- package/lib/core/helpers/adapters.js.map +1 -0
- package/lib/core/helpers/core.d.ts +23 -0
- package/lib/core/helpers/core.js +210 -0
- package/lib/core/helpers/core.js.map +1 -0
- package/lib/core/helpers/signer.d.ts +5 -0
- package/lib/core/helpers/signer.js +54 -0
- package/lib/core/helpers/signer.js.map +1 -0
- package/lib/core/helpers/vaults.d.ts +16 -0
- package/lib/core/helpers/vaults.js +145 -0
- package/lib/core/helpers/vaults.js.map +1 -0
- package/lib/core/helpers/web3.d.ts +29 -0
- package/lib/core/helpers/web3.js +376 -0
- package/lib/core/helpers/web3.js.map +1 -0
- package/lib/core/index.d.ts +9 -9
- package/lib/core/index.js +9 -9
- package/lib/core/logger/slack.js +3 -3
- package/lib/core/logger/slack.js.map +1 -1
- package/lib/core/read.actions.d.ts +3 -0
- package/lib/core/read.actions.js +39 -0
- package/lib/core/read.actions.js.map +1 -0
- package/lib/core/vault.utils.d.ts +4 -0
- package/lib/core/vault.utils.js +35 -0
- package/lib/core/vault.utils.js.map +1 -0
- package/lib/core/web3.helpers.d.ts +29 -0
- package/lib/core/web3.helpers.js +365 -0
- package/lib/core/web3.helpers.js.map +1 -0
- package/lib/core/write.actions.d.ts +9 -0
- package/lib/core/write.actions.js +51 -0
- package/lib/core/write.actions.js.map +1 -0
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/lib/main.d.ts +3 -0
- package/lib/main.js.map +1 -1
- package/lib/modules/vaults/adapter.helpers.js +4 -4
- package/lib/modules/vaults/adapter.helpers.js.map +1 -1
- package/lib/modules/vaults/constants.d.ts +63 -0
- package/lib/modules/vaults/constants.js +186 -0
- package/lib/modules/vaults/constants.js.map +1 -0
- package/lib/modules/vaults/getters.d.ts +6 -2
- package/lib/modules/vaults/getters.js +142 -43
- package/lib/modules/vaults/getters.js.map +1 -1
- package/lib/modules/vaults/main.d.ts +4 -1
- package/lib/modules/vaults/main.js +4 -6
- package/lib/modules/vaults/main.js.map +1 -1
- package/lib/modules/vaults/utils.js +10 -5
- package/lib/modules/vaults/utils.js.map +1 -1
- package/lib/modules/vaults/vault.actions.d.ts +10 -0
- package/lib/modules/vaults/vault.actions.js +95 -0
- package/lib/modules/vaults/vault.actions.js.map +1 -0
- package/lib/services/debank/utils.js +4 -4
- package/lib/services/debank/utils.js.map +1 -1
- package/lib/services/octavfi/fetcher.d.ts +2 -0
- package/lib/services/octavfi/fetcher.js +73 -0
- package/lib/services/octavfi/fetcher.js.map +1 -0
- package/lib/services/octavfi/index.d.ts +3 -0
- package/lib/services/octavfi/index.js +20 -0
- package/lib/services/octavfi/index.js.map +1 -0
- package/lib/services/octavfi/types.d.ts +34 -0
- package/lib/services/octavfi/types.js +3 -0
- package/lib/services/octavfi/types.js.map +1 -0
- package/lib/services/octavfi/utils.d.ts +3 -0
- package/lib/services/octavfi/utils.js +178 -0
- package/lib/services/octavfi/utils.js.map +1 -0
- package/lib/services/subgraph/vaults.js +60 -11
- package/lib/services/subgraph/vaults.js.map +1 -1
- package/lib/types/pools.d.ts +1 -1
- package/lib/types/vaults.d.ts +1 -0
- package/lib/types/webserver.d.ts +1 -0
- package/package.json +1 -1
|
@@ -4,7 +4,7 @@ exports.getParaswapQuote = getParaswapQuote;
|
|
|
4
4
|
exports.buildSwapAndDepositTransaction = buildSwapAndDepositTransaction;
|
|
5
5
|
exports.buildNativeDepositTransaction = buildNativeDepositTransaction;
|
|
6
6
|
exports.previewAdapterDeposit = previewAdapterDeposit;
|
|
7
|
-
const
|
|
7
|
+
const adapters_1 = require("../../core/constants/adapters");
|
|
8
8
|
const abis_1 = require("../../abis");
|
|
9
9
|
const core_1 = require("../../core");
|
|
10
10
|
const PARASWAP_PRICES_API = 'https://api.paraswap.io/prices';
|
|
@@ -58,7 +58,7 @@ async function buildNativeDepositTransaction({ signer, srcToken, amount, poolNam
|
|
|
58
58
|
provider: signer,
|
|
59
59
|
abi: adapterConfig.abi || abis_1.ABI_WRAPPER_ADAPTER,
|
|
60
60
|
});
|
|
61
|
-
if (poolName ===
|
|
61
|
+
if (poolName === adapters_1.POOL_NAMES.ETH_TREEHOUSE_GROWTH) {
|
|
62
62
|
if (isNative) {
|
|
63
63
|
return {
|
|
64
64
|
contract: wrapperContract,
|
|
@@ -73,7 +73,7 @@ async function buildNativeDepositTransaction({ signer, srcToken, amount, poolNam
|
|
|
73
73
|
args: [BigInt(amount), adapterConfig.referralId],
|
|
74
74
|
};
|
|
75
75
|
}
|
|
76
|
-
if (poolName ===
|
|
76
|
+
if (poolName === adapters_1.POOL_NAMES.AVAX_AVAX) {
|
|
77
77
|
return {
|
|
78
78
|
contract: wrapperContract,
|
|
79
79
|
functionName: 'depositETH',
|
|
@@ -81,7 +81,7 @@ async function buildNativeDepositTransaction({ signer, srcToken, amount, poolNam
|
|
|
81
81
|
value: BigInt(amount),
|
|
82
82
|
};
|
|
83
83
|
}
|
|
84
|
-
if (poolName ===
|
|
84
|
+
if (poolName === adapters_1.POOL_NAMES.ETH_KELP_TAC_RSETH) {
|
|
85
85
|
if (isNative) {
|
|
86
86
|
return {
|
|
87
87
|
contract: wrapperContract,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.helpers.js","sourceRoot":"","sources":["../../../src.ts/modules/vaults/adapter.helpers.ts"],"names":[],"mappings":";;AA6BA,4CAoCC;AAQD,wEA4CC;AAKD,sEAoFC;AAKD,sDAgEC;AAzQD,
|
|
1
|
+
{"version":3,"file":"adapter.helpers.js","sourceRoot":"","sources":["../../../src.ts/modules/vaults/adapter.helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { IAddress, IContractRunner, IPoolFunctions } from '../../types';
|
|
2
|
+
export declare const VAULT_AgoraAUSD: IAddress;
|
|
3
|
+
export declare const SUBACCOUNT_CALEB: IAddress;
|
|
4
|
+
export declare const WRAPPER_ADAPTOR: {
|
|
5
|
+
43114: IAddress;
|
|
6
|
+
1: IAddress;
|
|
7
|
+
};
|
|
8
|
+
export declare const VAULT_FUNCTIONS_V1: IPoolFunctions[];
|
|
9
|
+
export declare const VAULT_FUNCTIONS_V2: IPoolFunctions[];
|
|
10
|
+
export declare const VAULT_FUNCTIONS_V2_RECEIPT: IPoolFunctions[];
|
|
11
|
+
export declare const VAULT_FUNCTIONS_V2_WHITELISTED_ASSETS: IPoolFunctions[];
|
|
12
|
+
export declare const SUBGRAPH_POOL_URLS: (apiKey: string, chainId?: number, pool?: IAddress) => {
|
|
13
|
+
1: string;
|
|
14
|
+
8453: string;
|
|
15
|
+
43114: string;
|
|
16
|
+
42161: string;
|
|
17
|
+
56: string;
|
|
18
|
+
} | {
|
|
19
|
+
999: string;
|
|
20
|
+
};
|
|
21
|
+
export declare const IDLE_CAPITAL_BORROWER_ADDRESS: `0x${string}`[];
|
|
22
|
+
export declare const SUBGRAPH_VAULT_URLS: {
|
|
23
|
+
tacUSR: string;
|
|
24
|
+
upINJUSDT: string;
|
|
25
|
+
'tac-tETH': string;
|
|
26
|
+
upBTC: string;
|
|
27
|
+
upAUSD: string;
|
|
28
|
+
TACcbBTC: string;
|
|
29
|
+
xUpUSDC: string;
|
|
30
|
+
uptBTC: string;
|
|
31
|
+
gtETH: string;
|
|
32
|
+
agETH: string;
|
|
33
|
+
upUSDC: string;
|
|
34
|
+
hgETH: string;
|
|
35
|
+
upsSYLVA: string;
|
|
36
|
+
hbBTC: string;
|
|
37
|
+
hbHYPE: string;
|
|
38
|
+
upAZT: string;
|
|
39
|
+
sUSDT: string;
|
|
40
|
+
upEDGE: string;
|
|
41
|
+
coreUSDC: string;
|
|
42
|
+
upcUSDO: string;
|
|
43
|
+
shiftETH: string;
|
|
44
|
+
upsUSDe: string;
|
|
45
|
+
upLBTC: string;
|
|
46
|
+
upAVAX: string;
|
|
47
|
+
TACrsEth: string;
|
|
48
|
+
mUSD: string;
|
|
49
|
+
wildUSD: string;
|
|
50
|
+
earnAUSD: string;
|
|
51
|
+
AlpineCoinshiftUSDC: string;
|
|
52
|
+
AlpineUSDCFlagship: string;
|
|
53
|
+
UpStrBTC: string;
|
|
54
|
+
maxiUSR: string;
|
|
55
|
+
upGAMMAusdc: string;
|
|
56
|
+
xHYPE: string;
|
|
57
|
+
};
|
|
58
|
+
type VaultSymbols = 'testWETHTSA' | 'tacUSR' | 'upINJUSDT' | 'tac-tETH' | 'upAUSD' | 'TACcbBTC' | 'xUpUSDC' | 'uptBTC' | 'gtETH' | 'agETH' | 'upUSDC' | 'hgETH' | 'upsSYLVA' | 'hbBTC' | 'hbHYPE' | 'upAZT' | 'sUSDT' | 'upEDGE' | 'coreUSDC' | 'upcUSDO' | 'shiftETH' | 'upsUSDe' | 'upLBTC' | 'upAVAX' | 'TACrsEth' | 'mUSD' | 'earnAUSD' | 'AlpineUSDCFlagship' | 'AlpineCoinshiftUSDC' | 'upBTC' | 'UpStrBTC' | 'maxiUSR' | 'upGAMMAusdc' | 'xHYPE' | 'wildUSD';
|
|
59
|
+
export declare const VAULT_SYMBOLS: Record<IAddress, VaultSymbols>;
|
|
60
|
+
export declare const VAULT_SYMBOLS_REVERSE: Record<VaultSymbols, IAddress>;
|
|
61
|
+
export declare const isBadVault: (address?: string) => boolean;
|
|
62
|
+
export declare function getVaultSymbol(vault: IAddress, provider: IContractRunner): Promise<string>;
|
|
63
|
+
export {};
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isBadVault = exports.VAULT_SYMBOLS_REVERSE = exports.VAULT_SYMBOLS = exports.SUBGRAPH_VAULT_URLS = exports.IDLE_CAPITAL_BORROWER_ADDRESS = exports.SUBGRAPH_POOL_URLS = exports.VAULT_FUNCTIONS_V2_WHITELISTED_ASSETS = exports.VAULT_FUNCTIONS_V2_RECEIPT = exports.VAULT_FUNCTIONS_V2 = exports.VAULT_FUNCTIONS_V1 = exports.WRAPPER_ADAPTOR = exports.SUBACCOUNT_CALEB = exports.VAULT_AgoraAUSD = void 0;
|
|
4
|
+
exports.getVaultSymbol = getVaultSymbol;
|
|
5
|
+
const core_1 = require("../../core");
|
|
6
|
+
const ethers_1 = require("ethers");
|
|
7
|
+
exports.VAULT_AgoraAUSD = (0, ethers_1.getAddress)('0x828BC5895b78b2fb591018Ca5bDC2064742D6D0f');
|
|
8
|
+
exports.SUBACCOUNT_CALEB = (0, ethers_1.getAddress)('0xFff71B0b66f076C60Fa2f176a34a6EA709ccF21B');
|
|
9
|
+
exports.WRAPPER_ADAPTOR = {
|
|
10
|
+
43114: (0, ethers_1.getAddress)('0xb2C57614B93c41A7Ec3B91980C0Bb7453904c6e8'),
|
|
11
|
+
1: (0, ethers_1.getAddress)('0x044155804b2ef8fc53C69E3661ceA9b905EDE7Bc'),
|
|
12
|
+
};
|
|
13
|
+
exports.VAULT_FUNCTIONS_V1 = [
|
|
14
|
+
'decimals',
|
|
15
|
+
'asset',
|
|
16
|
+
'totalSupply',
|
|
17
|
+
'totalAssets',
|
|
18
|
+
'maxSupply',
|
|
19
|
+
'withdrawalFee',
|
|
20
|
+
'lagDuration',
|
|
21
|
+
'withdrawalsPaused',
|
|
22
|
+
];
|
|
23
|
+
exports.VAULT_FUNCTIONS_V2 = [
|
|
24
|
+
'assetsWhitelistAddress',
|
|
25
|
+
'getTotalAssets',
|
|
26
|
+
'asset',
|
|
27
|
+
'withdrawalFee',
|
|
28
|
+
'maxDepositAmount',
|
|
29
|
+
'lagDuration',
|
|
30
|
+
'withdrawalsPaused',
|
|
31
|
+
'lpTokenAddress',
|
|
32
|
+
];
|
|
33
|
+
exports.VAULT_FUNCTIONS_V2_RECEIPT = [
|
|
34
|
+
'decimals',
|
|
35
|
+
'totalSupply',
|
|
36
|
+
];
|
|
37
|
+
exports.VAULT_FUNCTIONS_V2_WHITELISTED_ASSETS = [
|
|
38
|
+
'getWhitelistedAssets',
|
|
39
|
+
];
|
|
40
|
+
const SUBGRAPH_POOL_URLS = (apiKey, chainId, pool) => {
|
|
41
|
+
if (chainId === 999) {
|
|
42
|
+
if (!pool) {
|
|
43
|
+
throw new Error(`Pool address is required for chainId ${chainId}`);
|
|
44
|
+
}
|
|
45
|
+
switch (pool) {
|
|
46
|
+
case exports.VAULT_SYMBOLS_REVERSE.hbHYPE:
|
|
47
|
+
return {
|
|
48
|
+
999: 'https://api.goldsky.com/api/public/project_cm9g0xy3o4j6v01vd34r3hvv9/subgraphs/august-hyperevm-hyperbeat/1.0.0/gn',
|
|
49
|
+
};
|
|
50
|
+
case exports.VAULT_SYMBOLS_REVERSE.hbBTC:
|
|
51
|
+
return {
|
|
52
|
+
999: 'https://api.goldsky.com/api/public/project_cm9g0xy3o4j6v01vd34r3hvv9/subgraphs/august-hyperevm-hbBTC/1.0.0/gn',
|
|
53
|
+
};
|
|
54
|
+
default:
|
|
55
|
+
throw new Error(`Unsupported pool for chainId ${chainId}: ${pool}`);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
const urls = {
|
|
59
|
+
1: `https://gateway.thegraph.com/api/${apiKey}/subgraphs/id/BtbHLe7XtX2x9Ude9PKv2uagNHj6JYhjjFcimxvk7NPD`,
|
|
60
|
+
8453: `https://gateway.thegraph.com/api/${apiKey}/subgraphs/id/E96gN4ZAmtCwLfsYccy3TqCTBbizGPWssFFeZfJ5QSQP`,
|
|
61
|
+
43114: `https://gateway.thegraph.com/api/${apiKey}/subgraphs/id/Ho15f2DBGndTMAYx9bPxJzasQRsAd5oLdci4oZvWs2u6`,
|
|
62
|
+
42161: `https://gateway.thegraph.com/api/${apiKey}/subgraphs/id/BrqNoj6FWm678yFRKdVWBncwt3zUnpbA3u4n9A9puUSg`,
|
|
63
|
+
56: `https://gateway.thegraph.com/api/${apiKey}/subgraphs/id/4BDCXZvSBuNGX3ck6C6nTGos7Dg5SxjfHMjrKnQz4YE2`,
|
|
64
|
+
};
|
|
65
|
+
if (chainId && !(chainId in urls)) {
|
|
66
|
+
throw new Error(`Unsupported chainId: ${chainId}. Supported chains: ${Object.keys(urls).join(', ')}`);
|
|
67
|
+
}
|
|
68
|
+
return urls;
|
|
69
|
+
};
|
|
70
|
+
exports.SUBGRAPH_POOL_URLS = SUBGRAPH_POOL_URLS;
|
|
71
|
+
exports.IDLE_CAPITAL_BORROWER_ADDRESS = [
|
|
72
|
+
(0, ethers_1.getAddress)('0x2151C90C93F52bE82186f162c86DaEABc8911188'),
|
|
73
|
+
(0, ethers_1.getAddress)('0xb74c137E5f976dbdCC638Ec9fd3e05d6D9124E55'),
|
|
74
|
+
];
|
|
75
|
+
const GOLDSKY_BASE_URL = 'https://api.goldsky.com/api/private/project_cm9g0xy3o4j6v01vd34r3hvv9/subgraphs';
|
|
76
|
+
exports.SUBGRAPH_VAULT_URLS = {
|
|
77
|
+
tacUSR: `${GOLDSKY_BASE_URL}/august-eth-tacUSR/1.0.0/gn`,
|
|
78
|
+
upINJUSDT: `${GOLDSKY_BASE_URL}/august-eth-upINJUSDT/1.0.0/gn`,
|
|
79
|
+
'tac-tETH': `${GOLDSKY_BASE_URL}/august-eth-tactETH/1.0.0/gn`,
|
|
80
|
+
upBTC: `${GOLDSKY_BASE_URL}/august-eth-upBTC/1.0.0/gn`,
|
|
81
|
+
upAUSD: `${GOLDSKY_BASE_URL}/august-avax-upAUSD/1.0.0/gn`,
|
|
82
|
+
TACcbBTC: `${GOLDSKY_BASE_URL}/august-eth-TACcbBTC/1.0.0/gn`,
|
|
83
|
+
xUpUSDC: `${GOLDSKY_BASE_URL}/august-eth-xUpUSDC/1.0.0/gn`,
|
|
84
|
+
uptBTC: `${GOLDSKY_BASE_URL}/august-eth-uptBTC/1.0.0/gn`,
|
|
85
|
+
gtETH: `${GOLDSKY_BASE_URL}/august-eth-gtETH/1.0.0/gn`,
|
|
86
|
+
agETH: `${GOLDSKY_BASE_URL}/august-eth-agETH/1.0.0/gn`,
|
|
87
|
+
upUSDC: `${GOLDSKY_BASE_URL}/august-eth-upUSDC/1.0.0/gn`,
|
|
88
|
+
hgETH: `${GOLDSKY_BASE_URL}/august-eth-hgETH/1.0.0/gn`,
|
|
89
|
+
upsSYLVA: `${GOLDSKY_BASE_URL}/august-eth-upsSYLVA/1.0.0/gn`,
|
|
90
|
+
hbBTC: `${GOLDSKY_BASE_URL}/august-hyperevm-hbBTC/1.0.0/gn`,
|
|
91
|
+
hbHYPE: `${GOLDSKY_BASE_URL}/august-hyperevm-hyperbeat/1.0.0/gn`,
|
|
92
|
+
upAZT: `${GOLDSKY_BASE_URL}/august-eth-upAZT/1.0.0/gn`,
|
|
93
|
+
sUSDT: `${GOLDSKY_BASE_URL}/august-bsc-sUSDT/1.0.0/gn`,
|
|
94
|
+
upEDGE: `${GOLDSKY_BASE_URL}/august-eth-upEDGE/1.0.0/gn`,
|
|
95
|
+
coreUSDC: `${GOLDSKY_BASE_URL}/august-eth-coreUSDC/1.0.0/gn`,
|
|
96
|
+
upcUSDO: `${GOLDSKY_BASE_URL}/august-eth-upcUSDO/1.0.0/gn`,
|
|
97
|
+
shiftETH: `${GOLDSKY_BASE_URL}/august-eth-shiftETH/1.0.0/gn`,
|
|
98
|
+
upsUSDe: `${GOLDSKY_BASE_URL}/august-eth-upsUSDe/1.0.0/gn`,
|
|
99
|
+
upLBTC: `${GOLDSKY_BASE_URL}/august-eth-upLBTC/1.0.0/gn`,
|
|
100
|
+
upAVAX: `${GOLDSKY_BASE_URL}/august-avax-upAVAX/1.0.0/gn`,
|
|
101
|
+
TACrsEth: `${GOLDSKY_BASE_URL}/august-eth-TACrsEth/1.0.0/gn`,
|
|
102
|
+
mUSD: `${GOLDSKY_BASE_URL}/august-mezo-mUSD/1.0.0/gn`,
|
|
103
|
+
wildUSD: `${GOLDSKY_BASE_URL}/august-eth-wildUSD/1.0.0/gn`,
|
|
104
|
+
earnAUSD: `${GOLDSKY_BASE_URL}/august-eth-earnAUSD/1.0.0/gn`,
|
|
105
|
+
AlpineCoinshiftUSDC: `${GOLDSKY_BASE_URL}/august-eth-AlpineCoinshiftUSDC/1.0.0/gn`,
|
|
106
|
+
AlpineUSDCFlagship: `${GOLDSKY_BASE_URL}/august-eth-AlpineUSDCFlagship/1.0.0/gn`,
|
|
107
|
+
UpStrBTC: `${GOLDSKY_BASE_URL}/august-eth-UpStrBTC/1.0.0/gn`,
|
|
108
|
+
maxiUSR: `${GOLDSKY_BASE_URL}/august-eth-maxiUSR/1.0.0/gn`,
|
|
109
|
+
upGAMMAusdc: `${GOLDSKY_BASE_URL}/august-eth-upGAMMAusdc/1.0.0/gn`,
|
|
110
|
+
xHYPE: `${GOLDSKY_BASE_URL}/august-hyperevm-xHYPE/1.0.0/gn`,
|
|
111
|
+
};
|
|
112
|
+
exports.VAULT_SYMBOLS = {
|
|
113
|
+
'0x686c83Aa81ba206354fDcbc2cd282B4531365E29': 'tacUSR',
|
|
114
|
+
'0x02991EE6134dEE504668e2227C5879Dd78EfCDc3': 'upINJUSDT',
|
|
115
|
+
'0xf7b65fBA4d02110089fC6e2bE6d73809b45852f8': 'tac-tETH',
|
|
116
|
+
'0x3408b22d8895753C9A3e14e4222E981d4E9A599E': 'upAUSD',
|
|
117
|
+
'0xeb402fc96C7ed2f889d837C9976D6d821c1B5f01': 'TACcbBTC',
|
|
118
|
+
'0x396A3f77EE1faf5A3C46e878bA7b7a2dcbe55517': 'xUpUSDC',
|
|
119
|
+
'0x8AcA0841993ef4C87244d519166e767f49362C21': 'uptBTC',
|
|
120
|
+
'0x5Fde59415625401278c4d41C6beFCe3790eb357f': 'gtETH',
|
|
121
|
+
'0xe1B4d34E8754600962Cd944B535180Bd758E6c2e': 'agETH',
|
|
122
|
+
'0x80E1048eDE66ec4c364b4F22C8768fc657FF6A42': 'upUSDC',
|
|
123
|
+
'0xc824A08dB624942c5E5F330d56530cD1598859fD': 'hgETH',
|
|
124
|
+
'0xc428439fB7B1EFE56360Eb837Ca98F551fdD9B26': 'upsSYLVA',
|
|
125
|
+
'0xc061d38903b99aC12713B550C2CB44B221674F94': 'hbBTC',
|
|
126
|
+
'0x96C6cBB6251Ee1c257b2162ca0f39AA5Fa44B1FB': 'hbHYPE',
|
|
127
|
+
'0x69FC3f84FD837217377d9Dae0212068cEB65818e': 'upAZT',
|
|
128
|
+
'0xD0b717ef23817b1a127139830Cf0FcD449ef74F0': 'sUSDT',
|
|
129
|
+
'0xEAA3b922E9fEbCa37d1c02D2142A59595094C605': 'upEDGE',
|
|
130
|
+
'0xE9B725010A9E419412ed67d0fA5f3A5f40159D32': 'coreUSDC',
|
|
131
|
+
'0x7383c2454D23A1e34B35ba02674be0a41Bd5aa56': 'upcUSDO',
|
|
132
|
+
'0xB78dAf3fD674B81ebeaaa88d711506fa069E1C5E': 'shiftETH',
|
|
133
|
+
'0xd684AF965b1c17D628ee0d77cae94259c41260F4': 'upsUSDe',
|
|
134
|
+
'0x8EC5C8642397791cff83563C9C83b9C1409D5F48': 'testWETHTSA',
|
|
135
|
+
'0x4e2D90f0307A93b54ACA31dc606F93FE6b9132d2': 'upLBTC',
|
|
136
|
+
'0xB2bFb52cfc40584AC4e9e2B36a5B8d6554A56e0b': 'upAVAX',
|
|
137
|
+
'0x419386E3Ef42368e602720CC458e00c0B28c47A7': 'TACrsEth',
|
|
138
|
+
'0x221B2D9aD7B994861Af3f4c8A80c86C4aa86Bf53': 'mUSD',
|
|
139
|
+
'0x828BC5895b78b2fb591018Ca5bDC2064742D6D0f': 'earnAUSD',
|
|
140
|
+
'0xD066649Bcb7d8D3335fE29CaD0AED6E17D5828B5': 'AlpineUSDCFlagship',
|
|
141
|
+
'0x0985C88929A776a2E059615137a48bA5A473E25D': 'AlpineCoinshiftUSDC',
|
|
142
|
+
'0xEBac5e50003d4B17Be422ff9775043cD61002f7f': 'upBTC',
|
|
143
|
+
'0x787f5541Ee40cD0c94175251686DDBbcf69A7344': 'UpStrBTC',
|
|
144
|
+
'0xdA89af5bF2eb0B225d787aBfA9095610f2E79e7D': 'maxiUSR',
|
|
145
|
+
'0x998D7b14c123c1982404562b68edDB057b0477cB': 'upGAMMAusdc',
|
|
146
|
+
'0x3a214b33A648f17fdcb78eD895dD0579dc3cc330': 'xHYPE',
|
|
147
|
+
'0x18EE038C114a07f4B08b420fb1E4149a4F357249': 'wildUSD',
|
|
148
|
+
};
|
|
149
|
+
exports.VAULT_SYMBOLS_REVERSE = Object.fromEntries(Object.entries(exports.VAULT_SYMBOLS).map(([key, value]) => [value, key]));
|
|
150
|
+
const isBadVault = (address) => {
|
|
151
|
+
if (!address)
|
|
152
|
+
return false;
|
|
153
|
+
switch (address) {
|
|
154
|
+
case '0x706162790b601A8514c18718d0c63C9D1268e89C':
|
|
155
|
+
return true;
|
|
156
|
+
case '0xd684AF965b1c17D628ee0d77cae94259c41260F4':
|
|
157
|
+
return true;
|
|
158
|
+
case '0xB78dAf3fD674B81ebeaaa88d711506fa069E1C5E':
|
|
159
|
+
return true;
|
|
160
|
+
case '0x4e2D90f0307A93b54ACA31dc606F93FE6b9132d2':
|
|
161
|
+
return true;
|
|
162
|
+
case '0x18a5a3D575F34e5eBa92ac99B0976dBe26f9F869':
|
|
163
|
+
return true;
|
|
164
|
+
case '0xD0b717ef23817b1a127139830Cf0FcD449ef74F0':
|
|
165
|
+
return true;
|
|
166
|
+
case '0xeb402fc96C7ed2f889d837C9976D6d821c1B5f01':
|
|
167
|
+
return true;
|
|
168
|
+
case '0xEBac5e50003d4B17Be422ff9775043cD61002f7f':
|
|
169
|
+
return true;
|
|
170
|
+
case '0x419386E3Ef42368e602720CC458e00c0B28c47A7':
|
|
171
|
+
return true;
|
|
172
|
+
default:
|
|
173
|
+
return false;
|
|
174
|
+
}
|
|
175
|
+
};
|
|
176
|
+
exports.isBadVault = isBadVault;
|
|
177
|
+
async function getVaultSymbol(vault, provider) {
|
|
178
|
+
const address = (0, ethers_1.getAddress)(vault);
|
|
179
|
+
if (address in exports.VAULT_SYMBOLS)
|
|
180
|
+
return exports.VAULT_SYMBOLS[address];
|
|
181
|
+
else {
|
|
182
|
+
const symbol = await (0, core_1.getSymbol)(provider, vault);
|
|
183
|
+
return symbol;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
//# sourceMappingURL=constants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src.ts/modules/vaults/constants.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IAddress, INormalizedNumber, IVault, IVaultAllocations, IVaultAvailableRedemption, IVaultLoan, IVaultPosition, IVaultRedemptionHistoryItem, IActiveStakingPosition, IVaultHistoricalParams } from '../../types';
|
|
1
|
+
import { IAddress, INormalizedNumber, ISubgraphWithdrawProccessed, IVault, IVaultAllocations, IVaultAvailableRedemption, IVaultLoan, IVaultPosition, IVaultRedemptionHistoryItem, IActiveStakingPosition, IVaultHistoricalParams } from '../../types';
|
|
2
2
|
import { IVaultBaseOptions } from '.';
|
|
3
3
|
export declare function getVault({ vault, loans, allocations, options, }: {
|
|
4
4
|
vault: IAddress;
|
|
@@ -11,8 +11,12 @@ export declare function getVaultAllocations(vault: IAddress, options: IVaultBase
|
|
|
11
11
|
export declare function getVaultAvailableRedemptions({ vault, wallet, options, }: {
|
|
12
12
|
vault: IAddress;
|
|
13
13
|
wallet?: IAddress;
|
|
14
|
-
options: IVaultBaseOptions
|
|
14
|
+
options: IVaultBaseOptions & {
|
|
15
|
+
verbose?: boolean;
|
|
16
|
+
};
|
|
15
17
|
}): Promise<{
|
|
18
|
+
processedWithdrawals: ISubgraphWithdrawProccessed[];
|
|
19
|
+
requestedWithdrawals: import("../../types").ISubgraphWithdrawRequest[];
|
|
16
20
|
availableRedemptions: IVaultAvailableRedemption[];
|
|
17
21
|
pendingRedemptions: IVaultAvailableRedemption[];
|
|
18
22
|
}>;
|
|
@@ -60,6 +60,7 @@ const EVM = __importStar(require("../../adapters/evm"));
|
|
|
60
60
|
const TokenizedVaultV2_1 = require("../../abis/TokenizedVaultV2");
|
|
61
61
|
const TokenizedVaultV2Receipt_1 = require("../../abis/TokenizedVaultV2Receipt");
|
|
62
62
|
const ethereum_block_by_date_1 = __importDefault(require("ethereum-block-by-date"));
|
|
63
|
+
const octavfi_1 = require("../../services/octavfi");
|
|
63
64
|
async function getVault({ vault, loans = false, allocations = false, options, }) {
|
|
64
65
|
let returnedVault;
|
|
65
66
|
try {
|
|
@@ -238,14 +239,39 @@ async function getVaultAllocations(vault, options) {
|
|
|
238
239
|
else {
|
|
239
240
|
for (const borrower of uniqueBorrowers) {
|
|
240
241
|
try {
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
242
|
+
let debankRes;
|
|
243
|
+
const isSolanaAddress = solana_1.Solana.utils.isSolanaAddress(borrower);
|
|
244
|
+
if (isSolanaAddress) {
|
|
245
|
+
try {
|
|
246
|
+
const octavfiPortfolios = await (0, octavfi_1.fetchOctavfiPortfolios)([borrower]);
|
|
247
|
+
if (octavfiPortfolios.length > 0) {
|
|
248
|
+
debankRes = (0, octavfi_1.transformOctavfiToDebank)(octavfiPortfolios[0]);
|
|
249
|
+
}
|
|
250
|
+
else {
|
|
251
|
+
debankRes = false;
|
|
252
|
+
debankErr = true;
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
catch (octavfiError) {
|
|
256
|
+
core_1.Logger.log.error('getVaultAllocations:octavfi', octavfiError, {
|
|
257
|
+
borrower,
|
|
258
|
+
});
|
|
259
|
+
debankRes = false;
|
|
260
|
+
debankErr = true;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
debankRes = await (0, debank_1.fetchDebankResponse)(borrower);
|
|
265
|
+
if (debankRes === false) {
|
|
266
|
+
debankErr = true;
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
if (debankRes !== false) {
|
|
270
|
+
(0, debank_1.parseVaultLevelDebank)(debankRes, protocolExposure, tokenExposure, borrower, exposurePerCategory, netValue);
|
|
271
|
+
unfilteredTokens = debankRes?.subaccount?.tokens;
|
|
272
|
+
const debankPerLoan = (0, debank_1.parseLoanLevelDebank)(debankRes);
|
|
273
|
+
defiPerBorrower[borrower] = debankPerLoan;
|
|
244
274
|
}
|
|
245
|
-
(0, debank_1.parseVaultLevelDebank)(debankRes, protocolExposure, tokenExposure, borrower, exposurePerCategory, netValue);
|
|
246
|
-
unfilteredTokens = debankRes?.subaccount?.tokens;
|
|
247
|
-
const debankPerLoan = (0, debank_1.parseLoanLevelDebank)(debankRes);
|
|
248
|
-
defiPerBorrower[borrower] = debankPerLoan;
|
|
249
275
|
}
|
|
250
276
|
catch (e) {
|
|
251
277
|
core_1.Logger.log.error('getVaultAllocations:debank', e, { borrower });
|
|
@@ -305,7 +331,16 @@ async function getVaultAvailableRedemptions({ vault, wallet, options, }) {
|
|
|
305
331
|
const provider = (0, core_1.createProvider)(options.rpcUrl);
|
|
306
332
|
const tokenizedVault = (await (0, core_1.fetchTokenizedVaults)(vault, options?.headers))?.[0];
|
|
307
333
|
if (!tokenizedVault) {
|
|
308
|
-
return {
|
|
334
|
+
return {
|
|
335
|
+
...{
|
|
336
|
+
availableRedemptions: [],
|
|
337
|
+
pendingRedemptions: [],
|
|
338
|
+
},
|
|
339
|
+
...(options.verbose && {
|
|
340
|
+
processedWithdrawals: [],
|
|
341
|
+
requestedWithdrawals: [],
|
|
342
|
+
}),
|
|
343
|
+
};
|
|
309
344
|
}
|
|
310
345
|
const version = (0, core_1.getVaultVersionV2)(tokenizedVault);
|
|
311
346
|
let abi;
|
|
@@ -327,6 +362,8 @@ async function getVaultAvailableRedemptions({ vault, wallet, options, }) {
|
|
|
327
362
|
abi: abi,
|
|
328
363
|
provider,
|
|
329
364
|
});
|
|
365
|
+
const ld = await vaultContract['lagDuration']();
|
|
366
|
+
const lagDuration = parseInt(ld);
|
|
330
367
|
const { withdrawalRequesteds, withdrawalProcesseds } = await (0, subgraph_1.getSubgraphAllWithdrawals)(vault, provider);
|
|
331
368
|
const availableRedemptions = [];
|
|
332
369
|
const pendingRedemptions = [];
|
|
@@ -335,46 +372,90 @@ async function getVaultAvailableRedemptions({ vault, wallet, options, }) {
|
|
|
335
372
|
core_1.Logger.log.warn('getVaultAvailableRedemptions', `Skipping invalid event: ${ev}`);
|
|
336
373
|
continue;
|
|
337
374
|
}
|
|
375
|
+
const date = new Date(Number(ev.timestamp_) * 1000);
|
|
376
|
+
let month;
|
|
377
|
+
let day;
|
|
378
|
+
let year;
|
|
379
|
+
if (version === 'evm-2') {
|
|
380
|
+
month = date.getMonth() + 1;
|
|
381
|
+
day = date.getDate();
|
|
382
|
+
year = date.getFullYear();
|
|
383
|
+
}
|
|
338
384
|
if (!ev.year || !ev.month || !ev.day || !ev.receiverAddr) {
|
|
339
|
-
|
|
340
|
-
|
|
385
|
+
if (version !== 'evm-2') {
|
|
386
|
+
core_1.Logger.log.warn('getVaultAvailableRedemptions', `Skipping event with missing required properties: ${ev}`);
|
|
387
|
+
continue;
|
|
388
|
+
}
|
|
389
|
+
else {
|
|
390
|
+
if (!year || !month || !day || !ev.receiverAddr) {
|
|
391
|
+
if (version !== 'evm-2') {
|
|
392
|
+
core_1.Logger.log.warn('getVaultAvailableRedemptions', `Skipping event with missing required properties: ${ev}`);
|
|
393
|
+
continue;
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
}
|
|
341
397
|
}
|
|
342
|
-
const fullDate =
|
|
343
|
-
|
|
344
|
-
|
|
398
|
+
const fullDate = version === 'evm-2'
|
|
399
|
+
? new Date(Number(ev.timestamp_) * 1000)
|
|
400
|
+
: new Date(Number(ev.year), Number(ev.month) - 1, Number(ev.day));
|
|
401
|
+
const foundRedemptionAgainstClaim = withdrawalProcesseds.find((h) => version === 'evm-2'
|
|
402
|
+
? new Date(h.timestamp_).toDateString() === fullDate.toDateString() &&
|
|
403
|
+
h.receiverAddr === ev.receiverAddr
|
|
404
|
+
: new Date(h.processedOn).toDateString() === fullDate.toDateString() &&
|
|
405
|
+
h.receiverAddr === ev.receiverAddr);
|
|
345
406
|
if (wallet && (0, ethers_1.isAddress)(wallet)) {
|
|
346
407
|
if (ev?.receiverAddr?.toLowerCase() === wallet.toLowerCase()) {
|
|
347
|
-
const alreadyRedeemed =
|
|
348
|
-
|
|
349
|
-
|
|
408
|
+
const alreadyRedeemed = version === 'evm-2'
|
|
409
|
+
? withdrawalProcesseds.find((red) => {
|
|
410
|
+
if (Number(ev.timestamp_) * 1000 + lagDuration * 1000 <=
|
|
411
|
+
1000 * Number(red.timestamp_) &&
|
|
412
|
+
red.receiverAddr.toLowerCase() === wallet.toLowerCase()) {
|
|
413
|
+
return red;
|
|
414
|
+
}
|
|
415
|
+
})
|
|
416
|
+
: availableRedemptions.find((red) => BigInt(red.day.raw) === BigInt(ev.day) &&
|
|
417
|
+
BigInt(red.month.raw) === BigInt(ev.month) &&
|
|
418
|
+
BigInt(red.year.raw) === BigInt(ev.year));
|
|
350
419
|
if (!(foundRedemptionAgainstClaim && alreadyRedeemed)) {
|
|
351
420
|
try {
|
|
352
421
|
switch (version) {
|
|
353
422
|
case 'evm-2': {
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
423
|
+
if (alreadyRedeemed) {
|
|
424
|
+
const index = withdrawalProcesseds.findIndex((item) => item.id === alreadyRedeemed.id);
|
|
425
|
+
if (index !== -1) {
|
|
426
|
+
withdrawalProcesseds.splice(index, 1);
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
if (!alreadyRedeemed) {
|
|
430
|
+
availableRedemptions.push({
|
|
431
|
+
id: ev.transactionHash_ || ev.id,
|
|
432
|
+
hash: ev.transactionHash_ || ev.id,
|
|
433
|
+
timestamp: Number(ev.timestamp_),
|
|
434
|
+
receiver: ev.receiverAddr,
|
|
435
|
+
day: (0, core_1.toNormalizedBn)(day, 0),
|
|
436
|
+
month: (0, core_1.toNormalizedBn)(month, 0),
|
|
437
|
+
year: (0, core_1.toNormalizedBn)(year, 0),
|
|
438
|
+
amount: (0, core_1.toNormalizedBn)(ev.shares, decimals),
|
|
439
|
+
date: fullDate,
|
|
440
|
+
vault,
|
|
441
|
+
});
|
|
442
|
+
}
|
|
443
|
+
const pendingCondition = Number(ev.timestamp_) * 1000 + 1000 * lagDuration <
|
|
444
|
+
Date.now();
|
|
445
|
+
if (pendingCondition && !alreadyRedeemed) {
|
|
446
|
+
pendingRedemptions.push({
|
|
447
|
+
id: ev.transactionHash_ || ev.id,
|
|
448
|
+
hash: ev.transactionHash_ || ev.id,
|
|
449
|
+
timestamp: Number(ev.timestamp_),
|
|
450
|
+
receiver: ev.receiverAddr,
|
|
451
|
+
day: (0, core_1.toNormalizedBn)(day, 0),
|
|
452
|
+
month: (0, core_1.toNormalizedBn)(month, 0),
|
|
453
|
+
year: (0, core_1.toNormalizedBn)(year, 0),
|
|
454
|
+
amount: (0, core_1.toNormalizedBn)(ev.shares || BigInt(0), decimals),
|
|
455
|
+
date: fullDate,
|
|
456
|
+
vault,
|
|
457
|
+
});
|
|
458
|
+
}
|
|
378
459
|
break;
|
|
379
460
|
}
|
|
380
461
|
default: {
|
|
@@ -444,11 +525,29 @@ async function getVaultAvailableRedemptions({ vault, wallet, options, }) {
|
|
|
444
525
|
}
|
|
445
526
|
}
|
|
446
527
|
}
|
|
447
|
-
return {
|
|
528
|
+
return {
|
|
529
|
+
...{
|
|
530
|
+
availableRedemptions,
|
|
531
|
+
pendingRedemptions,
|
|
532
|
+
},
|
|
533
|
+
...(options.verbose && {
|
|
534
|
+
processedWithdrawals: withdrawalProcesseds,
|
|
535
|
+
requestedWithdrawals: withdrawalRequesteds,
|
|
536
|
+
}),
|
|
537
|
+
};
|
|
448
538
|
}
|
|
449
539
|
catch (e) {
|
|
450
540
|
core_1.Logger.log.error('getVaultAvailableRedemptions', e, { vault, wallet });
|
|
451
|
-
return {
|
|
541
|
+
return {
|
|
542
|
+
...{
|
|
543
|
+
availableRedemptions: [],
|
|
544
|
+
pendingRedemptions: [],
|
|
545
|
+
},
|
|
546
|
+
...(options.verbose && {
|
|
547
|
+
processedWithdrawals: [],
|
|
548
|
+
requestedWithdrawals: [],
|
|
549
|
+
}),
|
|
550
|
+
};
|
|
452
551
|
}
|
|
453
552
|
}
|
|
454
553
|
async function getVaultRedemptionHistory({ vault, wallet, options, }) {
|
|
@@ -593,7 +692,7 @@ async function getVaultPositions({ vault, wallet, solanaWallet, options, }) {
|
|
|
593
692
|
wallet,
|
|
594
693
|
options,
|
|
595
694
|
});
|
|
596
|
-
const aggregateAvailableRedemptions = availableRedemptions
|
|
695
|
+
const aggregateAvailableRedemptions = availableRedemptions.reduce((acc, curr) => acc + BigInt(curr.amount.raw), BigInt(0));
|
|
597
696
|
return {
|
|
598
697
|
vault,
|
|
599
698
|
status: renderStatus(availableRedemptions, balance),
|