diff options
author | Alex Browne <stephenalexbrowne@gmail.com> | 2018-10-19 08:48:52 +0800 |
---|---|---|
committer | Fred Carlsen <fred@sjelfull.no> | 2018-12-06 19:04:24 +0800 |
commit | 0166c296254493686fda1b8dbda1dab2bcecf603 (patch) | |
tree | 3315b2ad4fbab0c236eb3d63c11a65f1fb44a279 /packages/pipeline/src/index.ts | |
parent | 9c35d5369491ae5b62101b680b947e4f6fe64821 (diff) | |
download | dexon-sol-tools-0166c296254493686fda1b8dbda1dab2bcecf603.tar dexon-sol-tools-0166c296254493686fda1b8dbda1dab2bcecf603.tar.gz dexon-sol-tools-0166c296254493686fda1b8dbda1dab2bcecf603.tar.bz2 dexon-sol-tools-0166c296254493686fda1b8dbda1dab2bcecf603.tar.lz dexon-sol-tools-0166c296254493686fda1b8dbda1dab2bcecf603.tar.xz dexon-sol-tools-0166c296254493686fda1b8dbda1dab2bcecf603.tar.zst dexon-sol-tools-0166c296254493686fda1b8dbda1dab2bcecf603.zip |
Rename index.ts -> merge_v2_events
Diffstat (limited to 'packages/pipeline/src/index.ts')
-rw-r--r-- | packages/pipeline/src/index.ts | 78 |
1 files changed, 0 insertions, 78 deletions
diff --git a/packages/pipeline/src/index.ts b/packages/pipeline/src/index.ts deleted file mode 100644 index 58646fc56..000000000 --- a/packages/pipeline/src/index.ts +++ /dev/null @@ -1,78 +0,0 @@ -import { web3Factory } from '@0x/dev-utils'; -import 'reflect-metadata'; -import { Connection, createConnection } from 'typeorm'; - -import { ExchangeEventsSource } from './data_sources/contract-wrappers/exchange_events'; -import { deployConfig } from './ormconfig'; -import { parseExchangeEvents } from './parsers/events'; -import { ExchangeFillEvent } from './entities/ExchangeFillEvent'; - -let connection: Connection; - -(async () => { - connection = await createConnection(deployConfig); - await getExchangeEventsAsync(); - await mergeExchangeEventsAsync(); - console.log('Exiting process'); - process.exit(0); -})(); - -// TODO(albrow): Separately: Errors do not appear to be handled correctly. If you use the -// wrong rpcUrl it just returns early with no error. -async function getExchangeEventsAsync(): Promise<void> { - console.log('Getting event logs...'); - const provider = web3Factory.getRpcProvider({ - rpcUrl: 'https://mainnet.infura.io', - }); - const eventsRepository = connection.getRepository(ExchangeFillEvent); - const exchangeEvents = new ExchangeEventsSource(provider, 1); - const eventLogs = await exchangeEvents.getFillEventsAsync(); - console.log('Parsing events...'); - const events = parseExchangeEvents(eventLogs); - console.log(`Retrieved and parsed ${events.length} total events.`); - console.log('Saving events...'); - eventsRepository.save(events); - console.log('Saved events.'); -} - -const insertEventsRawQuery = `INSERT INTO events_raw ( - event_type, - error_id, - order_hash, - maker, - maker_amount, - maker_fee, - maker_token, - taker, - taker_amount, - taker_fee, - taker_token, - txn_hash, - fee_recipient, - block_number, - log_index -) -( - SELECT - 'LogFill', - null, - "orderHash", - "makerAddress", - "makerAssetFilledAmount"::numeric(78), - "makerFeePaid"::numeric(78), - "makerTokenAddress", - "takerAddress", - "takerAssetFilledAmount"::numeric(78), - "takerFeePaid"::numeric(78), - "takerTokenAddress", - "transactionHash", - "feeRecipientAddress", - "blockNumber", - "logIndex" - FROM exchange_fill_event -) ON CONFLICT (order_hash, txn_hash, log_index) DO NOTHING`; - -async function mergeExchangeEventsAsync(): Promise<void> { - console.log('Merging results into events_raw...'); - await connection.query(insertEventsRawQuery); -} |