├── .gitignore ├── .travis.yml ├── LICENSE ├── README.MD ├── example ├── .gitignore ├── LICENSE ├── README.md ├── package-lock.json ├── package.json └── src │ ├── App.js │ └── schema │ ├── resolvers │ ├── index.js │ └── user.js │ └── schema.gql ├── greenkeeper.json ├── index.js ├── lib ├── index.js └── mockBuilder.js ├── logo.png ├── package-lock.json ├── package.json ├── test ├── arrMockBuilderSchemas.js ├── boolean.js ├── mockBuilder.js ├── mockBuilderSchemaJS.js ├── multiplesSchemas.js ├── number.js ├── schema-js │ ├── index.js │ ├── mutations │ │ └── createUser.js │ ├── queries │ │ └── getUser.js │ └── types │ │ └── userType.js ├── schema │ ├── invalidSchema.gql │ ├── location.gql │ ├── schema.gql │ ├── school.gql │ └── student.gql └── string.js └── util ├── constants.js ├── customMock.js ├── index.js ├── randomData ├── boolean.js ├── number.js └── string.js └── utils.js /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .vscode 3 | .npmignore 4 | .nyc_output 5 | .DS_Store 6 | demo -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | sudo: false 3 | node_js: 4 | - 8 5 | 6 | install: 7 | - npm install 8 | script: 9 | - npm run standard 10 | - npm test 11 | after_success: 12 | - npm run coveralls 13 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | ###The MIT License 2 | 3 | Copyright (c) 2018 EasyGraphQL 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. -------------------------------------------------------------------------------- /README.MD: -------------------------------------------------------------------------------- 1 |

2 | EasyGraphQL Mock 3 |
4 | easygraphql-mock 5 |
6 |
7 |

8 | 9 | [![Coverage Status](https://coveralls.io/repos/github/EasyGraphQL/easygraphql-mock/badge.svg?branch=master)](https://coveralls.io/github/EasyGraphQL/easygraphql-mock?branch=master) [![Greenkeeper badge](https://badges.greenkeeper.io/EasyGraphQL/easygraphql-mock.svg)](https://greenkeeper.io/) 10 | 11 | `easygraphql-mock` is a node library used to create mocks of a schema. 12 | It will create mocks of all the types that are on the GraphQL Schema, including the nested types. 13 | 14 | ## Installation 15 | 16 | To install the package on your project just run on the root of your project 17 | ```shell 18 | $ npm install easygraphql-mock --save 19 | ``` 20 | 21 | ## How to use it? 22 | 23 | + Import [`easygraphql-mock`](https://github.com/EasyGraphQL/easygraphql-mock) package. 24 | + Read the schema. 25 | + Initialize the mock, and pass the schema as the first argument. 26 | + If there are multiples schemas pass an array with the schemas an argument. 27 | + **Note**: In order to use multiples schema files, the queries and mutations must be extended. 28 | + The second argument is optional and it is going to be your custom schema, in case you want to pass it. 29 | 30 | *In case you have a custom scalar, set it on the second argument, if it's not set it will be {}* 31 | 32 | ### One schema file 33 | ```js 34 | 'use strict' 35 | 36 | const easygraphqlMock = require('easygraphql-mock') 37 | const fs = require('fs') 38 | const path = require('path') 39 | 40 | const userSchema = fs.readFileSync(path.join(__dirname, 'schema', 'user.gql'), 'utf8') 41 | 42 | const mockedSchema = easygraphqlMock(userSchema) 43 | ``` 44 | 45 | ### Multiples schemas files 46 | ```js 47 | 'use strict' 48 | 49 | const easygraphqlMock = require('easygraphql-mock') 50 | const fs = require('fs') 51 | const path = require('path') 52 | 53 | const userSchema = fs.readFileSync(path.join(__dirname, 'schema', 'user.gql'), 'utf8') 54 | const familySchema = fs.readFileSync(path.join(__dirname, 'schema', 'family.gql'), 'utf8') 55 | 56 | const mockedSchema = easygraphqlMock([userSchema, familySchema]) 57 | ``` 58 | 59 | ### Custom schema 60 | You can set some values to the fields that you want on the schema. To do that, you might pass an object as a second argument. 61 | It must have the same name of the type and the field that you want to set. 62 | 63 | ```js 64 | 'use strict' 65 | 66 | const easygraphqlMock = require('easygraphql-mock') 67 | const fs = require('fs') 68 | const path = require('path') 69 | 70 | const userSchema = fs.readFileSync(path.join(__dirname, 'schema', 'user.gql'), 'utf8') 71 | const familySchema = fs.readFileSync(path.join(__dirname, 'schema', 'family.gql'), 'utf8') 72 | 73 | const mockedSchema = easygraphqlMock([userSchema, familySchema], { 74 | CustomScalarDate: '2018-10-10', 75 | Family: { 76 | name: 'Super test 1', 77 | ages: [10], 78 | familyRelation: 'Mother', 79 | familyRelationArr: ['Mother', 'Brother'] 80 | } 81 | }) 82 | ``` 83 | 84 | ### Result 85 | Here is the result of `mockedSchema.Family` 86 | 87 | ```js 88 | { 89 | name: 'Super test 1', 90 | ages: [ 10 ], 91 | createdAt: '2018-10-10', 92 | user: { 93 | email: 'ulalilid@herem.gl', 94 | username: 'tNfwN', 95 | fullName: 'Nathan Lewis', 96 | phone: '(231) 616-1744', 97 | family: { 98 | name: 'Super test 1', 99 | ages: [ 10 ], 100 | user: { 101 | email: 'ulalilid@herem.gl', 102 | username: 'tNfwN', 103 | fullName: 'Nathan Lewis', 104 | phone: '(231) 616-1744', 105 | family: '...' 106 | }, 107 | familyRelation: 'Mother', 108 | familyRelationArr: [ 'Mother', 'Brother' ] 109 | } 110 | }, 111 | familyRelation: 'Mother', 112 | familyRelationArr: [ 'Mother', 'Brother' ] 113 | } 114 | ``` 115 | 116 | ## Demo 117 | Here is a [Demo](https://github.com/EasyGraphQL/easygraphql-mock-demo) that can be useful! 118 | 119 | # License 120 | ### The MIT License 121 | 122 | Copyright (c) 2018 EasyGraphQL 123 | 124 | Permission is hereby granted, free of charge, to any person obtaining a copy 125 | of this software and associated documentation files (the "Software"), to deal 126 | in the Software without restriction, including without limitation the rights 127 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 128 | copies of the Software, and to permit persons to whom the Software is 129 | furnished to do so, subject to the following conditions: 130 | 131 | The above copyright notice and this permission notice shall be included in 132 | all copies or substantial portions of the Software. 133 | 134 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 135 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 136 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 137 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 138 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 139 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 140 | THE SOFTWARE. -------------------------------------------------------------------------------- /example/.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .vscode -------------------------------------------------------------------------------- /example/LICENSE: -------------------------------------------------------------------------------- 1 | ###The MIT License 2 | 3 | Copyright (c) 2018 EasyGraphQL 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. -------------------------------------------------------------------------------- /example/README.md: -------------------------------------------------------------------------------- 1 |

2 | EasyGraphQL Mock 3 |
4 | EasyGraphQL Mock Demo 5 |
6 |
7 |

8 | 9 | This is a demo of `easygraphql-mock`. 10 | 11 | To run the demo yourself, git clone the repo and then 12 | ```bash 13 | $ npm install 14 | $ npm start 15 | ``` 16 | Point your browser at http://localhost:7000 to see the demo. 17 | 18 | # License 19 | ### The MIT License 20 | 21 | Copyright (c) 2018 EasyGraphQL 22 | 23 | Permission is hereby granted, free of charge, to any person obtaining a copy 24 | of this software and associated documentation files (the "Software"), to deal 25 | in the Software without restriction, including without limitation the rights 26 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 27 | copies of the Software, and to permit persons to whom the Software is 28 | furnished to do so, subject to the following conditions: 29 | 30 | The above copyright notice and this permission notice shall be included in 31 | all copies or substantial portions of the Software. 32 | 33 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 34 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 35 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 36 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 37 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 38 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 39 | THE SOFTWARE. 40 | -------------------------------------------------------------------------------- /example/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "easygqlmock-demo", 3 | "version": "0.0.2", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "accepts": { 8 | "version": "1.3.5", 9 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", 10 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", 11 | "requires": { 12 | "mime-types": "2.1.21", 13 | "negotiator": "0.6.1" 14 | } 15 | }, 16 | "acorn": { 17 | "version": "6.0.4", 18 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.0.4.tgz", 19 | "integrity": "sha512-VY4i5EKSKkofY2I+6QLTbTTN/UvEQPCo6eiwzzSaSWfpaDhOmStMCMod6wmuPciNq+XS0faCglFu2lHZpdHUtg==", 20 | "dev": true 21 | }, 22 | "acorn-jsx": { 23 | "version": "5.0.0", 24 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.0.tgz", 25 | "integrity": "sha512-XkB50fn0MURDyww9+UYL3c1yLbOBz0ZFvrdYlGB8l+Ije1oSC75qAqrzSPjYQbdnQUzhlUGNKuesryAv0gxZOg==", 26 | "dev": true 27 | }, 28 | "ajv": { 29 | "version": "6.5.5", 30 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.5.5.tgz", 31 | "integrity": "sha512-7q7gtRQDJSyuEHjuVgHoUa2VuemFiCMrfQc9Tc08XTAc4Zj/5U1buQJ0HU6i7fKjXU09SVgSmxa4sLvuvS8Iyg==", 32 | "dev": true, 33 | "requires": { 34 | "fast-deep-equal": "2.0.1", 35 | "fast-json-stable-stringify": "2.0.0", 36 | "json-schema-traverse": "0.4.1", 37 | "uri-js": "4.2.2" 38 | } 39 | }, 40 | "ajv-keywords": { 41 | "version": "3.2.0", 42 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.2.0.tgz", 43 | "integrity": "sha1-6GuBnGAs+IIa1jdBNpjx3sAhhHo=", 44 | "dev": true 45 | }, 46 | "ansi-escapes": { 47 | "version": "3.1.0", 48 | "resolved": "http://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", 49 | "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", 50 | "dev": true 51 | }, 52 | "ansi-regex": { 53 | "version": "2.1.1", 54 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 55 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 56 | "dev": true 57 | }, 58 | "ansi-styles": { 59 | "version": "2.2.1", 60 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 61 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 62 | "dev": true 63 | }, 64 | "argparse": { 65 | "version": "1.0.10", 66 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 67 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 68 | "dev": true, 69 | "requires": { 70 | "sprintf-js": "1.0.3" 71 | } 72 | }, 73 | "array-flatten": { 74 | "version": "1.1.1", 75 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 76 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 77 | }, 78 | "array-includes": { 79 | "version": "3.0.3", 80 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 81 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 82 | "dev": true, 83 | "requires": { 84 | "define-properties": "1.1.3", 85 | "es-abstract": "1.12.0" 86 | } 87 | }, 88 | "array-union": { 89 | "version": "1.0.2", 90 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 91 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 92 | "dev": true, 93 | "requires": { 94 | "array-uniq": "1.0.3" 95 | } 96 | }, 97 | "array-uniq": { 98 | "version": "1.0.3", 99 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 100 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 101 | "dev": true 102 | }, 103 | "babel-code-frame": { 104 | "version": "6.26.0", 105 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 106 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 107 | "dev": true, 108 | "requires": { 109 | "chalk": "1.1.3", 110 | "esutils": "2.0.2", 111 | "js-tokens": "3.0.2" 112 | }, 113 | "dependencies": { 114 | "chalk": { 115 | "version": "1.1.3", 116 | "resolved": "http://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 117 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 118 | "dev": true, 119 | "requires": { 120 | "ansi-styles": "2.2.1", 121 | "escape-string-regexp": "1.0.5", 122 | "has-ansi": "2.0.0", 123 | "strip-ansi": "3.0.1", 124 | "supports-color": "2.0.0" 125 | } 126 | }, 127 | "strip-ansi": { 128 | "version": "3.0.1", 129 | "resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 130 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 131 | "dev": true, 132 | "requires": { 133 | "ansi-regex": "2.1.1" 134 | } 135 | } 136 | } 137 | }, 138 | "balanced-match": { 139 | "version": "1.0.0", 140 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 141 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 142 | "dev": true 143 | }, 144 | "body-parser": { 145 | "version": "1.18.3", 146 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz", 147 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=", 148 | "requires": { 149 | "bytes": "3.0.0", 150 | "content-type": "1.0.4", 151 | "debug": "2.6.9", 152 | "depd": "1.1.2", 153 | "http-errors": "1.6.3", 154 | "iconv-lite": "0.4.23", 155 | "on-finished": "2.3.0", 156 | "qs": "6.5.2", 157 | "raw-body": "2.3.3", 158 | "type-is": "1.6.16" 159 | } 160 | }, 161 | "brace-expansion": { 162 | "version": "1.1.11", 163 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 164 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 165 | "dev": true, 166 | "requires": { 167 | "balanced-match": "1.0.0", 168 | "concat-map": "0.0.1" 169 | } 170 | }, 171 | "builtin-modules": { 172 | "version": "1.1.1", 173 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 174 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 175 | "dev": true 176 | }, 177 | "bytes": { 178 | "version": "3.0.0", 179 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 180 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 181 | }, 182 | "caller-path": { 183 | "version": "0.1.0", 184 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", 185 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", 186 | "dev": true, 187 | "requires": { 188 | "callsites": "0.2.0" 189 | } 190 | }, 191 | "callsites": { 192 | "version": "0.2.0", 193 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", 194 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", 195 | "dev": true 196 | }, 197 | "chalk": { 198 | "version": "2.4.1", 199 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 200 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 201 | "dev": true, 202 | "requires": { 203 | "ansi-styles": "3.2.1", 204 | "escape-string-regexp": "1.0.5", 205 | "supports-color": "5.5.0" 206 | }, 207 | "dependencies": { 208 | "ansi-styles": { 209 | "version": "3.2.1", 210 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 211 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 212 | "dev": true, 213 | "requires": { 214 | "color-convert": "1.9.3" 215 | } 216 | }, 217 | "supports-color": { 218 | "version": "5.5.0", 219 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 220 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 221 | "dev": true, 222 | "requires": { 223 | "has-flag": "3.0.0" 224 | } 225 | } 226 | } 227 | }, 228 | "chardet": { 229 | "version": "0.4.2", 230 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.4.2.tgz", 231 | "integrity": "sha1-tUc7M9yXxCTl2Y3IfVXU2KKci/I=", 232 | "dev": true 233 | }, 234 | "circular-json": { 235 | "version": "0.3.3", 236 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", 237 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", 238 | "dev": true 239 | }, 240 | "cli-cursor": { 241 | "version": "2.1.0", 242 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 243 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 244 | "dev": true, 245 | "requires": { 246 | "restore-cursor": "2.0.0" 247 | } 248 | }, 249 | "cli-width": { 250 | "version": "2.2.0", 251 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 252 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 253 | "dev": true 254 | }, 255 | "color-convert": { 256 | "version": "1.9.3", 257 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 258 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 259 | "dev": true, 260 | "requires": { 261 | "color-name": "1.1.3" 262 | } 263 | }, 264 | "color-name": { 265 | "version": "1.1.3", 266 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 267 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 268 | "dev": true 269 | }, 270 | "concat-map": { 271 | "version": "0.0.1", 272 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 273 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 274 | "dev": true 275 | }, 276 | "contains-path": { 277 | "version": "0.1.0", 278 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 279 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 280 | "dev": true 281 | }, 282 | "content-disposition": { 283 | "version": "0.5.2", 284 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 285 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 286 | }, 287 | "content-type": { 288 | "version": "1.0.4", 289 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 290 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 291 | }, 292 | "cookie": { 293 | "version": "0.3.1", 294 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 295 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 296 | }, 297 | "cookie-signature": { 298 | "version": "1.0.6", 299 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 300 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 301 | }, 302 | "cross-spawn": { 303 | "version": "6.0.5", 304 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 305 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 306 | "dev": true, 307 | "requires": { 308 | "nice-try": "1.0.5", 309 | "path-key": "2.0.1", 310 | "semver": "5.6.0", 311 | "shebang-command": "1.2.0", 312 | "which": "1.3.1" 313 | } 314 | }, 315 | "debug": { 316 | "version": "2.6.9", 317 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 318 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 319 | "requires": { 320 | "ms": "2.0.0" 321 | } 322 | }, 323 | "debug-log": { 324 | "version": "1.0.1", 325 | "resolved": "https://registry.npmjs.org/debug-log/-/debug-log-1.0.1.tgz", 326 | "integrity": "sha1-IwdjLUwEOCuN+KMvcLiVBG1SdF8=", 327 | "dev": true 328 | }, 329 | "deep-is": { 330 | "version": "0.1.3", 331 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 332 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 333 | "dev": true 334 | }, 335 | "define-properties": { 336 | "version": "1.1.3", 337 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 338 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 339 | "dev": true, 340 | "requires": { 341 | "object-keys": "1.0.12" 342 | } 343 | }, 344 | "deglob": { 345 | "version": "2.1.1", 346 | "resolved": "https://registry.npmjs.org/deglob/-/deglob-2.1.1.tgz", 347 | "integrity": "sha512-2kjwuGGonL7gWE1XU4Fv79+vVzpoQCl0V+boMwWtOQJV2AGDabCwez++nB1Nli/8BabAfZQ/UuHPlp6AymKdWw==", 348 | "dev": true, 349 | "requires": { 350 | "find-root": "1.1.0", 351 | "glob": "7.1.3", 352 | "ignore": "3.3.10", 353 | "pkg-config": "1.1.1", 354 | "run-parallel": "1.1.9", 355 | "uniq": "1.0.1" 356 | }, 357 | "dependencies": { 358 | "ignore": { 359 | "version": "3.3.10", 360 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", 361 | "integrity": "sha512-Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug==", 362 | "dev": true 363 | } 364 | } 365 | }, 366 | "del": { 367 | "version": "3.0.0", 368 | "resolved": "https://registry.npmjs.org/del/-/del-3.0.0.tgz", 369 | "integrity": "sha1-U+z2mf/LyzljdpGrE7rxYIGXZuU=", 370 | "dev": true, 371 | "requires": { 372 | "globby": "6.1.0", 373 | "is-path-cwd": "1.0.0", 374 | "is-path-in-cwd": "1.0.1", 375 | "p-map": "1.2.0", 376 | "pify": "3.0.0", 377 | "rimraf": "2.6.2" 378 | } 379 | }, 380 | "depd": { 381 | "version": "1.1.2", 382 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 383 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 384 | }, 385 | "destroy": { 386 | "version": "1.0.4", 387 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 388 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 389 | }, 390 | "doctrine": { 391 | "version": "2.1.0", 392 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 393 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 394 | "dev": true, 395 | "requires": { 396 | "esutils": "2.0.2" 397 | } 398 | }, 399 | "ee-first": { 400 | "version": "1.1.1", 401 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 402 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 403 | }, 404 | "encodeurl": { 405 | "version": "1.0.2", 406 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 407 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 408 | }, 409 | "error-ex": { 410 | "version": "1.3.2", 411 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 412 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 413 | "dev": true, 414 | "requires": { 415 | "is-arrayish": "0.2.1" 416 | } 417 | }, 418 | "es-abstract": { 419 | "version": "1.12.0", 420 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.12.0.tgz", 421 | "integrity": "sha512-C8Fx/0jFmV5IPoMOFPA9P9G5NtqW+4cOPit3MIuvR2t7Ag2K15EJTpxnHAYTzL+aYQJIESYeXZmDBfOBE1HcpA==", 422 | "dev": true, 423 | "requires": { 424 | "es-to-primitive": "1.2.0", 425 | "function-bind": "1.1.1", 426 | "has": "1.0.3", 427 | "is-callable": "1.1.4", 428 | "is-regex": "1.0.4" 429 | } 430 | }, 431 | "es-to-primitive": { 432 | "version": "1.2.0", 433 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 434 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 435 | "dev": true, 436 | "requires": { 437 | "is-callable": "1.1.4", 438 | "is-date-object": "1.0.1", 439 | "is-symbol": "1.0.2" 440 | } 441 | }, 442 | "escape-html": { 443 | "version": "1.0.3", 444 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 445 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 446 | }, 447 | "escape-string-regexp": { 448 | "version": "1.0.5", 449 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 450 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 451 | "dev": true 452 | }, 453 | "eslint": { 454 | "version": "5.4.0", 455 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.4.0.tgz", 456 | "integrity": "sha512-UIpL91XGex3qtL6qwyCQJar2j3osKxK9e3ano3OcGEIRM4oWIpCkDg9x95AXEC2wMs7PnxzOkPZ2gq+tsMS9yg==", 457 | "dev": true, 458 | "requires": { 459 | "ajv": "6.5.5", 460 | "babel-code-frame": "6.26.0", 461 | "chalk": "2.4.1", 462 | "cross-spawn": "6.0.5", 463 | "debug": "3.2.6", 464 | "doctrine": "2.1.0", 465 | "eslint-scope": "4.0.0", 466 | "eslint-utils": "1.3.1", 467 | "eslint-visitor-keys": "1.0.0", 468 | "espree": "4.1.0", 469 | "esquery": "1.0.1", 470 | "esutils": "2.0.2", 471 | "file-entry-cache": "2.0.0", 472 | "functional-red-black-tree": "1.0.1", 473 | "glob": "7.1.3", 474 | "globals": "11.8.0", 475 | "ignore": "4.0.6", 476 | "imurmurhash": "0.1.4", 477 | "inquirer": "5.2.0", 478 | "is-resolvable": "1.1.0", 479 | "js-yaml": "3.12.0", 480 | "json-stable-stringify-without-jsonify": "1.0.1", 481 | "levn": "0.3.0", 482 | "lodash": "4.17.11", 483 | "minimatch": "3.0.4", 484 | "mkdirp": "0.5.1", 485 | "natural-compare": "1.4.0", 486 | "optionator": "0.8.2", 487 | "path-is-inside": "1.0.2", 488 | "pluralize": "7.0.0", 489 | "progress": "2.0.1", 490 | "regexpp": "2.0.1", 491 | "require-uncached": "1.0.3", 492 | "semver": "5.6.0", 493 | "strip-ansi": "4.0.0", 494 | "strip-json-comments": "2.0.1", 495 | "table": "4.0.3", 496 | "text-table": "0.2.0" 497 | }, 498 | "dependencies": { 499 | "debug": { 500 | "version": "3.2.6", 501 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 502 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 503 | "dev": true, 504 | "requires": { 505 | "ms": "2.1.1" 506 | } 507 | }, 508 | "ms": { 509 | "version": "2.1.1", 510 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 511 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 512 | "dev": true 513 | } 514 | } 515 | }, 516 | "eslint-config-standard": { 517 | "version": "12.0.0", 518 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-12.0.0.tgz", 519 | "integrity": "sha512-COUz8FnXhqFitYj4DTqHzidjIL/t4mumGZto5c7DrBpvWoie+Sn3P4sLEzUGeYhRElWuFEf8K1S1EfvD1vixCQ==", 520 | "dev": true 521 | }, 522 | "eslint-config-standard-jsx": { 523 | "version": "6.0.2", 524 | "resolved": "https://registry.npmjs.org/eslint-config-standard-jsx/-/eslint-config-standard-jsx-6.0.2.tgz", 525 | "integrity": "sha512-D+YWAoXw+2GIdbMBRAzWwr1ZtvnSf4n4yL0gKGg7ShUOGXkSOLerI17K4F6LdQMJPNMoWYqepzQD/fKY+tXNSg==", 526 | "dev": true 527 | }, 528 | "eslint-import-resolver-node": { 529 | "version": "0.3.2", 530 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 531 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 532 | "dev": true, 533 | "requires": { 534 | "debug": "2.6.9", 535 | "resolve": "1.8.1" 536 | } 537 | }, 538 | "eslint-module-utils": { 539 | "version": "2.2.0", 540 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.2.0.tgz", 541 | "integrity": "sha1-snA2LNiLGkitMIl2zn+lTphBF0Y=", 542 | "dev": true, 543 | "requires": { 544 | "debug": "2.6.9", 545 | "pkg-dir": "1.0.0" 546 | } 547 | }, 548 | "eslint-plugin-es": { 549 | "version": "1.3.2", 550 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-1.3.2.tgz", 551 | "integrity": "sha512-xrdbConViY20DhGrt9FwjhDo4fr/9Yus2pYf0xJsdJaCcUzMq7+pAoNH7kSXF6V08bRHMpgDWclYbcr/Sn3hNg==", 552 | "dev": true, 553 | "requires": { 554 | "eslint-utils": "1.3.1", 555 | "regexpp": "2.0.1" 556 | } 557 | }, 558 | "eslint-plugin-import": { 559 | "version": "2.14.0", 560 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.14.0.tgz", 561 | "integrity": "sha512-FpuRtniD/AY6sXByma2Wr0TXvXJ4nA/2/04VPlfpmUDPOpOY264x+ILiwnrk/k4RINgDAyFZByxqPUbSQ5YE7g==", 562 | "dev": true, 563 | "requires": { 564 | "contains-path": "0.1.0", 565 | "debug": "2.6.9", 566 | "doctrine": "1.5.0", 567 | "eslint-import-resolver-node": "0.3.2", 568 | "eslint-module-utils": "2.2.0", 569 | "has": "1.0.3", 570 | "lodash": "4.17.11", 571 | "minimatch": "3.0.4", 572 | "read-pkg-up": "2.0.0", 573 | "resolve": "1.8.1" 574 | }, 575 | "dependencies": { 576 | "doctrine": { 577 | "version": "1.5.0", 578 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 579 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 580 | "dev": true, 581 | "requires": { 582 | "esutils": "2.0.2", 583 | "isarray": "1.0.0" 584 | } 585 | } 586 | } 587 | }, 588 | "eslint-plugin-node": { 589 | "version": "7.0.1", 590 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-7.0.1.tgz", 591 | "integrity": "sha512-lfVw3TEqThwq0j2Ba/Ckn2ABdwmL5dkOgAux1rvOk6CO7A6yGyPI2+zIxN6FyNkp1X1X/BSvKOceD6mBWSj4Yw==", 592 | "dev": true, 593 | "requires": { 594 | "eslint-plugin-es": "1.3.2", 595 | "eslint-utils": "1.3.1", 596 | "ignore": "4.0.6", 597 | "minimatch": "3.0.4", 598 | "resolve": "1.8.1", 599 | "semver": "5.6.0" 600 | } 601 | }, 602 | "eslint-plugin-promise": { 603 | "version": "4.0.1", 604 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-4.0.1.tgz", 605 | "integrity": "sha512-Si16O0+Hqz1gDHsys6RtFRrW7cCTB6P7p3OJmKp3Y3dxpQE2qwOA7d3xnV+0mBmrPoi0RBnxlCKvqu70te6wjg==", 606 | "dev": true 607 | }, 608 | "eslint-plugin-react": { 609 | "version": "7.11.1", 610 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.11.1.tgz", 611 | "integrity": "sha512-cVVyMadRyW7qsIUh3FHp3u6QHNhOgVrLQYdQEB1bPWBsgbNCHdFAeNMquBMCcZJu59eNthX053L70l7gRt4SCw==", 612 | "dev": true, 613 | "requires": { 614 | "array-includes": "3.0.3", 615 | "doctrine": "2.1.0", 616 | "has": "1.0.3", 617 | "jsx-ast-utils": "2.0.1", 618 | "prop-types": "15.6.2" 619 | } 620 | }, 621 | "eslint-plugin-standard": { 622 | "version": "4.0.0", 623 | "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-4.0.0.tgz", 624 | "integrity": "sha512-OwxJkR6TQiYMmt1EsNRMe5qG3GsbjlcOhbGUBY4LtavF9DsLaTcoR+j2Tdjqi23oUwKNUqX7qcn5fPStafMdlA==", 625 | "dev": true 626 | }, 627 | "eslint-scope": { 628 | "version": "4.0.0", 629 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz", 630 | "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==", 631 | "dev": true, 632 | "requires": { 633 | "esrecurse": "4.2.1", 634 | "estraverse": "4.2.0" 635 | } 636 | }, 637 | "eslint-utils": { 638 | "version": "1.3.1", 639 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", 640 | "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", 641 | "dev": true 642 | }, 643 | "eslint-visitor-keys": { 644 | "version": "1.0.0", 645 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 646 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 647 | "dev": true 648 | }, 649 | "espree": { 650 | "version": "4.1.0", 651 | "resolved": "https://registry.npmjs.org/espree/-/espree-4.1.0.tgz", 652 | "integrity": "sha512-I5BycZW6FCVIub93TeVY1s7vjhP9CY6cXCznIRfiig7nRviKZYdRnj/sHEWC6A7WE9RDWOFq9+7OsWSYz8qv2w==", 653 | "dev": true, 654 | "requires": { 655 | "acorn": "6.0.4", 656 | "acorn-jsx": "5.0.0", 657 | "eslint-visitor-keys": "1.0.0" 658 | } 659 | }, 660 | "esprima": { 661 | "version": "4.0.1", 662 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 663 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 664 | "dev": true 665 | }, 666 | "esquery": { 667 | "version": "1.0.1", 668 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 669 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 670 | "dev": true, 671 | "requires": { 672 | "estraverse": "4.2.0" 673 | } 674 | }, 675 | "esrecurse": { 676 | "version": "4.2.1", 677 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 678 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 679 | "dev": true, 680 | "requires": { 681 | "estraverse": "4.2.0" 682 | } 683 | }, 684 | "estraverse": { 685 | "version": "4.2.0", 686 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 687 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 688 | "dev": true 689 | }, 690 | "esutils": { 691 | "version": "2.0.2", 692 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 693 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 694 | "dev": true 695 | }, 696 | "etag": { 697 | "version": "1.8.1", 698 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 699 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 700 | }, 701 | "express": { 702 | "version": "4.16.4", 703 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.4.tgz", 704 | "integrity": "sha512-j12Uuyb4FMrd/qQAm6uCHAkPtO8FDTRJZBDd5D2KOL2eLaz1yUNdUB/NOIyq0iU4q4cFarsUCrnFDPBcnksuOg==", 705 | "requires": { 706 | "accepts": "1.3.5", 707 | "array-flatten": "1.1.1", 708 | "body-parser": "1.18.3", 709 | "content-disposition": "0.5.2", 710 | "content-type": "1.0.4", 711 | "cookie": "0.3.1", 712 | "cookie-signature": "1.0.6", 713 | "debug": "2.6.9", 714 | "depd": "1.1.2", 715 | "encodeurl": "1.0.2", 716 | "escape-html": "1.0.3", 717 | "etag": "1.8.1", 718 | "finalhandler": "1.1.1", 719 | "fresh": "0.5.2", 720 | "merge-descriptors": "1.0.1", 721 | "methods": "1.1.2", 722 | "on-finished": "2.3.0", 723 | "parseurl": "1.3.2", 724 | "path-to-regexp": "0.1.7", 725 | "proxy-addr": "2.0.4", 726 | "qs": "6.5.2", 727 | "range-parser": "1.2.0", 728 | "safe-buffer": "5.1.2", 729 | "send": "0.16.2", 730 | "serve-static": "1.13.2", 731 | "setprototypeof": "1.1.0", 732 | "statuses": "1.4.0", 733 | "type-is": "1.6.16", 734 | "utils-merge": "1.0.1", 735 | "vary": "1.1.2" 736 | }, 737 | "dependencies": { 738 | "statuses": { 739 | "version": "1.4.0", 740 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 741 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 742 | } 743 | } 744 | }, 745 | "express-graphql": { 746 | "version": "0.8.0", 747 | "resolved": "https://registry.npmjs.org/express-graphql/-/express-graphql-0.8.0.tgz", 748 | "integrity": "sha512-yjFFLTw9J/7QbLBs/SRX1IykEnJHIdaAeDTiw1yC+zPHoQSCijKdPZYhe+B0SC0sFJydAXW6RSqqnERGgKPH7g==", 749 | "requires": { 750 | "accepts": "^1.3.5", 751 | "content-type": "^1.0.4", 752 | "http-errors": "^1.7.2", 753 | "raw-body": "^2.3.3" 754 | }, 755 | "dependencies": { 756 | "http-errors": { 757 | "version": "1.7.2", 758 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 759 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 760 | "requires": { 761 | "depd": "~1.1.2", 762 | "inherits": "2.0.3", 763 | "setprototypeof": "1.1.1", 764 | "statuses": ">= 1.5.0 < 2", 765 | "toidentifier": "1.0.0" 766 | } 767 | }, 768 | "setprototypeof": { 769 | "version": "1.1.1", 770 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 771 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 772 | } 773 | } 774 | }, 775 | "external-editor": { 776 | "version": "2.2.0", 777 | "resolved": "http://registry.npmjs.org/external-editor/-/external-editor-2.2.0.tgz", 778 | "integrity": "sha512-bSn6gvGxKt+b7+6TKEv1ZycHleA7aHhRHyAqJyp5pbUFuYYNIzpZnQDk7AsYckyWdEnTeAnay0aCy2aV6iTk9A==", 779 | "dev": true, 780 | "requires": { 781 | "chardet": "0.4.2", 782 | "iconv-lite": "0.4.23", 783 | "tmp": "0.0.33" 784 | } 785 | }, 786 | "fast-deep-equal": { 787 | "version": "2.0.1", 788 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 789 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 790 | "dev": true 791 | }, 792 | "fast-json-stable-stringify": { 793 | "version": "2.0.0", 794 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 795 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 796 | "dev": true 797 | }, 798 | "fast-levenshtein": { 799 | "version": "2.0.6", 800 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 801 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 802 | "dev": true 803 | }, 804 | "figures": { 805 | "version": "2.0.0", 806 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 807 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 808 | "dev": true, 809 | "requires": { 810 | "escape-string-regexp": "1.0.5" 811 | } 812 | }, 813 | "file-entry-cache": { 814 | "version": "2.0.0", 815 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", 816 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", 817 | "dev": true, 818 | "requires": { 819 | "flat-cache": "1.3.2", 820 | "object-assign": "4.1.1" 821 | } 822 | }, 823 | "finalhandler": { 824 | "version": "1.1.1", 825 | "resolved": "http://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz", 826 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", 827 | "requires": { 828 | "debug": "2.6.9", 829 | "encodeurl": "1.0.2", 830 | "escape-html": "1.0.3", 831 | "on-finished": "2.3.0", 832 | "parseurl": "1.3.2", 833 | "statuses": "1.4.0", 834 | "unpipe": "1.0.0" 835 | }, 836 | "dependencies": { 837 | "statuses": { 838 | "version": "1.4.0", 839 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 840 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 841 | } 842 | } 843 | }, 844 | "find-root": { 845 | "version": "1.1.0", 846 | "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz", 847 | "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==", 848 | "dev": true 849 | }, 850 | "find-up": { 851 | "version": "1.1.2", 852 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 853 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 854 | "dev": true, 855 | "requires": { 856 | "path-exists": "2.1.0", 857 | "pinkie-promise": "2.0.1" 858 | } 859 | }, 860 | "flat-cache": { 861 | "version": "1.3.2", 862 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.2.tgz", 863 | "integrity": "sha512-KByBY8c98sLUAGpnmjEdWTrtrLZRtZdwds+kAL/ciFXTCb7AZgqKsAnVnYFQj1hxepwO8JKN/8AsRWwLq+RK0A==", 864 | "dev": true, 865 | "requires": { 866 | "circular-json": "0.3.3", 867 | "del": "3.0.0", 868 | "graceful-fs": "4.1.15", 869 | "write": "0.2.1" 870 | } 871 | }, 872 | "forwarded": { 873 | "version": "0.1.2", 874 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 875 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 876 | }, 877 | "fresh": { 878 | "version": "0.5.2", 879 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 880 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 881 | }, 882 | "fs.realpath": { 883 | "version": "1.0.0", 884 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 885 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 886 | "dev": true 887 | }, 888 | "function-bind": { 889 | "version": "1.1.1", 890 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 891 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 892 | "dev": true 893 | }, 894 | "functional-red-black-tree": { 895 | "version": "1.0.1", 896 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 897 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 898 | "dev": true 899 | }, 900 | "get-stdin": { 901 | "version": "6.0.0", 902 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", 903 | "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", 904 | "dev": true 905 | }, 906 | "glob": { 907 | "version": "7.1.3", 908 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 909 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 910 | "dev": true, 911 | "requires": { 912 | "fs.realpath": "1.0.0", 913 | "inflight": "1.0.6", 914 | "inherits": "2.0.3", 915 | "minimatch": "3.0.4", 916 | "once": "1.4.0", 917 | "path-is-absolute": "1.0.1" 918 | } 919 | }, 920 | "globals": { 921 | "version": "11.8.0", 922 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.8.0.tgz", 923 | "integrity": "sha512-io6LkyPVuzCHBSQV9fmOwxZkUk6nIaGmxheLDgmuFv89j0fm2aqDbIXKAGfzCMHqz3HLF2Zf8WSG6VqMh2qFmA==", 924 | "dev": true 925 | }, 926 | "globby": { 927 | "version": "6.1.0", 928 | "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", 929 | "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", 930 | "dev": true, 931 | "requires": { 932 | "array-union": "1.0.2", 933 | "glob": "7.1.3", 934 | "object-assign": "4.1.1", 935 | "pify": "2.3.0", 936 | "pinkie-promise": "2.0.1" 937 | }, 938 | "dependencies": { 939 | "pify": { 940 | "version": "2.3.0", 941 | "resolved": "http://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 942 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 943 | "dev": true 944 | } 945 | } 946 | }, 947 | "graceful-fs": { 948 | "version": "4.1.15", 949 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 950 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 951 | "dev": true 952 | }, 953 | "graphql": { 954 | "version": "14.0.2", 955 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-14.0.2.tgz", 956 | "integrity": "sha512-gUC4YYsaiSJT1h40krG3J+USGlwhzNTXSb4IOZljn9ag5Tj+RkoXrWp+Kh7WyE3t1NCfab5kzCuxBIvOMERMXw==", 957 | "requires": { 958 | "iterall": "1.2.2" 959 | } 960 | }, 961 | "graphql-type-json": { 962 | "version": "0.3.0", 963 | "resolved": "https://registry.npmjs.org/graphql-type-json/-/graphql-type-json-0.3.0.tgz", 964 | "integrity": "sha512-lnxg5HiB95yxy+/5cDKtP6pZo0zgntsOmqsjeCBXFGJ4YoMF3+1YaSEKWJntNTu+VsAm3zf6lPxFpp1kxzofLA==" 965 | }, 966 | "has": { 967 | "version": "1.0.3", 968 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 969 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 970 | "dev": true, 971 | "requires": { 972 | "function-bind": "1.1.1" 973 | } 974 | }, 975 | "has-ansi": { 976 | "version": "2.0.0", 977 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 978 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 979 | "dev": true, 980 | "requires": { 981 | "ansi-regex": "2.1.1" 982 | } 983 | }, 984 | "has-flag": { 985 | "version": "3.0.0", 986 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 987 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 988 | "dev": true 989 | }, 990 | "has-symbols": { 991 | "version": "1.0.0", 992 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 993 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 994 | "dev": true 995 | }, 996 | "hosted-git-info": { 997 | "version": "2.7.1", 998 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 999 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 1000 | "dev": true 1001 | }, 1002 | "http-errors": { 1003 | "version": "1.6.3", 1004 | "resolved": "http://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 1005 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", 1006 | "requires": { 1007 | "depd": "1.1.2", 1008 | "inherits": "2.0.3", 1009 | "setprototypeof": "1.1.0", 1010 | "statuses": "1.5.0" 1011 | } 1012 | }, 1013 | "iconv-lite": { 1014 | "version": "0.4.23", 1015 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 1016 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 1017 | "requires": { 1018 | "safer-buffer": "2.1.2" 1019 | } 1020 | }, 1021 | "ignore": { 1022 | "version": "4.0.6", 1023 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1024 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1025 | "dev": true 1026 | }, 1027 | "imurmurhash": { 1028 | "version": "0.1.4", 1029 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1030 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1031 | "dev": true 1032 | }, 1033 | "inflight": { 1034 | "version": "1.0.6", 1035 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1036 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1037 | "dev": true, 1038 | "requires": { 1039 | "once": "1.4.0", 1040 | "wrappy": "1.0.2" 1041 | } 1042 | }, 1043 | "inherits": { 1044 | "version": "2.0.3", 1045 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1046 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1047 | }, 1048 | "inquirer": { 1049 | "version": "5.2.0", 1050 | "resolved": "http://registry.npmjs.org/inquirer/-/inquirer-5.2.0.tgz", 1051 | "integrity": "sha512-E9BmnJbAKLPGonz0HeWHtbKf+EeSP93paWO3ZYoUpq/aowXvYGjjCSuashhXPpzbArIjBbji39THkxTz9ZeEUQ==", 1052 | "dev": true, 1053 | "requires": { 1054 | "ansi-escapes": "3.1.0", 1055 | "chalk": "2.4.1", 1056 | "cli-cursor": "2.1.0", 1057 | "cli-width": "2.2.0", 1058 | "external-editor": "2.2.0", 1059 | "figures": "2.0.0", 1060 | "lodash": "4.17.11", 1061 | "mute-stream": "0.0.7", 1062 | "run-async": "2.3.0", 1063 | "rxjs": "5.5.12", 1064 | "string-width": "2.1.1", 1065 | "strip-ansi": "4.0.0", 1066 | "through": "2.3.8" 1067 | } 1068 | }, 1069 | "ipaddr.js": { 1070 | "version": "1.8.0", 1071 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz", 1072 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4=" 1073 | }, 1074 | "is-arrayish": { 1075 | "version": "0.2.1", 1076 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1077 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1078 | "dev": true 1079 | }, 1080 | "is-builtin-module": { 1081 | "version": "1.0.0", 1082 | "resolved": "http://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 1083 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 1084 | "dev": true, 1085 | "requires": { 1086 | "builtin-modules": "1.1.1" 1087 | } 1088 | }, 1089 | "is-callable": { 1090 | "version": "1.1.4", 1091 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1092 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 1093 | "dev": true 1094 | }, 1095 | "is-date-object": { 1096 | "version": "1.0.1", 1097 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1098 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1099 | "dev": true 1100 | }, 1101 | "is-fullwidth-code-point": { 1102 | "version": "2.0.0", 1103 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1104 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1105 | "dev": true 1106 | }, 1107 | "is-path-cwd": { 1108 | "version": "1.0.0", 1109 | "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", 1110 | "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", 1111 | "dev": true 1112 | }, 1113 | "is-path-in-cwd": { 1114 | "version": "1.0.1", 1115 | "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz", 1116 | "integrity": "sha512-FjV1RTW48E7CWM7eE/J2NJvAEEVektecDBVBE5Hh3nM1Jd0kvhHtX68Pr3xsDf857xt3Y4AkwVULK1Vku62aaQ==", 1117 | "dev": true, 1118 | "requires": { 1119 | "is-path-inside": "1.0.1" 1120 | } 1121 | }, 1122 | "is-path-inside": { 1123 | "version": "1.0.1", 1124 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 1125 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 1126 | "dev": true, 1127 | "requires": { 1128 | "path-is-inside": "1.0.2" 1129 | } 1130 | }, 1131 | "is-promise": { 1132 | "version": "2.1.0", 1133 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1134 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1135 | "dev": true 1136 | }, 1137 | "is-regex": { 1138 | "version": "1.0.4", 1139 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1140 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1141 | "dev": true, 1142 | "requires": { 1143 | "has": "1.0.3" 1144 | } 1145 | }, 1146 | "is-resolvable": { 1147 | "version": "1.1.0", 1148 | "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", 1149 | "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", 1150 | "dev": true 1151 | }, 1152 | "is-symbol": { 1153 | "version": "1.0.2", 1154 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1155 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1156 | "dev": true, 1157 | "requires": { 1158 | "has-symbols": "1.0.0" 1159 | } 1160 | }, 1161 | "isarray": { 1162 | "version": "1.0.0", 1163 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1164 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1165 | "dev": true 1166 | }, 1167 | "isexe": { 1168 | "version": "2.0.0", 1169 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1170 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1171 | "dev": true 1172 | }, 1173 | "iterall": { 1174 | "version": "1.2.2", 1175 | "resolved": "https://registry.npmjs.org/iterall/-/iterall-1.2.2.tgz", 1176 | "integrity": "sha512-yynBb1g+RFUPY64fTrFv7nsjRrENBQJaX2UL+2Szc9REFrSNm1rpSXHGzhmAy7a9uv3vlvgBlXnf9RqmPH1/DA==" 1177 | }, 1178 | "js-tokens": { 1179 | "version": "3.0.2", 1180 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 1181 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", 1182 | "dev": true 1183 | }, 1184 | "js-yaml": { 1185 | "version": "3.12.0", 1186 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 1187 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 1188 | "dev": true, 1189 | "requires": { 1190 | "argparse": "1.0.10", 1191 | "esprima": "4.0.1" 1192 | } 1193 | }, 1194 | "json-parse-better-errors": { 1195 | "version": "1.0.2", 1196 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1197 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1198 | "dev": true 1199 | }, 1200 | "json-schema-traverse": { 1201 | "version": "0.4.1", 1202 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1203 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1204 | "dev": true 1205 | }, 1206 | "json-stable-stringify-without-jsonify": { 1207 | "version": "1.0.1", 1208 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1209 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1210 | "dev": true 1211 | }, 1212 | "jsx-ast-utils": { 1213 | "version": "2.0.1", 1214 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.0.1.tgz", 1215 | "integrity": "sha1-6AGxs5mF4g//yHtA43SAgOLcrH8=", 1216 | "dev": true, 1217 | "requires": { 1218 | "array-includes": "3.0.3" 1219 | } 1220 | }, 1221 | "levn": { 1222 | "version": "0.3.0", 1223 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1224 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1225 | "dev": true, 1226 | "requires": { 1227 | "prelude-ls": "1.1.2", 1228 | "type-check": "0.3.2" 1229 | } 1230 | }, 1231 | "load-json-file": { 1232 | "version": "2.0.0", 1233 | "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1234 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1235 | "dev": true, 1236 | "requires": { 1237 | "graceful-fs": "4.1.15", 1238 | "parse-json": "2.2.0", 1239 | "pify": "2.3.0", 1240 | "strip-bom": "3.0.0" 1241 | }, 1242 | "dependencies": { 1243 | "pify": { 1244 | "version": "2.3.0", 1245 | "resolved": "http://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1246 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1247 | "dev": true 1248 | } 1249 | } 1250 | }, 1251 | "locate-path": { 1252 | "version": "2.0.0", 1253 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1254 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1255 | "dev": true, 1256 | "requires": { 1257 | "p-locate": "2.0.0", 1258 | "path-exists": "3.0.0" 1259 | }, 1260 | "dependencies": { 1261 | "path-exists": { 1262 | "version": "3.0.0", 1263 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1264 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1265 | "dev": true 1266 | } 1267 | } 1268 | }, 1269 | "lodash": { 1270 | "version": "4.17.11", 1271 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 1272 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", 1273 | "dev": true 1274 | }, 1275 | "loose-envify": { 1276 | "version": "1.4.0", 1277 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1278 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1279 | "dev": true, 1280 | "requires": { 1281 | "js-tokens": "3.0.2" 1282 | } 1283 | }, 1284 | "media-typer": { 1285 | "version": "0.3.0", 1286 | "resolved": "http://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1287 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1288 | }, 1289 | "merge-descriptors": { 1290 | "version": "1.0.1", 1291 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1292 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1293 | }, 1294 | "methods": { 1295 | "version": "1.1.2", 1296 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1297 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1298 | }, 1299 | "mime": { 1300 | "version": "1.4.1", 1301 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 1302 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" 1303 | }, 1304 | "mime-db": { 1305 | "version": "1.37.0", 1306 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz", 1307 | "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg==" 1308 | }, 1309 | "mime-types": { 1310 | "version": "2.1.21", 1311 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz", 1312 | "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==", 1313 | "requires": { 1314 | "mime-db": "1.37.0" 1315 | } 1316 | }, 1317 | "mimic-fn": { 1318 | "version": "1.2.0", 1319 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1320 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1321 | "dev": true 1322 | }, 1323 | "minimatch": { 1324 | "version": "3.0.4", 1325 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1326 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1327 | "dev": true, 1328 | "requires": { 1329 | "brace-expansion": "1.1.11" 1330 | } 1331 | }, 1332 | "minimist": { 1333 | "version": "0.0.8", 1334 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1335 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1336 | "dev": true 1337 | }, 1338 | "mkdirp": { 1339 | "version": "0.5.1", 1340 | "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1341 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1342 | "dev": true, 1343 | "requires": { 1344 | "minimist": "0.0.8" 1345 | } 1346 | }, 1347 | "ms": { 1348 | "version": "2.0.0", 1349 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1350 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1351 | }, 1352 | "mute-stream": { 1353 | "version": "0.0.7", 1354 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1355 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1356 | "dev": true 1357 | }, 1358 | "natural-compare": { 1359 | "version": "1.4.0", 1360 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1361 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1362 | "dev": true 1363 | }, 1364 | "negotiator": { 1365 | "version": "0.6.1", 1366 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1367 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 1368 | }, 1369 | "nice-try": { 1370 | "version": "1.0.5", 1371 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1372 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1373 | "dev": true 1374 | }, 1375 | "normalize-package-data": { 1376 | "version": "2.4.0", 1377 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 1378 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 1379 | "dev": true, 1380 | "requires": { 1381 | "hosted-git-info": "2.7.1", 1382 | "is-builtin-module": "1.0.0", 1383 | "semver": "5.6.0", 1384 | "validate-npm-package-license": "3.0.4" 1385 | } 1386 | }, 1387 | "object-assign": { 1388 | "version": "4.1.1", 1389 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1390 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1391 | "dev": true 1392 | }, 1393 | "object-keys": { 1394 | "version": "1.0.12", 1395 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.12.tgz", 1396 | "integrity": "sha512-FTMyFUm2wBcGHnH2eXmz7tC6IwlqQZ6mVZ+6dm6vZ4IQIHjs6FdNsQBuKGPuUUUY6NfJw2PshC08Tn6LzLDOag==", 1397 | "dev": true 1398 | }, 1399 | "on-finished": { 1400 | "version": "2.3.0", 1401 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1402 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1403 | "requires": { 1404 | "ee-first": "1.1.1" 1405 | } 1406 | }, 1407 | "once": { 1408 | "version": "1.4.0", 1409 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1410 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1411 | "dev": true, 1412 | "requires": { 1413 | "wrappy": "1.0.2" 1414 | } 1415 | }, 1416 | "onetime": { 1417 | "version": "2.0.1", 1418 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1419 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1420 | "dev": true, 1421 | "requires": { 1422 | "mimic-fn": "1.2.0" 1423 | } 1424 | }, 1425 | "optionator": { 1426 | "version": "0.8.2", 1427 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1428 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1429 | "dev": true, 1430 | "requires": { 1431 | "deep-is": "0.1.3", 1432 | "fast-levenshtein": "2.0.6", 1433 | "levn": "0.3.0", 1434 | "prelude-ls": "1.1.2", 1435 | "type-check": "0.3.2", 1436 | "wordwrap": "1.0.0" 1437 | } 1438 | }, 1439 | "os-tmpdir": { 1440 | "version": "1.0.2", 1441 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1442 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1443 | "dev": true 1444 | }, 1445 | "p-limit": { 1446 | "version": "1.3.0", 1447 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1448 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1449 | "dev": true, 1450 | "requires": { 1451 | "p-try": "1.0.0" 1452 | } 1453 | }, 1454 | "p-locate": { 1455 | "version": "2.0.0", 1456 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1457 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1458 | "dev": true, 1459 | "requires": { 1460 | "p-limit": "1.3.0" 1461 | } 1462 | }, 1463 | "p-map": { 1464 | "version": "1.2.0", 1465 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-1.2.0.tgz", 1466 | "integrity": "sha512-r6zKACMNhjPJMTl8KcFH4li//gkrXWfbD6feV8l6doRHlzljFWGJ2AP6iKaCJXyZmAUMOPtvbW7EXkbWO/pLEA==", 1467 | "dev": true 1468 | }, 1469 | "p-try": { 1470 | "version": "1.0.0", 1471 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1472 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1473 | "dev": true 1474 | }, 1475 | "parse-json": { 1476 | "version": "2.2.0", 1477 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1478 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1479 | "dev": true, 1480 | "requires": { 1481 | "error-ex": "1.3.2" 1482 | } 1483 | }, 1484 | "parseurl": { 1485 | "version": "1.3.2", 1486 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 1487 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 1488 | }, 1489 | "path-exists": { 1490 | "version": "2.1.0", 1491 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 1492 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 1493 | "dev": true, 1494 | "requires": { 1495 | "pinkie-promise": "2.0.1" 1496 | } 1497 | }, 1498 | "path-is-absolute": { 1499 | "version": "1.0.1", 1500 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1501 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1502 | "dev": true 1503 | }, 1504 | "path-is-inside": { 1505 | "version": "1.0.2", 1506 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1507 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1508 | "dev": true 1509 | }, 1510 | "path-key": { 1511 | "version": "2.0.1", 1512 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1513 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1514 | "dev": true 1515 | }, 1516 | "path-parse": { 1517 | "version": "1.0.6", 1518 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1519 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1520 | "dev": true 1521 | }, 1522 | "path-to-regexp": { 1523 | "version": "0.1.7", 1524 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1525 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1526 | }, 1527 | "path-type": { 1528 | "version": "2.0.0", 1529 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1530 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1531 | "dev": true, 1532 | "requires": { 1533 | "pify": "2.3.0" 1534 | }, 1535 | "dependencies": { 1536 | "pify": { 1537 | "version": "2.3.0", 1538 | "resolved": "http://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1539 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1540 | "dev": true 1541 | } 1542 | } 1543 | }, 1544 | "pify": { 1545 | "version": "3.0.0", 1546 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1547 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1548 | "dev": true 1549 | }, 1550 | "pinkie": { 1551 | "version": "2.0.4", 1552 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 1553 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 1554 | "dev": true 1555 | }, 1556 | "pinkie-promise": { 1557 | "version": "2.0.1", 1558 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 1559 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 1560 | "dev": true, 1561 | "requires": { 1562 | "pinkie": "2.0.4" 1563 | } 1564 | }, 1565 | "pkg-conf": { 1566 | "version": "2.1.0", 1567 | "resolved": "https://registry.npmjs.org/pkg-conf/-/pkg-conf-2.1.0.tgz", 1568 | "integrity": "sha1-ISZRTKbyq/69FoWW3xi6V4Z/AFg=", 1569 | "dev": true, 1570 | "requires": { 1571 | "find-up": "2.1.0", 1572 | "load-json-file": "4.0.0" 1573 | }, 1574 | "dependencies": { 1575 | "find-up": { 1576 | "version": "2.1.0", 1577 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1578 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1579 | "dev": true, 1580 | "requires": { 1581 | "locate-path": "2.0.0" 1582 | } 1583 | }, 1584 | "load-json-file": { 1585 | "version": "4.0.0", 1586 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 1587 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 1588 | "dev": true, 1589 | "requires": { 1590 | "graceful-fs": "4.1.15", 1591 | "parse-json": "4.0.0", 1592 | "pify": "3.0.0", 1593 | "strip-bom": "3.0.0" 1594 | } 1595 | }, 1596 | "parse-json": { 1597 | "version": "4.0.0", 1598 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1599 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1600 | "dev": true, 1601 | "requires": { 1602 | "error-ex": "1.3.2", 1603 | "json-parse-better-errors": "1.0.2" 1604 | } 1605 | } 1606 | } 1607 | }, 1608 | "pkg-config": { 1609 | "version": "1.1.1", 1610 | "resolved": "https://registry.npmjs.org/pkg-config/-/pkg-config-1.1.1.tgz", 1611 | "integrity": "sha1-VX7yLXPaPIg3EHdmxS6tq94pj+Q=", 1612 | "dev": true, 1613 | "requires": { 1614 | "debug-log": "1.0.1", 1615 | "find-root": "1.1.0", 1616 | "xtend": "4.0.1" 1617 | } 1618 | }, 1619 | "pkg-dir": { 1620 | "version": "1.0.0", 1621 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", 1622 | "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", 1623 | "dev": true, 1624 | "requires": { 1625 | "find-up": "1.1.2" 1626 | } 1627 | }, 1628 | "pluralize": { 1629 | "version": "7.0.0", 1630 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", 1631 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", 1632 | "dev": true 1633 | }, 1634 | "prelude-ls": { 1635 | "version": "1.1.2", 1636 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1637 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1638 | "dev": true 1639 | }, 1640 | "progress": { 1641 | "version": "2.0.1", 1642 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.1.tgz", 1643 | "integrity": "sha512-OE+a6vzqazc+K6LxJrX5UPyKFvGnL5CYmq2jFGNIBWHpc4QyE49/YOumcrpQFJpfejmvRtbJzgO1zPmMCqlbBg==", 1644 | "dev": true 1645 | }, 1646 | "prop-types": { 1647 | "version": "15.6.2", 1648 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.6.2.tgz", 1649 | "integrity": "sha512-3pboPvLiWD7dkI3qf3KbUe6hKFKa52w+AE0VCqECtf+QHAKgOL37tTaNCnuX1nAAQ4ZhyP+kYVKf8rLmJ/feDQ==", 1650 | "dev": true, 1651 | "requires": { 1652 | "loose-envify": "1.4.0", 1653 | "object-assign": "4.1.1" 1654 | } 1655 | }, 1656 | "proxy-addr": { 1657 | "version": "2.0.4", 1658 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz", 1659 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==", 1660 | "requires": { 1661 | "forwarded": "0.1.2", 1662 | "ipaddr.js": "1.8.0" 1663 | } 1664 | }, 1665 | "punycode": { 1666 | "version": "2.1.1", 1667 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1668 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1669 | "dev": true 1670 | }, 1671 | "qs": { 1672 | "version": "6.5.2", 1673 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1674 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 1675 | }, 1676 | "range-parser": { 1677 | "version": "1.2.0", 1678 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 1679 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 1680 | }, 1681 | "raw-body": { 1682 | "version": "2.3.3", 1683 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", 1684 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", 1685 | "requires": { 1686 | "bytes": "3.0.0", 1687 | "http-errors": "1.6.3", 1688 | "iconv-lite": "0.4.23", 1689 | "unpipe": "1.0.0" 1690 | } 1691 | }, 1692 | "read-pkg": { 1693 | "version": "2.0.0", 1694 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1695 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1696 | "dev": true, 1697 | "requires": { 1698 | "load-json-file": "2.0.0", 1699 | "normalize-package-data": "2.4.0", 1700 | "path-type": "2.0.0" 1701 | } 1702 | }, 1703 | "read-pkg-up": { 1704 | "version": "2.0.0", 1705 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1706 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1707 | "dev": true, 1708 | "requires": { 1709 | "find-up": "2.1.0", 1710 | "read-pkg": "2.0.0" 1711 | }, 1712 | "dependencies": { 1713 | "find-up": { 1714 | "version": "2.1.0", 1715 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1716 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1717 | "dev": true, 1718 | "requires": { 1719 | "locate-path": "2.0.0" 1720 | } 1721 | } 1722 | } 1723 | }, 1724 | "regexpp": { 1725 | "version": "2.0.1", 1726 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1727 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1728 | "dev": true 1729 | }, 1730 | "require-uncached": { 1731 | "version": "1.0.3", 1732 | "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", 1733 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", 1734 | "dev": true, 1735 | "requires": { 1736 | "caller-path": "0.1.0", 1737 | "resolve-from": "1.0.1" 1738 | } 1739 | }, 1740 | "resolve": { 1741 | "version": "1.8.1", 1742 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.8.1.tgz", 1743 | "integrity": "sha512-AicPrAC7Qu1JxPCZ9ZgCZlY35QgFnNqc+0LtbRNxnVw4TXvjQ72wnuL9JQcEBgXkI9JM8MsT9kaQoHcpCRJOYA==", 1744 | "dev": true, 1745 | "requires": { 1746 | "path-parse": "1.0.6" 1747 | } 1748 | }, 1749 | "resolve-from": { 1750 | "version": "1.0.1", 1751 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", 1752 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", 1753 | "dev": true 1754 | }, 1755 | "restore-cursor": { 1756 | "version": "2.0.0", 1757 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1758 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1759 | "dev": true, 1760 | "requires": { 1761 | "onetime": "2.0.1", 1762 | "signal-exit": "3.0.2" 1763 | } 1764 | }, 1765 | "rimraf": { 1766 | "version": "2.6.2", 1767 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 1768 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 1769 | "dev": true, 1770 | "requires": { 1771 | "glob": "7.1.3" 1772 | } 1773 | }, 1774 | "run-async": { 1775 | "version": "2.3.0", 1776 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1777 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1778 | "dev": true, 1779 | "requires": { 1780 | "is-promise": "2.1.0" 1781 | } 1782 | }, 1783 | "run-parallel": { 1784 | "version": "1.1.9", 1785 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.9.tgz", 1786 | "integrity": "sha512-DEqnSRTDw/Tc3FXf49zedI638Z9onwUotBMiUFKmrO2sdFKIbXamXGQ3Axd4qgphxKB4kw/qP1w5kTxnfU1B9Q==", 1787 | "dev": true 1788 | }, 1789 | "rxjs": { 1790 | "version": "5.5.12", 1791 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-5.5.12.tgz", 1792 | "integrity": "sha512-xx2itnL5sBbqeeiVgNPVuQQ1nC8Jp2WfNJhXWHmElW9YmrpS9UVnNzhP3EH3HFqexO5Tlp8GhYY+WEcqcVMvGw==", 1793 | "dev": true, 1794 | "requires": { 1795 | "symbol-observable": "1.0.1" 1796 | } 1797 | }, 1798 | "safe-buffer": { 1799 | "version": "5.1.2", 1800 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1801 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1802 | }, 1803 | "safer-buffer": { 1804 | "version": "2.1.2", 1805 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1806 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1807 | }, 1808 | "semver": { 1809 | "version": "5.6.0", 1810 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 1811 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", 1812 | "dev": true 1813 | }, 1814 | "send": { 1815 | "version": "0.16.2", 1816 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 1817 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 1818 | "requires": { 1819 | "debug": "2.6.9", 1820 | "depd": "1.1.2", 1821 | "destroy": "1.0.4", 1822 | "encodeurl": "1.0.2", 1823 | "escape-html": "1.0.3", 1824 | "etag": "1.8.1", 1825 | "fresh": "0.5.2", 1826 | "http-errors": "1.6.3", 1827 | "mime": "1.4.1", 1828 | "ms": "2.0.0", 1829 | "on-finished": "2.3.0", 1830 | "range-parser": "1.2.0", 1831 | "statuses": "1.4.0" 1832 | }, 1833 | "dependencies": { 1834 | "statuses": { 1835 | "version": "1.4.0", 1836 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 1837 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 1838 | } 1839 | } 1840 | }, 1841 | "serve-static": { 1842 | "version": "1.13.2", 1843 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 1844 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 1845 | "requires": { 1846 | "encodeurl": "1.0.2", 1847 | "escape-html": "1.0.3", 1848 | "parseurl": "1.3.2", 1849 | "send": "0.16.2" 1850 | } 1851 | }, 1852 | "setprototypeof": { 1853 | "version": "1.1.0", 1854 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 1855 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 1856 | }, 1857 | "shebang-command": { 1858 | "version": "1.2.0", 1859 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1860 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1861 | "dev": true, 1862 | "requires": { 1863 | "shebang-regex": "1.0.0" 1864 | } 1865 | }, 1866 | "shebang-regex": { 1867 | "version": "1.0.0", 1868 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1869 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1870 | "dev": true 1871 | }, 1872 | "signal-exit": { 1873 | "version": "3.0.2", 1874 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1875 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1876 | "dev": true 1877 | }, 1878 | "slice-ansi": { 1879 | "version": "1.0.0", 1880 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", 1881 | "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", 1882 | "dev": true, 1883 | "requires": { 1884 | "is-fullwidth-code-point": "2.0.0" 1885 | } 1886 | }, 1887 | "spdx-correct": { 1888 | "version": "3.0.2", 1889 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.0.2.tgz", 1890 | "integrity": "sha512-q9hedtzyXHr5S0A1vEPoK/7l8NpfkFYTq6iCY+Pno2ZbdZR6WexZFtqeVGkGxW3TEJMN914Z55EnAGMmenlIQQ==", 1891 | "dev": true, 1892 | "requires": { 1893 | "spdx-expression-parse": "3.0.0", 1894 | "spdx-license-ids": "3.0.2" 1895 | } 1896 | }, 1897 | "spdx-exceptions": { 1898 | "version": "2.2.0", 1899 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 1900 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 1901 | "dev": true 1902 | }, 1903 | "spdx-expression-parse": { 1904 | "version": "3.0.0", 1905 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 1906 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 1907 | "dev": true, 1908 | "requires": { 1909 | "spdx-exceptions": "2.2.0", 1910 | "spdx-license-ids": "3.0.2" 1911 | } 1912 | }, 1913 | "spdx-license-ids": { 1914 | "version": "3.0.2", 1915 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.2.tgz", 1916 | "integrity": "sha512-qky9CVt0lVIECkEsYbNILVnPvycuEBkXoMFLRWsREkomQLevYhtRKC+R91a5TOAQ3bCMjikRwhyaRqj1VYatYg==", 1917 | "dev": true 1918 | }, 1919 | "sprintf-js": { 1920 | "version": "1.0.3", 1921 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1922 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1923 | "dev": true 1924 | }, 1925 | "standard": { 1926 | "version": "12.0.1", 1927 | "resolved": "https://registry.npmjs.org/standard/-/standard-12.0.1.tgz", 1928 | "integrity": "sha512-UqdHjh87OG2gUrNCSM4QRLF5n9h3TFPwrCNyVlkqu31Hej0L/rc8hzKqVvkb2W3x0WMq7PzZdkLfEcBhVOR6lg==", 1929 | "dev": true, 1930 | "requires": { 1931 | "eslint": "5.4.0", 1932 | "eslint-config-standard": "12.0.0", 1933 | "eslint-config-standard-jsx": "6.0.2", 1934 | "eslint-plugin-import": "2.14.0", 1935 | "eslint-plugin-node": "7.0.1", 1936 | "eslint-plugin-promise": "4.0.1", 1937 | "eslint-plugin-react": "7.11.1", 1938 | "eslint-plugin-standard": "4.0.0", 1939 | "standard-engine": "9.0.0" 1940 | } 1941 | }, 1942 | "standard-engine": { 1943 | "version": "9.0.0", 1944 | "resolved": "https://registry.npmjs.org/standard-engine/-/standard-engine-9.0.0.tgz", 1945 | "integrity": "sha512-ZfNfCWZ2Xq67VNvKMPiVMKHnMdvxYzvZkf1AH8/cw2NLDBm5LRsxMqvEJpsjLI/dUosZ3Z1d6JlHDp5rAvvk2w==", 1946 | "dev": true, 1947 | "requires": { 1948 | "deglob": "2.1.1", 1949 | "get-stdin": "6.0.0", 1950 | "minimist": "1.2.0", 1951 | "pkg-conf": "2.1.0" 1952 | }, 1953 | "dependencies": { 1954 | "minimist": { 1955 | "version": "1.2.0", 1956 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1957 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1958 | "dev": true 1959 | } 1960 | } 1961 | }, 1962 | "statuses": { 1963 | "version": "1.5.0", 1964 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1965 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1966 | }, 1967 | "string-width": { 1968 | "version": "2.1.1", 1969 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1970 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1971 | "dev": true, 1972 | "requires": { 1973 | "is-fullwidth-code-point": "2.0.0", 1974 | "strip-ansi": "4.0.0" 1975 | } 1976 | }, 1977 | "strip-ansi": { 1978 | "version": "4.0.0", 1979 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1980 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1981 | "dev": true, 1982 | "requires": { 1983 | "ansi-regex": "3.0.0" 1984 | }, 1985 | "dependencies": { 1986 | "ansi-regex": { 1987 | "version": "3.0.0", 1988 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1989 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1990 | "dev": true 1991 | } 1992 | } 1993 | }, 1994 | "strip-bom": { 1995 | "version": "3.0.0", 1996 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1997 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1998 | "dev": true 1999 | }, 2000 | "strip-json-comments": { 2001 | "version": "2.0.1", 2002 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2003 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2004 | "dev": true 2005 | }, 2006 | "supports-color": { 2007 | "version": "2.0.0", 2008 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 2009 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 2010 | "dev": true 2011 | }, 2012 | "symbol-observable": { 2013 | "version": "1.0.1", 2014 | "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.0.1.tgz", 2015 | "integrity": "sha1-g0D8RwLDEi310iKI+IKD9RPT/dQ=", 2016 | "dev": true 2017 | }, 2018 | "table": { 2019 | "version": "4.0.3", 2020 | "resolved": "http://registry.npmjs.org/table/-/table-4.0.3.tgz", 2021 | "integrity": "sha512-S7rnFITmBH1EnyKcvxBh1LjYeQMmnZtCXSEbHcH6S0NoKit24ZuFO/T1vDcLdYsLQkM188PVVhQmzKIuThNkKg==", 2022 | "dev": true, 2023 | "requires": { 2024 | "ajv": "6.5.5", 2025 | "ajv-keywords": "3.2.0", 2026 | "chalk": "2.4.1", 2027 | "lodash": "4.17.11", 2028 | "slice-ansi": "1.0.0", 2029 | "string-width": "2.1.1" 2030 | } 2031 | }, 2032 | "text-table": { 2033 | "version": "0.2.0", 2034 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2035 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2036 | "dev": true 2037 | }, 2038 | "through": { 2039 | "version": "2.3.8", 2040 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", 2041 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2042 | "dev": true 2043 | }, 2044 | "tmp": { 2045 | "version": "0.0.33", 2046 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2047 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2048 | "dev": true, 2049 | "requires": { 2050 | "os-tmpdir": "1.0.2" 2051 | } 2052 | }, 2053 | "toidentifier": { 2054 | "version": "1.0.0", 2055 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 2056 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 2057 | }, 2058 | "type-check": { 2059 | "version": "0.3.2", 2060 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2061 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2062 | "dev": true, 2063 | "requires": { 2064 | "prelude-ls": "1.1.2" 2065 | } 2066 | }, 2067 | "type-is": { 2068 | "version": "1.6.16", 2069 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz", 2070 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==", 2071 | "requires": { 2072 | "media-typer": "0.3.0", 2073 | "mime-types": "2.1.21" 2074 | } 2075 | }, 2076 | "uniq": { 2077 | "version": "1.0.1", 2078 | "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", 2079 | "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", 2080 | "dev": true 2081 | }, 2082 | "unpipe": { 2083 | "version": "1.0.0", 2084 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2085 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2086 | }, 2087 | "uri-js": { 2088 | "version": "4.2.2", 2089 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2090 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2091 | "dev": true, 2092 | "requires": { 2093 | "punycode": "2.1.1" 2094 | } 2095 | }, 2096 | "utils-merge": { 2097 | "version": "1.0.1", 2098 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2099 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 2100 | }, 2101 | "validate-npm-package-license": { 2102 | "version": "3.0.4", 2103 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2104 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2105 | "dev": true, 2106 | "requires": { 2107 | "spdx-correct": "3.0.2", 2108 | "spdx-expression-parse": "3.0.0" 2109 | } 2110 | }, 2111 | "vary": { 2112 | "version": "1.1.2", 2113 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2114 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2115 | }, 2116 | "which": { 2117 | "version": "1.3.1", 2118 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2119 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2120 | "dev": true, 2121 | "requires": { 2122 | "isexe": "2.0.0" 2123 | } 2124 | }, 2125 | "wordwrap": { 2126 | "version": "1.0.0", 2127 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2128 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 2129 | "dev": true 2130 | }, 2131 | "wrappy": { 2132 | "version": "1.0.2", 2133 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2134 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2135 | "dev": true 2136 | }, 2137 | "write": { 2138 | "version": "0.2.1", 2139 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", 2140 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", 2141 | "dev": true, 2142 | "requires": { 2143 | "mkdirp": "0.5.1" 2144 | } 2145 | }, 2146 | "xtend": { 2147 | "version": "4.0.1", 2148 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2149 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", 2150 | "dev": true 2151 | } 2152 | } 2153 | } 2154 | -------------------------------------------------------------------------------- /example/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "easygqlmock-demo", 3 | "version": "0.0.2", 4 | "description": "", 5 | "main": "src/App.js", 6 | "scripts": { 7 | "start": "node src/App.js", 8 | "test": "echo \"Error: no test specified\" && exit 1" 9 | }, 10 | "keywords": [ 11 | "nodejs", 12 | "graphql", 13 | "mock", 14 | "schema" 15 | ], 16 | "homepage": "https://github.com/EasyGraphQL/easygraphql-mock-demo", 17 | "author": { 18 | "name": "EasyGraphQL", 19 | "url": "https://github.com/EasyGraphQL" 20 | }, 21 | "repository": { 22 | "type": "git", 23 | "url": "https://github.com/EasyGraphQL/easygraphql-mock-demo" 24 | }, 25 | "bugs": { 26 | "url": "https://github.com/EasyGraphQL/easygraphql-mock-demo/issues" 27 | }, 28 | "license": "MIT", 29 | "dependencies": { 30 | "body-parser": "^1.18.2", 31 | "express": "^4.16.2", 32 | "express-graphql": "^0.8.0", 33 | "graphql": "^14.0.2", 34 | "graphql-type-json": "^0.3.0" 35 | }, 36 | "devDependencies": { 37 | "standard": "^12.0.1" 38 | } 39 | } 40 | -------------------------------------------------------------------------------- /example/src/App.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const express = require('express') 4 | const { buildSchema } = require('graphql') 5 | const graphqlHTTP = require('express-graphql') 6 | const bodyParser = require('body-parser') 7 | const fs = require('fs') 8 | const path = require('path') 9 | const root = require('./schema/resolvers') 10 | 11 | const app = express() 12 | 13 | app.set('port', 7000) 14 | app.use(bodyParser.json({ limit: '10mb' })) 15 | app.use(bodyParser.urlencoded({ extended: true })) 16 | 17 | const schemaCode = fs.readFileSync(path.join(__dirname, 'schema', 'schema.gql'), 'utf8') 18 | const schema = buildSchema(schemaCode) 19 | 20 | app.use('/', (req, res) => { 21 | graphqlHTTP({ 22 | schema, 23 | rootValue: root, 24 | graphiql: true, 25 | context: { schemaCode } 26 | })(req, res) 27 | }) 28 | 29 | const server = app.listen(app.get('port'), () => { 30 | console.log(`Server running -> PORT ${server.address().port}`) 31 | }) 32 | 33 | module.exports = app 34 | -------------------------------------------------------------------------------- /example/src/schema/resolvers/index.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const user = require('./user') 4 | 5 | const resolvers = { 6 | createUser: user.createUser, 7 | login: user.login, 8 | updatePassword: user.updatePassword, 9 | getMe: user.getMe, 10 | getUserByUsername: user.getUserByUsername 11 | } 12 | 13 | module.exports = resolvers 14 | -------------------------------------------------------------------------------- /example/src/schema/resolvers/user.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const mocker = require('../../../../index') 4 | 5 | const user = { 6 | createUser: ({ input }, { schemaCode }) => { 7 | const mock = mocker(schemaCode, { 8 | User: { 9 | email: input.email, 10 | username: input.username, 11 | fullName: input.fullName 12 | } 13 | }) 14 | 15 | return mock.User 16 | }, 17 | 18 | login: ({ input }, { schemaCode }) => { 19 | const mock = mocker(schemaCode, { 20 | Me: { 21 | email: input.email 22 | } 23 | }) 24 | 25 | return mock.Me 26 | }, 27 | 28 | updatePassword: ({ input }, { schemaCode }) => { 29 | const mock = mocker(schemaCode) 30 | 31 | return mock.Me 32 | }, 33 | 34 | getMe: async (args, { schemaCode }) => { 35 | const mock = mocker(schemaCode, { 36 | User: { 37 | email: 'test@test.com' 38 | } 39 | }) 40 | return mock.Me 41 | }, 42 | 43 | getUserByUsername: async (args, { schemaCode }) => { 44 | const mock = mocker(schemaCode, { 45 | User: { 46 | username: args.username 47 | } 48 | }) 49 | 50 | return mock.User 51 | } 52 | } 53 | 54 | module.exports = user 55 | -------------------------------------------------------------------------------- /example/src/schema/schema.gql: -------------------------------------------------------------------------------- 1 | scalar JSON 2 | 3 | type User { 4 | email: String! 5 | username: String! 6 | fullName: String! 7 | } 8 | 9 | type Me { 10 | id: ID! 11 | email: String! 12 | username: String! 13 | fullName: String! 14 | profession: String! 15 | gender: String! 16 | address: String! 17 | country: String! 18 | date: String! 19 | scores: [Int]! 20 | age: Int! 21 | phone: String! 22 | apiKey: String! 23 | familyInfo: FamilyInfo! 24 | } 25 | 26 | type FamilyInfo { 27 | father: User! 28 | mother: User! 29 | brothers: [User]! 30 | } 31 | 32 | # MUTATIONS 33 | 34 | # Create a new User 35 | input UserInput { 36 | email: String! 37 | username: String! 38 | fullName: String! 39 | password: String! 40 | } 41 | # Login 42 | input LoginInput { 43 | email: String! 44 | password: String! 45 | } 46 | # Update password 47 | input UpdatePasswordInput { 48 | oldPassword: String! 49 | newPassword: String! 50 | } 51 | 52 | type Query { 53 | getMe: Me 54 | getUserByUsername(username: String!): User 55 | } 56 | 57 | type Mutation { 58 | createUser(input: UserInput!): User 59 | login(input: LoginInput!): Me 60 | updatePassword(input: UpdatePasswordInput!): Me 61 | } 62 | -------------------------------------------------------------------------------- /greenkeeper.json: -------------------------------------------------------------------------------- 1 | { 2 | "groups": { 3 | "default": { 4 | "packages": [ 5 | "example/package.json", 6 | "package.json" 7 | ] 8 | } 9 | } 10 | } 11 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | module.exports = require('./lib') 4 | -------------------------------------------------------------------------------- /lib/index.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | module.exports = require('./mockBuilder') 4 | -------------------------------------------------------------------------------- /lib/mockBuilder.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const schemaParser = require('easygraphql-parser') 4 | const { memoizedField, clearMemoizedFields } = require('../util') 5 | 6 | function mockBuilder (schemaCode, customMock) { 7 | // Parse the schema on the GQL file to create a cutom object easier to loop 8 | // and create mocks. 9 | const schema = schemaParser(schemaCode) 10 | 11 | // This will be the result to return, when the mocks of the types are ready 12 | // those will be set to this object using as key the name of the type. 13 | const mockSchema = {} 14 | for (const type of Object.keys(schema)) { 15 | const mockField = memoizedField(type, customMock, schema) 16 | if (Object.keys(mockField).length > 0) { 17 | mockSchema[type] = mockField 18 | } 19 | } 20 | clearMemoizedFields() 21 | 22 | return mockSchema 23 | } 24 | 25 | module.exports = mockBuilder 26 | -------------------------------------------------------------------------------- /logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/EasyGraphQL/easygraphql-mock/b90d68af2080d78a0ec41aae04cc6bd1dd7def9b/logo.png -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "easygraphql-mock", 3 | "version": "0.1.17", 4 | "description": "Create mocks of your GraphQL Schema", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "nyc --check-coverage --lines 90 mocha", 8 | "standard": "standard", 9 | "standard-fix": "standard --fix", 10 | "coveralls": "nyc npm test && nyc report --reporter=text-lcov | coveralls" 11 | }, 12 | "husky": { 13 | "hooks": { 14 | "pre-commit": "npm run standard", 15 | "pre-push": "npm run test" 16 | } 17 | }, 18 | "standard": { 19 | "ignore": [ 20 | "/example/node_modules" 21 | ] 22 | }, 23 | "keywords": [ 24 | "nodejs", 25 | "graphql", 26 | "mock", 27 | "schema" 28 | ], 29 | "homepage": "https://github.com/EasyGraphQL/easygraphql-mock", 30 | "author": { 31 | "name": "EasyGraphQL", 32 | "url": "https://github.com/EasyGraphQL" 33 | }, 34 | "repository": { 35 | "type": "git", 36 | "url": "https://github.com/EasyGraphQL/easygraphql-mock" 37 | }, 38 | "bugs": { 39 | "url": "https://github.com/EasyGraphQL/easygraphql-mock/issues" 40 | }, 41 | "license": "MIT", 42 | "dependencies": { 43 | "chance": "^1.0.16", 44 | "easygraphql-parser": "^0.0.15" 45 | }, 46 | "devDependencies": { 47 | "chai": "^4.1.2", 48 | "coveralls": "^3.0.2", 49 | "graphql": "^15.3.0", 50 | "husky": "^3.0.0", 51 | "mocha": "^6.1.4", 52 | "nyc": "^14.1.1", 53 | "standard": "^12.0.1" 54 | } 55 | } 56 | -------------------------------------------------------------------------------- /test/arrMockBuilderSchemas.js: -------------------------------------------------------------------------------- 1 | /* eslint-env mocha */ 2 | /* eslint-disable no-unused-expressions */ 3 | 4 | 'use strict' 5 | 6 | const fs = require('fs') 7 | const path = require('path') 8 | const { expect } = require('chai') 9 | const easygqlmock = require('../lib/mockBuilder') 10 | 11 | const studentSchema = fs.readFileSync(path.join(__dirname, 'schema', 'student.gql'), 'utf8') 12 | const schoolSchema = fs.readFileSync(path.join(__dirname, 'schema', 'school.gql'), 'utf8') 13 | const locationSchema = fs.readFileSync(path.join(__dirname, 'schema', 'location.gql'), 'utf8') 14 | 15 | describe('Parse arr of schemas into one obj', () => { 16 | let mock 17 | 18 | before(() => { 19 | mock = easygqlmock([studentSchema, schoolSchema, locationSchema]) 20 | }) 21 | 22 | describe('Type Student', () => { 23 | it('Should have the Student', () => { 24 | expect(mock.Student).to.exist 25 | expect(mock.Student.email).to.be.a('string') 26 | expect(mock.Student.username).to.be.a('string') 27 | expect(mock.Student.fullName).to.be.a('string') 28 | }) 29 | }) 30 | 31 | describe('Type School', () => { 32 | it('Should have the school info', () => { 33 | expect(mock.School).to.exist 34 | expect(mock.School.name).to.be.a('string') 35 | expect(mock.School.location).to.exist 36 | expect(mock.School.location.id).to.be.a('string') 37 | expect(mock.School.users).to.be.a('array') 38 | expect(mock.School.users.length).to.be.gt(0) 39 | }) 40 | }) 41 | 42 | describe('Type Location', () => { 43 | it('Should have the location info', () => { 44 | expect(mock.Location).to.exist 45 | expect(mock.Location.id).to.be.a('string') 46 | expect(mock.Location.name).to.be.a('string') 47 | }) 48 | }) 49 | 50 | describe('Queries', () => { 51 | it('Should have all the queries', () => { 52 | expect(mock.Query.getStudentByUsername).to.exist 53 | expect(mock.Query.getStudents).to.exist 54 | expect(mock.Query.getSchoolByLocation).to.exist 55 | expect(mock.Query.getSchools).to.exist 56 | expect(mock.Query.getLocations).to.exist 57 | expect(mock.Query.search).to.exist 58 | expect(mock.Query.search.some(member => member.__typename === 'Student')).to.be.true 59 | expect(mock.Query.search.some(member => member.__typename === 'School')).to.be.true 60 | expect(mock.Query.search.some(member => member.__typename === 'Location')).to.be.true 61 | }) 62 | }) 63 | 64 | describe('Mutations', () => { 65 | it('Should have all the mutations', () => { 66 | expect(mock.Mutation.createStudent).to.exist 67 | expect(mock.Mutation.createStudents).to.exist 68 | expect(mock.Mutation.createSchool).to.exist 69 | expect(mock.Mutation.createLocation).to.exist 70 | }) 71 | }) 72 | }) 73 | -------------------------------------------------------------------------------- /test/boolean.js: -------------------------------------------------------------------------------- 1 | /* eslint-env mocha */ 2 | /* eslint-disable no-unused-expressions */ 3 | 4 | 'use strict' 5 | 6 | const { expect } = require('chai') 7 | const randomBooleanData = require('../util/randomData/boolean') 8 | 9 | describe('#Util', () => { 10 | describe('#randomBooleanData', () => { 11 | it('Should return an array of boolean', () => { 12 | const field = { 13 | isArray: true, 14 | noNull: true, 15 | name: 'age' 16 | } 17 | 18 | const booleanArr = randomBooleanData(field) 19 | 20 | expect(booleanArr).to.be.a('array') 21 | expect(booleanArr.length).to.be.gt(0) 22 | expect(booleanArr[0]).to.be.a('boolean') 23 | }) 24 | 25 | it('Can return null', () => { 26 | const field = { 27 | isArray: false, 28 | noNull: false, 29 | name: 'test' 30 | } 31 | 32 | const boolean = randomBooleanData(field) 33 | 34 | if (typeof boolean === 'boolean') { 35 | expect(boolean).to.be.a('boolean') 36 | } else { 37 | expect(boolean).to.be.null 38 | } 39 | }) 40 | }) 41 | }) 42 | -------------------------------------------------------------------------------- /test/mockBuilder.js: -------------------------------------------------------------------------------- 1 | /* eslint-env mocha */ 2 | /* eslint-disable no-unused-expressions */ 3 | 4 | 'use strict' 5 | 6 | const fs = require('fs') 7 | const path = require('path') 8 | const { expect } = require('chai') 9 | const easygqlmock = require('../lib/mockBuilder') 10 | 11 | const schemaCode = fs.readFileSync(path.join(__dirname, 'schema', 'schema.gql'), 'utf8') 12 | const invalidSchema = fs.readFileSync(path.join(__dirname, 'schema', 'invalidSchema.gql'), 'utf8') 13 | 14 | describe('Create a mock of GraphQL Schema', () => { 15 | let mock 16 | 17 | before(() => { 18 | mock = easygqlmock(schemaCode, { 19 | DateTime: '2018-10-10', 20 | Me: { 21 | id: '123', 22 | fullName: 'Hello World!', 23 | username: ['estrada9166'], 24 | result: 10 25 | }, 26 | Family: { 27 | name: 'Super test 1', 28 | ages: [10], 29 | familyRelation: 'Mother', 30 | familyRelationArr: ['Mother', 'Brother'] 31 | } 32 | }) 33 | }) 34 | 35 | describe('Type Me', () => { 36 | // type Me { 37 | // id: ID! 38 | // email: String 39 | // username: [String]! 40 | // fullName: String! 41 | // result: Float 42 | // phone: [Int]! 43 | // apiKey: String! 44 | // users: [User]! 45 | // verified: Boolean! 46 | // } 47 | 48 | it('Mock should have the type Me', () => { 49 | expect(mock.Me).to.exist 50 | expect(mock.Me.id).to.be.a('string') 51 | expect(mock.Me.id).to.be.eq('123') 52 | expect(mock.Me.username).to.be.a('array') 53 | expect(mock.Me.username[0]).to.be.a('string') 54 | expect(mock.Me.username[0]).to.be.eq('estrada9166') 55 | expect(mock.Me.fullName).to.be.a('string') 56 | expect(mock.Me.fullName).to.be.eq('Hello World!') 57 | expect(mock.Me.phone).to.be.a('array') 58 | expect(mock.Me.phone[0]).to.be.a('number') 59 | expect(mock.Me.apiKey).to.be.a('string') 60 | expect(mock.Me.users).to.exist 61 | expect(mock.Me.users[0].email).to.be.a('string') 62 | expect(mock.Me.users[0].family).to.exist 63 | expect(mock.Me.users[0].family.name).to.be.a('string') 64 | expect(['Father', 'Mother', 'Brother']).to.include(mock.Me.users[0].family.familyRelation) 65 | expect(mock.Me.verified).to.be.a('boolean') 66 | expect(mock.Me.createdAt).to.be.exist 67 | expect(mock.Me.createdAt).to.be.eq('2018-10-10') 68 | }) 69 | }) 70 | 71 | describe('Mock Type Family', () => { 72 | // enum FamilyRelation { 73 | // Father 74 | // Mother 75 | // Brother 76 | // } 77 | 78 | // type Family { 79 | // name: String! 80 | // ages: [Int]! 81 | // user: User! 82 | // familyRelation: FamilyRelation! 83 | // } 84 | 85 | it('Mock should have the type Family', () => { 86 | expect(mock.Family.name).to.be.eq('Super test 1') 87 | expect(mock.Family.ages).to.be.a('array') 88 | expect(mock.Family.ages[0]).to.be.eq(10) 89 | expect(['Father', 'Mother', 'Brother']).to.include(mock.Family.familyRelation) 90 | expect(['Father', 'Mother', 'Brother']).to.include(mock.Family.familyRelationArr[0]) 91 | expect(['Father', 'Mother', 'Brother']).to.include(mock.Family.familyRelationArr[1]) 92 | expect(mock.Family.familyRelation).to.be.eq('Mother') 93 | expect(mock.Family.user).to.exist 94 | expect(mock.Family.user.email).to.be.a('string') 95 | expect(mock.Family.user.family).to.exist 96 | expect(mock.Family.user.family.name).to.be.a('string') 97 | expect(mock.Family.user.family.ages).to.be.a('array') 98 | expect(mock.Family.user.family.ages.length).to.be.gte(1) 99 | expect(['Father', 'Mother', 'Brother']).to.include(mock.Family.user.family.familyRelation) 100 | expect(mock.Family.user.family.familyRelationArr).to.be.a('array') 101 | }) 102 | }) 103 | 104 | describe('Type User', () => { 105 | // type User { 106 | // me: Me! 107 | // email: String! 108 | // username: String! 109 | // fullName: String! 110 | // phone: String! 111 | // family: Family! 112 | // } 113 | 114 | it('Mock should have the type User', () => { 115 | expect(mock.User).to.exist 116 | expect(mock.User.email).to.be.a('string') 117 | expect(mock.User.username).to.be.a('string') 118 | expect(mock.User.fullName).to.be.a('string') 119 | expect(mock.User.phone).to.be.a('string') 120 | }) 121 | 122 | it('User mock should have the family type with a user mock nested', () => { 123 | expect(mock.User.family).to.exist 124 | expect(mock.User.family.name).to.be.a('string') 125 | expect(mock.User.family.ages).to.be.a('array') 126 | expect(mock.User.family.user).to.exist 127 | expect(mock.User.family.user.email).to.be.a('string') 128 | expect(mock.User.family.user.username).to.be.a('string') 129 | expect(mock.User.family.user.fullName).to.be.a('string') 130 | expect(mock.User.family.user.phone).to.be.a('string') 131 | }) 132 | 133 | it('User mock should reference a Me mock with full set of mocked fields', () => { 134 | expect(mock.User.me).to.exist 135 | expect(mock.User.me.id).to.be.a('string') 136 | expect(mock.User.me.id).to.be.eq('123') 137 | expect(mock.User.me.username).to.be.a('array') 138 | expect(mock.User.me.username[0]).to.be.a('string') 139 | expect(mock.User.me.username[0]).to.be.eq('estrada9166') 140 | expect(mock.User.me.fullName).to.be.a('string') 141 | expect(mock.User.me.fullName).to.be.eq('Hello World!') 142 | expect(mock.User.me.phone).to.be.a('array') 143 | expect(mock.User.me.phone[0]).to.be.a('number') 144 | expect(mock.User.me.apiKey).to.be.a('string') 145 | expect(mock.User.me.users).to.exist 146 | expect(mock.User.me.users[0].email).to.be.a('string') 147 | expect(mock.User.me.users[0].family).to.exist 148 | expect(mock.User.me.users[0].family.name).to.be.a('string') 149 | expect(['Father', 'Mother', 'Brother']).to.include(mock.User.me.users[0].family.familyRelation) 150 | expect(mock.User.me.verified).to.be.a('boolean') 151 | }) 152 | }) 153 | 154 | describe('Type UserInput', () => { 155 | // input UserInput { 156 | // email: String! 157 | // username: String! 158 | // fullName: String! 159 | // password: String! 160 | // } 161 | 162 | it('Mock should have the type UserInput', () => { 163 | expect(mock.UserInput).to.exist 164 | expect(mock.UserInput.email).to.be.a('string') 165 | expect(mock.UserInput.username).to.be.a('string') 166 | expect(mock.UserInput.fullName).to.be.a('string') 167 | expect(mock.UserInput.password).to.be.a('string') 168 | }) 169 | }) 170 | 171 | describe('Type LoginInput', () => { 172 | // input LoginInput { 173 | // email: String! 174 | // password: String! 175 | // } 176 | 177 | it('Mock should have the type LoginInput', () => { 178 | expect(mock.LoginInput).to.exist 179 | expect(mock.LoginInput.email).to.be.a('string') 180 | expect(mock.LoginInput.password).to.be.a('string') 181 | }) 182 | }) 183 | 184 | describe('Type UpdatePasswordInput', () => { 185 | // input UpdatePasswordInput { 186 | // oldPassword: String! 187 | // newPassword: String! 188 | // } 189 | 190 | it('Mock should have the type UpdatePasswordInput', () => { 191 | expect(mock.UpdatePasswordInput).to.exist 192 | expect(mock.UpdatePasswordInput.oldPassword).to.be.a('string') 193 | expect(mock.UpdatePasswordInput.newPassword).to.be.a('string') 194 | }) 195 | }) 196 | }) 197 | 198 | describe('It should fail if there is a type missing on the schema', () => { 199 | it('Should fail if User is missing on schema', () => { 200 | let error 201 | try { 202 | easygqlmock(invalidSchema) 203 | } catch (err) { 204 | error = err 205 | } 206 | 207 | expect(error).to.exist 208 | expect(error.message).to.be.eq('Type "User" not found in document.') 209 | }) 210 | }) 211 | -------------------------------------------------------------------------------- /test/mockBuilderSchemaJS.js: -------------------------------------------------------------------------------- 1 | /* eslint-env mocha */ 2 | /* eslint-disable no-unused-expressions */ 3 | 4 | 'use strict' 5 | 6 | const { expect } = require('chai') 7 | const easygqlmock = require('../lib/mockBuilder') 8 | 9 | const schemaCode = require('./schema-js') 10 | 11 | describe('Create a mock of GraphQL Schema', () => { 12 | let mock 13 | 14 | before(() => { 15 | mock = easygqlmock(schemaCode) 16 | }) 17 | 18 | describe('Type User', () => { 19 | it('Mock should have the type User', () => { 20 | expect(mock.User).to.exist 21 | expect(mock.User.email).to.be.a('string') 22 | expect(mock.User.fullName).to.be.a('string') 23 | expect(mock.User.username).to.be.a('string') 24 | }) 25 | }) 26 | }) 27 | -------------------------------------------------------------------------------- /test/multiplesSchemas.js: -------------------------------------------------------------------------------- 1 | /* eslint-env mocha */ 2 | /* eslint-disable no-unused-expressions */ 3 | 4 | 'use strict' 5 | 6 | const { expect } = require('chai') 7 | const easygraphqlMock = require('../lib/mockBuilder') 8 | 9 | describe('#Multilples schemas', () => { 10 | const schema1 = ` 11 | type Author { 12 | name: String! 13 | } 14 | ` 15 | 16 | const schema2 = ` 17 | type Author { 18 | title: String! 19 | favoriteProject: Project! 20 | } 21 | 22 | type Project { 23 | name: String! 24 | } 25 | ` 26 | 27 | it('Should return schema1 info', () => { 28 | const mockedSchema1 = easygraphqlMock(schema1) 29 | 30 | expect(mockedSchema1.Author.name).to.be.a('string') 31 | }) 32 | 33 | it('Should return schema2 info', () => { 34 | const mockedSchema2 = easygraphqlMock(schema2) 35 | 36 | expect(mockedSchema2.Author.title).to.be.a('string') 37 | expect(mockedSchema2.Author.favoriteProject).to.be.an('object') 38 | expect(mockedSchema2.Author.favoriteProject.name).to.be.a('string') 39 | expect(mockedSchema2.Project.name).to.be.a('string') 40 | }) 41 | }) 42 | -------------------------------------------------------------------------------- /test/number.js: -------------------------------------------------------------------------------- 1 | /* eslint-env mocha */ 2 | /* eslint-disable no-unused-expressions */ 3 | 4 | 'use strict' 5 | 6 | const { expect } = require('chai') 7 | const randomNumberData = require('../util/randomData/number') 8 | 9 | describe('#Util', () => { 10 | describe('#randomNumberData', () => { 11 | it('Should return an array of numbers with age', () => { 12 | const field = { 13 | isArray: true, 14 | noNull: true, 15 | name: 'age' 16 | } 17 | 18 | const numberArr = randomNumberData(field) 19 | 20 | expect(numberArr).to.be.a('array') 21 | expect(numberArr.length).to.be.gt(0) 22 | expect(numberArr[0]).to.be.a('number') 23 | }) 24 | 25 | it('Can return null', () => { 26 | const field = { 27 | isArray: false, 28 | noNull: false, 29 | name: 'test' 30 | } 31 | 32 | const number = randomNumberData(field) 33 | 34 | if (typeof number === 'number') { 35 | expect(number).to.be.a('number') 36 | } else { 37 | expect(number).to.be.null 38 | } 39 | }) 40 | 41 | it('Should return an random float number', () => { 42 | const field = { 43 | isArray: false, 44 | noNull: true, 45 | name: 'test' 46 | } 47 | 48 | const number = randomNumberData(field, true) 49 | 50 | expect(number).to.be.a('number') 51 | expect(number).to.be.gt(0) 52 | }) 53 | 54 | it('Should return an random number', () => { 55 | const field = { 56 | isArray: false, 57 | noNull: true, 58 | name: 'test' 59 | } 60 | 61 | const number = randomNumberData(field) 62 | 63 | expect(number).to.be.a('number') 64 | }) 65 | 66 | it('Should return a timestamp number', () => { 67 | const field = { 68 | isArray: false, 69 | noNull: true, 70 | name: 'timestamp' 71 | } 72 | 73 | const number = randomNumberData(field) 74 | 75 | expect(number).to.be.a('number') 76 | expect(number).to.be.gt(0) 77 | }) 78 | 79 | it('Should return a hammertime number', () => { 80 | const field = { 81 | isArray: false, 82 | noNull: true, 83 | name: 'hammertime' 84 | } 85 | 86 | const number = randomNumberData(field) 87 | 88 | expect(number).to.be.a('number') 89 | expect(number).to.be.gt(0) 90 | }) 91 | 92 | it('Should return a hour number', () => { 93 | const field = { 94 | isArray: false, 95 | noNull: true, 96 | name: 'hour' 97 | } 98 | 99 | const number = randomNumberData(field) 100 | 101 | expect(number).to.be.a('number') 102 | expect(number).to.be.gte(0) 103 | expect(number).to.be.lt(24) 104 | }) 105 | 106 | it('Should return a minute number', () => { 107 | const field = { 108 | isArray: false, 109 | noNull: true, 110 | name: 'minute' 111 | } 112 | 113 | const number = randomNumberData(field) 114 | 115 | expect(number).to.be.a('number') 116 | expect(number).to.be.gte(0) 117 | expect(number).to.be.lt(60) 118 | }) 119 | 120 | it('Should return a second number', () => { 121 | const field = { 122 | isArray: false, 123 | noNull: true, 124 | name: 'second' 125 | } 126 | 127 | const number = randomNumberData(field) 128 | 129 | expect(number).to.be.a('number') 130 | expect(number).to.be.gte(0) 131 | expect(number).to.be.lt(60) 132 | }) 133 | 134 | it('Should return a millisecond number', () => { 135 | const field = { 136 | isArray: false, 137 | noNull: true, 138 | name: 'millisecond' 139 | } 140 | 141 | const number = randomNumberData(field) 142 | 143 | expect(number).to.be.a('number') 144 | expect(number).to.be.gte(0) 145 | expect(number).to.be.lt(1000) 146 | }) 147 | 148 | it('Should return a year number', () => { 149 | const field = { 150 | isArray: false, 151 | noNull: true, 152 | name: 'year' 153 | } 154 | 155 | const number = randomNumberData(field) 156 | 157 | expect(number).to.be.a('number') 158 | expect(number).to.be.gte(0) 159 | expect(number).to.be.lt(2300) 160 | }) 161 | }) 162 | }) 163 | -------------------------------------------------------------------------------- /test/schema-js/index.js: -------------------------------------------------------------------------------- 1 | const { GraphQLSchema, GraphQLObjectType } = require('graphql') 2 | 3 | const GetUserQuery = require('./queries/getUser') 4 | const CreateUserMutation = require('./mutations/createUser') 5 | 6 | const RootQueryType = new GraphQLObjectType({ 7 | name: 'RootQuery', 8 | fields: () => ({ 9 | getUser: GetUserQuery 10 | }) 11 | }) 12 | 13 | const RootMutationType = new GraphQLObjectType({ 14 | name: 'RootMutation', 15 | fields: () => ({ 16 | createUser: CreateUserMutation 17 | }) 18 | }) 19 | 20 | const schema = new GraphQLSchema({ 21 | query: RootQueryType, 22 | mutation: RootMutationType 23 | }) 24 | 25 | module.exports = schema 26 | -------------------------------------------------------------------------------- /test/schema-js/mutations/createUser.js: -------------------------------------------------------------------------------- 1 | const { 2 | GraphQLInputObjectType, 3 | GraphQLString, 4 | GraphQLNonNull 5 | } = require('graphql') 6 | 7 | const UserType = require('../types/userType') 8 | 9 | const UserInputType = new GraphQLInputObjectType({ 10 | name: 'UserInput', 11 | fields: { 12 | email: { type: GraphQLNonNull(GraphQLString) }, 13 | username: { type: GraphQLNonNull(GraphQLString) }, 14 | fullName: { type: GraphQLNonNull(GraphQLString) }, 15 | password: { type: GraphQLNonNull(GraphQLString) } 16 | } 17 | }) 18 | 19 | module.exports = { 20 | type: UserType, 21 | args: { 22 | input: { type: new GraphQLNonNull(UserInputType) } 23 | }, 24 | resolve: async (obj, { input }, ctx) => { 25 | const { email, username, fullName } = input 26 | 27 | return { 28 | email, 29 | username, 30 | fullName 31 | } 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /test/schema-js/queries/getUser.js: -------------------------------------------------------------------------------- 1 | const UserType = require('../types/userType') 2 | 3 | module.exports = { 4 | type: UserType, 5 | description: 'This query will get the current user', 6 | resolve (obj, args, ctx) { 7 | return { 8 | email: 'demo@demo.com', 9 | username: 'demo', 10 | fullName: 'demo' 11 | } 12 | } 13 | } 14 | -------------------------------------------------------------------------------- /test/schema-js/types/userType.js: -------------------------------------------------------------------------------- 1 | const { 2 | GraphQLObjectType, 3 | GraphQLString, 4 | GraphQLNonNull 5 | } = require('graphql') 6 | 7 | const UserType = new GraphQLObjectType({ 8 | name: 'User', 9 | fields: () => { 10 | return { 11 | email: { type: GraphQLNonNull(GraphQLString) }, 12 | username: { type: GraphQLNonNull(GraphQLString) }, 13 | fullName: { type: GraphQLNonNull(GraphQLString) } 14 | } 15 | } 16 | }) 17 | 18 | module.exports = UserType 19 | -------------------------------------------------------------------------------- /test/schema/invalidSchema.gql: -------------------------------------------------------------------------------- 1 | type City { 2 | id: ID! 3 | name: String! 4 | user: User! 5 | } 6 | 7 | extend type Query { 8 | getLocations: [City]! 9 | } 10 | -------------------------------------------------------------------------------- /test/schema/location.gql: -------------------------------------------------------------------------------- 1 | type Location { 2 | id: ID! 3 | name: String! 4 | } 5 | 6 | input CreateLocationInput { 7 | name: String! 8 | } 9 | 10 | extend type Query { 11 | getLocations: [Location]! 12 | } 13 | 14 | extend type Mutation { 15 | createLocation(input: CreateLocationInput!): Location! 16 | } 17 | -------------------------------------------------------------------------------- /test/schema/schema.gql: -------------------------------------------------------------------------------- 1 | scalar DateTime 2 | 3 | enum FamilyRelation { 4 | Father 5 | Mother 6 | Brother 7 | } 8 | 9 | type Family { 10 | name: String! 11 | ages: [Int]! 12 | user: User! 13 | familyRelation: FamilyRelation! 14 | familyRelationArr: [FamilyRelation]! 15 | } 16 | 17 | type Me { 18 | id: ID! 19 | email: String 20 | username: [String]! 21 | fullName: String! 22 | result: Float 23 | phone: [Int]! 24 | apiKey: String! 25 | users: [User]! 26 | verified: Boolean! 27 | createdAt: DateTime! 28 | } 29 | 30 | type User { 31 | me: Me! 32 | email: String! 33 | username: String! 34 | fullName: String! 35 | phone: String! 36 | family: Family! 37 | } 38 | 39 | # MUTATIONS 40 | 41 | # Create a new User 42 | input UserInput { 43 | email: String! 44 | username: String! 45 | fullName: String! 46 | password: String! 47 | } 48 | # Login 49 | input LoginInput { 50 | email: String! 51 | password: String! 52 | } 53 | # Update password 54 | input UpdatePasswordInput { 55 | oldPassword: String! 56 | newPassword: String! 57 | } 58 | 59 | type Query { 60 | getMe: Me 61 | getUserByUsername(username: String!, id: Int!): User 62 | } 63 | 64 | type Mutation { 65 | createUser(input: UserInput!): Me 66 | login(input: LoginInput!): Me 67 | updatePassword(input: UpdatePasswordInput!): Me 68 | } 69 | 70 | schema { 71 | query: Query 72 | mutation: Mutation 73 | } 74 | -------------------------------------------------------------------------------- /test/schema/school.gql: -------------------------------------------------------------------------------- 1 | type School { 2 | name: String! 3 | location: Location! 4 | users: [Student]! 5 | } 6 | 7 | input CreateSchoolInput { 8 | name: String! 9 | location: String! 10 | } 11 | 12 | extend type Query { 13 | getSchoolByLocation(location: String!): School! 14 | getSchools: [School]! 15 | } 16 | 17 | extend type Mutation { 18 | createSchool(input: CreateSchoolInput!): School! 19 | } 20 | -------------------------------------------------------------------------------- /test/schema/student.gql: -------------------------------------------------------------------------------- 1 | union SearchResult = Student | School | Location 2 | 3 | type Student { 4 | email: String! 5 | username: String! 6 | fullName: String! 7 | } 8 | 9 | input StudentInput { 10 | email: String! 11 | username: String! 12 | fullName: String! 13 | password: String! 14 | } 15 | 16 | type Query { 17 | getStudentByUsername(username: String!, name: String!): Student 18 | getStudents: [Student]! 19 | search(nname: String!): [SearchResult]! 20 | } 21 | 22 | type Mutation { 23 | createStudent(input: StudentInput!): Student 24 | createStudents(input: [StudentInput]!): [Student]! 25 | } 26 | -------------------------------------------------------------------------------- /test/string.js: -------------------------------------------------------------------------------- 1 | /* eslint-env mocha */ 2 | /* eslint-disable no-unused-expressions */ 3 | 4 | 'use strict' 5 | 6 | const { expect } = require('chai') 7 | const randomStringData = require('../util/randomData/string') 8 | 9 | describe('#Util', () => { 10 | describe('#randomStringData', () => { 11 | it('Should return an array of strings with full names', () => { 12 | const field = { 13 | isArray: true, 14 | noNull: true, 15 | name: 'fullName' 16 | } 17 | 18 | const stringArr = randomStringData(field) 19 | 20 | expect(stringArr).to.be.a('array') 21 | expect(stringArr.length).to.be.gt(0) 22 | expect(stringArr[0]).to.be.a('string') 23 | }) 24 | 25 | it('Should create a number string', () => { 26 | const field = { 27 | isArray: false, 28 | noNull: true, 29 | name: 'id' 30 | } 31 | 32 | const string = randomStringData(field) 33 | 34 | expect(string).to.be.a('string') 35 | expect(string.length).to.be.gt(0) 36 | expect(parseInt(string)).to.be.a('number') 37 | }) 38 | 39 | it('Should create a lastname string', () => { 40 | const field = { 41 | isArray: false, 42 | noNull: true, 43 | name: 'last' 44 | } 45 | 46 | const string = randomStringData(field) 47 | 48 | expect(string).to.be.a('string') 49 | expect(string.length).to.be.gt(0) 50 | }) 51 | 52 | it('Should create a gender string', () => { 53 | const field = { 54 | isArray: false, 55 | noNull: true, 56 | name: 'gender' 57 | } 58 | 59 | const string = randomStringData(field) 60 | 61 | expect(string).to.be.a('string') 62 | expect(string.length).to.be.gt(0) 63 | }) 64 | 65 | it('Should create a prefix string', () => { 66 | const field = { 67 | isArray: false, 68 | noNull: true, 69 | name: 'prefix' 70 | } 71 | 72 | const string = randomStringData(field) 73 | 74 | expect(string).to.be.a('string') 75 | expect(string.length).to.be.gt(0) 76 | }) 77 | 78 | it('Should create a phone string', () => { 79 | const field = { 80 | isArray: false, 81 | noNull: true, 82 | name: 'phone' 83 | } 84 | 85 | const string = randomStringData(field) 86 | 87 | expect(string).to.be.a('string') 88 | expect(string.length).to.be.gt(0) 89 | expect(string).to.include('-') 90 | }) 91 | 92 | it('Should create a profession string', () => { 93 | const field = { 94 | isArray: false, 95 | noNull: true, 96 | name: 'profession' 97 | } 98 | 99 | const string = randomStringData(field) 100 | 101 | expect(string).to.be.a('string') 102 | expect(string.length).to.be.gt(0) 103 | }) 104 | 105 | it('Should create a date string', () => { 106 | const field = { 107 | isArray: false, 108 | noNull: true, 109 | name: 'date' 110 | } 111 | 112 | const string = randomStringData(field) 113 | 114 | expect(string).to.be.a('string') 115 | expect(string.length).to.be.gt(0) 116 | }) 117 | 118 | it('Should create a address string', () => { 119 | const field = { 120 | isArray: false, 121 | noNull: true, 122 | name: 'address' 123 | } 124 | 125 | const string = randomStringData(field) 126 | 127 | expect(string).to.be.a('string') 128 | expect(string.length).to.be.gt(0) 129 | }) 130 | 131 | it('Should create a city string', () => { 132 | const field = { 133 | isArray: false, 134 | noNull: true, 135 | name: 'city' 136 | } 137 | 138 | const string = randomStringData(field) 139 | 140 | expect(string).to.be.a('string') 141 | expect(string.length).to.be.gt(0) 142 | }) 143 | 144 | it('Should create a country string', () => { 145 | const field = { 146 | isArray: false, 147 | noNull: true, 148 | name: 'country' 149 | } 150 | 151 | const string = randomStringData(field) 152 | 153 | expect(string).to.be.a('string') 154 | expect(string.length).to.be.gt(0) 155 | }) 156 | 157 | it('Should create a random string', () => { 158 | const field = { 159 | isArray: false, 160 | noNull: true, 161 | name: 'test' 162 | } 163 | 164 | const string = randomStringData(field) 165 | 166 | expect(string).to.be.a('string') 167 | expect(string.length).to.be.gt(0) 168 | }) 169 | }) 170 | 171 | it('Should create a timezone string', () => { 172 | const field = { 173 | isArray: false, 174 | noNull: true, 175 | name: 'timezone' 176 | } 177 | 178 | const string = randomStringData(field) 179 | 180 | expect(string).to.be.a('string') 181 | expect(string.length).to.be.gt(0) 182 | }) 183 | 184 | it('Should create a weekday string', () => { 185 | const field = { 186 | isArray: false, 187 | noNull: true, 188 | name: 'weekday' 189 | } 190 | 191 | const string = randomStringData(field) 192 | 193 | expect(string).to.be.a('string') 194 | expect(string).to.be.oneOf(['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']) 195 | }) 196 | }) 197 | -------------------------------------------------------------------------------- /util/constants.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const constants = { 4 | ID: 'ID', 5 | id: 'id', 6 | string: 'String', 7 | int: 'Int', 8 | number: 'number', 9 | float: 'Float', 10 | boolean: 'Boolean', 11 | email: 'email', 12 | emails: 'emails', 13 | phone: 'phone', 14 | phones: 'phones', 15 | name: 'name', 16 | names: 'names', 17 | first: 'first', 18 | firstName: 'firstname', 19 | lastName: 'lastname', 20 | last: 'last', 21 | fullName: 'fullname', 22 | fullNames: 'fullnames', 23 | age: 'age', 24 | ages: 'ages', 25 | gender: 'gender', 26 | genders: 'genders', 27 | prefix: 'prefix', 28 | prefixes: 'prefixes', 29 | profession: 'profession', 30 | professions: 'professions', 31 | date: 'date', 32 | dates: 'dates', 33 | address: 'address', 34 | addresses: 'addresses', 35 | city: 'city', 36 | cities: 'cities', 37 | country: 'country', 38 | countries: 'countries', 39 | timestamp: 'timestamp', 40 | timestamps: 'timestamps', 41 | hammertime: 'hammertime', 42 | hammertimes: 'hammertimes', 43 | timezone: 'timezone', 44 | timezones: 'timezones', 45 | weekday: 'weekday', 46 | weekdays: 'weekdays', 47 | hour: 'hour', 48 | hours: 'hours', 49 | minute: 'minute', 50 | minutes: 'minutes', 51 | second: 'second', 52 | seconds: 'seconds', 53 | millisecond: 'millisecond', 54 | milliseconds: 'milliseconds', 55 | year: 'year', 56 | years: 'years' 57 | } 58 | 59 | module.exports = constants 60 | -------------------------------------------------------------------------------- /util/customMock.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable valid-typeof */ 2 | const constants = require('./constants') 3 | 4 | // Convert the type of the field to return the type and check the typeof 5 | function fieldTypes (type) { 6 | switch (type) { 7 | case constants.ID: 8 | case constants.string: 9 | return 'string' 10 | 11 | case constants.int: 12 | case constants.float: 13 | return 'number' 14 | 15 | default: 16 | } 17 | } 18 | 19 | function getCustomMockData (field, schemaName, customMock, schema) { 20 | const mockedVal = customMock[schemaName][field.name] 21 | 22 | // Validate if the field can't be null and the passed value doesn't exists 23 | // or is null. 24 | if (field.noNull && !mockedVal) { 25 | throw new Error(`Field name ${field.name.toUpperCase()} must have a value`) 26 | } 27 | 28 | // Validate if the field must be an array and the passed value is not. 29 | if (field.isArray && !Array.isArray(mockedVal)) { 30 | throw new Error(`Field name ${field.name.toUpperCase()} type that is defined 31 | in the options is not valid, it must be an array` 32 | ) 33 | } 34 | 35 | // Validate if each value inside the array is the same type as it should be 36 | // on the schema. 37 | if (field.isArray) { 38 | mockedVal.forEach(element => { 39 | // First validate if the field is enum value, in case that it is, check if 40 | // the values of it exist on the schema enum. 41 | if (schema[field.type] && schema[field.type].values.length > 0) { 42 | if (!schema[field.type].values.some(val => val === element)) { 43 | throw new Error(`The value ${element.toUpperCase()} is not on the 44 | enum ${field.type}` 45 | ) 46 | } 47 | } else if (typeof element !== fieldTypes(field.type)) { 48 | throw new Error(`Field name ${field.name.toUpperCase()} values on the 49 | array are different on the Schema` 50 | ) 51 | } 52 | }) 53 | } 54 | 55 | // Validate that the field is enum, in case it is, check that the mocked value 56 | // exists on the enum values and return it. 57 | if (!field.isArray && schema[field.type] && schema[field.type].values.length > 0) { 58 | if (!schema[field.type].values.some(val => val === mockedVal)) { 59 | throw new Error(`The value ${mockedVal.toUpperCase()} is not on the 60 | enum ${field.type}` 61 | ) 62 | } 63 | return mockedVal 64 | } 65 | 66 | // Validate that the type of value mocked is the same as the one deffined on 67 | // the schema. 68 | if (!field.isArray && typeof mockedVal !== fieldTypes(field.type)) { 69 | throw new Error(`Field name ${field.name.toUpperCase()} type is different 70 | on the Schema` 71 | ) 72 | } 73 | 74 | // If the mocked value pass all the validations, it is ready to be returned! 75 | return mockedVal 76 | } 77 | 78 | module.exports = getCustomMockData 79 | -------------------------------------------------------------------------------- /util/index.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable valid-typeof */ 2 | 'use strict' 3 | 4 | const getCustomMockData = require('./customMock') 5 | const constants = require('./constants') 6 | const randomStringData = require('./randomData/string') 7 | const randomNumberData = require('./randomData/number') 8 | const randomBooleanData = require('./randomData/boolean') 9 | const { randomNumber } = require('./utils') 10 | 11 | let cache = {} 12 | const memoize = (fn) => { 13 | return (type, customMock, schema) => { 14 | if (type in cache) { 15 | return cache[type] 16 | } else { 17 | // To handle cycles in schema types put a reference to the mocked field in 18 | // the cache before attempting to compute its properties. 19 | const result = {} 20 | if (schema[type].type === 'InterfaceTypeDefinition' && schema[type].implementedTypes.length) { 21 | result['__typename'] = schema[type].implementedTypes[0] 22 | } else { 23 | result['__typename'] = type 24 | } 25 | cache[type] = result 26 | const mock = fn(type, customMock, schema) 27 | Object.assign(result, mock) 28 | return result 29 | } 30 | } 31 | } 32 | 33 | const clearMemoizedFields = () => { 34 | cache = {} 35 | } 36 | 37 | const mockedField = (type, customMock, schema) => { 38 | // This will be the result of each field inside the type, the key is going to 39 | // be the same name that is set inside the type. 40 | const mockField = {} 41 | // Validate if the type have fields that need to be mocked. 42 | if (schema[type].fields && schema[type].fields.length > 0) { 43 | schema[type].fields.forEach(field => { 44 | const data = createData(field, type, customMock, schema) 45 | if (data === undefined) { 46 | throw new Error(`Type "${field.type}" not found in document.`) 47 | } 48 | // If the mocked value is valid, it will be asigned to the field name. 49 | mockField[field.name] = data 50 | }) 51 | } 52 | return mockField 53 | } 54 | 55 | const memoizedField = memoize(mockedField) 56 | 57 | function createData (field, schemaName, customMock = {}, schema) { 58 | // Validate if the field is a scalar, if it's validate if there is a custom 59 | // value to assign to it. 60 | if ( 61 | schema[field.type] && 62 | schema[field.type].type === 'ScalarTypeDefinition' && 63 | customMock[field.type] 64 | ) { 65 | return customMock[field.type] 66 | } 67 | // Validate if the schema name exists on the custom mock and also check if the 68 | // actual field exists, in case that it exists, make the validations to set it 69 | // as result. 70 | if (customMock[schemaName] && customMock[schemaName][field.name]) { 71 | return getCustomMockData(field, schemaName, customMock, schema) 72 | } 73 | 74 | // Handle the existing types, if it is not one of the regular ones it should be 75 | // a nested one, so the default must handle it. 76 | switch (field.type) { 77 | // The ID type is string by default on GraphQL. 78 | case constants.ID: 79 | case constants.string: 80 | return randomStringData(field) 81 | 82 | case constants.int: 83 | return randomNumberData(field) 84 | 85 | case constants.float: 86 | return randomNumberData(field, true) 87 | 88 | case constants.boolean: 89 | return randomBooleanData(field) 90 | 91 | default: 92 | // In case that the type is not found, check if it exists on the schema, 93 | // and visit that node; in case it is an array, create it. 94 | if (schema[field.type]) { 95 | if (field.isArray) { 96 | const arrLength = randomNumber(1, 3) 97 | const dataArr = [] 98 | for (let i = 0; i < arrLength; i++) { 99 | // Validate if is enun value 100 | if (schema[field.type].values.length > 0) { 101 | dataArr.push(selecteEnumVal(field, schema)) 102 | // validate if is union 103 | } else if (schema[field.type].types.length > 0) { 104 | const types = getUnionVals(field, schema) 105 | types.forEach(type => 106 | dataArr.push(memoizedField(type, customMock, schema)) 107 | ) 108 | } else { 109 | dataArr.push( 110 | memoizedField(field.type, customMock, schema) 111 | ) 112 | } 113 | } 114 | return dataArr 115 | } 116 | 117 | // Before looking for a nested type, validate if the field is a enum on 118 | // the schema, and if it has defined values, in that case, we can choose 119 | // an existing value. 120 | if (schema[field.type].values.length > 0) { 121 | return selecteEnumVal(field, schema) 122 | } 123 | 124 | // If the nensted type is an union, the values that are going to be assigned 125 | // are going to be one of each type inside the union. 126 | if (schema[field.type].types.length > 0) { 127 | const type = getUnionVal(field, schema) 128 | return memoizedField(type, customMock, schema) 129 | } 130 | 131 | // To handle a nested data, we might pass, the fields of the nested data, 132 | // The field.type that is going to be the new schema name, also the custom mock, 133 | // the complete schema and the deep level to prevent an infint loop. 134 | return memoizedField(field.type, customMock, schema) 135 | } 136 | } 137 | } 138 | 139 | function selecteEnumVal (field, schema) { 140 | const values = schema[field.type].values 141 | const selectedValue = randomNumber(0, values.length - 1) 142 | return values[selectedValue] 143 | } 144 | 145 | function getUnionVal (field, schema) { 146 | const types = schema[field.type].types 147 | const selectedValue = randomNumber(0, types.length - 1) 148 | return types[selectedValue] 149 | } 150 | 151 | function getUnionVals (field, schema) { 152 | return schema[field.type].types 153 | } 154 | 155 | module.exports = { memoizedField, clearMemoizedFields } 156 | -------------------------------------------------------------------------------- /util/randomData/boolean.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const { randomNumber } = require('../utils') 4 | 5 | function randomBooleanData (field) { 6 | let data 7 | 8 | // If it is an array, create a random length array of strings 9 | if (field.isArray) { 10 | const arrLength = randomNumber(1, 10) 11 | const dataArr = [] 12 | for (let i = 0; i < arrLength; i++) { 13 | dataArr.push(createRandomBoolean()) 14 | } 15 | data = dataArr 16 | } else { 17 | data = createRandomBoolean() 18 | } 19 | 20 | // If the field can be null, randomly return null or the random string 21 | if (!field.noNull) { 22 | const selectedAnswer = randomNumber(0, 1) 23 | return [null, data][selectedAnswer] 24 | } 25 | return data 26 | } 27 | 28 | function createRandomBoolean () { 29 | const selectedAnswer = randomNumber(0, 1) 30 | return [true, false][selectedAnswer] 31 | } 32 | 33 | module.exports = randomBooleanData 34 | -------------------------------------------------------------------------------- /util/randomData/number.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const Chance = require('chance') 4 | const constants = require('../constants') 5 | const { randomNumber } = require('../utils') 6 | 7 | const chance = new Chance() 8 | 9 | function randomNumberData (field, float) { 10 | let data 11 | 12 | // If it is an array, create a random length array of numbers 13 | if (field.isArray) { 14 | const arrLength = randomNumber(1, 10) 15 | const dataArr = [] 16 | for (let i = 0; i < arrLength; i++) { 17 | dataArr.push(createDataType(field, float)) 18 | } 19 | data = dataArr 20 | } else { 21 | data = createDataType(field, float) 22 | } 23 | 24 | // If the field can be null, randomly return null or the random number 25 | if (!field.noNull) { 26 | const selectedAnswer = randomNumber(0, 1) 27 | return [null, data][selectedAnswer] 28 | } 29 | 30 | return data 31 | } 32 | 33 | function createDataType (field, float) { 34 | if (float) { 35 | return createRandomNumber(float) 36 | } 37 | 38 | switch (field.name.toLowerCase()) { 39 | case constants.age: 40 | case constants.ages: 41 | return chance.age() 42 | 43 | case constants.timestamp: 44 | case constants.timestamps: 45 | return chance.timestamp() 46 | 47 | case constants.hammertime: 48 | case constants.hammertimes: 49 | return chance.hammertime() 50 | 51 | case constants.hour: 52 | case constants.hours: 53 | return chance.hour() 54 | 55 | case constants.minute: 56 | case constants.minutes: 57 | case constants.second: 58 | case constants.seconds: 59 | return chance.second() 60 | 61 | case constants.millisecond: 62 | case constants.milliseconds: 63 | return chance.millisecond() 64 | 65 | case constants.year: 66 | case constants.years: 67 | return parseInt(chance.year()) 68 | 69 | default: 70 | return createRandomNumber() 71 | } 72 | } 73 | 74 | function createRandomNumber (float) { 75 | if (float) { 76 | const precision = 100 77 | return Math.floor(Math.random() * (10 * precision - 1 * precision) + 1 * precision) / (1 * precision) 78 | } 79 | 80 | return Math.floor(Math.random() * 11) 81 | } 82 | 83 | module.exports = randomNumberData 84 | -------------------------------------------------------------------------------- /util/randomData/string.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | const Chance = require('chance') 4 | const constants = require('../constants') 5 | const { randomNumber } = require('../utils') 6 | 7 | const chance = new Chance() 8 | 9 | function randomStringData (field) { 10 | let data 11 | 12 | // If it is an array, create a random length array of strings 13 | if (field.isArray) { 14 | const arrLength = randomNumber(1, 10) 15 | const dataArr = [] 16 | for (let i = 0; i < arrLength; i++) { 17 | dataArr.push(createDataType(field.name.toLowerCase())) 18 | } 19 | data = dataArr 20 | } else { 21 | data = createDataType(field.name.toLowerCase()) 22 | } 23 | 24 | // If the field can be null, randomly return null or the random string 25 | if (!field.noNull) { 26 | const selectedAnswer = randomNumber(0, 1) 27 | return [null, data][selectedAnswer] 28 | } 29 | 30 | return data 31 | } 32 | 33 | function createDataType (fieldName) { 34 | switch (fieldName) { 35 | case constants.name: 36 | case constants.names: 37 | case constants.firstName: 38 | case constants.first: 39 | return chance.first() 40 | 41 | case constants.lastName: 42 | case constants.last: 43 | return chance.last() 44 | 45 | case constants.fullName: 46 | case constants.fullNames: 47 | return chance.name() 48 | 49 | case constants.gender: 50 | case constants.genders: 51 | return chance.gender() 52 | 53 | case constants.prefix: 54 | case constants.prefixes: 55 | return chance.prefix() 56 | 57 | case constants.email: 58 | case constants.emails: 59 | return chance.email() 60 | 61 | case constants.phone: 62 | case constants.phones: 63 | return chance.phone() 64 | 65 | case constants.profession: 66 | case constants.professions: 67 | return chance.profession() 68 | 69 | case constants.date: 70 | case constants.dates: 71 | return chance.date({ string: true }) 72 | 73 | case constants.address: 74 | case constants.addresses: 75 | return chance.address({ short_suffix: true }) 76 | 77 | case constants.city: 78 | case constants.cities: 79 | return chance.city() 80 | 81 | case constants.country: 82 | case constants.countries: 83 | return chance.country({ full: true }) 84 | 85 | case constants.id: 86 | return createRandomId() 87 | 88 | case constants.timezone: 89 | case constants.timezones: 90 | return chance.timezone().name 91 | 92 | case constants.weekday: 93 | case constants.weekdays: 94 | return chance.weekday() 95 | 96 | default: 97 | return createRandomString() 98 | } 99 | } 100 | 101 | function createRandomString (length) { 102 | const chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ' 103 | length = length || randomNumber(5, 20) 104 | let result = '' 105 | for (let i = length; i > 0; --i) result += chars[randomNumber(0, chars.length)] 106 | return result 107 | } 108 | 109 | function createRandomId () { 110 | return randomNumber(1, 99).toString() 111 | } 112 | 113 | module.exports = randomStringData 114 | -------------------------------------------------------------------------------- /util/utils.js: -------------------------------------------------------------------------------- 1 | function randomNumber (min, max) { 2 | return Math.floor(Math.random() * (max - min + 1)) + min 3 | } 4 | 5 | module.exports = { randomNumber } 6 | --------------------------------------------------------------------------------