mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
160 lines
4.7 KiB
TypeScript
160 lines
4.7 KiB
TypeScript
import hre, { ethers } from "hardhat";
|
|
import { IERC20Minimal__factory } from "../../../typechain";
|
|
import { BigNumber as BN } from "ethers";
|
|
|
|
export const DEAD_ADDRESS = "0x0000000000000000000000000000000000000001";
|
|
export const ZERO_ADDRESS = "0x0000000000000000000000000000000000000000";
|
|
|
|
export const DEFAULT_DECIMALS = 18;
|
|
|
|
export const ZERO = BN.from(0);
|
|
export const ONE_MIN = BN.from(60);
|
|
export const TEN_MINS = BN.from(60 * 10);
|
|
export const ONE_HOUR = BN.from(60 * 60);
|
|
export const ONE_DAY = BN.from(60 * 60 * 24);
|
|
export const FIVE_DAYS = BN.from(60 * 60 * 24 * 5);
|
|
export const TEN_DAYS = BN.from(60 * 60 * 24 * 10);
|
|
export const ONE_WEEK = BN.from(60 * 60 * 24 * 7);
|
|
export const ONE_YEAR = BN.from(60 * 60 * 24 * 365);
|
|
|
|
export const connectorName = "MStable";
|
|
|
|
interface TokenData {
|
|
tokenAddress: string;
|
|
tokenWhaleAddress?: string;
|
|
feederPool?: string;
|
|
}
|
|
|
|
export const toEther = (amount: BN) => ethers.utils.formatEther(amount);
|
|
|
|
export const getToken = (tokenSymbol: string): TokenData => {
|
|
switch (tokenSymbol) {
|
|
case "MTA":
|
|
return {
|
|
tokenAddress: "0xf501dd45a1198c2e1b5aef5314a68b9006d842e0"
|
|
};
|
|
case "mUSD":
|
|
return {
|
|
tokenAddress: "0xe840b73e5287865eec17d250bfb1536704b43b21",
|
|
tokenWhaleAddress: "0x4393b9c542bf79e5235180d6da1915c0f9bc02c3"
|
|
};
|
|
|
|
case "DAI":
|
|
return {
|
|
tokenAddress: "0x8f3cf7ad23cd3cadbd9735aff958023239c6a063",
|
|
tokenWhaleAddress: "0x49854708A8c42eEB837A97Dd97D597890CEb1334"
|
|
};
|
|
case "USDC":
|
|
return {
|
|
tokenAddress: "0x2791bca1f2de4661ed88a30c99a7a9449aa84174"
|
|
};
|
|
case "imUSD":
|
|
return {
|
|
tokenAddress: "0x5290Ad3d83476CA6A2b178Cd9727eE1EF72432af"
|
|
};
|
|
|
|
case "imUSDVault":
|
|
return {
|
|
tokenAddress: "0x32aBa856Dc5fFd5A56Bcd182b13380e5C855aa29"
|
|
};
|
|
|
|
case "FRAX":
|
|
return {
|
|
tokenAddress: "0x104592a158490a9228070E0A8e5343B499e125D0",
|
|
tokenWhaleAddress: "0xAE0f77C239f72da36d4dA20a4bBdaAe4Ca48e03F",
|
|
feederPool: "0xb30a907084ac8a0d25dddab4e364827406fd09f0"
|
|
};
|
|
|
|
default:
|
|
throw new Error(`Token ${tokenSymbol} not supported`);
|
|
}
|
|
};
|
|
|
|
export const sendToken = async (token: string, amount: any, from: string, to: string): Promise<any> => {
|
|
await hre.network.provider.request({
|
|
method: "hardhat_impersonateAccount",
|
|
params: [from]
|
|
});
|
|
const [signer] = await ethers.getSigners();
|
|
const sender = hre.ethers.provider.getSigner(from);
|
|
|
|
await signer.sendTransaction({
|
|
to: from,
|
|
value: ethers.utils.parseEther("1")
|
|
});
|
|
|
|
return await IERC20Minimal__factory.connect(token, sender).transfer(to, amount);
|
|
};
|
|
|
|
export const fundWallet = async (token: string, amount: any, to: string) => {
|
|
const { tokenAddress, tokenWhaleAddress } = getToken(token);
|
|
await sendToken(tokenAddress, amount, tokenWhaleAddress!, to);
|
|
};
|
|
|
|
export const calcMinOut = (amount: BN, slippage: number): BN => {
|
|
const value = simpleToExactAmount(1 - slippage);
|
|
const minOut = amount.mul(value).div(ethers.BigNumber.from(10).pow(DEFAULT_DECIMALS));
|
|
return minOut;
|
|
};
|
|
|
|
export const simpleToExactAmount = (amount: number | string | BN, decimals: number | BN = DEFAULT_DECIMALS): BN => {
|
|
let amountString = amount.toString();
|
|
const decimalsBN = BN.from(decimals);
|
|
|
|
if (decimalsBN.gt(100)) {
|
|
throw new Error(`Invalid decimals amount`);
|
|
}
|
|
|
|
const scale = BN.from(10).pow(decimals);
|
|
const scaleString = scale.toString();
|
|
|
|
// Is it negative?
|
|
const negative = amountString.substring(0, 1) === "-";
|
|
if (negative) {
|
|
amountString = amountString.substring(1);
|
|
}
|
|
|
|
if (amountString === ".") {
|
|
throw new Error(`Error converting number ${amountString} to precise unit, invalid value`);
|
|
}
|
|
|
|
// Split it into a whole and fractional part
|
|
// eslint-disable-next-line prefer-const
|
|
let [whole, fraction, ...rest] = amountString.split(".");
|
|
if (rest.length > 0) {
|
|
throw new Error(`Error converting number ${amountString} to precise unit, too many decimal points`);
|
|
}
|
|
|
|
if (!whole) {
|
|
whole = "0";
|
|
}
|
|
if (!fraction) {
|
|
fraction = "0";
|
|
}
|
|
|
|
if (fraction.length > scaleString.length - 1) {
|
|
throw new Error(`Error converting number ${amountString} to precise unit, too many decimal places`);
|
|
}
|
|
|
|
while (fraction.length < scaleString.length - 1) {
|
|
fraction += "0";
|
|
}
|
|
|
|
const wholeBN = BN.from(whole);
|
|
const fractionBN = BN.from(fraction);
|
|
let result = wholeBN.mul(scale).add(fractionBN);
|
|
|
|
if (negative) {
|
|
result = result.mul("-1");
|
|
}
|
|
|
|
return result;
|
|
};
|
|
|
|
export const advanceBlock = async (): Promise<void> => ethers.provider.send("evm_mine", []);
|
|
|
|
export const increaseTime = async (length: BN | number): Promise<void> => {
|
|
await ethers.provider.send("evm_increaseTime", [BN.from(length).toNumber()]);
|
|
await advanceBlock();
|
|
};
|