diff options
author | Leonid <logvinov.leon@gmail.com> | 2017-06-03 01:53:01 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-03 01:53:01 +0800 |
commit | 5925f81fe185a90efaa82dd90bd8d65d74326f11 (patch) | |
tree | 12daf7aec686c576634b2daa5a58af2831cc497d /src/0x.js.ts | |
parent | 2ff8f4ca6ed238f331cb69aaeb912a94b3df901e (diff) | |
parent | 35c9330d6246183509a3543cdf1278b9ced191e2 (diff) | |
download | dexon-sol-tools-5925f81fe185a90efaa82dd90bd8d65d74326f11.tar dexon-sol-tools-5925f81fe185a90efaa82dd90bd8d65d74326f11.tar.gz dexon-sol-tools-5925f81fe185a90efaa82dd90bd8d65d74326f11.tar.bz2 dexon-sol-tools-5925f81fe185a90efaa82dd90bd8d65d74326f11.tar.lz dexon-sol-tools-5925f81fe185a90efaa82dd90bd8d65d74326f11.tar.xz dexon-sol-tools-5925f81fe185a90efaa82dd90bd8d65d74326f11.tar.zst dexon-sol-tools-5925f81fe185a90efaa82dd90bd8d65d74326f11.zip |
Merge pull request #31 from 0xProject/unavailableFilledCancelled
Implement Unavailable, Filled and Cancelled
Diffstat (limited to 'src/0x.js.ts')
-rw-r--r-- | src/0x.js.ts | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/src/0x.js.ts b/src/0x.js.ts index 7cf313666..40290467a 100644 --- a/src/0x.js.ts +++ b/src/0x.js.ts @@ -17,7 +17,7 @@ import {TokenRegistryWrapper} from './contract_wrappers/token_registry_wrapper'; import {ecSignatureSchema} from './schemas/ec_signature_schema'; import {TokenWrapper} from './contract_wrappers/token_wrapper'; import {SolidityTypes, ECSignature, ZeroExError} from './types'; -import {Order} from './types'; +import {Order, SignedOrder} from './types'; import {orderSchema} from './schemas/order_schemas'; import * as ExchangeArtifacts from './artifacts/Exchange.json'; @@ -69,11 +69,16 @@ export class ZeroEx { const salt = randomNumber.times(factor).round(); return salt; } - /** Checks if order hash is valid */ - public static isValidOrderHash(orderHash: string): boolean { - assert.isString('orderHash', orderHash); - const isValid = /^0x[0-9A-F]{64}$/i.test(orderHash); - return isValid; + /** + * Checks if the supplied hex encoded order hash is valid. + * Note: Valid means it has the expected format, not that an order with the orderHash exists. + */ + public static isValidOrderHash(orderHashHex: string): boolean { + // Since this method can be called to check if any arbitrary string conforms to an orderHash's + // format, we only assert that we were indeed passed a string. + assert.isString('orderHashHex', orderHashHex); + const isValidOrderHash = utils.isValidOrderHash(orderHashHex); + return isValidOrderHash; } /** * A unit amount is defined as the amount of a token above the specified decimal places (integer part). @@ -132,7 +137,7 @@ export class ZeroEx { /** * Computes the orderHash for a given order and returns it as a hex encoded string. */ - public async getOrderHashHexAsync(order: Order): Promise<string> { + public async getOrderHashHexAsync(order: Order|SignedOrder): Promise<string> { const exchangeContractAddr = await this.getExchangeAddressAsync(); assert.doesConformToSchema('order', SchemaValidator.convertToJSONSchemaCompatibleObject(order as object), |