├── .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 |
3 |
4 | easygraphql-mock
5 |
6 |
7 |
8 |
9 | [](https://coveralls.io/github/EasyGraphQL/easygraphql-mock?branch=master) [](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 |
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 |
--------------------------------------------------------------------------------