aboutsummaryrefslogtreecommitdiffstats
path: root/packages/contracts/migrations/3_register_tokens.ts
diff options
context:
space:
mode:
authorAmir Bandeali <abandeali1@gmail.com>2017-11-30 14:02:43 +0800
committerAmir Bandeali <abandeali1@gmail.com>2017-11-30 23:10:18 +0800
commit4b3e0383235ca4ca0127f24c2e05543bb45a56bb (patch)
tree7a9c1888f99b1121826b09ca28185565ed47cd50 /packages/contracts/migrations/3_register_tokens.ts
parentc57190dead41846809effb8823bd4e486ca72512 (diff)
downloaddexon-sol-tools-4b3e0383235ca4ca0127f24c2e05543bb45a56bb.tar
dexon-sol-tools-4b3e0383235ca4ca0127f24c2e05543bb45a56bb.tar.gz
dexon-sol-tools-4b3e0383235ca4ca0127f24c2e05543bb45a56bb.tar.bz2
dexon-sol-tools-4b3e0383235ca4ca0127f24c2e05543bb45a56bb.tar.lz
dexon-sol-tools-4b3e0383235ca4ca0127f24c2e05543bb45a56bb.tar.xz
dexon-sol-tools-4b3e0383235ca4ca0127f24c2e05543bb45a56bb.tar.zst
dexon-sol-tools-4b3e0383235ca4ca0127f24c2e05543bb45a56bb.zip
Add contracts to packages, fix most linting errors
Diffstat (limited to 'packages/contracts/migrations/3_register_tokens.ts')
-rw-r--r--packages/contracts/migrations/3_register_tokens.ts86
1 files changed, 86 insertions, 0 deletions
diff --git a/packages/contracts/migrations/3_register_tokens.ts b/packages/contracts/migrations/3_register_tokens.ts
new file mode 100644
index 000000000..ef0e03123
--- /dev/null
+++ b/packages/contracts/migrations/3_register_tokens.ts
@@ -0,0 +1,86 @@
+import * as Bluebird from 'bluebird';
+import * as _ from 'lodash';
+
+import {Artifacts} from '../util/artifacts';
+import {constants} from '../util/constants';
+import {ContractInstance, Token, TokenInfoByNetwork} from '../util/types';
+
+import {tokenInfo} from './config/token_info';
+const {
+ DummyToken,
+ EtherToken,
+ ZRXToken,
+ TokenRegistry,
+} = new Artifacts(artifacts);
+
+module.exports = (deployer: any, network: string) => {
+ const tokens = network === 'live' ? tokenInfo.live : tokenInfo.development;
+ deployer.then(() => {
+ return TokenRegistry.deployed();
+ }).then((tokenRegistry: ContractInstance) => {
+ if (network !== 'live') {
+ const totalSupply = Math.pow(10, 18) * 1000000000;
+ return Bluebird.each(tokens.map((token: Token) => DummyToken.new(
+ token.name,
+ token.symbol,
+ token.decimals,
+ totalSupply,
+ )), _.noop).then((dummyTokens: ContractInstance[]) => {
+ const weth = {
+ address: EtherToken.address,
+ name: 'Ether Token',
+ symbol: 'WETH',
+ url: '',
+ decimals: 18,
+ ipfsHash: constants.NULL_BYTES,
+ swarmHash: constants.NULL_BYTES,
+ };
+ return Bluebird.each(dummyTokens.map((tokenContract: ContractInstance, i: number) => {
+ const token = tokens[i];
+ return tokenRegistry.addToken(
+ tokenContract.address,
+ token.name,
+ token.symbol,
+ token.decimals,
+ token.ipfsHash,
+ token.swarmHash,
+ );
+ }).concat(tokenRegistry.addToken(
+ weth.address,
+ weth.name,
+ weth.symbol,
+ weth.decimals,
+ weth.ipfsHash,
+ weth.swarmHash,
+ )), _.noop);
+ });
+ } else {
+ const zrx = {
+ address: ZRXToken.address,
+ name: '0x Protocol Token',
+ symbol: 'ZRX',
+ url: 'https://www.0xproject.com/',
+ decimals: 18,
+ ipfsHash: constants.NULL_BYTES,
+ swarmHash: constants.NULL_BYTES,
+ };
+ return Bluebird.each(tokens.map((token: Token) => {
+ return tokenRegistry.addToken(
+ token.address,
+ token.name,
+ token.symbol,
+ token.decimals,
+ token.ipfsHash,
+ token.swarmHash,
+ );
+ }).concat(tokenRegistry.addToken(
+ zrx.address,
+ zrx.name,
+ zrx.symbol,
+ zrx.decimals,
+ zrx.ipfsHash,
+ zrx.swarmHash,
+ )), _.noop);
+ }
+ });
+};