Skip to content

Commit

Permalink
fix steth conversion bug on OpenLongPreview (#1117)
Browse files Browse the repository at this point in the history
* checks if steth market for baseAmount on openlong

* move isSteth logic to appconfig
  • Loading branch information
jackburrus authored May 30, 2024
1 parent 2e5eae1 commit 6f6a867
Show file tree
Hide file tree
Showing 4 changed files with 53 additions and 36 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { calculateAprFromPrice, Long } from "@delvtech/hyperdrive-viem";
import {
findBaseToken,
findYieldSourceToken,
HyperdriveConfig,
TokenConfig,
} from "@hyperdrive/appconfig";
Expand Down Expand Up @@ -40,6 +41,10 @@ export function OpenLongPreview({
baseTokenAddress: hyperdrive.baseToken,
tokens: appConfig.tokens,
});
const sharesToken = findYieldSourceToken({
yieldSourceTokenAddress: hyperdrive.sharesToken,
tokens: appConfig.tokens,
});
const { fixedAPR } = useCurrentFixedAPR(hyperdrive.address);

const termLengthMS = Number(hyperdrive.poolConfig.positionDuration * 1000n);
Expand Down Expand Up @@ -99,15 +104,16 @@ export function OpenLongPreview({
calculateAprFromPrice({
positionDuration:
hyperdrive.poolConfig.positionDuration || 0n,
baseAmount: asBase
? long.baseAmountPaid
: // TODO: move sharesAmountPaid into the sdk's Long interface
// instead of converting here
convertSharesToBase({
sharesAmount: long.baseAmountPaid,
vaultSharePrice: vaultSharePrice,
decimals: activeToken.decimals,
}),
baseAmount:
asBase || sharesToken.extensions.isSharesPeggedToBase
? long.baseAmountPaid
: // TODO: move sharesAmountPaid into the sdk's Long interface
// instead of converting here
convertSharesToBase({
sharesAmount: long.baseAmountPaid,
vaultSharePrice: vaultSharePrice,
decimals: activeToken.decimals,
}),
bondAmount: long.bondAmount,
}),
baseToken.decimals,
Expand Down
59 changes: 32 additions & 27 deletions packages/hyperdrive-appconfig/src/generated/11155111.appconfig.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export const sepoliaAppConfig: AppConfig = {
extensions: {
shortName: "Lido stETH",
protocol: "lido",
isSharesPeggedToBase: true,
},
},
{
Expand All @@ -31,20 +32,6 @@ export const sepoliaAppConfig: AppConfig = {
extensions: {},
iconUrl: "https://cryptologos.cc/logos/ethereum-eth-logo.png?v=029",
},
{
address: "0x3B57E3b2531a376Ee5B248943Bb6DE99E333BB5D",
decimals: 18,
places: 4,
name: "Renzo ezETH",
symbol: "ezETH",
iconUrl:
"",
tags: ["yieldSource", "ezeth"],
extensions: {
shortName: "Renzo ezETH",
protocol: "renzo",
},
},
{
address: "0xF4A3178BC28DaE9a842837a3421f8652CBCdf7bF",
decimals: 18,
Expand All @@ -57,19 +44,37 @@ export const sepoliaAppConfig: AppConfig = {
extensions: {
shortName: "Rocket Pool ETH",
protocol: "rocketPool",
isSharesPeggedToBase: false,
},
},
{
address: "0xAb1895c74902F2dbd40e76CB616d80e4aA780713",
address: "0x3B57E3b2531a376Ee5B248943Bb6DE99E333BB5D",
decimals: 18,
places: 4,
name: "Renzo ezETH",
symbol: "ezETH",
iconUrl:
"",
tags: ["yieldSource", "ezeth"],
extensions: {
shortName: "Renzo ezETH",
protocol: "renzo",
isSharesPeggedToBase: false,
},
},
{
address: "0x80191B6a6A8E2026209fB5d1e4e9CC9A73029511",
decimals: 18,
places: 2,
name: "Savings DAI",
symbol: "SDAI",
iconUrl: "https://etherscan.io/token/images/Badgedai_32.svg",
name: "Hyperdrive DAI",
symbol: "hyperdriveDAI",
iconUrl:
"https://assets.coingecko.com/coins/images/29837/large/2022-official-morpho-token.png?1696528764",
tags: ["yieldSource", "erc4626"],
extensions: {
shortName: "Maker DSR",
protocol: "maker",
shortName: "MetaMorpho",
protocol: "morpho",
isSharesPeggedToBase: false,
},
},
{
Expand All @@ -84,17 +89,17 @@ export const sepoliaAppConfig: AppConfig = {
extensions: {},
},
{
address: "0x80191B6a6A8E2026209fB5d1e4e9CC9A73029511",
address: "0xAb1895c74902F2dbd40e76CB616d80e4aA780713",
decimals: 18,
places: 2,
name: "Hyperdrive DAI",
symbol: "hyperdriveDAI",
iconUrl:
"https://assets.coingecko.com/coins/images/29837/large/2022-official-morpho-token.png?1696528764",
name: "Savings DAI",
symbol: "SDAI",
iconUrl: "https://etherscan.io/token/images/Badgedai_32.svg",
tags: ["yieldSource", "erc4626"],
extensions: {
shortName: "MetaMorpho",
protocol: "morpho",
shortName: "Maker DSR",
protocol: "maker",
isSharesPeggedToBase: false,
},
},
],
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@ import { protocols } from "src/protocols/protocols";
export interface YieldSourceExtensions {
shortName: string;
protocol: keyof typeof protocols;
isSharesPeggedToBase: boolean;
}
5 changes: 5 additions & 0 deletions packages/hyperdrive-appconfig/src/yieldSources/extensions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,24 +3,29 @@ import { YieldSourceExtensions } from "src/index";
export const sdaiExtensions: YieldSourceExtensions = {
shortName: "Maker DSR",
protocol: "maker",
isSharesPeggedToBase: false,
};

export const stethExtensions: YieldSourceExtensions = {
shortName: "Lido stETH",
protocol: "lido",
isSharesPeggedToBase: true,
};

export const metaMorphoExtensions: YieldSourceExtensions = {
shortName: "MetaMorpho",
protocol: "morpho",
isSharesPeggedToBase: false,
};

export const rethExtensions: YieldSourceExtensions = {
shortName: "Rocket Pool ETH",
protocol: "rocketPool",
isSharesPeggedToBase: false,
};

export const ezethExtensions: YieldSourceExtensions = {
shortName: "Renzo ezETH",
protocol: "renzo",
isSharesPeggedToBase: false,
};

0 comments on commit 6f6a867

Please sign in to comment.