init dvm context
This commit is contained in:
@@ -13,6 +13,27 @@ if (process.env["COVERAGE"]) {
|
||||
import { getDefaultWeb3 } from './EVM';
|
||||
import { Contract } from 'web3-eth-contract';
|
||||
|
||||
export const CLONE_FACTORY_CONTRACT_NAME = "CloneFactory"
|
||||
export const DODO_CONTRACT_NAME = "DODO"
|
||||
export const TEST_ERC20_CONTRACT_NAME = "TestERC20"
|
||||
export const NAIVE_ORACLE_CONTRACT_NAME = "NaiveOracle"
|
||||
export const DODO_LP_TOKEN_CONTRACT_NAME = "DODOLpToken"
|
||||
export const DODO_ZOO_CONTRACT_NAME = "DOOZoo"
|
||||
export const DODO_WILD_CONTRACT_NAME = "DOOWild"
|
||||
export const DODO_ETH_PROXY_CONTRACT_NAME = "DODOEthProxy"
|
||||
export const WETH_CONTRACT_NAME = "WETH"
|
||||
export const UNISWAP_CONTRACT_NAME = "Uniswap"
|
||||
export const UNISWAP_ARBITRAGEUR_CONTRACT_NAME = "UniswapArbitrageur"
|
||||
export const DODO_TOKEN_CONTRACT_NAME = "DODOToken"
|
||||
export const LOCKED_TOKEN_VAULT_CONTRACT_NAME = "LockedTokenVault"
|
||||
export const DODO_MINE_NAME = "DODOMine"
|
||||
export const DODO_MINE_READER_NAME = "DODOMineReader"
|
||||
export const DVM_VAULT_NAME = "DVMVault"
|
||||
export const DVM_CONTROLLER_NAME = "DVMController"
|
||||
export const DVM_FACTORY_NAME = "DVMFactory"
|
||||
export const SMART_ROUTE_NAME = "SmartRoute"
|
||||
export const NAIVE_FEE_RATE_MODEL_NAME = "NaiveFeeRateModel"
|
||||
|
||||
interface ContractJson {
|
||||
abi: any;
|
||||
networks: { [network: number]: any };
|
||||
|
||||
@@ -40,7 +40,7 @@ export interface DVMContextInitConfig {
|
||||
| 70% | 23.3% |
|
||||
+──────────────────────+───────────────+
|
||||
*/
|
||||
export let DefaultDODOContextInitConfig = {
|
||||
export let DefaultDVMContextInitConfig = {
|
||||
lpFeeRate: decimalStr("0.002"),
|
||||
mtFeeRate: decimalStr("0.001"),
|
||||
k: decimalStr("0.1"),
|
||||
@@ -48,29 +48,33 @@ export let DefaultDODOContextInitConfig = {
|
||||
gasPriceLimit: gweiStr("100"),
|
||||
};
|
||||
|
||||
export class DODOContext {
|
||||
export class DVMContext {
|
||||
EVM: EVM;
|
||||
Web3: Web3;
|
||||
DODO: Contract;
|
||||
DODOZoo: Contract;
|
||||
Route: Contract;
|
||||
DVMFactory: Contract;
|
||||
DVM: Contract;
|
||||
Vault: Contract;
|
||||
BASE: Contract;
|
||||
BaseCapital: Contract;
|
||||
QUOTE: Contract;
|
||||
QuoteCapital: Contract;
|
||||
ORACLE: Contract;
|
||||
Deployer: string;
|
||||
Supervisor: string;
|
||||
Maintainer: string;
|
||||
spareAccounts: string[];
|
||||
SpareAccounts: string[];
|
||||
|
||||
constructor() { }
|
||||
|
||||
async init(config: DODOContextInitConfig) {
|
||||
async init(config: DVMContextInitConfig) {
|
||||
this.EVM = new EVM();
|
||||
this.Web3 = getDefaultWeb3();
|
||||
this.Route = await contracts.newContract(contracts.SMART_ROUTE_NAME)
|
||||
|
||||
var cloneFactory = await contracts.newContract(
|
||||
contracts.CLONE_FACTORY_CONTRACT_NAME
|
||||
);
|
||||
var vaultTemplate = await contracts.newContract(contracts.DVM_VAULT_NAME)
|
||||
var controllerTemplate = await contracts.newContract(contracts.DVM_CONTROLLER_NAME)
|
||||
|
||||
this.DVMFactory = await contracts.newContract(contracts.DVM_FACTORY_NAME, [cloneFactory.options.address, vaultTemplate.options.address, controllerTemplate.options.address])
|
||||
|
||||
this.BASE = await contracts.newContract(
|
||||
contracts.TEST_ERC20_CONTRACT_NAME,
|
||||
@@ -80,65 +84,27 @@ export class DODOContext {
|
||||
contracts.TEST_ERC20_CONTRACT_NAME,
|
||||
["TestQuote", 18]
|
||||
);
|
||||
this.ORACLE = await contracts.newContract(
|
||||
contracts.NAIVE_ORACLE_CONTRACT_NAME
|
||||
);
|
||||
|
||||
const allAccounts = await this.Web3.eth.getAccounts();
|
||||
this.Deployer = allAccounts[0];
|
||||
this.Supervisor = allAccounts[1];
|
||||
this.Maintainer = allAccounts[2];
|
||||
this.spareAccounts = allAccounts.slice(3, 10);
|
||||
this.Maintainer = allAccounts[1];
|
||||
this.SpareAccounts = allAccounts.slice(2, 10);
|
||||
|
||||
var DODOTemplate = await contracts.newContract(
|
||||
contracts.DODO_CONTRACT_NAME
|
||||
);
|
||||
this.DODOZoo = await contracts.newContract(
|
||||
contracts.DODO_ZOO_CONTRACT_NAME,
|
||||
[
|
||||
DODOTemplate.options.address,
|
||||
cloneFactory.options.address,
|
||||
this.Supervisor,
|
||||
]
|
||||
);
|
||||
var lpFeeRateModel = await contracts.newContract(contracts.NAIVE_FEE_RATE_MODEL_NAME, [config.lpFeeRate])
|
||||
var mtFeeRateModel = await contracts.newContract(contracts.NAIVE_FEE_RATE_MODEL_NAME, [config.mtFeeRate])
|
||||
var DVMAddress = this.DVMFactory.methods.createDODOVenderMachine(
|
||||
this.Maintainer,
|
||||
this.BASE.options.address,
|
||||
this.QUOTE.options.address,
|
||||
lpFeeRateModel.options.address,
|
||||
mtFeeRateModel.options.address,
|
||||
config.i,
|
||||
config.k,
|
||||
config.gasPriceLimit).send(this.sendParam(this.Deployer))
|
||||
|
||||
await this.DODOZoo.methods
|
||||
.breedDODO(
|
||||
this.Maintainer,
|
||||
this.BASE.options.address,
|
||||
this.QUOTE.options.address,
|
||||
this.ORACLE.options.address,
|
||||
config.lpFeeRate,
|
||||
config.mtFeeRate,
|
||||
config.k,
|
||||
config.gasPriceLimit
|
||||
)
|
||||
.send(this.sendParam(this.Deployer));
|
||||
this.DVM = contracts.getContractWithAddress(contracts.DVM_CONTROLLER_NAME, DVMAddress)
|
||||
|
||||
this.DODO = contracts.getContractWithAddress(
|
||||
contracts.DODO_CONTRACT_NAME,
|
||||
await this.DODOZoo.methods
|
||||
.getDODO(this.BASE.options.address, this.QUOTE.options.address)
|
||||
.call()
|
||||
);
|
||||
await this.DODO.methods
|
||||
.enableBaseDeposit()
|
||||
.send(this.sendParam(this.Deployer));
|
||||
await this.DODO.methods
|
||||
.enableQuoteDeposit()
|
||||
.send(this.sendParam(this.Deployer));
|
||||
await this.DODO.methods.enableTrading().send(this.sendParam(this.Deployer));
|
||||
|
||||
this.BaseCapital = contracts.getContractWithAddress(
|
||||
contracts.DODO_LP_TOKEN_CONTRACT_NAME,
|
||||
await this.DODO.methods._BASE_CAPITAL_TOKEN_().call()
|
||||
);
|
||||
this.QuoteCapital = contracts.getContractWithAddress(
|
||||
contracts.DODO_LP_TOKEN_CONTRACT_NAME,
|
||||
await this.DODO.methods._QUOTE_CAPITAL_TOKEN_().call()
|
||||
);
|
||||
|
||||
console.log(log.blueText("[Init dodo context]"));
|
||||
console.log(log.blueText("[Init DVM context]"));
|
||||
}
|
||||
|
||||
sendParam(sender, value = "0") {
|
||||
@@ -150,12 +116,6 @@ export class DODOContext {
|
||||
};
|
||||
}
|
||||
|
||||
async setOraclePrice(price: string) {
|
||||
await this.ORACLE.methods
|
||||
.setPrice(price)
|
||||
.send(this.sendParam(this.Deployer));
|
||||
}
|
||||
|
||||
async mintTestToken(to: string, base: string, quote: string) {
|
||||
await this.BASE.methods.mint(to, base).send(this.sendParam(this.Deployer));
|
||||
await this.QUOTE.methods
|
||||
@@ -163,20 +123,20 @@ export class DODOContext {
|
||||
.send(this.sendParam(this.Deployer));
|
||||
}
|
||||
|
||||
async approveDODO(account: string) {
|
||||
async approveRoute(account: string) {
|
||||
await this.BASE.methods
|
||||
.approve(this.DODO.options.address, MAX_UINT256)
|
||||
.approve(this.Route.options.address, MAX_UINT256)
|
||||
.send(this.sendParam(account));
|
||||
await this.QUOTE.methods
|
||||
.approve(this.DODO.options.address, MAX_UINT256)
|
||||
.approve(this.Route.options.address, MAX_UINT256)
|
||||
.send(this.sendParam(account));
|
||||
}
|
||||
}
|
||||
|
||||
export async function getDODOContext(
|
||||
config: DODOContextInitConfig = DefaultDODOContextInitConfig
|
||||
): Promise<DODOContext> {
|
||||
var context = new DODOContext();
|
||||
config: DVMContextInitConfig = DefaultDVMContextInitConfig
|
||||
): Promise<DVMContext> {
|
||||
var context = new DVMContext();
|
||||
await context.init(config);
|
||||
return context;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user