├── .eslintignore
├── .eslintrc.json
├── .gitignore
├── .huskyrc.json
├── .lintstagedrc.json
├── .npmignore
├── .prettierignore
├── .prettierrc
├── .vscode
└── settings.json
├── LICENSE
├── README.md
├── package-lock.json
├── package.json
├── sandbox
└── index.js
└── src
├── index.js
└── lib
└── crypto.js
/.eslintignore:
--------------------------------------------------------------------------------
1 | node_modules/
--------------------------------------------------------------------------------
/.eslintrc.json:
--------------------------------------------------------------------------------
1 | {
2 | "root": true,
3 | "extends": ["airbnb-base", "prettier", "plugin:node/recommended"],
4 | "plugins": ["prettier"],
5 | "rules": {
6 | "prettier/prettier": "error",
7 | "no-console": "off",
8 | "class-methods-use-this": "off",
9 | "no-underscore-dangle": "off",
10 | "no-shadow": "off",
11 | "no-restricted-syntax": "off",
12 | "no-lonely-if": "off"
13 | }
14 | }
15 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | sandbox/database.json
2 |
3 | # Logs
4 | logs
5 | *.log
6 | npm-debug.log*
7 | yarn-debug.log*
8 | yarn-error.log*
9 | lerna-debug.log*
10 |
11 | # Diagnostic reports (https://nodejs.org/api/report.html)
12 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
13 |
14 | # Runtime data
15 | pids
16 | *.pid
17 | *.seed
18 | *.pid.lock
19 |
20 | # Directory for instrumented libs generated by jscoverage/JSCover
21 | lib-cov
22 |
23 | # Coverage directory used by tools like istanbul
24 | coverage
25 | *.lcov
26 |
27 | # nyc test coverage
28 | .nyc_output
29 |
30 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
31 | .grunt
32 |
33 | # Bower dependency directory (https://bower.io/)
34 | bower_components
35 |
36 | # node-waf configuration
37 | .lock-wscript
38 |
39 | # Compiled binary addons (https://nodejs.org/api/addons.html)
40 | build/Release
41 |
42 | # Dependency directories
43 | node_modules/
44 | jspm_packages/
45 |
46 | # TypeScript v1 declaration files
47 | typings/
48 |
49 | # TypeScript cache
50 | *.tsbuildinfo
51 |
52 | # Optional npm cache directory
53 | .npm
54 |
55 | # Optional eslint cache
56 | .eslintcache
57 |
58 | # Microbundle cache
59 | .rpt2_cache/
60 | .rts2_cache_cjs/
61 | .rts2_cache_es/
62 | .rts2_cache_umd/
63 |
64 | # Optional REPL history
65 | .node_repl_history
66 |
67 | # Output of 'npm pack'
68 | *.tgz
69 |
70 | # Yarn Integrity file
71 | .yarn-integrity
72 |
73 | # dotenv environment variables file
74 | .env
75 | .env.test
76 |
77 | # parcel-bundler cache (https://parceljs.org/)
78 | .cache
79 |
80 | # Next.js build output
81 | .next
82 |
83 | # Nuxt.js build / generate output
84 | .nuxt
85 | dist
86 |
87 | # Gatsby files
88 | .cache/
89 | # Comment in the public line in if your project uses Gatsby and *not* Next.js
90 | # https://nextjs.org/blog/next-9-1#public-directory-support
91 | # public
92 |
93 | # vuepress build output
94 | .vuepress/dist
95 |
96 | # Serverless directories
97 | .serverless/
98 |
99 | # FuseBox cache
100 | .fusebox/
101 |
102 | # DynamoDB Local files
103 | .dynamodb/
104 |
105 | # TernJS port file
106 | .tern-port
107 |
--------------------------------------------------------------------------------
/.huskyrc.json:
--------------------------------------------------------------------------------
1 | {
2 | "hooks": {
3 | "pre-commit": "lint-staged"
4 | }
5 | }
6 |
--------------------------------------------------------------------------------
/.lintstagedrc.json:
--------------------------------------------------------------------------------
1 | {
2 | "*.js": "eslint --fix",
3 | "*.{json,md}": "prettier --write"
4 | }
5 |
--------------------------------------------------------------------------------
/.npmignore:
--------------------------------------------------------------------------------
1 | .vscode/
2 | sandbox/
--------------------------------------------------------------------------------
/.prettierignore:
--------------------------------------------------------------------------------
1 | node_modules/
--------------------------------------------------------------------------------
/.prettierrc:
--------------------------------------------------------------------------------
1 | {
2 | "singleQuote": true,
3 | "arrowParens": "avoid",
4 | "endOfLine": "auto",
5 | "tabWidth": 2,
6 | "semi": true
7 | }
8 |
--------------------------------------------------------------------------------
/.vscode/settings.json:
--------------------------------------------------------------------------------
1 | {
2 | "editor.formatOnSave": true
3 | }
4 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2021 Maze Peterson
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 all
13 | 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 THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 |
2 |
ZeroDB
3 |
Easy to use JSON database for Node.js with encryption.
4 |
5 |
6 | ## Table of Contents
7 |
8 | - [Install](#install)
9 | - [Usage](#usage)
10 | - [Encryption](#encryption)
11 | - [Contributing](#contributing)
12 | - [Author](#author)
13 | - [Support](#show-your-support)
14 | - [License](#license)
15 |
16 | ## Install
17 |
18 | npm:
19 |
20 | ```bash
21 | npm install zerodb
22 | ```
23 |
24 | Yarn:
25 |
26 | ```bash
27 | yarn add zerodb
28 | ```
29 |
30 | GitHub:
31 |
32 | ```bash
33 | git clone https://github.com/mazecodes/zerodb.git
34 | ```
35 |
36 | ## Usage
37 |
38 | Load a database:
39 |
40 | ```javascript
41 | const ZeroDB = require('zerodb');
42 |
43 | const db = new ZeroDB('./database.json');
44 | ```
45 |
46 | If the database doesn't exist, ZeroDB will create a new one.
47 |
48 | Adding defaults:
49 |
50 | ```javascript
51 | db.init({
52 | posts: [],
53 | user: {},
54 | });
55 | ```
56 |
57 | You can also force the database to replace the current state with the initial state:
58 |
59 | ```javascript
60 | db.init(
61 | {
62 | posts: [],
63 | user: [],
64 | },
65 | { force: true }
66 | );
67 | ```
68 |
69 | Save the database:
70 |
71 | ```javascript
72 | await db.save();
73 | ```
74 |
75 | Set a value:
76 |
77 | ```javascript
78 | db.set('user.name', 'John Doe');
79 | ```
80 |
81 | You can set multiple values with chaining:
82 |
83 | ```javascript
84 | db.set('user.name', 'John Doe')
85 | .set('user.age', 18)
86 | .set('user.email', 'john@doe.com');
87 | ```
88 |
89 | Get a value:
90 |
91 | ```javascript
92 | db.get('user.name');
93 | ```
94 |
95 | You can also provide a fallback value:
96 |
97 | ```javascript
98 | db.get('user.admin', false);
99 | ```
100 |
101 | Push to an array:
102 |
103 | ```javascript
104 | db.push('posts', {
105 | id: 0,
106 | title: 'Hello World',
107 | });
108 | ```
109 |
110 | You can also push multiple values with chaining:
111 |
112 | ```javascript
113 | db.push('posts', {
114 | id: 0,
115 | title: 'Hello World 1',
116 | })
117 | .push('posts', {
118 | id: 1,
119 | title: 'Hello World 2',
120 | })
121 | .push('posts', {
122 | id: 2,
123 | title: 'Hello World 3',
124 | })
125 | .push('posts', {
126 | id: 3,
127 | title: 'Hello World 4',
128 | });
129 | ```
130 |
131 | ZeroDB will set a new array if the pushing path doesn't exist.
132 |
133 | Check if a property exists:
134 |
135 | ```javascript
136 | db.has('user.name'); // true
137 | ```
138 |
139 | Delete a propery:
140 |
141 | ```javascript
142 | db.delete('user.name');
143 | db.has('user.name'); // false
144 | ```
145 |
146 | Reset the database to its initial state:
147 |
148 | ```javascript
149 | db.reset();
150 | ```
151 |
152 | Find all the matches:
153 |
154 | ```javascript
155 | db.find('posts', { author: 'John' });
156 | ```
157 |
158 | You can also use RegExp:
159 |
160 | ```javascript
161 | db.find('posts', { title: /^Hello/ });
162 | ```
163 |
164 | Find only the first match:
165 |
166 | ```javascript
167 | db.findOne('post', { id: 0 });
168 | ```
169 |
170 | Increase the value:
171 |
172 | ```javascript
173 | db.increment('user.age'); // Increase by 1
174 | db.increment('user.age', 5); // Increase by 5
175 | ```
176 |
177 | Decrease the value:
178 |
179 | ```javascript
180 | db.decrement('user.age'); // Decrease by 1
181 | db.decrement('user.age', 5); // Decrease by 5
182 | ```
183 |
184 | Update a property based on its last value:
185 |
186 | ```javascript
187 | db.update('user.name', name => name.toLowerCase());
188 | ```
189 |
190 | Get the current state of the database:
191 |
192 | ```javascript
193 | db.getState();
194 | ```
195 |
196 | Replace the current state:
197 |
198 | ```javascript
199 | db.setState({ foo: 'bar' });
200 | ```
201 |
202 | Destory the database:
203 |
204 | ```javascript
205 | db.destory();
206 | ```
207 |
208 | This will also delete the database file. If you don't want that, you can specify it like this:
209 |
210 | ```javascript
211 | db.destroy(false);
212 | ```
213 |
214 | ## Encryption
215 |
216 | Using encryption with ZeroDB is pretty simple. All you have to do is:
217 |
218 | ```javascript
219 | new ZeroDB('./database.json', {
220 | encryption: true,
221 | secret: 's3cr3t',
222 | iterations: 50_000,
223 | });
224 | ```
225 |
226 | `iterations` is the number of iterations used for key derivation. The encryption key will be derived from `secret`.
227 |
228 | ZeroDB uses **PBKDF2** for key derivation with default iterations set to **50,000** and uses **AES256** for encryption. It will also use **HMAC-SHA256** for signing the state.
229 |
230 | **Note**: The encryption will only happen when the database is being saved.
231 |
232 | ## Contributing
233 |
234 | All contributions, issues and feature requests are welcome!
235 | Please feel free to check [issues page](https://github.com/mazecodes/zerodb/issues).
236 |
237 | 1. Fork the project
238 | 1. Create your feature branch (`git checkout -b feature/AwesomeFeature`)
239 | 1. Commit your changes (`git commit -m "Add Awesome Feature"`)
240 | 1. Push to the branch (`git push origin feature/AwesomeFeature`)
241 | 1. Open a Pull Request
242 |
243 | ## Author
244 |
245 | Maze Peterson:
246 |
247 | - Twitter: [mazecodes](https://twitter.com/mazecodes)
248 | - GitHub: [mazecodes](https://github.com/mazecodes)
249 | - npm: [mazecodes](https://npmjs.com/~mazecodes)
250 |
251 | ## Show your support
252 |
253 | Give a ⭐ if you liked this project!
254 |
255 | ## License
256 |
257 | [MIT](https://github.com/mazecodes/zerodb/blob/master/LICENSE) © Maze Peterson
258 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "zerodb",
3 | "version": "0.1.0",
4 | "lockfileVersion": 1,
5 | "requires": true,
6 | "dependencies": {
7 | "@babel/code-frame": {
8 | "version": "7.12.11",
9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz",
10 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==",
11 | "dev": true,
12 | "requires": {
13 | "@babel/highlight": "^7.10.4"
14 | }
15 | },
16 | "@babel/generator": {
17 | "version": "7.12.11",
18 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.12.11.tgz",
19 | "integrity": "sha512-Ggg6WPOJtSi8yYQvLVjG8F/TlpWDlKx0OpS4Kt+xMQPs5OaGYWy+v1A+1TvxI6sAMGZpKWWoAQ1DaeQbImlItA==",
20 | "dev": true,
21 | "requires": {
22 | "@babel/types": "^7.12.11",
23 | "jsesc": "^2.5.1",
24 | "source-map": "^0.5.0"
25 | }
26 | },
27 | "@babel/helper-function-name": {
28 | "version": "7.12.11",
29 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.12.11.tgz",
30 | "integrity": "sha512-AtQKjtYNolKNi6nNNVLQ27CP6D9oFR6bq/HPYSizlzbp7uC1M59XJe8L+0uXjbIaZaUJF99ruHqVGiKXU/7ybA==",
31 | "dev": true,
32 | "requires": {
33 | "@babel/helper-get-function-arity": "^7.12.10",
34 | "@babel/template": "^7.12.7",
35 | "@babel/types": "^7.12.11"
36 | }
37 | },
38 | "@babel/helper-get-function-arity": {
39 | "version": "7.12.10",
40 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.12.10.tgz",
41 | "integrity": "sha512-mm0n5BPjR06wh9mPQaDdXWDoll/j5UpCAPl1x8fS71GHm7HA6Ua2V4ylG1Ju8lvcTOietbPNNPaSilKj+pj+Ag==",
42 | "dev": true,
43 | "requires": {
44 | "@babel/types": "^7.12.10"
45 | }
46 | },
47 | "@babel/helper-split-export-declaration": {
48 | "version": "7.12.11",
49 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.12.11.tgz",
50 | "integrity": "sha512-LsIVN8j48gHgwzfocYUSkO/hjYAOJqlpJEc7tGXcIm4cubjVUf8LGW6eWRyxEu7gA25q02p0rQUWoCI33HNS5g==",
51 | "dev": true,
52 | "requires": {
53 | "@babel/types": "^7.12.11"
54 | }
55 | },
56 | "@babel/helper-validator-identifier": {
57 | "version": "7.12.11",
58 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz",
59 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==",
60 | "dev": true
61 | },
62 | "@babel/highlight": {
63 | "version": "7.10.4",
64 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz",
65 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==",
66 | "dev": true,
67 | "requires": {
68 | "@babel/helper-validator-identifier": "^7.10.4",
69 | "chalk": "^2.0.0",
70 | "js-tokens": "^4.0.0"
71 | },
72 | "dependencies": {
73 | "chalk": {
74 | "version": "2.4.2",
75 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
76 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
77 | "dev": true,
78 | "requires": {
79 | "ansi-styles": "^3.2.1",
80 | "escape-string-regexp": "^1.0.5",
81 | "supports-color": "^5.3.0"
82 | }
83 | }
84 | }
85 | },
86 | "@babel/parser": {
87 | "version": "7.12.11",
88 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.12.11.tgz",
89 | "integrity": "sha512-N3UxG+uuF4CMYoNj8AhnbAcJF0PiuJ9KHuy1lQmkYsxTer/MAH9UBNHsBoAX/4s6NvlDD047No8mYVGGzLL4hg==",
90 | "dev": true
91 | },
92 | "@babel/template": {
93 | "version": "7.12.7",
94 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.12.7.tgz",
95 | "integrity": "sha512-GkDzmHS6GV7ZeXfJZ0tLRBhZcMcY0/Lnb+eEbXDBfCAcZCjrZKe6p3J4we/D24O9Y8enxWAg1cWwof59yLh2ow==",
96 | "dev": true,
97 | "requires": {
98 | "@babel/code-frame": "^7.10.4",
99 | "@babel/parser": "^7.12.7",
100 | "@babel/types": "^7.12.7"
101 | }
102 | },
103 | "@babel/traverse": {
104 | "version": "7.12.12",
105 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.12.12.tgz",
106 | "integrity": "sha512-s88i0X0lPy45RrLM8b9mz8RPH5FqO9G9p7ti59cToE44xFm1Q+Pjh5Gq4SXBbtb88X7Uy7pexeqRIQDDMNkL0w==",
107 | "dev": true,
108 | "requires": {
109 | "@babel/code-frame": "^7.12.11",
110 | "@babel/generator": "^7.12.11",
111 | "@babel/helper-function-name": "^7.12.11",
112 | "@babel/helper-split-export-declaration": "^7.12.11",
113 | "@babel/parser": "^7.12.11",
114 | "@babel/types": "^7.12.12",
115 | "debug": "^4.1.0",
116 | "globals": "^11.1.0",
117 | "lodash": "^4.17.19"
118 | },
119 | "dependencies": {
120 | "globals": {
121 | "version": "11.12.0",
122 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
123 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
124 | "dev": true
125 | }
126 | }
127 | },
128 | "@babel/types": {
129 | "version": "7.12.12",
130 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.12.12.tgz",
131 | "integrity": "sha512-lnIX7piTxOH22xE7fDXDbSHg9MM1/6ORnafpJmov5rs0kX5g4BZxeXNJLXsMRiO0U5Rb8/FvMS6xlTnTHvxonQ==",
132 | "dev": true,
133 | "requires": {
134 | "@babel/helper-validator-identifier": "^7.12.11",
135 | "lodash": "^4.17.19",
136 | "to-fast-properties": "^2.0.0"
137 | }
138 | },
139 | "@eslint/eslintrc": {
140 | "version": "0.3.0",
141 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.3.0.tgz",
142 | "integrity": "sha512-1JTKgrOKAHVivSvOYw+sJOunkBjUOvjqWk1DPja7ZFhIS2mX/4EgTT8M7eTK9jrKhL/FvXXEbQwIs3pg1xp3dg==",
143 | "dev": true,
144 | "requires": {
145 | "ajv": "^6.12.4",
146 | "debug": "^4.1.1",
147 | "espree": "^7.3.0",
148 | "globals": "^12.1.0",
149 | "ignore": "^4.0.6",
150 | "import-fresh": "^3.2.1",
151 | "js-yaml": "^3.13.1",
152 | "lodash": "^4.17.20",
153 | "minimatch": "^3.0.4",
154 | "strip-json-comments": "^3.1.1"
155 | }
156 | },
157 | "@types/json5": {
158 | "version": "0.0.29",
159 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz",
160 | "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=",
161 | "dev": true
162 | },
163 | "@types/parse-json": {
164 | "version": "4.0.0",
165 | "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz",
166 | "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==",
167 | "dev": true
168 | },
169 | "acorn": {
170 | "version": "7.4.1",
171 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz",
172 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==",
173 | "dev": true
174 | },
175 | "acorn-jsx": {
176 | "version": "5.3.1",
177 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz",
178 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==",
179 | "dev": true
180 | },
181 | "aggregate-error": {
182 | "version": "3.1.0",
183 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz",
184 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==",
185 | "dev": true,
186 | "requires": {
187 | "clean-stack": "^2.0.0",
188 | "indent-string": "^4.0.0"
189 | }
190 | },
191 | "ajv": {
192 | "version": "6.12.6",
193 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
194 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
195 | "dev": true,
196 | "requires": {
197 | "fast-deep-equal": "^3.1.1",
198 | "fast-json-stable-stringify": "^2.0.0",
199 | "json-schema-traverse": "^0.4.1",
200 | "uri-js": "^4.2.2"
201 | }
202 | },
203 | "ansi-colors": {
204 | "version": "4.1.1",
205 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz",
206 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==",
207 | "dev": true
208 | },
209 | "ansi-escapes": {
210 | "version": "4.3.1",
211 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz",
212 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==",
213 | "dev": true,
214 | "requires": {
215 | "type-fest": "^0.11.0"
216 | },
217 | "dependencies": {
218 | "type-fest": {
219 | "version": "0.11.0",
220 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz",
221 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==",
222 | "dev": true
223 | }
224 | }
225 | },
226 | "ansi-regex": {
227 | "version": "5.0.0",
228 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz",
229 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==",
230 | "dev": true
231 | },
232 | "ansi-styles": {
233 | "version": "3.2.1",
234 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
235 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
236 | "dev": true,
237 | "requires": {
238 | "color-convert": "^1.9.0"
239 | }
240 | },
241 | "argparse": {
242 | "version": "1.0.10",
243 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
244 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
245 | "dev": true,
246 | "requires": {
247 | "sprintf-js": "~1.0.2"
248 | }
249 | },
250 | "array-includes": {
251 | "version": "3.1.2",
252 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.2.tgz",
253 | "integrity": "sha512-w2GspexNQpx+PutG3QpT437/BenZBj0M/MZGn5mzv/MofYqo0xmRHzn4lFsoDlWJ+THYsGJmFlW68WlDFx7VRw==",
254 | "dev": true,
255 | "requires": {
256 | "call-bind": "^1.0.0",
257 | "define-properties": "^1.1.3",
258 | "es-abstract": "^1.18.0-next.1",
259 | "get-intrinsic": "^1.0.1",
260 | "is-string": "^1.0.5"
261 | }
262 | },
263 | "array.prototype.flat": {
264 | "version": "1.2.4",
265 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.4.tgz",
266 | "integrity": "sha512-4470Xi3GAPAjZqFcljX2xzckv1qeKPizoNkiS0+O4IoPR2ZNpcjE0pkhdihlDouK+x6QOast26B4Q/O9DJnwSg==",
267 | "dev": true,
268 | "requires": {
269 | "call-bind": "^1.0.0",
270 | "define-properties": "^1.1.3",
271 | "es-abstract": "^1.18.0-next.1"
272 | }
273 | },
274 | "astral-regex": {
275 | "version": "2.0.0",
276 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz",
277 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==",
278 | "dev": true
279 | },
280 | "babel-eslint": {
281 | "version": "10.1.0",
282 | "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.1.0.tgz",
283 | "integrity": "sha512-ifWaTHQ0ce+448CYop8AdrQiBsGrnC+bMgfyKFdi6EsPLTAWG+QfyDeM6OH+FmWnKvEq5NnBMLvlBUPKQZoDSg==",
284 | "dev": true,
285 | "requires": {
286 | "@babel/code-frame": "^7.0.0",
287 | "@babel/parser": "^7.7.0",
288 | "@babel/traverse": "^7.7.0",
289 | "@babel/types": "^7.7.0",
290 | "eslint-visitor-keys": "^1.0.0",
291 | "resolve": "^1.12.0"
292 | },
293 | "dependencies": {
294 | "eslint-visitor-keys": {
295 | "version": "1.3.0",
296 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz",
297 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==",
298 | "dev": true
299 | }
300 | }
301 | },
302 | "balanced-match": {
303 | "version": "1.0.0",
304 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
305 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
306 | "dev": true
307 | },
308 | "brace-expansion": {
309 | "version": "1.1.11",
310 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
311 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
312 | "dev": true,
313 | "requires": {
314 | "balanced-match": "^1.0.0",
315 | "concat-map": "0.0.1"
316 | }
317 | },
318 | "braces": {
319 | "version": "3.0.2",
320 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
321 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
322 | "dev": true,
323 | "requires": {
324 | "fill-range": "^7.0.1"
325 | }
326 | },
327 | "call-bind": {
328 | "version": "1.0.2",
329 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
330 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
331 | "dev": true,
332 | "requires": {
333 | "function-bind": "^1.1.1",
334 | "get-intrinsic": "^1.0.2"
335 | }
336 | },
337 | "callsites": {
338 | "version": "3.1.0",
339 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
340 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
341 | "dev": true
342 | },
343 | "chalk": {
344 | "version": "4.1.0",
345 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
346 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
347 | "dev": true,
348 | "requires": {
349 | "ansi-styles": "^4.1.0",
350 | "supports-color": "^7.1.0"
351 | },
352 | "dependencies": {
353 | "ansi-styles": {
354 | "version": "4.3.0",
355 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
356 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
357 | "dev": true,
358 | "requires": {
359 | "color-convert": "^2.0.1"
360 | }
361 | },
362 | "color-convert": {
363 | "version": "2.0.1",
364 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
365 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
366 | "dev": true,
367 | "requires": {
368 | "color-name": "~1.1.4"
369 | }
370 | },
371 | "color-name": {
372 | "version": "1.1.4",
373 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
374 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
375 | "dev": true
376 | },
377 | "has-flag": {
378 | "version": "4.0.0",
379 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
380 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
381 | "dev": true
382 | },
383 | "supports-color": {
384 | "version": "7.2.0",
385 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
386 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
387 | "dev": true,
388 | "requires": {
389 | "has-flag": "^4.0.0"
390 | }
391 | }
392 | }
393 | },
394 | "chardet": {
395 | "version": "0.7.0",
396 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz",
397 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==",
398 | "dev": true
399 | },
400 | "ci-info": {
401 | "version": "2.0.0",
402 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz",
403 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==",
404 | "dev": true
405 | },
406 | "clean-stack": {
407 | "version": "2.2.0",
408 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz",
409 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==",
410 | "dev": true
411 | },
412 | "cli-cursor": {
413 | "version": "3.1.0",
414 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz",
415 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==",
416 | "dev": true,
417 | "requires": {
418 | "restore-cursor": "^3.1.0"
419 | }
420 | },
421 | "cli-truncate": {
422 | "version": "2.1.0",
423 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz",
424 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==",
425 | "dev": true,
426 | "requires": {
427 | "slice-ansi": "^3.0.0",
428 | "string-width": "^4.2.0"
429 | },
430 | "dependencies": {
431 | "ansi-styles": {
432 | "version": "4.3.0",
433 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
434 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
435 | "dev": true,
436 | "requires": {
437 | "color-convert": "^2.0.1"
438 | }
439 | },
440 | "color-convert": {
441 | "version": "2.0.1",
442 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
443 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
444 | "dev": true,
445 | "requires": {
446 | "color-name": "~1.1.4"
447 | }
448 | },
449 | "color-name": {
450 | "version": "1.1.4",
451 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
452 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
453 | "dev": true
454 | },
455 | "slice-ansi": {
456 | "version": "3.0.0",
457 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz",
458 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==",
459 | "dev": true,
460 | "requires": {
461 | "ansi-styles": "^4.0.0",
462 | "astral-regex": "^2.0.0",
463 | "is-fullwidth-code-point": "^3.0.0"
464 | }
465 | }
466 | }
467 | },
468 | "cli-width": {
469 | "version": "3.0.0",
470 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz",
471 | "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==",
472 | "dev": true
473 | },
474 | "clone-deep": {
475 | "version": "4.0.1",
476 | "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz",
477 | "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==",
478 | "requires": {
479 | "is-plain-object": "^2.0.4",
480 | "kind-of": "^6.0.2",
481 | "shallow-clone": "^3.0.0"
482 | }
483 | },
484 | "color-convert": {
485 | "version": "1.9.3",
486 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
487 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
488 | "dev": true,
489 | "requires": {
490 | "color-name": "1.1.3"
491 | }
492 | },
493 | "color-name": {
494 | "version": "1.1.3",
495 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
496 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
497 | "dev": true
498 | },
499 | "commander": {
500 | "version": "6.2.1",
501 | "resolved": "https://registry.npmjs.org/commander/-/commander-6.2.1.tgz",
502 | "integrity": "sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA==",
503 | "dev": true
504 | },
505 | "compare-versions": {
506 | "version": "3.6.0",
507 | "resolved": "https://registry.npmjs.org/compare-versions/-/compare-versions-3.6.0.tgz",
508 | "integrity": "sha512-W6Af2Iw1z4CB7q4uU4hv646dW9GQuBM+YpC0UvUCWSD8w90SJjp+ujJuXaEMtAXBtSqGfMPuFOVn4/+FlaqfBA==",
509 | "dev": true
510 | },
511 | "concat-map": {
512 | "version": "0.0.1",
513 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
514 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
515 | "dev": true
516 | },
517 | "confusing-browser-globals": {
518 | "version": "1.0.10",
519 | "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.10.tgz",
520 | "integrity": "sha512-gNld/3lySHwuhaVluJUKLePYirM3QNCKzVxqAdhJII9/WXKVX5PURzMVJspS1jTslSqjeuG4KMVTSouit5YPHA==",
521 | "dev": true
522 | },
523 | "contains-path": {
524 | "version": "0.1.0",
525 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz",
526 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=",
527 | "dev": true
528 | },
529 | "cosmiconfig": {
530 | "version": "7.0.0",
531 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.0.0.tgz",
532 | "integrity": "sha512-pondGvTuVYDk++upghXJabWzL6Kxu6f26ljFw64Swq9v6sQPUL3EUlVDV56diOjpCayKihL6hVe8exIACU4XcA==",
533 | "dev": true,
534 | "requires": {
535 | "@types/parse-json": "^4.0.0",
536 | "import-fresh": "^3.2.1",
537 | "parse-json": "^5.0.0",
538 | "path-type": "^4.0.0",
539 | "yaml": "^1.10.0"
540 | },
541 | "dependencies": {
542 | "parse-json": {
543 | "version": "5.2.0",
544 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
545 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
546 | "dev": true,
547 | "requires": {
548 | "@babel/code-frame": "^7.0.0",
549 | "error-ex": "^1.3.1",
550 | "json-parse-even-better-errors": "^2.3.0",
551 | "lines-and-columns": "^1.1.6"
552 | }
553 | },
554 | "path-type": {
555 | "version": "4.0.0",
556 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
557 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
558 | "dev": true
559 | }
560 | }
561 | },
562 | "cross-spawn": {
563 | "version": "7.0.3",
564 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
565 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
566 | "dev": true,
567 | "requires": {
568 | "path-key": "^3.1.0",
569 | "shebang-command": "^2.0.0",
570 | "which": "^2.0.1"
571 | }
572 | },
573 | "crypto-js": {
574 | "version": "4.0.0",
575 | "resolved": "https://registry.npmjs.org/crypto-js/-/crypto-js-4.0.0.tgz",
576 | "integrity": "sha512-bzHZN8Pn+gS7DQA6n+iUmBfl0hO5DJq++QP3U6uTucDtk/0iGpXd/Gg7CGR0p8tJhofJyaKoWBuJI4eAO00BBg=="
577 | },
578 | "debug": {
579 | "version": "4.3.1",
580 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz",
581 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==",
582 | "dev": true,
583 | "requires": {
584 | "ms": "2.1.2"
585 | }
586 | },
587 | "dedent": {
588 | "version": "0.7.0",
589 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz",
590 | "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=",
591 | "dev": true
592 | },
593 | "deep-is": {
594 | "version": "0.1.3",
595 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz",
596 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=",
597 | "dev": true
598 | },
599 | "define-properties": {
600 | "version": "1.1.3",
601 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz",
602 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==",
603 | "dev": true,
604 | "requires": {
605 | "object-keys": "^1.0.12"
606 | }
607 | },
608 | "doctrine": {
609 | "version": "3.0.0",
610 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz",
611 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==",
612 | "dev": true,
613 | "requires": {
614 | "esutils": "^2.0.2"
615 | }
616 | },
617 | "emoji-regex": {
618 | "version": "8.0.0",
619 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
620 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
621 | "dev": true
622 | },
623 | "end-of-stream": {
624 | "version": "1.4.4",
625 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
626 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
627 | "dev": true,
628 | "requires": {
629 | "once": "^1.4.0"
630 | }
631 | },
632 | "enquirer": {
633 | "version": "2.3.6",
634 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz",
635 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==",
636 | "dev": true,
637 | "requires": {
638 | "ansi-colors": "^4.1.1"
639 | }
640 | },
641 | "error-ex": {
642 | "version": "1.3.2",
643 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
644 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
645 | "dev": true,
646 | "requires": {
647 | "is-arrayish": "^0.2.1"
648 | }
649 | },
650 | "es-abstract": {
651 | "version": "1.18.0-next.2",
652 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.2.tgz",
653 | "integrity": "sha512-Ih4ZMFHEtZupnUh6497zEL4y2+w8+1ljnCyaTa+adcoafI1GOvMwFlDjBLfWR7y9VLfrjRJe9ocuHY1PSR9jjw==",
654 | "dev": true,
655 | "requires": {
656 | "call-bind": "^1.0.2",
657 | "es-to-primitive": "^1.2.1",
658 | "function-bind": "^1.1.1",
659 | "get-intrinsic": "^1.0.2",
660 | "has": "^1.0.3",
661 | "has-symbols": "^1.0.1",
662 | "is-callable": "^1.2.2",
663 | "is-negative-zero": "^2.0.1",
664 | "is-regex": "^1.1.1",
665 | "object-inspect": "^1.9.0",
666 | "object-keys": "^1.1.1",
667 | "object.assign": "^4.1.2",
668 | "string.prototype.trimend": "^1.0.3",
669 | "string.prototype.trimstart": "^1.0.3"
670 | }
671 | },
672 | "es-to-primitive": {
673 | "version": "1.2.1",
674 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz",
675 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==",
676 | "dev": true,
677 | "requires": {
678 | "is-callable": "^1.1.4",
679 | "is-date-object": "^1.0.1",
680 | "is-symbol": "^1.0.2"
681 | }
682 | },
683 | "escape-string-regexp": {
684 | "version": "1.0.5",
685 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
686 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
687 | "dev": true
688 | },
689 | "eslint": {
690 | "version": "7.18.0",
691 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.18.0.tgz",
692 | "integrity": "sha512-fbgTiE8BfUJZuBeq2Yi7J3RB3WGUQ9PNuNbmgi6jt9Iv8qrkxfy19Ds3OpL1Pm7zg3BtTVhvcUZbIRQ0wmSjAQ==",
693 | "dev": true,
694 | "requires": {
695 | "@babel/code-frame": "^7.0.0",
696 | "@eslint/eslintrc": "^0.3.0",
697 | "ajv": "^6.10.0",
698 | "chalk": "^4.0.0",
699 | "cross-spawn": "^7.0.2",
700 | "debug": "^4.0.1",
701 | "doctrine": "^3.0.0",
702 | "enquirer": "^2.3.5",
703 | "eslint-scope": "^5.1.1",
704 | "eslint-utils": "^2.1.0",
705 | "eslint-visitor-keys": "^2.0.0",
706 | "espree": "^7.3.1",
707 | "esquery": "^1.2.0",
708 | "esutils": "^2.0.2",
709 | "file-entry-cache": "^6.0.0",
710 | "functional-red-black-tree": "^1.0.1",
711 | "glob-parent": "^5.0.0",
712 | "globals": "^12.1.0",
713 | "ignore": "^4.0.6",
714 | "import-fresh": "^3.0.0",
715 | "imurmurhash": "^0.1.4",
716 | "is-glob": "^4.0.0",
717 | "js-yaml": "^3.13.1",
718 | "json-stable-stringify-without-jsonify": "^1.0.1",
719 | "levn": "^0.4.1",
720 | "lodash": "^4.17.20",
721 | "minimatch": "^3.0.4",
722 | "natural-compare": "^1.4.0",
723 | "optionator": "^0.9.1",
724 | "progress": "^2.0.0",
725 | "regexpp": "^3.1.0",
726 | "semver": "^7.2.1",
727 | "strip-ansi": "^6.0.0",
728 | "strip-json-comments": "^3.1.0",
729 | "table": "^6.0.4",
730 | "text-table": "^0.2.0",
731 | "v8-compile-cache": "^2.0.3"
732 | }
733 | },
734 | "eslint-config-airbnb-base": {
735 | "version": "14.2.1",
736 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-14.2.1.tgz",
737 | "integrity": "sha512-GOrQyDtVEc1Xy20U7vsB2yAoB4nBlfH5HZJeatRXHleO+OS5Ot+MWij4Dpltw4/DyIkqUfqz1epfhVR5XWWQPA==",
738 | "dev": true,
739 | "requires": {
740 | "confusing-browser-globals": "^1.0.10",
741 | "object.assign": "^4.1.2",
742 | "object.entries": "^1.1.2"
743 | }
744 | },
745 | "eslint-config-esnext": {
746 | "version": "4.1.0",
747 | "resolved": "https://registry.npmjs.org/eslint-config-esnext/-/eslint-config-esnext-4.1.0.tgz",
748 | "integrity": "sha512-GhfVEXdqYKEIIj7j+Fw2SQdL9qyZMekgXfq6PyXM66cQw0B435ddjz3P3kxOBVihMRJ0xGYjosaveQz5Y6z0uA==",
749 | "dev": true,
750 | "requires": {
751 | "babel-eslint": "^10.0.1",
752 | "eslint": "^6.8.0",
753 | "eslint-plugin-babel": "^5.2.1",
754 | "eslint-plugin-import": "^2.14.0"
755 | },
756 | "dependencies": {
757 | "ansi-regex": {
758 | "version": "4.1.0",
759 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
760 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
761 | "dev": true
762 | },
763 | "astral-regex": {
764 | "version": "1.0.0",
765 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz",
766 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==",
767 | "dev": true
768 | },
769 | "chalk": {
770 | "version": "2.4.2",
771 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
772 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
773 | "dev": true,
774 | "requires": {
775 | "ansi-styles": "^3.2.1",
776 | "escape-string-regexp": "^1.0.5",
777 | "supports-color": "^5.3.0"
778 | }
779 | },
780 | "cross-spawn": {
781 | "version": "6.0.5",
782 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz",
783 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==",
784 | "dev": true,
785 | "requires": {
786 | "nice-try": "^1.0.4",
787 | "path-key": "^2.0.1",
788 | "semver": "^5.5.0",
789 | "shebang-command": "^1.2.0",
790 | "which": "^1.2.9"
791 | },
792 | "dependencies": {
793 | "semver": {
794 | "version": "5.7.1",
795 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
796 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
797 | "dev": true
798 | }
799 | }
800 | },
801 | "emoji-regex": {
802 | "version": "7.0.3",
803 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz",
804 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==",
805 | "dev": true
806 | },
807 | "eslint": {
808 | "version": "6.8.0",
809 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz",
810 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==",
811 | "dev": true,
812 | "requires": {
813 | "@babel/code-frame": "^7.0.0",
814 | "ajv": "^6.10.0",
815 | "chalk": "^2.1.0",
816 | "cross-spawn": "^6.0.5",
817 | "debug": "^4.0.1",
818 | "doctrine": "^3.0.0",
819 | "eslint-scope": "^5.0.0",
820 | "eslint-utils": "^1.4.3",
821 | "eslint-visitor-keys": "^1.1.0",
822 | "espree": "^6.1.2",
823 | "esquery": "^1.0.1",
824 | "esutils": "^2.0.2",
825 | "file-entry-cache": "^5.0.1",
826 | "functional-red-black-tree": "^1.0.1",
827 | "glob-parent": "^5.0.0",
828 | "globals": "^12.1.0",
829 | "ignore": "^4.0.6",
830 | "import-fresh": "^3.0.0",
831 | "imurmurhash": "^0.1.4",
832 | "inquirer": "^7.0.0",
833 | "is-glob": "^4.0.0",
834 | "js-yaml": "^3.13.1",
835 | "json-stable-stringify-without-jsonify": "^1.0.1",
836 | "levn": "^0.3.0",
837 | "lodash": "^4.17.14",
838 | "minimatch": "^3.0.4",
839 | "mkdirp": "^0.5.1",
840 | "natural-compare": "^1.4.0",
841 | "optionator": "^0.8.3",
842 | "progress": "^2.0.0",
843 | "regexpp": "^2.0.1",
844 | "semver": "^6.1.2",
845 | "strip-ansi": "^5.2.0",
846 | "strip-json-comments": "^3.0.1",
847 | "table": "^5.2.3",
848 | "text-table": "^0.2.0",
849 | "v8-compile-cache": "^2.0.3"
850 | }
851 | },
852 | "eslint-utils": {
853 | "version": "1.4.3",
854 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz",
855 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==",
856 | "dev": true,
857 | "requires": {
858 | "eslint-visitor-keys": "^1.1.0"
859 | }
860 | },
861 | "eslint-visitor-keys": {
862 | "version": "1.3.0",
863 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz",
864 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==",
865 | "dev": true
866 | },
867 | "espree": {
868 | "version": "6.2.1",
869 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz",
870 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==",
871 | "dev": true,
872 | "requires": {
873 | "acorn": "^7.1.1",
874 | "acorn-jsx": "^5.2.0",
875 | "eslint-visitor-keys": "^1.1.0"
876 | }
877 | },
878 | "file-entry-cache": {
879 | "version": "5.0.1",
880 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz",
881 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==",
882 | "dev": true,
883 | "requires": {
884 | "flat-cache": "^2.0.1"
885 | }
886 | },
887 | "flat-cache": {
888 | "version": "2.0.1",
889 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz",
890 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==",
891 | "dev": true,
892 | "requires": {
893 | "flatted": "^2.0.0",
894 | "rimraf": "2.6.3",
895 | "write": "1.0.3"
896 | }
897 | },
898 | "flatted": {
899 | "version": "2.0.2",
900 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz",
901 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==",
902 | "dev": true
903 | },
904 | "is-fullwidth-code-point": {
905 | "version": "2.0.0",
906 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
907 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=",
908 | "dev": true
909 | },
910 | "levn": {
911 | "version": "0.3.0",
912 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz",
913 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=",
914 | "dev": true,
915 | "requires": {
916 | "prelude-ls": "~1.1.2",
917 | "type-check": "~0.3.2"
918 | }
919 | },
920 | "optionator": {
921 | "version": "0.8.3",
922 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz",
923 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==",
924 | "dev": true,
925 | "requires": {
926 | "deep-is": "~0.1.3",
927 | "fast-levenshtein": "~2.0.6",
928 | "levn": "~0.3.0",
929 | "prelude-ls": "~1.1.2",
930 | "type-check": "~0.3.2",
931 | "word-wrap": "~1.2.3"
932 | }
933 | },
934 | "path-key": {
935 | "version": "2.0.1",
936 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
937 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
938 | "dev": true
939 | },
940 | "prelude-ls": {
941 | "version": "1.1.2",
942 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz",
943 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=",
944 | "dev": true
945 | },
946 | "regexpp": {
947 | "version": "2.0.1",
948 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz",
949 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==",
950 | "dev": true
951 | },
952 | "rimraf": {
953 | "version": "2.6.3",
954 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz",
955 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==",
956 | "dev": true,
957 | "requires": {
958 | "glob": "^7.1.3"
959 | }
960 | },
961 | "semver": {
962 | "version": "6.3.0",
963 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
964 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
965 | "dev": true
966 | },
967 | "shebang-command": {
968 | "version": "1.2.0",
969 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
970 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
971 | "dev": true,
972 | "requires": {
973 | "shebang-regex": "^1.0.0"
974 | }
975 | },
976 | "shebang-regex": {
977 | "version": "1.0.0",
978 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
979 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
980 | "dev": true
981 | },
982 | "slice-ansi": {
983 | "version": "2.1.0",
984 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz",
985 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==",
986 | "dev": true,
987 | "requires": {
988 | "ansi-styles": "^3.2.0",
989 | "astral-regex": "^1.0.0",
990 | "is-fullwidth-code-point": "^2.0.0"
991 | }
992 | },
993 | "string-width": {
994 | "version": "3.1.0",
995 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
996 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
997 | "dev": true,
998 | "requires": {
999 | "emoji-regex": "^7.0.1",
1000 | "is-fullwidth-code-point": "^2.0.0",
1001 | "strip-ansi": "^5.1.0"
1002 | }
1003 | },
1004 | "strip-ansi": {
1005 | "version": "5.2.0",
1006 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
1007 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
1008 | "dev": true,
1009 | "requires": {
1010 | "ansi-regex": "^4.1.0"
1011 | }
1012 | },
1013 | "table": {
1014 | "version": "5.4.6",
1015 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz",
1016 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==",
1017 | "dev": true,
1018 | "requires": {
1019 | "ajv": "^6.10.2",
1020 | "lodash": "^4.17.14",
1021 | "slice-ansi": "^2.1.0",
1022 | "string-width": "^3.0.0"
1023 | }
1024 | },
1025 | "type-check": {
1026 | "version": "0.3.2",
1027 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz",
1028 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=",
1029 | "dev": true,
1030 | "requires": {
1031 | "prelude-ls": "~1.1.2"
1032 | }
1033 | },
1034 | "which": {
1035 | "version": "1.3.1",
1036 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
1037 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
1038 | "dev": true,
1039 | "requires": {
1040 | "isexe": "^2.0.0"
1041 | }
1042 | }
1043 | }
1044 | },
1045 | "eslint-config-node": {
1046 | "version": "4.1.0",
1047 | "resolved": "https://registry.npmjs.org/eslint-config-node/-/eslint-config-node-4.1.0.tgz",
1048 | "integrity": "sha512-Wz17xV5O2WFG8fGdMYEBdbiL6TL7YNJSJvSX9V4sXQownewfYmoqlly7wxqLkOUv/57pq6LnnotMiQQrrPjCqQ==",
1049 | "dev": true,
1050 | "requires": {
1051 | "eslint": "^6.8.0",
1052 | "eslint-config-esnext": "^4.1.0"
1053 | },
1054 | "dependencies": {
1055 | "ansi-regex": {
1056 | "version": "4.1.0",
1057 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
1058 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
1059 | "dev": true
1060 | },
1061 | "astral-regex": {
1062 | "version": "1.0.0",
1063 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz",
1064 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==",
1065 | "dev": true
1066 | },
1067 | "chalk": {
1068 | "version": "2.4.2",
1069 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
1070 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
1071 | "dev": true,
1072 | "requires": {
1073 | "ansi-styles": "^3.2.1",
1074 | "escape-string-regexp": "^1.0.5",
1075 | "supports-color": "^5.3.0"
1076 | }
1077 | },
1078 | "cross-spawn": {
1079 | "version": "6.0.5",
1080 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz",
1081 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==",
1082 | "dev": true,
1083 | "requires": {
1084 | "nice-try": "^1.0.4",
1085 | "path-key": "^2.0.1",
1086 | "semver": "^5.5.0",
1087 | "shebang-command": "^1.2.0",
1088 | "which": "^1.2.9"
1089 | },
1090 | "dependencies": {
1091 | "semver": {
1092 | "version": "5.7.1",
1093 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
1094 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
1095 | "dev": true
1096 | }
1097 | }
1098 | },
1099 | "emoji-regex": {
1100 | "version": "7.0.3",
1101 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz",
1102 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==",
1103 | "dev": true
1104 | },
1105 | "eslint": {
1106 | "version": "6.8.0",
1107 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz",
1108 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==",
1109 | "dev": true,
1110 | "requires": {
1111 | "@babel/code-frame": "^7.0.0",
1112 | "ajv": "^6.10.0",
1113 | "chalk": "^2.1.0",
1114 | "cross-spawn": "^6.0.5",
1115 | "debug": "^4.0.1",
1116 | "doctrine": "^3.0.0",
1117 | "eslint-scope": "^5.0.0",
1118 | "eslint-utils": "^1.4.3",
1119 | "eslint-visitor-keys": "^1.1.0",
1120 | "espree": "^6.1.2",
1121 | "esquery": "^1.0.1",
1122 | "esutils": "^2.0.2",
1123 | "file-entry-cache": "^5.0.1",
1124 | "functional-red-black-tree": "^1.0.1",
1125 | "glob-parent": "^5.0.0",
1126 | "globals": "^12.1.0",
1127 | "ignore": "^4.0.6",
1128 | "import-fresh": "^3.0.0",
1129 | "imurmurhash": "^0.1.4",
1130 | "inquirer": "^7.0.0",
1131 | "is-glob": "^4.0.0",
1132 | "js-yaml": "^3.13.1",
1133 | "json-stable-stringify-without-jsonify": "^1.0.1",
1134 | "levn": "^0.3.0",
1135 | "lodash": "^4.17.14",
1136 | "minimatch": "^3.0.4",
1137 | "mkdirp": "^0.5.1",
1138 | "natural-compare": "^1.4.0",
1139 | "optionator": "^0.8.3",
1140 | "progress": "^2.0.0",
1141 | "regexpp": "^2.0.1",
1142 | "semver": "^6.1.2",
1143 | "strip-ansi": "^5.2.0",
1144 | "strip-json-comments": "^3.0.1",
1145 | "table": "^5.2.3",
1146 | "text-table": "^0.2.0",
1147 | "v8-compile-cache": "^2.0.3"
1148 | }
1149 | },
1150 | "eslint-utils": {
1151 | "version": "1.4.3",
1152 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz",
1153 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==",
1154 | "dev": true,
1155 | "requires": {
1156 | "eslint-visitor-keys": "^1.1.0"
1157 | }
1158 | },
1159 | "eslint-visitor-keys": {
1160 | "version": "1.3.0",
1161 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz",
1162 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==",
1163 | "dev": true
1164 | },
1165 | "espree": {
1166 | "version": "6.2.1",
1167 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz",
1168 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==",
1169 | "dev": true,
1170 | "requires": {
1171 | "acorn": "^7.1.1",
1172 | "acorn-jsx": "^5.2.0",
1173 | "eslint-visitor-keys": "^1.1.0"
1174 | }
1175 | },
1176 | "file-entry-cache": {
1177 | "version": "5.0.1",
1178 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz",
1179 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==",
1180 | "dev": true,
1181 | "requires": {
1182 | "flat-cache": "^2.0.1"
1183 | }
1184 | },
1185 | "flat-cache": {
1186 | "version": "2.0.1",
1187 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz",
1188 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==",
1189 | "dev": true,
1190 | "requires": {
1191 | "flatted": "^2.0.0",
1192 | "rimraf": "2.6.3",
1193 | "write": "1.0.3"
1194 | }
1195 | },
1196 | "flatted": {
1197 | "version": "2.0.2",
1198 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz",
1199 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==",
1200 | "dev": true
1201 | },
1202 | "is-fullwidth-code-point": {
1203 | "version": "2.0.0",
1204 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
1205 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=",
1206 | "dev": true
1207 | },
1208 | "levn": {
1209 | "version": "0.3.0",
1210 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz",
1211 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=",
1212 | "dev": true,
1213 | "requires": {
1214 | "prelude-ls": "~1.1.2",
1215 | "type-check": "~0.3.2"
1216 | }
1217 | },
1218 | "optionator": {
1219 | "version": "0.8.3",
1220 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz",
1221 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==",
1222 | "dev": true,
1223 | "requires": {
1224 | "deep-is": "~0.1.3",
1225 | "fast-levenshtein": "~2.0.6",
1226 | "levn": "~0.3.0",
1227 | "prelude-ls": "~1.1.2",
1228 | "type-check": "~0.3.2",
1229 | "word-wrap": "~1.2.3"
1230 | }
1231 | },
1232 | "path-key": {
1233 | "version": "2.0.1",
1234 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
1235 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
1236 | "dev": true
1237 | },
1238 | "prelude-ls": {
1239 | "version": "1.1.2",
1240 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz",
1241 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=",
1242 | "dev": true
1243 | },
1244 | "regexpp": {
1245 | "version": "2.0.1",
1246 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz",
1247 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==",
1248 | "dev": true
1249 | },
1250 | "rimraf": {
1251 | "version": "2.6.3",
1252 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz",
1253 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==",
1254 | "dev": true,
1255 | "requires": {
1256 | "glob": "^7.1.3"
1257 | }
1258 | },
1259 | "semver": {
1260 | "version": "6.3.0",
1261 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1262 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1263 | "dev": true
1264 | },
1265 | "shebang-command": {
1266 | "version": "1.2.0",
1267 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
1268 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
1269 | "dev": true,
1270 | "requires": {
1271 | "shebang-regex": "^1.0.0"
1272 | }
1273 | },
1274 | "shebang-regex": {
1275 | "version": "1.0.0",
1276 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
1277 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
1278 | "dev": true
1279 | },
1280 | "slice-ansi": {
1281 | "version": "2.1.0",
1282 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz",
1283 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==",
1284 | "dev": true,
1285 | "requires": {
1286 | "ansi-styles": "^3.2.0",
1287 | "astral-regex": "^1.0.0",
1288 | "is-fullwidth-code-point": "^2.0.0"
1289 | }
1290 | },
1291 | "string-width": {
1292 | "version": "3.1.0",
1293 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
1294 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
1295 | "dev": true,
1296 | "requires": {
1297 | "emoji-regex": "^7.0.1",
1298 | "is-fullwidth-code-point": "^2.0.0",
1299 | "strip-ansi": "^5.1.0"
1300 | }
1301 | },
1302 | "strip-ansi": {
1303 | "version": "5.2.0",
1304 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
1305 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
1306 | "dev": true,
1307 | "requires": {
1308 | "ansi-regex": "^4.1.0"
1309 | }
1310 | },
1311 | "table": {
1312 | "version": "5.4.6",
1313 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz",
1314 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==",
1315 | "dev": true,
1316 | "requires": {
1317 | "ajv": "^6.10.2",
1318 | "lodash": "^4.17.14",
1319 | "slice-ansi": "^2.1.0",
1320 | "string-width": "^3.0.0"
1321 | }
1322 | },
1323 | "type-check": {
1324 | "version": "0.3.2",
1325 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz",
1326 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=",
1327 | "dev": true,
1328 | "requires": {
1329 | "prelude-ls": "~1.1.2"
1330 | }
1331 | },
1332 | "which": {
1333 | "version": "1.3.1",
1334 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
1335 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
1336 | "dev": true,
1337 | "requires": {
1338 | "isexe": "^2.0.0"
1339 | }
1340 | }
1341 | }
1342 | },
1343 | "eslint-config-prettier": {
1344 | "version": "7.2.0",
1345 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-7.2.0.tgz",
1346 | "integrity": "sha512-rV4Qu0C3nfJKPOAhFujFxB7RMP+URFyQqqOZW9DMRD7ZDTFyjaIlETU3xzHELt++4ugC0+Jm084HQYkkJe+Ivg==",
1347 | "dev": true
1348 | },
1349 | "eslint-import-resolver-node": {
1350 | "version": "0.3.4",
1351 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.4.tgz",
1352 | "integrity": "sha512-ogtf+5AB/O+nM6DIeBUNr2fuT7ot9Qg/1harBfBtaP13ekEWFQEEMP94BCB7zaNW3gyY+8SHYF00rnqYwXKWOA==",
1353 | "dev": true,
1354 | "requires": {
1355 | "debug": "^2.6.9",
1356 | "resolve": "^1.13.1"
1357 | },
1358 | "dependencies": {
1359 | "debug": {
1360 | "version": "2.6.9",
1361 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
1362 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
1363 | "dev": true,
1364 | "requires": {
1365 | "ms": "2.0.0"
1366 | }
1367 | },
1368 | "ms": {
1369 | "version": "2.0.0",
1370 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
1371 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
1372 | "dev": true
1373 | }
1374 | }
1375 | },
1376 | "eslint-module-utils": {
1377 | "version": "2.6.0",
1378 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.6.0.tgz",
1379 | "integrity": "sha512-6j9xxegbqe8/kZY8cYpcp0xhbK0EgJlg3g9mib3/miLaExuuwc3n5UEfSnU6hWMbT0FAYVvDbL9RrRgpUeQIvA==",
1380 | "dev": true,
1381 | "requires": {
1382 | "debug": "^2.6.9",
1383 | "pkg-dir": "^2.0.0"
1384 | },
1385 | "dependencies": {
1386 | "debug": {
1387 | "version": "2.6.9",
1388 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
1389 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
1390 | "dev": true,
1391 | "requires": {
1392 | "ms": "2.0.0"
1393 | }
1394 | },
1395 | "ms": {
1396 | "version": "2.0.0",
1397 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
1398 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
1399 | "dev": true
1400 | }
1401 | }
1402 | },
1403 | "eslint-plugin-babel": {
1404 | "version": "5.3.1",
1405 | "resolved": "https://registry.npmjs.org/eslint-plugin-babel/-/eslint-plugin-babel-5.3.1.tgz",
1406 | "integrity": "sha512-VsQEr6NH3dj664+EyxJwO4FCYm/00JhYb3Sk3ft8o+fpKuIfQ9TaW6uVUfvwMXHcf/lsnRIoyFPsLMyiWCSL/g==",
1407 | "dev": true,
1408 | "requires": {
1409 | "eslint-rule-composer": "^0.3.0"
1410 | }
1411 | },
1412 | "eslint-plugin-es": {
1413 | "version": "3.0.1",
1414 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-3.0.1.tgz",
1415 | "integrity": "sha512-GUmAsJaN4Fc7Gbtl8uOBlayo2DqhwWvEzykMHSCZHU3XdJ+NSzzZcVhXh3VxX5icqQ+oQdIEawXX8xkR3mIFmQ==",
1416 | "dev": true,
1417 | "requires": {
1418 | "eslint-utils": "^2.0.0",
1419 | "regexpp": "^3.0.0"
1420 | }
1421 | },
1422 | "eslint-plugin-import": {
1423 | "version": "2.22.1",
1424 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.22.1.tgz",
1425 | "integrity": "sha512-8K7JjINHOpH64ozkAhpT3sd+FswIZTfMZTjdx052pnWrgRCVfp8op9tbjpAk3DdUeI/Ba4C8OjdC0r90erHEOw==",
1426 | "dev": true,
1427 | "requires": {
1428 | "array-includes": "^3.1.1",
1429 | "array.prototype.flat": "^1.2.3",
1430 | "contains-path": "^0.1.0",
1431 | "debug": "^2.6.9",
1432 | "doctrine": "1.5.0",
1433 | "eslint-import-resolver-node": "^0.3.4",
1434 | "eslint-module-utils": "^2.6.0",
1435 | "has": "^1.0.3",
1436 | "minimatch": "^3.0.4",
1437 | "object.values": "^1.1.1",
1438 | "read-pkg-up": "^2.0.0",
1439 | "resolve": "^1.17.0",
1440 | "tsconfig-paths": "^3.9.0"
1441 | },
1442 | "dependencies": {
1443 | "debug": {
1444 | "version": "2.6.9",
1445 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
1446 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
1447 | "dev": true,
1448 | "requires": {
1449 | "ms": "2.0.0"
1450 | }
1451 | },
1452 | "doctrine": {
1453 | "version": "1.5.0",
1454 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz",
1455 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=",
1456 | "dev": true,
1457 | "requires": {
1458 | "esutils": "^2.0.2",
1459 | "isarray": "^1.0.0"
1460 | }
1461 | },
1462 | "ms": {
1463 | "version": "2.0.0",
1464 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
1465 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
1466 | "dev": true
1467 | }
1468 | }
1469 | },
1470 | "eslint-plugin-node": {
1471 | "version": "11.1.0",
1472 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-11.1.0.tgz",
1473 | "integrity": "sha512-oUwtPJ1W0SKD0Tr+wqu92c5xuCeQqB3hSCHasn/ZgjFdA9iDGNkNf2Zi9ztY7X+hNuMib23LNGRm6+uN+KLE3g==",
1474 | "dev": true,
1475 | "requires": {
1476 | "eslint-plugin-es": "^3.0.0",
1477 | "eslint-utils": "^2.0.0",
1478 | "ignore": "^5.1.1",
1479 | "minimatch": "^3.0.4",
1480 | "resolve": "^1.10.1",
1481 | "semver": "^6.1.0"
1482 | },
1483 | "dependencies": {
1484 | "ignore": {
1485 | "version": "5.1.8",
1486 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.8.tgz",
1487 | "integrity": "sha512-BMpfD7PpiETpBl/A6S498BaIJ6Y/ABT93ETbby2fP00v4EbvPBXWEoaR1UBPKs3iR53pJY7EtZk5KACI57i1Uw==",
1488 | "dev": true
1489 | },
1490 | "semver": {
1491 | "version": "6.3.0",
1492 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1493 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1494 | "dev": true
1495 | }
1496 | }
1497 | },
1498 | "eslint-plugin-prettier": {
1499 | "version": "3.3.1",
1500 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.3.1.tgz",
1501 | "integrity": "sha512-Rq3jkcFY8RYeQLgk2cCwuc0P7SEFwDravPhsJZOQ5N4YI4DSg50NyqJ/9gdZHzQlHf8MvafSesbNJCcP/FF6pQ==",
1502 | "dev": true,
1503 | "requires": {
1504 | "prettier-linter-helpers": "^1.0.0"
1505 | }
1506 | },
1507 | "eslint-rule-composer": {
1508 | "version": "0.3.0",
1509 | "resolved": "https://registry.npmjs.org/eslint-rule-composer/-/eslint-rule-composer-0.3.0.tgz",
1510 | "integrity": "sha512-bt+Sh8CtDmn2OajxvNO+BX7Wn4CIWMpTRm3MaiKPCQcnnlm0CS2mhui6QaoeQugs+3Kj2ESKEEGJUdVafwhiCg==",
1511 | "dev": true
1512 | },
1513 | "eslint-scope": {
1514 | "version": "5.1.1",
1515 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz",
1516 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==",
1517 | "dev": true,
1518 | "requires": {
1519 | "esrecurse": "^4.3.0",
1520 | "estraverse": "^4.1.1"
1521 | }
1522 | },
1523 | "eslint-utils": {
1524 | "version": "2.1.0",
1525 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz",
1526 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==",
1527 | "dev": true,
1528 | "requires": {
1529 | "eslint-visitor-keys": "^1.1.0"
1530 | },
1531 | "dependencies": {
1532 | "eslint-visitor-keys": {
1533 | "version": "1.3.0",
1534 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz",
1535 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==",
1536 | "dev": true
1537 | }
1538 | }
1539 | },
1540 | "eslint-visitor-keys": {
1541 | "version": "2.0.0",
1542 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz",
1543 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==",
1544 | "dev": true
1545 | },
1546 | "espree": {
1547 | "version": "7.3.1",
1548 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz",
1549 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==",
1550 | "dev": true,
1551 | "requires": {
1552 | "acorn": "^7.4.0",
1553 | "acorn-jsx": "^5.3.1",
1554 | "eslint-visitor-keys": "^1.3.0"
1555 | },
1556 | "dependencies": {
1557 | "eslint-visitor-keys": {
1558 | "version": "1.3.0",
1559 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz",
1560 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==",
1561 | "dev": true
1562 | }
1563 | }
1564 | },
1565 | "esprima": {
1566 | "version": "4.0.1",
1567 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
1568 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
1569 | "dev": true
1570 | },
1571 | "esquery": {
1572 | "version": "1.3.1",
1573 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz",
1574 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==",
1575 | "dev": true,
1576 | "requires": {
1577 | "estraverse": "^5.1.0"
1578 | },
1579 | "dependencies": {
1580 | "estraverse": {
1581 | "version": "5.2.0",
1582 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz",
1583 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==",
1584 | "dev": true
1585 | }
1586 | }
1587 | },
1588 | "esrecurse": {
1589 | "version": "4.3.0",
1590 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
1591 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
1592 | "dev": true,
1593 | "requires": {
1594 | "estraverse": "^5.2.0"
1595 | },
1596 | "dependencies": {
1597 | "estraverse": {
1598 | "version": "5.2.0",
1599 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz",
1600 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==",
1601 | "dev": true
1602 | }
1603 | }
1604 | },
1605 | "estraverse": {
1606 | "version": "4.3.0",
1607 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz",
1608 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==",
1609 | "dev": true
1610 | },
1611 | "esutils": {
1612 | "version": "2.0.3",
1613 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
1614 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
1615 | "dev": true
1616 | },
1617 | "execa": {
1618 | "version": "4.1.0",
1619 | "resolved": "https://registry.npmjs.org/execa/-/execa-4.1.0.tgz",
1620 | "integrity": "sha512-j5W0//W7f8UxAn8hXVnwG8tLwdiUy4FJLcSupCg6maBYZDpyBvTApK7KyuI4bKj8KOh1r2YH+6ucuYtJv1bTZA==",
1621 | "dev": true,
1622 | "requires": {
1623 | "cross-spawn": "^7.0.0",
1624 | "get-stream": "^5.0.0",
1625 | "human-signals": "^1.1.1",
1626 | "is-stream": "^2.0.0",
1627 | "merge-stream": "^2.0.0",
1628 | "npm-run-path": "^4.0.0",
1629 | "onetime": "^5.1.0",
1630 | "signal-exit": "^3.0.2",
1631 | "strip-final-newline": "^2.0.0"
1632 | }
1633 | },
1634 | "external-editor": {
1635 | "version": "3.1.0",
1636 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz",
1637 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==",
1638 | "dev": true,
1639 | "requires": {
1640 | "chardet": "^0.7.0",
1641 | "iconv-lite": "^0.4.24",
1642 | "tmp": "^0.0.33"
1643 | }
1644 | },
1645 | "fast-deep-equal": {
1646 | "version": "3.1.3",
1647 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
1648 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
1649 | "dev": true
1650 | },
1651 | "fast-diff": {
1652 | "version": "1.2.0",
1653 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz",
1654 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==",
1655 | "dev": true
1656 | },
1657 | "fast-json-stable-stringify": {
1658 | "version": "2.1.0",
1659 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
1660 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
1661 | "dev": true
1662 | },
1663 | "fast-levenshtein": {
1664 | "version": "2.0.6",
1665 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
1666 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=",
1667 | "dev": true
1668 | },
1669 | "figures": {
1670 | "version": "3.2.0",
1671 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz",
1672 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==",
1673 | "dev": true,
1674 | "requires": {
1675 | "escape-string-regexp": "^1.0.5"
1676 | }
1677 | },
1678 | "file-entry-cache": {
1679 | "version": "6.0.0",
1680 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.0.tgz",
1681 | "integrity": "sha512-fqoO76jZ3ZnYrXLDRxBR1YvOvc0k844kcOg40bgsPrE25LAb/PDqTY+ho64Xh2c8ZXgIKldchCFHczG2UVRcWA==",
1682 | "dev": true,
1683 | "requires": {
1684 | "flat-cache": "^3.0.4"
1685 | }
1686 | },
1687 | "fill-range": {
1688 | "version": "7.0.1",
1689 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
1690 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
1691 | "dev": true,
1692 | "requires": {
1693 | "to-regex-range": "^5.0.1"
1694 | }
1695 | },
1696 | "find-up": {
1697 | "version": "2.1.0",
1698 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz",
1699 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=",
1700 | "dev": true,
1701 | "requires": {
1702 | "locate-path": "^2.0.0"
1703 | }
1704 | },
1705 | "find-versions": {
1706 | "version": "4.0.0",
1707 | "resolved": "https://registry.npmjs.org/find-versions/-/find-versions-4.0.0.tgz",
1708 | "integrity": "sha512-wgpWy002tA+wgmO27buH/9KzyEOQnKsG/R0yrcjPT9BOFm0zRBVQbZ95nRGXWMywS8YR5knRbpohio0bcJABxQ==",
1709 | "dev": true,
1710 | "requires": {
1711 | "semver-regex": "^3.1.2"
1712 | }
1713 | },
1714 | "flat-cache": {
1715 | "version": "3.0.4",
1716 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz",
1717 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==",
1718 | "dev": true,
1719 | "requires": {
1720 | "flatted": "^3.1.0",
1721 | "rimraf": "^3.0.2"
1722 | }
1723 | },
1724 | "flatted": {
1725 | "version": "3.1.1",
1726 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz",
1727 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==",
1728 | "dev": true
1729 | },
1730 | "fs.realpath": {
1731 | "version": "1.0.0",
1732 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
1733 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=",
1734 | "dev": true
1735 | },
1736 | "function-bind": {
1737 | "version": "1.1.1",
1738 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
1739 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
1740 | "dev": true
1741 | },
1742 | "functional-red-black-tree": {
1743 | "version": "1.0.1",
1744 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz",
1745 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=",
1746 | "dev": true
1747 | },
1748 | "get-intrinsic": {
1749 | "version": "1.1.0",
1750 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.0.tgz",
1751 | "integrity": "sha512-M11rgtQp5GZMZzDL7jLTNxbDfurpzuau5uqRWDPvlHjfvg3TdScAZo96GLvhMjImrmR8uAt0FS2RLoMrfWGKlg==",
1752 | "dev": true,
1753 | "requires": {
1754 | "function-bind": "^1.1.1",
1755 | "has": "^1.0.3",
1756 | "has-symbols": "^1.0.1"
1757 | }
1758 | },
1759 | "get-own-enumerable-property-symbols": {
1760 | "version": "3.0.2",
1761 | "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz",
1762 | "integrity": "sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==",
1763 | "dev": true
1764 | },
1765 | "get-stream": {
1766 | "version": "5.2.0",
1767 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz",
1768 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==",
1769 | "dev": true,
1770 | "requires": {
1771 | "pump": "^3.0.0"
1772 | }
1773 | },
1774 | "glob": {
1775 | "version": "7.1.6",
1776 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz",
1777 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==",
1778 | "dev": true,
1779 | "requires": {
1780 | "fs.realpath": "^1.0.0",
1781 | "inflight": "^1.0.4",
1782 | "inherits": "2",
1783 | "minimatch": "^3.0.4",
1784 | "once": "^1.3.0",
1785 | "path-is-absolute": "^1.0.0"
1786 | }
1787 | },
1788 | "glob-parent": {
1789 | "version": "5.1.1",
1790 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz",
1791 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==",
1792 | "dev": true,
1793 | "requires": {
1794 | "is-glob": "^4.0.1"
1795 | }
1796 | },
1797 | "globals": {
1798 | "version": "12.4.0",
1799 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz",
1800 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==",
1801 | "dev": true,
1802 | "requires": {
1803 | "type-fest": "^0.8.1"
1804 | }
1805 | },
1806 | "graceful-fs": {
1807 | "version": "4.2.4",
1808 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz",
1809 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==",
1810 | "dev": true
1811 | },
1812 | "has": {
1813 | "version": "1.0.3",
1814 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
1815 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
1816 | "dev": true,
1817 | "requires": {
1818 | "function-bind": "^1.1.1"
1819 | }
1820 | },
1821 | "has-flag": {
1822 | "version": "3.0.0",
1823 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
1824 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
1825 | "dev": true
1826 | },
1827 | "has-symbols": {
1828 | "version": "1.0.1",
1829 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz",
1830 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg=="
1831 | },
1832 | "hosted-git-info": {
1833 | "version": "2.8.8",
1834 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz",
1835 | "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==",
1836 | "dev": true
1837 | },
1838 | "human-signals": {
1839 | "version": "1.1.1",
1840 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz",
1841 | "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==",
1842 | "dev": true
1843 | },
1844 | "husky": {
1845 | "version": "4.3.8",
1846 | "resolved": "https://registry.npmjs.org/husky/-/husky-4.3.8.tgz",
1847 | "integrity": "sha512-LCqqsB0PzJQ/AlCgfrfzRe3e3+NvmefAdKQhRYpxS4u6clblBoDdzzvHi8fmxKRzvMxPY/1WZWzomPZww0Anow==",
1848 | "dev": true,
1849 | "requires": {
1850 | "chalk": "^4.0.0",
1851 | "ci-info": "^2.0.0",
1852 | "compare-versions": "^3.6.0",
1853 | "cosmiconfig": "^7.0.0",
1854 | "find-versions": "^4.0.0",
1855 | "opencollective-postinstall": "^2.0.2",
1856 | "pkg-dir": "^5.0.0",
1857 | "please-upgrade-node": "^3.2.0",
1858 | "slash": "^3.0.0",
1859 | "which-pm-runs": "^1.0.0"
1860 | },
1861 | "dependencies": {
1862 | "find-up": {
1863 | "version": "5.0.0",
1864 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
1865 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
1866 | "dev": true,
1867 | "requires": {
1868 | "locate-path": "^6.0.0",
1869 | "path-exists": "^4.0.0"
1870 | }
1871 | },
1872 | "locate-path": {
1873 | "version": "6.0.0",
1874 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
1875 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
1876 | "dev": true,
1877 | "requires": {
1878 | "p-locate": "^5.0.0"
1879 | }
1880 | },
1881 | "p-limit": {
1882 | "version": "3.1.0",
1883 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
1884 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
1885 | "dev": true,
1886 | "requires": {
1887 | "yocto-queue": "^0.1.0"
1888 | }
1889 | },
1890 | "p-locate": {
1891 | "version": "5.0.0",
1892 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
1893 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
1894 | "dev": true,
1895 | "requires": {
1896 | "p-limit": "^3.0.2"
1897 | }
1898 | },
1899 | "path-exists": {
1900 | "version": "4.0.0",
1901 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
1902 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
1903 | "dev": true
1904 | },
1905 | "pkg-dir": {
1906 | "version": "5.0.0",
1907 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-5.0.0.tgz",
1908 | "integrity": "sha512-NPE8TDbzl/3YQYY7CSS228s3g2ollTFnc+Qi3tqmqJp9Vg2ovUpixcJEo2HJScN2Ez+kEaal6y70c0ehqJBJeA==",
1909 | "dev": true,
1910 | "requires": {
1911 | "find-up": "^5.0.0"
1912 | }
1913 | }
1914 | }
1915 | },
1916 | "iconv-lite": {
1917 | "version": "0.4.24",
1918 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
1919 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
1920 | "dev": true,
1921 | "requires": {
1922 | "safer-buffer": ">= 2.1.2 < 3"
1923 | }
1924 | },
1925 | "ignore": {
1926 | "version": "4.0.6",
1927 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz",
1928 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==",
1929 | "dev": true
1930 | },
1931 | "import-fresh": {
1932 | "version": "3.3.0",
1933 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
1934 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
1935 | "dev": true,
1936 | "requires": {
1937 | "parent-module": "^1.0.0",
1938 | "resolve-from": "^4.0.0"
1939 | }
1940 | },
1941 | "imurmurhash": {
1942 | "version": "0.1.4",
1943 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
1944 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
1945 | "dev": true
1946 | },
1947 | "indent-string": {
1948 | "version": "4.0.0",
1949 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz",
1950 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==",
1951 | "dev": true
1952 | },
1953 | "inflight": {
1954 | "version": "1.0.6",
1955 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
1956 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
1957 | "dev": true,
1958 | "requires": {
1959 | "once": "^1.3.0",
1960 | "wrappy": "1"
1961 | }
1962 | },
1963 | "inherits": {
1964 | "version": "2.0.4",
1965 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
1966 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
1967 | "dev": true
1968 | },
1969 | "inquirer": {
1970 | "version": "7.3.3",
1971 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.3.3.tgz",
1972 | "integrity": "sha512-JG3eIAj5V9CwcGvuOmoo6LB9kbAYT8HXffUl6memuszlwDC/qvFAJw49XJ5NROSFNPxp3iQg1GqkFhaY/CR0IA==",
1973 | "dev": true,
1974 | "requires": {
1975 | "ansi-escapes": "^4.2.1",
1976 | "chalk": "^4.1.0",
1977 | "cli-cursor": "^3.1.0",
1978 | "cli-width": "^3.0.0",
1979 | "external-editor": "^3.0.3",
1980 | "figures": "^3.0.0",
1981 | "lodash": "^4.17.19",
1982 | "mute-stream": "0.0.8",
1983 | "run-async": "^2.4.0",
1984 | "rxjs": "^6.6.0",
1985 | "string-width": "^4.1.0",
1986 | "strip-ansi": "^6.0.0",
1987 | "through": "^2.3.6"
1988 | }
1989 | },
1990 | "is-arrayish": {
1991 | "version": "0.2.1",
1992 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
1993 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
1994 | "dev": true
1995 | },
1996 | "is-callable": {
1997 | "version": "1.2.2",
1998 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.2.tgz",
1999 | "integrity": "sha512-dnMqspv5nU3LoewK2N/y7KLtxtakvTuaCsU9FU50/QDmdbHNy/4/JuRtMHqRU22o3q+W89YQndQEeCVwK+3qrA==",
2000 | "dev": true
2001 | },
2002 | "is-core-module": {
2003 | "version": "2.2.0",
2004 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.2.0.tgz",
2005 | "integrity": "sha512-XRAfAdyyY5F5cOXn7hYQDqh2Xmii+DEfIcQGxK/uNwMHhIkPWO0g8msXcbzLe+MpGoR951MlqM/2iIlU4vKDdQ==",
2006 | "dev": true,
2007 | "requires": {
2008 | "has": "^1.0.3"
2009 | }
2010 | },
2011 | "is-date-object": {
2012 | "version": "1.0.2",
2013 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz",
2014 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==",
2015 | "dev": true
2016 | },
2017 | "is-extglob": {
2018 | "version": "2.1.1",
2019 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
2020 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
2021 | "dev": true
2022 | },
2023 | "is-fullwidth-code-point": {
2024 | "version": "3.0.0",
2025 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
2026 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
2027 | "dev": true
2028 | },
2029 | "is-glob": {
2030 | "version": "4.0.1",
2031 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
2032 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
2033 | "dev": true,
2034 | "requires": {
2035 | "is-extglob": "^2.1.1"
2036 | }
2037 | },
2038 | "is-negative-zero": {
2039 | "version": "2.0.1",
2040 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.1.tgz",
2041 | "integrity": "sha512-2z6JzQvZRa9A2Y7xC6dQQm4FSTSTNWjKIYYTt4246eMTJmIo0Q+ZyOsU66X8lxK1AbB92dFeglPLrhwpeRKO6w==",
2042 | "dev": true
2043 | },
2044 | "is-number": {
2045 | "version": "7.0.0",
2046 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
2047 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
2048 | "dev": true
2049 | },
2050 | "is-obj": {
2051 | "version": "1.0.1",
2052 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz",
2053 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=",
2054 | "dev": true
2055 | },
2056 | "is-plain-object": {
2057 | "version": "2.0.4",
2058 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz",
2059 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==",
2060 | "requires": {
2061 | "isobject": "^3.0.1"
2062 | }
2063 | },
2064 | "is-regex": {
2065 | "version": "1.1.1",
2066 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz",
2067 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==",
2068 | "requires": {
2069 | "has-symbols": "^1.0.1"
2070 | }
2071 | },
2072 | "is-regexp": {
2073 | "version": "1.0.0",
2074 | "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz",
2075 | "integrity": "sha1-/S2INUXEa6xaYz57mgnof6LLUGk=",
2076 | "dev": true
2077 | },
2078 | "is-stream": {
2079 | "version": "2.0.0",
2080 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz",
2081 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==",
2082 | "dev": true
2083 | },
2084 | "is-string": {
2085 | "version": "1.0.5",
2086 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz",
2087 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==",
2088 | "dev": true
2089 | },
2090 | "is-symbol": {
2091 | "version": "1.0.3",
2092 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz",
2093 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==",
2094 | "dev": true,
2095 | "requires": {
2096 | "has-symbols": "^1.0.1"
2097 | }
2098 | },
2099 | "isarray": {
2100 | "version": "1.0.0",
2101 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
2102 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
2103 | "dev": true
2104 | },
2105 | "isexe": {
2106 | "version": "2.0.0",
2107 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
2108 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
2109 | "dev": true
2110 | },
2111 | "isobject": {
2112 | "version": "3.0.1",
2113 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz",
2114 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8="
2115 | },
2116 | "js-tokens": {
2117 | "version": "4.0.0",
2118 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
2119 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
2120 | "dev": true
2121 | },
2122 | "js-yaml": {
2123 | "version": "3.14.1",
2124 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz",
2125 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==",
2126 | "dev": true,
2127 | "requires": {
2128 | "argparse": "^1.0.7",
2129 | "esprima": "^4.0.0"
2130 | }
2131 | },
2132 | "jsesc": {
2133 | "version": "2.5.2",
2134 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
2135 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
2136 | "dev": true
2137 | },
2138 | "json-parse-even-better-errors": {
2139 | "version": "2.3.1",
2140 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
2141 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
2142 | "dev": true
2143 | },
2144 | "json-schema-traverse": {
2145 | "version": "0.4.1",
2146 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
2147 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
2148 | "dev": true
2149 | },
2150 | "json-stable-stringify-without-jsonify": {
2151 | "version": "1.0.1",
2152 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
2153 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=",
2154 | "dev": true
2155 | },
2156 | "json5": {
2157 | "version": "1.0.1",
2158 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz",
2159 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==",
2160 | "dev": true,
2161 | "requires": {
2162 | "minimist": "^1.2.0"
2163 | }
2164 | },
2165 | "kind-of": {
2166 | "version": "6.0.3",
2167 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
2168 | "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw=="
2169 | },
2170 | "levn": {
2171 | "version": "0.4.1",
2172 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
2173 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
2174 | "dev": true,
2175 | "requires": {
2176 | "prelude-ls": "^1.2.1",
2177 | "type-check": "~0.4.0"
2178 | }
2179 | },
2180 | "lines-and-columns": {
2181 | "version": "1.1.6",
2182 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz",
2183 | "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=",
2184 | "dev": true
2185 | },
2186 | "lint-staged": {
2187 | "version": "10.5.3",
2188 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-10.5.3.tgz",
2189 | "integrity": "sha512-TanwFfuqUBLufxCc3RUtFEkFraSPNR3WzWcGF39R3f2J7S9+iF9W0KTVLfSy09lYGmZS5NDCxjNvhGMSJyFCWg==",
2190 | "dev": true,
2191 | "requires": {
2192 | "chalk": "^4.1.0",
2193 | "cli-truncate": "^2.1.0",
2194 | "commander": "^6.2.0",
2195 | "cosmiconfig": "^7.0.0",
2196 | "debug": "^4.2.0",
2197 | "dedent": "^0.7.0",
2198 | "enquirer": "^2.3.6",
2199 | "execa": "^4.1.0",
2200 | "listr2": "^3.2.2",
2201 | "log-symbols": "^4.0.0",
2202 | "micromatch": "^4.0.2",
2203 | "normalize-path": "^3.0.0",
2204 | "please-upgrade-node": "^3.2.0",
2205 | "string-argv": "0.3.1",
2206 | "stringify-object": "^3.3.0"
2207 | }
2208 | },
2209 | "listr2": {
2210 | "version": "3.3.0",
2211 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-3.3.0.tgz",
2212 | "integrity": "sha512-G9IFI/m65icgVlifS0wMQnvn35/8VJGzEb3crpE4NnaegQYQOn/wP7yqi9TTJQ/eoxme4UaPbffBK1XqKP/DOg==",
2213 | "dev": true,
2214 | "requires": {
2215 | "chalk": "^4.1.0",
2216 | "cli-truncate": "^2.1.0",
2217 | "figures": "^3.2.0",
2218 | "indent-string": "^4.0.0",
2219 | "log-update": "^4.0.0",
2220 | "p-map": "^4.0.0",
2221 | "rxjs": "^6.6.3",
2222 | "through": "^2.3.8",
2223 | "wrap-ansi": "^7.0.0"
2224 | }
2225 | },
2226 | "load-json-file": {
2227 | "version": "2.0.0",
2228 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz",
2229 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=",
2230 | "dev": true,
2231 | "requires": {
2232 | "graceful-fs": "^4.1.2",
2233 | "parse-json": "^2.2.0",
2234 | "pify": "^2.0.0",
2235 | "strip-bom": "^3.0.0"
2236 | }
2237 | },
2238 | "locate-path": {
2239 | "version": "2.0.0",
2240 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz",
2241 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=",
2242 | "dev": true,
2243 | "requires": {
2244 | "p-locate": "^2.0.0",
2245 | "path-exists": "^3.0.0"
2246 | }
2247 | },
2248 | "lodash": {
2249 | "version": "4.17.20",
2250 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz",
2251 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA=="
2252 | },
2253 | "log-symbols": {
2254 | "version": "4.0.0",
2255 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz",
2256 | "integrity": "sha512-FN8JBzLx6CzeMrB0tg6pqlGU1wCrXW+ZXGH481kfsBqer0hToTIiHdjH4Mq8xJUbvATujKCvaREGWpGUionraA==",
2257 | "dev": true,
2258 | "requires": {
2259 | "chalk": "^4.0.0"
2260 | }
2261 | },
2262 | "log-update": {
2263 | "version": "4.0.0",
2264 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz",
2265 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==",
2266 | "dev": true,
2267 | "requires": {
2268 | "ansi-escapes": "^4.3.0",
2269 | "cli-cursor": "^3.1.0",
2270 | "slice-ansi": "^4.0.0",
2271 | "wrap-ansi": "^6.2.0"
2272 | },
2273 | "dependencies": {
2274 | "ansi-styles": {
2275 | "version": "4.3.0",
2276 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
2277 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
2278 | "dev": true,
2279 | "requires": {
2280 | "color-convert": "^2.0.1"
2281 | }
2282 | },
2283 | "color-convert": {
2284 | "version": "2.0.1",
2285 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
2286 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
2287 | "dev": true,
2288 | "requires": {
2289 | "color-name": "~1.1.4"
2290 | }
2291 | },
2292 | "color-name": {
2293 | "version": "1.1.4",
2294 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
2295 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
2296 | "dev": true
2297 | },
2298 | "wrap-ansi": {
2299 | "version": "6.2.0",
2300 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz",
2301 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==",
2302 | "dev": true,
2303 | "requires": {
2304 | "ansi-styles": "^4.0.0",
2305 | "string-width": "^4.1.0",
2306 | "strip-ansi": "^6.0.0"
2307 | }
2308 | }
2309 | }
2310 | },
2311 | "lru-cache": {
2312 | "version": "6.0.0",
2313 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
2314 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
2315 | "dev": true,
2316 | "requires": {
2317 | "yallist": "^4.0.0"
2318 | }
2319 | },
2320 | "merge-stream": {
2321 | "version": "2.0.0",
2322 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
2323 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
2324 | "dev": true
2325 | },
2326 | "micromatch": {
2327 | "version": "4.0.2",
2328 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz",
2329 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==",
2330 | "dev": true,
2331 | "requires": {
2332 | "braces": "^3.0.1",
2333 | "picomatch": "^2.0.5"
2334 | }
2335 | },
2336 | "mimic-fn": {
2337 | "version": "2.1.0",
2338 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
2339 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
2340 | "dev": true
2341 | },
2342 | "minimatch": {
2343 | "version": "3.0.4",
2344 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
2345 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
2346 | "dev": true,
2347 | "requires": {
2348 | "brace-expansion": "^1.1.7"
2349 | }
2350 | },
2351 | "minimist": {
2352 | "version": "1.2.5",
2353 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
2354 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
2355 | "dev": true
2356 | },
2357 | "mkdirp": {
2358 | "version": "0.5.5",
2359 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz",
2360 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==",
2361 | "dev": true,
2362 | "requires": {
2363 | "minimist": "^1.2.5"
2364 | }
2365 | },
2366 | "ms": {
2367 | "version": "2.1.2",
2368 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
2369 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
2370 | "dev": true
2371 | },
2372 | "mute-stream": {
2373 | "version": "0.0.8",
2374 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz",
2375 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==",
2376 | "dev": true
2377 | },
2378 | "natural-compare": {
2379 | "version": "1.4.0",
2380 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
2381 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=",
2382 | "dev": true
2383 | },
2384 | "nice-try": {
2385 | "version": "1.0.5",
2386 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
2387 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==",
2388 | "dev": true
2389 | },
2390 | "normalize-package-data": {
2391 | "version": "2.5.0",
2392 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz",
2393 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==",
2394 | "dev": true,
2395 | "requires": {
2396 | "hosted-git-info": "^2.1.4",
2397 | "resolve": "^1.10.0",
2398 | "semver": "2 || 3 || 4 || 5",
2399 | "validate-npm-package-license": "^3.0.1"
2400 | },
2401 | "dependencies": {
2402 | "semver": {
2403 | "version": "5.7.1",
2404 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
2405 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
2406 | "dev": true
2407 | }
2408 | }
2409 | },
2410 | "normalize-path": {
2411 | "version": "3.0.0",
2412 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
2413 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
2414 | "dev": true
2415 | },
2416 | "npm-run-path": {
2417 | "version": "4.0.1",
2418 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz",
2419 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==",
2420 | "dev": true,
2421 | "requires": {
2422 | "path-key": "^3.0.0"
2423 | }
2424 | },
2425 | "object-inspect": {
2426 | "version": "1.9.0",
2427 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.9.0.tgz",
2428 | "integrity": "sha512-i3Bp9iTqwhaLZBxGkRfo5ZbE07BQRT7MGu8+nNgwW9ItGp1TzCTw2DLEoWwjClxBjOFI/hWljTAmYGCEwmtnOw==",
2429 | "dev": true
2430 | },
2431 | "object-keys": {
2432 | "version": "1.1.1",
2433 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz",
2434 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==",
2435 | "dev": true
2436 | },
2437 | "object.assign": {
2438 | "version": "4.1.2",
2439 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz",
2440 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==",
2441 | "dev": true,
2442 | "requires": {
2443 | "call-bind": "^1.0.0",
2444 | "define-properties": "^1.1.3",
2445 | "has-symbols": "^1.0.1",
2446 | "object-keys": "^1.1.1"
2447 | }
2448 | },
2449 | "object.entries": {
2450 | "version": "1.1.3",
2451 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.3.tgz",
2452 | "integrity": "sha512-ym7h7OZebNS96hn5IJeyUmaWhaSM4SVtAPPfNLQEI2MYWCO2egsITb9nab2+i/Pwibx+R0mtn+ltKJXRSeTMGg==",
2453 | "dev": true,
2454 | "requires": {
2455 | "call-bind": "^1.0.0",
2456 | "define-properties": "^1.1.3",
2457 | "es-abstract": "^1.18.0-next.1",
2458 | "has": "^1.0.3"
2459 | }
2460 | },
2461 | "object.values": {
2462 | "version": "1.1.2",
2463 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.2.tgz",
2464 | "integrity": "sha512-MYC0jvJopr8EK6dPBiO8Nb9mvjdypOachO5REGk6MXzujbBrAisKo3HmdEI6kZDL6fC31Mwee/5YbtMebixeag==",
2465 | "dev": true,
2466 | "requires": {
2467 | "call-bind": "^1.0.0",
2468 | "define-properties": "^1.1.3",
2469 | "es-abstract": "^1.18.0-next.1",
2470 | "has": "^1.0.3"
2471 | }
2472 | },
2473 | "once": {
2474 | "version": "1.4.0",
2475 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
2476 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
2477 | "dev": true,
2478 | "requires": {
2479 | "wrappy": "1"
2480 | }
2481 | },
2482 | "onetime": {
2483 | "version": "5.1.2",
2484 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz",
2485 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==",
2486 | "dev": true,
2487 | "requires": {
2488 | "mimic-fn": "^2.1.0"
2489 | }
2490 | },
2491 | "opencollective-postinstall": {
2492 | "version": "2.0.3",
2493 | "resolved": "https://registry.npmjs.org/opencollective-postinstall/-/opencollective-postinstall-2.0.3.tgz",
2494 | "integrity": "sha512-8AV/sCtuzUeTo8gQK5qDZzARrulB3egtLzFgteqB2tcT4Mw7B8Kt7JcDHmltjz6FOAHsvTevk70gZEbhM4ZS9Q==",
2495 | "dev": true
2496 | },
2497 | "optionator": {
2498 | "version": "0.9.1",
2499 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz",
2500 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==",
2501 | "dev": true,
2502 | "requires": {
2503 | "deep-is": "^0.1.3",
2504 | "fast-levenshtein": "^2.0.6",
2505 | "levn": "^0.4.1",
2506 | "prelude-ls": "^1.2.1",
2507 | "type-check": "^0.4.0",
2508 | "word-wrap": "^1.2.3"
2509 | }
2510 | },
2511 | "os-tmpdir": {
2512 | "version": "1.0.2",
2513 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
2514 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=",
2515 | "dev": true
2516 | },
2517 | "p-limit": {
2518 | "version": "1.3.0",
2519 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz",
2520 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==",
2521 | "dev": true,
2522 | "requires": {
2523 | "p-try": "^1.0.0"
2524 | }
2525 | },
2526 | "p-locate": {
2527 | "version": "2.0.0",
2528 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz",
2529 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=",
2530 | "dev": true,
2531 | "requires": {
2532 | "p-limit": "^1.1.0"
2533 | }
2534 | },
2535 | "p-map": {
2536 | "version": "4.0.0",
2537 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz",
2538 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==",
2539 | "dev": true,
2540 | "requires": {
2541 | "aggregate-error": "^3.0.0"
2542 | }
2543 | },
2544 | "p-try": {
2545 | "version": "1.0.0",
2546 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz",
2547 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=",
2548 | "dev": true
2549 | },
2550 | "parent-module": {
2551 | "version": "1.0.1",
2552 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
2553 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
2554 | "dev": true,
2555 | "requires": {
2556 | "callsites": "^3.0.0"
2557 | }
2558 | },
2559 | "parse-json": {
2560 | "version": "2.2.0",
2561 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz",
2562 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=",
2563 | "dev": true,
2564 | "requires": {
2565 | "error-ex": "^1.2.0"
2566 | }
2567 | },
2568 | "path-exists": {
2569 | "version": "3.0.0",
2570 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz",
2571 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=",
2572 | "dev": true
2573 | },
2574 | "path-is-absolute": {
2575 | "version": "1.0.1",
2576 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
2577 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
2578 | "dev": true
2579 | },
2580 | "path-key": {
2581 | "version": "3.1.1",
2582 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
2583 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
2584 | "dev": true
2585 | },
2586 | "path-parse": {
2587 | "version": "1.0.6",
2588 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz",
2589 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==",
2590 | "dev": true
2591 | },
2592 | "path-type": {
2593 | "version": "2.0.0",
2594 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz",
2595 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=",
2596 | "dev": true,
2597 | "requires": {
2598 | "pify": "^2.0.0"
2599 | }
2600 | },
2601 | "picomatch": {
2602 | "version": "2.2.2",
2603 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz",
2604 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==",
2605 | "dev": true
2606 | },
2607 | "pify": {
2608 | "version": "2.3.0",
2609 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz",
2610 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=",
2611 | "dev": true
2612 | },
2613 | "pkg-dir": {
2614 | "version": "2.0.0",
2615 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz",
2616 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=",
2617 | "dev": true,
2618 | "requires": {
2619 | "find-up": "^2.1.0"
2620 | }
2621 | },
2622 | "please-upgrade-node": {
2623 | "version": "3.2.0",
2624 | "resolved": "https://registry.npmjs.org/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz",
2625 | "integrity": "sha512-gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg==",
2626 | "dev": true,
2627 | "requires": {
2628 | "semver-compare": "^1.0.0"
2629 | }
2630 | },
2631 | "prelude-ls": {
2632 | "version": "1.2.1",
2633 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
2634 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
2635 | "dev": true
2636 | },
2637 | "prettier": {
2638 | "version": "2.2.1",
2639 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.2.1.tgz",
2640 | "integrity": "sha512-PqyhM2yCjg/oKkFPtTGUojv7gnZAoG80ttl45O6x2Ug/rMJw4wcc9k6aaf2hibP7BGVCCM33gZoGjyvt9mm16Q==",
2641 | "dev": true
2642 | },
2643 | "prettier-linter-helpers": {
2644 | "version": "1.0.0",
2645 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz",
2646 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==",
2647 | "dev": true,
2648 | "requires": {
2649 | "fast-diff": "^1.1.2"
2650 | }
2651 | },
2652 | "progress": {
2653 | "version": "2.0.3",
2654 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz",
2655 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==",
2656 | "dev": true
2657 | },
2658 | "pump": {
2659 | "version": "3.0.0",
2660 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
2661 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
2662 | "dev": true,
2663 | "requires": {
2664 | "end-of-stream": "^1.1.0",
2665 | "once": "^1.3.1"
2666 | }
2667 | },
2668 | "punycode": {
2669 | "version": "2.1.1",
2670 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
2671 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==",
2672 | "dev": true
2673 | },
2674 | "read-pkg": {
2675 | "version": "2.0.0",
2676 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz",
2677 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=",
2678 | "dev": true,
2679 | "requires": {
2680 | "load-json-file": "^2.0.0",
2681 | "normalize-package-data": "^2.3.2",
2682 | "path-type": "^2.0.0"
2683 | }
2684 | },
2685 | "read-pkg-up": {
2686 | "version": "2.0.0",
2687 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz",
2688 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=",
2689 | "dev": true,
2690 | "requires": {
2691 | "find-up": "^2.0.0",
2692 | "read-pkg": "^2.0.0"
2693 | }
2694 | },
2695 | "regexpp": {
2696 | "version": "3.1.0",
2697 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz",
2698 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==",
2699 | "dev": true
2700 | },
2701 | "require-from-string": {
2702 | "version": "2.0.2",
2703 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz",
2704 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==",
2705 | "dev": true
2706 | },
2707 | "resolve": {
2708 | "version": "1.19.0",
2709 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.19.0.tgz",
2710 | "integrity": "sha512-rArEXAgsBG4UgRGcynxWIWKFvh/XZCcS8UJdHhwy91zwAvCZIbcs+vAbflgBnNjYMs/i/i+/Ux6IZhML1yPvxg==",
2711 | "dev": true,
2712 | "requires": {
2713 | "is-core-module": "^2.1.0",
2714 | "path-parse": "^1.0.6"
2715 | }
2716 | },
2717 | "resolve-from": {
2718 | "version": "4.0.0",
2719 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
2720 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
2721 | "dev": true
2722 | },
2723 | "restore-cursor": {
2724 | "version": "3.1.0",
2725 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz",
2726 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==",
2727 | "dev": true,
2728 | "requires": {
2729 | "onetime": "^5.1.0",
2730 | "signal-exit": "^3.0.2"
2731 | }
2732 | },
2733 | "rimraf": {
2734 | "version": "3.0.2",
2735 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
2736 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
2737 | "dev": true,
2738 | "requires": {
2739 | "glob": "^7.1.3"
2740 | }
2741 | },
2742 | "run-async": {
2743 | "version": "2.4.1",
2744 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz",
2745 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==",
2746 | "dev": true
2747 | },
2748 | "rxjs": {
2749 | "version": "6.6.3",
2750 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.3.tgz",
2751 | "integrity": "sha512-trsQc+xYYXZ3urjOiJOuCOa5N3jAZ3eiSpQB5hIT8zGlL2QfnHLJ2r7GMkBGuIausdJN1OneaI6gQlsqNHHmZQ==",
2752 | "dev": true,
2753 | "requires": {
2754 | "tslib": "^1.9.0"
2755 | }
2756 | },
2757 | "safer-buffer": {
2758 | "version": "2.1.2",
2759 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
2760 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==",
2761 | "dev": true
2762 | },
2763 | "semver": {
2764 | "version": "7.3.4",
2765 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz",
2766 | "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==",
2767 | "dev": true,
2768 | "requires": {
2769 | "lru-cache": "^6.0.0"
2770 | }
2771 | },
2772 | "semver-compare": {
2773 | "version": "1.0.0",
2774 | "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz",
2775 | "integrity": "sha1-De4hahyUGrN+nvsXiPavxf9VN/w=",
2776 | "dev": true
2777 | },
2778 | "semver-regex": {
2779 | "version": "3.1.2",
2780 | "resolved": "https://registry.npmjs.org/semver-regex/-/semver-regex-3.1.2.tgz",
2781 | "integrity": "sha512-bXWyL6EAKOJa81XG1OZ/Yyuq+oT0b2YLlxx7c+mrdYPaPbnj6WgVULXhinMIeZGufuUBu/eVRqXEhiv4imfwxA==",
2782 | "dev": true
2783 | },
2784 | "shallow-clone": {
2785 | "version": "3.0.1",
2786 | "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz",
2787 | "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==",
2788 | "requires": {
2789 | "kind-of": "^6.0.2"
2790 | }
2791 | },
2792 | "shallowequal": {
2793 | "version": "1.1.0",
2794 | "resolved": "https://registry.npmjs.org/shallowequal/-/shallowequal-1.1.0.tgz",
2795 | "integrity": "sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ=="
2796 | },
2797 | "shebang-command": {
2798 | "version": "2.0.0",
2799 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
2800 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
2801 | "dev": true,
2802 | "requires": {
2803 | "shebang-regex": "^3.0.0"
2804 | }
2805 | },
2806 | "shebang-regex": {
2807 | "version": "3.0.0",
2808 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
2809 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
2810 | "dev": true
2811 | },
2812 | "signal-exit": {
2813 | "version": "3.0.3",
2814 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz",
2815 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==",
2816 | "dev": true
2817 | },
2818 | "slash": {
2819 | "version": "3.0.0",
2820 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
2821 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
2822 | "dev": true
2823 | },
2824 | "slice-ansi": {
2825 | "version": "4.0.0",
2826 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz",
2827 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==",
2828 | "dev": true,
2829 | "requires": {
2830 | "ansi-styles": "^4.0.0",
2831 | "astral-regex": "^2.0.0",
2832 | "is-fullwidth-code-point": "^3.0.0"
2833 | },
2834 | "dependencies": {
2835 | "ansi-styles": {
2836 | "version": "4.3.0",
2837 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
2838 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
2839 | "dev": true,
2840 | "requires": {
2841 | "color-convert": "^2.0.1"
2842 | }
2843 | },
2844 | "color-convert": {
2845 | "version": "2.0.1",
2846 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
2847 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
2848 | "dev": true,
2849 | "requires": {
2850 | "color-name": "~1.1.4"
2851 | }
2852 | },
2853 | "color-name": {
2854 | "version": "1.1.4",
2855 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
2856 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
2857 | "dev": true
2858 | }
2859 | }
2860 | },
2861 | "source-map": {
2862 | "version": "0.5.7",
2863 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
2864 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
2865 | "dev": true
2866 | },
2867 | "spdx-correct": {
2868 | "version": "3.1.1",
2869 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz",
2870 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==",
2871 | "dev": true,
2872 | "requires": {
2873 | "spdx-expression-parse": "^3.0.0",
2874 | "spdx-license-ids": "^3.0.0"
2875 | }
2876 | },
2877 | "spdx-exceptions": {
2878 | "version": "2.3.0",
2879 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz",
2880 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==",
2881 | "dev": true
2882 | },
2883 | "spdx-expression-parse": {
2884 | "version": "3.0.1",
2885 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz",
2886 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==",
2887 | "dev": true,
2888 | "requires": {
2889 | "spdx-exceptions": "^2.1.0",
2890 | "spdx-license-ids": "^3.0.0"
2891 | }
2892 | },
2893 | "spdx-license-ids": {
2894 | "version": "3.0.7",
2895 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.7.tgz",
2896 | "integrity": "sha512-U+MTEOO0AiDzxwFvoa4JVnMV6mZlJKk2sBLt90s7G0Gd0Mlknc7kxEn3nuDPNZRta7O2uy8oLcZLVT+4sqNZHQ==",
2897 | "dev": true
2898 | },
2899 | "sprintf-js": {
2900 | "version": "1.0.3",
2901 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
2902 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=",
2903 | "dev": true
2904 | },
2905 | "string-argv": {
2906 | "version": "0.3.1",
2907 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz",
2908 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==",
2909 | "dev": true
2910 | },
2911 | "string-width": {
2912 | "version": "4.2.0",
2913 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz",
2914 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==",
2915 | "dev": true,
2916 | "requires": {
2917 | "emoji-regex": "^8.0.0",
2918 | "is-fullwidth-code-point": "^3.0.0",
2919 | "strip-ansi": "^6.0.0"
2920 | }
2921 | },
2922 | "string.prototype.trimend": {
2923 | "version": "1.0.3",
2924 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.3.tgz",
2925 | "integrity": "sha512-ayH0pB+uf0U28CtjlLvL7NaohvR1amUvVZk+y3DYb0Ey2PUV5zPkkKy9+U1ndVEIXO8hNg18eIv9Jntbii+dKw==",
2926 | "dev": true,
2927 | "requires": {
2928 | "call-bind": "^1.0.0",
2929 | "define-properties": "^1.1.3"
2930 | }
2931 | },
2932 | "string.prototype.trimstart": {
2933 | "version": "1.0.3",
2934 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.3.tgz",
2935 | "integrity": "sha512-oBIBUy5lea5tt0ovtOFiEQaBkoBBkyJhZXzJYrSmDo5IUUqbOPvVezuRs/agBIdZ2p2Eo1FD6bD9USyBLfl3xg==",
2936 | "dev": true,
2937 | "requires": {
2938 | "call-bind": "^1.0.0",
2939 | "define-properties": "^1.1.3"
2940 | }
2941 | },
2942 | "stringify-object": {
2943 | "version": "3.3.0",
2944 | "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz",
2945 | "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==",
2946 | "dev": true,
2947 | "requires": {
2948 | "get-own-enumerable-property-symbols": "^3.0.0",
2949 | "is-obj": "^1.0.1",
2950 | "is-regexp": "^1.0.0"
2951 | }
2952 | },
2953 | "strip-ansi": {
2954 | "version": "6.0.0",
2955 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
2956 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
2957 | "dev": true,
2958 | "requires": {
2959 | "ansi-regex": "^5.0.0"
2960 | }
2961 | },
2962 | "strip-bom": {
2963 | "version": "3.0.0",
2964 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz",
2965 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=",
2966 | "dev": true
2967 | },
2968 | "strip-final-newline": {
2969 | "version": "2.0.0",
2970 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz",
2971 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==",
2972 | "dev": true
2973 | },
2974 | "strip-json-comments": {
2975 | "version": "3.1.1",
2976 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
2977 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
2978 | "dev": true
2979 | },
2980 | "supports-color": {
2981 | "version": "5.5.0",
2982 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
2983 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
2984 | "dev": true,
2985 | "requires": {
2986 | "has-flag": "^3.0.0"
2987 | }
2988 | },
2989 | "table": {
2990 | "version": "6.0.7",
2991 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz",
2992 | "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==",
2993 | "dev": true,
2994 | "requires": {
2995 | "ajv": "^7.0.2",
2996 | "lodash": "^4.17.20",
2997 | "slice-ansi": "^4.0.0",
2998 | "string-width": "^4.2.0"
2999 | },
3000 | "dependencies": {
3001 | "ajv": {
3002 | "version": "7.0.3",
3003 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.0.3.tgz",
3004 | "integrity": "sha512-R50QRlXSxqXcQP5SvKUrw8VZeypvo12i2IX0EeR5PiZ7bEKeHWgzgo264LDadUsCU42lTJVhFikTqJwNeH34gQ==",
3005 | "dev": true,
3006 | "requires": {
3007 | "fast-deep-equal": "^3.1.1",
3008 | "json-schema-traverse": "^1.0.0",
3009 | "require-from-string": "^2.0.2",
3010 | "uri-js": "^4.2.2"
3011 | }
3012 | },
3013 | "json-schema-traverse": {
3014 | "version": "1.0.0",
3015 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz",
3016 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==",
3017 | "dev": true
3018 | }
3019 | }
3020 | },
3021 | "text-table": {
3022 | "version": "0.2.0",
3023 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
3024 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=",
3025 | "dev": true
3026 | },
3027 | "through": {
3028 | "version": "2.3.8",
3029 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz",
3030 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=",
3031 | "dev": true
3032 | },
3033 | "tmp": {
3034 | "version": "0.0.33",
3035 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz",
3036 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==",
3037 | "dev": true,
3038 | "requires": {
3039 | "os-tmpdir": "~1.0.2"
3040 | }
3041 | },
3042 | "to-fast-properties": {
3043 | "version": "2.0.0",
3044 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
3045 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=",
3046 | "dev": true
3047 | },
3048 | "to-regex-range": {
3049 | "version": "5.0.1",
3050 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
3051 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
3052 | "dev": true,
3053 | "requires": {
3054 | "is-number": "^7.0.0"
3055 | }
3056 | },
3057 | "tsconfig-paths": {
3058 | "version": "3.9.0",
3059 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.9.0.tgz",
3060 | "integrity": "sha512-dRcuzokWhajtZWkQsDVKbWyY+jgcLC5sqJhg2PSgf4ZkH2aHPvaOY8YWGhmjb68b5qqTfasSsDO9k7RUiEmZAw==",
3061 | "dev": true,
3062 | "requires": {
3063 | "@types/json5": "^0.0.29",
3064 | "json5": "^1.0.1",
3065 | "minimist": "^1.2.0",
3066 | "strip-bom": "^3.0.0"
3067 | }
3068 | },
3069 | "tslib": {
3070 | "version": "1.14.1",
3071 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
3072 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==",
3073 | "dev": true
3074 | },
3075 | "type-check": {
3076 | "version": "0.4.0",
3077 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
3078 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
3079 | "dev": true,
3080 | "requires": {
3081 | "prelude-ls": "^1.2.1"
3082 | }
3083 | },
3084 | "type-fest": {
3085 | "version": "0.8.1",
3086 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz",
3087 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==",
3088 | "dev": true
3089 | },
3090 | "uri-js": {
3091 | "version": "4.4.1",
3092 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
3093 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
3094 | "dev": true,
3095 | "requires": {
3096 | "punycode": "^2.1.0"
3097 | }
3098 | },
3099 | "v8-compile-cache": {
3100 | "version": "2.2.0",
3101 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.2.0.tgz",
3102 | "integrity": "sha512-gTpR5XQNKFwOd4clxfnhaqvfqMpqEwr4tOtCyz4MtYZX2JYhfr1JvBFKdS+7K/9rfpZR3VLX+YWBbKoxCgS43Q==",
3103 | "dev": true
3104 | },
3105 | "validate-npm-package-license": {
3106 | "version": "3.0.4",
3107 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
3108 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
3109 | "dev": true,
3110 | "requires": {
3111 | "spdx-correct": "^3.0.0",
3112 | "spdx-expression-parse": "^3.0.0"
3113 | }
3114 | },
3115 | "which": {
3116 | "version": "2.0.2",
3117 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
3118 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
3119 | "dev": true,
3120 | "requires": {
3121 | "isexe": "^2.0.0"
3122 | }
3123 | },
3124 | "which-pm-runs": {
3125 | "version": "1.0.0",
3126 | "resolved": "https://registry.npmjs.org/which-pm-runs/-/which-pm-runs-1.0.0.tgz",
3127 | "integrity": "sha1-Zws6+8VS4LVd9rd4DKdGFfI60cs=",
3128 | "dev": true
3129 | },
3130 | "word-wrap": {
3131 | "version": "1.2.3",
3132 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
3133 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==",
3134 | "dev": true
3135 | },
3136 | "wrap-ansi": {
3137 | "version": "7.0.0",
3138 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
3139 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
3140 | "dev": true,
3141 | "requires": {
3142 | "ansi-styles": "^4.0.0",
3143 | "string-width": "^4.1.0",
3144 | "strip-ansi": "^6.0.0"
3145 | },
3146 | "dependencies": {
3147 | "ansi-styles": {
3148 | "version": "4.3.0",
3149 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
3150 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
3151 | "dev": true,
3152 | "requires": {
3153 | "color-convert": "^2.0.1"
3154 | }
3155 | },
3156 | "color-convert": {
3157 | "version": "2.0.1",
3158 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
3159 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
3160 | "dev": true,
3161 | "requires": {
3162 | "color-name": "~1.1.4"
3163 | }
3164 | },
3165 | "color-name": {
3166 | "version": "1.1.4",
3167 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
3168 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
3169 | "dev": true
3170 | }
3171 | }
3172 | },
3173 | "wrappy": {
3174 | "version": "1.0.2",
3175 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
3176 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
3177 | "dev": true
3178 | },
3179 | "write": {
3180 | "version": "1.0.3",
3181 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz",
3182 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==",
3183 | "dev": true,
3184 | "requires": {
3185 | "mkdirp": "^0.5.1"
3186 | }
3187 | },
3188 | "yallist": {
3189 | "version": "4.0.0",
3190 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
3191 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
3192 | "dev": true
3193 | },
3194 | "yaml": {
3195 | "version": "1.10.0",
3196 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.0.tgz",
3197 | "integrity": "sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg==",
3198 | "dev": true
3199 | },
3200 | "yocto-queue": {
3201 | "version": "0.1.0",
3202 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
3203 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
3204 | "dev": true
3205 | }
3206 | }
3207 | }
3208 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "zerodb",
3 | "version": "0.2.2",
4 | "description": "Easy to use JSON database for Node.js with encryption.",
5 | "main": "src/index.js",
6 | "scripts": {
7 | "lint": "eslint \"./**/*.js\"",
8 | "lint:fix": "npm run lint -- --fix",
9 | "format": "prettier . --write"
10 | },
11 | "repository": {
12 | "type": "git",
13 | "url": "git+https://github.com/mazecodes/zerodb.git"
14 | },
15 | "keywords": [
16 | "database",
17 | "db",
18 | "json",
19 | "encryption"
20 | ],
21 | "author": "Maze Petersom",
22 | "license": "MIT",
23 | "bugs": {
24 | "url": "https://github.com/mazecodes/zerodb/issues"
25 | },
26 | "homepage": "https://github.com/mazecodes/zerodb#readme",
27 | "devDependencies": {
28 | "eslint": "^7.18.0",
29 | "eslint-config-airbnb-base": "^14.2.1",
30 | "eslint-config-node": "^4.1.0",
31 | "eslint-config-prettier": "^7.2.0",
32 | "eslint-plugin-import": "^2.22.1",
33 | "eslint-plugin-node": "^11.1.0",
34 | "eslint-plugin-prettier": "^3.3.1",
35 | "husky": "^4.3.8",
36 | "lint-staged": "^10.5.3",
37 | "prettier": "^2.2.1"
38 | },
39 | "dependencies": {
40 | "clone-deep": "^4.0.1",
41 | "crypto-js": "^4.0.0",
42 | "is-regex": "^1.1.1",
43 | "lodash": "^4.17.20",
44 | "shallowequal": "^1.1.0"
45 | }
46 | }
47 |
--------------------------------------------------------------------------------
/sandbox/index.js:
--------------------------------------------------------------------------------
1 | const ZeroDB = require('../src');
2 |
3 | const zdb = new ZeroDB('./database.json', {
4 | encryption: true,
5 | secret: 's3cr3t',
6 | });
7 |
8 | zdb.init({ posts: [], user: {} }, { force: true });
9 |
10 | zdb.set('user.name', 'John Doe');
11 |
12 | zdb
13 | .push('posts', {
14 | id: 0,
15 | title: 'Title 1',
16 | })
17 | .push('posts', {
18 | id: 1,
19 | title: 'Title 2',
20 | })
21 | .push('posts', {
22 | id: 2,
23 | title: 'Title 3',
24 | });
25 |
26 | console.log(zdb.get('user.name'));
27 |
28 | const post = zdb.findOne('posts', { id: 0 });
29 |
30 | console.log(post);
31 |
32 | console.log(zdb.has('posts'));
33 |
34 | zdb.delete('posts');
35 | zdb.reset();
36 |
37 | zdb.set('user.age', 18);
38 | zdb.increment('user.age');
39 | zdb.increment('user.age', 10);
40 | zdb.decrement('user.age');
41 | zdb.decrement('user.age', 5);
42 |
43 | console.log(zdb.get('user.age'));
44 |
45 | zdb.set('user.name', 'John Doe');
46 |
47 | zdb.update('user.name', name => name.toLowerCase());
48 | console.log(zdb.get('user.name'));
49 |
50 | console.log(zdb.getState());
51 |
52 | zdb
53 | .setState({
54 | posts: [
55 | {
56 | title: 'Test',
57 | },
58 | ],
59 | })
60 | .save()
61 | .then(() => console.log('Saved'));
62 |
63 | zdb.destroy();
64 |
--------------------------------------------------------------------------------
/src/index.js:
--------------------------------------------------------------------------------
1 | const path = require('path');
2 | const fs = require('fs');
3 | const { promisify } = require('util');
4 | const _ = require('lodash');
5 | const shallowEqual = require('shallowequal');
6 | const isRegex = require('is-regex');
7 | const cloneDeep = require('clone-deep');
8 |
9 | const crypto = require('./lib/crypto');
10 |
11 | class ZeroDB {
12 | /**
13 | * @constructor
14 | *
15 | * @param {String} source - Database source
16 | * @param {Object} [options] - The custom options (optional)
17 | * @param {Boolean} [options.encryption] - If there should be encryption/decryption
18 | * @param {String} [options.secret] - The secret to use for encryption/decryption (Required if the encryption is true)
19 | * @param {Number} [options.iterations] - The number of iterations for key generation
20 | * @param {Boolean} [options.empty] - If it should create an empty database anyway
21 | * @returns {void}
22 | *
23 | * @example
24 | * new ZeroDB('./database.json')
25 | */
26 | constructor(source, options = {}) {
27 | this.source = source;
28 | this.filePath = '';
29 | this.database = {};
30 | this.initialState = {};
31 |
32 | this.encryption = !!options.encryption;
33 | this.secret = options.secret || '';
34 | this.iterations = options.iterations || 50000;
35 | this.salt = '';
36 |
37 | this.empty = !!options.empty;
38 |
39 | this.validateSource();
40 | this.validateCrypto();
41 |
42 | this.readDatabase();
43 | }
44 |
45 | /**
46 | * @property {Function} validateSource - Validate the database source
47 | * @access private
48 | *
49 | * @returns {void}
50 | *
51 | * @example
52 | * zerodb.validateSource()
53 | */
54 | validateSource() {
55 | if (!this.source) {
56 | throw new Error('Database source should be provided');
57 | }
58 |
59 | if (typeof this.source !== 'string') {
60 | throw new Error('Database source should be a valid string');
61 | }
62 |
63 | if (path.extname(this.source) !== '.json') {
64 | throw new Error('Database source should be JSON');
65 | }
66 | }
67 |
68 | /**
69 | * @property {Function} validateCrypto - Validate the crypto config
70 | * @access private
71 | *
72 | * @returns {void}
73 | *
74 | * @example
75 | * zerodb.validateCrypto()
76 | */
77 | validateCrypto() {
78 | if (this.encryption) {
79 | if (!this.secret) {
80 | throw new Error('The secret must be provided for encryption');
81 | }
82 |
83 | if (typeof this.secret !== 'string') {
84 | throw new Error('The secret must be a string');
85 | }
86 |
87 | if (typeof this.iterations !== 'number') {
88 | throw new Error('The iterations must be a number');
89 | }
90 | }
91 | }
92 |
93 | /**
94 | * @property {Function} validateState - Validate the given state
95 | * @access private
96 | *
97 | * @param {*} state - State to validate
98 | * @returns {void}
99 | *
100 | * @example
101 | * zerodb.validateState({ foo: 'bar' })
102 | */
103 | validateState(state) {
104 | if (typeof state !== 'object') {
105 | throw new Error('State should be an object');
106 | }
107 | }
108 |
109 | /**
110 | * @property {Function} readDatabase - Read the database, create one if it doesn't exists
111 | * @access private
112 | *
113 | * @returns {void}
114 | *
115 | * @example
116 | * zerodb.readDatabase()
117 | */
118 | readDatabase() {
119 | const filePath = path.resolve(require.main.path, this.source);
120 | const fileExists = fs.existsSync(filePath);
121 |
122 | this.filePath = filePath;
123 |
124 | if (fileExists && !this.empty) {
125 | const stats = fs.statSync(this.filePath);
126 | const isFile = stats.isFile();
127 |
128 | if (!isFile) {
129 | throw new Error('Database source should be a file');
130 | }
131 |
132 | try {
133 | const data = fs.readFileSync(this.filePath, 'utf-8');
134 | const database = JSON.parse(data);
135 |
136 | if (this.encryption) {
137 | if (!database._encryption) {
138 | this.salt = crypto.generateSalt();
139 | this.key = crypto.generateKey(
140 | this.secret,
141 | this.salt,
142 | this.iterations
143 | );
144 | this.database = database;
145 |
146 | const encryptedState = this.encryptState();
147 |
148 | fs.writeFileSync(
149 | this.filePath,
150 | JSON.stringify(encryptedState),
151 | 'utf-8'
152 | );
153 | } else {
154 | this.decryptDatabase(database);
155 | }
156 | } else {
157 | this.database = database;
158 | }
159 | } catch (err) {
160 | if (err instanceof SyntaxError) {
161 | throw new Error('Database source contains malformed JSON');
162 | }
163 |
164 | throw err;
165 | }
166 | } else {
167 | this.createDatabase();
168 | }
169 | }
170 |
171 | /**
172 | * @property {Function} generateKey - Generate a key based on encryption config
173 | * @access private
174 | *
175 | * @returns {String} - An encryption key
176 | *
177 | * @example
178 | * zerodb.generateKey()
179 | */
180 | generateKey() {
181 | return crypto.generateKey(this.secret, this.salt, this.iterations);
182 | }
183 |
184 | /**
185 | * @property {Function} decryptDatabase - Decrypt the given database
186 | * @access private
187 | *
188 | * @param {Object} database - The database to decrypt
189 | * @returns {void}
190 | *
191 | * @example
192 | * zerodb.decryptDatabase(db)
193 | */
194 | decryptDatabase(database) {
195 | const { salt, iterations } = database._encryption;
196 |
197 | this.salt = !salt ? crypto.generateSalt() : salt;
198 | this.iterations =
199 | typeof iterations === 'number' ? iterations : this.iterations;
200 |
201 | this.key = this.generateKey();
202 |
203 | const stateContent = database.state.content;
204 | const stateSignature = database.state.signature;
205 |
206 | if (!stateContent || !stateSignature) {
207 | throw new Error('The state is not valid');
208 | }
209 |
210 | const isStateValid = crypto.isStateValid(
211 | stateContent,
212 | stateSignature,
213 | this.key
214 | );
215 |
216 | if (!isStateValid) {
217 | throw new Error('The state has been altered');
218 | }
219 |
220 | const decryptedState = crypto.decryptState(stateContent, this.key);
221 |
222 | this.database = JSON.parse(decryptedState);
223 | }
224 |
225 | /**
226 | * @property {Function} createDatabase - Create a database
227 | * @access private
228 | *
229 | * @returns {void}
230 | *
231 | * @example
232 | * zerodb.createDatabase('/path/to/db.json')
233 | */
234 | createDatabase() {
235 | let data = '{}';
236 |
237 | if (this.encryption) {
238 | this.salt = crypto.generateSalt();
239 | this.key = crypto.generateKey(this.secret, this.salt, this.iterations);
240 |
241 | const encryptedState = this.encryptState();
242 |
243 | data = JSON.stringify(encryptedState);
244 | }
245 |
246 | fs.writeFileSync(this.filePath, data, 'utf-8');
247 | }
248 |
249 | /**
250 | * @property {Function} encryptState - Encrypt the current state
251 | * @access private
252 | *
253 | * @returns {Object} - An object containing the state and encryption config
254 | *
255 | * @example
256 | * zerodb.encryptState()
257 | */
258 | encryptState() {
259 | const state = JSON.stringify(this.database);
260 | const encryptedState = crypto.encryptState(state, this.key);
261 |
262 | const stateObject = {
263 | _encryption: {
264 | salt: this.salt,
265 | iterations: this.iterations,
266 | },
267 | state: {
268 | content: encryptedState.state,
269 | signature: encryptedState.signature,
270 | },
271 | };
272 |
273 | return stateObject;
274 | }
275 |
276 | /**
277 | * @property {Function} init - Set initial state of the database
278 | *
279 | * @param {Object} initialState - The initial state
280 | * @param {Object} [options] - The options object (optional)
281 | * @param {Boolean} [options.force] - If the database should be replaced with the initial state (optional)
282 | * @returns {Object} - The ZeroDB database
283 | *
284 | * @example
285 | * zerodb.init({ posts: [] })
286 | * zerodb.init({ posts: [] }, { force: true })
287 | */
288 | init(initialState = {}, options = {}) {
289 | this.validateState(initialState);
290 | this.initialState = cloneDeep(initialState);
291 |
292 | const isForced = options.force;
293 | const isEmpty = Object.keys(this.database).length === 0;
294 |
295 | if (isEmpty || isForced) {
296 | this.database = initialState;
297 | }
298 |
299 | return this;
300 | }
301 |
302 | /**
303 | * @property {Function} save - Save the database
304 | *
305 | * @returns {Boolean} - True if it was successful
306 | *
307 | * @example
308 | * zerodb.save()
309 | */
310 | async save() {
311 | const writeFile = promisify(fs.writeFile);
312 | const data = this.encryption
313 | ? JSON.stringify(this.encryptState())
314 | : JSON.stringify(this.database);
315 |
316 | await writeFile(this.filePath, data, 'utf-8');
317 | return true;
318 | }
319 |
320 | /**
321 | * @property {Function} set - Set a value
322 | *
323 | * @param {String} path - Path to set
324 | * @param {*} value - Value to set
325 | * @returns {Object} - The ZeroDB object
326 | *
327 | * @example
328 | * zerodb.set('user.name', 'John Doe')
329 | */
330 | set(path, value) {
331 | _.set(this.database, path, value);
332 |
333 | return this;
334 | }
335 |
336 | /**
337 | * @property {Function} get - Get a value
338 | *
339 | * @param {String} path - Path to get the value from
340 | * @param {*} defaultValue - The default value
341 | * @returns {*} - The main value if it exists or the default value
342 | *
343 | * @example
344 | * zerodb.get('name')
345 | * zerodb.get('post.title', 'Title')
346 | */
347 | get(path, defaultValue = null) {
348 | const data = _.get(this.database, path, defaultValue);
349 |
350 | return cloneDeep(data);
351 | }
352 |
353 | /**
354 | * @property {Function} push - Push a value into an array
355 | *
356 | * @param {String} path - Path to push the value to
357 | * @param {*} value - The value to push
358 | * @returns {Object} - The ZeroDB object
359 | *
360 | * @example
361 | * zerodb.push('posts', { title: 'Foo' })
362 | */
363 | push(path, value) {
364 | const destination = _.get(this.database, path);
365 |
366 | if (!destination) {
367 | this.set(path, [value]);
368 |
369 | return this;
370 | }
371 |
372 | if (!(destination instanceof Array)) {
373 | throw new Error('You can only push values to an array');
374 | }
375 |
376 | destination.push(value);
377 |
378 | return this;
379 | }
380 |
381 | /**
382 | * @property {Function} has - Check if a property exists
383 | *
384 | * @param {String} path - Path to check
385 | * @returns {Boolean} - True if exists
386 | *
387 | * @example
388 | * zerodb.has('posts')
389 | * zerodb.has('user.name')
390 | */
391 | has(path) {
392 | return _.has(this.database, path);
393 | }
394 |
395 | /**
396 | * @property {Function} find - Find objects which match with the query
397 | *
398 | * @param {String} path - Path to find in
399 | * @param {Object} query - The query to search for
400 | * @returns {(null|Array)} - The result, null if it found nothing
401 | *
402 | * @example
403 | * zerodb.find('posts', { author: 'John' })
404 | * zerodb.find('posts', { title: /^Hello/ })
405 | */
406 | find(path, query) {
407 | const destination = this.get(path);
408 |
409 | if (typeof query !== 'object') {
410 | throw new Error('Query must be an object');
411 | }
412 |
413 | if (!destination || !(destination instanceof Array)) {
414 | return null;
415 | }
416 |
417 | const foundings = destination.filter(data => {
418 | for (const key of Object.keys(query)) {
419 | if (isRegex(query[key])) {
420 | if (typeof data[key] !== 'string') {
421 | return false;
422 | }
423 |
424 | if (!query[key].test(data[key])) {
425 | return false;
426 | }
427 | } else {
428 | if (!shallowEqual(query[key], data[key])) {
429 | return false;
430 | }
431 | }
432 | }
433 |
434 | return true;
435 | });
436 |
437 | return foundings;
438 | }
439 |
440 | /**
441 | * @property {Function} findOne - Find one object which matches with the query
442 | *
443 | * @param {String} path - Path to find in
444 | * @param {*} query - The query to search for
445 | * @returns {(null|Object)} - The result, null if it found nothing
446 | *
447 | * @example
448 | * zerodb.findOne('posts', { id: 0 })
449 | */
450 | findOne(path, query) {
451 | const result = this.find(path, query);
452 |
453 | if (!result) {
454 | return null;
455 | }
456 |
457 | return result.length !== 0 ? result[0] : null;
458 | }
459 |
460 | /**
461 | * @property {Function} reset - Reset the database to its initial state
462 | *
463 | * @returns {Object} - The ZeroDB object
464 | *
465 | * @example
466 | * zerodb.reset()
467 | */
468 | reset() {
469 | this.database = this.initialState;
470 |
471 | return this;
472 | }
473 |
474 | /**
475 | * @property {Function} delete - Delete the given path
476 | *
477 | * @param {String} path - Path to delete
478 | * @returns {Object} - The ZeroDB object
479 | *
480 | * @example
481 | * zerodb.delete('user.name')
482 | */
483 | delete(path) {
484 | _.unset(this.database, path);
485 |
486 | return this;
487 | }
488 |
489 | /**
490 | * @property {Function} increment - Increase the value of the given path
491 | *
492 | * @param {String} path - The path to increase
493 | * @param {Number} [amount] - The amount to add (optional)
494 | * @returns {Object} - The ZeroDB object
495 | *
496 | * @example
497 | * zerodb.increment('age')
498 | * zerodb.increment('age', 5)
499 | */
500 | increment(path, amount = 1) {
501 | if (typeof amount !== 'number') {
502 | throw new Error('The amount to increase must be a number');
503 | }
504 |
505 | const currentValue = this.get(path);
506 |
507 | if (!currentValue) {
508 | throw new Error(`Path '${path}' doesn't exist`);
509 | }
510 |
511 | if (typeof currentValue !== 'number') {
512 | throw new Error('You can only increase number values');
513 | }
514 |
515 | const increasedValue = currentValue + amount;
516 |
517 | return this.set(path, increasedValue);
518 | }
519 |
520 | /**
521 | * @property {Function} decrement - Decrease the value of the given path
522 | *
523 | * @param {String} path - The path to decrease
524 | * @param {Number} [amount] - The amount to subtract (optional)
525 | * @returns {Object} - The ZeroDB object
526 | *
527 | * @example
528 | * zerodb.decrement('age')
529 | * zerodb.decrement('age', 5)
530 | */
531 | decrement(path, amount = 1) {
532 | if (typeof amount !== 'number') {
533 | throw new Error('The amount to decrease must be a number');
534 | }
535 |
536 | const currentValue = this.get(path);
537 |
538 | if (!currentValue) {
539 | throw new Error(`Path '${path}' doesn't exist`);
540 | }
541 |
542 | if (typeof currentValue !== 'number') {
543 | throw new Error('You can only decrease number values');
544 | }
545 |
546 | const decreasedValue = currentValue - amount;
547 |
548 | return this.set(path, decreasedValue);
549 | }
550 |
551 | /**
552 | * @property {Function} update - Update the given path the updater
553 | *
554 | * @param {String} path - The path to update
555 | * @param {Function} updater - The updater function
556 | * @returns {Object} - The ZeroDB object
557 | *
558 | * @example
559 | * zerodb.update('username', value => value.toLowerCase())
560 | */
561 | update(path, updater) {
562 | if (typeof updater !== 'function') {
563 | throw new Error('Updater must be a function');
564 | }
565 |
566 | const currentValue = this.get(path);
567 |
568 | if (!currentValue) {
569 | throw new Error(`Path '${path}' doesn't exist`);
570 | }
571 |
572 | const newValue = updater(currentValue);
573 |
574 | return this.set(path, newValue);
575 | }
576 |
577 | /**
578 | * @property {Function} getState - Get the current state of the database
579 | *
580 | * @returns {Object} - The current state of the database
581 | *
582 | * @example
583 | * zerodb.getState()
584 | */
585 | getState() {
586 | const state = this.database;
587 |
588 | return cloneDeep(state);
589 | }
590 |
591 | /**
592 | * @property {Function} setState - Replace the current state with a new one
593 | *
594 | * @param {Object} state - The new state
595 | * @returns {Object} - The ZeroDB object
596 | *
597 | * @example
598 | * zerodb.setState({ foo: 'bar' })
599 | */
600 | setState(state) {
601 | this.validateState(state);
602 | this.database = state;
603 |
604 | return this;
605 | }
606 |
607 | /**
608 | * @property {Function} destroy - Destroy the database
609 | *
610 | * @param {Boolean} removeDatabase - If it should removes the database file
611 | * @returns {Object} - The ZeroDB object
612 | *
613 | * @example
614 | * zerodb.destroy()
615 | * zerodb.destroy(false)
616 | */
617 | destroy(removeDatabase = true) {
618 | this.database = {};
619 | this.initialState = {};
620 |
621 | if (removeDatabase) {
622 | fs.unlinkSync(this.filePath);
623 | }
624 |
625 | return this;
626 | }
627 | }
628 |
629 | module.exports = ZeroDB;
630 |
--------------------------------------------------------------------------------
/src/lib/crypto.js:
--------------------------------------------------------------------------------
1 | const CryptoJS = require('crypto-js');
2 |
3 | /**
4 | * Generate a random salt value
5 | *
6 | * @returns {String} - A random salt
7 | *
8 | * @example
9 | * generateSalt()
10 | */
11 | const generateSalt = () =>
12 | CryptoJS.lib.WordArray.random(16).toString(CryptoJS.enc.Hex);
13 |
14 | /**
15 | * Generate a key based on a secret
16 | *
17 | * @param {String} secret - The secret to generate a key for
18 | * @param {String} salt - The salt
19 | * @param {Number} [iterations] - PBKDF2 iterations count (optional)
20 | * @returns {String} - 256-bit key
21 | *
22 | * @example
23 | * generateKey('secret', 'salt')
24 | * generateKey('secret', 'salt', 50000)
25 | */
26 | const generateKey = (secret, salt, iterations = 100000) =>
27 | CryptoJS.PBKDF2(secret, salt, {
28 | keySize: 256 / 32,
29 | iterations,
30 | }).toString(CryptoJS.enc.Hex);
31 |
32 | /**
33 | * Encrypt the given state
34 | *
35 | * @param {String} state - The state to encrypt
36 | * @param {String} key - The key to be used for encryption
37 | * @returns {Object} - Encrypted state and the signature
38 | *
39 | * @example
40 | * encryptState('{ foo: "bar"}', 'key')
41 | */
42 | const encryptState = (state, key) => {
43 | const encryptedState = CryptoJS.AES.encrypt(state, key, {
44 | mode: CryptoJS.mode.CBC,
45 | }).toString();
46 | const signature = CryptoJS.HmacSHA256(encryptedState, key).toString(
47 | CryptoJS.enc.Hex
48 | );
49 |
50 | return {
51 | state: encryptedState,
52 | signature,
53 | };
54 | };
55 |
56 | /**
57 | * Decrypt the given state
58 | *
59 | * @param {String} encryptedState - The encrypted state
60 | * @param {String} key - The key used for encryption
61 | * @returns {String} - The decrypted state
62 | *
63 | * @example
64 | * decryptState(encryptedState, 'key')
65 | */
66 | const decryptState = (encryptedState, key) => {
67 | const decryptedState = CryptoJS.AES.decrypt(encryptedState, key, {
68 | mode: CryptoJS.mode.CBC,
69 | }).toString(CryptoJS.enc.Utf8);
70 |
71 | return decryptedState;
72 | };
73 |
74 | /**
75 | * Check if a signature is valid
76 | *
77 | * @param {String} encryptedState - The encrypted state
78 | * @param {String} signature - The given signature
79 | * @param {String} key - The key used for encryption and signing
80 | * @returns {Boolean} - True if it was valid
81 | *
82 | * @example
83 | * isStateValid(encryptedState, signature, 'key')
84 | */
85 | const isStateValid = (encryptedState, signature, key) => {
86 | const _signature = CryptoJS.HmacSHA256(encryptedState, key).toString(
87 | CryptoJS.enc.Hex
88 | );
89 |
90 | return _signature === signature;
91 | };
92 |
93 | module.exports = {
94 | generateSalt,
95 | generateKey,
96 | encryptState,
97 | decryptState,
98 | isStateValid,
99 | };
100 |
--------------------------------------------------------------------------------