From bdafb171aed8a5e37b2668378f90452182f99f0c Mon Sep 17 00:00:00 2001 From: Kristijan Sedlak Date: Wed, 19 Sep 2018 08:56:42 +0200 Subject: [PATCH] Add general validators --- README.md | 155 +- packages/rawmodel-handlers/package.json | 3 - .../src/handlers/mongo-uniqueness.ts | 2 +- packages/rawmodel-validators/.gitignore | 5 + packages/rawmodel-validators/.npmignore | 4 + packages/rawmodel-validators/nodemon.json | 4 + .../rawmodel-validators/package-lock.json | 3531 +++++++++++++++++ packages/rawmodel-validators/package.json | 86 + packages/rawmodel-validators/src/index.ts | 22 + .../src/tests/index.test.ts | 31 + .../src/tests/validators/absence.test.ts | 22 + .../tests/validators/array-exclusion.test.ts | 14 + .../tests/validators/array-inclusion.test.ts | 14 + .../src/tests/validators/array-length.test.ts | 28 + .../src/tests/validators/base64.test.ts | 36 + .../tests/validators/bson-object-id.test.ts | 18 + .../src/tests/validators/date.test.ts | 26 + .../tests/validators/downcase-string.test.ts | 18 + .../src/tests/validators/email.test.ts | 41 + .../src/tests/validators/eth-address.test.ts | 22 + .../src/tests/validators/fqdn.test.ts | 34 + .../src/tests/validators/hex-color.test.ts | 18 + .../src/tests/validators/hex.test.ts | 18 + .../src/tests/validators/json-string.test.ts | 18 + .../src/tests/validators/match.test.ts | 10 + .../src/tests/validators/number-size.test.ts | 28 + .../src/tests/validators/presence.test.ts | 22 + .../tests/validators/string-exclusion.test.ts | 18 + .../tests/validators/string-inclusion.test.ts | 18 + .../tests/validators/string-length.test.ts | 29 + .../tests/validators/upcase-string.test.ts | 18 + .../src/tests/validators/uuid.test.ts | 35 + .../src/validators/absence.ts | 10 + .../src/validators/array-exclusion.ts | 12 + .../src/validators/array-inclusion.ts | 18 + .../src/validators/array-length.ts | 36 + .../src/validators/base64.ts | 17 + .../src/validators/bson-object-id.ts | 17 + .../src/validators/date.ts | 27 + .../src/validators/downcase-string.ts | 15 + .../src/validators/email.ts | 64 + .../src/validators/eth-address.ts | 15 + .../src/validators/fqdn.ts | 55 + .../src/validators/hex-color.ts | 15 + .../rawmodel-validators/src/validators/hex.ts | 15 + .../src/validators/json-string.ts | 19 + .../src/validators/match.ts | 18 + .../src/validators/number-size.ts | 34 + .../src/validators/presence.ts | 8 + .../src/validators/string-exclusion.ts | 10 + .../src/validators/string-inclusion.ts | 19 + .../src/validators/string-length.ts | 38 + .../src/validators/upcase-string.ts | 15 + .../src/validators/uuid.ts | 43 + packages/rawmodel-validators/tsconfig.json | 13 + packages/rawmodel-validators/tslint.json | 60 + 56 files changed, 4936 insertions(+), 5 deletions(-) create mode 100644 packages/rawmodel-validators/.gitignore create mode 100644 packages/rawmodel-validators/.npmignore create mode 100644 packages/rawmodel-validators/nodemon.json create mode 100644 packages/rawmodel-validators/package-lock.json create mode 100644 packages/rawmodel-validators/package.json create mode 100644 packages/rawmodel-validators/src/index.ts create mode 100644 packages/rawmodel-validators/src/tests/index.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/absence.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/array-exclusion.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/array-inclusion.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/array-length.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/base64.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/bson-object-id.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/date.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/downcase-string.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/email.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/eth-address.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/fqdn.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/hex-color.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/hex.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/json-string.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/match.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/number-size.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/presence.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/string-exclusion.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/string-inclusion.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/string-length.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/upcase-string.test.ts create mode 100644 packages/rawmodel-validators/src/tests/validators/uuid.test.ts create mode 100644 packages/rawmodel-validators/src/validators/absence.ts create mode 100644 packages/rawmodel-validators/src/validators/array-exclusion.ts create mode 100644 packages/rawmodel-validators/src/validators/array-inclusion.ts create mode 100644 packages/rawmodel-validators/src/validators/array-length.ts create mode 100644 packages/rawmodel-validators/src/validators/base64.ts create mode 100644 packages/rawmodel-validators/src/validators/bson-object-id.ts create mode 100644 packages/rawmodel-validators/src/validators/date.ts create mode 100644 packages/rawmodel-validators/src/validators/downcase-string.ts create mode 100644 packages/rawmodel-validators/src/validators/email.ts create mode 100644 packages/rawmodel-validators/src/validators/eth-address.ts create mode 100644 packages/rawmodel-validators/src/validators/fqdn.ts create mode 100644 packages/rawmodel-validators/src/validators/hex-color.ts create mode 100644 packages/rawmodel-validators/src/validators/hex.ts create mode 100644 packages/rawmodel-validators/src/validators/json-string.ts create mode 100644 packages/rawmodel-validators/src/validators/match.ts create mode 100644 packages/rawmodel-validators/src/validators/number-size.ts create mode 100644 packages/rawmodel-validators/src/validators/presence.ts create mode 100644 packages/rawmodel-validators/src/validators/string-exclusion.ts create mode 100644 packages/rawmodel-validators/src/validators/string-inclusion.ts create mode 100644 packages/rawmodel-validators/src/validators/string-length.ts create mode 100644 packages/rawmodel-validators/src/validators/upcase-string.ts create mode 100644 packages/rawmodel-validators/src/validators/uuid.ts create mode 100644 packages/rawmodel-validators/tsconfig.json create mode 100644 packages/rawmodel-validators/tslint.json diff --git a/README.md b/README.md index 246ea3a..6e4aaf4 100644 --- a/README.md +++ b/README.md @@ -727,9 +727,161 @@ try { | 'Date' | Date object. | Model | Nested model instance. +### Available Validators + +**absenceValidator()**: Function + +> Validates that the specified property is blank. + +**arrayExclusionValidator(options)**: Function + +> Validates that the specified property is not in an array of values. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.values | Array | Yes | - | Array of restricted values. + +**arrayInclusionValidator(options)**: Function + +> Validates that the specified property is in an array of values. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.values | Array | Yes | - | Array of allowed values. + +**arrayLengthValidator(options)**: Function + +> Validates the size of an array. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.min | Number | No | - | Allowed minimum items count. +| options.minOrEqual | Number | No | - | Allowed minimum items count (allowing equal). +| options.max | Number | No | - | Allowed maximum items count. +| options.maxOrEqual | Number | No | - | Allowed maximum items count (allowing equal). + +**base64Validator()**: Function + +> Validates that the specified property is base64 encoded string. + +**bsonObjectIdValidator()**: Function + +> Validates that the specified property is BSON ObjectId encoded string. + +**dateValidator(options)**: Function + +> Validates that the specified property is a date string. + +| Option | Type | Required | Default | Description +|--------|------|----------|----------|----------- +| options.iso | Boolean | No | false | When `true` only ISO-8601 date format is accepted. + +**downcaseStringValidator()**: Function + +> Validates that the specified property is lowercase. + +**emailValidator(options)**: Function + +> Validates that the specified property is an email. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.allowDisplayName | Boolean | No | false | When set to true, the validator will also match `name
`. +| options.allowUtf8LocalPart | Boolean | No | false | When set to false, the validator will not allow any non-English UTF8 character in email address' local part. +| options.requireTld | Boolean | No | true | When set to false, email addresses without having TLD in their domain will also be matched. + +**ethAddressValidator()**: Function + +> Checks if the string represents an ethereum address. + +**fqdnValidator(options)**: Function + +> Validates that the specified property is a fully qualified domain name (e.g. domain.com). + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.requireTld | Boolean | No | true | Require top-level domain name. +| options.allowUnderscores | Boolean | No | false | Allow string to include underscores. +| options.allowTrailingDot | Boolean | No | false | Allow string to include a trailing dot. + +**hexColorValidator()**: Function + +> Validates that the specified property is a hexadecimal color string. + +**hexValidator()**: Function + +> Validates that a specified property is a hexadecimal number. + +**jsonStringValidator(options)**: Function + +> Validates that the specified property is a JSON string. + +**matchValidator(options)**: Function + +> Validates that the specified property matches the pattern. + +| Key | Type | Required | Default | Description +|-----|------|----------|---------|------------ +| options.regexp | RegExp | Yes | - | Regular expression pattern. + +**numberSizeValidator(options)**: Function + +> Validates the size of a number. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.min | Number | No | - | Allowed minimum value. +| options.minOrEqual | Number | No | - | Allowed minimum value (allowing equal). +| options.max | Number | No | - | Allowed maximum value. +| options.maxOrEqual | Number | No | - | Allowed maximum value (allowing equal). + +**presenceValidator()**: Function + +> Validates that the specified property is not blank. + +**stringExclusionValidator(options)**: Function + +> Checks if the string does not contain the seed. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.seed | String | Yes | - | The seed which should exist in the string. + +**stringInclusionValidator()**: Function + +> Checks if the string contains the seed. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.seed | String | Yes | - | The seed which should exist in the string. + +**stringLengthValidator(options)**: Function + +> Validates the length of the specified property. + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.bytes | Boolean | No | false | When `true` the number of bytes is returned. +| options.min | Number | No | - | Allowed minimum number of characters. +| options.minOrEqual | Number | No | - | Allowed minimum value number of characters (allowing equal). +| options.max | Number | No | - | Allowed maximum number of characters. +| options.maxOrEqual | Number | No | - | Allowed maximum number of characters (allowing equal). + +**upcaseStringValidator()**: Function + +> Validates that the specified property is uppercase. + +**uuidValidator(options)**: Function + +> Validates that the specified property is a [UUID](https://en.wikipedia.org/wiki/Universally_unique_identifier). + +| Option | Type | Required | Default | Description +|--------|------|----------|---------|------------ +| options.version | Integer | No | - | UUID version (1, 2, 3, 4 or 5). + ### Available Handlers -**mongoUniquenessHandler(options)** +**mongoUniquenessHandler(options)**: Function > Checks if the error represents a MongoDB unique constraint error. @@ -756,6 +908,7 @@ const recipe = { // make sure that this index name exists in your MongoDB collec | [@rawmodel/parser](https://github.com/rawmodel/framework/tree/master/packages/rawmodel-parser) | Parsing and type casting. | [![NPM Version](https://badge.fury.io/js/@rawmodel%2Fparser.svg)](https://badge.fury.io/js/%40rawmodel%2Fparser) | [@rawmodel/utils](https://github.com/rawmodel/framework/tree/master/packages/rawmodel-utils) | Framework helpers. | [![NPM Version](https://badge.fury.io/js/@rawmodel%2Futils.svg)](https://badge.fury.io/js/%40rawmodel%2Futils) | [@rawmodel/validator](https://github.com/rawmodel/framework/tree/master/packages/rawmodel-validator) | Property validator. | [![NPM Version](https://badge.fury.io/js/@rawmodel%2Fvalidator.svg)](https://badge.fury.io/js/%40rawmodel%2Fvalidator) +| [@rawmodel/validators](https://github.com/rawmodel/framework/tree/master/packages/rawmodel-validators) | Collection of validators. | [![NPM Version](https://badge.fury.io/js/@rawmodel%2Fvalidators.svg)](https://badge.fury.io/js/%40rawmodel%2Fvalidators) ## Contributing diff --git a/packages/rawmodel-handlers/package.json b/packages/rawmodel-handlers/package.json index 2070bf9..cb41c7c 100644 --- a/packages/rawmodel-handlers/package.json +++ b/packages/rawmodel-handlers/package.json @@ -79,8 +79,5 @@ "ts-node": "^7.0.1", "tslint": "^5.11.0", "typescript": "^3.0.3" - }, - "dependencies": { - "@rawmodel/utils": "^2.0.3" } } diff --git a/packages/rawmodel-handlers/src/handlers/mongo-uniqueness.ts b/packages/rawmodel-handlers/src/handlers/mongo-uniqueness.ts index 328e099..4878fbc 100644 --- a/packages/rawmodel-handlers/src/handlers/mongo-uniqueness.ts +++ b/packages/rawmodel-handlers/src/handlers/mongo-uniqueness.ts @@ -27,5 +27,5 @@ export function mongoUniquenessHandler(options?: { } else { return false; } - } + }; } diff --git a/packages/rawmodel-validators/.gitignore b/packages/rawmodel-validators/.gitignore new file mode 100644 index 0000000..2e60cb7 --- /dev/null +++ b/packages/rawmodel-validators/.gitignore @@ -0,0 +1,5 @@ +.DS_Store +.vscode +.nyc_output +dist +node_modules diff --git a/packages/rawmodel-validators/.npmignore b/packages/rawmodel-validators/.npmignore new file mode 100644 index 0000000..417dbec --- /dev/null +++ b/packages/rawmodel-validators/.npmignore @@ -0,0 +1,4 @@ +.DS_Store +.vscode +.nyc_output +node_modules diff --git a/packages/rawmodel-validators/nodemon.json b/packages/rawmodel-validators/nodemon.json new file mode 100644 index 0000000..82b8933 --- /dev/null +++ b/packages/rawmodel-validators/nodemon.json @@ -0,0 +1,4 @@ +{ + "ignore": ["dist/*"], + "ext": "js,ts" +} diff --git a/packages/rawmodel-validators/package-lock.json b/packages/rawmodel-validators/package-lock.json new file mode 100644 index 0000000..2108148 --- /dev/null +++ b/packages/rawmodel-validators/package-lock.json @@ -0,0 +1,3531 @@ +{ + "name": "@rawmodel/validators", + "version": "2.0.3", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@babel/code-frame": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0-beta.51.tgz", + "integrity": "sha1-vXHZsZKvl435FYKdOdQJRFZDmgw=", + "dev": true, + "requires": { + "@babel/highlight": "7.0.0-beta.51" + } + }, + "@babel/generator": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.0.0-beta.51.tgz", + "integrity": "sha1-bHV1/952HQdIXgS67cA5LG2eMPY=", + "dev": true, + "requires": { + "@babel/types": "7.0.0-beta.51", + "jsesc": "^2.5.1", + "lodash": "^4.17.5", + "source-map": "^0.5.0", + "trim-right": "^1.0.1" + } + }, + "@babel/helper-function-name": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.0.0-beta.51.tgz", + "integrity": "sha1-IbSHSiJ8+Z7K/MMKkDAtpaJkBWE=", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "7.0.0-beta.51", + "@babel/template": "7.0.0-beta.51", + "@babel/types": "7.0.0-beta.51" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.0.0-beta.51.tgz", + "integrity": "sha1-MoGy0EWvlcFyzpGyCCXYXqRnZBE=", + "dev": true, + "requires": { + "@babel/types": "7.0.0-beta.51" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.0.0-beta.51.tgz", + "integrity": "sha1-imw/ZsTSZTUvwHdIT59ugKUauXg=", + "dev": true, + "requires": { + "@babel/types": "7.0.0-beta.51" + } + }, + "@babel/highlight": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0-beta.51.tgz", + "integrity": "sha1-6IRK4loVlcz9QriWI7Q3bKBtIl0=", + "dev": true, + "requires": { + "chalk": "^2.0.0", + "esutils": "^2.0.2", + "js-tokens": "^3.0.0" + } + }, + "@babel/parser": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.0.0-beta.51.tgz", + "integrity": "sha1-J87C30Cd9gr1gnDtj2qlVAnqhvY=", + "dev": true + }, + "@babel/template": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.0.0-beta.51.tgz", + "integrity": "sha1-lgKkCuvPNXrpZ34lMu9fyBD1+/8=", + "dev": true, + "requires": { + "@babel/code-frame": "7.0.0-beta.51", + "@babel/parser": "7.0.0-beta.51", + "@babel/types": "7.0.0-beta.51", + "lodash": "^4.17.5" + } + }, + "@babel/traverse": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.0.0-beta.51.tgz", + "integrity": "sha1-mB2vLOw0emIx06odnhgDsDqqpKg=", + "dev": true, + "requires": { + "@babel/code-frame": "7.0.0-beta.51", + "@babel/generator": "7.0.0-beta.51", + "@babel/helper-function-name": "7.0.0-beta.51", + "@babel/helper-split-export-declaration": "7.0.0-beta.51", + "@babel/parser": "7.0.0-beta.51", + "@babel/types": "7.0.0-beta.51", + "debug": "^3.1.0", + "globals": "^11.1.0", + "invariant": "^2.2.0", + "lodash": "^4.17.5" + }, + "dependencies": { + "debug": { + "version": "3.2.5", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.5.tgz", + "integrity": "sha512-D61LaDQPQkxJ5AUM2mbSJRbPkNs/TmdmOeLAi1hgDkpDfIfetSrjmWhccwtuResSwMbACjx/xXQofvM9CE/aeg==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + }, + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", + "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", + "dev": true + } + } + }, + "@babel/types": { + "version": "7.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.0.0-beta.51.tgz", + "integrity": "sha1-2AK3tUO1g2x3iqaReXq/APPZfqk=", + "dev": true, + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.5", + "to-fast-properties": "^2.0.0" + } + }, + "@hayspec/cli": { + "version": "0.4.21", + "resolved": "https://registry.npmjs.org/@hayspec/cli/-/cli-0.4.21.tgz", + "integrity": "sha512-EGlJVk7ySkWBy8PC1J3cVzp1GKcHiW7CqfrXn1Ogw/dMLxO+4ipZAXizBAzyd7j5UDFRD12GsBu5IexIaDoWBA==", + "dev": true, + "requires": { + "@hayspec/init": "^0.4.21", + "@hayspec/reporter": "^0.4.21", + "@hayspec/runner": "^0.4.21", + "@hayspec/spec": "^0.4.21", + "inquirer": "^6.0.0", + "yargs": "^11.0.0" + } + }, + "@hayspec/init": { + "version": "0.4.21", + "resolved": "https://registry.npmjs.org/@hayspec/init/-/init-0.4.21.tgz", + "integrity": "sha512-oVF6m7LrSIMWcNT0sJZ5WyuJe6mKqaLZDIduELcfX6+ZWLBFViWw19Oa+JjJOT5djUp8U33bUKVl918VPC42KA==", + "dev": true, + "requires": { + "fs-extra": "^6.0.1" + } + }, + "@hayspec/reporter": { + "version": "0.4.21", + "resolved": "https://registry.npmjs.org/@hayspec/reporter/-/reporter-0.4.21.tgz", + "integrity": "sha512-fpFk9buEkuAEL0cUIbf0UwqKCkK4/D/+9Z7TqGCIVlAwyAmQu1euoh+bsvER5xpUdjiCXqKtH45ywXda9Xsn3Q==", + "dev": true, + "requires": { + "@hayspec/spec": "^0.4.21", + "chalk": "^2.4.1" + } + }, + "@hayspec/runner": { + "version": "0.4.21", + "resolved": "https://registry.npmjs.org/@hayspec/runner/-/runner-0.4.21.tgz", + "integrity": "sha512-5dhRbxu7vpMZpwsOvuHkSAiqOHc/ir1STdIrsBj6/4/2ZkPYWdDQ/QXWmN8+L+ac8TCVNY3NTtr3lGL2Kf7MZQ==", + "dev": true, + "requires": { + "@hayspec/spec": "^0.4.21", + "fast-glob": "^2.2.2" + } + }, + "@hayspec/spec": { + "version": "0.4.21", + "resolved": "https://registry.npmjs.org/@hayspec/spec/-/spec-0.4.21.tgz", + "integrity": "sha512-kr1gGZOB0GVopVWxojnrhP02PgiXTymLuhkRIRXXWKI/gMlLg+hhw4rQNYK91p2k82Rapd1/eYA+4xKfmnjYmQ==", + "dev": true + }, + "@mrmlnc/readdir-enhanced": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz", + "integrity": "sha512-bPHp6Ji8b41szTOcaP63VlnbbO5Ny6dwAATtY6JTjh5N2OLrb5Qk/Th5cRkRQhkWCt+EJsYrNB0MiL+Gpn6e3g==", + "dev": true, + "requires": { + "call-me-maybe": "^1.0.1", + "glob-to-regexp": "^0.3.0" + } + }, + "@nodelib/fs.stat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-1.1.2.tgz", + "integrity": "sha512-yprFYuno9FtNsSHVlSWd+nRlmGoAbqbeCwOryP6sC/zoCjhpArcRMYp19EvpSUSizJAlsXEwJv+wcWS9XaXdMw==", + "dev": true + }, + "@rawmodel/utils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@rawmodel/utils/-/utils-2.0.3.tgz", + "integrity": "sha512-l31femLKXcaDlvHRX0y6WHQhBu/Bvr2IPkMYcczc9r4wG0C/OaxcWWL6XUHr1YHcDnX61jm7nUXCWeR0k7Q+IQ==" + }, + "ansi-escapes": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", + "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", + "dev": true + }, + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", + "dev": true + }, + "arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", + "dev": true + }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", + "dev": true + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", + "dev": true + }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", + "dev": true + }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", + "dev": true + }, + "atob": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", + "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", + "dev": true + }, + "babel-code-frame": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", + "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", + "dev": true, + "requires": { + "chalk": "^1.1.3", + "esutils": "^2.0.2", + "js-tokens": "^3.0.2" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", + "dev": true + }, + "chalk": { + "version": "1.1.3", + "resolved": "http://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "dev": true, + "requires": { + "ansi-styles": "^2.2.1", + "escape-string-regexp": "^1.0.2", + "has-ansi": "^2.0.0", + "strip-ansi": "^3.0.0", + "supports-color": "^2.0.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", + "dev": true + } + } + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "dev": true, + "requires": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "dev": true, + "requires": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", + "dev": true + }, + "builtin-modules": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", + "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", + "dev": true + }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "dev": true, + "requires": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + } + }, + "call-me-maybe": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.1.tgz", + "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=", + "dev": true + }, + "camelcase": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", + "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", + "dev": true + }, + "chalk": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", + "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", + "dev": true + }, + "class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "cli-cursor": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", + "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", + "dev": true, + "requires": { + "restore-cursor": "^2.0.0" + } + }, + "cli-width": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", + "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", + "dev": true + }, + "cliui": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", + "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", + "dev": true, + "requires": { + "string-width": "^2.1.1", + "strip-ansi": "^4.0.0", + "wrap-ansi": "^2.0.0" + } + }, + "code-point-at": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", + "dev": true + }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "dev": true, + "requires": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "commander": { + "version": "2.18.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.18.0.tgz", + "integrity": "sha512-6CYPa+JP2ftfRU2qkDK+UTVeQYosOg/2GbcjIcKPHfinyOLPVGXu/ovN86RP49Re5ndJK1N0kuiidFFuepc4ZQ==", + "dev": true + }, + "component-emitter": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", + "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", + "dev": true + }, + "cross-spawn": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", + "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true + }, + "decode-uri-component": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", + "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", + "dev": true + }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "dev": true, + "requires": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "dependencies": { + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "diff": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", + "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", + "dev": true + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "esutils": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", + "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", + "dev": true + }, + "execa": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", + "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", + "dev": true, + "requires": { + "cross-spawn": "^5.0.1", + "get-stream": "^3.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "dev": true, + "requires": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "dev": true, + "requires": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "external-editor": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", + "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", + "dev": true, + "requires": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "dev": true, + "requires": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "fast-glob": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-2.2.2.tgz", + "integrity": "sha512-TR6zxCKftDQnUAPvkrCWdBgDq/gbqx8A3ApnBrR5rMvpp6+KMJI0Igw7fkWPgeVK0uhRXTXdvO3O+YP0CaUX2g==", + "dev": true, + "requires": { + "@mrmlnc/readdir-enhanced": "^2.2.1", + "@nodelib/fs.stat": "^1.0.1", + "glob-parent": "^3.1.0", + "is-glob": "^4.0.0", + "merge2": "^1.2.1", + "micromatch": "^3.1.10" + } + }, + "figures": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", + "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", + "dev": true, + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", + "dev": true + }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "dev": true, + "requires": { + "map-cache": "^0.2.2" + } + }, + "fs-extra": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-6.0.1.tgz", + "integrity": "sha512-GnyIkKhhzXZUWFCaJzvyDLEEgDkPfb4/TPvJCJVuS8MWZgoSsErf++QpiAlDnKFcqhRlm+tIOcencCjyJE6ZCA==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "get-caller-file": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", + "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==", + "dev": true + }, + "get-stream": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", + "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", + "dev": true + }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", + "dev": true + }, + "glob": { + "version": "7.1.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", + "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "dev": true, + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "glob-to-regexp": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.3.0.tgz", + "integrity": "sha1-jFoUlNIGbFcMw7/kSWF1rMTVAqs=", + "dev": true + }, + "globals": { + "version": "11.7.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.7.0.tgz", + "integrity": "sha512-K8BNSPySfeShBQXsahYB/AbbWruVOTyVpgoIDnl8odPpeSfP2J5QO2oLFFdl2j7GfDCtZj2bMKar2T49itTPCg==", + "dev": true + }, + "graceful-fs": { + "version": "4.1.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", + "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", + "dev": true + }, + "has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + } + } + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true + }, + "has-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", + "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "dev": true, + "requires": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "has-values": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", + "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "dependencies": { + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + }, + "inquirer": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.0.tgz", + "integrity": "sha512-QIEQG4YyQ2UYZGDC4srMZ7BjHOmNk1lR2JQj5UknBapklm6WHA+VVH7N+sUdX3A7NeCfGF8o4X1S3Ao7nAcIeg==", + "dev": true, + "requires": { + "ansi-escapes": "^3.0.0", + "chalk": "^2.0.0", + "cli-cursor": "^2.1.0", + "cli-width": "^2.0.0", + "external-editor": "^3.0.0", + "figures": "^2.0.0", + "lodash": "^4.17.10", + "mute-stream": "0.0.7", + "run-async": "^2.2.0", + "rxjs": "^6.1.0", + "string-width": "^2.1.0", + "strip-ansi": "^4.0.0", + "through": "^2.3.6" + } + }, + "invariant": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", + "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", + "dev": true, + "requires": { + "loose-envify": "^1.0.0" + } + }, + "invert-kv": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", + "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=", + "dev": true + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", + "dev": true + } + } + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "is-glob": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz", + "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", + "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", + "dev": true + }, + "is-stream": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", + "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", + "dev": true + }, + "is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", + "dev": true + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", + "dev": true + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "dev": true + }, + "istanbul-lib-coverage": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.1.tgz", + "integrity": "sha512-nPvSZsVlbG9aLhZYaC3Oi1gT/tpyo3Yt5fNyf6NmcKIayz4VV/txxJFFKAK/gU4dcNn8ehsanBbVHVl0+amOLA==", + "dev": true + }, + "istanbul-lib-instrument": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-2.3.2.tgz", + "integrity": "sha512-l7TD/VnBsIB2OJvSyxaLW/ab1+92dxZNH9wLH7uHPPioy3JZ8tnx2UXUdKmdkgmP2EFPzg64CToUP6dAS3U32Q==", + "dev": true, + "requires": { + "@babel/generator": "7.0.0-beta.51", + "@babel/parser": "7.0.0-beta.51", + "@babel/template": "7.0.0-beta.51", + "@babel/traverse": "7.0.0-beta.51", + "@babel/types": "7.0.0-beta.51", + "istanbul-lib-coverage": "^2.0.1", + "semver": "^5.5.0" + } + }, + "js-tokens": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", + "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", + "dev": true + }, + "js-yaml": { + "version": "3.12.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", + "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsesc": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.1.tgz", + "integrity": "sha1-5CGiqOINawgZ3yiQj3glJrlt0f4=", + "dev": true + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true + }, + "lcid": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", + "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", + "dev": true, + "requires": { + "invert-kv": "^1.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "lodash": { + "version": "4.17.11", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", + "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", + "dev": true + }, + "loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "dev": true, + "requires": { + "js-tokens": "^3.0.0 || ^4.0.0" + } + }, + "lru-cache": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.3.tgz", + "integrity": "sha512-fFEhvcgzuIoJVUF8fYr5KR0YqxD238zgObTps31YdADwPPAp82a4M8TrckkWyx7ekNlf9aBcVn81cFwwXngrJA==", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "make-error": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.5.tgz", + "integrity": "sha512-c3sIjNUow0+8swNwVpqoH4YCShKNFkMaw6oH1mNS2haDZQqkeZFlHS3dhoeEbKKmJB4vXpJucU6oH75aDYeE9g==", + "dev": true + }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", + "dev": true + }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "dev": true, + "requires": { + "object-visit": "^1.0.0" + } + }, + "mem": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/mem/-/mem-1.1.0.tgz", + "integrity": "sha1-Xt1StIXKHZAP5kiVUFOZoN+kX3Y=", + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "merge2": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.2.2.tgz", + "integrity": "sha512-bgM8twH86rWni21thii6WCMQMRMmwqqdW3sGWi9IipnVAszdLXRjwDwAnyrVXo6DuP3AjRMMttZKUB48QWIFGg==", + "dev": true + }, + "micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + } + }, + "mimic-fn": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", + "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.0", + "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", + "dev": true + }, + "mixin-deep": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.1.tgz", + "integrity": "sha512-8ZItLHeEgaqEvd5lYBXfm4EZSFCX29Jb9K+lAHhDKzReKBQKj3R+7NOF6tjqYi9t4oI8VUfaWITJQm86wnXGNQ==", + "dev": true, + "requires": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "mkdirp": { + "version": "0.5.1", + "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "dev": true, + "requires": { + "minimist": "0.0.8" + }, + "dependencies": { + "minimist": { + "version": "0.0.8", + "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", + "dev": true + } + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + }, + "mute-stream": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", + "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", + "dev": true + }, + "nanomatch": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", + "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", + "dev": true, + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + } + }, + "npm-run-path": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", + "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", + "dev": true, + "requires": { + "path-key": "^2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", + "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", + "dev": true + }, + "nyc": { + "version": "13.0.1", + "resolved": "https://registry.npmjs.org/nyc/-/nyc-13.0.1.tgz", + "integrity": "sha512-Op/bjhEF74IMtzMmgYt+ModTeMHoPZzHe4qseUguPBwg5qC6r4rYMBt1L3yRXQIbjUpEqmn24/1xAC/umQGU7w==", + "dev": true, + "requires": { + "archy": "^1.0.0", + "arrify": "^1.0.1", + "caching-transform": "^2.0.0", + "convert-source-map": "^1.5.1", + "debug-log": "^1.0.1", + "find-cache-dir": "^2.0.0", + "find-up": "^3.0.0", + "foreground-child": "^1.5.6", + "glob": "^7.1.2", + "istanbul-lib-coverage": "^2.0.1", + "istanbul-lib-hook": "^2.0.1", + "istanbul-lib-instrument": "^2.3.2", + "istanbul-lib-report": "^2.0.1", + "istanbul-lib-source-maps": "^2.0.1", + "istanbul-reports": "^2.0.0", + "make-dir": "^1.3.0", + "merge-source-map": "^1.1.0", + "resolve-from": "^4.0.0", + "rimraf": "^2.6.2", + "signal-exit": "^3.0.2", + "spawn-wrap": "^1.4.2", + "test-exclude": "^5.0.0", + "uuid": "^3.3.2", + "yargs": "11.1.0", + "yargs-parser": "^9.0.2" + }, + "dependencies": { + "align-text": { + "version": "0.1.4", + "bundled": true, + "dev": true, + "requires": { + "kind-of": "^3.0.2", + "longest": "^1.0.1", + "repeat-string": "^1.5.2" + } + }, + "amdefine": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "ansi-regex": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "append-transform": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "default-require-extensions": "^2.0.0" + } + }, + "archy": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "arrify": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "async": { + "version": "1.5.2", + "bundled": true, + "dev": true + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "bundled": true, + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "builtin-modules": { + "version": "1.1.1", + "bundled": true, + "dev": true + }, + "caching-transform": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "make-dir": "^1.0.0", + "md5-hex": "^2.0.0", + "package-hash": "^2.0.0", + "write-file-atomic": "^2.0.0" + } + }, + "camelcase": { + "version": "1.2.1", + "bundled": true, + "dev": true, + "optional": true + }, + "center-align": { + "version": "0.1.3", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "align-text": "^0.1.3", + "lazy-cache": "^1.0.3" + } + }, + "cliui": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "center-align": "^0.1.1", + "right-align": "^0.1.1", + "wordwrap": "0.0.2" + }, + "dependencies": { + "wordwrap": { + "version": "0.0.2", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "commondir": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "dev": true + }, + "convert-source-map": { + "version": "1.5.1", + "bundled": true, + "dev": true + }, + "cross-spawn": { + "version": "4.0.2", + "bundled": true, + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "which": "^1.2.9" + } + }, + "debug": { + "version": "3.1.0", + "bundled": true, + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "debug-log": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "decamelize": { + "version": "1.2.0", + "bundled": true, + "dev": true + }, + "default-require-extensions": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "strip-bom": "^3.0.0" + } + }, + "error-ex": { + "version": "1.3.2", + "bundled": true, + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es6-error": { + "version": "4.1.1", + "bundled": true, + "dev": true + }, + "execa": { + "version": "0.7.0", + "bundled": true, + "dev": true, + "requires": { + "cross-spawn": "^5.0.1", + "get-stream": "^3.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + }, + "dependencies": { + "cross-spawn": { + "version": "5.1.0", + "bundled": true, + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + } + } + }, + "find-cache-dir": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^1.0.0", + "pkg-dir": "^3.0.0" + } + }, + "find-up": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "foreground-child": { + "version": "1.5.6", + "bundled": true, + "dev": true, + "requires": { + "cross-spawn": "^4", + "signal-exit": "^3.0.0" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "get-caller-file": { + "version": "1.0.3", + "bundled": true, + "dev": true + }, + "get-stream": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "graceful-fs": { + "version": "4.1.11", + "bundled": true, + "dev": true + }, + "handlebars": { + "version": "4.0.11", + "bundled": true, + "dev": true, + "requires": { + "async": "^1.4.0", + "optimist": "^0.6.1", + "source-map": "^0.4.4", + "uglify-js": "^2.6" + }, + "dependencies": { + "source-map": { + "version": "0.4.4", + "bundled": true, + "dev": true, + "requires": { + "amdefine": ">=0.0.4" + } + } + } + }, + "has-flag": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "hosted-git-info": { + "version": "2.7.1", + "bundled": true, + "dev": true + }, + "imurmurhash": { + "version": "0.1.4", + "bundled": true, + "dev": true + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true, + "dev": true + }, + "invert-kv": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "is-arrayish": { + "version": "0.2.1", + "bundled": true, + "dev": true + }, + "is-buffer": { + "version": "1.1.6", + "bundled": true, + "dev": true + }, + "is-builtin-module": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "builtin-modules": "^1.0.0" + } + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "is-stream": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "isexe": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "istanbul-lib-coverage": { + "version": "2.0.1", + "bundled": true, + "dev": true + }, + "istanbul-lib-hook": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "append-transform": "^1.0.0" + } + }, + "istanbul-lib-report": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "istanbul-lib-coverage": "^2.0.1", + "make-dir": "^1.3.0", + "supports-color": "^5.4.0" + } + }, + "istanbul-lib-source-maps": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "debug": "^3.1.0", + "istanbul-lib-coverage": "^2.0.1", + "make-dir": "^1.3.0", + "rimraf": "^2.6.2", + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "bundled": true, + "dev": true + } + } + }, + "istanbul-reports": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "handlebars": "^4.0.11" + } + }, + "json-parse-better-errors": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "bundled": true, + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + }, + "lazy-cache": { + "version": "1.0.4", + "bundled": true, + "dev": true, + "optional": true + }, + "lcid": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "invert-kv": "^1.0.0" + } + }, + "load-json-file": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + } + }, + "locate-path": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "lodash.flattendeep": { + "version": "4.4.0", + "bundled": true, + "dev": true + }, + "longest": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "lru-cache": { + "version": "4.1.3", + "bundled": true, + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "make-dir": { + "version": "1.3.0", + "bundled": true, + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "md5-hex": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "md5-o-matic": "^0.1.1" + } + }, + "md5-o-matic": { + "version": "0.1.1", + "bundled": true, + "dev": true + }, + "mem": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "merge-source-map": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "source-map": "^0.6.1" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "bundled": true, + "dev": true + } + } + }, + "mimic-fn": { + "version": "1.2.0", + "bundled": true, + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "0.0.10", + "bundled": true, + "dev": true + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "0.0.8" + }, + "dependencies": { + "minimist": { + "version": "0.0.8", + "bundled": true, + "dev": true + } + } + }, + "ms": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "normalize-package-data": { + "version": "2.4.0", + "bundled": true, + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "is-builtin-module": "^1.0.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "npm-run-path": { + "version": "2.0.2", + "bundled": true, + "dev": true, + "requires": { + "path-key": "^2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "optimist": { + "version": "0.6.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "~0.0.1", + "wordwrap": "~0.0.2" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "os-locale": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "execa": "^0.7.0", + "lcid": "^1.0.0", + "mem": "^1.1.0" + } + }, + "p-finally": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "p-limit": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "p-try": "^2.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "p-try": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "package-hash": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "graceful-fs": "^4.1.11", + "lodash.flattendeep": "^4.4.0", + "md5-hex": "^2.0.0", + "release-zalgo": "^1.0.0" + } + }, + "parse-json": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-exists": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "path-key": { + "version": "2.0.1", + "bundled": true, + "dev": true + }, + "path-type": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "pify": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "pkg-dir": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + }, + "pseudomap": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "find-up": "^3.0.0", + "read-pkg": "^3.0.0" + } + }, + "release-zalgo": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "es6-error": "^4.0.1" + } + }, + "repeat-string": { + "version": "1.6.1", + "bundled": true, + "dev": true + }, + "require-directory": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "require-main-filename": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "resolve-from": { + "version": "4.0.0", + "bundled": true, + "dev": true + }, + "right-align": { + "version": "0.1.3", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "align-text": "^0.1.1" + } + }, + "rimraf": { + "version": "2.6.2", + "bundled": true, + "dev": true, + "requires": { + "glob": "^7.0.5" + } + }, + "semver": { + "version": "5.5.0", + "bundled": true, + "dev": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "dev": true + }, + "source-map": { + "version": "0.5.7", + "bundled": true, + "dev": true, + "optional": true + }, + "spawn-wrap": { + "version": "1.4.2", + "bundled": true, + "dev": true, + "requires": { + "foreground-child": "^1.5.6", + "mkdirp": "^0.5.0", + "os-homedir": "^1.0.1", + "rimraf": "^2.6.2", + "signal-exit": "^3.0.2", + "which": "^1.3.0" + } + }, + "spdx-correct": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.1.0", + "bundled": true, + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "string-width": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + }, + "strip-bom": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "strip-eof": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "supports-color": { + "version": "5.4.0", + "bundled": true, + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "test-exclude": { + "version": "5.0.0", + "bundled": true, + "dev": true, + "requires": { + "arrify": "^1.0.1", + "minimatch": "^3.0.4", + "read-pkg-up": "^4.0.0", + "require-main-filename": "^1.0.1" + } + }, + "uglify-js": { + "version": "2.8.29", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "source-map": "~0.5.1", + "uglify-to-browserify": "~1.0.0", + "yargs": "~3.10.0" + }, + "dependencies": { + "yargs": { + "version": "3.10.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "camelcase": "^1.0.2", + "cliui": "^2.1.0", + "decamelize": "^1.0.0", + "window-size": "0.1.0" + } + } + } + }, + "uglify-to-browserify": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "uuid": { + "version": "3.3.2", + "bundled": true, + "dev": true + }, + "validate-npm-package-license": { + "version": "3.0.3", + "bundled": true, + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "which": { + "version": "1.3.1", + "bundled": true, + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-module": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "window-size": { + "version": "0.1.0", + "bundled": true, + "dev": true, + "optional": true + }, + "wordwrap": { + "version": "0.0.3", + "bundled": true, + "dev": true + }, + "wrap-ansi": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "write-file-atomic": { + "version": "2.3.0", + "bundled": true, + "dev": true, + "requires": { + "graceful-fs": "^4.1.11", + "imurmurhash": "^0.1.4", + "signal-exit": "^3.0.2" + } + }, + "y18n": { + "version": "3.2.1", + "bundled": true, + "dev": true + }, + "yallist": { + "version": "2.1.2", + "bundled": true, + "dev": true + }, + "yargs": { + "version": "11.1.0", + "bundled": true, + "dev": true, + "requires": { + "cliui": "^4.0.0", + "decamelize": "^1.1.1", + "find-up": "^2.1.0", + "get-caller-file": "^1.0.1", + "os-locale": "^2.0.0", + "require-directory": "^2.1.1", + "require-main-filename": "^1.0.1", + "set-blocking": "^2.0.0", + "string-width": "^2.0.0", + "which-module": "^2.0.0", + "y18n": "^3.2.1", + "yargs-parser": "^9.0.2" + }, + "dependencies": { + "cliui": { + "version": "4.1.0", + "bundled": true, + "dev": true, + "requires": { + "string-width": "^2.1.1", + "strip-ansi": "^4.0.0", + "wrap-ansi": "^2.0.0" + } + }, + "find-up": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "locate-path": "^2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "bundled": true, + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "bundled": true, + "dev": true + } + } + }, + "yargs-parser": { + "version": "9.0.2", + "bundled": true, + "dev": true, + "requires": { + "camelcase": "^4.1.0" + }, + "dependencies": { + "camelcase": { + "version": "4.1.0", + "bundled": true, + "dev": true + } + } + } + } + }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "dev": true, + "requires": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "dev": true, + "requires": { + "isobject": "^3.0.0" + } + }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "onetime": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", + "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "os-locale": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-2.1.0.tgz", + "integrity": "sha512-3sslG3zJbEYcaC4YVAvDorjGxc7tv6KVATnLPZONiljsUncvihe9BQoVCEs0RZ1kmf4Hk9OBqlZfJZWI4GanKA==", + "dev": true, + "requires": { + "execa": "^0.7.0", + "lcid": "^1.0.0", + "mem": "^1.1.0" + } + }, + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true + }, + "p-finally": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", + "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", + "dev": true + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "dev": true, + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "dev": true, + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "dev": true + }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", + "dev": true + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", + "dev": true + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", + "dev": true + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", + "dev": true + }, + "posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", + "dev": true + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", + "dev": true + }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + } + }, + "repeat-element": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", + "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", + "dev": true + }, + "repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", + "dev": true + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", + "dev": true + }, + "require-main-filename": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", + "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", + "dev": true + }, + "resolve": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.8.1.tgz", + "integrity": "sha512-AicPrAC7Qu1JxPCZ9ZgCZlY35QgFnNqc+0LtbRNxnVw4TXvjQ72wnuL9JQcEBgXkI9JM8MsT9kaQoHcpCRJOYA==", + "dev": true, + "requires": { + "path-parse": "^1.0.5" + } + }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", + "dev": true + }, + "restore-cursor": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", + "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", + "dev": true, + "requires": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + } + }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", + "dev": true + }, + "run-async": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", + "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", + "dev": true, + "requires": { + "is-promise": "^2.1.0" + } + }, + "rxjs": { + "version": "6.3.2", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.3.2.tgz", + "integrity": "sha512-hV7criqbR0pe7EeL3O66UYVg92IR0XsA97+9y+BWTePK9SKmEI5Qd3Zj6uPnGkNzXsBywBQWTvujPl+1Kn9Zjw==", + "dev": true, + "requires": { + "tslib": "^1.9.0" + } + }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "dev": true, + "requires": { + "ret": "~0.1.10" + } + }, + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "semver": { + "version": "5.5.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.1.tgz", + "integrity": "sha512-PqpAxfrEhlSUWge8dwIp4tZnQ25DIOthpiaHNIthsjEFQD6EvqUKUDM7L8O2rShkFccYo1VjJR0coWfNkCubRw==", + "dev": true + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true + }, + "set-value": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", + "integrity": "sha512-hw0yxk9GT/Hr5yJEYnHNKYXkIA8mVJgd9ditYZCe16ZczcaELYYcfvaXesNACk2O8O0nTiPQcQhGUQj8JLzeeg==", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true + }, + "signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true + }, + "snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", + "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "dev": true, + "requires": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "dev": true, + "requires": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "dev": true, + "requires": { + "kind-of": "^3.2.0" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", + "dev": true + }, + "source-map-resolve": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", + "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", + "dev": true, + "requires": { + "atob": "^2.1.1", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "source-map-support": { + "version": "0.5.9", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.9.tgz", + "integrity": "sha512-gR6Rw4MvUlYy83vP0vxoVNzM6t8MUXqNuRsuBmBHQDu1Fh6X015FrLdgoDKcNdkwGubozq0P4N0Q37UyFVr1EA==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + }, + "dependencies": { + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + } + } + }, + "source-map-url": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", + "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", + "dev": true + }, + "split-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "dev": true, + "requires": { + "extend-shallow": "^3.0.0" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "dev": true, + "requires": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + }, + "strip-eof": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", + "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "through": { + "version": "2.3.8", + "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", + "dev": true + }, + "tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "dev": true, + "requires": { + "os-tmpdir": "~1.0.2" + } + }, + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", + "dev": true + }, + "to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", + "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "dev": true, + "requires": { + "kind-of": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "dev": true, + "requires": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + } + }, + "to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", + "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "dev": true, + "requires": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + } + }, + "trim-right": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", + "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", + "dev": true + }, + "ts-node": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-7.0.1.tgz", + "integrity": "sha512-BVwVbPJRspzNh2yfslyT1PSbl5uIk03EZlb493RKHN4qej/D06n1cEhjlOJG69oFsE7OT8XjpTUcYf6pKTLMhw==", + "dev": true, + "requires": { + "arrify": "^1.0.0", + "buffer-from": "^1.1.0", + "diff": "^3.1.0", + "make-error": "^1.1.1", + "minimist": "^1.2.0", + "mkdirp": "^0.5.1", + "source-map-support": "^0.5.6", + "yn": "^2.0.0" + } + }, + "tslib": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", + "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", + "dev": true + }, + "tslint": { + "version": "5.11.0", + "resolved": "https://registry.npmjs.org/tslint/-/tslint-5.11.0.tgz", + "integrity": "sha1-mPMMAurjzecAYgHkwzywi0hYHu0=", + "dev": true, + "requires": { + "babel-code-frame": "^6.22.0", + "builtin-modules": "^1.1.1", + "chalk": "^2.3.0", + "commander": "^2.12.1", + "diff": "^3.2.0", + "glob": "^7.1.1", + "js-yaml": "^3.7.0", + "minimatch": "^3.0.4", + "resolve": "^1.3.2", + "semver": "^5.3.0", + "tslib": "^1.8.0", + "tsutils": "^2.27.2" + } + }, + "tsutils": { + "version": "2.29.0", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", + "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", + "dev": true, + "requires": { + "tslib": "^1.8.1" + } + }, + "typescript": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.0.3.tgz", + "integrity": "sha512-kk80vLW9iGtjMnIv11qyxLqZm20UklzuR2tL0QAnDIygIUIemcZMxlMWudl9OOt76H3ntVzcTiddQ1/pAAJMYg==", + "dev": true + }, + "union-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", + "integrity": "sha1-XHHDTLW61dzr4+oM0IIHulqhrqQ=", + "dev": true, + "requires": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^0.4.3" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "set-value": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-0.4.3.tgz", + "integrity": "sha1-fbCPnT0i3H945Trzw79GZuzfzPE=", + "dev": true, + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.1", + "to-object-path": "^0.3.0" + } + } + } + }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true + }, + "unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", + "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "dev": true, + "requires": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "dev": true, + "requires": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "dev": true, + "requires": { + "isarray": "1.0.0" + } + } + } + }, + "has-values": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", + "dev": true + } + } + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", + "dev": true + }, + "use": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", + "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-module": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", + "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", + "dev": true + }, + "wrap-ansi": { + "version": "2.1.0", + "resolved": "http://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", + "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", + "dev": true, + "requires": { + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "dev": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + }, + "y18n": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", + "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + }, + "yargs": { + "version": "11.1.0", + "resolved": "http://registry.npmjs.org/yargs/-/yargs-11.1.0.tgz", + "integrity": "sha512-NwW69J42EsCSanF8kyn5upxvjp5ds+t3+udGBeTbFnERA+lF541DDpMawzo4z6W/QrzNM18D+BPMiOBibnFV5A==", + "dev": true, + "requires": { + "cliui": "^4.0.0", + "decamelize": "^1.1.1", + "find-up": "^2.1.0", + "get-caller-file": "^1.0.1", + "os-locale": "^2.0.0", + "require-directory": "^2.1.1", + "require-main-filename": "^1.0.1", + "set-blocking": "^2.0.0", + "string-width": "^2.0.0", + "which-module": "^2.0.0", + "y18n": "^3.2.1", + "yargs-parser": "^9.0.2" + } + }, + "yargs-parser": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-9.0.2.tgz", + "integrity": "sha1-nM9qQ0YP5O1Aqbto9I1DuKaMwHc=", + "dev": true, + "requires": { + "camelcase": "^4.1.0" + } + }, + "yn": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/yn/-/yn-2.0.0.tgz", + "integrity": "sha1-5a2ryKz0CPY4X8dklWhMiOavaJo=", + "dev": true + } + } +} diff --git a/packages/rawmodel-validators/package.json b/packages/rawmodel-validators/package.json new file mode 100644 index 0000000..330fd95 --- /dev/null +++ b/packages/rawmodel-validators/package.json @@ -0,0 +1,86 @@ +{ + "name": "@rawmodel/validators", + "version": "2.0.3", + "description": "General validators for RawModel.", + "main": "./dist/index.js", + "types": "./dist/index.d.ts", + "scripts": { + "clean": "rm -Rf ./dist", + "transpile": "npm run clean; tsc", + "lint": "tslint 'src/**/*.ts?(x)'", + "prepare": "npm run transpile", + "test": "nyc hayspec test --require ts-node/register --match ./src/tests/**/*.test.ts" + }, + "nyc": { + "extension": [ + ".ts" + ], + "require": [ + "ts-node/register" + ], + "exclude": [ + "src/tests" + ] + }, + "repository": { + "type": "git", + "url": "git+https://github.com/rawmodel/framework.git" + }, + "bugs": { + "url": "https://github.com/rawmodel/framework/issues" + }, + "homepage": "https://github.com/rawmodel/framework#readme", + "keywords": [ + "model", + "modeling", + "document", + "object", + "schema", + "orm", + "odm", + "map", + "mapping", + "context", + "contextify", + "rawmodel", + "class", + "db", + "database", + "storage", + "structure", + "structuring", + "error", + "errors", + "handling", + "handle", + "valid", + "validate", + "validation", + "validator", + "validating", + "type", + "cast", + "casting", + "history", + "tracking", + "change", + "field", + "fields", + "serialize", + "serialization", + "serializable" + ], + "author": "Kristijan Sedlak (Xpepermint)", + "license": "MIT", + "devDependencies": { + "@hayspec/cli": "^0.4.21", + "@hayspec/spec": "^0.4.21", + "nyc": "^13.0.1", + "ts-node": "^7.0.1", + "tslint": "^5.11.0", + "typescript": "^3.0.3" + }, + "dependencies": { + "@rawmodel/utils": "^2.0.3" + } +} diff --git a/packages/rawmodel-validators/src/index.ts b/packages/rawmodel-validators/src/index.ts new file mode 100644 index 0000000..10dc880 --- /dev/null +++ b/packages/rawmodel-validators/src/index.ts @@ -0,0 +1,22 @@ +export * from './validators/absence'; +export * from './validators/array-exclusion'; +export * from './validators/array-inclusion'; +export * from './validators/array-length'; +export * from './validators/base64'; +export * from './validators/bson-object-id'; +export * from './validators/date'; +export * from './validators/email'; +export * from './validators/eth-address'; +export * from './validators/fqdn'; +export * from './validators/hex-color'; +export * from './validators/hex'; +export * from './validators/json-string'; +export * from './validators/downcase-string'; +export * from './validators/match'; +export * from './validators/number-size'; +export * from './validators/presence'; +export * from './validators/string-exclusion'; +export * from './validators/string-inclusion'; +export * from './validators/string-length'; +export * from './validators/upcase-string'; +export * from './validators/uuid'; diff --git a/packages/rawmodel-validators/src/tests/index.test.ts b/packages/rawmodel-validators/src/tests/index.test.ts new file mode 100644 index 0000000..bbfe033 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/index.test.ts @@ -0,0 +1,31 @@ +import { Spec } from '@hayspec/spec'; +import * as validators from '..'; + +const spec = new Spec(); + +spec.test('exposed content', (t) => { + t.true(!!validators.absenceValidator); + t.true(!!validators.arrayExclusionValidator); + t.true(!!validators.arrayInclusionValidator); + t.true(!!validators.arrayLengthValidator); + t.true(!!validators.base64Validator); + t.true(!!validators.bsonObjectIdValidator); + t.true(!!validators.dateValidator); + t.true(!!validators.emailValidator); + t.true(!!validators.ethAddressValidator); + t.true(!!validators.fqdnValidator); + t.true(!!validators.hexColorValidator); + t.true(!!validators.hexValidator); + t.true(!!validators.jsonStringValidator); + t.true(!!validators.downcaseStringValidator); + t.true(!!validators.matchValidator); + t.true(!!validators.numberSizeValidator); + t.true(!!validators.presenceValidator); + t.true(!!validators.stringExclusionValidator); + t.true(!!validators.stringInclusionValidator); + t.true(!!validators.stringLengthValidator); + t.true(!!validators.upcaseStringValidator); + t.true(!!validators.uuidValidator); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/absence.test.ts b/packages/rawmodel-validators/src/tests/validators/absence.test.ts new file mode 100644 index 0000000..c9451b2 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/absence.test.ts @@ -0,0 +1,22 @@ +import { Spec } from '@hayspec/spec'; +import { absenceValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not blank', (ctx) => { + ctx.false(absenceValidator()('text')); +}); + +spec.test('passes when null', (ctx) => { + ctx.true(absenceValidator()(null)); +}); + +spec.test('passes when undefined', (ctx) => { + ctx.true(absenceValidator()()); +}); + +spec.test('passes when blank', (ctx) => { + ctx.true(absenceValidator()('')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/array-exclusion.test.ts b/packages/rawmodel-validators/src/tests/validators/array-exclusion.test.ts new file mode 100644 index 0000000..e1023b9 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/array-exclusion.test.ts @@ -0,0 +1,14 @@ +import { Spec } from '@hayspec/spec'; +import { arrayExclusionValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when included in the list', (t) => { + t.true(arrayExclusionValidator({ values: [false] })(true)); +}); + +spec.test('passes when not included in the list', (t) => { + t.false(arrayExclusionValidator({ values: [false, true] })(true)); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/array-inclusion.test.ts b/packages/rawmodel-validators/src/tests/validators/array-inclusion.test.ts new file mode 100644 index 0000000..c7560cd --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/array-inclusion.test.ts @@ -0,0 +1,14 @@ +import { Spec } from '@hayspec/spec'; +import { arrayInclusionValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not included in the list', (ctx) => { + ctx.false(arrayInclusionValidator({ values: [false] })(true)); +}); + +spec.test('passes when included in the list', (ctx) => { + ctx.true(arrayInclusionValidator({ values: [false, true] })(true)); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/array-length.test.ts b/packages/rawmodel-validators/src/tests/validators/array-length.test.ts new file mode 100644 index 0000000..b625484 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/array-length.test.ts @@ -0,0 +1,28 @@ +import { Spec } from '@hayspec/spec'; +import { arrayLengthValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not an array', (ctx) => { + ctx.false(arrayLengthValidator()(true)); +}); + +spec.test('fails when too small', (ctx) => { + ctx.false(arrayLengthValidator({ min: 3 })([1, 2])); +}); + +spec.test('fails when too large', (ctx) => { + ctx.false(arrayLengthValidator({ max: 2 })([1, 2, 3])); +}); + +spec.test('passes without options', (ctx) => { + ctx.true(arrayLengthValidator()([1, 2, 3])); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(arrayLengthValidator({ min: 2, max: 4 })([1, 2, 3])); + ctx.true(arrayLengthValidator({ minOrEqual: 2 })([1, 2])); + ctx.true(arrayLengthValidator({ maxOrEqual: 2 })([1, 2])); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/base64.test.ts b/packages/rawmodel-validators/src/tests/validators/base64.test.ts new file mode 100644 index 0000000..d8be3ee --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/base64.test.ts @@ -0,0 +1,36 @@ +import { Spec } from '@hayspec/spec'; +import { base64Validator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(base64Validator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(base64Validator()('1')); + ctx.false(base64Validator()('12345')); + ctx.false(base64Validator()('')); + ctx.false(base64Validator()('Vml2YW11cyBmZXJtZtesting123')); + ctx.false(base64Validator()('Zg=')); + ctx.false(base64Validator()('Z===')); + ctx.false(base64Validator()('Zm=8')); + ctx.false(base64Validator()('=m9vYg==')); + ctx.false(base64Validator()('Zm9vYmFy====')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(base64Validator()('Zg==')); + ctx.true(base64Validator()('Zm8=')); + ctx.true(base64Validator()('Zm9v')); + ctx.true(base64Validator()('Zm9vYg==')); + ctx.true(base64Validator()('Zm9vYmE=')); + ctx.true(base64Validator()('Zm9vYmFy')); + ctx.true(base64Validator()('dGVzdA==')); + ctx.true(base64Validator()('TG9yZW0gaXBzdW0gZG9sb3Igc2l0IGFtZXQsIGNvbnNlY3RldHVyIGFkaXBpc2NpbmcgZWxpdC4=')); + ctx.true(base64Validator()('Vml2YW11cyBmZXJtZW50dW0gc2VtcGVyIHBvcnRhLg==')); + ctx.true(base64Validator()('U3VzcGVuZGlzc2UgbGVjdHVzIGxlbw==')); + ctx.true(base64Validator()('MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuMPNS1Ufof9EW/M98FNwUAKrwflsqVxaxQjBQnHQmiI7Vac40t8x7pIb8gLGV6wL7sBTJiPovJ0V7y7oc0YerhKh0Rm4skP2z/jHwwZICgGzBvA0rH8xlhUiTvcwDCJ0kc+fh35hNt8srZQM4619FTgB66Xmp4EtVyhpQV+t02g6NzK72oZI0vnAvqhpkxLeLiMCyrI416wHm5TkukhxQmcL2a6hNOyu0ixX/x2kSFXApEnVrJ+/IxGyfyw8kf4N2IZpW5nEP847lpfj0SZZFwrd1mnfnDbYohX2zRptLy2ZUn06Qo9pkG5ntvFEPo9bfZeULtjYzIl6K8gJ2uGZHQIDAQAB')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/bson-object-id.test.ts b/packages/rawmodel-validators/src/tests/validators/bson-object-id.test.ts new file mode 100644 index 0000000..8f1db0f --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/bson-object-id.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { bsonObjectIdValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(bsonObjectIdValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(bsonObjectIdValidator()('507f1f77bcf86cd7994390')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(bsonObjectIdValidator()('507f1f77bcf86cd799439011')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/date.test.ts b/packages/rawmodel-validators/src/tests/validators/date.test.ts new file mode 100644 index 0000000..dbc67b4 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/date.test.ts @@ -0,0 +1,26 @@ +import { Spec } from '@hayspec/spec'; +import { dateValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(dateValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(dateValidator()('x')); +}); + +spec.test('fails when invalid iso8601', (ctx) => { + ctx.false(dateValidator({ iso: true })('12.12.2016')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(dateValidator()('2009')); +}); + +spec.test('passes when valid iso8601', (ctx) => { + ctx.true(dateValidator({ iso: true })('2009-12T12:34')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/downcase-string.test.ts b/packages/rawmodel-validators/src/tests/validators/downcase-string.test.ts new file mode 100644 index 0000000..2eb6c76 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/downcase-string.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { downcaseStringValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(downcaseStringValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(downcaseStringValidator()('Hello')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(downcaseStringValidator()('hello')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/email.test.ts b/packages/rawmodel-validators/src/tests/validators/email.test.ts new file mode 100644 index 0000000..58694ef --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/email.test.ts @@ -0,0 +1,41 @@ +import { Spec } from '@hayspec/spec'; +import { emailValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(emailValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(emailValidator()('john')); +}); + +spec.test('fails when display name', (ctx) => { + ctx.false(emailValidator()('John ')); +}); + +spec.test('fails with UTF8 characters', (ctx) => { + ctx.false(emailValidator()('šžćč@domain.com')); +}); + +spec.test('fails without top-level domain name', (ctx) => { + ctx.false(emailValidator()('john@domain')); +}); + +spec.test('fails without top-level domain name', (ctx) => { + ctx.true(emailValidator({ requireTld: false })('john@domain')); + ctx.false(emailValidator({ requireTld: true })('john@domain')); +}); + +spec.test('passes with display name when allowDisplayName is true', (ctx) => { + ctx.true(emailValidator({ allowDisplayName: true })('John ')); + ctx.false(emailValidator({ allowDisplayName: false })('John ')); +}); + +spec.test('passes with UTF8 characters when allowUtf8LocalPart is true', (ctx) => { + ctx.true(emailValidator({ allowUtf8LocalPart: true })('đšpŽĆČ@domain.com')); + ctx.false(emailValidator({ allowUtf8LocalPart: false })('đšpŽĆČ@domain.com')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/eth-address.test.ts b/packages/rawmodel-validators/src/tests/validators/eth-address.test.ts new file mode 100644 index 0000000..73a7444 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/eth-address.test.ts @@ -0,0 +1,22 @@ +import { Spec } from '@hayspec/spec'; +import { ethAddressValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(ethAddressValidator()(true)); +}); + +spec.test('fails on invalid address', (ctx) => { + ctx.false(ethAddressValidator()('domain')); + ctx.false(ethAddressValidator()('0x0')); +}); + +spec.test('passes on valid address', (ctx) => { + ctx.true(ethAddressValidator()('0x5aAeb6053F3E94C9b9A09f33669435E7Ef1BeAed')); + ctx.true(ethAddressValidator()('0xfB6916095ca1df60bB79Ce92cE3Ea74c37c5d359')); + ctx.true(ethAddressValidator()('0xdbF03B407c01E7cD3CBea99509d93f8DDDC8C6FB')); + ctx.true(ethAddressValidator()('0xD1220A0cf47c7B9Be7A2E6BA89F429762e7b9aDb')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/fqdn.test.ts b/packages/rawmodel-validators/src/tests/validators/fqdn.test.ts new file mode 100644 index 0000000..363751d --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/fqdn.test.ts @@ -0,0 +1,34 @@ +import { Spec } from '@hayspec/spec'; +import { fqdnValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(fqdnValidator()(true)); +}); + +spec.test('fails without top-level domain name', (ctx) => { + ctx.false(fqdnValidator()('domain')); +}); + +spec.test('fails when including underscore', (ctx) => { + ctx.false(fqdnValidator()('do_main.com')); +}); + +spec.test('fails when including trailing dot', (ctx) => { + ctx.false(fqdnValidator()('domain.com.')); +}); + +spec.test('passes with top-level domain name', (ctx) => { + ctx.true(fqdnValidator()('domain.com')); +}); + +spec.test('passes when including underscore where allowUnderscores is true', (ctx) => { + ctx.true(fqdnValidator({ allowUnderscores: true })('do_main.com')); +}); + +spec.test('passes when including trailing dot where allowTrailingDot is true', (ctx) => { + ctx.true(fqdnValidator({ allowTrailingDot: true })('domain.com.')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/hex-color.test.ts b/packages/rawmodel-validators/src/tests/validators/hex-color.test.ts new file mode 100644 index 0000000..f64441b --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/hex-color.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { hexColorValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(hexColorValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(hexColorValidator()('#ff')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(hexColorValidator()('#ff0034')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/hex.test.ts b/packages/rawmodel-validators/src/tests/validators/hex.test.ts new file mode 100644 index 0000000..e82d6ef --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/hex.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { hexValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(hexValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(hexValidator()('abcdefg')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(hexValidator()('ff0044')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/json-string.test.ts b/packages/rawmodel-validators/src/tests/validators/json-string.test.ts new file mode 100644 index 0000000..3d5aeb0 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/json-string.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { jsonStringValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(jsonStringValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(jsonStringValidator()('{key: "value"}')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(jsonStringValidator()('{"key": "value"}')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/match.test.ts b/packages/rawmodel-validators/src/tests/validators/match.test.ts new file mode 100644 index 0000000..855f539 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/match.test.ts @@ -0,0 +1,10 @@ +import { Spec } from '@hayspec/spec'; +import { matchValidator } from '../..'; + +const spec = new Spec(); + +spec.test('passes with a valid pattern', (ctx) => { + ctx.true(matchValidator({ regexp: /me/i })('me')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/number-size.test.ts b/packages/rawmodel-validators/src/tests/validators/number-size.test.ts new file mode 100644 index 0000000..bf39cba --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/number-size.test.ts @@ -0,0 +1,28 @@ +import { Spec } from '@hayspec/spec'; +import { numberSizeValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a number', (ctx) => { + ctx.false(numberSizeValidator()(true)); +}); + +spec.test('fails when too small', (ctx) => { + ctx.false(numberSizeValidator({ min: 200 })(100)); +}); + +spec.test('fails when too large', (ctx) => { + ctx.false(numberSizeValidator({ max: 20 })(100)); +}); + +spec.test('passes without options', (ctx) => { + ctx.true(numberSizeValidator()(100)); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(numberSizeValidator({ min: 10, max: 1000 })(100)); + ctx.true(numberSizeValidator({ minOrEqual: 100 })(100)); + ctx.true(numberSizeValidator({ maxOrEqual: 100 })(100)); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/presence.test.ts b/packages/rawmodel-validators/src/tests/validators/presence.test.ts new file mode 100644 index 0000000..25e59dd --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/presence.test.ts @@ -0,0 +1,22 @@ +import { Spec } from '@hayspec/spec'; +import { presenceValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when null', (ctx) => { + ctx.false(presenceValidator()(null)); +}); + +spec.test('fails when undefined', (ctx) => { + ctx.false(presenceValidator()()); +}); + +spec.test('fails when blank', (ctx) => { + ctx.false(presenceValidator()('')); +}); + +spec.test('passes when present', (ctx) => { + ctx.true(presenceValidator()('john')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/string-exclusion.test.ts b/packages/rawmodel-validators/src/tests/validators/string-exclusion.test.ts new file mode 100644 index 0000000..b7cedf7 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/string-exclusion.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { stringExclusionValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when a string', (ctx) => { + ctx.true(stringExclusionValidator({ seed: 'true' })(true)); +}); + +spec.test('fails when containing the provided seed', (ctx) => { + ctx.true(stringExclusionValidator({ seed: 'black' })('my fake2 description')); +}); + +spec.test('passes when not containing the provided seed', (ctx) => { + ctx.false(stringExclusionValidator({ seed: 'fake' })('my fake description')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/string-inclusion.test.ts b/packages/rawmodel-validators/src/tests/validators/string-inclusion.test.ts new file mode 100644 index 0000000..f2202d8 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/string-inclusion.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { stringInclusionValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(stringInclusionValidator({ seed: 'true' })(true)); +}); + +spec.test('fails when not containing the provided seed', (ctx) => { + ctx.false(stringInclusionValidator({ seed: 'black' })('my fake2 description')); +}); + +spec.test('passes when containing the provided seed', (ctx) => { + ctx.true(stringInclusionValidator({ seed: 'fake' })('my fake description')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/string-length.test.ts b/packages/rawmodel-validators/src/tests/validators/string-length.test.ts new file mode 100644 index 0000000..f86bddc --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/string-length.test.ts @@ -0,0 +1,29 @@ +import { Spec } from '@hayspec/spec'; +import { stringLengthValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(stringLengthValidator()(true)); +}); + +spec.test('fails when too short', (ctx) => { + ctx.false(stringLengthValidator({ min: 10 })('hello')); +}); + +spec.test('fails when too long', (ctx) => { + ctx.false(stringLengthValidator({ max: 2 })('hello')); +}); + +spec.test('passes without options', (ctx) => { + ctx.true(stringLengthValidator()('hello')); +}); + +spec.test('supports bytes length', (ctx) => { + ctx.false(stringLengthValidator({ bytes: true, max: 3 })('ašč')); + ctx.true(stringLengthValidator({ bytes: true, max: 6 })('ašč')); + ctx.true(stringLengthValidator({ minOrEqual: 3 })('ašč')); + ctx.true(stringLengthValidator({ maxOrEqual: 3 })('ašč')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/upcase-string.test.ts b/packages/rawmodel-validators/src/tests/validators/upcase-string.test.ts new file mode 100644 index 0000000..72d1eb6 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/upcase-string.test.ts @@ -0,0 +1,18 @@ +import { Spec } from '@hayspec/spec'; +import { upcaseStringValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(upcaseStringValidator()(true)); +}); + +spec.test('fails when invalid', (ctx) => { + ctx.false(upcaseStringValidator()('Hello')); +}); + +spec.test('passes when valid', (ctx) => { + ctx.true(upcaseStringValidator()('HELLO')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/tests/validators/uuid.test.ts b/packages/rawmodel-validators/src/tests/validators/uuid.test.ts new file mode 100644 index 0000000..0fe20e9 --- /dev/null +++ b/packages/rawmodel-validators/src/tests/validators/uuid.test.ts @@ -0,0 +1,35 @@ +import { Spec } from '@hayspec/spec'; +import { uuidValidator } from '../..'; + +const spec = new Spec(); + +spec.test('fails when not a string', (ctx) => { + ctx.false(uuidValidator()(true)); +}); + +spec.test('passes for valid v1', (ctx) => { + ctx.true(uuidValidator({ version: 1 })('857b3f0a-a777-11e5-bf7f-feff819cdc9f')); + ctx.true(uuidValidator({ version: 1 })('857b4504-a777-11e5-bf7f-feff819cdc9f')); +}); + +spec.test('passes for valid v2', (ctx) => { + ctx.true(uuidValidator({ version: 2 })('a14e3bb3-d7a3-2ea8-9481-881eaf75fdc5')); + ctx.true(uuidValidator({ version: 2 })('5a3c2348-6e2f-280e-aade-7dc8afdb18b9')); +}); + +spec.test('passes for valid v3', (ctx) => { + ctx.true(uuidValidator({ version: 3 })('49072879-c5c6-3b4e-9900-34e5df285522')); + ctx.true(uuidValidator({ version: 3 })('5a3c2348-6e2f-380e-aade-7dc8afdb18b9')); +}); + +spec.test('passes for valid v4', (ctx) => { + ctx.true(uuidValidator({ version: 4 })('82ca85b8-7841-42f0-80d8-48bbe11a005b')); + ctx.true(uuidValidator({ version: 4 })('58dbb3a5-a95a-4120-b4e0-483eea26ab74')); +}); + +spec.test('passes for valid v5', (ctx) => { + ctx.true(uuidValidator({ version: 5 })('482d11be-b03f-5ff3-b99d-9b6ceef18874')); + ctx.true(uuidValidator({ version: 5 })('6a5b4d3f-02cf-5e2d-89d5-2f2163bb69f9')); +}); + +export default spec; diff --git a/packages/rawmodel-validators/src/validators/absence.ts b/packages/rawmodel-validators/src/validators/absence.ts new file mode 100644 index 0000000..e7163fb --- /dev/null +++ b/packages/rawmodel-validators/src/validators/absence.ts @@ -0,0 +1,10 @@ +import { isPresent } from '@rawmodel/utils/dist/helpers/is-present'; + +/** + * Returns a function for detecting empty values. + */ +export function absenceValidator() { + return (value?: any) => { + return !isPresent(value); + }; +} diff --git a/packages/rawmodel-validators/src/validators/array-exclusion.ts b/packages/rawmodel-validators/src/validators/array-exclusion.ts new file mode 100644 index 0000000..af31a17 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/array-exclusion.ts @@ -0,0 +1,12 @@ +import { arrayInclusionValidator } from './array-inclusion'; + +/** + * Returns a function for detecting values that do not exist in the array. + */ +export function arrayExclusionValidator(options: { + values?: any[]; +} = {}) { + return (value?: any) => { + return !arrayInclusionValidator(options)(value); + }; +} diff --git a/packages/rawmodel-validators/src/validators/array-inclusion.ts b/packages/rawmodel-validators/src/validators/array-inclusion.ts new file mode 100644 index 0000000..2da5538 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/array-inclusion.ts @@ -0,0 +1,18 @@ +import { isArray } from '@rawmodel/utils/dist/helpers/is-array'; + +/** + * Returns a function for detecting values that exist in the array. + */ +export function arrayInclusionValidator(options: { + values?: any[]; +} = {}) { + return (value?: any) => { + const { values } = options; + + if (!isArray(values)) { + return false; + } + + return values.indexOf(value) !== -1; + }; +} diff --git a/packages/rawmodel-validators/src/validators/array-length.ts b/packages/rawmodel-validators/src/validators/array-length.ts new file mode 100644 index 0000000..f382584 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/array-length.ts @@ -0,0 +1,36 @@ +import { isArray } from '@rawmodel/utils/dist/helpers/is-array'; +import { isNumber } from '@rawmodel/utils/dist/helpers/is-number'; + +/** + * Returns a function for detecting array size. + */ +export function arrayLengthValidator(options: { + min?: number; + minOrEqual?: number; + max?: number; + maxOrEqual?: number; +} = {}) { + return (value?: any) => { + + if (!isArray(value)) { + return false; + } + + const size = value.length; + const { min, minOrEqual, max, maxOrEqual } = options; + if (isNumber(min) && !(size > min)) { + return false; + } + if (isNumber(minOrEqual) && !(size >= minOrEqual)) { + return false; + } + if (isNumber(max) && !(size < max)) { + return false; + } + if (isNumber(maxOrEqual) && !(size <= maxOrEqual)) { + return false; + } + + return true; + }; +} diff --git a/packages/rawmodel-validators/src/validators/base64.ts b/packages/rawmodel-validators/src/validators/base64.ts new file mode 100644 index 0000000..8680c50 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/base64.ts @@ -0,0 +1,17 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +const BASE64_REGEX = /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=|[A-Za-z0-9+/]{4})$/; + +/** + * Returns a function for detecting base64 strings. + */ +export function base64Validator() { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + return BASE64_REGEX.test(value); + }; +} diff --git a/packages/rawmodel-validators/src/validators/bson-object-id.ts b/packages/rawmodel-validators/src/validators/bson-object-id.ts new file mode 100644 index 0000000..3840045 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/bson-object-id.ts @@ -0,0 +1,17 @@ +import { toString } from '@rawmodel/utils/dist/helpers/to-string'; +import { hexValidator } from './hex'; + +/** + * Returns a function for detecting BSON ObjectId objects. + */ +export function bsonObjectIdValidator() { + return (value?: any) => { + + value = toString(value); + + return ( + hexValidator()(value) + && value.length === 24 + ); + }; +} diff --git a/packages/rawmodel-validators/src/validators/date.ts b/packages/rawmodel-validators/src/validators/date.ts new file mode 100644 index 0000000..f46509f --- /dev/null +++ b/packages/rawmodel-validators/src/validators/date.ts @@ -0,0 +1,27 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +const ISO8601_REGEX = /^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-2])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T\s]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/; + +/** + * Returns a function for detecting date values. + */ +export function dateValidator(recipe: { + iso?: boolean; +} = {}) { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + const date = Date.parse(value); + if (!date) return false; + + const { iso } = recipe; + if (iso) { + return ISO8601_REGEX.test(value); + } + + return true; + }; +} diff --git a/packages/rawmodel-validators/src/validators/downcase-string.ts b/packages/rawmodel-validators/src/validators/downcase-string.ts new file mode 100644 index 0000000..010224b --- /dev/null +++ b/packages/rawmodel-validators/src/validators/downcase-string.ts @@ -0,0 +1,15 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting lower cased strings. + */ +export function downcaseStringValidator() { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + return value === value.toLowerCase(); + }; +} diff --git a/packages/rawmodel-validators/src/validators/email.ts b/packages/rawmodel-validators/src/validators/email.ts new file mode 100644 index 0000000..3f15930 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/email.ts @@ -0,0 +1,64 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; +import { fqdnValidator } from './fqdn'; +import { stringLengthValidator } from './string-length'; + +const DISPLAY_NAME_REGEX = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~\.\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~\.\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF\s]*<(.+)>$/i; +const EMAIL_USER_REGEX = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~]+$/i; +const QUOTED_EMAIL_USER_REGEX = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f]))*$/i; +const EMAIL_USER_UTF8_REGEX = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+$/i; +const QUOTED_EMAIL_USER_UTF8_REGEX = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))*$/i; + +/** + * Returns a function for detecting email strings. + */ +export function emailValidator(recipe: { + allowDisplayName?: boolean; + allowUtf8LocalPart?: boolean; + requireTld?: boolean; +} = {}) { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + const { allowDisplayName = false, allowUtf8LocalPart = false, requireTld = true } = recipe; + if (allowDisplayName) { + const displayEmail = value.match(DISPLAY_NAME_REGEX); + if (displayEmail) { + value = displayEmail[1]; + } + } + + const parts = value.split('@'); + const domain = parts.pop(); + let user = parts.join('@'); + const lowerDomain = domain.toLowerCase(); + if (lowerDomain === 'gmail.com' || lowerDomain === 'googlemail.com') { + user = user.replace(/\./g, '').toLowerCase(); + } + + if (!stringLengthValidator({ bytes: true, max: 64 })(user) || !stringLengthValidator({ bytes: true, max: 256 })(domain)) { + return false; + } else if (!fqdnValidator({ requireTld })(domain)) { + return false; + } else if (user[0] === '"') { + user = user.slice(1, user.length - 1); + return allowUtf8LocalPart + ? QUOTED_EMAIL_USER_UTF8_REGEX.test(user) + : QUOTED_EMAIL_USER_REGEX.test(user); + } + + const pattern = allowUtf8LocalPart + ? EMAIL_USER_UTF8_REGEX + : EMAIL_USER_REGEX; + const userParts = user.split('.'); + for (let i = 0; i < userParts.length; i++) { + if (!pattern.test(userParts[i])) { + return false; + } + } + + return true; + }; +} diff --git a/packages/rawmodel-validators/src/validators/eth-address.ts b/packages/rawmodel-validators/src/validators/eth-address.ts new file mode 100644 index 0000000..fdafacb --- /dev/null +++ b/packages/rawmodel-validators/src/validators/eth-address.ts @@ -0,0 +1,15 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting Ethereum address. + */ +export function ethAddressValidator() { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + return /^0x[a-fA-F0-9]{40}$/i.test(value); + }; +} diff --git a/packages/rawmodel-validators/src/validators/fqdn.ts b/packages/rawmodel-validators/src/validators/fqdn.ts new file mode 100644 index 0000000..e672b75 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/fqdn.ts @@ -0,0 +1,55 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting domain names. + */ +export function fqdnValidator(options: { + requireTld?: boolean; + allowUnderscores?: boolean; + allowTrailingDot?: boolean; +} = {}) { + return (value?: any) => { + + const { requireTld = true, allowUnderscores = false, allowTrailingDot = false } = options; + + if (!isString(value)) { + return false; + } + + if (allowTrailingDot && value[value.length - 1] === '.') { + value = value.substring(0, value.length - 1); + } + + const parts = value.split('.'); + + if (requireTld) { + const tld = parts.pop(); + + if (!parts.length || !/^([a-z\u00a1-\uffff]{2,}|xn[a-z0-9-]{2,})$/i.test(tld)) { + return false; + } + } + + for (let part, i = 0; i < parts.length; i++) { + part = parts[i]; + + if (allowUnderscores) { + if (part.indexOf('__') >= 0) { + return false; + } else { + part = part.replace(/_/g, ''); + } + } + + if (!/^[a-z\u00a1-\uffff0-9-]+$/i.test(part)) { + return false; + } else if (/[\uff01-\uff5e]/.test(part)) { + return false; // disallow full-width chars + } else if (part[0] === '-' || part[part.length - 1] === '-') { + return false; + } + } + + return true; + }; +} diff --git a/packages/rawmodel-validators/src/validators/hex-color.ts b/packages/rawmodel-validators/src/validators/hex-color.ts new file mode 100644 index 0000000..335e705 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/hex-color.ts @@ -0,0 +1,15 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting hexadecimal colors. + */ +export function hexColorValidator() { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + return /^#?([0-9A-F]{3}|[0-9A-F]{6})$/i.test(value); + }; +} diff --git a/packages/rawmodel-validators/src/validators/hex.ts b/packages/rawmodel-validators/src/validators/hex.ts new file mode 100644 index 0000000..f840589 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/hex.ts @@ -0,0 +1,15 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting hexadecimal values. + */ +export function hexValidator() { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + return /^[0-9A-F]+$/i.test(value); + }; +} diff --git a/packages/rawmodel-validators/src/validators/json-string.ts b/packages/rawmodel-validators/src/validators/json-string.ts new file mode 100644 index 0000000..90b3547 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/json-string.ts @@ -0,0 +1,19 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting JSON strings. + */ +export function jsonStringValidator() { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + try { + const obj = JSON.parse(value); + return !!obj && typeof obj === 'object'; + } catch (e) {} + return false; + }; +} diff --git a/packages/rawmodel-validators/src/validators/match.ts b/packages/rawmodel-validators/src/validators/match.ts new file mode 100644 index 0000000..de3e59b --- /dev/null +++ b/packages/rawmodel-validators/src/validators/match.ts @@ -0,0 +1,18 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting values based on regular expressions. + */ +export function matchValidator(options: { + regexp?: RegExp; +} = {}) { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + const { regexp } = options; + return regexp.test(value); + }; +} diff --git a/packages/rawmodel-validators/src/validators/number-size.ts b/packages/rawmodel-validators/src/validators/number-size.ts new file mode 100644 index 0000000..e4ec2e1 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/number-size.ts @@ -0,0 +1,34 @@ +import { isNumber } from '@rawmodel/utils'; + +/** + * Returns a function for detecting number size. + */ +export function numberSizeValidator(options: { + min?: number; + minOrEqual?: number; + max?: number; + maxOrEqual?: number; +} = {}) { + return (value?: any) => { + + if (!isNumber(value)) { + return false; + } + + const { min, minOrEqual, max, maxOrEqual } = options; + if (isNumber(min) && !(value > min)) { + return false; + } + if (isNumber(minOrEqual) && !(value >= minOrEqual)) { + return false; + } + if (isNumber(max) && !(value < max)) { + return false; + } + if (isNumber(maxOrEqual) && !(value <= maxOrEqual)) { + return false; + } + + return true; + }; +} diff --git a/packages/rawmodel-validators/src/validators/presence.ts b/packages/rawmodel-validators/src/validators/presence.ts new file mode 100644 index 0000000..7286696 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/presence.ts @@ -0,0 +1,8 @@ +import { isPresent } from '@rawmodel/utils/dist/helpers/is-present'; + +/** + * Returns a function for detecting if the value exists. + */ +export function presenceValidator() { + return (value?: any) => isPresent(value); +} diff --git a/packages/rawmodel-validators/src/validators/string-exclusion.ts b/packages/rawmodel-validators/src/validators/string-exclusion.ts new file mode 100644 index 0000000..f965fe6 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/string-exclusion.ts @@ -0,0 +1,10 @@ +import { stringInclusionValidator } from './string-inclusion'; + +/** + * Returns a function for detecting words that do not exist in a string. + */ +export function stringExclusionValidator(options: { + seed?: string; +}) { + return (value?: any) => !stringInclusionValidator(options)(value); +} diff --git a/packages/rawmodel-validators/src/validators/string-inclusion.ts b/packages/rawmodel-validators/src/validators/string-inclusion.ts new file mode 100644 index 0000000..99ab78c --- /dev/null +++ b/packages/rawmodel-validators/src/validators/string-inclusion.ts @@ -0,0 +1,19 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; +import { toString } from '@rawmodel/utils/dist/helpers/to-string'; + +/** + * Returns a function for detecting words that exist in a string. + */ +export function stringInclusionValidator(options: { + seed?: string; +} = {}) { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + const { seed } = options; + return value.indexOf(toString(seed)) >= 0; + }; +} diff --git a/packages/rawmodel-validators/src/validators/string-length.ts b/packages/rawmodel-validators/src/validators/string-length.ts new file mode 100644 index 0000000..0af39b9 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/string-length.ts @@ -0,0 +1,38 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; +import { isNumber } from '@rawmodel/utils/dist/helpers/is-number'; + +/** + * Returns a function for detecting string length. + */ +export function stringLengthValidator(recipe: { + bytes?: boolean; + min?: number; + minOrEqual?: number; + max?: number; + maxOrEqual?: number; +} = {}) { + return (value?: any) => { + + if (!isString(value)) return false; + + const { bytes = false, min, minOrEqual, max, maxOrEqual } = recipe; + const len = bytes + ? encodeURI(value).split(/%..|./).length - 1 + : value.length; + + if (isNumber(min) && !(len > min)) { + return false; + } + if (isNumber(minOrEqual) && !(len >= minOrEqual)) { + return false; + } + if (isNumber(max) && !(len < max)) { + return false; + } + if (isNumber(maxOrEqual) && !(len <= maxOrEqual)) { + return false; + } + + return true; + }; +} diff --git a/packages/rawmodel-validators/src/validators/upcase-string.ts b/packages/rawmodel-validators/src/validators/upcase-string.ts new file mode 100644 index 0000000..45a3462 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/upcase-string.ts @@ -0,0 +1,15 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +/** + * Returns a function for detecting uppercased string. + */ +export function upcaseStringValidator() { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + return value === value.toUpperCase(); + }; +} diff --git a/packages/rawmodel-validators/src/validators/uuid.ts b/packages/rawmodel-validators/src/validators/uuid.ts new file mode 100644 index 0000000..8682e62 --- /dev/null +++ b/packages/rawmodel-validators/src/validators/uuid.ts @@ -0,0 +1,43 @@ +import { isString } from '@rawmodel/utils/dist/helpers/is-string'; + +const V1_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[1][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i; +const V2_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[2][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i; +const V3_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[3][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i; +const V4_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i; +const V5_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i; + +/** + * Returns a function for detecting UUID values. + */ +export function uuidValidator(recipe: { + version?: number; +} = {}) { + return (value?: any) => { + + if (!isString(value)) { + return false; + } + + const { version } = recipe; + switch (version) { + case 1: + return V1_REGEX.test(value); + case 2: + return V2_REGEX.test(value); + case 3: + return V3_REGEX.test(value); + case 4: + return V4_REGEX.test(value); + case 5: + return V5_REGEX.test(value); + } + + return ( + V1_REGEX.test(value) + || V2_REGEX.test(value) + || V3_REGEX.test(value) + || V4_REGEX.test(value) + || V5_REGEX.test(value) + ); + }; +} diff --git a/packages/rawmodel-validators/tsconfig.json b/packages/rawmodel-validators/tsconfig.json new file mode 100644 index 0000000..dbc05f7 --- /dev/null +++ b/packages/rawmodel-validators/tsconfig.json @@ -0,0 +1,13 @@ +{ + "compilerOptions": { + "module": "commonjs", + "target": "es5", + "noImplicitAny": false, + "removeComments": true, + "sourceMap": true, + "outDir": "dist", + "declaration": true, + "experimentalDecorators": true, + "lib": ["es2015.promise", "es2015.iterable", "es5"] + } +} diff --git a/packages/rawmodel-validators/tslint.json b/packages/rawmodel-validators/tslint.json new file mode 100644 index 0000000..88f5b48 --- /dev/null +++ b/packages/rawmodel-validators/tslint.json @@ -0,0 +1,60 @@ +{ + "rules": { + "class-name": true, + "comment-format": [ + true, + "check-space" + ], + "indent": [ + true, + "spaces" + ], + "one-line": [ + true, + "check-open-brace", + "check-whitespace" + ], + "no-var-keyword": true, + "quotemark": [ + true, + "single", + "avoid-escape" + ], + "semicolon": [ + true, + "always", + "ignore-bound-class-methods" + ], + "whitespace": [ + true, + "check-branch", + "check-decl", + "check-operator", + "check-module", + "check-separator", + "check-type" + ], + "typedef-whitespace": [ + true, + { + "call-signature": "nospace", + "index-signature": "nospace", + "parameter": "nospace", + "property-declaration": "nospace", + "variable-declaration": "nospace" + }, + { + "call-signature": "onespace", + "index-signature": "onespace", + "parameter": "onespace", + "property-declaration": "onespace", + "variable-declaration": "onespace" + } + ], + "no-internal-module": true, + "no-trailing-whitespace": true, + "no-null-keyword": false, + "prefer-const": true, + "jsdoc-format": true + } +}