├── .eslintrc.js ├── .gitignore ├── LICENSE ├── README.md ├── client.js ├── config.example.js ├── download.js ├── index.js ├── package-lock.json ├── package.json ├── radarr.js ├── sonarr.js └── util.js /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | commonjs: true, 4 | es2020: true, 5 | node: true, 6 | }, 7 | extends: ["plugin:prettier/recommended", "eslint:recommended"], 8 | parserOptions: { 9 | ecmaVersion: 11, 10 | }, 11 | }; 12 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Our stuff 2 | 3 | config.js 4 | 5 | # Generated stuff 6 | 7 | # Logs 8 | logs 9 | *.log 10 | npm-debug.log* 11 | yarn-debug.log* 12 | yarn-error.log* 13 | lerna-debug.log* 14 | 15 | # Diagnostic reports (https://nodejs.org/api/report.html) 16 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 17 | 18 | # Runtime data 19 | pids 20 | *.pid 21 | *.seed 22 | *.pid.lock 23 | 24 | # Directory for instrumented libs generated by jscoverage/JSCover 25 | lib-cov 26 | 27 | # Coverage directory used by tools like istanbul 28 | coverage 29 | *.lcov 30 | 31 | # nyc test coverage 32 | .nyc_output 33 | 34 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 35 | .grunt 36 | 37 | # Bower dependency directory (https://bower.io/) 38 | bower_components 39 | 40 | # node-waf configuration 41 | .lock-wscript 42 | 43 | # Compiled binary addons (https://nodejs.org/api/addons.html) 44 | build/Release 45 | 46 | # Dependency directories 47 | node_modules/ 48 | jspm_packages/ 49 | 50 | # TypeScript v1 declaration files 51 | typings/ 52 | 53 | # TypeScript cache 54 | *.tsbuildinfo 55 | 56 | # Optional npm cache directory 57 | .npm 58 | 59 | # Optional eslint cache 60 | .eslintcache 61 | 62 | # Microbundle cache 63 | .rpt2_cache/ 64 | .rts2_cache_cjs/ 65 | .rts2_cache_es/ 66 | .rts2_cache_umd/ 67 | 68 | # Optional REPL history 69 | .node_repl_history 70 | 71 | # Output of 'npm pack' 72 | *.tgz 73 | 74 | # Yarn Integrity file 75 | .yarn-integrity 76 | 77 | # dotenv environment variables file 78 | .env 79 | .env.test 80 | 81 | # parcel-bundler cache (https://parceljs.org/) 82 | .cache 83 | 84 | # Next.js build output 85 | .next 86 | 87 | # Nuxt.js build / generate output 88 | .nuxt 89 | dist 90 | 91 | # Gatsby files 92 | .cache/ 93 | # Comment in the public line in if your project uses Gatsby and *not* Next.js 94 | # https://nextjs.org/blog/next-9-1#public-directory-support 95 | # public 96 | 97 | # vuepress build output 98 | .vuepress/dist 99 | 100 | # Serverless directories 101 | .serverless/ 102 | 103 | # FuseBox cache 104 | .fusebox/ 105 | 106 | # DynamoDB Local files 107 | .dynamodb/ 108 | 109 | # TernJS port file 110 | .tern-port 111 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 boban-bmw 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 | # cross-seedarr 2 | 3 | Cross seeding helper for radarr & sonarr. 4 | 5 | | Which problem does this solve? 6 | 7 | You don't need to manually cross-seed a release among your many trackers. 8 | 9 | ## How it works 10 | 11 | It searches all your search-enabled indexers for a movie/show and matches releases within `config.threshold` percent in size. 12 | This is done because certain trackers rename releases, include/exclude samples/nfos, etc. 13 | 14 | Only monitored and downloaded items are considered. For TV shows, only season packs and complete packs are searched for. 15 | 16 | ## Installation 17 | 18 | Prerequisites: `git` and `node` (I recommend using [nvm](https://github.com/nvm-sh/nvm)) 19 | 20 | ``` 21 | git clone https://github.com/boban-bmw/cross-seedarr.git 22 | cd cross-seedarr && npm install --production 23 | cp config.example.js config.js 24 | vim config.js # edit config.js to suit your needs 25 | ``` 26 | 27 | ## Usage 28 | 29 | ``` 30 | Usage: node index.js [options] 31 | 32 | Commands: 33 | index.js radarr Search for movies. 34 | index.js sonarr Search for shows. 35 | 36 | Options: 37 | --version Show version number [boolean] 38 | --recent Consider movies/shows downloaded in the last x days. If omitted, 39 | everything is searched for. [number] 40 | --verbose Turn off log pretty printing. [boolean] 41 | --help Show help [boolean] 42 | 43 | Examples: 44 | node index.js radarr sonarr --recent 14 Search radarr and sonarr for all 45 | movies/shows downloaded in the last 46 | 14 days. 47 | ``` 48 | 49 | `config.torrentDir` will contain all potential matching torrents - pass these to [autotorrent](https://github.com/JohnDoee/autotorrent). 50 | 51 | `cross-seedarr` will not download duplicate `.torrent` files - so it is recommended to use `autotorrent` without the `-d` flag 52 | 53 | ### Tested versions 54 | 55 | - `radarr v3` 56 | - `sonarr v3` 57 | - `node v14` 58 | - `ubuntu v20` - other OS-es should work as well 59 | 60 | ## License 61 | 62 | MIT 63 | -------------------------------------------------------------------------------- /client.js: -------------------------------------------------------------------------------- 1 | const axios = require("axios"); 2 | 3 | module.exports = function makeClient(settings, v3 = false) { 4 | return axios.create({ 5 | baseURL: `${settings.url}/api${v3 ? "/v3" : ""}`, 6 | headers: { 7 | "X-Api-Key": settings.apiKey, 8 | }, 9 | timeout: 120000, 10 | }); 11 | }; 12 | -------------------------------------------------------------------------------- /config.example.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | // amount of time to wait between search indexers requests in seconds 3 | timeout: 5, 4 | radarr: { 5 | // url you use to access radarr 6 | // https://your.seedbox.url/radarr 7 | // in case you are using http auth, the url should look like this 8 | // https://username:password@your.seedbox.url/radarr 9 | url: "", 10 | // radarr api key, found in settings -> general 11 | apiKey: "", 12 | // error threshold in % - torrent size difference which is ignored (treated as same release) 13 | // this is useful for eg. samples which some trackers include and others don't 14 | threshold: 5, 15 | // absolute path to the directory where we save matches 16 | torrentDir: "/tmp/torrents", 17 | // we search all "search-enabled" indexers - results from indexers listed below will be ignored 18 | // eg. ignoredIndexers: ["IPT", "TL"] 19 | ignoredIndexers: [], 20 | }, 21 | sonarr: { 22 | // same as for radarr 23 | url: "", 24 | apiKey: "", 25 | threshold: 5, 26 | torrentDir: "/tmp/torrents", 27 | ignoredIndexers: [], 28 | }, 29 | }; 30 | -------------------------------------------------------------------------------- /download.js: -------------------------------------------------------------------------------- 1 | const path = require("path"); 2 | const axios = require("axios"); 3 | const fs = require("fs"); 4 | 5 | const { logger } = require("./util"); 6 | 7 | module.exports = function downloadRelease(basePath, release) { 8 | return new Promise((resolve, reject) => { 9 | const { downloadUrl } = release; 10 | 11 | const fileName = `[${release.indexer}]${release.title}.torrent`; 12 | 13 | const savePath = path.resolve(basePath, fileName); 14 | 15 | if (fs.existsSync(savePath)) { 16 | logger.info(`${fileName} already exists, skipping...`); 17 | 18 | resolve(); 19 | 20 | return; 21 | } 22 | 23 | const writeStream = fs.createWriteStream(savePath); 24 | 25 | writeStream.on("finish", () => { 26 | logger.info( 27 | `Successfully downloaded ${release.title} from ${release.indexer}` 28 | ); 29 | 30 | resolve(); 31 | }); 32 | 33 | writeStream.on("error", reject); 34 | 35 | axios 36 | .get(downloadUrl, { 37 | responseType: "stream", 38 | }) 39 | .then((response) => { 40 | response.data.pipe(writeStream); 41 | }) 42 | .catch((e) => { 43 | logger.error( 44 | e, 45 | `An error occurred while downloading ${release.title} from ${release.indexer}` 46 | ); 47 | 48 | resolve(); 49 | }); 50 | }); 51 | }; 52 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const { argv } = require("yargs") 2 | .usage("Usage: node $0 [options]") 3 | .command("radarr", "Search for movies.") 4 | .command("sonarr", "Search for shows.") 5 | .demandCommand(1, 2) 6 | .number("recent") 7 | .describe( 8 | "recent", 9 | "Consider movies/shows downloaded in the last x days. If omitted, everything is searched for." 10 | ) 11 | .boolean("verbose") 12 | .describe("verbose", "Turn off log pretty printing.") 13 | .example( 14 | "node $0 radarr sonarr --recent 14", 15 | "Search radarr and sonarr for all movies/shows downloaded in the last 14 days." 16 | ) 17 | .help("help"); 18 | 19 | const radarrFlow = require("./radarr"); 20 | const sonarrFlow = require("./sonarr"); 21 | 22 | async function start() { 23 | if (argv._.indexOf("radarr") > -1) { 24 | await radarrFlow(); 25 | } 26 | 27 | if (argv._.indexOf("sonarr") > -1) { 28 | await sonarrFlow(); 29 | } 30 | } 31 | 32 | start(); 33 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "cross-seedarr", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.10.1", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.1.tgz", 10 | "integrity": "sha512-IGhtTmpjGbYzcEDOw7DcQtbQSXcG9ftmAXtWTu9V936vDye4xjjekktFAtgZsWpzTj/X01jocB46mTywm/4SZw==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.10.1" 14 | } 15 | }, 16 | "@babel/helper-validator-identifier": { 17 | "version": "7.10.1", 18 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.1.tgz", 19 | "integrity": "sha512-5vW/JXLALhczRCWP0PnFDMCJAchlBvM7f4uk/jXritBnIa6E1KmqmtrS3yn1LAnxFBypQ3eneLuXjsnfQsgILw==", 20 | "dev": true 21 | }, 22 | "@babel/highlight": { 23 | "version": "7.10.1", 24 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.1.tgz", 25 | "integrity": "sha512-8rMof+gVP8mxYZApLF/JgNDAkdKa+aJt3ZYxF8z6+j/hpeXL7iMsKCPHa2jNMHu/qqBwzQF4OHNoYi8dMA/rYg==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/helper-validator-identifier": "^7.10.1", 29 | "chalk": "^2.0.0", 30 | "js-tokens": "^4.0.0" 31 | }, 32 | "dependencies": { 33 | "ansi-styles": { 34 | "version": "3.2.1", 35 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 36 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 37 | "dev": true, 38 | "requires": { 39 | "color-convert": "^1.9.0" 40 | } 41 | }, 42 | "chalk": { 43 | "version": "2.4.2", 44 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 45 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 46 | "dev": true, 47 | "requires": { 48 | "ansi-styles": "^3.2.1", 49 | "escape-string-regexp": "^1.0.5", 50 | "supports-color": "^5.3.0" 51 | } 52 | }, 53 | "color-convert": { 54 | "version": "1.9.3", 55 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 56 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 57 | "dev": true, 58 | "requires": { 59 | "color-name": "1.1.3" 60 | } 61 | }, 62 | "color-name": { 63 | "version": "1.1.3", 64 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 65 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 66 | "dev": true 67 | }, 68 | "has-flag": { 69 | "version": "3.0.0", 70 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 71 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 72 | "dev": true 73 | }, 74 | "supports-color": { 75 | "version": "5.5.0", 76 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 77 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 78 | "dev": true, 79 | "requires": { 80 | "has-flag": "^3.0.0" 81 | } 82 | } 83 | } 84 | }, 85 | "@hapi/bourne": { 86 | "version": "2.0.0", 87 | "resolved": "https://registry.npmjs.org/@hapi/bourne/-/bourne-2.0.0.tgz", 88 | "integrity": "sha512-WEezM1FWztfbzqIUbsDzFRVMxSoLy3HugVcux6KDDtTqzPsLE8NDRHfXvev66aH1i2oOKKar3/XDjbvh/OUBdg==" 89 | }, 90 | "@types/color-name": { 91 | "version": "1.1.1", 92 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 93 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==" 94 | }, 95 | "@types/parse-json": { 96 | "version": "4.0.0", 97 | "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", 98 | "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==", 99 | "dev": true 100 | }, 101 | "acorn": { 102 | "version": "7.3.1", 103 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.3.1.tgz", 104 | "integrity": "sha512-tLc0wSnatxAQHVHUapaHdz72pi9KUyHjq5KyHjGg9Y8Ifdc79pTh2XvI6I1/chZbnM7QtNKzh66ooDogPZSleA==", 105 | "dev": true 106 | }, 107 | "acorn-jsx": { 108 | "version": "5.2.0", 109 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 110 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 111 | "dev": true 112 | }, 113 | "aggregate-error": { 114 | "version": "3.0.1", 115 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.0.1.tgz", 116 | "integrity": "sha512-quoaXsZ9/BLNae5yiNoUz+Nhkwz83GhWwtYFglcjEQB2NDHCIpApbqXxIFnm4Pq/Nvhrsq5sYJFyohrrxnTGAA==", 117 | "dev": true, 118 | "requires": { 119 | "clean-stack": "^2.0.0", 120 | "indent-string": "^4.0.0" 121 | } 122 | }, 123 | "ajv": { 124 | "version": "6.12.2", 125 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.2.tgz", 126 | "integrity": "sha512-k+V+hzjm5q/Mr8ef/1Y9goCmlsK4I6Sm74teeyGvFk1XrOsbsKLjEdrvny42CZ+a8sXbk8KWpY/bDwS+FLL2UQ==", 127 | "dev": true, 128 | "requires": { 129 | "fast-deep-equal": "^3.1.1", 130 | "fast-json-stable-stringify": "^2.0.0", 131 | "json-schema-traverse": "^0.4.1", 132 | "uri-js": "^4.2.2" 133 | } 134 | }, 135 | "ansi-colors": { 136 | "version": "3.2.4", 137 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.4.tgz", 138 | "integrity": "sha512-hHUXGagefjN2iRrID63xckIvotOXOojhQKWIPUZ4mNUZ9nLZW+7FMNoE1lOkEhNWYsx/7ysGIuJYCiMAA9FnrA==", 139 | "dev": true 140 | }, 141 | "ansi-escapes": { 142 | "version": "4.3.1", 143 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 144 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 145 | "dev": true, 146 | "requires": { 147 | "type-fest": "^0.11.0" 148 | } 149 | }, 150 | "ansi-regex": { 151 | "version": "5.0.0", 152 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 153 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" 154 | }, 155 | "ansi-styles": { 156 | "version": "4.2.1", 157 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 158 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 159 | "requires": { 160 | "@types/color-name": "^1.1.1", 161 | "color-convert": "^2.0.1" 162 | } 163 | }, 164 | "argparse": { 165 | "version": "1.0.10", 166 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 167 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 168 | "dev": true, 169 | "requires": { 170 | "sprintf-js": "~1.0.2" 171 | } 172 | }, 173 | "args": { 174 | "version": "5.0.1", 175 | "resolved": "https://registry.npmjs.org/args/-/args-5.0.1.tgz", 176 | "integrity": "sha512-1kqmFCFsPffavQFGt8OxJdIcETti99kySRUPMpOhaGjL6mRJn8HFU1OxKY5bMqfZKUwTQc1mZkAjmGYaVOHFtQ==", 177 | "requires": { 178 | "camelcase": "5.0.0", 179 | "chalk": "2.4.2", 180 | "leven": "2.1.0", 181 | "mri": "1.1.4" 182 | }, 183 | "dependencies": { 184 | "ansi-styles": { 185 | "version": "3.2.1", 186 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 187 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 188 | "requires": { 189 | "color-convert": "^1.9.0" 190 | } 191 | }, 192 | "chalk": { 193 | "version": "2.4.2", 194 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 195 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 196 | "requires": { 197 | "ansi-styles": "^3.2.1", 198 | "escape-string-regexp": "^1.0.5", 199 | "supports-color": "^5.3.0" 200 | } 201 | }, 202 | "color-convert": { 203 | "version": "1.9.3", 204 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 205 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 206 | "requires": { 207 | "color-name": "1.1.3" 208 | } 209 | }, 210 | "color-name": { 211 | "version": "1.1.3", 212 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 213 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 214 | }, 215 | "has-flag": { 216 | "version": "3.0.0", 217 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 218 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 219 | }, 220 | "supports-color": { 221 | "version": "5.5.0", 222 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 223 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 224 | "requires": { 225 | "has-flag": "^3.0.0" 226 | } 227 | } 228 | } 229 | }, 230 | "astral-regex": { 231 | "version": "2.0.0", 232 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 233 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 234 | "dev": true 235 | }, 236 | "atomic-sleep": { 237 | "version": "1.0.0", 238 | "resolved": "https://registry.npmjs.org/atomic-sleep/-/atomic-sleep-1.0.0.tgz", 239 | "integrity": "sha512-kNOjDqAh7px0XWNI+4QbzoiR/nTkHAWNud2uvnJquD1/x5a7EQZMJT0AczqK0Qn67oY/TTQ1LbUKajZpp3I9tQ==" 240 | }, 241 | "axios": { 242 | "version": "0.21.1", 243 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.21.1.tgz", 244 | "integrity": "sha512-dKQiRHxGD9PPRIUNIWvZhPTPpl1rf/OxTYKsqKUDjBwYylTvV7SjSHJb9ratfyzM6wCdLCOYLzs73qpg5c4iGA==", 245 | "requires": { 246 | "follow-redirects": "^1.10.0" 247 | } 248 | }, 249 | "balanced-match": { 250 | "version": "1.0.0", 251 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 252 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 253 | "dev": true 254 | }, 255 | "brace-expansion": { 256 | "version": "1.1.11", 257 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 258 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 259 | "dev": true, 260 | "requires": { 261 | "balanced-match": "^1.0.0", 262 | "concat-map": "0.0.1" 263 | } 264 | }, 265 | "braces": { 266 | "version": "3.0.2", 267 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 268 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 269 | "dev": true, 270 | "requires": { 271 | "fill-range": "^7.0.1" 272 | } 273 | }, 274 | "callsites": { 275 | "version": "3.1.0", 276 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 277 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 278 | "dev": true 279 | }, 280 | "camelcase": { 281 | "version": "5.0.0", 282 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.0.0.tgz", 283 | "integrity": "sha512-faqwZqnWxbxn+F1d399ygeamQNy3lPp/H9H6rNrqYh4FSVCtcY+3cub1MxA8o9mDd55mM8Aghuu/kuyYA6VTsA==" 284 | }, 285 | "chalk": { 286 | "version": "4.1.0", 287 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 288 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 289 | "dev": true, 290 | "requires": { 291 | "ansi-styles": "^4.1.0", 292 | "supports-color": "^7.1.0" 293 | } 294 | }, 295 | "chardet": { 296 | "version": "0.7.0", 297 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 298 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 299 | "dev": true 300 | }, 301 | "ci-info": { 302 | "version": "2.0.0", 303 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 304 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 305 | "dev": true 306 | }, 307 | "clean-stack": { 308 | "version": "2.2.0", 309 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 310 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 311 | "dev": true 312 | }, 313 | "cli-cursor": { 314 | "version": "3.1.0", 315 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 316 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 317 | "dev": true, 318 | "requires": { 319 | "restore-cursor": "^3.1.0" 320 | } 321 | }, 322 | "cli-truncate": { 323 | "version": "2.1.0", 324 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 325 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 326 | "dev": true, 327 | "requires": { 328 | "slice-ansi": "^3.0.0", 329 | "string-width": "^4.2.0" 330 | } 331 | }, 332 | "cli-width": { 333 | "version": "2.2.1", 334 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.1.tgz", 335 | "integrity": "sha512-GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw==", 336 | "dev": true 337 | }, 338 | "cliui": { 339 | "version": "6.0.0", 340 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", 341 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 342 | "requires": { 343 | "string-width": "^4.2.0", 344 | "strip-ansi": "^6.0.0", 345 | "wrap-ansi": "^6.2.0" 346 | } 347 | }, 348 | "color-convert": { 349 | "version": "2.0.1", 350 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 351 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 352 | "requires": { 353 | "color-name": "~1.1.4" 354 | } 355 | }, 356 | "color-name": { 357 | "version": "1.1.4", 358 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 359 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 360 | }, 361 | "commander": { 362 | "version": "5.1.0", 363 | "resolved": "https://registry.npmjs.org/commander/-/commander-5.1.0.tgz", 364 | "integrity": "sha512-P0CysNDQ7rtVw4QIQtm+MRxV66vKFSvlsQvGYXZWR3qFU0jlMKHZZZgw8e+8DSah4UDKMqnknRDQz+xuQXQ/Zg==", 365 | "dev": true 366 | }, 367 | "compare-versions": { 368 | "version": "3.6.0", 369 | "resolved": "https://registry.npmjs.org/compare-versions/-/compare-versions-3.6.0.tgz", 370 | "integrity": "sha512-W6Af2Iw1z4CB7q4uU4hv646dW9GQuBM+YpC0UvUCWSD8w90SJjp+ujJuXaEMtAXBtSqGfMPuFOVn4/+FlaqfBA==", 371 | "dev": true 372 | }, 373 | "concat-map": { 374 | "version": "0.0.1", 375 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 376 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 377 | "dev": true 378 | }, 379 | "cosmiconfig": { 380 | "version": "6.0.0", 381 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-6.0.0.tgz", 382 | "integrity": "sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg==", 383 | "dev": true, 384 | "requires": { 385 | "@types/parse-json": "^4.0.0", 386 | "import-fresh": "^3.1.0", 387 | "parse-json": "^5.0.0", 388 | "path-type": "^4.0.0", 389 | "yaml": "^1.7.2" 390 | } 391 | }, 392 | "cross-spawn": { 393 | "version": "7.0.3", 394 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 395 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 396 | "dev": true, 397 | "requires": { 398 | "path-key": "^3.1.0", 399 | "shebang-command": "^2.0.0", 400 | "which": "^2.0.1" 401 | } 402 | }, 403 | "dateformat": { 404 | "version": "3.0.3", 405 | "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-3.0.3.tgz", 406 | "integrity": "sha512-jyCETtSl3VMZMWeRo7iY1FL19ges1t55hMo5yaam4Jrsm5EPL89UQkoQRyiI+Yf4k8r2ZpdngkV8hr1lIdjb3Q==" 407 | }, 408 | "debug": { 409 | "version": "4.1.1", 410 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 411 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 412 | "dev": true, 413 | "requires": { 414 | "ms": "^2.1.1" 415 | } 416 | }, 417 | "decamelize": { 418 | "version": "1.2.0", 419 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 420 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 421 | }, 422 | "dedent": { 423 | "version": "0.7.0", 424 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", 425 | "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", 426 | "dev": true 427 | }, 428 | "deep-is": { 429 | "version": "0.1.3", 430 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 431 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 432 | "dev": true 433 | }, 434 | "doctrine": { 435 | "version": "3.0.0", 436 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 437 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 438 | "dev": true, 439 | "requires": { 440 | "esutils": "^2.0.2" 441 | } 442 | }, 443 | "emoji-regex": { 444 | "version": "8.0.0", 445 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 446 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 447 | }, 448 | "end-of-stream": { 449 | "version": "1.4.4", 450 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 451 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 452 | "requires": { 453 | "once": "^1.4.0" 454 | } 455 | }, 456 | "enquirer": { 457 | "version": "2.3.5", 458 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.5.tgz", 459 | "integrity": "sha512-BNT1C08P9XD0vNg3J475yIUG+mVdp9T6towYFHUv897X0KoHBjB1shyrNmhmtHWKP17iSWgo7Gqh7BBuzLZMSA==", 460 | "dev": true, 461 | "requires": { 462 | "ansi-colors": "^3.2.1" 463 | } 464 | }, 465 | "error-ex": { 466 | "version": "1.3.2", 467 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 468 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 469 | "dev": true, 470 | "requires": { 471 | "is-arrayish": "^0.2.1" 472 | } 473 | }, 474 | "escape-string-regexp": { 475 | "version": "1.0.5", 476 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 477 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 478 | }, 479 | "eslint": { 480 | "version": "7.2.0", 481 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.2.0.tgz", 482 | "integrity": "sha512-B3BtEyaDKC5MlfDa2Ha8/D6DsS4fju95zs0hjS3HdGazw+LNayai38A25qMppK37wWGWNYSPOR6oYzlz5MHsRQ==", 483 | "dev": true, 484 | "requires": { 485 | "@babel/code-frame": "^7.0.0", 486 | "ajv": "^6.10.0", 487 | "chalk": "^4.0.0", 488 | "cross-spawn": "^7.0.2", 489 | "debug": "^4.0.1", 490 | "doctrine": "^3.0.0", 491 | "eslint-scope": "^5.1.0", 492 | "eslint-utils": "^2.0.0", 493 | "eslint-visitor-keys": "^1.2.0", 494 | "espree": "^7.1.0", 495 | "esquery": "^1.2.0", 496 | "esutils": "^2.0.2", 497 | "file-entry-cache": "^5.0.1", 498 | "functional-red-black-tree": "^1.0.1", 499 | "glob-parent": "^5.0.0", 500 | "globals": "^12.1.0", 501 | "ignore": "^4.0.6", 502 | "import-fresh": "^3.0.0", 503 | "imurmurhash": "^0.1.4", 504 | "inquirer": "^7.0.0", 505 | "is-glob": "^4.0.0", 506 | "js-yaml": "^3.13.1", 507 | "json-stable-stringify-without-jsonify": "^1.0.1", 508 | "levn": "^0.4.1", 509 | "lodash": "^4.17.14", 510 | "minimatch": "^3.0.4", 511 | "natural-compare": "^1.4.0", 512 | "optionator": "^0.9.1", 513 | "progress": "^2.0.0", 514 | "regexpp": "^3.1.0", 515 | "semver": "^7.2.1", 516 | "strip-ansi": "^6.0.0", 517 | "strip-json-comments": "^3.1.0", 518 | "table": "^5.2.3", 519 | "text-table": "^0.2.0", 520 | "v8-compile-cache": "^2.0.3" 521 | } 522 | }, 523 | "eslint-config-prettier": { 524 | "version": "6.11.0", 525 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.11.0.tgz", 526 | "integrity": "sha512-oB8cpLWSAjOVFEJhhyMZh6NOEOtBVziaqdDQ86+qhDHFbZXoRTM7pNSvFRfW/W/L/LrQ38C99J5CGuRBBzBsdA==", 527 | "dev": true, 528 | "requires": { 529 | "get-stdin": "^6.0.0" 530 | } 531 | }, 532 | "eslint-plugin-prettier": { 533 | "version": "3.1.3", 534 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.1.3.tgz", 535 | "integrity": "sha512-+HG5jmu/dN3ZV3T6eCD7a4BlAySdN7mLIbJYo0z1cFQuI+r2DiTJEFeF68ots93PsnrMxbzIZ2S/ieX+mkrBeQ==", 536 | "dev": true, 537 | "requires": { 538 | "prettier-linter-helpers": "^1.0.0" 539 | } 540 | }, 541 | "eslint-scope": { 542 | "version": "5.1.0", 543 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.0.tgz", 544 | "integrity": "sha512-iiGRvtxWqgtx5m8EyQUJihBloE4EnYeGE/bz1wSPwJE6tZuJUtHlhqDM4Xj2ukE8Dyy1+HCZ4hE0fzIVMzb58w==", 545 | "dev": true, 546 | "requires": { 547 | "esrecurse": "^4.1.0", 548 | "estraverse": "^4.1.1" 549 | } 550 | }, 551 | "eslint-utils": { 552 | "version": "2.0.0", 553 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.0.0.tgz", 554 | "integrity": "sha512-0HCPuJv+7Wv1bACm8y5/ECVfYdfsAm9xmVb7saeFlxjPYALefjhbYoCkBjPdPzGH8wWyTpAez82Fh3VKYEZ8OA==", 555 | "dev": true, 556 | "requires": { 557 | "eslint-visitor-keys": "^1.1.0" 558 | } 559 | }, 560 | "eslint-visitor-keys": { 561 | "version": "1.2.0", 562 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.2.0.tgz", 563 | "integrity": "sha512-WFb4ihckKil6hu3Dp798xdzSfddwKKU3+nGniKF6HfeW6OLd2OUDEPP7TcHtB5+QXOKg2s6B2DaMPE1Nn/kxKQ==", 564 | "dev": true 565 | }, 566 | "espree": { 567 | "version": "7.1.0", 568 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.1.0.tgz", 569 | "integrity": "sha512-dcorZSyfmm4WTuTnE5Y7MEN1DyoPYy1ZR783QW1FJoenn7RailyWFsq/UL6ZAAA7uXurN9FIpYyUs3OfiIW+Qw==", 570 | "dev": true, 571 | "requires": { 572 | "acorn": "^7.2.0", 573 | "acorn-jsx": "^5.2.0", 574 | "eslint-visitor-keys": "^1.2.0" 575 | } 576 | }, 577 | "esprima": { 578 | "version": "4.0.1", 579 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 580 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 581 | "dev": true 582 | }, 583 | "esquery": { 584 | "version": "1.3.1", 585 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 586 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 587 | "dev": true, 588 | "requires": { 589 | "estraverse": "^5.1.0" 590 | }, 591 | "dependencies": { 592 | "estraverse": { 593 | "version": "5.1.0", 594 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 595 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 596 | "dev": true 597 | } 598 | } 599 | }, 600 | "esrecurse": { 601 | "version": "4.2.1", 602 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 603 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 604 | "dev": true, 605 | "requires": { 606 | "estraverse": "^4.1.0" 607 | } 608 | }, 609 | "estraverse": { 610 | "version": "4.3.0", 611 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 612 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 613 | "dev": true 614 | }, 615 | "esutils": { 616 | "version": "2.0.3", 617 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 618 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 619 | "dev": true 620 | }, 621 | "execa": { 622 | "version": "4.0.2", 623 | "resolved": "https://registry.npmjs.org/execa/-/execa-4.0.2.tgz", 624 | "integrity": "sha512-QI2zLa6CjGWdiQsmSkZoGtDx2N+cQIGb3yNolGTdjSQzydzLgYYf8LRuagp7S7fPimjcrzUDSUFd/MgzELMi4Q==", 625 | "dev": true, 626 | "requires": { 627 | "cross-spawn": "^7.0.0", 628 | "get-stream": "^5.0.0", 629 | "human-signals": "^1.1.1", 630 | "is-stream": "^2.0.0", 631 | "merge-stream": "^2.0.0", 632 | "npm-run-path": "^4.0.0", 633 | "onetime": "^5.1.0", 634 | "signal-exit": "^3.0.2", 635 | "strip-final-newline": "^2.0.0" 636 | } 637 | }, 638 | "external-editor": { 639 | "version": "3.1.0", 640 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 641 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 642 | "dev": true, 643 | "requires": { 644 | "chardet": "^0.7.0", 645 | "iconv-lite": "^0.4.24", 646 | "tmp": "^0.0.33" 647 | } 648 | }, 649 | "fast-deep-equal": { 650 | "version": "3.1.3", 651 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 652 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 653 | "dev": true 654 | }, 655 | "fast-diff": { 656 | "version": "1.2.0", 657 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 658 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 659 | "dev": true 660 | }, 661 | "fast-json-stable-stringify": { 662 | "version": "2.1.0", 663 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 664 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 665 | "dev": true 666 | }, 667 | "fast-levenshtein": { 668 | "version": "2.0.6", 669 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 670 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 671 | "dev": true 672 | }, 673 | "fast-redact": { 674 | "version": "2.0.0", 675 | "resolved": "https://registry.npmjs.org/fast-redact/-/fast-redact-2.0.0.tgz", 676 | "integrity": "sha512-zxpkULI9W9MNTK2sJ3BpPQrTEXFNESd2X6O1tXMFpK/XM0G5c5Rll2EVYZH2TqI3xRGK/VaJ+eEOt7pnENJpeA==" 677 | }, 678 | "fast-safe-stringify": { 679 | "version": "2.0.7", 680 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.7.tgz", 681 | "integrity": "sha512-Utm6CdzT+6xsDk2m8S6uL8VHxNwI6Jub+e9NYTcAms28T84pTa25GJQV9j0CY0N1rM8hK4x6grpF2BQf+2qwVA==" 682 | }, 683 | "figures": { 684 | "version": "3.2.0", 685 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 686 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 687 | "dev": true, 688 | "requires": { 689 | "escape-string-regexp": "^1.0.5" 690 | } 691 | }, 692 | "file-entry-cache": { 693 | "version": "5.0.1", 694 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 695 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 696 | "dev": true, 697 | "requires": { 698 | "flat-cache": "^2.0.1" 699 | } 700 | }, 701 | "fill-range": { 702 | "version": "7.0.1", 703 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 704 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 705 | "dev": true, 706 | "requires": { 707 | "to-regex-range": "^5.0.1" 708 | } 709 | }, 710 | "find-up": { 711 | "version": "4.1.0", 712 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 713 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 714 | "requires": { 715 | "locate-path": "^5.0.0", 716 | "path-exists": "^4.0.0" 717 | } 718 | }, 719 | "find-versions": { 720 | "version": "3.2.0", 721 | "resolved": "https://registry.npmjs.org/find-versions/-/find-versions-3.2.0.tgz", 722 | "integrity": "sha512-P8WRou2S+oe222TOCHitLy8zj+SIsVJh52VP4lvXkaFVnOFFdoWv1H1Jjvel1aI6NCFOAaeAVm8qrI0odiLcww==", 723 | "dev": true, 724 | "requires": { 725 | "semver-regex": "^2.0.0" 726 | } 727 | }, 728 | "flat-cache": { 729 | "version": "2.0.1", 730 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 731 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 732 | "dev": true, 733 | "requires": { 734 | "flatted": "^2.0.0", 735 | "rimraf": "2.6.3", 736 | "write": "1.0.3" 737 | } 738 | }, 739 | "flatstr": { 740 | "version": "1.0.12", 741 | "resolved": "https://registry.npmjs.org/flatstr/-/flatstr-1.0.12.tgz", 742 | "integrity": "sha512-4zPxDyhCyiN2wIAtSLI6gc82/EjqZc1onI4Mz/l0pWrAlsSfYH/2ZIcU+e3oA2wDwbzIWNKwa23F8rh6+DRWkw==" 743 | }, 744 | "flatted": { 745 | "version": "2.0.2", 746 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 747 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 748 | "dev": true 749 | }, 750 | "follow-redirects": { 751 | "version": "1.13.1", 752 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.13.1.tgz", 753 | "integrity": "sha512-SSG5xmZh1mkPGyKzjZP8zLjltIfpW32Y5QpdNJyjcfGxK3qo3NDDkZOZSFiGn1A6SclQxY9GzEwAHQ3dmYRWpg==" 754 | }, 755 | "fs.realpath": { 756 | "version": "1.0.0", 757 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 758 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 759 | "dev": true 760 | }, 761 | "functional-red-black-tree": { 762 | "version": "1.0.1", 763 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 764 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 765 | "dev": true 766 | }, 767 | "get-caller-file": { 768 | "version": "2.0.5", 769 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 770 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" 771 | }, 772 | "get-own-enumerable-property-symbols": { 773 | "version": "3.0.2", 774 | "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz", 775 | "integrity": "sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==", 776 | "dev": true 777 | }, 778 | "get-stdin": { 779 | "version": "6.0.0", 780 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", 781 | "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", 782 | "dev": true 783 | }, 784 | "get-stream": { 785 | "version": "5.1.0", 786 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.1.0.tgz", 787 | "integrity": "sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw==", 788 | "dev": true, 789 | "requires": { 790 | "pump": "^3.0.0" 791 | } 792 | }, 793 | "glob": { 794 | "version": "7.1.6", 795 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 796 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 797 | "dev": true, 798 | "requires": { 799 | "fs.realpath": "^1.0.0", 800 | "inflight": "^1.0.4", 801 | "inherits": "2", 802 | "minimatch": "^3.0.4", 803 | "once": "^1.3.0", 804 | "path-is-absolute": "^1.0.0" 805 | } 806 | }, 807 | "glob-parent": { 808 | "version": "5.1.2", 809 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 810 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 811 | "dev": true, 812 | "requires": { 813 | "is-glob": "^4.0.1" 814 | } 815 | }, 816 | "globals": { 817 | "version": "12.4.0", 818 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 819 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 820 | "dev": true, 821 | "requires": { 822 | "type-fest": "^0.8.1" 823 | }, 824 | "dependencies": { 825 | "type-fest": { 826 | "version": "0.8.1", 827 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 828 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 829 | "dev": true 830 | } 831 | } 832 | }, 833 | "has-flag": { 834 | "version": "4.0.0", 835 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 836 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 837 | }, 838 | "human-signals": { 839 | "version": "1.1.1", 840 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz", 841 | "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==", 842 | "dev": true 843 | }, 844 | "husky": { 845 | "version": "4.2.5", 846 | "resolved": "https://registry.npmjs.org/husky/-/husky-4.2.5.tgz", 847 | "integrity": "sha512-SYZ95AjKcX7goYVZtVZF2i6XiZcHknw50iXvY7b0MiGoj5RwdgRQNEHdb+gPDPCXKlzwrybjFjkL6FOj8uRhZQ==", 848 | "dev": true, 849 | "requires": { 850 | "chalk": "^4.0.0", 851 | "ci-info": "^2.0.0", 852 | "compare-versions": "^3.6.0", 853 | "cosmiconfig": "^6.0.0", 854 | "find-versions": "^3.2.0", 855 | "opencollective-postinstall": "^2.0.2", 856 | "pkg-dir": "^4.2.0", 857 | "please-upgrade-node": "^3.2.0", 858 | "slash": "^3.0.0", 859 | "which-pm-runs": "^1.0.0" 860 | } 861 | }, 862 | "iconv-lite": { 863 | "version": "0.4.24", 864 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 865 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 866 | "dev": true, 867 | "requires": { 868 | "safer-buffer": ">= 2.1.2 < 3" 869 | } 870 | }, 871 | "ignore": { 872 | "version": "4.0.6", 873 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 874 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 875 | "dev": true 876 | }, 877 | "import-fresh": { 878 | "version": "3.2.1", 879 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 880 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 881 | "dev": true, 882 | "requires": { 883 | "parent-module": "^1.0.0", 884 | "resolve-from": "^4.0.0" 885 | } 886 | }, 887 | "imurmurhash": { 888 | "version": "0.1.4", 889 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 890 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 891 | "dev": true 892 | }, 893 | "indent-string": { 894 | "version": "4.0.0", 895 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 896 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 897 | "dev": true 898 | }, 899 | "inflight": { 900 | "version": "1.0.6", 901 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 902 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 903 | "dev": true, 904 | "requires": { 905 | "once": "^1.3.0", 906 | "wrappy": "1" 907 | } 908 | }, 909 | "inherits": { 910 | "version": "2.0.4", 911 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 912 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 913 | }, 914 | "inquirer": { 915 | "version": "7.1.0", 916 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.1.0.tgz", 917 | "integrity": "sha512-5fJMWEmikSYu0nv/flMc475MhGbB7TSPd/2IpFV4I4rMklboCH2rQjYY5kKiYGHqUF9gvaambupcJFFG9dvReg==", 918 | "dev": true, 919 | "requires": { 920 | "ansi-escapes": "^4.2.1", 921 | "chalk": "^3.0.0", 922 | "cli-cursor": "^3.1.0", 923 | "cli-width": "^2.0.0", 924 | "external-editor": "^3.0.3", 925 | "figures": "^3.0.0", 926 | "lodash": "^4.17.15", 927 | "mute-stream": "0.0.8", 928 | "run-async": "^2.4.0", 929 | "rxjs": "^6.5.3", 930 | "string-width": "^4.1.0", 931 | "strip-ansi": "^6.0.0", 932 | "through": "^2.3.6" 933 | }, 934 | "dependencies": { 935 | "chalk": { 936 | "version": "3.0.0", 937 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 938 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 939 | "dev": true, 940 | "requires": { 941 | "ansi-styles": "^4.1.0", 942 | "supports-color": "^7.1.0" 943 | } 944 | } 945 | } 946 | }, 947 | "is-arrayish": { 948 | "version": "0.2.1", 949 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 950 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 951 | "dev": true 952 | }, 953 | "is-extglob": { 954 | "version": "2.1.1", 955 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 956 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 957 | "dev": true 958 | }, 959 | "is-fullwidth-code-point": { 960 | "version": "3.0.0", 961 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 962 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 963 | }, 964 | "is-glob": { 965 | "version": "4.0.1", 966 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 967 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 968 | "dev": true, 969 | "requires": { 970 | "is-extglob": "^2.1.1" 971 | } 972 | }, 973 | "is-number": { 974 | "version": "7.0.0", 975 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 976 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 977 | "dev": true 978 | }, 979 | "is-obj": { 980 | "version": "1.0.1", 981 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 982 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 983 | "dev": true 984 | }, 985 | "is-regexp": { 986 | "version": "1.0.0", 987 | "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz", 988 | "integrity": "sha1-/S2INUXEa6xaYz57mgnof6LLUGk=", 989 | "dev": true 990 | }, 991 | "is-stream": { 992 | "version": "2.0.0", 993 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 994 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 995 | "dev": true 996 | }, 997 | "isexe": { 998 | "version": "2.0.0", 999 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1000 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1001 | "dev": true 1002 | }, 1003 | "jmespath": { 1004 | "version": "0.15.0", 1005 | "resolved": "https://registry.npmjs.org/jmespath/-/jmespath-0.15.0.tgz", 1006 | "integrity": "sha1-o/Iiqarp+Wb10nx5ZRDigJF2Qhc=" 1007 | }, 1008 | "joycon": { 1009 | "version": "2.2.5", 1010 | "resolved": "https://registry.npmjs.org/joycon/-/joycon-2.2.5.tgz", 1011 | "integrity": "sha512-YqvUxoOcVPnCp0VU1/56f+iKSdvIRJYPznH22BdXV3xMk75SFXhWeJkZ8C9XxUWt1b5x2X1SxuFygW1U0FmkEQ==" 1012 | }, 1013 | "js-tokens": { 1014 | "version": "4.0.0", 1015 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1016 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1017 | "dev": true 1018 | }, 1019 | "js-yaml": { 1020 | "version": "3.14.0", 1021 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 1022 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 1023 | "dev": true, 1024 | "requires": { 1025 | "argparse": "^1.0.7", 1026 | "esprima": "^4.0.0" 1027 | } 1028 | }, 1029 | "json-parse-better-errors": { 1030 | "version": "1.0.2", 1031 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1032 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1033 | "dev": true 1034 | }, 1035 | "json-schema-traverse": { 1036 | "version": "0.4.1", 1037 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1038 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1039 | "dev": true 1040 | }, 1041 | "json-stable-stringify-without-jsonify": { 1042 | "version": "1.0.1", 1043 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1044 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1045 | "dev": true 1046 | }, 1047 | "leven": { 1048 | "version": "2.1.0", 1049 | "resolved": "https://registry.npmjs.org/leven/-/leven-2.1.0.tgz", 1050 | "integrity": "sha1-wuep93IJTe6dNCAq6KzORoeHVYA=" 1051 | }, 1052 | "levn": { 1053 | "version": "0.4.1", 1054 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1055 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1056 | "dev": true, 1057 | "requires": { 1058 | "prelude-ls": "^1.2.1", 1059 | "type-check": "~0.4.0" 1060 | } 1061 | }, 1062 | "lines-and-columns": { 1063 | "version": "1.1.6", 1064 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", 1065 | "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=", 1066 | "dev": true 1067 | }, 1068 | "lint-staged": { 1069 | "version": "10.2.10", 1070 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-10.2.10.tgz", 1071 | "integrity": "sha512-dgelFaNH6puUGAcU+OVMgbfpKSerNYsPSn6+nlbRDjovL0KigpsVpCu0PFZG6BJxX8gnHJqaZlR9krZamQsb0w==", 1072 | "dev": true, 1073 | "requires": { 1074 | "chalk": "^4.0.0", 1075 | "cli-truncate": "2.1.0", 1076 | "commander": "^5.1.0", 1077 | "cosmiconfig": "^6.0.0", 1078 | "debug": "^4.1.1", 1079 | "dedent": "^0.7.0", 1080 | "enquirer": "^2.3.5", 1081 | "execa": "^4.0.1", 1082 | "listr2": "^2.1.0", 1083 | "log-symbols": "^4.0.0", 1084 | "micromatch": "^4.0.2", 1085 | "normalize-path": "^3.0.0", 1086 | "please-upgrade-node": "^3.2.0", 1087 | "string-argv": "0.3.1", 1088 | "stringify-object": "^3.3.0" 1089 | } 1090 | }, 1091 | "listr2": { 1092 | "version": "2.1.3", 1093 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-2.1.3.tgz", 1094 | "integrity": "sha512-6oy3QhrZAlJGrG8oPcRp1hix1zUpb5AvyvZ5je979HCyf48tIj3Hn1TG5+rfyhz30t7HfySH/OIaVbwrI2kruA==", 1095 | "dev": true, 1096 | "requires": { 1097 | "chalk": "^4.0.0", 1098 | "cli-truncate": "^2.1.0", 1099 | "figures": "^3.2.0", 1100 | "indent-string": "^4.0.0", 1101 | "log-update": "^4.0.0", 1102 | "p-map": "^4.0.0", 1103 | "rxjs": "^6.5.5", 1104 | "through": "^2.3.8" 1105 | } 1106 | }, 1107 | "locate-path": { 1108 | "version": "5.0.0", 1109 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 1110 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 1111 | "requires": { 1112 | "p-locate": "^4.1.0" 1113 | } 1114 | }, 1115 | "lodash": { 1116 | "version": "4.17.21", 1117 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1118 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1119 | "dev": true 1120 | }, 1121 | "log-symbols": { 1122 | "version": "4.0.0", 1123 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz", 1124 | "integrity": "sha512-FN8JBzLx6CzeMrB0tg6pqlGU1wCrXW+ZXGH481kfsBqer0hToTIiHdjH4Mq8xJUbvATujKCvaREGWpGUionraA==", 1125 | "dev": true, 1126 | "requires": { 1127 | "chalk": "^4.0.0" 1128 | } 1129 | }, 1130 | "log-update": { 1131 | "version": "4.0.0", 1132 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 1133 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 1134 | "dev": true, 1135 | "requires": { 1136 | "ansi-escapes": "^4.3.0", 1137 | "cli-cursor": "^3.1.0", 1138 | "slice-ansi": "^4.0.0", 1139 | "wrap-ansi": "^6.2.0" 1140 | }, 1141 | "dependencies": { 1142 | "slice-ansi": { 1143 | "version": "4.0.0", 1144 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1145 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1146 | "dev": true, 1147 | "requires": { 1148 | "ansi-styles": "^4.0.0", 1149 | "astral-regex": "^2.0.0", 1150 | "is-fullwidth-code-point": "^3.0.0" 1151 | } 1152 | } 1153 | } 1154 | }, 1155 | "merge-stream": { 1156 | "version": "2.0.0", 1157 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1158 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1159 | "dev": true 1160 | }, 1161 | "micromatch": { 1162 | "version": "4.0.2", 1163 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz", 1164 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==", 1165 | "dev": true, 1166 | "requires": { 1167 | "braces": "^3.0.1", 1168 | "picomatch": "^2.0.5" 1169 | } 1170 | }, 1171 | "mimic-fn": { 1172 | "version": "2.1.0", 1173 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1174 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1175 | "dev": true 1176 | }, 1177 | "minimatch": { 1178 | "version": "3.0.4", 1179 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1180 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1181 | "dev": true, 1182 | "requires": { 1183 | "brace-expansion": "^1.1.7" 1184 | } 1185 | }, 1186 | "minimist": { 1187 | "version": "1.2.5", 1188 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1189 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1190 | "dev": true 1191 | }, 1192 | "mkdirp": { 1193 | "version": "0.5.5", 1194 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1195 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1196 | "dev": true, 1197 | "requires": { 1198 | "minimist": "^1.2.5" 1199 | } 1200 | }, 1201 | "moment": { 1202 | "version": "2.26.0", 1203 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.26.0.tgz", 1204 | "integrity": "sha512-oIixUO+OamkUkwjhAVE18rAMfRJNsNe/Stid/gwHSOfHrOtw9EhAY2AHvdKZ/k/MggcYELFCJz/Sn2pL8b8JMw==" 1205 | }, 1206 | "mri": { 1207 | "version": "1.1.4", 1208 | "resolved": "https://registry.npmjs.org/mri/-/mri-1.1.4.tgz", 1209 | "integrity": "sha512-6y7IjGPm8AzlvoUrwAaw1tLnUBudaS3752vcd8JtrpGGQn+rXIe63LFVHm/YMwtqAuh+LJPCFdlLYPWM1nYn6w==" 1210 | }, 1211 | "ms": { 1212 | "version": "2.1.2", 1213 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1214 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1215 | "dev": true 1216 | }, 1217 | "mute-stream": { 1218 | "version": "0.0.8", 1219 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1220 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1221 | "dev": true 1222 | }, 1223 | "natural-compare": { 1224 | "version": "1.4.0", 1225 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1226 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1227 | "dev": true 1228 | }, 1229 | "normalize-path": { 1230 | "version": "3.0.0", 1231 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1232 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1233 | "dev": true 1234 | }, 1235 | "npm-run-path": { 1236 | "version": "4.0.1", 1237 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 1238 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 1239 | "dev": true, 1240 | "requires": { 1241 | "path-key": "^3.0.0" 1242 | } 1243 | }, 1244 | "once": { 1245 | "version": "1.4.0", 1246 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1247 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1248 | "requires": { 1249 | "wrappy": "1" 1250 | } 1251 | }, 1252 | "onetime": { 1253 | "version": "5.1.0", 1254 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1255 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1256 | "dev": true, 1257 | "requires": { 1258 | "mimic-fn": "^2.1.0" 1259 | } 1260 | }, 1261 | "opencollective-postinstall": { 1262 | "version": "2.0.3", 1263 | "resolved": "https://registry.npmjs.org/opencollective-postinstall/-/opencollective-postinstall-2.0.3.tgz", 1264 | "integrity": "sha512-8AV/sCtuzUeTo8gQK5qDZzARrulB3egtLzFgteqB2tcT4Mw7B8Kt7JcDHmltjz6FOAHsvTevk70gZEbhM4ZS9Q==", 1265 | "dev": true 1266 | }, 1267 | "optionator": { 1268 | "version": "0.9.1", 1269 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1270 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1271 | "dev": true, 1272 | "requires": { 1273 | "deep-is": "^0.1.3", 1274 | "fast-levenshtein": "^2.0.6", 1275 | "levn": "^0.4.1", 1276 | "prelude-ls": "^1.2.1", 1277 | "type-check": "^0.4.0", 1278 | "word-wrap": "^1.2.3" 1279 | } 1280 | }, 1281 | "os-tmpdir": { 1282 | "version": "1.0.2", 1283 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1284 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1285 | "dev": true 1286 | }, 1287 | "p-limit": { 1288 | "version": "2.3.0", 1289 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 1290 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1291 | "requires": { 1292 | "p-try": "^2.0.0" 1293 | } 1294 | }, 1295 | "p-locate": { 1296 | "version": "4.1.0", 1297 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 1298 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 1299 | "requires": { 1300 | "p-limit": "^2.2.0" 1301 | } 1302 | }, 1303 | "p-map": { 1304 | "version": "4.0.0", 1305 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 1306 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 1307 | "dev": true, 1308 | "requires": { 1309 | "aggregate-error": "^3.0.0" 1310 | } 1311 | }, 1312 | "p-try": { 1313 | "version": "2.2.0", 1314 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1315 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" 1316 | }, 1317 | "parent-module": { 1318 | "version": "1.0.1", 1319 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1320 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1321 | "dev": true, 1322 | "requires": { 1323 | "callsites": "^3.0.0" 1324 | } 1325 | }, 1326 | "parse-json": { 1327 | "version": "5.0.0", 1328 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.0.0.tgz", 1329 | "integrity": "sha512-OOY5b7PAEFV0E2Fir1KOkxchnZNCdowAJgQ5NuxjpBKTRP3pQhwkrkxqQjeoKJ+fO7bCpmIZaogI4eZGDMEGOw==", 1330 | "dev": true, 1331 | "requires": { 1332 | "@babel/code-frame": "^7.0.0", 1333 | "error-ex": "^1.3.1", 1334 | "json-parse-better-errors": "^1.0.1", 1335 | "lines-and-columns": "^1.1.6" 1336 | } 1337 | }, 1338 | "path-exists": { 1339 | "version": "4.0.0", 1340 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1341 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" 1342 | }, 1343 | "path-is-absolute": { 1344 | "version": "1.0.1", 1345 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1346 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1347 | "dev": true 1348 | }, 1349 | "path-key": { 1350 | "version": "3.1.1", 1351 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1352 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1353 | "dev": true 1354 | }, 1355 | "path-type": { 1356 | "version": "4.0.0", 1357 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1358 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1359 | "dev": true 1360 | }, 1361 | "picomatch": { 1362 | "version": "2.2.2", 1363 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 1364 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 1365 | "dev": true 1366 | }, 1367 | "pino": { 1368 | "version": "6.3.2", 1369 | "resolved": "https://registry.npmjs.org/pino/-/pino-6.3.2.tgz", 1370 | "integrity": "sha512-EiP3L1hoFw19KPocWimjnfXeysld0ne89ZRQ+bf8nAeA2TyuLoggNlibAi+Kla67GvQBopLdIZOsh1z/Lruo5Q==", 1371 | "requires": { 1372 | "fast-redact": "^2.0.0", 1373 | "fast-safe-stringify": "^2.0.7", 1374 | "flatstr": "^1.0.12", 1375 | "pino-std-serializers": "^2.4.2", 1376 | "quick-format-unescaped": "^4.0.1", 1377 | "sonic-boom": "^1.0.0" 1378 | } 1379 | }, 1380 | "pino-pretty": { 1381 | "version": "4.0.0", 1382 | "resolved": "https://registry.npmjs.org/pino-pretty/-/pino-pretty-4.0.0.tgz", 1383 | "integrity": "sha512-YLy/n3dMXYWOodSm530gelkSAJGmEp29L9pqiycInlIae5FEJPWAkMRO3JFMbIFtjD2Ve4SH2aBcz2aRreGpBQ==", 1384 | "requires": { 1385 | "@hapi/bourne": "^2.0.0", 1386 | "args": "^5.0.1", 1387 | "chalk": "^3.0.0", 1388 | "dateformat": "^3.0.3", 1389 | "fast-safe-stringify": "^2.0.7", 1390 | "jmespath": "^0.15.0", 1391 | "joycon": "^2.2.5", 1392 | "pump": "^3.0.0", 1393 | "readable-stream": "^3.6.0", 1394 | "split2": "^3.1.1", 1395 | "strip-json-comments": "^3.0.1" 1396 | }, 1397 | "dependencies": { 1398 | "chalk": { 1399 | "version": "3.0.0", 1400 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 1401 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 1402 | "requires": { 1403 | "ansi-styles": "^4.1.0", 1404 | "supports-color": "^7.1.0" 1405 | } 1406 | } 1407 | } 1408 | }, 1409 | "pino-std-serializers": { 1410 | "version": "2.4.2", 1411 | "resolved": "https://registry.npmjs.org/pino-std-serializers/-/pino-std-serializers-2.4.2.tgz", 1412 | "integrity": "sha512-WaL504dO8eGs+vrK+j4BuQQq6GLKeCCcHaMB2ItygzVURcL1CycwNEUHTD/lHFHs/NL5qAz2UKrjYWXKSf4aMQ==" 1413 | }, 1414 | "pkg-dir": { 1415 | "version": "4.2.0", 1416 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 1417 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 1418 | "dev": true, 1419 | "requires": { 1420 | "find-up": "^4.0.0" 1421 | } 1422 | }, 1423 | "please-upgrade-node": { 1424 | "version": "3.2.0", 1425 | "resolved": "https://registry.npmjs.org/please-upgrade-node/-/please-upgrade-node-3.2.0.tgz", 1426 | "integrity": "sha512-gQR3WpIgNIKwBMVLkpMUeR3e1/E1y42bqDQZfql+kDeXd8COYfM8PQA4X6y7a8u9Ua9FHmsrrmirW2vHs45hWg==", 1427 | "dev": true, 1428 | "requires": { 1429 | "semver-compare": "^1.0.0" 1430 | } 1431 | }, 1432 | "prelude-ls": { 1433 | "version": "1.2.1", 1434 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1435 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1436 | "dev": true 1437 | }, 1438 | "prettier": { 1439 | "version": "2.0.5", 1440 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.0.5.tgz", 1441 | "integrity": "sha512-7PtVymN48hGcO4fGjybyBSIWDsLU4H4XlvOHfq91pz9kkGlonzwTfYkaIEwiRg/dAJF9YlbsduBAgtYLi+8cFg==", 1442 | "dev": true 1443 | }, 1444 | "prettier-linter-helpers": { 1445 | "version": "1.0.0", 1446 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 1447 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 1448 | "dev": true, 1449 | "requires": { 1450 | "fast-diff": "^1.1.2" 1451 | } 1452 | }, 1453 | "progress": { 1454 | "version": "2.0.3", 1455 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1456 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1457 | "dev": true 1458 | }, 1459 | "pump": { 1460 | "version": "3.0.0", 1461 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1462 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1463 | "requires": { 1464 | "end-of-stream": "^1.1.0", 1465 | "once": "^1.3.1" 1466 | } 1467 | }, 1468 | "punycode": { 1469 | "version": "2.1.1", 1470 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1471 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1472 | "dev": true 1473 | }, 1474 | "quick-format-unescaped": { 1475 | "version": "4.0.1", 1476 | "resolved": "https://registry.npmjs.org/quick-format-unescaped/-/quick-format-unescaped-4.0.1.tgz", 1477 | "integrity": "sha512-RyYpQ6Q5/drsJyOhrWHYMWTedvjTIat+FTwv0K4yoUxzvekw2aRHMQJLlnvt8UantkZg2++bEzD9EdxXqkWf4A==" 1478 | }, 1479 | "readable-stream": { 1480 | "version": "3.6.0", 1481 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", 1482 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", 1483 | "requires": { 1484 | "inherits": "^2.0.3", 1485 | "string_decoder": "^1.1.1", 1486 | "util-deprecate": "^1.0.1" 1487 | } 1488 | }, 1489 | "regexpp": { 1490 | "version": "3.1.0", 1491 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1492 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1493 | "dev": true 1494 | }, 1495 | "require-directory": { 1496 | "version": "2.1.1", 1497 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1498 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" 1499 | }, 1500 | "require-main-filename": { 1501 | "version": "2.0.0", 1502 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1503 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==" 1504 | }, 1505 | "resolve-from": { 1506 | "version": "4.0.0", 1507 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1508 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1509 | "dev": true 1510 | }, 1511 | "restore-cursor": { 1512 | "version": "3.1.0", 1513 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1514 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1515 | "dev": true, 1516 | "requires": { 1517 | "onetime": "^5.1.0", 1518 | "signal-exit": "^3.0.2" 1519 | } 1520 | }, 1521 | "rimraf": { 1522 | "version": "2.6.3", 1523 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1524 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1525 | "dev": true, 1526 | "requires": { 1527 | "glob": "^7.1.3" 1528 | } 1529 | }, 1530 | "run-async": { 1531 | "version": "2.4.1", 1532 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", 1533 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", 1534 | "dev": true 1535 | }, 1536 | "rxjs": { 1537 | "version": "6.5.5", 1538 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.5.tgz", 1539 | "integrity": "sha512-WfQI+1gohdf0Dai/Bbmk5L5ItH5tYqm3ki2c5GdWhKjalzjg93N3avFjVStyZZz+A2Em+ZxKH5bNghw9UeylGQ==", 1540 | "dev": true, 1541 | "requires": { 1542 | "tslib": "^1.9.0" 1543 | } 1544 | }, 1545 | "safe-buffer": { 1546 | "version": "5.2.1", 1547 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1548 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 1549 | }, 1550 | "safer-buffer": { 1551 | "version": "2.1.2", 1552 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1553 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1554 | "dev": true 1555 | }, 1556 | "semver": { 1557 | "version": "7.3.2", 1558 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 1559 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 1560 | "dev": true 1561 | }, 1562 | "semver-compare": { 1563 | "version": "1.0.0", 1564 | "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", 1565 | "integrity": "sha1-De4hahyUGrN+nvsXiPavxf9VN/w=", 1566 | "dev": true 1567 | }, 1568 | "semver-regex": { 1569 | "version": "2.0.0", 1570 | "resolved": "https://registry.npmjs.org/semver-regex/-/semver-regex-2.0.0.tgz", 1571 | "integrity": "sha512-mUdIBBvdn0PLOeP3TEkMH7HHeUP3GjsXCwKarjv/kGmUFOYg1VqEemKhoQpWMu6X2I8kHeuVdGibLGkVK+/5Qw==", 1572 | "dev": true 1573 | }, 1574 | "set-blocking": { 1575 | "version": "2.0.0", 1576 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1577 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1578 | }, 1579 | "shebang-command": { 1580 | "version": "2.0.0", 1581 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1582 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1583 | "dev": true, 1584 | "requires": { 1585 | "shebang-regex": "^3.0.0" 1586 | } 1587 | }, 1588 | "shebang-regex": { 1589 | "version": "3.0.0", 1590 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1591 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1592 | "dev": true 1593 | }, 1594 | "signal-exit": { 1595 | "version": "3.0.3", 1596 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1597 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 1598 | "dev": true 1599 | }, 1600 | "slash": { 1601 | "version": "3.0.0", 1602 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 1603 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 1604 | "dev": true 1605 | }, 1606 | "slice-ansi": { 1607 | "version": "3.0.0", 1608 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 1609 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 1610 | "dev": true, 1611 | "requires": { 1612 | "ansi-styles": "^4.0.0", 1613 | "astral-regex": "^2.0.0", 1614 | "is-fullwidth-code-point": "^3.0.0" 1615 | } 1616 | }, 1617 | "sonic-boom": { 1618 | "version": "1.0.1", 1619 | "resolved": "https://registry.npmjs.org/sonic-boom/-/sonic-boom-1.0.1.tgz", 1620 | "integrity": "sha512-o9tx+bonVEXSaPtptyXQXpP8l6UV9Bi3im2geZskvWw2a/o/hrbWI7EBbbv+rOx6Hubnzun9GgH4WfbgEA3MFQ==", 1621 | "requires": { 1622 | "atomic-sleep": "^1.0.0", 1623 | "flatstr": "^1.0.12" 1624 | } 1625 | }, 1626 | "split2": { 1627 | "version": "3.1.1", 1628 | "resolved": "https://registry.npmjs.org/split2/-/split2-3.1.1.tgz", 1629 | "integrity": "sha512-emNzr1s7ruq4N+1993yht631/JH+jaj0NYBosuKmLcq+JkGQ9MmTw1RB1fGaTCzUuseRIClrlSLHRNYGwWQ58Q==", 1630 | "requires": { 1631 | "readable-stream": "^3.0.0" 1632 | } 1633 | }, 1634 | "sprintf-js": { 1635 | "version": "1.0.3", 1636 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1637 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1638 | "dev": true 1639 | }, 1640 | "string-argv": { 1641 | "version": "0.3.1", 1642 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 1643 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 1644 | "dev": true 1645 | }, 1646 | "string-width": { 1647 | "version": "4.2.0", 1648 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1649 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1650 | "requires": { 1651 | "emoji-regex": "^8.0.0", 1652 | "is-fullwidth-code-point": "^3.0.0", 1653 | "strip-ansi": "^6.0.0" 1654 | } 1655 | }, 1656 | "string_decoder": { 1657 | "version": "1.3.0", 1658 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1659 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1660 | "requires": { 1661 | "safe-buffer": "~5.2.0" 1662 | } 1663 | }, 1664 | "stringify-object": { 1665 | "version": "3.3.0", 1666 | "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz", 1667 | "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==", 1668 | "dev": true, 1669 | "requires": { 1670 | "get-own-enumerable-property-symbols": "^3.0.0", 1671 | "is-obj": "^1.0.1", 1672 | "is-regexp": "^1.0.0" 1673 | } 1674 | }, 1675 | "strip-ansi": { 1676 | "version": "6.0.0", 1677 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1678 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1679 | "requires": { 1680 | "ansi-regex": "^5.0.0" 1681 | } 1682 | }, 1683 | "strip-final-newline": { 1684 | "version": "2.0.0", 1685 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 1686 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 1687 | "dev": true 1688 | }, 1689 | "strip-json-comments": { 1690 | "version": "3.1.0", 1691 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.0.tgz", 1692 | "integrity": "sha512-e6/d0eBu7gHtdCqFt0xJr642LdToM5/cN4Qb9DbHjVx1CP5RyeM+zH7pbecEmDv/lBqb0QH+6Uqq75rxFPkM0w==" 1693 | }, 1694 | "supports-color": { 1695 | "version": "7.1.0", 1696 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1697 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1698 | "requires": { 1699 | "has-flag": "^4.0.0" 1700 | } 1701 | }, 1702 | "table": { 1703 | "version": "5.4.6", 1704 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 1705 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1706 | "dev": true, 1707 | "requires": { 1708 | "ajv": "^6.10.2", 1709 | "lodash": "^4.17.14", 1710 | "slice-ansi": "^2.1.0", 1711 | "string-width": "^3.0.0" 1712 | }, 1713 | "dependencies": { 1714 | "ansi-regex": { 1715 | "version": "4.1.0", 1716 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1717 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1718 | "dev": true 1719 | }, 1720 | "ansi-styles": { 1721 | "version": "3.2.1", 1722 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1723 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1724 | "dev": true, 1725 | "requires": { 1726 | "color-convert": "^1.9.0" 1727 | } 1728 | }, 1729 | "astral-regex": { 1730 | "version": "1.0.0", 1731 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 1732 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 1733 | "dev": true 1734 | }, 1735 | "color-convert": { 1736 | "version": "1.9.3", 1737 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1738 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1739 | "dev": true, 1740 | "requires": { 1741 | "color-name": "1.1.3" 1742 | } 1743 | }, 1744 | "color-name": { 1745 | "version": "1.1.3", 1746 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1747 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 1748 | "dev": true 1749 | }, 1750 | "emoji-regex": { 1751 | "version": "7.0.3", 1752 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 1753 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 1754 | "dev": true 1755 | }, 1756 | "is-fullwidth-code-point": { 1757 | "version": "2.0.0", 1758 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1759 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1760 | "dev": true 1761 | }, 1762 | "slice-ansi": { 1763 | "version": "2.1.0", 1764 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1765 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1766 | "dev": true, 1767 | "requires": { 1768 | "ansi-styles": "^3.2.0", 1769 | "astral-regex": "^1.0.0", 1770 | "is-fullwidth-code-point": "^2.0.0" 1771 | } 1772 | }, 1773 | "string-width": { 1774 | "version": "3.1.0", 1775 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1776 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1777 | "dev": true, 1778 | "requires": { 1779 | "emoji-regex": "^7.0.1", 1780 | "is-fullwidth-code-point": "^2.0.0", 1781 | "strip-ansi": "^5.1.0" 1782 | } 1783 | }, 1784 | "strip-ansi": { 1785 | "version": "5.2.0", 1786 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1787 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1788 | "dev": true, 1789 | "requires": { 1790 | "ansi-regex": "^4.1.0" 1791 | } 1792 | } 1793 | } 1794 | }, 1795 | "text-table": { 1796 | "version": "0.2.0", 1797 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1798 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1799 | "dev": true 1800 | }, 1801 | "through": { 1802 | "version": "2.3.8", 1803 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1804 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1805 | "dev": true 1806 | }, 1807 | "tmp": { 1808 | "version": "0.0.33", 1809 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1810 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1811 | "dev": true, 1812 | "requires": { 1813 | "os-tmpdir": "~1.0.2" 1814 | } 1815 | }, 1816 | "to-regex-range": { 1817 | "version": "5.0.1", 1818 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1819 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1820 | "dev": true, 1821 | "requires": { 1822 | "is-number": "^7.0.0" 1823 | } 1824 | }, 1825 | "tslib": { 1826 | "version": "1.13.0", 1827 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.13.0.tgz", 1828 | "integrity": "sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q==", 1829 | "dev": true 1830 | }, 1831 | "type-check": { 1832 | "version": "0.4.0", 1833 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1834 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1835 | "dev": true, 1836 | "requires": { 1837 | "prelude-ls": "^1.2.1" 1838 | } 1839 | }, 1840 | "type-fest": { 1841 | "version": "0.11.0", 1842 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 1843 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 1844 | "dev": true 1845 | }, 1846 | "uri-js": { 1847 | "version": "4.2.2", 1848 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1849 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1850 | "dev": true, 1851 | "requires": { 1852 | "punycode": "^2.1.0" 1853 | } 1854 | }, 1855 | "util-deprecate": { 1856 | "version": "1.0.2", 1857 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1858 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1859 | }, 1860 | "v8-compile-cache": { 1861 | "version": "2.1.1", 1862 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 1863 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 1864 | "dev": true 1865 | }, 1866 | "which": { 1867 | "version": "2.0.2", 1868 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1869 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1870 | "dev": true, 1871 | "requires": { 1872 | "isexe": "^2.0.0" 1873 | } 1874 | }, 1875 | "which-module": { 1876 | "version": "2.0.0", 1877 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1878 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" 1879 | }, 1880 | "which-pm-runs": { 1881 | "version": "1.0.0", 1882 | "resolved": "https://registry.npmjs.org/which-pm-runs/-/which-pm-runs-1.0.0.tgz", 1883 | "integrity": "sha1-Zws6+8VS4LVd9rd4DKdGFfI60cs=", 1884 | "dev": true 1885 | }, 1886 | "word-wrap": { 1887 | "version": "1.2.3", 1888 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1889 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1890 | "dev": true 1891 | }, 1892 | "wrap-ansi": { 1893 | "version": "6.2.0", 1894 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 1895 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 1896 | "requires": { 1897 | "ansi-styles": "^4.0.0", 1898 | "string-width": "^4.1.0", 1899 | "strip-ansi": "^6.0.0" 1900 | } 1901 | }, 1902 | "wrappy": { 1903 | "version": "1.0.2", 1904 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1905 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1906 | }, 1907 | "write": { 1908 | "version": "1.0.3", 1909 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 1910 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 1911 | "dev": true, 1912 | "requires": { 1913 | "mkdirp": "^0.5.1" 1914 | } 1915 | }, 1916 | "y18n": { 1917 | "version": "4.0.1", 1918 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.1.tgz", 1919 | "integrity": "sha512-wNcy4NvjMYL8gogWWYAO7ZFWFfHcbdbE57tZO8e4cbpj8tfUcwrwqSl3ad8HxpYWCdXcJUCeKKZS62Av1affwQ==" 1920 | }, 1921 | "yaml": { 1922 | "version": "1.10.0", 1923 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.0.tgz", 1924 | "integrity": "sha512-yr2icI4glYaNG+KWONODapy2/jDdMSDnrONSjblABjD9B4Z5LgiircSt8m8sRZFNi08kG9Sm0uSHtEmP3zaEGg==", 1925 | "dev": true 1926 | }, 1927 | "yargs": { 1928 | "version": "15.3.1", 1929 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.3.1.tgz", 1930 | "integrity": "sha512-92O1HWEjw27sBfgmXiixJWT5hRBp2eobqXicLtPBIDBhYB+1HpwZlXmbW2luivBJHBzki+7VyCLRtAkScbTBQA==", 1931 | "requires": { 1932 | "cliui": "^6.0.0", 1933 | "decamelize": "^1.2.0", 1934 | "find-up": "^4.1.0", 1935 | "get-caller-file": "^2.0.1", 1936 | "require-directory": "^2.1.1", 1937 | "require-main-filename": "^2.0.0", 1938 | "set-blocking": "^2.0.0", 1939 | "string-width": "^4.2.0", 1940 | "which-module": "^2.0.0", 1941 | "y18n": "^4.0.0", 1942 | "yargs-parser": "^18.1.1" 1943 | } 1944 | }, 1945 | "yargs-parser": { 1946 | "version": "18.1.3", 1947 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", 1948 | "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", 1949 | "requires": { 1950 | "camelcase": "^5.0.0", 1951 | "decamelize": "^1.2.0" 1952 | } 1953 | } 1954 | } 1955 | } 1956 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "cross-seedarr", 3 | "version": "1.0.0", 4 | "description": "Cross seeding helper for radarr & sonarr.", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "node index.js" 8 | }, 9 | "repository": { 10 | "type": "git", 11 | "url": "git+https://github.com/boban-bmw/cross-seedarr.git" 12 | }, 13 | "keywords": [ 14 | "radarr", 15 | "sonarr", 16 | "cross-seeding" 17 | ], 18 | "author": "Boban BMW", 19 | "license": "MIT", 20 | "bugs": { 21 | "url": "https://github.com/boban-bmw/cross-seedarr/issues" 22 | }, 23 | "homepage": "https://github.com/boban-bmw/cross-seedarr#readme", 24 | "devDependencies": { 25 | "eslint": "^7.2.0", 26 | "eslint-config-prettier": "^6.11.0", 27 | "eslint-plugin-prettier": "^3.1.3", 28 | "husky": "^4.2.5", 29 | "lint-staged": "^10.2.10", 30 | "prettier": "^2.0.5" 31 | }, 32 | "husky": { 33 | "hooks": { 34 | "pre-commit": "lint-staged" 35 | } 36 | }, 37 | "lint-staged": { 38 | "*.{js,md}": "prettier --write", 39 | "*.js": "eslint" 40 | }, 41 | "dependencies": { 42 | "axios": "^0.21.1", 43 | "moment": "^2.26.0", 44 | "pino": "^6.3.2", 45 | "pino-pretty": "^4.0.0", 46 | "yargs": "^15.3.1" 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /radarr.js: -------------------------------------------------------------------------------- 1 | const { radarr } = require("./config"); 2 | const { 3 | delay, 4 | logger, 5 | mkdir, 6 | deleteEmptyFiles, 7 | eligibleRelease, 8 | validIndexers, 9 | recentlyDownloaded, 10 | } = require("./util"); 11 | const makeClient = require("./client"); 12 | const downloadRelease = require("./download"); 13 | 14 | async function getMovieReleases(radarrApi, movie) { 15 | const movieName = `${movie.title} (${movie.year})`; 16 | let releases = []; 17 | 18 | try { 19 | const { movieFile } = movie; 20 | 21 | logger.info(`Searching for ${movieName}...`); 22 | 23 | const searchResults = ( 24 | await radarrApi.get(`/release?movieId=${movie.id}`) 25 | ).data.filter((result) => result.protocol === "torrent"); 26 | 27 | releases = searchResults 28 | .filter(eligibleRelease(movieFile.size, radarr.threshold)) 29 | .filter(validIndexers(radarr.ignoredIndexers)); 30 | 31 | logger.info( 32 | `Found ${searchResults.length} result(s) - Eligible: ${releases.length}` 33 | ); 34 | } catch (e) { 35 | logger.error( 36 | e, 37 | `An error occurred while searching for ${movieName}, skipping...` 38 | ); 39 | } 40 | 41 | return releases; 42 | } 43 | 44 | module.exports = async function radarrFlow() { 45 | if (!radarr || !radarr.url || !radarr.apiKey) { 46 | logger.warn("radarr config unset, skipping..."); 47 | return; 48 | } 49 | 50 | mkdir(radarr.torrentDir); 51 | 52 | const radarrApi = makeClient(radarr); 53 | 54 | try { 55 | logger.info("Fetching movies..."); 56 | 57 | const { data: allMovies } = await radarrApi.get("/movie"); 58 | 59 | const movies = allMovies 60 | .filter((movie) => movie.monitored && movie.downloaded && movie.hasFile) 61 | .filter((movie) => recentlyDownloaded(movie.movieFile)); 62 | 63 | logger.info( 64 | `Fetching movies complete - Eligible movies found: ${movies.length}` 65 | ); 66 | 67 | let counter = 0; 68 | 69 | for (const movie of movies) { 70 | const releases = await getMovieReleases(radarrApi, movie); 71 | 72 | for (const release of releases) { 73 | try { 74 | await downloadRelease(radarr.torrentDir, release); 75 | } catch (e) { 76 | logger.error( 77 | e, 78 | `An error occurred while saving ${release.title} from ${release.indexer}` 79 | ); 80 | } 81 | } 82 | 83 | counter += 1; 84 | 85 | logger.info( 86 | `Progress: ${((counter / movies.length) * 100).toFixed( 87 | 2 88 | )}% (${counter}/${movies.length})` 89 | ); 90 | 91 | await delay(); 92 | } 93 | 94 | deleteEmptyFiles(radarr.torrentDir); 95 | } catch (e) { 96 | logger.error(e, "An error occurred while processing movies"); 97 | } 98 | }; 99 | -------------------------------------------------------------------------------- /sonarr.js: -------------------------------------------------------------------------------- 1 | const { sonarr } = require("./config"); 2 | const { 3 | delay, 4 | logger, 5 | mkdir, 6 | deleteEmptyFiles, 7 | eligibleRelease, 8 | validIndexers, 9 | recentlyDownloaded, 10 | } = require("./util"); 11 | const makeClient = require("./client"); 12 | const downloadRelease = require("./download"); 13 | 14 | async function getSeasonReleases(sonarrApi, show, season) { 15 | const seasonName = `${show.title} (${show.year}) S${ 16 | season.seasonNumber < 10 ? 0 : "" 17 | }${season.seasonNumber}`; 18 | 19 | let releases = []; 20 | 21 | try { 22 | logger.info(`Searching for ${seasonName}...`); 23 | 24 | const searchResults = ( 25 | await sonarrApi.get( 26 | `/release?seriesId=${show.id}&seasonNumber=${season.seasonNumber}` 27 | ) 28 | ).data.filter((result) => result.protocol === "torrent"); 29 | 30 | releases = searchResults 31 | .filter(eligibleRelease(season.statistics.sizeOnDisk, sonarr.threshold)) 32 | .filter(validIndexers(sonarr.ignoredIndexers)); 33 | 34 | if (show.seasons.length > 1 && season.seasonNumber === 1) { 35 | const completeShowSize = show.seasons.reduce( 36 | (prev, next) => prev + next.statistics.sizeOnDisk, 37 | 0 38 | ); 39 | 40 | const completePacks = searchResults 41 | .filter(eligibleRelease(completeShowSize, sonarr.threshold)) 42 | .filter(validIndexers(sonarr.ignoredIndexers)); 43 | 44 | releases.push(...completePacks); 45 | } 46 | 47 | logger.info( 48 | `Found ${searchResults.length} results(s) - Eligible: ${releases.length}` 49 | ); 50 | } catch (e) { 51 | logger.error( 52 | e, 53 | `An error occurred while searching for ${seasonName}, skipping...` 54 | ); 55 | } 56 | 57 | return releases; 58 | } 59 | 60 | module.exports = async function sonarrFlow() { 61 | if (!sonarr || !sonarr.url || !sonarr.apiKey) { 62 | logger.warn("sonarr config unset, skipping..."); 63 | return; 64 | } 65 | 66 | mkdir(sonarr.torrentDir); 67 | 68 | const sonarrApi = makeClient(sonarr, true); 69 | 70 | try { 71 | logger.info("Fetching series..."); 72 | 73 | const { data: allSeries } = await sonarrApi.get("/series"); 74 | 75 | const series = allSeries.filter( 76 | (series) => series.statistics.episodeFileCount > 0 77 | ); 78 | 79 | logger.info("Fetching series complete - processing episodes..."); 80 | 81 | let counter = 0; 82 | 83 | for (const show of series) { 84 | const { data: allEpisodeFiles } = await sonarrApi.get( 85 | `/episodeFile?seriesId=${show.id}` 86 | ); 87 | 88 | for (const season of show.seasons) { 89 | const relevantEpisodes = allEpisodeFiles 90 | .filter((episode) => episode.seasonNumber === season.seasonNumber) 91 | .filter(recentlyDownloaded); 92 | 93 | if ( 94 | season.monitored && 95 | season.statistics.percentOfEpisodes === 100 && 96 | relevantEpisodes.length > 0 97 | ) { 98 | const releases = await getSeasonReleases(sonarrApi, show, season); 99 | 100 | for (const release of releases) { 101 | try { 102 | await downloadRelease(sonarr.torrentDir, release); 103 | } catch (e) { 104 | logger.error( 105 | e, 106 | `An error occurred while saving ${release.title} from ${release.indexer}` 107 | ); 108 | } 109 | } 110 | 111 | await delay(); 112 | } 113 | } 114 | 115 | counter += 1; 116 | 117 | logger.info( 118 | `Progress: ${((counter / series.length) * 100).toFixed( 119 | 2 120 | )}% (${counter}/${series.length})` 121 | ); 122 | } 123 | 124 | deleteEmptyFiles(sonarr.torrentDir); 125 | } catch (e) { 126 | logger.error(e, "An error occurred while processing series"); 127 | } 128 | }; 129 | -------------------------------------------------------------------------------- /util.js: -------------------------------------------------------------------------------- 1 | const fs = require("fs"); 2 | const path = require("path"); 3 | const { argv } = require("yargs"); 4 | const logger = require("pino")({ 5 | prettyPrint: !argv.verbose, 6 | }); 7 | const moment = require("moment"); 8 | 9 | const { timeout } = require("./config"); 10 | 11 | const now = moment(); 12 | 13 | module.exports = { 14 | delay() { 15 | return new Promise((resolve) => { 16 | logger.info(`Waiting ${timeout} seconds...`); 17 | 18 | setTimeout(() => { 19 | resolve(); 20 | }, timeout * 1000); 21 | }); 22 | }, 23 | logger, 24 | mkdir(dir) { 25 | if (!fs.existsSync(dir)) { 26 | fs.mkdirSync(dir); 27 | } 28 | }, 29 | deleteEmptyFiles(dir) { 30 | const fileNames = fs.readdirSync(dir); 31 | 32 | for (const fileName of fileNames) { 33 | const filePath = path.join(dir, fileName); 34 | const file = fs.statSync(filePath); 35 | 36 | if (!file.isDirectory() && file.size === 0) { 37 | fs.unlinkSync(filePath); 38 | 39 | logger.info(`Deleted invalid file ${filePath}`); 40 | } 41 | } 42 | }, 43 | eligibleRelease(size, threshold) { 44 | return (release) => { 45 | const sizeDifference = Math.abs(size - release.size); 46 | const sizeDifferencePercentage = sizeDifference / size; 47 | 48 | return sizeDifferencePercentage < threshold / 100; 49 | }; 50 | }, 51 | validIndexers(ignoredIndexers) { 52 | return (release) => ignoredIndexers.indexOf(release.indexer) === -1; 53 | }, 54 | recentlyDownloaded(item) { 55 | if (!argv.recent) { 56 | return true; 57 | } 58 | 59 | return now.diff(moment(item.dateAdded), "day") <= argv.recent; 60 | }, 61 | }; 62 | --------------------------------------------------------------------------------