aboutsummaryrefslogtreecommitdiffstats
path: root/src/mempool/event_watcher.ts
diff options
context:
space:
mode:
authorLeonid Logvinov <logvinov.leon@gmail.com>2017-10-30 16:53:59 +0800
committerLeonid Logvinov <logvinov.leon@gmail.com>2017-11-10 03:11:45 +0800
commitfd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320 (patch)
tree1b702de7d4efa36e543aa032090688ebd4d6c9bb /src/mempool/event_watcher.ts
parenta2ffd7de2ec718b87dcaee950160f000d9e3d28f (diff)
downloaddexon-sol-tools-fd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320.tar
dexon-sol-tools-fd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320.tar.gz
dexon-sol-tools-fd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320.tar.bz2
dexon-sol-tools-fd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320.tar.lz
dexon-sol-tools-fd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320.tar.xz
dexon-sol-tools-fd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320.tar.zst
dexon-sol-tools-fd54a6a3ad91a6aaff0e2a81f4fd9856b02ff320.zip
Rename MempoolWatcher to EventWatcher and remove from public interface
Diffstat (limited to 'src/mempool/event_watcher.ts')
-rw-r--r--src/mempool/event_watcher.ts66
1 files changed, 66 insertions, 0 deletions
diff --git a/src/mempool/event_watcher.ts b/src/mempool/event_watcher.ts
new file mode 100644
index 000000000..e28219682
--- /dev/null
+++ b/src/mempool/event_watcher.ts
@@ -0,0 +1,66 @@
+import * as Web3 from 'web3';
+import * as _ from 'lodash';
+import {Web3Wrapper} from '../web3_wrapper';
+import {BlockParamLiteral, EventCallback, MempoolEventCallback} from '../types';
+import {AbiDecoder} from '../utils/abi_decoder';
+import {intervalUtils} from '../utils/interval_utils';
+
+const DEFAULT_MEMPOOL_POLLING_INTERVAL = 200;
+
+export class EventWatcher {
+ private _web3Wrapper: Web3Wrapper;
+ private _pollingIntervalMs: number;
+ private _intervalId: NodeJS.Timer;
+ private _lastMempoolEvents: Web3.LogEntry[] = [];
+ private _callback?: MempoolEventCallback;
+ constructor(web3Wrapper: Web3Wrapper, pollingIntervalMs: undefined|number) {
+ this._web3Wrapper = web3Wrapper;
+ this._pollingIntervalMs = _.isUndefined(pollingIntervalMs) ?
+ DEFAULT_MEMPOOL_POLLING_INTERVAL :
+ pollingIntervalMs;
+ }
+ public subscribe(callback: MempoolEventCallback): void {
+ this._callback = callback;
+ this._intervalId = intervalUtils.setAsyncExcludingInterval(
+ this._pollForMempoolEventsAsync.bind(this), this._pollingIntervalMs);
+ }
+ public unsubscribe(): void {
+ delete this._callback;
+ intervalUtils.clearAsyncExcludingInterval(this._intervalId);
+ }
+ private async _pollForMempoolEventsAsync(): Promise<void> {
+ const pendingEvents = await this._getMempoolEventsAsync();
+ if (pendingEvents.length === 0) {
+ // HACK: Sometimes when node rebuilds the pending block we get back the empty result.
+ // We don't want to emit a lot of removal events and bring them back after a couple of miliseconds,
+ // that's why we just ignore those cases.
+ return;
+ }
+ const removedEvents = _.differenceBy(this._lastMempoolEvents, pendingEvents, JSON.stringify);
+ const newEvents = _.differenceBy(pendingEvents, this._lastMempoolEvents, JSON.stringify);
+ let isRemoved = true;
+ this._emitDifferences(removedEvents, isRemoved);
+ isRemoved = false;
+ this._emitDifferences(newEvents, isRemoved);
+ this._lastMempoolEvents = pendingEvents;
+ }
+ private async _getMempoolEventsAsync(): Promise<Web3.LogEntry[]> {
+ const mempoolFilter = {
+ fromBlock: BlockParamLiteral.Pending,
+ toBlock: BlockParamLiteral.Pending,
+ };
+ const pendingEvents = await this._web3Wrapper.getLogsAsync(mempoolFilter);
+ return pendingEvents;
+ }
+ private _emitDifferences(logs: Web3.LogEntry[], isRemoved: boolean): void {
+ _.forEach(logs, log => {
+ const logEvent = {
+ removed: isRemoved,
+ ...log,
+ };
+ if (!_.isUndefined(this._callback)) {
+ this._callback(logEvent);
+ }
+ });
+ }
+}