Skip to content
This repository has been archived by the owner on Sep 28, 2022. It is now read-only.

Commit

Permalink
Merge pull request #227 from makerdao/no-more-mdai
Browse files Browse the repository at this point in the history
remove MDAI and MWETH
  • Loading branch information
levity authored May 26, 2020
2 parents a624aca + fcbeec5 commit be2fcc8
Show file tree
Hide file tree
Showing 43 changed files with 241 additions and 258 deletions.
8 changes: 4 additions & 4 deletions packages/dai-plugin-mcd/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ multi-collateral dai contracts
### Example usage

```js
import { McdPlugin, ETH, REP, MDAI } from '@makerdao/dai-plugin-mcd';
import { McdPlugin, ETH, REP, DAI } from '@makerdao/dai-plugin-mcd';
import Maker from '@makerdao/dai';
import { createCurrency } from '@makerdao/currency';
import { tokenAddress, tokenAbi } from 'someOtherTokenData';
Expand All @@ -33,9 +33,9 @@ const maker = await Maker.create('http', {

await maker.service('proxy').ensureProxy();
const cdpManager = maker.service('mcd:cdpManager');
const cdp1 = await cdpManager.openLockAndDraw('REP-A', REP(50), MDAI(1000));
const cdp2 = await cdpManager.openLockAndDraw('ETH-A', ETH(50), MDAI(1000));
const cdp3 = await cdpManager.openLockAndDraw('TOK-Z', TOK(50), MDAI(1000));
const cdp1 = await cdpManager.openLockAndDraw('REP-A', REP(50), DAI(1000));
const cdp2 = await cdpManager.openLockAndDraw('ETH-A', ETH(50), DAI(1000));
const cdp3 = await cdpManager.openLockAndDraw('TOK-Z', TOK(50), DAI(1000));
```

Please visit [docs.makerdao.com](https://docs.makerdao.com/building-with-maker/daijs) for more documentation.
Expand Down
4 changes: 2 additions & 2 deletions packages/dai-plugin-mcd/src/Auction.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { WAD } from './constants';
import BigNumber from 'bignumber.js';
import { MDAI } from './index';
import { DAI } from './index';

export default class Auction {
constructor(ilk, smartContractService) {
switch (ilk) {
case MDAI.symbol:
case DAI.symbol:
this.contract = smartContractService.getContract('MCD_FLAP');
break;
case 'MKR':
Expand Down
10 changes: 5 additions & 5 deletions packages/dai-plugin-mcd/src/CdpManager.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import ManagedCdp from './ManagedCdp';
import { castAsCurrency, stringToBytes, bytesToString } from './utils';
import has from 'lodash/has';
import padStart from 'lodash/padStart';
import { MDAI, ETH, GNT } from './index';
import { DAI, ETH, GNT } from './index';
const { CDP_MANAGER, CDP_TYPE, SYSTEM_DATA } = ServiceRoles;
import getEventHistoryImpl from './EventHistory';

Expand Down Expand Up @@ -115,13 +115,13 @@ export default class CdpManager extends LocalService {
}

@tracksTransactionsWithOptions({ numArguments: 5 })
async lockAndDraw(id, ilk, lockAmount, drawAmount = MDAI(0), { promise }) {
async lockAndDraw(id, ilk, lockAmount, drawAmount = DAI(0), { promise }) {
assert(lockAmount && drawAmount, 'both amounts must be specified');
assert(
lockAmount instanceof Currency,
'lockAmount must be a Currency value'
);
drawAmount = castAsCurrency(drawAmount, MDAI);
drawAmount = castAsCurrency(drawAmount, DAI);
const proxyAddress = await this.get('proxy').ensureProxy({ promise });
const jugAddress = this.get('smartContract').getContractAddress('MCD_JUG');
const isEth = ETH.isInstance(lockAmount);
Expand Down Expand Up @@ -194,13 +194,13 @@ export default class CdpManager extends LocalService {
this.get('smartContract').getContractAddress('MCD_JUG'),
this._adapterAddress('DAI'),
this.getIdBytes(id),
castAsCurrency(drawAmount, MDAI).toFixed('wei'),
castAsCurrency(drawAmount, DAI).toFixed('wei'),
{ dsProxy: true, promise, metadata: { id, ilk, drawAmount } }
);
}

@tracksTransactionsWithOptions({ numArguments: 5 })
wipeAndFree(id, ilk, wipeAmount = MDAI(0), freeAmount, { promise }) {
wipeAndFree(id, ilk, wipeAmount = DAI(0), freeAmount, { promise }) {
const isEth = ETH.isInstance(freeAmount);
const method = isEth ? 'wipeAndFreeETH' : 'wipeAndFreeGem';
return this.proxyActions[method](
Expand Down
6 changes: 3 additions & 3 deletions packages/dai-plugin-mcd/src/CdpType.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import assert from 'assert';
import { ServiceRoles } from './constants';
import { stringToBytes } from './utils';
import { MDAI, ETH, MWETH } from './index';
import { DAI, ETH, WETH } from './index';
import * as math from './math';

export default class CdpType {
Expand All @@ -28,7 +28,7 @@ export default class CdpType {

get totalDebt() {
const { Art, rate } = this._getCached('vatInfo');
return MDAI.wei(Art)
return DAI.wei(Art)
.times(rate)
.shiftedBy(-27);
}
Expand Down Expand Up @@ -72,7 +72,7 @@ export default class CdpType {
// separate calls
if (!this._prefetchPromise) {
const adapterAddress = this._systemData.adapterAddress(this.ilk);
const { symbol } = this.currency === ETH ? MWETH : this.currency;
const { symbol } = this.currency === ETH ? WETH : this.currency;

this._prefetchPromise = Promise.all([
this._systemData
Expand Down
22 changes: 7 additions & 15 deletions packages/dai-plugin-mcd/src/ManagedCdp.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import tracksTransactions, {
} from './utils/tracksTransactions';
import { ServiceRoles } from './constants';
import assert from 'assert';
import { MDAI } from './index';
import { DAI } from './index';
import * as math from './math';

export default class ManagedCdp {
Expand Down Expand Up @@ -93,14 +93,10 @@ export default class ManagedCdp {
}

@tracksTransactionsWithOptions({ numArguments: 3 })
lockAndDraw(
lockAmount = this.currency(0),
drawAmount = MDAI(0),
{ promise }
) {
lockAndDraw(lockAmount = this.currency(0), drawAmount = DAI(0), { promise }) {
assert(lockAmount && drawAmount, 'amounts must be defined');
lockAmount = castAsCurrency(lockAmount, this.currency);
drawAmount = castAsCurrency(drawAmount, MDAI);
drawAmount = castAsCurrency(drawAmount, DAI);
return this._cdpManager.lockAndDraw(
this.id,
this.ilk,
Expand All @@ -111,12 +107,12 @@ export default class ManagedCdp {
}

wipeDai(amount) {
amount = castAsCurrency(amount, MDAI);
amount = castAsCurrency(amount, DAI);
return this._cdpManager.wipe(this.id, amount, null);
}

unsafeWipe(amount) {
amount = castAsCurrency(amount, MDAI);
amount = castAsCurrency(amount, DAI);
return this._cdpManager.unsafeWipe(this.id, amount);
}

Expand All @@ -141,13 +137,9 @@ export default class ManagedCdp {
}

@tracksTransactionsWithOptions({ numArguments: 3 })
wipeAndFree(
wipeAmount = MDAI(0),
freeAmount = this.currency(0),
{ promise }
) {
wipeAndFree(wipeAmount = DAI(0), freeAmount = this.currency(0), { promise }) {
assert(wipeAmount && freeAmount, 'amounts must be defined');
wipeAmount = castAsCurrency(wipeAmount, MDAI);
wipeAmount = castAsCurrency(wipeAmount, DAI);
freeAmount = castAsCurrency(freeAmount, this.currency);
return this._cdpManager.wipeAndFree(
this.id,
Expand Down
10 changes: 5 additions & 5 deletions packages/dai-plugin-mcd/src/SavingsService.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { PublicService } from '@makerdao/services-core';
import { ServiceRoles } from './constants';
import { MDAI } from './index';
import { DAI } from './index';
import BigNumber from 'bignumber.js';
import { RAY, WAD, SECONDS_PER_YEAR } from './constants';
import tracksTransactions from './utils/tracksTransactions';
Expand Down Expand Up @@ -55,13 +55,13 @@ export default class SavingsService extends PublicService {
async balance() {
const proxy = await this.get('proxy').currentProxy();

return proxy ? this.balanceOf(proxy) : MDAI(0);
return proxy ? this.balanceOf(proxy) : DAI(0);
}

async balanceOf(guy) {
const slice = new BigNumber(await this._pot.pie(guy));
const chi = await this.chi();
return MDAI(
return DAI(
slice
.times(chi)
.div(WAD)
Expand All @@ -72,7 +72,7 @@ export default class SavingsService extends PublicService {
async getTotalDai() {
const totalPie = new BigNumber(await this._pot.Pie());
const chi = await this.chi();
return MDAI(
return DAI(
totalPie
.times(chi)
.div(WAD)
Expand Down Expand Up @@ -119,7 +119,7 @@ export default class SavingsService extends PublicService {
if (type === 'DSR_WITHDRAW') sum = sum.minus(amount);
});
const balance = await this.balanceOf(address);
return balance.gt(sum) ? balance.minus(sum) : MDAI(0);
return balance.gt(sum) ? balance.minus(sum) : DAI(0);
}

resetEventHistoryCache(address = null) {
Expand Down
4 changes: 2 additions & 2 deletions packages/dai-plugin-mcd/src/SystemDataService.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { PublicService } from '@makerdao/services-core';
import { RAD, RAY, ServiceRoles, SECONDS_PER_YEAR } from './constants';
import BigNumber from 'bignumber.js';
import { MDAI } from './index';
import { DAI } from './index';

export default class SystemDataService extends PublicService {
constructor(name = ServiceRoles.SYSTEM_DATA) {
Expand Down Expand Up @@ -40,7 +40,7 @@ export default class SystemDataService extends PublicService {
this.vat.dai(vowAddr),
this.vat.sin(vowAddr)
]);
return MDAI.rad(dai).minus(MDAI.rad(sin));
return DAI.rad(dai).minus(DAI.rad(sin));
}

// Helpers ----------------------------------------------
Expand Down
18 changes: 8 additions & 10 deletions packages/dai-plugin-mcd/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import AuctionService from './AuctionService';
import SystemDataService from './SystemDataService';
import { ServiceRoles as ServiceRoles_ } from './constants';
import BigNumber from 'bignumber.js';
import wethAbi from '../contracts/abis/WETH9.json';

export const ServiceRoles = ServiceRoles_;
const { CDP_MANAGER, CDP_TYPE, SYSTEM_DATA, AUCTION, SAVINGS } = ServiceRoles;
Expand Down Expand Up @@ -54,11 +55,8 @@ export const MKR = createCurrency('MKR');
export const USD = createCurrency('USD');
export const USD_ETH = createCurrencyRatio(USD, ETH);

// these are prefixed with M so that they don't override their SCD versions--
// otherwise, adding the MCD plugin would break MCD. maybe there's a better way
// to work around this?
export const MWETH = createCurrency('MWETH');
export const MDAI = createCurrency('MDAI');
export const WETH = createCurrency('WETH');
export const DAI = createCurrency('DAI');

// Casting for savings dai
export const DSR_DAI = createCurrency('DSR-DAI');
Expand Down Expand Up @@ -88,8 +86,8 @@ export const ALLOWANCE_AMOUNT = BigNumber(
export const defaultTokens = [
...new Set([
...defaultCdpTypes.map(type => type.currency),
MDAI,
MWETH,
DAI,
WETH,
SAI,
DSR_DAI
])
Expand All @@ -107,7 +105,7 @@ export const McdPlugin = {
}));
}
const tokens = uniqBy(cdpTypes, 'currency').map(
({ currency, address, abi, decimals }, idx) => {
({ currency, address, abi, decimals }) => {
const data =
address && abi ? { address, abi } : addContracts[currency.symbol];
assert(data, `No address and ABI found for "${currency.symbol}"`);
Expand All @@ -127,8 +125,8 @@ export const McdPlugin = {
smartContract: { addContracts },
token: {
erc20: [
{ currency: MDAI, address: addContracts.MCD_DAI.address },
{ currency: MWETH, address: addContracts.ETH.address },
{ currency: DAI, address: addContracts.MCD_DAI.address },
{ currency: WETH, address: addContracts.ETH.address, abi: wethAbi },
...tokens
]
},
Expand Down
14 changes: 7 additions & 7 deletions packages/dai-plugin-mcd/src/math.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import BigNumber from 'bignumber.js';
import { createCurrencyRatio } from '@makerdao/currency';
import { RAY } from './constants';
import { MDAI, USD } from './index';
import { DAI, USD } from './index';

// NOTE: When a function below has an argument with the same name as a function
// defined earlier in the file, that means it expects that argument's value to
Expand All @@ -12,7 +12,7 @@ import { MDAI, USD } from './index';
// ilk math

export function debtCeiling(line) {
return MDAI.rad(line);
return DAI.rad(line);
}

export function liquidationPenalty(chop) {
Expand All @@ -23,7 +23,7 @@ export function liquidationPenalty(chop) {
}

export function liquidationRatio(mat) {
const ratio = createCurrencyRatio(USD, MDAI);
const ratio = createCurrencyRatio(USD, DAI);
return ratio(new BigNumber(mat.toString()).dividedBy(RAY).toString());
}

Expand Down Expand Up @@ -57,13 +57,13 @@ export function collateralValue(collateralAmount, price) {
}

export function debtValue(art, rate) {
art = MDAI.wei(art);
art = DAI.wei(art);
return art.times(rate).shiftedBy(-27);
}

export function collateralizationRatio(collateralValue, debtValue) {
if (debtValue.eq(0)) {
const ratio = createCurrencyRatio(USD, MDAI);
const ratio = createCurrencyRatio(USD, DAI);
return ratio(Infinity);
}
return collateralValue.div(debtValue);
Expand All @@ -88,6 +88,6 @@ export function minSafeCollateralAmount(debtValue, liquidationRatio, price) {
export function daiAvailable(collateralValue, debtValue, liquidationRatio) {
const maxSafeDebtValue = collateralValue.div(liquidationRatio);
return debtValue.lt(maxSafeDebtValue)
? MDAI(maxSafeDebtValue.minus(debtValue))
: MDAI(0);
? DAI(maxSafeDebtValue.minus(debtValue))
: DAI(0);
}
6 changes: 3 additions & 3 deletions packages/dai-plugin-mcd/src/schemas/computed.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import {
liquidationPrice as calcLiquidationPrice,
minSafeCollateralAmount as calcMinSafeCollateralAmount
} from '../math';
import { USD, MDAI, DSR_DAI, defaultCdpTypes, ALLOWANCE_AMOUNT } from '../';
import { USD, DAI, DSR_DAI, defaultCdpTypes, ALLOWANCE_AMOUNT } from '../';
import BigNumber from 'bignumber.js';
import {
RATIO_DAI_USD,
Expand Down Expand Up @@ -166,7 +166,7 @@ export const debtValue = {
[DEBT_SCALING_FACTOR, [VAULT_TYPE, id]]
],
computed: (encumberedDebt, debtScalingFactor) => {
return MDAI(encumberedDebt).times(debtScalingFactor);
return DAI(encumberedDebt).times(debtScalingFactor);
}
})
};
Expand Down Expand Up @@ -528,7 +528,7 @@ export const collateralDebt = {
[DEBT_SCALING_FACTOR, collateralTypeName]
],
computed: (totalEncumberedDebt, debtScalingFactor) => {
return MDAI(totalEncumberedDebt).times(debtScalingFactor);
return DAI(totalEncumberedDebt).times(debtScalingFactor);
}
})
};
Expand Down
6 changes: 3 additions & 3 deletions packages/dai-plugin-mcd/src/schemas/spot.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { toHex, fromRay } from '../utils';
import { createCurrencyRatio } from '@makerdao/currency';
import { MDAI, USD } from '../..';
import { DAI, USD } from '..';

import {
PRICE_FEED_ADDRESS,
Expand All @@ -27,7 +27,7 @@ export const spotIlks = {
transforms: {
[LIQUIDATION_RATIO]: liqRatio =>
liqRatio.toString() !== '0'
? createCurrencyRatio(USD, MDAI)(fromRay(liqRatio))
? createCurrencyRatio(USD, DAI)(fromRay(liqRatio))
: null
}
}),
Expand All @@ -45,7 +45,7 @@ export const spotPar = {
contract: 'MCD_SPOT',
call: ['par()(uint256)']
}),
returns: [[RATIO_DAI_USD, v => createCurrencyRatio(MDAI, USD)(fromRay(v))]]
returns: [[RATIO_DAI_USD, v => createCurrencyRatio(DAI, USD)(fromRay(v))]]
};

export default {
Expand Down
Loading

0 comments on commit be2fcc8

Please sign in to comment.