diff options
author | Leonid <logvinov.leon@gmail.com> | 2017-06-10 18:23:34 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-10 18:23:34 +0800 |
commit | b739ae24944876c28a2ff474993e72a7178b3d1b (patch) | |
tree | 5e176f2208a97471d83ad0e1ffbc9980e25cdd24 /src/utils | |
parent | 1460966d8f03e5ec0012b21d4c4614c4c3ec44bc (diff) | |
parent | 823134b3bf24c93bd470a1de65bd39adaf554f73 (diff) | |
download | dexon-sol-tools-b739ae24944876c28a2ff474993e72a7178b3d1b.tar dexon-sol-tools-b739ae24944876c28a2ff474993e72a7178b3d1b.tar.gz dexon-sol-tools-b739ae24944876c28a2ff474993e72a7178b3d1b.tar.bz2 dexon-sol-tools-b739ae24944876c28a2ff474993e72a7178b3d1b.tar.lz dexon-sol-tools-b739ae24944876c28a2ff474993e72a7178b3d1b.tar.xz dexon-sol-tools-b739ae24944876c28a2ff474993e72a7178b3d1b.tar.zst dexon-sol-tools-b739ae24944876c28a2ff474993e72a7178b3d1b.zip |
Merge pull request #52 from 0xProject/json-schema
Convert to JSON schema compatible object by default
Diffstat (limited to 'src/utils')
-rw-r--r-- | src/utils/schema_validator.ts | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/src/utils/schema_validator.ts b/src/utils/schema_validator.ts index 755f6e715..9097dce88 100644 --- a/src/utils/schema_validator.ts +++ b/src/utils/schema_validator.ts @@ -7,13 +7,6 @@ import {orderFillOrKillRequestsSchema} from '../schemas/order_fill_or_kill_reque export class SchemaValidator { private validator: Validator; - // In order to validate a complex JS object using jsonschema, we must replace any complex - // sub-types (e.g BigNumber) with a simpler string representation. Since BigNumber and other - // complex types implement the `toString` method, we can stringify the object and - // then parse it. The resultant object can then be checked using jsonschema. - public static convertToJSONSchemaCompatibleObject(obj: any): any { - return JSON.parse(JSON.stringify(obj)); - } constructor() { this.validator = new Validator(); this.validator.addSchema(tokenSchema, tokenSchema.id); @@ -25,7 +18,12 @@ export class SchemaValidator { this.validator.addSchema(ecSignatureParameterSchema, ecSignatureParameterSchema.id); this.validator.addSchema(orderFillOrKillRequestsSchema, orderFillOrKillRequestsSchema.id); } - public validate(instance: object, schema: Schema): ValidatorResult { - return this.validator.validate(instance, schema); + // In order to validate a complex JS object using jsonschema, we must replace any complex + // sub-types (e.g BigNumber) with a simpler string representation. Since BigNumber and other + // complex types implement the `toString` method, we can stringify the object and + // then parse it. The resultant object can then be checked using jsonschema. + public validate(instance: any, schema: Schema): ValidatorResult { + const jsonSchemaCompatibleObject = JSON.parse(JSON.stringify(instance)); + return this.validator.validate(jsonSchemaCompatibleObject, schema); } } |