aboutsummaryrefslogtreecommitdiffstats
path: root/packages
diff options
context:
space:
mode:
authorLeonid Logvinov <logvinov.leon@gmail.com>2017-11-21 01:10:25 +0800
committerLeonid Logvinov <logvinov.leon@gmail.com>2017-11-21 01:10:25 +0800
commit856a5c3369c0248ec32924b25ec77dce6b4e1071 (patch)
treeb1a6219a2e7ac2c1673086c176b2346020351aae /packages
parent2c193a1244d9f288c7c01142d42e442a687ce114 (diff)
downloaddexon-0x-contracts-856a5c3369c0248ec32924b25ec77dce6b4e1071.tar
dexon-0x-contracts-856a5c3369c0248ec32924b25ec77dce6b4e1071.tar.gz
dexon-0x-contracts-856a5c3369c0248ec32924b25ec77dce6b4e1071.tar.bz2
dexon-0x-contracts-856a5c3369c0248ec32924b25ec77dce6b4e1071.tar.lz
dexon-0x-contracts-856a5c3369c0248ec32924b25ec77dce6b4e1071.tar.xz
dexon-0x-contracts-856a5c3369c0248ec32924b25ec77dce6b4e1071.tar.zst
dexon-0x-contracts-856a5c3369c0248ec32924b25ec77dce6b4e1071.zip
Throw when subscription is already present
Diffstat (limited to 'packages')
-rw-r--r--packages/0x.js/src/order_watcher/expiration_watcher.ts5
1 files changed, 4 insertions, 1 deletions
diff --git a/packages/0x.js/src/order_watcher/expiration_watcher.ts b/packages/0x.js/src/order_watcher/expiration_watcher.ts
index acc7e7e5d..6d9556336 100644
--- a/packages/0x.js/src/order_watcher/expiration_watcher.ts
+++ b/packages/0x.js/src/order_watcher/expiration_watcher.ts
@@ -2,7 +2,7 @@ import * as _ from 'lodash';
import {BigNumber} from 'bignumber.js';
import {utils} from '../utils/utils';
import {intervalUtils} from '../utils/interval_utils';
-import {SignedOrder} from '../types';
+import {SignedOrder, ZeroExError} from '../types';
import {Heap} from '../utils/heap';
import {ZeroEx} from '../0x';
@@ -26,6 +26,9 @@ export class ExpirationWatcher {
this.orderHashHeapByExpiration = new Heap(scoreFunction);
}
public subscribe(callback: (orderHash: string) => void): void {
+ if (!_.isUndefined(this.callbackIfExists)) {
+ throw new Error(ZeroExError.SubscriptionAlreadyPresent);
+ }
this.callbackIfExists = callback;
this.orderExpirationCheckingIntervalIdIfExists = intervalUtils.setAsyncExcludingInterval(
this.pruneExpiredOrders.bind(this), this.orderExpirationCheckingIntervalMs,