├── .gitignore ├── .prettierrc ├── LICENSE ├── README.md ├── bin └── ghi.js ├── package-lock.json ├── package.json ├── src ├── Config.ts ├── app.ts ├── commands │ ├── doctor.ts │ ├── list.ts │ └── login.ts ├── flags.ts ├── queries │ ├── aboutMe.graphql │ └── issues.graphql └── utils │ ├── getSavedQueries.ts │ ├── graphql.ts │ └── showSpinnerWhileProcessing.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | 8 | # Runtime data 9 | pids 10 | *.pid 11 | *.seed 12 | *.pid.lock 13 | 14 | # Directory for instrumented libs generated by jscoverage/JSCover 15 | lib-cov 16 | 17 | # Coverage directory used by tools like istanbul 18 | coverage 19 | 20 | # nyc test coverage 21 | .nyc_output 22 | 23 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 24 | .grunt 25 | 26 | # Bower dependency directory (https://bower.io/) 27 | bower_components 28 | 29 | # node-waf configuration 30 | .lock-wscript 31 | 32 | # Compiled binary addons (https://nodejs.org/api/addons.html) 33 | build/Release 34 | 35 | # Dependency directories 36 | node_modules/ 37 | jspm_packages/ 38 | 39 | # TypeScript v1 declaration files 40 | typings/ 41 | 42 | # Optional npm cache directory 43 | .npm 44 | 45 | # Optional eslint cache 46 | .eslintcache 47 | 48 | # Optional REPL history 49 | .node_repl_history 50 | 51 | # Output of 'npm pack' 52 | *.tgz 53 | 54 | # Yarn Integrity file 55 | .yarn-integrity 56 | 57 | # dotenv environment variables file 58 | .env 59 | 60 | # next.js build output 61 | .next 62 | dist 63 | tsconfig.tsbuildinfo 64 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "semi": false, 3 | "trailingComma": "es5" 4 | } 5 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 Shingo Inoue 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 | # `ghi` - github-issue-cli 2 | 3 | ![](https://user-images.githubusercontent.com/1424963/69118167-bfc6a580-0ad5-11ea-989d-ad7ea13631a4.gif) 4 | 5 | github-issue-cli(`ghi`) is CLI application to search for your good first issue. 6 | This tool looks for issues that no one is working on. 7 | 8 | Note: This tool is under development so if you use it, please be careful. 9 | 10 | ## Getting started 11 | 12 | At first, please install `github-issue-cli` globally 13 | 14 | ``` 15 | npm i -g github-issue-cli 16 | ``` 17 | 18 | Next, You will need to run a `login` subcommand to use ghi. 19 | (After installing github-issue-cli, you will be able to use `ghi` command.) 20 | 21 | ``` 22 | ghi login 23 | ``` 24 | 25 | The token you entered will be stored in `~/.ghirc`. 26 | 27 | ## Basic usage 28 | 29 | You can list issues with `good first issue` label by using following command: 30 | 31 | ``` 32 | ghi list [org]/[repo] 33 | ``` 34 | 35 | For example, the following command will list `good first issue` in `microsoft/TypeScript` that no one is working on. 36 | 37 | ``` 38 | ghi list microsoft/TypeScript 39 | ``` 40 | 41 | ## Advanced topics 42 | 43 | ### Saved queries 44 | 45 | If you want to search for issues with label other than `good first issue`, you can use saved queries. 46 | Currently, in order to add or change a saved query, edit the `~/.ghirc` directly. 47 | 48 | `.ghirc` is a JSON file. When you execute the login command, it will be automatically generated with the following keys. 49 | 50 | ```json 51 | { 52 | "token": "xxx", 53 | "login": "yyy" 54 | } 55 | ``` 56 | 57 | To register a custom query, add a `queries` field like this: 58 | 59 | ```diff 60 | { 61 | "token": "xxx", 62 | "login": "yyy" 63 | + "queries": { 64 | + "*/*": { 65 | + "for all repository": "label:Bug" 66 | + }, 67 | + "Leko/*": { 68 | + "for specified owner/org repositories": "no:assignee -label:bug" 69 | + }, 70 | + "microsoft/TypeScript": { 71 | + "for specified repository": "label:\"good first issue\" label:\"help wanted\" -label:\"In Discussion\" label:\"Experience Enhancement\"" 72 | + } 73 | + } 74 | } 75 | ``` 76 | 77 | Specify the repository name directly under the `queries` field. You can also specify wildcards using an asterisk (`*`). 78 | When executing the `list` command, if there are multiple queries that match the repository specified in its argument, select which query to execute. 79 | 80 | ## Contribution 81 | 82 | 1. Fork this repository 83 | 1. Write your code 84 | 1. Run tests 85 | 1. Create pull request to master branch 86 | 87 | ## Development 88 | 89 | ``` 90 | git clone git@github.com:Leko/github-issue-cli.git 91 | cd github-issue-cli 92 | npm i 93 | 94 | npx ts-node -T src/app.ts 95 | ``` 96 | 97 | ## License 98 | 99 | This package under [MIT](https://opensource.org/licenses/MIT) license. 100 | -------------------------------------------------------------------------------- /bin/ghi.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | const updateNotifier = require("update-notifier") 3 | const pkg = require('../package.json') 4 | 5 | require('../dist/app') 6 | 7 | updateNotifier({ pkg }).notify() 8 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "github-issue-cli", 3 | "version": "0.0.11", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@octokit/endpoint": { 8 | "version": "5.5.1", 9 | "resolved": "https://registry.npmjs.org/@octokit/endpoint/-/endpoint-5.5.1.tgz", 10 | "integrity": "sha512-nBFhRUb5YzVTCX/iAK1MgQ4uWo89Gu0TH00qQHoYRCsE12dWcG1OiLd7v2EIo2+tpUKPMOQ62QFy9hy9Vg2ULg==", 11 | "requires": { 12 | "@octokit/types": "^2.0.0", 13 | "is-plain-object": "^3.0.0", 14 | "universal-user-agent": "^4.0.0" 15 | } 16 | }, 17 | "@octokit/graphql": { 18 | "version": "4.3.1", 19 | "resolved": "https://registry.npmjs.org/@octokit/graphql/-/graphql-4.3.1.tgz", 20 | "integrity": "sha512-hCdTjfvrK+ilU2keAdqNBWOk+gm1kai1ZcdjRfB30oA3/T6n53UVJb7w0L5cR3/rhU91xT3HSqCd+qbvH06yxA==", 21 | "requires": { 22 | "@octokit/request": "^5.3.0", 23 | "@octokit/types": "^2.0.0", 24 | "universal-user-agent": "^4.0.0" 25 | } 26 | }, 27 | "@octokit/request": { 28 | "version": "5.3.1", 29 | "resolved": "https://registry.npmjs.org/@octokit/request/-/request-5.3.1.tgz", 30 | "integrity": "sha512-5/X0AL1ZgoU32fAepTfEoggFinO3rxsMLtzhlUX+RctLrusn/CApJuGFCd0v7GMFhF+8UiCsTTfsu7Fh1HnEJg==", 31 | "requires": { 32 | "@octokit/endpoint": "^5.5.0", 33 | "@octokit/request-error": "^1.0.1", 34 | "@octokit/types": "^2.0.0", 35 | "deprecation": "^2.0.0", 36 | "is-plain-object": "^3.0.0", 37 | "node-fetch": "^2.3.0", 38 | "once": "^1.4.0", 39 | "universal-user-agent": "^4.0.0" 40 | } 41 | }, 42 | "@octokit/request-error": { 43 | "version": "1.2.0", 44 | "resolved": "https://registry.npmjs.org/@octokit/request-error/-/request-error-1.2.0.tgz", 45 | "integrity": "sha512-DNBhROBYjjV/I9n7A8kVkmQNkqFAMem90dSxqvPq57e2hBr7mNTX98y3R2zDpqMQHVRpBDjsvsfIGgBzy+4PAg==", 46 | "requires": { 47 | "@octokit/types": "^2.0.0", 48 | "deprecation": "^2.0.0", 49 | "once": "^1.4.0" 50 | } 51 | }, 52 | "@octokit/types": { 53 | "version": "2.0.1", 54 | "resolved": "https://registry.npmjs.org/@octokit/types/-/types-2.0.1.tgz", 55 | "integrity": "sha512-YDYgV6nCzdGdOm7wy43Ce8SQ3M5DMKegB8E5sTB/1xrxOdo2yS/KgUgML2N2ZGD621mkbdrAglwTyA4NDOlFFA==", 56 | "requires": { 57 | "@types/node": ">= 8" 58 | } 59 | }, 60 | "@sindresorhus/is": { 61 | "version": "0.14.0", 62 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 63 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==" 64 | }, 65 | "@szmarczak/http-timer": { 66 | "version": "1.1.2", 67 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 68 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 69 | "requires": { 70 | "defer-to-connect": "^1.0.1" 71 | } 72 | }, 73 | "@types/braces": { 74 | "version": "3.0.0", 75 | "resolved": "https://registry.npmjs.org/@types/braces/-/braces-3.0.0.tgz", 76 | "integrity": "sha512-TbH79tcyi9FHwbyboOKeRachRq63mSuWYXOflsNO9ZyE5ClQ/JaozNKl+aWUq87qPNsXasXxi2AbgfwIJ+8GQw==", 77 | "dev": true 78 | }, 79 | "@types/color-name": { 80 | "version": "1.1.1", 81 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 82 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==" 83 | }, 84 | "@types/inquirer": { 85 | "version": "6.5.0", 86 | "resolved": "https://registry.npmjs.org/@types/inquirer/-/inquirer-6.5.0.tgz", 87 | "integrity": "sha512-rjaYQ9b9y/VFGOpqBEXRavc3jh0a+e6evAbI31tMda8VlPaSy0AZJfXsvmIe3wklc7W6C3zCSfleuMXR7NOyXw==", 88 | "dev": true, 89 | "requires": { 90 | "@types/through": "*", 91 | "rxjs": "^6.4.0" 92 | } 93 | }, 94 | "@types/micromatch": { 95 | "version": "3.1.1", 96 | "resolved": "https://registry.npmjs.org/@types/micromatch/-/micromatch-3.1.1.tgz", 97 | "integrity": "sha512-Wr5y4uv3r7JP4jEUqv7rZeYiMBGRHcbojDVsl11wq6gw1v/ZZQvJexd9rtvVx3EIVqw8dwtcRjSs8m2DV9qHjQ==", 98 | "dev": true, 99 | "requires": { 100 | "@types/braces": "*" 101 | } 102 | }, 103 | "@types/node": { 104 | "version": "13.13.4", 105 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.4.tgz", 106 | "integrity": "sha512-x26ur3dSXgv5AwKS0lNfbjpCakGIduWU1DU91Zz58ONRWrIKGunmZBNv4P7N+e27sJkiGDsw/3fT4AtsqQBrBA==" 107 | }, 108 | "@types/node-emoji": { 109 | "version": "1.8.1", 110 | "resolved": "https://registry.npmjs.org/@types/node-emoji/-/node-emoji-1.8.1.tgz", 111 | "integrity": "sha512-0fRfA90FWm6KJfw6P9QGyo0HDTCmthZ7cWaBQndITlaWLTZ6njRyKwrwpzpg+n6kBXBIGKeUHEQuBx7bphGJkA==", 112 | "dev": true 113 | }, 114 | "@types/through": { 115 | "version": "0.0.29", 116 | "resolved": "https://registry.npmjs.org/@types/through/-/through-0.0.29.tgz", 117 | "integrity": "sha512-9a7C5VHh+1BKblaYiq+7Tfc+EOmjMdZaD1MYtkQjSoxgB69tBjW98ry6SKsi4zEIWztLOMRuL87A3bdT/Fc/4w==", 118 | "dev": true, 119 | "requires": { 120 | "@types/node": "*" 121 | } 122 | }, 123 | "@types/update-notifier": { 124 | "version": "2.5.0", 125 | "resolved": "https://registry.npmjs.org/@types/update-notifier/-/update-notifier-2.5.0.tgz", 126 | "integrity": "sha512-YV+ZcSIiv30GhLM7WwxI+bsbcW34d3Yhl2JSFBNFL6qtfsoI9++hogxz+jTqeS86ynKcMUE0AsnLWQynfJnsfA==", 127 | "dev": true 128 | }, 129 | "@types/yargs": { 130 | "version": "13.0.3", 131 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-13.0.3.tgz", 132 | "integrity": "sha512-K8/LfZq2duW33XW/tFwEAfnZlqIfVsoyRB3kfXdPXYhl0nfM8mmh7GS0jg7WrX2Dgq/0Ha/pR1PaR+BvmWwjiQ==", 133 | "dev": true, 134 | "requires": { 135 | "@types/yargs-parser": "*" 136 | } 137 | }, 138 | "@types/yargs-parser": { 139 | "version": "13.1.0", 140 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-13.1.0.tgz", 141 | "integrity": "sha512-gCubfBUZ6KxzoibJ+SCUc/57Ms1jz5NjHe4+dI2krNmU5zCPAphyLJYyTOg06ueIyfj+SaCUqmzun7ImlxDcKg==", 142 | "dev": true 143 | }, 144 | "ansi-align": { 145 | "version": "3.0.0", 146 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.0.tgz", 147 | "integrity": "sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw==", 148 | "requires": { 149 | "string-width": "^3.0.0" 150 | } 151 | }, 152 | "ansi-escapes": { 153 | "version": "4.3.0", 154 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.0.tgz", 155 | "integrity": "sha512-EiYhwo0v255HUL6eDyuLrXEkTi7WwVCLAw+SeOQ7M7qdun1z1pum4DEm/nuqIVbPvi9RPPc9k9LbyBv6H0DwVg==", 156 | "requires": { 157 | "type-fest": "^0.8.1" 158 | } 159 | }, 160 | "ansi-regex": { 161 | "version": "4.1.0", 162 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 163 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" 164 | }, 165 | "ansi-styles": { 166 | "version": "3.2.1", 167 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 168 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 169 | "requires": { 170 | "color-convert": "^1.9.0" 171 | } 172 | }, 173 | "arg": { 174 | "version": "4.1.1", 175 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.1.tgz", 176 | "integrity": "sha512-SlmP3fEA88MBv0PypnXZ8ZfJhwmDeIE3SP71j37AiXQBXYosPV0x6uISAaHYSlSVhmHOVkomen0tbGk6Anlebw==", 177 | "dev": true 178 | }, 179 | "boxen": { 180 | "version": "4.2.0", 181 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz", 182 | "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==", 183 | "requires": { 184 | "ansi-align": "^3.0.0", 185 | "camelcase": "^5.3.1", 186 | "chalk": "^3.0.0", 187 | "cli-boxes": "^2.2.0", 188 | "string-width": "^4.1.0", 189 | "term-size": "^2.1.0", 190 | "type-fest": "^0.8.1", 191 | "widest-line": "^3.1.0" 192 | }, 193 | "dependencies": { 194 | "ansi-regex": { 195 | "version": "5.0.0", 196 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 197 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" 198 | }, 199 | "emoji-regex": { 200 | "version": "8.0.0", 201 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 202 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 203 | }, 204 | "is-fullwidth-code-point": { 205 | "version": "3.0.0", 206 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 207 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 208 | }, 209 | "string-width": { 210 | "version": "4.2.0", 211 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 212 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 213 | "requires": { 214 | "emoji-regex": "^8.0.0", 215 | "is-fullwidth-code-point": "^3.0.0", 216 | "strip-ansi": "^6.0.0" 217 | } 218 | }, 219 | "strip-ansi": { 220 | "version": "6.0.0", 221 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 222 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 223 | "requires": { 224 | "ansi-regex": "^5.0.0" 225 | } 226 | } 227 | } 228 | }, 229 | "braces": { 230 | "version": "3.0.2", 231 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 232 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 233 | "requires": { 234 | "fill-range": "^7.0.1" 235 | } 236 | }, 237 | "buffer-from": { 238 | "version": "1.1.1", 239 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 240 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 241 | "dev": true 242 | }, 243 | "cacheable-request": { 244 | "version": "6.1.0", 245 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 246 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 247 | "requires": { 248 | "clone-response": "^1.0.2", 249 | "get-stream": "^5.1.0", 250 | "http-cache-semantics": "^4.0.0", 251 | "keyv": "^3.0.0", 252 | "lowercase-keys": "^2.0.0", 253 | "normalize-url": "^4.1.0", 254 | "responselike": "^1.0.2" 255 | }, 256 | "dependencies": { 257 | "get-stream": { 258 | "version": "5.1.0", 259 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.1.0.tgz", 260 | "integrity": "sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw==", 261 | "requires": { 262 | "pump": "^3.0.0" 263 | } 264 | }, 265 | "lowercase-keys": { 266 | "version": "2.0.0", 267 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 268 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==" 269 | } 270 | } 271 | }, 272 | "camelcase": { 273 | "version": "5.3.1", 274 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 275 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" 276 | }, 277 | "chalk": { 278 | "version": "3.0.0", 279 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 280 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 281 | "requires": { 282 | "ansi-styles": "^4.1.0", 283 | "supports-color": "^7.1.0" 284 | }, 285 | "dependencies": { 286 | "ansi-styles": { 287 | "version": "4.2.0", 288 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.0.tgz", 289 | "integrity": "sha512-7kFQgnEaMdRtwf6uSfUnVr9gSGC7faurn+J/Mv90/W+iTtN0405/nLdopfMWwchyxhbGYl6TC4Sccn9TUkGAgg==", 290 | "requires": { 291 | "@types/color-name": "^1.1.1", 292 | "color-convert": "^2.0.1" 293 | } 294 | }, 295 | "color-convert": { 296 | "version": "2.0.1", 297 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 298 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 299 | "requires": { 300 | "color-name": "~1.1.4" 301 | } 302 | }, 303 | "color-name": { 304 | "version": "1.1.4", 305 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 306 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 307 | } 308 | } 309 | }, 310 | "chardet": { 311 | "version": "0.7.0", 312 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 313 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==" 314 | }, 315 | "chromatism": { 316 | "version": "3.0.0", 317 | "resolved": "https://registry.npmjs.org/chromatism/-/chromatism-3.0.0.tgz", 318 | "integrity": "sha1-pySdNTweTzV35ESsQRccTi5iSxI=" 319 | }, 320 | "ci-info": { 321 | "version": "2.0.0", 322 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 323 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" 324 | }, 325 | "cli-boxes": { 326 | "version": "2.2.0", 327 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.0.tgz", 328 | "integrity": "sha512-gpaBrMAizVEANOpfZp/EEUixTXDyGt7DFzdK5hU+UbWt/J0lB0w20ncZj59Z9a93xHb9u12zF5BS6i9RKbtg4w==" 329 | }, 330 | "cli-cursor": { 331 | "version": "3.1.0", 332 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 333 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 334 | "requires": { 335 | "restore-cursor": "^3.1.0" 336 | } 337 | }, 338 | "cli-width": { 339 | "version": "2.2.0", 340 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 341 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=" 342 | }, 343 | "cliui": { 344 | "version": "5.0.0", 345 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 346 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 347 | "requires": { 348 | "string-width": "^3.1.0", 349 | "strip-ansi": "^5.2.0", 350 | "wrap-ansi": "^5.1.0" 351 | } 352 | }, 353 | "clone-response": { 354 | "version": "1.0.2", 355 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 356 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 357 | "requires": { 358 | "mimic-response": "^1.0.0" 359 | } 360 | }, 361 | "color-convert": { 362 | "version": "1.9.3", 363 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 364 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 365 | "requires": { 366 | "color-name": "1.1.3" 367 | } 368 | }, 369 | "color-name": { 370 | "version": "1.1.3", 371 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 372 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 373 | }, 374 | "configstore": { 375 | "version": "5.0.0", 376 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.0.tgz", 377 | "integrity": "sha512-eE/hvMs7qw7DlcB5JPRnthmrITuHMmACUJAp89v6PT6iOqzoLS7HRWhBtuHMlhNHo2AhUSA/3Dh1bKNJHcublQ==", 378 | "requires": { 379 | "dot-prop": "^5.1.0", 380 | "graceful-fs": "^4.1.2", 381 | "make-dir": "^3.0.0", 382 | "unique-string": "^2.0.0", 383 | "write-file-atomic": "^3.0.0", 384 | "xdg-basedir": "^4.0.0" 385 | } 386 | }, 387 | "cross-spawn": { 388 | "version": "6.0.5", 389 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 390 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 391 | "requires": { 392 | "nice-try": "^1.0.4", 393 | "path-key": "^2.0.1", 394 | "semver": "^5.5.0", 395 | "shebang-command": "^1.2.0", 396 | "which": "^1.2.9" 397 | } 398 | }, 399 | "crypto-random-string": { 400 | "version": "2.0.0", 401 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 402 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==" 403 | }, 404 | "decamelize": { 405 | "version": "1.2.0", 406 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 407 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 408 | }, 409 | "decompress-response": { 410 | "version": "3.3.0", 411 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 412 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 413 | "requires": { 414 | "mimic-response": "^1.0.0" 415 | } 416 | }, 417 | "deep-extend": { 418 | "version": "0.6.0", 419 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 420 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 421 | }, 422 | "defer-to-connect": { 423 | "version": "1.1.1", 424 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.1.tgz", 425 | "integrity": "sha512-J7thop4u3mRTkYRQ+Vpfwy2G5Ehoy82I14+14W4YMDLKdWloI9gSzRbV30s/NckQGVJtPkWNcW4oMAUigTdqiQ==" 426 | }, 427 | "deprecation": { 428 | "version": "2.3.1", 429 | "resolved": "https://registry.npmjs.org/deprecation/-/deprecation-2.3.1.tgz", 430 | "integrity": "sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ==" 431 | }, 432 | "diff": { 433 | "version": "4.0.1", 434 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.1.tgz", 435 | "integrity": "sha512-s2+XdvhPCOF01LRQBC8hf4vhbVmI2CGS5aZnxLJlT5FtdhPCDFq80q++zK2KlrVorVDdL5BOGZ/VfLrVtYNF+Q==", 436 | "dev": true 437 | }, 438 | "dot-prop": { 439 | "version": "5.2.0", 440 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.2.0.tgz", 441 | "integrity": "sha512-uEUyaDKoSQ1M4Oq8l45hSE26SnTxL6snNnqvK/VWx5wJhmff5z0FUVJDKDanor/6w3kzE3i7XZOk+7wC0EXr1A==", 442 | "requires": { 443 | "is-obj": "^2.0.0" 444 | } 445 | }, 446 | "duplexer3": { 447 | "version": "0.1.4", 448 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 449 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=" 450 | }, 451 | "elegant-spinner": { 452 | "version": "2.0.0", 453 | "resolved": "https://registry.npmjs.org/elegant-spinner/-/elegant-spinner-2.0.0.tgz", 454 | "integrity": "sha512-5YRYHhvhYzV/FC4AiMdeSIg3jAYGq9xFvbhZMpPlJoBsfYgrw2DSCYeXfat6tYBu45PWiyRr3+flaCPPmviPaA==" 455 | }, 456 | "emoji-regex": { 457 | "version": "7.0.3", 458 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 459 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 460 | }, 461 | "end-of-stream": { 462 | "version": "1.4.4", 463 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 464 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 465 | "requires": { 466 | "once": "^1.4.0" 467 | } 468 | }, 469 | "escape-string-regexp": { 470 | "version": "1.0.5", 471 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 472 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 473 | }, 474 | "execa": { 475 | "version": "1.0.0", 476 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", 477 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", 478 | "requires": { 479 | "cross-spawn": "^6.0.0", 480 | "get-stream": "^4.0.0", 481 | "is-stream": "^1.1.0", 482 | "npm-run-path": "^2.0.0", 483 | "p-finally": "^1.0.0", 484 | "signal-exit": "^3.0.0", 485 | "strip-eof": "^1.0.0" 486 | } 487 | }, 488 | "external-editor": { 489 | "version": "3.1.0", 490 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 491 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 492 | "requires": { 493 | "chardet": "^0.7.0", 494 | "iconv-lite": "^0.4.24", 495 | "tmp": "^0.0.33" 496 | } 497 | }, 498 | "figures": { 499 | "version": "3.1.0", 500 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.1.0.tgz", 501 | "integrity": "sha512-ravh8VRXqHuMvZt/d8GblBeqDMkdJMBdv/2KntFH+ra5MXkO7nxNKpzQ3n6QD/2da1kH0aWmNISdvhM7gl2gVg==", 502 | "requires": { 503 | "escape-string-regexp": "^1.0.5" 504 | } 505 | }, 506 | "fill-range": { 507 | "version": "7.0.1", 508 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 509 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 510 | "requires": { 511 | "to-regex-range": "^5.0.1" 512 | } 513 | }, 514 | "find-up": { 515 | "version": "4.1.0", 516 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 517 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 518 | "requires": { 519 | "locate-path": "^5.0.0", 520 | "path-exists": "^4.0.0" 521 | } 522 | }, 523 | "get-caller-file": { 524 | "version": "2.0.5", 525 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 526 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" 527 | }, 528 | "get-stream": { 529 | "version": "4.1.0", 530 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 531 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 532 | "requires": { 533 | "pump": "^3.0.0" 534 | } 535 | }, 536 | "global-dirs": { 537 | "version": "2.0.1", 538 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.0.1.tgz", 539 | "integrity": "sha512-5HqUqdhkEovj2Of/ms3IeS/EekcO54ytHRLV4PEY2rhRwrHXLQjeVEES0Lhka0xwNDtGYn58wyC4s5+MHsOO6A==", 540 | "requires": { 541 | "ini": "^1.3.5" 542 | } 543 | }, 544 | "got": { 545 | "version": "9.6.0", 546 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 547 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 548 | "requires": { 549 | "@sindresorhus/is": "^0.14.0", 550 | "@szmarczak/http-timer": "^1.1.2", 551 | "cacheable-request": "^6.0.0", 552 | "decompress-response": "^3.3.0", 553 | "duplexer3": "^0.1.4", 554 | "get-stream": "^4.1.0", 555 | "lowercase-keys": "^1.0.1", 556 | "mimic-response": "^1.0.1", 557 | "p-cancelable": "^1.0.0", 558 | "to-readable-stream": "^1.0.0", 559 | "url-parse-lax": "^3.0.0" 560 | } 561 | }, 562 | "graceful-fs": { 563 | "version": "4.2.3", 564 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", 565 | "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==" 566 | }, 567 | "has-flag": { 568 | "version": "4.0.0", 569 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 570 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 571 | }, 572 | "has-yarn": { 573 | "version": "2.1.0", 574 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 575 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==" 576 | }, 577 | "http-cache-semantics": { 578 | "version": "4.0.3", 579 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.0.3.tgz", 580 | "integrity": "sha512-TcIMG3qeVLgDr1TEd2XvHaTnMPwYQUQMIBLy+5pLSDKYFc7UIqj39w8EGzZkaxoLv/l2K8HaI0t5AVA+YYgUew==" 581 | }, 582 | "iconv-lite": { 583 | "version": "0.4.24", 584 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 585 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 586 | "requires": { 587 | "safer-buffer": ">= 2.1.2 < 3" 588 | } 589 | }, 590 | "import-lazy": { 591 | "version": "2.1.0", 592 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 593 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=" 594 | }, 595 | "imurmurhash": { 596 | "version": "0.1.4", 597 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 598 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 599 | }, 600 | "ini": { 601 | "version": "1.3.5", 602 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 603 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 604 | }, 605 | "inquirer": { 606 | "version": "7.0.0", 607 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.0.0.tgz", 608 | "integrity": "sha512-rSdC7zelHdRQFkWnhsMu2+2SO41mpv2oF2zy4tMhmiLWkcKbOAs87fWAJhVXttKVwhdZvymvnuM95EyEXg2/tQ==", 609 | "requires": { 610 | "ansi-escapes": "^4.2.1", 611 | "chalk": "^2.4.2", 612 | "cli-cursor": "^3.1.0", 613 | "cli-width": "^2.0.0", 614 | "external-editor": "^3.0.3", 615 | "figures": "^3.0.0", 616 | "lodash": "^4.17.15", 617 | "mute-stream": "0.0.8", 618 | "run-async": "^2.2.0", 619 | "rxjs": "^6.4.0", 620 | "string-width": "^4.1.0", 621 | "strip-ansi": "^5.1.0", 622 | "through": "^2.3.6" 623 | }, 624 | "dependencies": { 625 | "ansi-regex": { 626 | "version": "5.0.0", 627 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 628 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" 629 | }, 630 | "chalk": { 631 | "version": "2.4.2", 632 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 633 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 634 | "requires": { 635 | "ansi-styles": "^3.2.1", 636 | "escape-string-regexp": "^1.0.5", 637 | "supports-color": "^5.3.0" 638 | } 639 | }, 640 | "emoji-regex": { 641 | "version": "8.0.0", 642 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 643 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 644 | }, 645 | "has-flag": { 646 | "version": "3.0.0", 647 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 648 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 649 | }, 650 | "is-fullwidth-code-point": { 651 | "version": "3.0.0", 652 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 653 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 654 | }, 655 | "string-width": { 656 | "version": "4.2.0", 657 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 658 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 659 | "requires": { 660 | "emoji-regex": "^8.0.0", 661 | "is-fullwidth-code-point": "^3.0.0", 662 | "strip-ansi": "^6.0.0" 663 | }, 664 | "dependencies": { 665 | "strip-ansi": { 666 | "version": "6.0.0", 667 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 668 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 669 | "requires": { 670 | "ansi-regex": "^5.0.0" 671 | } 672 | } 673 | } 674 | }, 675 | "supports-color": { 676 | "version": "5.5.0", 677 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 678 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 679 | "requires": { 680 | "has-flag": "^3.0.0" 681 | } 682 | } 683 | } 684 | }, 685 | "is-ci": { 686 | "version": "2.0.0", 687 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 688 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 689 | "requires": { 690 | "ci-info": "^2.0.0" 691 | } 692 | }, 693 | "is-fullwidth-code-point": { 694 | "version": "2.0.0", 695 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 696 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 697 | }, 698 | "is-installed-globally": { 699 | "version": "0.3.1", 700 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.1.tgz", 701 | "integrity": "sha512-oiEcGoQbGc+3/iijAijrK2qFpkNoNjsHOm/5V5iaeydyrS/hnwaRCEgH5cpW0P3T1lSjV5piB7S5b5lEugNLhg==", 702 | "requires": { 703 | "global-dirs": "^2.0.1", 704 | "is-path-inside": "^3.0.1" 705 | } 706 | }, 707 | "is-npm": { 708 | "version": "4.0.0", 709 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz", 710 | "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==" 711 | }, 712 | "is-number": { 713 | "version": "7.0.0", 714 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 715 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 716 | }, 717 | "is-obj": { 718 | "version": "2.0.0", 719 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 720 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==" 721 | }, 722 | "is-path-inside": { 723 | "version": "3.0.2", 724 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.2.tgz", 725 | "integrity": "sha512-/2UGPSgmtqwo1ktx8NDHjuPwZWmHhO+gj0f93EkhLB5RgW9RZevWYYlIkS6zePc6U2WpOdQYIwHe9YC4DWEBVg==" 726 | }, 727 | "is-plain-object": { 728 | "version": "3.0.0", 729 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-3.0.0.tgz", 730 | "integrity": "sha512-tZIpofR+P05k8Aocp7UI/2UTa9lTJSebCXpFFoR9aibpokDj/uXBsJ8luUu0tTVYKkMU6URDUuOfJZ7koewXvg==", 731 | "requires": { 732 | "isobject": "^4.0.0" 733 | } 734 | }, 735 | "is-promise": { 736 | "version": "2.1.0", 737 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 738 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 739 | }, 740 | "is-stream": { 741 | "version": "1.1.0", 742 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 743 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 744 | }, 745 | "is-typedarray": { 746 | "version": "1.0.0", 747 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 748 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 749 | }, 750 | "is-yarn-global": { 751 | "version": "0.3.0", 752 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 753 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==" 754 | }, 755 | "isexe": { 756 | "version": "2.0.0", 757 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 758 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 759 | }, 760 | "isobject": { 761 | "version": "4.0.0", 762 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-4.0.0.tgz", 763 | "integrity": "sha512-S/2fF5wH8SJA/kmwr6HYhK/RI/OkhD84k8ntalo0iJjZikgq1XFvR5M8NPT1x5F7fBwCG3qHfnzeP/Vh/ZxCUA==" 764 | }, 765 | "json-buffer": { 766 | "version": "3.0.0", 767 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 768 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=" 769 | }, 770 | "keyv": { 771 | "version": "3.1.0", 772 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 773 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 774 | "requires": { 775 | "json-buffer": "3.0.0" 776 | } 777 | }, 778 | "latest-version": { 779 | "version": "5.1.0", 780 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 781 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 782 | "requires": { 783 | "package-json": "^6.3.0" 784 | } 785 | }, 786 | "locate-path": { 787 | "version": "5.0.0", 788 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 789 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 790 | "requires": { 791 | "p-locate": "^4.1.0" 792 | } 793 | }, 794 | "lodash": { 795 | "version": "4.17.15", 796 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 797 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" 798 | }, 799 | "lodash.toarray": { 800 | "version": "4.4.0", 801 | "resolved": "https://registry.npmjs.org/lodash.toarray/-/lodash.toarray-4.4.0.tgz", 802 | "integrity": "sha1-JMS/zWsvuji/0FlNsRedjptlZWE=" 803 | }, 804 | "log-update": { 805 | "version": "3.3.0", 806 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-3.3.0.tgz", 807 | "integrity": "sha512-YSKm5n+YjZoGZT5lfmOqasVH1fIH9xQA9A81Y48nZ99PxAP62vdCCtua+Gcu6oTn0nqtZd/LwRV+Vflo53ZDWA==", 808 | "requires": { 809 | "ansi-escapes": "^3.2.0", 810 | "cli-cursor": "^2.1.0", 811 | "wrap-ansi": "^5.0.0" 812 | }, 813 | "dependencies": { 814 | "ansi-escapes": { 815 | "version": "3.2.0", 816 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 817 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==" 818 | }, 819 | "cli-cursor": { 820 | "version": "2.1.0", 821 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 822 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 823 | "requires": { 824 | "restore-cursor": "^2.0.0" 825 | } 826 | }, 827 | "mimic-fn": { 828 | "version": "1.2.0", 829 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 830 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==" 831 | }, 832 | "onetime": { 833 | "version": "2.0.1", 834 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 835 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 836 | "requires": { 837 | "mimic-fn": "^1.0.0" 838 | } 839 | }, 840 | "restore-cursor": { 841 | "version": "2.0.0", 842 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 843 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 844 | "requires": { 845 | "onetime": "^2.0.0", 846 | "signal-exit": "^3.0.2" 847 | } 848 | } 849 | } 850 | }, 851 | "lowercase-keys": { 852 | "version": "1.0.1", 853 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 854 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==" 855 | }, 856 | "macos-release": { 857 | "version": "2.3.0", 858 | "resolved": "https://registry.npmjs.org/macos-release/-/macos-release-2.3.0.tgz", 859 | "integrity": "sha512-OHhSbtcviqMPt7yfw5ef5aghS2jzFVKEFyCJndQt2YpSQ9qRVSEv2axSJI1paVThEu+FFGs584h/1YhxjVqajA==" 860 | }, 861 | "make-dir": { 862 | "version": "3.0.0", 863 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.0.0.tgz", 864 | "integrity": "sha512-grNJDhb8b1Jm1qeqW5R/O63wUo4UXo2v2HMic6YT9i/HBlF93S8jkMgH7yugvY9ABDShH4VZMn8I+U8+fCNegw==", 865 | "requires": { 866 | "semver": "^6.0.0" 867 | }, 868 | "dependencies": { 869 | "semver": { 870 | "version": "6.3.0", 871 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 872 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 873 | } 874 | } 875 | }, 876 | "make-error": { 877 | "version": "1.3.5", 878 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.5.tgz", 879 | "integrity": "sha512-c3sIjNUow0+8swNwVpqoH4YCShKNFkMaw6oH1mNS2haDZQqkeZFlHS3dhoeEbKKmJB4vXpJucU6oH75aDYeE9g==", 880 | "dev": true 881 | }, 882 | "micromatch": { 883 | "version": "4.0.2", 884 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz", 885 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==", 886 | "requires": { 887 | "braces": "^3.0.1", 888 | "picomatch": "^2.0.5" 889 | } 890 | }, 891 | "mimic-fn": { 892 | "version": "2.1.0", 893 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 894 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==" 895 | }, 896 | "mimic-response": { 897 | "version": "1.0.1", 898 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 899 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==" 900 | }, 901 | "minimist": { 902 | "version": "1.2.0", 903 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 904 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" 905 | }, 906 | "mute-stream": { 907 | "version": "0.0.8", 908 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 909 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" 910 | }, 911 | "nice-try": { 912 | "version": "1.0.5", 913 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 914 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" 915 | }, 916 | "node-emoji": { 917 | "version": "1.10.0", 918 | "resolved": "https://registry.npmjs.org/node-emoji/-/node-emoji-1.10.0.tgz", 919 | "integrity": "sha512-Yt3384If5H6BYGVHiHwTL+99OzJKHhgp82S8/dktEK73T26BazdgZ4JZh92xSVtGNJvz9UbXdNAc5hcrXV42vw==", 920 | "requires": { 921 | "lodash.toarray": "^4.4.0" 922 | } 923 | }, 924 | "node-fetch": { 925 | "version": "2.6.0", 926 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.0.tgz", 927 | "integrity": "sha512-8dG4H5ujfvFiqDmVu9fQ5bOHUC15JMjMY/Zumv26oOvvVJjM67KF8koCWIabKQ1GJIa9r2mMZscBq/TbdOcmNA==" 928 | }, 929 | "normalize-url": { 930 | "version": "4.5.0", 931 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.0.tgz", 932 | "integrity": "sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ==" 933 | }, 934 | "npm-run-path": { 935 | "version": "2.0.2", 936 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 937 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 938 | "requires": { 939 | "path-key": "^2.0.0" 940 | } 941 | }, 942 | "once": { 943 | "version": "1.4.0", 944 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 945 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 946 | "requires": { 947 | "wrappy": "1" 948 | } 949 | }, 950 | "onetime": { 951 | "version": "5.1.0", 952 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 953 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 954 | "requires": { 955 | "mimic-fn": "^2.1.0" 956 | } 957 | }, 958 | "os-name": { 959 | "version": "3.1.0", 960 | "resolved": "https://registry.npmjs.org/os-name/-/os-name-3.1.0.tgz", 961 | "integrity": "sha512-h8L+8aNjNcMpo/mAIBPn5PXCM16iyPGjHNWo6U1YO8sJTMHtEtyczI6QJnLoplswm6goopQkqc7OAnjhWcugVg==", 962 | "requires": { 963 | "macos-release": "^2.2.0", 964 | "windows-release": "^3.1.0" 965 | } 966 | }, 967 | "os-tmpdir": { 968 | "version": "1.0.2", 969 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 970 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 971 | }, 972 | "p-cancelable": { 973 | "version": "1.1.0", 974 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 975 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==" 976 | }, 977 | "p-finally": { 978 | "version": "1.0.0", 979 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 980 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" 981 | }, 982 | "p-limit": { 983 | "version": "2.2.1", 984 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.1.tgz", 985 | "integrity": "sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg==", 986 | "requires": { 987 | "p-try": "^2.0.0" 988 | } 989 | }, 990 | "p-locate": { 991 | "version": "4.1.0", 992 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 993 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 994 | "requires": { 995 | "p-limit": "^2.2.0" 996 | } 997 | }, 998 | "p-try": { 999 | "version": "2.2.0", 1000 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1001 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" 1002 | }, 1003 | "package-json": { 1004 | "version": "6.5.0", 1005 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 1006 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 1007 | "requires": { 1008 | "got": "^9.6.0", 1009 | "registry-auth-token": "^4.0.0", 1010 | "registry-url": "^5.0.0", 1011 | "semver": "^6.2.0" 1012 | }, 1013 | "dependencies": { 1014 | "semver": { 1015 | "version": "6.3.0", 1016 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1017 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 1018 | } 1019 | } 1020 | }, 1021 | "path-exists": { 1022 | "version": "4.0.0", 1023 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1024 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" 1025 | }, 1026 | "path-key": { 1027 | "version": "2.0.1", 1028 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1029 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 1030 | }, 1031 | "picomatch": { 1032 | "version": "2.1.1", 1033 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.1.1.tgz", 1034 | "integrity": "sha512-OYMyqkKzK7blWO/+XZYP6w8hH0LDvkBvdvKukti+7kqYFCiEAk+gI3DWnryapc0Dau05ugGTy0foQ6mqn4AHYA==" 1035 | }, 1036 | "prepend-http": { 1037 | "version": "2.0.0", 1038 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 1039 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=" 1040 | }, 1041 | "prettier": { 1042 | "version": "1.19.1", 1043 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.19.1.tgz", 1044 | "integrity": "sha512-s7PoyDv/II1ObgQunCbB9PdLmUcBZcnWOcxDh7O0N/UwDEsHyqkW+Qh28jW+mVuCdx7gLB0BotYI1Y6uI9iyew==", 1045 | "dev": true 1046 | }, 1047 | "pump": { 1048 | "version": "3.0.0", 1049 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1050 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1051 | "requires": { 1052 | "end-of-stream": "^1.1.0", 1053 | "once": "^1.3.1" 1054 | } 1055 | }, 1056 | "rc": { 1057 | "version": "1.2.8", 1058 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1059 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1060 | "requires": { 1061 | "deep-extend": "^0.6.0", 1062 | "ini": "~1.3.0", 1063 | "minimist": "^1.2.0", 1064 | "strip-json-comments": "~2.0.1" 1065 | } 1066 | }, 1067 | "registry-auth-token": { 1068 | "version": "4.0.0", 1069 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.0.0.tgz", 1070 | "integrity": "sha512-lpQkHxd9UL6tb3k/aHAVfnVtn+Bcs9ob5InuFLLEDqSqeq+AljB8GZW9xY0x7F+xYwEcjKe07nyoxzEYz6yvkw==", 1071 | "requires": { 1072 | "rc": "^1.2.8", 1073 | "safe-buffer": "^5.0.1" 1074 | } 1075 | }, 1076 | "registry-url": { 1077 | "version": "5.1.0", 1078 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1079 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1080 | "requires": { 1081 | "rc": "^1.2.8" 1082 | } 1083 | }, 1084 | "require-directory": { 1085 | "version": "2.1.1", 1086 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1087 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" 1088 | }, 1089 | "require-main-filename": { 1090 | "version": "2.0.0", 1091 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1092 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==" 1093 | }, 1094 | "responselike": { 1095 | "version": "1.0.2", 1096 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1097 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1098 | "requires": { 1099 | "lowercase-keys": "^1.0.0" 1100 | } 1101 | }, 1102 | "restore-cursor": { 1103 | "version": "3.1.0", 1104 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1105 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1106 | "requires": { 1107 | "onetime": "^5.1.0", 1108 | "signal-exit": "^3.0.2" 1109 | } 1110 | }, 1111 | "run-async": { 1112 | "version": "2.3.0", 1113 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1114 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1115 | "requires": { 1116 | "is-promise": "^2.1.0" 1117 | } 1118 | }, 1119 | "rxjs": { 1120 | "version": "6.5.3", 1121 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.3.tgz", 1122 | "integrity": "sha512-wuYsAYYFdWTAnAaPoKGNhfpWwKZbJW+HgAJ+mImp+Epl7BG8oNWBCTyRM8gba9k4lk8BgWdoYm21Mo/RYhhbgA==", 1123 | "requires": { 1124 | "tslib": "^1.9.0" 1125 | } 1126 | }, 1127 | "safe-buffer": { 1128 | "version": "5.2.0", 1129 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", 1130 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==" 1131 | }, 1132 | "safer-buffer": { 1133 | "version": "2.1.2", 1134 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1135 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1136 | }, 1137 | "semver": { 1138 | "version": "5.7.1", 1139 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1140 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1141 | }, 1142 | "semver-diff": { 1143 | "version": "3.1.1", 1144 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1145 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1146 | "requires": { 1147 | "semver": "^6.3.0" 1148 | }, 1149 | "dependencies": { 1150 | "semver": { 1151 | "version": "6.3.0", 1152 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1153 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 1154 | } 1155 | } 1156 | }, 1157 | "set-blocking": { 1158 | "version": "2.0.0", 1159 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1160 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1161 | }, 1162 | "shebang-command": { 1163 | "version": "1.2.0", 1164 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1165 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1166 | "requires": { 1167 | "shebang-regex": "^1.0.0" 1168 | } 1169 | }, 1170 | "shebang-regex": { 1171 | "version": "1.0.0", 1172 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1173 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 1174 | }, 1175 | "signal-exit": { 1176 | "version": "3.0.2", 1177 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1178 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 1179 | }, 1180 | "source-map": { 1181 | "version": "0.6.1", 1182 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1183 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1184 | "dev": true 1185 | }, 1186 | "source-map-support": { 1187 | "version": "0.5.16", 1188 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.16.tgz", 1189 | "integrity": "sha512-efyLRJDr68D9hBBNIPWFjhpFzURh+KJykQwvMyW5UiZzYwoF6l4YMMDIJJEyFWxWCqfyxLzz6tSfUFR+kXXsVQ==", 1190 | "dev": true, 1191 | "requires": { 1192 | "buffer-from": "^1.0.0", 1193 | "source-map": "^0.6.0" 1194 | } 1195 | }, 1196 | "string-width": { 1197 | "version": "3.1.0", 1198 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1199 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1200 | "requires": { 1201 | "emoji-regex": "^7.0.1", 1202 | "is-fullwidth-code-point": "^2.0.0", 1203 | "strip-ansi": "^5.1.0" 1204 | } 1205 | }, 1206 | "strip-ansi": { 1207 | "version": "5.2.0", 1208 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1209 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1210 | "requires": { 1211 | "ansi-regex": "^4.1.0" 1212 | } 1213 | }, 1214 | "strip-eof": { 1215 | "version": "1.0.0", 1216 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 1217 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" 1218 | }, 1219 | "strip-json-comments": { 1220 | "version": "2.0.1", 1221 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1222 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 1223 | }, 1224 | "supports-color": { 1225 | "version": "7.1.0", 1226 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1227 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1228 | "requires": { 1229 | "has-flag": "^4.0.0" 1230 | } 1231 | }, 1232 | "term-size": { 1233 | "version": "2.1.1", 1234 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.1.1.tgz", 1235 | "integrity": "sha512-UqvQSch04R+69g4RDhrslmGvGL3ucDRX/U+snYW0Mab4uCAyKSndUksaoqlJ81QKSpRnIsuOYQCbC2ZWx2896A==" 1236 | }, 1237 | "through": { 1238 | "version": "2.3.8", 1239 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1240 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 1241 | }, 1242 | "tmp": { 1243 | "version": "0.0.33", 1244 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1245 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1246 | "requires": { 1247 | "os-tmpdir": "~1.0.2" 1248 | } 1249 | }, 1250 | "to-readable-stream": { 1251 | "version": "1.0.0", 1252 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1253 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==" 1254 | }, 1255 | "to-regex-range": { 1256 | "version": "5.0.1", 1257 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1258 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1259 | "requires": { 1260 | "is-number": "^7.0.0" 1261 | } 1262 | }, 1263 | "ts-node": { 1264 | "version": "8.5.2", 1265 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.5.2.tgz", 1266 | "integrity": "sha512-W1DK/a6BGoV/D4x/SXXm6TSQx6q3blECUzd5TN+j56YEMX3yPVMpHsICLedUw3DvGF3aTQ8hfdR9AKMaHjIi+A==", 1267 | "dev": true, 1268 | "requires": { 1269 | "arg": "^4.1.0", 1270 | "diff": "^4.0.1", 1271 | "make-error": "^1.1.1", 1272 | "source-map-support": "^0.5.6", 1273 | "yn": "^3.0.0" 1274 | } 1275 | }, 1276 | "tslib": { 1277 | "version": "1.10.0", 1278 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 1279 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" 1280 | }, 1281 | "type-fest": { 1282 | "version": "0.8.1", 1283 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1284 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==" 1285 | }, 1286 | "typedarray-to-buffer": { 1287 | "version": "3.1.5", 1288 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1289 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1290 | "requires": { 1291 | "is-typedarray": "^1.0.0" 1292 | } 1293 | }, 1294 | "typescript": { 1295 | "version": "3.7.2", 1296 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.2.tgz", 1297 | "integrity": "sha512-ml7V7JfiN2Xwvcer+XAf2csGO1bPBdRbFCkYBczNZggrBZ9c7G3riSUeJmqEU5uOtXNPMhE3n+R4FA/3YOAWOQ==", 1298 | "dev": true 1299 | }, 1300 | "unique-string": { 1301 | "version": "2.0.0", 1302 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 1303 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 1304 | "requires": { 1305 | "crypto-random-string": "^2.0.0" 1306 | } 1307 | }, 1308 | "universal-user-agent": { 1309 | "version": "4.0.0", 1310 | "resolved": "https://registry.npmjs.org/universal-user-agent/-/universal-user-agent-4.0.0.tgz", 1311 | "integrity": "sha512-eM8knLpev67iBDizr/YtqkJsF3GK8gzDc6st/WKzrTuPtcsOKW/0IdL4cnMBsU69pOx0otavLWBDGTwg+dB0aA==", 1312 | "requires": { 1313 | "os-name": "^3.1.0" 1314 | } 1315 | }, 1316 | "update-notifier": { 1317 | "version": "4.0.0", 1318 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.0.0.tgz", 1319 | "integrity": "sha512-p9zf71hWt5GVXM4iEBujpUgx8mK9AWiCCapEJm/O1z5ntCim83Z1ATqzZFBHFYqx03laMqv8LiDgs/7ikXjf/g==", 1320 | "requires": { 1321 | "boxen": "^4.2.0", 1322 | "chalk": "^3.0.0", 1323 | "configstore": "^5.0.0", 1324 | "has-yarn": "^2.1.0", 1325 | "import-lazy": "^2.1.0", 1326 | "is-ci": "^2.0.0", 1327 | "is-installed-globally": "^0.3.1", 1328 | "is-npm": "^4.0.0", 1329 | "is-yarn-global": "^0.3.0", 1330 | "latest-version": "^5.0.0", 1331 | "semver-diff": "^3.1.1", 1332 | "xdg-basedir": "^4.0.0" 1333 | } 1334 | }, 1335 | "url-parse-lax": { 1336 | "version": "3.0.0", 1337 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 1338 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 1339 | "requires": { 1340 | "prepend-http": "^2.0.0" 1341 | } 1342 | }, 1343 | "which": { 1344 | "version": "1.3.1", 1345 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1346 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1347 | "requires": { 1348 | "isexe": "^2.0.0" 1349 | } 1350 | }, 1351 | "which-module": { 1352 | "version": "2.0.0", 1353 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1354 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" 1355 | }, 1356 | "widest-line": { 1357 | "version": "3.1.0", 1358 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 1359 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 1360 | "requires": { 1361 | "string-width": "^4.0.0" 1362 | }, 1363 | "dependencies": { 1364 | "ansi-regex": { 1365 | "version": "5.0.0", 1366 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1367 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" 1368 | }, 1369 | "emoji-regex": { 1370 | "version": "8.0.0", 1371 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1372 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 1373 | }, 1374 | "is-fullwidth-code-point": { 1375 | "version": "3.0.0", 1376 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1377 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 1378 | }, 1379 | "string-width": { 1380 | "version": "4.2.0", 1381 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1382 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1383 | "requires": { 1384 | "emoji-regex": "^8.0.0", 1385 | "is-fullwidth-code-point": "^3.0.0", 1386 | "strip-ansi": "^6.0.0" 1387 | } 1388 | }, 1389 | "strip-ansi": { 1390 | "version": "6.0.0", 1391 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1392 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1393 | "requires": { 1394 | "ansi-regex": "^5.0.0" 1395 | } 1396 | } 1397 | } 1398 | }, 1399 | "windows-release": { 1400 | "version": "3.2.0", 1401 | "resolved": "https://registry.npmjs.org/windows-release/-/windows-release-3.2.0.tgz", 1402 | "integrity": "sha512-QTlz2hKLrdqukrsapKsINzqMgOUpQW268eJ0OaOpJN32h272waxR9fkB9VoWRtK7uKHG5EHJcTXQBD8XZVJkFA==", 1403 | "requires": { 1404 | "execa": "^1.0.0" 1405 | } 1406 | }, 1407 | "wrap-ansi": { 1408 | "version": "5.1.0", 1409 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 1410 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 1411 | "requires": { 1412 | "ansi-styles": "^3.2.0", 1413 | "string-width": "^3.0.0", 1414 | "strip-ansi": "^5.0.0" 1415 | } 1416 | }, 1417 | "wrappy": { 1418 | "version": "1.0.2", 1419 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1420 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1421 | }, 1422 | "write-file-atomic": { 1423 | "version": "3.0.1", 1424 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.1.tgz", 1425 | "integrity": "sha512-JPStrIyyVJ6oCSz/691fAjFtefZ6q+fP6tm+OS4Qw6o+TGQxNp1ziY2PgS+X/m0V8OWhZiO/m4xSj+Pr4RrZvw==", 1426 | "requires": { 1427 | "imurmurhash": "^0.1.4", 1428 | "is-typedarray": "^1.0.0", 1429 | "signal-exit": "^3.0.2", 1430 | "typedarray-to-buffer": "^3.1.5" 1431 | } 1432 | }, 1433 | "xdg-basedir": { 1434 | "version": "4.0.0", 1435 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 1436 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==" 1437 | }, 1438 | "y18n": { 1439 | "version": "4.0.0", 1440 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 1441 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==" 1442 | }, 1443 | "yargs": { 1444 | "version": "15.0.0", 1445 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.0.0.tgz", 1446 | "integrity": "sha512-ywk8xVR7qlJQormKfBTCgN7LKtd7qpcTBY1nmiQKb4Xa9SDvqg+t98nCzXaQ++GyQII6Y6z8I+ecYjz+/tWlLQ==", 1447 | "requires": { 1448 | "cliui": "^5.0.0", 1449 | "decamelize": "^1.2.0", 1450 | "find-up": "^3.0.0", 1451 | "get-caller-file": "^2.0.1", 1452 | "require-directory": "^2.1.1", 1453 | "require-main-filename": "^2.0.0", 1454 | "set-blocking": "^2.0.0", 1455 | "string-width": "^3.0.0", 1456 | "which-module": "^2.0.0", 1457 | "y18n": "^4.0.0", 1458 | "yargs-parser": "^16.1.0" 1459 | }, 1460 | "dependencies": { 1461 | "find-up": { 1462 | "version": "3.0.0", 1463 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 1464 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 1465 | "requires": { 1466 | "locate-path": "^3.0.0" 1467 | } 1468 | }, 1469 | "locate-path": { 1470 | "version": "3.0.0", 1471 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1472 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1473 | "requires": { 1474 | "p-locate": "^3.0.0", 1475 | "path-exists": "^3.0.0" 1476 | } 1477 | }, 1478 | "p-locate": { 1479 | "version": "3.0.0", 1480 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1481 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1482 | "requires": { 1483 | "p-limit": "^2.0.0" 1484 | } 1485 | }, 1486 | "path-exists": { 1487 | "version": "3.0.0", 1488 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1489 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" 1490 | } 1491 | } 1492 | }, 1493 | "yargs-parser": { 1494 | "version": "16.1.0", 1495 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-16.1.0.tgz", 1496 | "integrity": "sha512-H/V41UNZQPkUMIT5h5hiwg4QKIY1RPvoBV4XcjUbRM8Bk2oKqqyZ0DIEbTFZB0XjbtSPG8SAa/0DxCQmiRgzKg==", 1497 | "requires": { 1498 | "camelcase": "^5.0.0", 1499 | "decamelize": "^1.2.0" 1500 | } 1501 | }, 1502 | "yn": { 1503 | "version": "3.1.1", 1504 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1505 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 1506 | "dev": true 1507 | } 1508 | } 1509 | } 1510 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "github-issue-cli", 3 | "version": "0.0.11", 4 | "description": "CLI application to search for your good first issue", 5 | "bin": { 6 | "ghi": "./bin/ghi.js" 7 | }, 8 | "files": [ 9 | "dist", 10 | "src", 11 | "bin" 12 | ], 13 | "scripts": { 14 | "prepare": "tsc && rm -rf dist/queries && cp -r src/queries dist/queries", 15 | "test": "jest" 16 | }, 17 | "repository": "Leko/github-issue-cli", 18 | "keywords": [ 19 | "github", 20 | "good", 21 | "first", 22 | "issue", 23 | "issue", 24 | "cli" 25 | ], 26 | "author": "Leko ", 27 | "license": "MIT", 28 | "bugs": { 29 | "url": "https://github.com/Leko/github-issue-cli/issues" 30 | }, 31 | "homepage": "https://github.com/Leko/github-issue-cli#readme", 32 | "dependencies": { 33 | "@octokit/graphql": "^4.3.1", 34 | "chalk": "^3.0.0", 35 | "chromatism": "^3.0.0", 36 | "elegant-spinner": "^2.0.0", 37 | "find-up": "^4.1.0", 38 | "inquirer": "^7.0.0", 39 | "log-update": "^3.3.0", 40 | "micromatch": "^4.0.2", 41 | "node-emoji": "^1.10.0", 42 | "update-notifier": "^4.0.0", 43 | "yargs": "^15.0.0" 44 | }, 45 | "devDependencies": { 46 | "@types/inquirer": "^6.5.0", 47 | "@types/micromatch": "^3.1.1", 48 | "@types/node": "~13.13.4", 49 | "@types/node-emoji": "^1.8.1", 50 | "@types/update-notifier": "^2.5.0", 51 | "@types/yargs": "^13.0.3", 52 | "prettier": "^1.19.1", 53 | "ts-node": "^8.5.2", 54 | "typescript": "^3.7.2" 55 | } 56 | } 57 | -------------------------------------------------------------------------------- /src/Config.ts: -------------------------------------------------------------------------------- 1 | import os from "os" 2 | import fs from "fs" 3 | import path from "path" 4 | import { sync as findUp } from "find-up" 5 | 6 | export type Config = { 7 | queries: { 8 | [repo: string]: { 9 | [name: string]: string 10 | } 11 | } 12 | } & ( 13 | | { 14 | token: string 15 | login: string 16 | } 17 | | { 18 | token: null 19 | login: null 20 | } 21 | ) 22 | 23 | const FILE_NAME = ".ghirc" 24 | export const DEFAULT_PATH = path.join(os.homedir(), FILE_NAME) 25 | 26 | const defaultConfig: Config = { 27 | token: null, 28 | login: null, 29 | queries: {}, 30 | } 31 | 32 | export function resolve(userConfig: string | null): Config { 33 | if (userConfig && !fs.existsSync(userConfig)) { 34 | throw new Error(`${userConfig} does not exists`) 35 | } 36 | 37 | const configPath = userConfig || findUp([FILE_NAME]) || DEFAULT_PATH 38 | 39 | if (!configPath) { 40 | return defaultConfig 41 | } 42 | 43 | try { 44 | return JSON.parse(fs.readFileSync(configPath, "utf8")) 45 | } catch (e) { 46 | return defaultConfig 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /src/app.ts: -------------------------------------------------------------------------------- 1 | import chalk from "chalk" 2 | import { flags } from "./flags" 3 | 4 | flags 5 | .fail((message, error) => { 6 | if (message) { 7 | console.error(chalk.red(message)) 8 | } else { 9 | console.error(chalk.red(error.stack)) 10 | } 11 | process.exit(1) 12 | }) 13 | .parse() 14 | -------------------------------------------------------------------------------- /src/commands/doctor.ts: -------------------------------------------------------------------------------- 1 | import { CommandModule } from "yargs" 2 | 3 | export default { 4 | command: "doctor", 5 | describe: "Check your environment to run ghi", 6 | builder: yargs => yargs.default("value", "true"), 7 | async handler(argv) { 8 | console.log(`doctor`, argv.config) 9 | }, 10 | } as CommandModule 11 | -------------------------------------------------------------------------------- /src/commands/list.ts: -------------------------------------------------------------------------------- 1 | import fs from "fs" 2 | import path from "path" 3 | import { CommandModule } from "yargs" 4 | import inquirer from "inquirer" 5 | import { emojify } from "node-emoji" 6 | import chalk from "chalk" 7 | import * as chromatism from "chromatism" 8 | import { resolve } from "../Config" 9 | import { getClient } from "../utils/graphql" 10 | import { showSpinnerWhileProcessing } from "../utils/showSpinnerWhileProcessing" 11 | import { getSavedQueries } from "../utils/getSavedQueries" 12 | 13 | const issuesQuery = fs.readFileSync( 14 | path.join(__dirname, "..", "queries", "issues.graphql"), 15 | "utf8" 16 | ) 17 | 18 | export default { 19 | command: "list ", 20 | describe: "List issues for specified repository", 21 | builder: yargs => 22 | yargs.positional("repo", { 23 | describe: "owner and repository name (e.g. microsoft/TypeScript)", 24 | }), 25 | async handler(argv) { 26 | const config = resolve(argv.config as string) 27 | const [owner, name] = (argv.repo as string).split("/") 28 | if (!owner || !name) { 29 | throw new Error("Malformed. must be formatted with `owner/name`") 30 | } 31 | const graphql = getClient(config) 32 | const savedQueries = getSavedQueries(config, { owner, name }) 33 | 34 | let query = savedQueries[0] 35 | if (savedQueries.length > 1) { 36 | const { queryIndex } = await inquirer.prompt([ 37 | { 38 | name: "queryIndex", 39 | type: "rawlist", 40 | message: `Multiple queries detected. Which one to use?`, 41 | choices: savedQueries.map(({ name, query }, i) => ({ 42 | name: `${name} (${query})`, 43 | value: i, 44 | })), 45 | }, 46 | ]) 47 | query = savedQueries[queryIndex] 48 | } 49 | 50 | const q = `is:open repo:${owner}/${name} ${query.query}` 51 | const { 52 | search, 53 | }: any = await showSpinnerWhileProcessing( 54 | `Fetching issues ${owner}/${name} issues`, 55 | async () => graphql(issuesQuery, { q }) 56 | ) 57 | const issues = search.edges.map(({ node }: any) => node) 58 | const noAssociatedIssues = issues 59 | .filter((issue: any) => { 60 | const timelineItems = issue.timelineItems.edges 61 | .filter(Boolean) 62 | .map(({ node }: any) => node) 63 | const willBeClosedEvents = timelineItems.filter( 64 | ({ willCloseTarget }: any) => willCloseTarget 65 | ) 66 | 67 | return willBeClosedEvents.length === 0 68 | }) 69 | .sort( 70 | (a: any, b: any) => 71 | new Date(a.updatedAt).getTime() - new Date(b.updatedAt).getTime() 72 | ) 73 | 74 | const now = Date.now() 75 | // @ts-ignore Property 'RelativeTimeFormat' does not exist on type 'typeof Intl' 76 | const formatter = new Intl.RelativeTimeFormat("en-US", { numeric: "auto" }) 77 | noAssociatedIssues.forEach( 78 | ({ number, title, url, updatedAt, comments, labels }: any) => { 79 | const relative = formatter.format( 80 | Math.round( 81 | (new Date(updatedAt).getTime() - now) / 1000 / 60 / 60 / 24 82 | ), 83 | "day" 84 | ) 85 | const numComments = comments.totalCount 86 | const labelsStr = labels.nodes 87 | .map(({ name, color }: any) => 88 | chalk.bgHex(color).hex(chromatism.contrastRatio(`#${color}`).hex)( 89 | name 90 | ) 91 | ) 92 | .join(", ") 93 | 94 | console.log(`\n#${number} ${chalk.bold(title)}`) 95 | console.log(emojify(` :link: ${url}`)) 96 | console.log(emojify(` :label: ${labelsStr}`)) 97 | console.log( 98 | emojify( 99 | ` :left_speech_bubble: ${numComments}, :timer_clock: ${relative}` 100 | ) 101 | ) 102 | } 103 | ) 104 | }, 105 | } as CommandModule 106 | -------------------------------------------------------------------------------- /src/commands/login.ts: -------------------------------------------------------------------------------- 1 | import fs from "fs" 2 | import path from "path" 3 | import { CommandModule } from "yargs" 4 | import chalk from "chalk" 5 | import emoji from "node-emoji" 6 | import inquirer from "inquirer" 7 | import { DEFAULT_PATH, resolve } from "../Config" 8 | import { getClient } from "../utils/graphql" 9 | import { showSpinnerWhileProcessing } from "../utils/showSpinnerWhileProcessing" 10 | 11 | const aboutMeQuery = fs.readFileSync( 12 | path.join(__dirname, "..", "queries", "aboutMe.graphql"), 13 | "utf8" 14 | ) 15 | 16 | export default { 17 | command: "login", 18 | describe: "Check your environment to run ghi", 19 | builder: yargs => yargs.default("value", "true"), 20 | async handler(argv) { 21 | const config = resolve(argv.config as string) 22 | if (config.token && config.login) { 23 | const { confirm } = await inquirer.prompt([ 24 | { 25 | name: "confirm", 26 | type: "confirm", 27 | message: `You're already logged in as ${config.login}. Do you want to continue?`, 28 | }, 29 | ]) 30 | if (!confirm) { 31 | return 32 | } 33 | } 34 | 35 | console.log(chalk.cyan("Welcome to ghi!")) 36 | console.log( 37 | "To get started, open the following URL to generate a GitHub token" 38 | ) 39 | console.log( 40 | "\n https://github.com/settings/tokens/new?scopes=public_repo\n" 41 | ) 42 | const { token } = await inquirer.prompt([ 43 | { 44 | name: "token", 45 | type: "password", 46 | mask: "*", 47 | message: "Please input your GitHub access token", 48 | }, 49 | ]) 50 | 51 | const graphql = getClient({ token }) 52 | const viewer = await showSpinnerWhileProcessing( 53 | "Fetching your information from GitHub", 54 | async () => { 55 | const { viewer }: any = await graphql(aboutMeQuery) 56 | 57 | return viewer 58 | } 59 | ) 60 | await showSpinnerWhileProcessing( 61 | `Saving credentials to ${chalk.dim(DEFAULT_PATH)}`, 62 | async () => { 63 | fs.writeFileSync( 64 | DEFAULT_PATH, 65 | JSON.stringify({ token, login: viewer.login }) 66 | ) 67 | } 68 | ) 69 | 70 | console.log(`Good job ${chalk.cyan(viewer.login)}!`) 71 | console.log( 72 | `This is the end of the instruction. If you have any questions, run 'ghi --help'.` 73 | ) 74 | console.log(emoji.emojify(`Enjoy :crossed_fingers:`)) 75 | }, 76 | } as CommandModule 77 | -------------------------------------------------------------------------------- /src/flags.ts: -------------------------------------------------------------------------------- 1 | import yargs from "yargs" 2 | import doctorCommand from "./commands/doctor" 3 | import loginCommand from "./commands/login" 4 | import listCommand from "./commands/list" 5 | 6 | export const flags = yargs 7 | .scriptName("ghi") 8 | .options({ 9 | config: { 10 | type: "string", 11 | description: "Path to .ghirc file", 12 | }, 13 | }) 14 | .command(doctorCommand) 15 | .command(loginCommand) 16 | .command(listCommand) 17 | .help() 18 | -------------------------------------------------------------------------------- /src/queries/aboutMe.graphql: -------------------------------------------------------------------------------- 1 | query AboutMe { 2 | viewer { 3 | login 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /src/queries/issues.graphql: -------------------------------------------------------------------------------- 1 | query issues($q: String!) { 2 | search(type: ISSUE, first: 100, query: $q) { 3 | edges { 4 | node { 5 | ... on Issue { 6 | number 7 | title 8 | url 9 | updatedAt 10 | comments { 11 | totalCount 12 | } 13 | labels(first: 100) { 14 | nodes { 15 | name 16 | color 17 | } 18 | } 19 | timelineItems( 20 | first: 100 21 | itemTypes: [REFERENCED_EVENT, CROSS_REFERENCED_EVENT] 22 | ) { 23 | edges { 24 | node { 25 | ... on CrossReferencedEvent { 26 | referencedAt 27 | resourcePath 28 | source { 29 | ... on PullRequest { 30 | number 31 | url 32 | title 33 | } 34 | } 35 | willCloseTarget 36 | } 37 | } 38 | } 39 | } 40 | } 41 | } 42 | } 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /src/utils/getSavedQueries.ts: -------------------------------------------------------------------------------- 1 | import { isMatch } from "micromatch" 2 | import { Config } from "../Config" 3 | 4 | const defaultQueries = { 5 | "good first issue": 'label:"good first issue"', 6 | } 7 | 8 | export function getSavedQueries( 9 | config: Pick, 10 | repo: { owner: string; name: string } 11 | ): { name: string; query: string }[] { 12 | const { owner, name } = repo 13 | const queries = Object.entries(config.queries || {}) 14 | .filter(([repo]) => isMatch(`${owner}/${name}`, repo)) 15 | .concat([["*/*", defaultQueries]]) 16 | .reduce( 17 | (acc, [_, queries]) => 18 | acc.concat( 19 | Object.entries(queries).map(([name, query]) => ({ name, query })) 20 | ), 21 | [] as { name: string; query: string }[] 22 | ) 23 | return queries 24 | } 25 | -------------------------------------------------------------------------------- /src/utils/graphql.ts: -------------------------------------------------------------------------------- 1 | import { graphql } from "@octokit/graphql" 2 | import { Config } from "../Config" 3 | 4 | export function getClient(config: Pick) { 5 | if (!config.token) { 6 | throw new Error(`Access token not found. Please try 'ghi login' before`) 7 | } 8 | 9 | return graphql.defaults({ 10 | headers: { 11 | authorization: `token ${config.token}`, 12 | }, 13 | }) 14 | } 15 | -------------------------------------------------------------------------------- /src/utils/showSpinnerWhileProcessing.ts: -------------------------------------------------------------------------------- 1 | import logUpdate from "log-update" 2 | import elegantSpinner from "elegant-spinner" 3 | import { emojify } from "node-emoji" 4 | 5 | const FPS = 20 6 | 7 | export async function showSpinnerWhileProcessing( 8 | initialMessage: string, 9 | fn: () => Promise 10 | ): Promise { 11 | const frame = elegantSpinner() 12 | const tid = setInterval(() => { 13 | logUpdate(`${frame()} ${initialMessage}`) 14 | }, 1000 / FPS) 15 | 16 | return fn() 17 | .then(ret => { 18 | logUpdate(emojify(`:heavy_check_mark: ${initialMessage}`)) 19 | return ret 20 | }) 21 | .finally(() => { 22 | logUpdate.done() 23 | clearTimeout(tid) 24 | }) 25 | } 26 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Basic Options */ 4 | "incremental": true /* Enable incremental compilation */, 5 | "target": "es2019" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019' or 'ESNEXT'. */, 6 | "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */, 7 | "lib": ["es2019"], 8 | 9 | /* Specify library files to be included in the compilation. */ 10 | "declaration": true /* Generates corresponding '.d.ts' file. */, 11 | "declarationMap": true /* Generates a sourcemap for each corresponding '.d.ts' file. */, 12 | "outDir": "./dist" /* Redirect output structure to the directory. */, 13 | "rootDir": "./src", 14 | 15 | /* Strict Type-Checking Options */ 16 | "strict": true /* Enable all strict type-checking options. */, 17 | 18 | /* Additional Checks */ 19 | "noUnusedLocals": true /* Report errors on unused locals. */, 20 | "noUnusedParameters": true /* Report errors on unused parameters. */, 21 | "noImplicitReturns": true /* Report error when not all code paths in function return a value. */, 22 | "noFallthroughCasesInSwitch": true /* Report errors for fallthrough cases in switch statement. */, 23 | 24 | /* Module Resolution Options */ 25 | "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, 26 | "resolveJsonModule": true, 27 | 28 | /* Advanced Options */ 29 | "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */ 30 | } 31 | } 32 | --------------------------------------------------------------------------------