Skip to content

Commit 606e1ee

Browse files
authored
Add Linea rsteth and ezeth (#1473)
* Re-use chainConfig as source of truth for earliestBlock * Refactor to camelCase util * Add token icon for rseth * colocate these closer to where they're used * Build for linea * Update token fiat price to handle native eth on any chain
1 parent 3099256 commit 606e1ee

File tree

24 files changed

+912
-309
lines changed

24 files changed

+912
-309
lines changed

apps/hyperdrive-trading/src/ui/token/hooks/useTokenFiatPrice.ts

Lines changed: 17 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,18 @@
11
import { parseFixed } from "@delvtech/fixed-point-wasm";
22
import { useQuery } from "@tanstack/react-query";
3+
import { ZERO_ADDRESS } from "src/base/constants";
34
import { makeQueryKey } from "src/base/makeQueryKey";
45
import { isTestnetChain } from "src/chains/isTestnetChain";
6+
import { ETH_MAGIC_NUMBER } from "src/token/ETH_MAGIC_NUMBER";
57
import { Address } from "viem";
6-
import { useChains } from "wagmi";
8+
import { gnosis, linea, mainnet } from "viem/chains";
79

10+
// NOTE: DefiLlama chain name identifier must be lower case.
11+
const defiLlamaChainNameIdentifier: Record<number, string> = {
12+
[mainnet.id]: "ethereum",
13+
[gnosis.id]: "gnosis",
14+
[linea.id]: "linea",
15+
};
816
export function useTokenFiatPrice({
917
tokenAddress,
1018
chainId,
@@ -14,13 +22,15 @@ export function useTokenFiatPrice({
1422
}): {
1523
fiatPrice: bigint | undefined;
1624
} {
17-
const chains = useChains();
18-
const chainName =
19-
chains?.find((network) => network.id === chainId)?.name ?? "ethereum";
20-
// NOTE: DefiLlama chain name identifier must be lower case.
21-
const defiLlamaTokenId = `${chainName.toLowerCase()}:${tokenAddress}`;
25+
// Always use mainnet ETH as the reference for native ETH price, regardless of
26+
// the current chain.
27+
let defiLlamaTokenId = `${defiLlamaChainNameIdentifier[chainId]}:${tokenAddress}`;
28+
if (tokenAddress === ETH_MAGIC_NUMBER) {
29+
defiLlamaTokenId = `ethereum:${ETH_MAGIC_NUMBER}`;
30+
}
2231

23-
const queryEnabled = !isTestnetChain(chainId) && !!tokenAddress;
32+
const queryEnabled =
33+
!isTestnetChain(chainId) && !!tokenAddress && tokenAddress !== ZERO_ADDRESS;
2434

2535
const { data } = useQuery({
2636
queryKey: makeQueryKey("tokenFiatPrice", { defiLlamaTokenId }),

packages/hyperdrive-appconfig/package.json

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,7 @@
1616
"gen:gnosis": "npx tsx ./src/scripts/gnosis.ts",
1717
"gen:sepolia": "npx tsx ./src/scripts/sepolia.ts",
1818
"gen:mainnet": "npx tsx ./src/scripts/mainnet.ts",
19+
"gen:linea": "npx tsx ./src/scripts/linea.ts",
1920
"generate": "npx tsx ./src/scripts/generate.ts",
2021
"build": "tsup src/index.ts --minify --format esm --clean --dts",
2122
"typecheck": "tsc --noEmit"
@@ -28,6 +29,8 @@
2829
"@hyperdrive/tsconfig": "*",
2930
"lodash.uniqby": "^4.7.0",
3031
"@types/lodash.uniqby": "^4.7.9",
32+
"lodash.camelcase": "^4.3.0",
33+
"@types/lodash.camelcase": "^4.3.9",
3134
"abitype": "^0.9.8",
3235
"dotenv": "^16.0.3",
3336
"tsx": "^4.7.0",

packages/hyperdrive-appconfig/src/appconfig/getAppConfig.ts

Lines changed: 46 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,7 @@ import {
1515
ETH_ICON_URL,
1616
EZETH_ICON_URL,
1717
RETH_ICON_URL,
18+
RSETH_ICON_URL,
1819
SDAI_ICON_URL,
1920
STUSD_ICON_URL,
2021
SXDAI_ICON_URL,
@@ -44,6 +45,45 @@ const hyperdriveKindResolvers: Record<
4445
string /* kind */,
4546
HyperdriveConfigResolver
4647
> = {
48+
RsETHLineaHyperdrive: async (hyperdrive, publicClient, earliestBlock) => {
49+
return getCustomHyperdrive({
50+
hyperdrive,
51+
yieldSource: "rseth",
52+
baseTokenIconUrl: ETH_ICON_URL,
53+
sharesTokenIconUrl: RSETH_ICON_URL,
54+
tokenPlaces: 4,
55+
sharesTokenTags: ["liquidStakingToken"],
56+
depositOptions: {
57+
isBaseTokenDepositEnabled: true,
58+
isShareTokenDepositsEnabled: true,
59+
},
60+
withdrawalOptions: {
61+
isBaseTokenWithdrawalEnabled: false,
62+
isShareTokenWithdrawalEnabled: true,
63+
},
64+
earliestBlock,
65+
});
66+
},
67+
68+
EzETHLineaHyperdrive: async (hyperdrive, publicClient, earliestBlock) => {
69+
return getCustomHyperdrive({
70+
hyperdrive,
71+
yieldSource: "lineaEzeth",
72+
baseTokenIconUrl: ETH_ICON_URL,
73+
sharesTokenIconUrl: EZETH_ICON_URL,
74+
tokenPlaces: 4,
75+
sharesTokenTags: ["liquidStakingToken"],
76+
depositOptions: {
77+
isBaseTokenDepositEnabled: false,
78+
isShareTokenDepositsEnabled: true,
79+
},
80+
withdrawalOptions: {
81+
isBaseTokenWithdrawalEnabled: false,
82+
isShareTokenWithdrawalEnabled: true,
83+
},
84+
earliestBlock,
85+
});
86+
},
4787
ChainlinkHyperdrive: async (hyperdrive, publicClient, earliestBlock) =>
4888
getGnosisWstethHyperdrive({
4989
hyperdrive,
@@ -52,7 +92,7 @@ const hyperdriveKindResolvers: Record<
5292
EETHHyperdrive: async (hyperdrive) =>
5393
getCustomHyperdrive({
5494
hyperdrive,
55-
yieldSource: "eEth",
95+
yieldSource: "eeth",
5696
baseTokenIconUrl: ETH_ICON_URL,
5797
sharesTokenIconUrl: EETH_ICON_URL,
5898
sharesTokenTags: ["liquidStakingToken"],
@@ -69,7 +109,7 @@ const hyperdriveKindResolvers: Record<
69109
EzETHHyperdrive: async (hyperdrive: ReadHyperdrive) =>
70110
getCustomHyperdrive({
71111
hyperdrive,
72-
yieldSource: "ezEth",
112+
yieldSource: "ezeth",
73113
depositOptions: {
74114
isBaseTokenDepositEnabled: false,
75115
isShareTokenDepositsEnabled: true,
@@ -105,8 +145,6 @@ const hyperdriveKindResolvers: Record<
105145
StETHHyperdrive: (hyperdrive) => getStethHyperdrive({ hyperdrive }),
106146

107147
ERC4626Hyperdrive: async (hyperdrive, publicClient, earliestBlock) => {
108-
const readSharesToken = await hyperdrive.getSharesToken();
109-
const sharesTokenSymbol = await readSharesToken.getSymbol();
110148
const hyperdriveName = await publicClient.readContract({
111149
address: hyperdrive.address,
112150
abi: hyperdrive.contract.abi,
@@ -143,7 +181,7 @@ const hyperdriveKindResolvers: Record<
143181
return getCustomHyperdrive({
144182
hyperdrive,
145183
earliestBlock,
146-
yieldSource: "sxDai",
184+
yieldSource: "sxdai",
147185
depositOptions: {
148186
isBaseTokenDepositEnabled: true,
149187
isShareTokenDepositsEnabled: true,
@@ -162,7 +200,7 @@ const hyperdriveKindResolvers: Record<
162200
if (hyperdriveName.includes("stUSD Hyperdrive")) {
163201
return getCustomHyperdrive({
164202
hyperdrive,
165-
yieldSource: "stUSD",
203+
yieldSource: "stusd",
166204
depositOptions: {
167205
isBaseTokenDepositEnabled: true,
168206
isShareTokenDepositsEnabled: true,
@@ -178,6 +216,8 @@ const hyperdriveKindResolvers: Record<
178216
});
179217
}
180218

219+
const readSharesToken = await hyperdrive.getSharesToken();
220+
const sharesTokenSymbol = await readSharesToken.getSymbol();
181221
throw new Error(
182222
`Unknown ERC4626Hyperdrive, name: ${hyperdriveName}, sharesTokenSymbol: ${sharesTokenSymbol}, hyperdrive address: ${hyperdrive.address}.`,
183223
);

packages/hyperdrive-appconfig/src/chains/chains.ts

Lines changed: 24 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -25,6 +25,28 @@ export interface ChainConfig {
2525
earliestBlock?: bigint;
2626
}
2727

28+
export const lineaChainConfig: ChainConfig = {
29+
id: linea.id,
30+
name: "Linea",
31+
blockExplorerName: "Lineascan",
32+
blockExplorerUrl: "https://lineascan.build/",
33+
earliestBlock: 9245278n, // block that the registry was deployed at
34+
dailyAverageBlocks: 43200n, // 2-second block times according to lineascan
35+
iconUrl:
36+
"",
37+
};
38+
39+
export const gnosisChainConfig: ChainConfig = {
40+
id: gnosis.id,
41+
name: "Gnosis",
42+
blockExplorerName: "Gnosisscan",
43+
blockExplorerUrl: "https://gnosisscan.io",
44+
earliestBlock: 35732205n,
45+
dailyAverageBlocks: 16605n,
46+
iconUrl:
47+
"",
48+
};
49+
2850
export const chains: Record<ChainId, ChainConfig> = {
2951
/* Mainnet chains */
3052
[mainnet.id]: {
@@ -36,26 +58,8 @@ export const chains: Record<ChainId, ChainConfig> = {
3658
iconUrl:
3759
"",
3860
},
39-
[gnosis.id]: {
40-
id: gnosis.id,
41-
name: "Gnosis",
42-
blockExplorerName: "Gnosisscan",
43-
blockExplorerUrl: "https://gnosisscan.io",
44-
earliestBlock: 35732205n,
45-
dailyAverageBlocks: 16605n,
46-
iconUrl:
47-
"",
48-
},
49-
[linea.id]: {
50-
id: linea.id,
51-
name: "Linea",
52-
blockExplorerName: "Lineascan",
53-
blockExplorerUrl: "https://lineascan.build/",
54-
earliestBlock: 9245278n, // block that the registry was deployed at
55-
dailyAverageBlocks: 43200n, // 2-second block times according to lineascan
56-
iconUrl:
57-
"",
58-
},
61+
[gnosis.id]: gnosisChainConfig,
62+
[linea.id]: lineaChainConfig,
5963

6064
/* Testnets */
6165
[cloudChain.id]: {

0 commit comments

Comments
 (0)