diff options
author | Leonid <logvinov.leon@gmail.com> | 2017-05-25 18:53:37 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-05-25 18:53:37 +0800 |
commit | dc1ca23e3006dc614e512353aa2ae354e584f1cf (patch) | |
tree | 3016829f0dabe508af7f52e3d4893c7e7d0b8de3 /src/ts/utils | |
parent | 5d64b562c60710e9b9b6a6286d4278718f043d0d (diff) | |
parent | b1a6c895cc095b39c263ff508d98395b1b901dc6 (diff) | |
download | dexon-sol-tools-dc1ca23e3006dc614e512353aa2ae354e584f1cf.tar dexon-sol-tools-dc1ca23e3006dc614e512353aa2ae354e584f1cf.tar.gz dexon-sol-tools-dc1ca23e3006dc614e512353aa2ae354e584f1cf.tar.bz2 dexon-sol-tools-dc1ca23e3006dc614e512353aa2ae354e584f1cf.tar.lz dexon-sol-tools-dc1ca23e3006dc614e512353aa2ae354e584f1cf.tar.xz dexon-sol-tools-dc1ca23e3006dc614e512353aa2ae354e584f1cf.tar.zst dexon-sol-tools-dc1ca23e3006dc614e512353aa2ae354e584f1cf.zip |
Merge branch 'master' into isValidOrderHash
Diffstat (limited to 'src/ts/utils')
-rw-r--r-- | src/ts/utils/assert.ts | 13 | ||||
-rw-r--r-- | src/ts/utils/schema_validator.ts | 14 |
2 files changed, 24 insertions, 3 deletions
diff --git a/src/ts/utils/assert.ts b/src/ts/utils/assert.ts index 602361233..58182dac0 100644 --- a/src/ts/utils/assert.ts +++ b/src/ts/utils/assert.ts @@ -1,6 +1,7 @@ import * as _ from 'lodash'; import * as BigNumber from 'bignumber.js'; import Web3 = require('web3'); +import {SchemaValidator} from './schema_validator'; const HEX_REGEX = /^0x([0-9A-F]{2})*$/i; @@ -20,12 +21,18 @@ export const assert = { const web3 = new Web3(); this.assert(web3.isAddress(value), this.typeAssertionMessage(variableName, 'ETHAddressHex', value)); }, - isObject(variableName: string, value: object) { - this.assert(_.isObject(value), this.typeAssertionMessage(variableName, 'object', value)); - }, isNumber(variableName: string, value: number) { this.assert(_.isFinite(value), this.typeAssertionMessage(variableName, 'number', value)); }, + doesConformToSchema(variableName: string, value: object, schema: Schema) { + const schemaValidator = new SchemaValidator(); + const validationResult = schemaValidator.validate(value, schema); + const hasValidationErrors = validationResult.errors.length > 0; + const msg = `Expected ${variableName} to conform to schema ${schema.id} +Encountered: ${JSON.stringify(value, null, '\t')} +Validation errors: ${validationResult.errors.join(', ')}`; + this.assert(!hasValidationErrors, msg); + }, assert(condition: boolean, message: string) { if (!condition) { throw new Error(message); diff --git a/src/ts/utils/schema_validator.ts b/src/ts/utils/schema_validator.ts new file mode 100644 index 000000000..bd2f97d2b --- /dev/null +++ b/src/ts/utils/schema_validator.ts @@ -0,0 +1,14 @@ +import {Validator, ValidatorResult} from 'jsonschema'; +import {ECSignatureSchema, ECSignatureParameter} from '../schemas/ec_signature_schema'; + +export class SchemaValidator { + private validator: Validator; + constructor() { + this.validator = new Validator(); + this.validator.addSchema(ECSignatureParameter, ECSignatureParameter.id); + this.validator.addSchema(ECSignatureSchema, ECSignatureSchema.id); + } + public validate(instance: object, schema: Schema): ValidatorResult { + return this.validator.validate(instance, schema); + } +} |