aboutsummaryrefslogtreecommitdiffstats
path: root/packages/0x.js/src/utils/exchange_transfer_simulator.ts
diff options
context:
space:
mode:
authorJacob Evans <jacob@dekz.net>2018-04-30 16:05:45 +0800
committerJacob Evans <jacob@dekz.net>2018-05-01 12:43:47 +0800
commitb36587fac833f4fa35aaed49e4ee05f6ce347a02 (patch)
tree1f902e97de4b33c885ca2ae5d6bd01119944e539 /packages/0x.js/src/utils/exchange_transfer_simulator.ts
parent47604384d4042c3c61f29a635491f8165236e763 (diff)
downloaddexon-sol-tools-b36587fac833f4fa35aaed49e4ee05f6ce347a02.tar
dexon-sol-tools-b36587fac833f4fa35aaed49e4ee05f6ce347a02.tar.gz
dexon-sol-tools-b36587fac833f4fa35aaed49e4ee05f6ce347a02.tar.bz2
dexon-sol-tools-b36587fac833f4fa35aaed49e4ee05f6ce347a02.tar.lz
dexon-sol-tools-b36587fac833f4fa35aaed49e4ee05f6ce347a02.tar.xz
dexon-sol-tools-b36587fac833f4fa35aaed49e4ee05f6ce347a02.tar.zst
dexon-sol-tools-b36587fac833f4fa35aaed49e4ee05f6ce347a02.zip
Execute taker side in trade simulation
Fill if the taker address is open
Diffstat (limited to 'packages/0x.js/src/utils/exchange_transfer_simulator.ts')
-rw-r--r--packages/0x.js/src/utils/exchange_transfer_simulator.ts6
1 files changed, 6 insertions, 0 deletions
diff --git a/packages/0x.js/src/utils/exchange_transfer_simulator.ts b/packages/0x.js/src/utils/exchange_transfer_simulator.ts
index 9a920c643..ccefea930 100644
--- a/packages/0x.js/src/utils/exchange_transfer_simulator.ts
+++ b/packages/0x.js/src/utils/exchange_transfer_simulator.ts
@@ -5,6 +5,7 @@ import * as _ from 'lodash';
import { TokenWrapper } from '../contract_wrappers/token_wrapper';
import { BalanceAndProxyAllowanceLazyStore } from '../stores/balance_proxy_allowance_lazy_store';
import { ExchangeContractErrs, TradeSide, TransferType } from '../types';
+import { constants } from '../utils/constants';
enum FailureReason {
Balance = 'balance',
@@ -66,6 +67,11 @@ export class ExchangeTransferSimulator {
tradeSide: TradeSide,
transferType: TransferType,
): Promise<void> {
+ // If we are simulating an open order then 0x0 will have no balance or allowance
+ if (from === constants.NULL_ADDRESS && tradeSide === TradeSide.Taker) {
+ await this._increaseBalanceAsync(tokenAddress, to, amountInBaseUnits);
+ return;
+ }
const balance = await this._store.getBalanceAsync(tokenAddress, from);
const proxyAllowance = await this._store.getProxyAllowanceAsync(tokenAddress, from);
if (proxyAllowance.lessThan(amountInBaseUnits)) {