├── .editorconfig ├── .eslintignore ├── .eslintrc.json ├── .gitignore ├── .prettierignore ├── .prettierrc ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── README.md ├── package-lock.json ├── package.json ├── src ├── extension.ts ├── tasks │ ├── commands │ │ ├── assembler │ │ │ ├── build.ts │ │ │ ├── invoke.ts │ │ │ └── make │ │ │ │ ├── command.ts │ │ │ │ ├── controller.ts │ │ │ │ ├── exception.ts │ │ │ │ ├── listener.ts │ │ │ │ ├── middleware.ts │ │ │ │ ├── preloadFile.ts │ │ │ │ ├── provider.ts │ │ │ │ ├── validator.ts │ │ │ │ └── view.ts │ │ ├── index.ts │ │ └── lucid │ │ │ ├── db │ │ │ └── seed.ts │ │ │ ├── make │ │ │ ├── migration.ts │ │ │ ├── model.ts │ │ │ └── seeder.ts │ │ │ └── migration │ │ │ ├── rollback.ts │ │ │ ├── run.ts │ │ │ └── status.ts │ ├── index.ts │ └── types │ │ ├── commandSteps.ts │ │ └── index.ts ├── test │ ├── runTest.ts │ └── suite │ │ └── index.ts └── utilities │ ├── command.ts │ ├── config.ts │ ├── constants.ts │ ├── index.ts │ ├── inputValidation.ts │ └── workspace.ts ├── tsconfig.json ├── tslint.json └── vsc-extension-quickstart.md /.editorconfig: -------------------------------------------------------------------------------- 1 | # http://editorconfig.org 2 | root = true 3 | 4 | [*] 5 | indent_size = 2 6 | indent_style = tab 7 | end_of_line = lf 8 | charset = utf-8 9 | trim_trailing_whitespace = true 10 | insert_final_newline = true 11 | 12 | [*.md] 13 | trim_trailing_whitespace = false 14 | indent_style = space 15 | 16 | [*.json] 17 | insert_final_newline = ignore 18 | 19 | [**.min.js] 20 | indent_style = ignore 21 | insert_final_newline = ignore 22 | 23 | [MakeFile] 24 | indent_style = tab 25 | -------------------------------------------------------------------------------- /.eslintignore: -------------------------------------------------------------------------------- 1 | out -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": [ 3 | "plugin:adonis/typescriptPackage", 4 | "prettier", 5 | "prettier/@typescript-eslint" 6 | ], 7 | "plugins": [ 8 | "prettier" 9 | ], 10 | "rules": { 11 | "prettier/prettier": [ 12 | "error" 13 | ] 14 | } 15 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | .vscode-test/ 4 | *.vsix 5 | coverage 6 | .nyc_output -------------------------------------------------------------------------------- /.prettierignore: -------------------------------------------------------------------------------- 1 | out 2 | config.json 3 | .eslintrc.json 4 | package.json 5 | *.html -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "trailingComma": "es5", 3 | "semi": false, 4 | "singleQuote": true, 5 | "useTabs": true, 6 | "quoteProps": "consistent", 7 | "bracketSpacing": true, 8 | "arrowParens": "always", 9 | "printWidth": 100 10 | } 11 | -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See http://go.microsoft.com/fwlink/?LinkId=827846 3 | // for the documentation about the extensions.json format 4 | "recommendations": ["ms-vscode.vscode-typescript-tslint-plugin"] 5 | } 6 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | { 6 | "version": "0.2.0", 7 | "configurations": [ 8 | { 9 | "name": "Run Extension", 10 | "type": "extensionHost", 11 | "request": "launch", 12 | "runtimeExecutable": "${execPath}", 13 | "args": ["--extensionDevelopmentPath=${workspaceFolder}"], 14 | "outFiles": ["${workspaceFolder}/out/**/*.js"], 15 | "preLaunchTask": "npm: watch" 16 | }, 17 | { 18 | "name": "Extension Tests", 19 | "type": "extensionHost", 20 | "request": "launch", 21 | "runtimeExecutable": "${execPath}", 22 | "args": [ 23 | "${workspaceFolder}/src/test/data/", 24 | "--extensionDevelopmentPath=${workspaceFolder}", 25 | "--extensionTestsPath=${workspaceFolder}/out/test/suite/index" 26 | ], 27 | "outFiles": ["${workspaceFolder}/out/test/**/*.js"], 28 | "preLaunchTask": "npm: watch" 29 | } 30 | ] 31 | } 32 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | // Place your settings in this file to overwrite default and user settings. 2 | { 3 | "files.exclude": { 4 | "out": false // set this to true to hide the "out" folder with the compiled JS files 5 | }, 6 | "search.exclude": { 7 | "out": true // set this to false to include "out" folder in search results 8 | }, 9 | // Turn off tsc task auto detection since we have the necessary tasks as npm scripts 10 | "typescript.tsc.autoDetect": "off" 11 | } 12 | -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // See https://go.microsoft.com/fwlink/?LinkId=733558 2 | // for the documentation about the tasks.json format 3 | { 4 | "version": "2.0.0", 5 | "tasks": [ 6 | { 7 | "type": "npm", 8 | "script": "watch", 9 | "problemMatcher": "$tsc-watch", 10 | "isBackground": true, 11 | "presentation": { 12 | "reveal": "never" 13 | }, 14 | "group": { 15 | "kind": "build", 16 | "isDefault": true 17 | } 18 | }, 19 | { 20 | "type": "npm", 21 | "script": "test", 22 | "group": "test", 23 | "problemMatcher": [] 24 | } 25 | ] 26 | } 27 | -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/test/** 4 | src/** 5 | .gitignore 6 | vsc-extension-quickstart.md 7 | **/tsconfig.json 8 | **/tslint.json 9 | **/*.map 10 | **/*.ts -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | All notable changes to the "adonisjs" extension will be documented in this file. 4 | 5 | Check [Keep a Changelog](http://keepachangelog.com/) for recommendations on how to structure this file. 6 | 7 | ## [Unreleased] 8 | 9 | - Initial release 10 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # adonisjs-vscode 2 | 3 | 🚨 The extension is not ready for usage yet 🚨 4 | 5 | Official VSCode extension for AdonisJS. 6 | 7 | ## Features 8 | 9 | - CLI task 10 | - AdonisJS snippets 11 | - Edge templating 12 | - Components and @include autocompletion 13 | - Autodetect (detecting edge files, adonis project etc). 14 | 15 | ## Requirements 16 | 17 | To run CLI tasks, ensure you are in a valid AdonisJS folder as your workspace directory. 18 | 19 | ## Extension Settings 20 | 21 | > None for now. 22 | 23 | ## Known Issues 24 | 25 | > None for now. 26 | 27 | ## Release Notes 28 | 29 | > None for now. 30 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "adonisjs", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.10.4", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", 10 | "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.10.4" 14 | } 15 | }, 16 | "@babel/helper-validator-identifier": { 17 | "version": "7.10.4", 18 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 19 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", 20 | "dev": true 21 | }, 22 | "@babel/highlight": { 23 | "version": "7.10.4", 24 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 25 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 26 | "dev": true, 27 | "requires": { 28 | "@babel/helper-validator-identifier": "^7.10.4", 29 | "chalk": "^2.0.0", 30 | "js-tokens": "^4.0.0" 31 | } 32 | }, 33 | "@eslint/eslintrc": { 34 | "version": "0.1.3", 35 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.1.3.tgz", 36 | "integrity": "sha512-4YVwPkANLeNtRjMekzux1ci8hIaH5eGKktGqR0d3LWsKNn5B2X/1Z6Trxy7jQXl9EBGE6Yj02O+t09FMeRllaA==", 37 | "dev": true, 38 | "requires": { 39 | "ajv": "^6.12.4", 40 | "debug": "^4.1.1", 41 | "espree": "^7.3.0", 42 | "globals": "^12.1.0", 43 | "ignore": "^4.0.6", 44 | "import-fresh": "^3.2.1", 45 | "js-yaml": "^3.13.1", 46 | "lodash": "^4.17.19", 47 | "minimatch": "^3.0.4", 48 | "strip-json-comments": "^3.1.1" 49 | }, 50 | "dependencies": { 51 | "debug": { 52 | "version": "4.2.0", 53 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", 54 | "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", 55 | "dev": true, 56 | "requires": { 57 | "ms": "2.1.2" 58 | } 59 | }, 60 | "ms": { 61 | "version": "2.1.2", 62 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 63 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 64 | "dev": true 65 | }, 66 | "strip-json-comments": { 67 | "version": "3.1.1", 68 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 69 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 70 | "dev": true 71 | } 72 | } 73 | }, 74 | "@types/eslint-visitor-keys": { 75 | "version": "1.0.0", 76 | "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 77 | "integrity": "sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag==", 78 | "dev": true 79 | }, 80 | "@types/events": { 81 | "version": "3.0.0", 82 | "resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.0.tgz", 83 | "integrity": "sha512-EaObqwIvayI5a8dCzhFrjKzVwKLxjoG9T6Ppd5CEo07LRKfQ8Yokw54r5+Wq7FaBQ+yXRvQAYPrHwya1/UFt9g==", 84 | "dev": true 85 | }, 86 | "@types/glob": { 87 | "version": "7.1.1", 88 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.1.tgz", 89 | "integrity": "sha512-1Bh06cbWJUHMC97acuD6UMG29nMt0Aqz1vF3guLfG+kHHJhy3AyohZFFxYk2f7Q1SQIrNwvncxAE0N/9s70F2w==", 90 | "dev": true, 91 | "requires": { 92 | "@types/events": "*", 93 | "@types/minimatch": "*", 94 | "@types/node": "*" 95 | } 96 | }, 97 | "@types/json-schema": { 98 | "version": "7.0.6", 99 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.6.tgz", 100 | "integrity": "sha512-3c+yGKvVP5Y9TYBEibGNR+kLtijnj7mYrXRg+WpFb2X9xm04g/DXYkfg4hmzJQosc9snFNUPkbYIhu+KAm6jJw==", 101 | "dev": true 102 | }, 103 | "@types/minimatch": { 104 | "version": "3.0.3", 105 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", 106 | "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==", 107 | "dev": true 108 | }, 109 | "@types/mocha": { 110 | "version": "5.2.7", 111 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-5.2.7.tgz", 112 | "integrity": "sha512-NYrtPht0wGzhwe9+/idPaBB+TqkY9AhTvOLMkThm0IoEfLaiVQZwBwyJ5puCkO3AUCWrmcoePjp2mbFocKy4SQ==", 113 | "dev": true 114 | }, 115 | "@types/node": { 116 | "version": "10.14.22", 117 | "resolved": "https://registry.npmjs.org/@types/node/-/node-10.14.22.tgz", 118 | "integrity": "sha512-9taxKC944BqoTVjE+UT3pQH0nHZlTvITwfsOZqyc+R3sfJuxaTtxWjfn1K2UlxyPcKHf0rnaXcVFrS9F9vf0bw==", 119 | "dev": true 120 | }, 121 | "@types/vscode": { 122 | "version": "1.39.0", 123 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.39.0.tgz", 124 | "integrity": "sha512-rlg0okXDt7NjAyHXbZ2nO1I/VY/8y9w67ltLRrOxXQ46ayvrYZavD4A6zpYrGbs2+ZOEQzcUs+QZOqcVGQIxXQ==", 125 | "dev": true 126 | }, 127 | "@typescript-eslint/eslint-plugin": { 128 | "version": "3.10.1", 129 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-3.10.1.tgz", 130 | "integrity": "sha512-PQg0emRtzZFWq6PxBcdxRH3QIQiyFO3WCVpRL3fgj5oQS3CDs3AeAKfv4DxNhzn8ITdNJGJ4D3Qw8eAJf3lXeQ==", 131 | "dev": true, 132 | "requires": { 133 | "@typescript-eslint/experimental-utils": "3.10.1", 134 | "debug": "^4.1.1", 135 | "functional-red-black-tree": "^1.0.1", 136 | "regexpp": "^3.0.0", 137 | "semver": "^7.3.2", 138 | "tsutils": "^3.17.1" 139 | }, 140 | "dependencies": { 141 | "debug": { 142 | "version": "4.2.0", 143 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", 144 | "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", 145 | "dev": true, 146 | "requires": { 147 | "ms": "2.1.2" 148 | } 149 | }, 150 | "ms": { 151 | "version": "2.1.2", 152 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 153 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 154 | "dev": true 155 | }, 156 | "semver": { 157 | "version": "7.3.2", 158 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 159 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 160 | "dev": true 161 | } 162 | } 163 | }, 164 | "@typescript-eslint/experimental-utils": { 165 | "version": "3.10.1", 166 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-3.10.1.tgz", 167 | "integrity": "sha512-DewqIgscDzmAfd5nOGe4zm6Bl7PKtMG2Ad0KG8CUZAHlXfAKTF9Ol5PXhiMh39yRL2ChRH1cuuUGOcVyyrhQIw==", 168 | "dev": true, 169 | "requires": { 170 | "@types/json-schema": "^7.0.3", 171 | "@typescript-eslint/types": "3.10.1", 172 | "@typescript-eslint/typescript-estree": "3.10.1", 173 | "eslint-scope": "^5.0.0", 174 | "eslint-utils": "^2.0.0" 175 | } 176 | }, 177 | "@typescript-eslint/parser": { 178 | "version": "3.10.1", 179 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-3.10.1.tgz", 180 | "integrity": "sha512-Ug1RcWcrJP02hmtaXVS3axPPTTPnZjupqhgj+NnZ6BCkwSImWk/283347+x9wN+lqOdK9Eo3vsyiyDHgsmiEJw==", 181 | "dev": true, 182 | "requires": { 183 | "@types/eslint-visitor-keys": "^1.0.0", 184 | "@typescript-eslint/experimental-utils": "3.10.1", 185 | "@typescript-eslint/types": "3.10.1", 186 | "@typescript-eslint/typescript-estree": "3.10.1", 187 | "eslint-visitor-keys": "^1.1.0" 188 | }, 189 | "dependencies": { 190 | "eslint-visitor-keys": { 191 | "version": "1.3.0", 192 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 193 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 194 | "dev": true 195 | } 196 | } 197 | }, 198 | "@typescript-eslint/types": { 199 | "version": "3.10.1", 200 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-3.10.1.tgz", 201 | "integrity": "sha512-+3+FCUJIahE9q0lDi1WleYzjCwJs5hIsbugIgnbB+dSCYUxl8L6PwmsyOPFZde2hc1DlTo/xnkOgiTLSyAbHiQ==", 202 | "dev": true 203 | }, 204 | "@typescript-eslint/typescript-estree": { 205 | "version": "3.10.1", 206 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-3.10.1.tgz", 207 | "integrity": "sha512-QbcXOuq6WYvnB3XPsZpIwztBoquEYLXh2MtwVU+kO8jgYCiv4G5xrSP/1wg4tkvrEE+esZVquIPX/dxPlePk1w==", 208 | "dev": true, 209 | "requires": { 210 | "@typescript-eslint/types": "3.10.1", 211 | "@typescript-eslint/visitor-keys": "3.10.1", 212 | "debug": "^4.1.1", 213 | "glob": "^7.1.6", 214 | "is-glob": "^4.0.1", 215 | "lodash": "^4.17.15", 216 | "semver": "^7.3.2", 217 | "tsutils": "^3.17.1" 218 | }, 219 | "dependencies": { 220 | "debug": { 221 | "version": "4.2.0", 222 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", 223 | "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", 224 | "dev": true, 225 | "requires": { 226 | "ms": "2.1.2" 227 | } 228 | }, 229 | "glob": { 230 | "version": "7.1.6", 231 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 232 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 233 | "dev": true, 234 | "requires": { 235 | "fs.realpath": "^1.0.0", 236 | "inflight": "^1.0.4", 237 | "inherits": "2", 238 | "minimatch": "^3.0.4", 239 | "once": "^1.3.0", 240 | "path-is-absolute": "^1.0.0" 241 | } 242 | }, 243 | "ms": { 244 | "version": "2.1.2", 245 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 246 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 247 | "dev": true 248 | }, 249 | "semver": { 250 | "version": "7.3.2", 251 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 252 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 253 | "dev": true 254 | } 255 | } 256 | }, 257 | "@typescript-eslint/visitor-keys": { 258 | "version": "3.10.1", 259 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-3.10.1.tgz", 260 | "integrity": "sha512-9JgC82AaQeglebjZMgYR5wgmfUdUc+EitGUUMW8u2nDckaeimzW+VsoLV6FoimPv2id3VQzfjwBxEMVz08ameQ==", 261 | "dev": true, 262 | "requires": { 263 | "eslint-visitor-keys": "^1.1.0" 264 | }, 265 | "dependencies": { 266 | "eslint-visitor-keys": { 267 | "version": "1.3.0", 268 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 269 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 270 | "dev": true 271 | } 272 | } 273 | }, 274 | "acorn": { 275 | "version": "7.4.1", 276 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 277 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 278 | "dev": true 279 | }, 280 | "acorn-jsx": { 281 | "version": "5.3.1", 282 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 283 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 284 | "dev": true 285 | }, 286 | "agent-base": { 287 | "version": "4.3.0", 288 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-4.3.0.tgz", 289 | "integrity": "sha512-salcGninV0nPrwpGNn4VTXBb1SOuXQBiqbrNXoeizJsHrsL6ERFM2Ne3JUSBWRE6aeNJI2ROP/WEEIDUiDe3cg==", 290 | "dev": true, 291 | "requires": { 292 | "es6-promisify": "^5.0.0" 293 | } 294 | }, 295 | "ajv": { 296 | "version": "6.12.6", 297 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 298 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 299 | "dev": true, 300 | "requires": { 301 | "fast-deep-equal": "^3.1.1", 302 | "fast-json-stable-stringify": "^2.0.0", 303 | "json-schema-traverse": "^0.4.1", 304 | "uri-js": "^4.2.2" 305 | } 306 | }, 307 | "ansi-colors": { 308 | "version": "3.2.3", 309 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 310 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 311 | "dev": true 312 | }, 313 | "ansi-regex": { 314 | "version": "5.0.0", 315 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 316 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" 317 | }, 318 | "ansi-styles": { 319 | "version": "3.2.1", 320 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 321 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 322 | "dev": true, 323 | "requires": { 324 | "color-convert": "^1.9.0" 325 | } 326 | }, 327 | "argparse": { 328 | "version": "1.0.10", 329 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 330 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 331 | "dev": true, 332 | "requires": { 333 | "sprintf-js": "~1.0.2" 334 | } 335 | }, 336 | "astral-regex": { 337 | "version": "1.0.0", 338 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 339 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 340 | "dev": true 341 | }, 342 | "balanced-match": { 343 | "version": "1.0.0", 344 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 345 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 346 | }, 347 | "brace-expansion": { 348 | "version": "1.1.11", 349 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 350 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 351 | "requires": { 352 | "balanced-match": "^1.0.0", 353 | "concat-map": "0.0.1" 354 | } 355 | }, 356 | "browser-stdout": { 357 | "version": "1.3.1", 358 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 359 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 360 | "dev": true 361 | }, 362 | "callsites": { 363 | "version": "3.1.0", 364 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 365 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 366 | "dev": true 367 | }, 368 | "camelcase": { 369 | "version": "5.3.1", 370 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 371 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 372 | "dev": true 373 | }, 374 | "chalk": { 375 | "version": "2.4.2", 376 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 377 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 378 | "dev": true, 379 | "requires": { 380 | "ansi-styles": "^3.2.1", 381 | "escape-string-regexp": "^1.0.5", 382 | "supports-color": "^5.3.0" 383 | }, 384 | "dependencies": { 385 | "supports-color": { 386 | "version": "5.5.0", 387 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 388 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 389 | "dev": true, 390 | "requires": { 391 | "has-flag": "^3.0.0" 392 | } 393 | } 394 | } 395 | }, 396 | "cliui": { 397 | "version": "5.0.0", 398 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 399 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 400 | "dev": true, 401 | "requires": { 402 | "string-width": "^3.1.0", 403 | "strip-ansi": "^5.2.0", 404 | "wrap-ansi": "^5.1.0" 405 | }, 406 | "dependencies": { 407 | "ansi-regex": { 408 | "version": "4.1.0", 409 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 410 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 411 | "dev": true 412 | }, 413 | "string-width": { 414 | "version": "3.1.0", 415 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 416 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 417 | "dev": true, 418 | "requires": { 419 | "emoji-regex": "^7.0.1", 420 | "is-fullwidth-code-point": "^2.0.0", 421 | "strip-ansi": "^5.1.0" 422 | } 423 | }, 424 | "strip-ansi": { 425 | "version": "5.2.0", 426 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 427 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 428 | "dev": true, 429 | "requires": { 430 | "ansi-regex": "^4.1.0" 431 | } 432 | } 433 | } 434 | }, 435 | "color-convert": { 436 | "version": "1.9.3", 437 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 438 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 439 | "dev": true, 440 | "requires": { 441 | "color-name": "1.1.3" 442 | } 443 | }, 444 | "color-name": { 445 | "version": "1.1.3", 446 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 447 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 448 | "dev": true 449 | }, 450 | "concat-map": { 451 | "version": "0.0.1", 452 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 453 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 454 | }, 455 | "cross-spawn": { 456 | "version": "7.0.3", 457 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 458 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 459 | "dev": true, 460 | "requires": { 461 | "path-key": "^3.1.0", 462 | "shebang-command": "^2.0.0", 463 | "which": "^2.0.1" 464 | }, 465 | "dependencies": { 466 | "which": { 467 | "version": "2.0.2", 468 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 469 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 470 | "dev": true, 471 | "requires": { 472 | "isexe": "^2.0.0" 473 | } 474 | } 475 | } 476 | }, 477 | "debug": { 478 | "version": "3.2.6", 479 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 480 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 481 | "dev": true, 482 | "requires": { 483 | "ms": "^2.1.1" 484 | } 485 | }, 486 | "decamelize": { 487 | "version": "1.2.0", 488 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 489 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 490 | "dev": true 491 | }, 492 | "deep-is": { 493 | "version": "0.1.3", 494 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 495 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 496 | "dev": true 497 | }, 498 | "define-properties": { 499 | "version": "1.1.3", 500 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 501 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 502 | "dev": true, 503 | "requires": { 504 | "object-keys": "^1.0.12" 505 | } 506 | }, 507 | "diff": { 508 | "version": "3.5.0", 509 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 510 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 511 | "dev": true 512 | }, 513 | "doctrine": { 514 | "version": "3.0.0", 515 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 516 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 517 | "dev": true, 518 | "requires": { 519 | "esutils": "^2.0.2" 520 | } 521 | }, 522 | "emoji-regex": { 523 | "version": "7.0.3", 524 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 525 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 526 | "dev": true 527 | }, 528 | "enquirer": { 529 | "version": "2.3.6", 530 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 531 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 532 | "dev": true, 533 | "requires": { 534 | "ansi-colors": "^4.1.1" 535 | }, 536 | "dependencies": { 537 | "ansi-colors": { 538 | "version": "4.1.1", 539 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 540 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 541 | "dev": true 542 | } 543 | } 544 | }, 545 | "es-abstract": { 546 | "version": "1.15.0", 547 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.15.0.tgz", 548 | "integrity": "sha512-bhkEqWJ2t2lMeaJDuk7okMkJWI/yqgH/EoGwpcvv0XW9RWQsRspI4wt6xuyuvMvvQE3gg/D9HXppgk21w78GyQ==", 549 | "dev": true, 550 | "requires": { 551 | "es-to-primitive": "^1.2.0", 552 | "function-bind": "^1.1.1", 553 | "has": "^1.0.3", 554 | "has-symbols": "^1.0.0", 555 | "is-callable": "^1.1.4", 556 | "is-regex": "^1.0.4", 557 | "object-inspect": "^1.6.0", 558 | "object-keys": "^1.1.1", 559 | "string.prototype.trimleft": "^2.1.0", 560 | "string.prototype.trimright": "^2.1.0" 561 | } 562 | }, 563 | "es-to-primitive": { 564 | "version": "1.2.0", 565 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 566 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 567 | "dev": true, 568 | "requires": { 569 | "is-callable": "^1.1.4", 570 | "is-date-object": "^1.0.1", 571 | "is-symbol": "^1.0.2" 572 | } 573 | }, 574 | "es6-promise": { 575 | "version": "4.2.8", 576 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", 577 | "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", 578 | "dev": true 579 | }, 580 | "es6-promisify": { 581 | "version": "5.0.0", 582 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz", 583 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 584 | "dev": true, 585 | "requires": { 586 | "es6-promise": "^4.0.3" 587 | } 588 | }, 589 | "escape-string-regexp": { 590 | "version": "1.0.5", 591 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 592 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 593 | "dev": true 594 | }, 595 | "eslint": { 596 | "version": "7.11.0", 597 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.11.0.tgz", 598 | "integrity": "sha512-G9+qtYVCHaDi1ZuWzBsOWo2wSwd70TXnU6UHA3cTYHp7gCTXZcpggWFoUVAMRarg68qtPoNfFbzPh+VdOgmwmw==", 599 | "dev": true, 600 | "requires": { 601 | "@babel/code-frame": "^7.0.0", 602 | "@eslint/eslintrc": "^0.1.3", 603 | "ajv": "^6.10.0", 604 | "chalk": "^4.0.0", 605 | "cross-spawn": "^7.0.2", 606 | "debug": "^4.0.1", 607 | "doctrine": "^3.0.0", 608 | "enquirer": "^2.3.5", 609 | "eslint-scope": "^5.1.1", 610 | "eslint-utils": "^2.1.0", 611 | "eslint-visitor-keys": "^2.0.0", 612 | "espree": "^7.3.0", 613 | "esquery": "^1.2.0", 614 | "esutils": "^2.0.2", 615 | "file-entry-cache": "^5.0.1", 616 | "functional-red-black-tree": "^1.0.1", 617 | "glob-parent": "^5.0.0", 618 | "globals": "^12.1.0", 619 | "ignore": "^4.0.6", 620 | "import-fresh": "^3.0.0", 621 | "imurmurhash": "^0.1.4", 622 | "is-glob": "^4.0.0", 623 | "js-yaml": "^3.13.1", 624 | "json-stable-stringify-without-jsonify": "^1.0.1", 625 | "levn": "^0.4.1", 626 | "lodash": "^4.17.19", 627 | "minimatch": "^3.0.4", 628 | "natural-compare": "^1.4.0", 629 | "optionator": "^0.9.1", 630 | "progress": "^2.0.0", 631 | "regexpp": "^3.1.0", 632 | "semver": "^7.2.1", 633 | "strip-ansi": "^6.0.0", 634 | "strip-json-comments": "^3.1.0", 635 | "table": "^5.2.3", 636 | "text-table": "^0.2.0", 637 | "v8-compile-cache": "^2.0.3" 638 | }, 639 | "dependencies": { 640 | "ansi-styles": { 641 | "version": "4.3.0", 642 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 643 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 644 | "dev": true, 645 | "requires": { 646 | "color-convert": "^2.0.1" 647 | } 648 | }, 649 | "chalk": { 650 | "version": "4.1.0", 651 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 652 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 653 | "dev": true, 654 | "requires": { 655 | "ansi-styles": "^4.1.0", 656 | "supports-color": "^7.1.0" 657 | } 658 | }, 659 | "color-convert": { 660 | "version": "2.0.1", 661 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 662 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 663 | "dev": true, 664 | "requires": { 665 | "color-name": "~1.1.4" 666 | } 667 | }, 668 | "color-name": { 669 | "version": "1.1.4", 670 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 671 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 672 | "dev": true 673 | }, 674 | "debug": { 675 | "version": "4.2.0", 676 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.2.0.tgz", 677 | "integrity": "sha512-IX2ncY78vDTjZMFUdmsvIRFY2Cf4FnD0wRs+nQwJU8Lu99/tPFdb0VybiiMTPe3I6rQmwsqQqRBvxU+bZ/I8sg==", 678 | "dev": true, 679 | "requires": { 680 | "ms": "2.1.2" 681 | } 682 | }, 683 | "has-flag": { 684 | "version": "4.0.0", 685 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 686 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 687 | "dev": true 688 | }, 689 | "ms": { 690 | "version": "2.1.2", 691 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 692 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 693 | "dev": true 694 | }, 695 | "semver": { 696 | "version": "7.3.2", 697 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 698 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 699 | "dev": true 700 | }, 701 | "strip-json-comments": { 702 | "version": "3.1.1", 703 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 704 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 705 | "dev": true 706 | }, 707 | "supports-color": { 708 | "version": "7.2.0", 709 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 710 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 711 | "dev": true, 712 | "requires": { 713 | "has-flag": "^4.0.0" 714 | } 715 | } 716 | } 717 | }, 718 | "eslint-config-prettier": { 719 | "version": "6.12.0", 720 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.12.0.tgz", 721 | "integrity": "sha512-9jWPlFlgNwRUYVoujvWTQ1aMO8o6648r+K7qU7K5Jmkbyqav1fuEZC0COYpGBxyiAJb65Ra9hrmFx19xRGwXWw==", 722 | "dev": true, 723 | "requires": { 724 | "get-stdin": "^6.0.0" 725 | } 726 | }, 727 | "eslint-plugin-adonis": { 728 | "version": "1.0.15", 729 | "resolved": "https://registry.npmjs.org/eslint-plugin-adonis/-/eslint-plugin-adonis-1.0.15.tgz", 730 | "integrity": "sha512-IIyDodzFqVCjE2tz6NuRAME0mFrv5/2SR+4GbM+AwU2dKJHSVFxANzZipxsbtTl3/OgFH2TDbOI9a1WH1cAuBA==", 731 | "dev": true, 732 | "requires": { 733 | "@typescript-eslint/eslint-plugin": "^3.10.1", 734 | "@typescript-eslint/parser": "^3.10.1" 735 | } 736 | }, 737 | "eslint-plugin-prettier": { 738 | "version": "3.1.4", 739 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.1.4.tgz", 740 | "integrity": "sha512-jZDa8z76klRqo+TdGDTFJSavwbnWK2ZpqGKNZ+VvweMW516pDUMmQ2koXvxEE4JhzNvTv+radye/bWGBmA6jmg==", 741 | "dev": true, 742 | "requires": { 743 | "prettier-linter-helpers": "^1.0.0" 744 | } 745 | }, 746 | "eslint-scope": { 747 | "version": "5.1.1", 748 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 749 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 750 | "dev": true, 751 | "requires": { 752 | "esrecurse": "^4.3.0", 753 | "estraverse": "^4.1.1" 754 | } 755 | }, 756 | "eslint-utils": { 757 | "version": "2.1.0", 758 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 759 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 760 | "dev": true, 761 | "requires": { 762 | "eslint-visitor-keys": "^1.1.0" 763 | }, 764 | "dependencies": { 765 | "eslint-visitor-keys": { 766 | "version": "1.3.0", 767 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 768 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 769 | "dev": true 770 | } 771 | } 772 | }, 773 | "eslint-visitor-keys": { 774 | "version": "2.0.0", 775 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 776 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 777 | "dev": true 778 | }, 779 | "espree": { 780 | "version": "7.3.0", 781 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.0.tgz", 782 | "integrity": "sha512-dksIWsvKCixn1yrEXO8UosNSxaDoSYpq9reEjZSbHLpT5hpaCAKTLBwq0RHtLrIr+c0ByiYzWT8KTMRzoRCNlw==", 783 | "dev": true, 784 | "requires": { 785 | "acorn": "^7.4.0", 786 | "acorn-jsx": "^5.2.0", 787 | "eslint-visitor-keys": "^1.3.0" 788 | }, 789 | "dependencies": { 790 | "eslint-visitor-keys": { 791 | "version": "1.3.0", 792 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 793 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 794 | "dev": true 795 | } 796 | } 797 | }, 798 | "esprima": { 799 | "version": "4.0.1", 800 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 801 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 802 | "dev": true 803 | }, 804 | "esquery": { 805 | "version": "1.3.1", 806 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 807 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 808 | "dev": true, 809 | "requires": { 810 | "estraverse": "^5.1.0" 811 | }, 812 | "dependencies": { 813 | "estraverse": { 814 | "version": "5.2.0", 815 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 816 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 817 | "dev": true 818 | } 819 | } 820 | }, 821 | "esrecurse": { 822 | "version": "4.3.0", 823 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 824 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 825 | "dev": true, 826 | "requires": { 827 | "estraverse": "^5.2.0" 828 | }, 829 | "dependencies": { 830 | "estraverse": { 831 | "version": "5.2.0", 832 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 833 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 834 | "dev": true 835 | } 836 | } 837 | }, 838 | "estraverse": { 839 | "version": "4.3.0", 840 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 841 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 842 | "dev": true 843 | }, 844 | "esutils": { 845 | "version": "2.0.3", 846 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 847 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 848 | "dev": true 849 | }, 850 | "fast-deep-equal": { 851 | "version": "3.1.3", 852 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 853 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 854 | "dev": true 855 | }, 856 | "fast-diff": { 857 | "version": "1.2.0", 858 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 859 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 860 | "dev": true 861 | }, 862 | "fast-json-stable-stringify": { 863 | "version": "2.1.0", 864 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 865 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 866 | "dev": true 867 | }, 868 | "fast-levenshtein": { 869 | "version": "2.0.6", 870 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 871 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 872 | "dev": true 873 | }, 874 | "file-entry-cache": { 875 | "version": "5.0.1", 876 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 877 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 878 | "dev": true, 879 | "requires": { 880 | "flat-cache": "^2.0.1" 881 | } 882 | }, 883 | "find-up": { 884 | "version": "3.0.0", 885 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 886 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 887 | "dev": true, 888 | "requires": { 889 | "locate-path": "^3.0.0" 890 | } 891 | }, 892 | "flat": { 893 | "version": "4.1.0", 894 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 895 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 896 | "dev": true, 897 | "requires": { 898 | "is-buffer": "~2.0.3" 899 | } 900 | }, 901 | "flat-cache": { 902 | "version": "2.0.1", 903 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 904 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 905 | "dev": true, 906 | "requires": { 907 | "flatted": "^2.0.0", 908 | "rimraf": "2.6.3", 909 | "write": "1.0.3" 910 | }, 911 | "dependencies": { 912 | "rimraf": { 913 | "version": "2.6.3", 914 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 915 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 916 | "dev": true, 917 | "requires": { 918 | "glob": "^7.1.3" 919 | } 920 | } 921 | } 922 | }, 923 | "flatted": { 924 | "version": "2.0.2", 925 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 926 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 927 | "dev": true 928 | }, 929 | "fs.realpath": { 930 | "version": "1.0.0", 931 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 932 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 933 | }, 934 | "function-bind": { 935 | "version": "1.1.1", 936 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 937 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 938 | "dev": true 939 | }, 940 | "functional-red-black-tree": { 941 | "version": "1.0.1", 942 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 943 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 944 | "dev": true 945 | }, 946 | "get-caller-file": { 947 | "version": "2.0.5", 948 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 949 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 950 | "dev": true 951 | }, 952 | "get-stdin": { 953 | "version": "6.0.0", 954 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", 955 | "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", 956 | "dev": true 957 | }, 958 | "glob": { 959 | "version": "7.1.5", 960 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.5.tgz", 961 | "integrity": "sha512-J9dlskqUXK1OeTOYBEn5s8aMukWMwWfs+rPTn/jn50Ux4MNXVhubL1wu/j2t+H4NVI+cXEcCaYellqaPVGXNqQ==", 962 | "requires": { 963 | "fs.realpath": "^1.0.0", 964 | "inflight": "^1.0.4", 965 | "inherits": "2", 966 | "minimatch": "^3.0.4", 967 | "once": "^1.3.0", 968 | "path-is-absolute": "^1.0.0" 969 | } 970 | }, 971 | "glob-parent": { 972 | "version": "5.1.1", 973 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 974 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 975 | "dev": true, 976 | "requires": { 977 | "is-glob": "^4.0.1" 978 | } 979 | }, 980 | "globals": { 981 | "version": "12.4.0", 982 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 983 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 984 | "dev": true, 985 | "requires": { 986 | "type-fest": "^0.8.1" 987 | } 988 | }, 989 | "growl": { 990 | "version": "1.10.5", 991 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 992 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 993 | "dev": true 994 | }, 995 | "has": { 996 | "version": "1.0.3", 997 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 998 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 999 | "dev": true, 1000 | "requires": { 1001 | "function-bind": "^1.1.1" 1002 | } 1003 | }, 1004 | "has-flag": { 1005 | "version": "3.0.0", 1006 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1007 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1008 | "dev": true 1009 | }, 1010 | "has-symbols": { 1011 | "version": "1.0.0", 1012 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 1013 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 1014 | "dev": true 1015 | }, 1016 | "he": { 1017 | "version": "1.2.0", 1018 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1019 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1020 | "dev": true 1021 | }, 1022 | "http-proxy-agent": { 1023 | "version": "2.1.0", 1024 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-2.1.0.tgz", 1025 | "integrity": "sha512-qwHbBLV7WviBl0rQsOzH6o5lwyOIvwp/BdFnvVxXORldu5TmjFfjzBcWUWS5kWAZhmv+JtiDhSuQCp4sBfbIgg==", 1026 | "dev": true, 1027 | "requires": { 1028 | "agent-base": "4", 1029 | "debug": "3.1.0" 1030 | }, 1031 | "dependencies": { 1032 | "debug": { 1033 | "version": "3.1.0", 1034 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1035 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1036 | "dev": true, 1037 | "requires": { 1038 | "ms": "2.0.0" 1039 | } 1040 | }, 1041 | "ms": { 1042 | "version": "2.0.0", 1043 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1044 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1045 | "dev": true 1046 | } 1047 | } 1048 | }, 1049 | "https-proxy-agent": { 1050 | "version": "2.2.3", 1051 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-2.2.3.tgz", 1052 | "integrity": "sha512-Ytgnz23gm2DVftnzqRRz2dOXZbGd2uiajSw/95bPp6v53zPRspQjLm/AfBgqbJ2qfeRXWIOMVLpp86+/5yX39Q==", 1053 | "dev": true, 1054 | "requires": { 1055 | "agent-base": "^4.3.0", 1056 | "debug": "^3.1.0" 1057 | } 1058 | }, 1059 | "ignore": { 1060 | "version": "4.0.6", 1061 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1062 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1063 | "dev": true 1064 | }, 1065 | "import-fresh": { 1066 | "version": "3.2.1", 1067 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 1068 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 1069 | "dev": true, 1070 | "requires": { 1071 | "parent-module": "^1.0.0", 1072 | "resolve-from": "^4.0.0" 1073 | } 1074 | }, 1075 | "imurmurhash": { 1076 | "version": "0.1.4", 1077 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1078 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1079 | "dev": true 1080 | }, 1081 | "inflight": { 1082 | "version": "1.0.6", 1083 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1084 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1085 | "requires": { 1086 | "once": "^1.3.0", 1087 | "wrappy": "1" 1088 | } 1089 | }, 1090 | "inherits": { 1091 | "version": "2.0.4", 1092 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1093 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1094 | }, 1095 | "is-buffer": { 1096 | "version": "2.0.4", 1097 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1098 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1099 | "dev": true 1100 | }, 1101 | "is-callable": { 1102 | "version": "1.1.4", 1103 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1104 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 1105 | "dev": true 1106 | }, 1107 | "is-date-object": { 1108 | "version": "1.0.1", 1109 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1110 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1111 | "dev": true 1112 | }, 1113 | "is-extglob": { 1114 | "version": "2.1.1", 1115 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1116 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1117 | "dev": true 1118 | }, 1119 | "is-fullwidth-code-point": { 1120 | "version": "2.0.0", 1121 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1122 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1123 | "dev": true 1124 | }, 1125 | "is-glob": { 1126 | "version": "4.0.1", 1127 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1128 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1129 | "dev": true, 1130 | "requires": { 1131 | "is-extglob": "^2.1.1" 1132 | } 1133 | }, 1134 | "is-regex": { 1135 | "version": "1.0.4", 1136 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1137 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1138 | "dev": true, 1139 | "requires": { 1140 | "has": "^1.0.1" 1141 | } 1142 | }, 1143 | "is-symbol": { 1144 | "version": "1.0.2", 1145 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1146 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1147 | "dev": true, 1148 | "requires": { 1149 | "has-symbols": "^1.0.0" 1150 | } 1151 | }, 1152 | "isexe": { 1153 | "version": "2.0.0", 1154 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1155 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1156 | "dev": true 1157 | }, 1158 | "js-tokens": { 1159 | "version": "4.0.0", 1160 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1161 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1162 | "dev": true 1163 | }, 1164 | "js-yaml": { 1165 | "version": "3.13.1", 1166 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1167 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1168 | "dev": true, 1169 | "requires": { 1170 | "argparse": "^1.0.7", 1171 | "esprima": "^4.0.0" 1172 | } 1173 | }, 1174 | "json-schema-traverse": { 1175 | "version": "0.4.1", 1176 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1177 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1178 | "dev": true 1179 | }, 1180 | "json-stable-stringify-without-jsonify": { 1181 | "version": "1.0.1", 1182 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1183 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1184 | "dev": true 1185 | }, 1186 | "levn": { 1187 | "version": "0.4.1", 1188 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1189 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1190 | "dev": true, 1191 | "requires": { 1192 | "prelude-ls": "^1.2.1", 1193 | "type-check": "~0.4.0" 1194 | } 1195 | }, 1196 | "locate-path": { 1197 | "version": "3.0.0", 1198 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1199 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1200 | "dev": true, 1201 | "requires": { 1202 | "p-locate": "^3.0.0", 1203 | "path-exists": "^3.0.0" 1204 | } 1205 | }, 1206 | "lodash": { 1207 | "version": "4.17.19", 1208 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 1209 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 1210 | "dev": true 1211 | }, 1212 | "log-symbols": { 1213 | "version": "2.2.0", 1214 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", 1215 | "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", 1216 | "dev": true, 1217 | "requires": { 1218 | "chalk": "^2.0.1" 1219 | } 1220 | }, 1221 | "minimatch": { 1222 | "version": "3.0.4", 1223 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1224 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1225 | "requires": { 1226 | "brace-expansion": "^1.1.7" 1227 | } 1228 | }, 1229 | "minimist": { 1230 | "version": "0.0.8", 1231 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1232 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1233 | "dev": true 1234 | }, 1235 | "mkdirp": { 1236 | "version": "0.5.1", 1237 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1238 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1239 | "dev": true, 1240 | "requires": { 1241 | "minimist": "0.0.8" 1242 | } 1243 | }, 1244 | "mocha": { 1245 | "version": "6.2.1", 1246 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-6.2.1.tgz", 1247 | "integrity": "sha512-VCcWkLHwk79NYQc8cxhkmI8IigTIhsCwZ6RTxQsqK6go4UvEhzJkYuHm8B2YtlSxcYq2fY+ucr4JBwoD6ci80A==", 1248 | "dev": true, 1249 | "requires": { 1250 | "ansi-colors": "3.2.3", 1251 | "browser-stdout": "1.3.1", 1252 | "debug": "3.2.6", 1253 | "diff": "3.5.0", 1254 | "escape-string-regexp": "1.0.5", 1255 | "find-up": "3.0.0", 1256 | "glob": "7.1.3", 1257 | "growl": "1.10.5", 1258 | "he": "1.2.0", 1259 | "js-yaml": "3.13.1", 1260 | "log-symbols": "2.2.0", 1261 | "minimatch": "3.0.4", 1262 | "mkdirp": "0.5.1", 1263 | "ms": "2.1.1", 1264 | "node-environment-flags": "1.0.5", 1265 | "object.assign": "4.1.0", 1266 | "strip-json-comments": "2.0.1", 1267 | "supports-color": "6.0.0", 1268 | "which": "1.3.1", 1269 | "wide-align": "1.1.3", 1270 | "yargs": "13.3.0", 1271 | "yargs-parser": "13.1.1", 1272 | "yargs-unparser": "1.6.0" 1273 | }, 1274 | "dependencies": { 1275 | "glob": { 1276 | "version": "7.1.3", 1277 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1278 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1279 | "dev": true, 1280 | "requires": { 1281 | "fs.realpath": "^1.0.0", 1282 | "inflight": "^1.0.4", 1283 | "inherits": "2", 1284 | "minimatch": "^3.0.4", 1285 | "once": "^1.3.0", 1286 | "path-is-absolute": "^1.0.0" 1287 | } 1288 | } 1289 | } 1290 | }, 1291 | "ms": { 1292 | "version": "2.1.1", 1293 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1294 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1295 | "dev": true 1296 | }, 1297 | "natural-compare": { 1298 | "version": "1.4.0", 1299 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1300 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1301 | "dev": true 1302 | }, 1303 | "node-environment-flags": { 1304 | "version": "1.0.5", 1305 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.5.tgz", 1306 | "integrity": "sha512-VNYPRfGfmZLx0Ye20jWzHUjyTW/c+6Wq+iLhDzUI4XmhrDd9l/FozXV3F2xOaXjvp0co0+v1YSR3CMP6g+VvLQ==", 1307 | "dev": true, 1308 | "requires": { 1309 | "object.getownpropertydescriptors": "^2.0.3", 1310 | "semver": "^5.7.0" 1311 | } 1312 | }, 1313 | "object-inspect": { 1314 | "version": "1.6.0", 1315 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.6.0.tgz", 1316 | "integrity": "sha512-GJzfBZ6DgDAmnuaM3104jR4s1Myxr3Y3zfIyN4z3UdqN69oSRacNK8UhnobDdC+7J2AHCjGwxQubNJfE70SXXQ==", 1317 | "dev": true 1318 | }, 1319 | "object-keys": { 1320 | "version": "1.1.1", 1321 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1322 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1323 | "dev": true 1324 | }, 1325 | "object.assign": { 1326 | "version": "4.1.0", 1327 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1328 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1329 | "dev": true, 1330 | "requires": { 1331 | "define-properties": "^1.1.2", 1332 | "function-bind": "^1.1.1", 1333 | "has-symbols": "^1.0.0", 1334 | "object-keys": "^1.0.11" 1335 | } 1336 | }, 1337 | "object.getownpropertydescriptors": { 1338 | "version": "2.0.3", 1339 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", 1340 | "integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=", 1341 | "dev": true, 1342 | "requires": { 1343 | "define-properties": "^1.1.2", 1344 | "es-abstract": "^1.5.1" 1345 | } 1346 | }, 1347 | "once": { 1348 | "version": "1.4.0", 1349 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1350 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1351 | "requires": { 1352 | "wrappy": "1" 1353 | } 1354 | }, 1355 | "optionator": { 1356 | "version": "0.9.1", 1357 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1358 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1359 | "dev": true, 1360 | "requires": { 1361 | "deep-is": "^0.1.3", 1362 | "fast-levenshtein": "^2.0.6", 1363 | "levn": "^0.4.1", 1364 | "prelude-ls": "^1.2.1", 1365 | "type-check": "^0.4.0", 1366 | "word-wrap": "^1.2.3" 1367 | } 1368 | }, 1369 | "p-limit": { 1370 | "version": "2.2.1", 1371 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.1.tgz", 1372 | "integrity": "sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg==", 1373 | "dev": true, 1374 | "requires": { 1375 | "p-try": "^2.0.0" 1376 | } 1377 | }, 1378 | "p-locate": { 1379 | "version": "3.0.0", 1380 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1381 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1382 | "dev": true, 1383 | "requires": { 1384 | "p-limit": "^2.0.0" 1385 | } 1386 | }, 1387 | "p-try": { 1388 | "version": "2.2.0", 1389 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1390 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1391 | "dev": true 1392 | }, 1393 | "parent-module": { 1394 | "version": "1.0.1", 1395 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1396 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1397 | "dev": true, 1398 | "requires": { 1399 | "callsites": "^3.0.0" 1400 | } 1401 | }, 1402 | "path-exists": { 1403 | "version": "3.0.0", 1404 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1405 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1406 | "dev": true 1407 | }, 1408 | "path-is-absolute": { 1409 | "version": "1.0.1", 1410 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1411 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1412 | }, 1413 | "path-key": { 1414 | "version": "3.1.1", 1415 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1416 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1417 | "dev": true 1418 | }, 1419 | "prelude-ls": { 1420 | "version": "1.2.1", 1421 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1422 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1423 | "dev": true 1424 | }, 1425 | "prettier": { 1426 | "version": "2.1.2", 1427 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.1.2.tgz", 1428 | "integrity": "sha512-16c7K+x4qVlJg9rEbXl7HEGmQyZlG4R9AgP+oHKRMsMsuk8s+ATStlf1NpDqyBI1HpVyfjLOeMhH2LvuNvV5Vg==", 1429 | "dev": true 1430 | }, 1431 | "prettier-linter-helpers": { 1432 | "version": "1.0.0", 1433 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 1434 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 1435 | "dev": true, 1436 | "requires": { 1437 | "fast-diff": "^1.1.2" 1438 | } 1439 | }, 1440 | "progress": { 1441 | "version": "2.0.3", 1442 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1443 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1444 | "dev": true 1445 | }, 1446 | "punycode": { 1447 | "version": "2.1.1", 1448 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1449 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1450 | "dev": true 1451 | }, 1452 | "regexpp": { 1453 | "version": "3.1.0", 1454 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1455 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1456 | "dev": true 1457 | }, 1458 | "require-directory": { 1459 | "version": "2.1.1", 1460 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1461 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1462 | "dev": true 1463 | }, 1464 | "require-main-filename": { 1465 | "version": "2.0.0", 1466 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1467 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1468 | "dev": true 1469 | }, 1470 | "resolve-from": { 1471 | "version": "4.0.0", 1472 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1473 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1474 | "dev": true 1475 | }, 1476 | "rimraf": { 1477 | "version": "2.7.1", 1478 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1479 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1480 | "dev": true, 1481 | "requires": { 1482 | "glob": "^7.1.3" 1483 | } 1484 | }, 1485 | "semver": { 1486 | "version": "5.7.1", 1487 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1488 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1489 | "dev": true 1490 | }, 1491 | "set-blocking": { 1492 | "version": "2.0.0", 1493 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1494 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1495 | "dev": true 1496 | }, 1497 | "shebang-command": { 1498 | "version": "2.0.0", 1499 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1500 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1501 | "dev": true, 1502 | "requires": { 1503 | "shebang-regex": "^3.0.0" 1504 | } 1505 | }, 1506 | "shebang-regex": { 1507 | "version": "3.0.0", 1508 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1509 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1510 | "dev": true 1511 | }, 1512 | "slice-ansi": { 1513 | "version": "2.1.0", 1514 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1515 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1516 | "dev": true, 1517 | "requires": { 1518 | "ansi-styles": "^3.2.0", 1519 | "astral-regex": "^1.0.0", 1520 | "is-fullwidth-code-point": "^2.0.0" 1521 | } 1522 | }, 1523 | "sprintf-js": { 1524 | "version": "1.0.3", 1525 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1526 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1527 | "dev": true 1528 | }, 1529 | "string-width": { 1530 | "version": "2.1.1", 1531 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1532 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1533 | "dev": true, 1534 | "requires": { 1535 | "is-fullwidth-code-point": "^2.0.0", 1536 | "strip-ansi": "^4.0.0" 1537 | }, 1538 | "dependencies": { 1539 | "ansi-regex": { 1540 | "version": "3.0.0", 1541 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1542 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1543 | "dev": true 1544 | }, 1545 | "strip-ansi": { 1546 | "version": "4.0.0", 1547 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1548 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1549 | "dev": true, 1550 | "requires": { 1551 | "ansi-regex": "^3.0.0" 1552 | } 1553 | } 1554 | } 1555 | }, 1556 | "string.prototype.trimleft": { 1557 | "version": "2.1.0", 1558 | "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.0.tgz", 1559 | "integrity": "sha512-FJ6b7EgdKxxbDxc79cOlok6Afd++TTs5szo+zJTUyow3ycrRfJVE2pq3vcN53XexvKZu/DJMDfeI/qMiZTrjTw==", 1560 | "dev": true, 1561 | "requires": { 1562 | "define-properties": "^1.1.3", 1563 | "function-bind": "^1.1.1" 1564 | } 1565 | }, 1566 | "string.prototype.trimright": { 1567 | "version": "2.1.0", 1568 | "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.0.tgz", 1569 | "integrity": "sha512-fXZTSV55dNBwv16uw+hh5jkghxSnc5oHq+5K/gXgizHwAvMetdAJlHqqoFC1FSDVPYWLkAKl2cxpUT41sV7nSg==", 1570 | "dev": true, 1571 | "requires": { 1572 | "define-properties": "^1.1.3", 1573 | "function-bind": "^1.1.1" 1574 | } 1575 | }, 1576 | "strip-ansi": { 1577 | "version": "6.0.0", 1578 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1579 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1580 | "requires": { 1581 | "ansi-regex": "^5.0.0" 1582 | } 1583 | }, 1584 | "strip-json-comments": { 1585 | "version": "2.0.1", 1586 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1587 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1588 | "dev": true 1589 | }, 1590 | "supports-color": { 1591 | "version": "6.0.0", 1592 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 1593 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 1594 | "dev": true, 1595 | "requires": { 1596 | "has-flag": "^3.0.0" 1597 | } 1598 | }, 1599 | "table": { 1600 | "version": "5.4.6", 1601 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 1602 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1603 | "dev": true, 1604 | "requires": { 1605 | "ajv": "^6.10.2", 1606 | "lodash": "^4.17.14", 1607 | "slice-ansi": "^2.1.0", 1608 | "string-width": "^3.0.0" 1609 | }, 1610 | "dependencies": { 1611 | "ansi-regex": { 1612 | "version": "4.1.0", 1613 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1614 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1615 | "dev": true 1616 | }, 1617 | "string-width": { 1618 | "version": "3.1.0", 1619 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1620 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1621 | "dev": true, 1622 | "requires": { 1623 | "emoji-regex": "^7.0.1", 1624 | "is-fullwidth-code-point": "^2.0.0", 1625 | "strip-ansi": "^5.1.0" 1626 | } 1627 | }, 1628 | "strip-ansi": { 1629 | "version": "5.2.0", 1630 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1631 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1632 | "dev": true, 1633 | "requires": { 1634 | "ansi-regex": "^4.1.0" 1635 | } 1636 | } 1637 | } 1638 | }, 1639 | "text-table": { 1640 | "version": "0.2.0", 1641 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1642 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1643 | "dev": true 1644 | }, 1645 | "tslib": { 1646 | "version": "1.14.1", 1647 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 1648 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 1649 | "dev": true 1650 | }, 1651 | "tsutils": { 1652 | "version": "3.17.1", 1653 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", 1654 | "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", 1655 | "dev": true, 1656 | "requires": { 1657 | "tslib": "^1.8.1" 1658 | } 1659 | }, 1660 | "type-check": { 1661 | "version": "0.4.0", 1662 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1663 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1664 | "dev": true, 1665 | "requires": { 1666 | "prelude-ls": "^1.2.1" 1667 | } 1668 | }, 1669 | "type-fest": { 1670 | "version": "0.8.1", 1671 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1672 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1673 | "dev": true 1674 | }, 1675 | "typescript": { 1676 | "version": "3.6.4", 1677 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.6.4.tgz", 1678 | "integrity": "sha512-unoCll1+l+YK4i4F8f22TaNVPRHcD9PA3yCuZ8g5e0qGqlVlJ/8FSateOLLSagn+Yg5+ZwuPkL8LFUc0Jcvksg==", 1679 | "dev": true 1680 | }, 1681 | "uri-js": { 1682 | "version": "4.4.0", 1683 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.0.tgz", 1684 | "integrity": "sha512-B0yRTzYdUCCn9n+F4+Gh4yIDtMQcaJsmYBDsTSG8g/OejKBodLQ2IHfN3bM7jUsRXndopT7OIXWdYqc1fjmV6g==", 1685 | "dev": true, 1686 | "requires": { 1687 | "punycode": "^2.1.0" 1688 | } 1689 | }, 1690 | "v8-compile-cache": { 1691 | "version": "2.1.1", 1692 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 1693 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 1694 | "dev": true 1695 | }, 1696 | "vscode-test": { 1697 | "version": "1.2.0", 1698 | "resolved": "https://registry.npmjs.org/vscode-test/-/vscode-test-1.2.0.tgz", 1699 | "integrity": "sha512-aowqgc8gZe0eflzVUXsBjBrlsJ8eC35kfgfSEeHu9PKA1vQKm/3rVK43TlbxGue8hKtZBElNAJ5QuYklR/vLJA==", 1700 | "dev": true, 1701 | "requires": { 1702 | "http-proxy-agent": "^2.1.0", 1703 | "https-proxy-agent": "^2.2.1", 1704 | "rimraf": "^2.6.3" 1705 | } 1706 | }, 1707 | "which": { 1708 | "version": "1.3.1", 1709 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1710 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1711 | "dev": true, 1712 | "requires": { 1713 | "isexe": "^2.0.0" 1714 | } 1715 | }, 1716 | "which-module": { 1717 | "version": "2.0.0", 1718 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1719 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 1720 | "dev": true 1721 | }, 1722 | "wide-align": { 1723 | "version": "1.1.3", 1724 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1725 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1726 | "dev": true, 1727 | "requires": { 1728 | "string-width": "^1.0.2 || 2" 1729 | } 1730 | }, 1731 | "word-wrap": { 1732 | "version": "1.2.3", 1733 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1734 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1735 | "dev": true 1736 | }, 1737 | "wrap-ansi": { 1738 | "version": "5.1.0", 1739 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 1740 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 1741 | "dev": true, 1742 | "requires": { 1743 | "ansi-styles": "^3.2.0", 1744 | "string-width": "^3.0.0", 1745 | "strip-ansi": "^5.0.0" 1746 | }, 1747 | "dependencies": { 1748 | "ansi-regex": { 1749 | "version": "4.1.0", 1750 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1751 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1752 | "dev": true 1753 | }, 1754 | "string-width": { 1755 | "version": "3.1.0", 1756 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1757 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1758 | "dev": true, 1759 | "requires": { 1760 | "emoji-regex": "^7.0.1", 1761 | "is-fullwidth-code-point": "^2.0.0", 1762 | "strip-ansi": "^5.1.0" 1763 | } 1764 | }, 1765 | "strip-ansi": { 1766 | "version": "5.2.0", 1767 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1768 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1769 | "dev": true, 1770 | "requires": { 1771 | "ansi-regex": "^4.1.0" 1772 | } 1773 | } 1774 | } 1775 | }, 1776 | "wrappy": { 1777 | "version": "1.0.2", 1778 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1779 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1780 | }, 1781 | "write": { 1782 | "version": "1.0.3", 1783 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 1784 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 1785 | "dev": true, 1786 | "requires": { 1787 | "mkdirp": "^0.5.1" 1788 | } 1789 | }, 1790 | "y18n": { 1791 | "version": "4.0.0", 1792 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 1793 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 1794 | "dev": true 1795 | }, 1796 | "yargs": { 1797 | "version": "13.3.0", 1798 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.0.tgz", 1799 | "integrity": "sha512-2eehun/8ALW8TLoIl7MVaRUrg+yCnenu8B4kBlRxj3GJGDKU1Og7sMXPNm1BYyM1DOJmTZ4YeN/Nwxv+8XJsUA==", 1800 | "dev": true, 1801 | "requires": { 1802 | "cliui": "^5.0.0", 1803 | "find-up": "^3.0.0", 1804 | "get-caller-file": "^2.0.1", 1805 | "require-directory": "^2.1.1", 1806 | "require-main-filename": "^2.0.0", 1807 | "set-blocking": "^2.0.0", 1808 | "string-width": "^3.0.0", 1809 | "which-module": "^2.0.0", 1810 | "y18n": "^4.0.0", 1811 | "yargs-parser": "^13.1.1" 1812 | }, 1813 | "dependencies": { 1814 | "ansi-regex": { 1815 | "version": "4.1.0", 1816 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1817 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1818 | "dev": true 1819 | }, 1820 | "string-width": { 1821 | "version": "3.1.0", 1822 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1823 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1824 | "dev": true, 1825 | "requires": { 1826 | "emoji-regex": "^7.0.1", 1827 | "is-fullwidth-code-point": "^2.0.0", 1828 | "strip-ansi": "^5.1.0" 1829 | } 1830 | }, 1831 | "strip-ansi": { 1832 | "version": "5.2.0", 1833 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1834 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1835 | "dev": true, 1836 | "requires": { 1837 | "ansi-regex": "^4.1.0" 1838 | } 1839 | } 1840 | } 1841 | }, 1842 | "yargs-parser": { 1843 | "version": "13.1.1", 1844 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.1.tgz", 1845 | "integrity": "sha512-oVAVsHz6uFrg3XQheFII8ESO2ssAf9luWuAd6Wexsu4F3OtIW0o8IribPXYrD4WC24LWtPrJlGy87y5udK+dxQ==", 1846 | "dev": true, 1847 | "requires": { 1848 | "camelcase": "^5.0.0", 1849 | "decamelize": "^1.2.0" 1850 | } 1851 | }, 1852 | "yargs-unparser": { 1853 | "version": "1.6.0", 1854 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 1855 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 1856 | "dev": true, 1857 | "requires": { 1858 | "flat": "^4.1.0", 1859 | "lodash": "^4.17.15", 1860 | "yargs": "^13.3.0" 1861 | } 1862 | } 1863 | } 1864 | } 1865 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "adonisjs", 3 | "displayName": "AdonisJS", 4 | "description": "Official extension for AdonisJS framework", 5 | "version": "0.0.1", 6 | "engines": { 7 | "vscode": "^1.39.0" 8 | }, 9 | "categories": [ 10 | "Other" 11 | ], 12 | "keywords": [ 13 | "adonis", 14 | "commands" 15 | ], 16 | "activationEvents": [ 17 | "workspaceContains:**/.adonisrc.json" 18 | ], 19 | "main": "./out/extension.js", 20 | "contributes": { 21 | "commands": [ 22 | { 23 | "title": "🚀 Adonis: Build", 24 | "command": "adonisjs.build" 25 | }, 26 | { 27 | "title": "🚀 Adonis: Invoke", 28 | "command": "adonisjs.invoke" 29 | }, 30 | { 31 | "title": "🚀 Adonis: DB Seed", 32 | "command": "adonisjs.db.seed" 33 | }, 34 | { 35 | "title": "🚀 Adonis: Make Command", 36 | "command": "adonisjs.make.command" 37 | }, 38 | { 39 | "title": "🚀 Adonis: Make Controller", 40 | "command": "adonisjs.make.controller" 41 | }, 42 | { 43 | "title": "🚀 Adonis: Make Exception", 44 | "command": "adonisjs.make.exception" 45 | }, 46 | { 47 | "title": "🚀 Adonis: Make Listener", 48 | "command": "adonisjs.make.listener" 49 | }, 50 | { 51 | "title": "🚀 Adonis: Make Middleware", 52 | "command": "adonisjs.make.middleware" 53 | }, 54 | { 55 | "title": "🚀 Adonis: Make Preload File", 56 | "command": "adonisjs.make.prldfile" 57 | }, 58 | { 59 | "title": "🚀 Adonis: Make Provider", 60 | "command": "adonisjs.make.provider" 61 | }, 62 | { 63 | "title": "🚀 Adonis: Make Validator", 64 | "command": "adonisjs.make.validator" 65 | }, 66 | { 67 | "title": "🚀 Adonis: Make View", 68 | "command": "adonisjs.make.view" 69 | }, 70 | { 71 | "title": "🚀 Adonis: Make Migration", 72 | "command": "adonisjs.make.migration" 73 | }, 74 | { 75 | "title": "🚀 Adonis: Make Model", 76 | "command": "adonisjs.make.model" 77 | }, 78 | { 79 | "title": "🚀 Adonis: Make Seed", 80 | "command": "adonisjs.make.seed" 81 | }, 82 | { 83 | "title": "🚀 Adonis: Migration Rollback", 84 | "command": "adonisjs.migration.rollback" 85 | }, 86 | { 87 | "title": "🚀 Adonis: Migration Run", 88 | "command": "adonisjs.migration.run" 89 | }, 90 | { 91 | "title": "🚀 Adonis: Migration Status", 92 | "command": "adonisjs.migration.status" 93 | } 94 | ], 95 | "configuration": { 96 | "type": "object", 97 | "title": "AdonisJS", 98 | "properties": { 99 | "adonisjs.tasks.disableOptionalValuePrompts": { 100 | "type": "boolean", 101 | "description": "Disable showing of prompts for optional fields. All commands will be ran with default values", 102 | "default": false 103 | }, 104 | "adonisjs.tasks.adonisExecutable": { 105 | "type": "string", 106 | "description": "Executable path for Adonis CLI", 107 | "default": "node ace" 108 | }, 109 | "adonisjs.tasks.maxBuffer": { 110 | "type": "integer", 111 | "description": "Buffer size for stdout and stderr", 112 | "default": 204800 113 | } 114 | } 115 | } 116 | }, 117 | "scripts": { 118 | "vscode:prepublish": "npm run compile", 119 | "format": "prettier --write .", 120 | "lint": "eslint . --ext=.ts", 121 | "compile": "npm run lint && tsc -p ./", 122 | "watch": "tsc -watch -p ./", 123 | "pretest": "npm run compile", 124 | "test": "node ./out/test/runTest.js" 125 | }, 126 | "devDependencies": { 127 | "@types/glob": "^7.1.1", 128 | "@types/mocha": "^5.2.6", 129 | "@types/node": "^10.12.21", 130 | "@types/vscode": "^1.39.0", 131 | "eslint": "^7.11.0", 132 | "eslint-config-prettier": "^6.12.0", 133 | "eslint-plugin-adonis": "^1.0.15", 134 | "eslint-plugin-prettier": "^3.1.4", 135 | "mocha": "^6.1.4", 136 | "prettier": "^2.1.2", 137 | "typescript": "^3.3.1", 138 | "vscode-test": "^1.2.0" 139 | }, 140 | "dependencies": { 141 | "glob": "^7.1.5", 142 | "strip-ansi": "^6.0.0" 143 | } 144 | } 145 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | import { ExtensionContext } from 'vscode' 2 | import Tasks from './tasks' 3 | 4 | export function activate(context: ExtensionContext) { 5 | const tasks = Tasks() 6 | 7 | context.subscriptions.push(...tasks) 8 | } 9 | 10 | export function deactivate() {} 11 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/build.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../types' 2 | import { CommandSteps } from '../../types/commandSteps' 3 | import InputValidation from '../../../utilities/inputValidation' 4 | 5 | enum ClientType { 6 | NPM = 'npm', 7 | Yarn = 'yarn', 8 | } 9 | 10 | const build = new CommandSteps( 11 | 'Compile typescript code to Javascript. Optionally watch for file changes', 12 | [ 13 | { 14 | param: 'watch', 15 | message: 'Watch filesystem and re-compile changes', 16 | optional: true, 17 | type: DataType.Boolean, 18 | }, 19 | { 20 | param: 'production', 21 | message: 'Build for production. This overrides watching.', 22 | optional: true, 23 | type: DataType.Boolean, 24 | }, 25 | { 26 | param: 'client', 27 | message: 'Select the package manager to decide which lock file to copy to the build folder', 28 | optional: true, 29 | type: ClientType, 30 | default: ClientType.NPM, 31 | }, 32 | { 33 | param: 'poll', 34 | message: 'Detect file changes by polling files instead of listening to filesystem events', 35 | optional: true, 36 | type: DataType.Boolean, 37 | }, 38 | ] 39 | ) 40 | 41 | export default build 42 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/invoke.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../types' 2 | import { CommandSteps } from '../../types/commandSteps' 3 | import InputValidation from '../../../utilities/inputValidation' 4 | 5 | const invoke = new CommandSteps('Invoke post install instructions on a given AdonisJS package', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the package for which to invoke post install instructions', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | ]) 13 | 14 | export default invoke 15 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/command.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeCommand = new CommandSteps('Make a new ace command', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the command class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | ]) 13 | 14 | export default makeCommand 15 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/controller.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeController = new CommandSteps('Make a new HTTP controller', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the controller class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | { 13 | param: 'resource', 14 | message: 'Create resourceful methods in the controller class?', 15 | optional: true, 16 | default: false, 17 | type: DataType.Boolean, 18 | }, 19 | ]) 20 | 21 | export default makeController 22 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/exception.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeException = new CommandSteps('Make a new exception handle', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the exception class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | { 13 | param: 'selfHandle', 14 | message: 'Add handle method to self handle the exception?', 15 | default: false, 16 | optional: true, 17 | type: DataType.Boolean, 18 | }, 19 | ]) 20 | 21 | export default makeException 22 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/listener.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeListener = new CommandSteps('Make a new event listener class', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the event listener class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | ]) 13 | 14 | export default makeListener 15 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/middleware.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeMiddleware = new CommandSteps('Make a new middleware', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the middleware class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | ]) 13 | 14 | export default makeMiddleware 15 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/preloadFile.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | enum Environment { 6 | Console = 'console', 7 | Web = 'web', 8 | Test = 'test', 9 | } 10 | 11 | const makeMiddleware = new CommandSteps( 12 | 'Make a new preloaded file. Preloaded files are loaded automatically on boot', 13 | [ 14 | { 15 | param: 'name', 16 | message: 'Name of the file', 17 | type: DataType.String, 18 | validateInput: InputValidation.notEmpty, 19 | }, 20 | { 21 | param: 'environment', 22 | message: 'Explicitly define the environment in which you want to load this file', 23 | type: Environment, 24 | optional: true, 25 | isMultiChoice: true, 26 | default: Environment.Console, 27 | validateInput: (input: string[]) => { 28 | const envs = Object.values(Environment) 29 | const notExists = InputValidation.existsIn(input, envs) 30 | if (notExists) return notExists 31 | }, 32 | }, 33 | ] 34 | ) 35 | 36 | export default makeMiddleware 37 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/provider.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeProvider = new CommandSteps('Make a new IoC container provider', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the provider class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | { 13 | param: 'ace', 14 | message: 'Registers provider under the ace providers array', 15 | optional: true, 16 | type: DataType.Boolean, 17 | }, 18 | ]) 19 | 20 | export default makeProvider 21 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/validator.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeValidator = new CommandSteps('Make a new validator', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the validator class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | ]) 13 | 14 | export default makeValidator 15 | -------------------------------------------------------------------------------- /src/tasks/commands/assembler/make/view.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeTrait = new CommandSteps('Make a new view template', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the view', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | ]) 13 | 14 | export default makeTrait 15 | -------------------------------------------------------------------------------- /src/tasks/commands/index.ts: -------------------------------------------------------------------------------- 1 | import { createVscodeCommand as createCommand } from '../../utilities/command' 2 | const VSCODE_COMMAND_BASE_NAME = 'adonisjs' 3 | 4 | // Assembler 5 | import assemblerBuild from './assembler/build' 6 | import assemblerInvoke from './assembler/invoke' 7 | import assemblerMakeCommand from './assembler/make/command' 8 | import assemblerMakeController from './assembler/make/controller' 9 | import assemblerMakeException from './assembler/make/exception' 10 | import assemblerMakeListener from './assembler/make/listener' 11 | import assemblerMakeMiddleware from './assembler/make/middleware' 12 | import assemblerMakePreloadFile from './assembler/make/preloadFile' 13 | import assemblerMakeProvider from './assembler/make/provider' 14 | import assemblerMakeValidator from './assembler/make/validator' 15 | import assemblerMakeView from './assembler/make/view' 16 | 17 | // Lucid 18 | import lucidMigrationRollback from './lucid/migration/rollback' 19 | import lucidMigrationRun from './lucid/migration/run' 20 | import lucidMigrationStatus from './lucid/migration/status' 21 | import lucidDbSeed from './lucid/db/seed' 22 | import lucidMakeMigration from './lucid/make/migration' 23 | import lucidMakeModel from './lucid/make/model' 24 | import lucidMakeSeeder from './lucid/make/seeder' 25 | 26 | const adonisCommands = { 27 | 'build': assemblerBuild, 28 | 'invoke': assemblerInvoke, 29 | 'db:seed': lucidDbSeed, 30 | 'make:command': assemblerMakeCommand, 31 | 'make:controller': assemblerMakeController, 32 | 'make:exception': assemblerMakeException, 33 | 'make:listener': assemblerMakeListener, 34 | 'make:middleware': assemblerMakeMiddleware, 35 | 'make:prldfile': assemblerMakePreloadFile, 36 | 'make:provider': assemblerMakeProvider, 37 | 'make:validator': assemblerMakeValidator, 38 | 'make:view': assemblerMakeView, 39 | 'make:migration': lucidMakeMigration, 40 | 'make:model': lucidMakeModel, 41 | 'make:seed': lucidMakeSeeder, 42 | 'migration:rollback': lucidMigrationRollback, 43 | 'migration:run': lucidMigrationRun, 44 | 'migration:status': lucidMigrationStatus, 45 | } 46 | 47 | export default Object.entries(adonisCommands).map(([key, steps]) => { 48 | return createCommand(key, steps, VSCODE_COMMAND_BASE_NAME) 49 | }) 50 | -------------------------------------------------------------------------------- /src/tasks/commands/lucid/db/seed.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const dbSeed = new CommandSteps('Execute database seeder files', [ 6 | { 7 | param: 'connection', 8 | message: 'Define a custom database connection', 9 | type: DataType.String, 10 | optional: true, 11 | validateInput: InputValidation.notEmpty, 12 | }, 13 | { 14 | param: 'interactive', 15 | message: 'Run seeders in interactive mode', 16 | type: DataType.Boolean, 17 | optional: true, 18 | }, 19 | { 20 | param: 'files', 21 | message: 'Define a custom set of seeders files names to run (separated with comma)', 22 | type: DataType.Array, 23 | optional: true, 24 | }, 25 | ]) 26 | 27 | export default dbSeed 28 | -------------------------------------------------------------------------------- /src/tasks/commands/lucid/make/migration.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeMigrations = new CommandSteps('Create a new migration file', [ 6 | { 7 | param: 'name', 8 | message: 'Name of migration file', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | { 13 | param: 'connection', 14 | message: 'Define a custom database connection for the migration', 15 | type: DataType.String, 16 | optional: true, 17 | validateInput: InputValidation.notEmpty, 18 | }, 19 | { 20 | param: 'folder', 21 | message: 'Pre-select a migration directory', 22 | type: DataType.String, 23 | optional: true, 24 | validateInput: InputValidation.notEmpty, 25 | }, 26 | { 27 | param: 'create', 28 | message: 'Define the table name for creating a new table', 29 | type: DataType.String, 30 | optional: true, 31 | validateInput: InputValidation.notEmpty, 32 | }, 33 | { 34 | param: 'table', 35 | message: 'Define the table name for altering an existing table', 36 | type: DataType.String, 37 | optional: true, 38 | validateInput: InputValidation.notEmpty, 39 | }, 40 | ]) 41 | 42 | export default makeMigrations 43 | -------------------------------------------------------------------------------- /src/tasks/commands/lucid/make/model.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeModel = new CommandSteps('Make a new Lucid model', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the model class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | { 13 | param: 'migration', 14 | message: 'Generate migration for the model', 15 | optional: true, 16 | type: DataType.Boolean, 17 | }, 18 | { 19 | param: 'controller', 20 | message: 'Generate the controller for the model', 21 | optional: true, 22 | type: DataType.Boolean, 23 | }, 24 | ]) 25 | 26 | export default makeModel 27 | -------------------------------------------------------------------------------- /src/tasks/commands/lucid/make/seeder.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const makeSeeder = new CommandSteps('Make a new Seeder file', [ 6 | { 7 | param: 'name', 8 | message: 'Name of the seeder class', 9 | type: DataType.String, 10 | validateInput: InputValidation.notEmpty, 11 | }, 12 | ]) 13 | 14 | export default makeSeeder 15 | -------------------------------------------------------------------------------- /src/tasks/commands/lucid/migration/rollback.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const migrationRollback = new CommandSteps('Rollback migrations to a given batch number', [ 6 | { 7 | param: 'connection', 8 | message: 'Define a custom database connection', 9 | type: DataType.String, 10 | optional: true, 11 | validateInput: InputValidation.notEmpty, 12 | }, 13 | { 14 | param: 'force', 15 | message: 'Explictly force to run migrations in production', 16 | type: DataType.Boolean, 17 | optional: true, 18 | }, 19 | { 20 | param: 'dryRun', 21 | message: 'Print SQL queries, instead of running the migrations', 22 | type: DataType.Boolean, 23 | optional: true, 24 | }, 25 | { 26 | param: 'batch', 27 | message: 'Define custom batch number for rollback. Use 0 to rollback to initial state', 28 | type: DataType.Integer, 29 | optional: true, 30 | validateInput: (input: string) => { 31 | const value = parseInt(input, 10) 32 | if (isNaN(value)) return 'Number is expected.' 33 | if (value < 0) return 'Number must be at least 0.' 34 | }, 35 | }, 36 | ]) 37 | 38 | export default migrationRollback 39 | -------------------------------------------------------------------------------- /src/tasks/commands/lucid/migration/run.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const migrationRun = new CommandSteps('Run pending migrations', [ 6 | { 7 | param: 'connection', 8 | message: 'Define a custom database connection', 9 | type: DataType.String, 10 | optional: true, 11 | validateInput: InputValidation.notEmpty, 12 | }, 13 | { 14 | param: 'force', 15 | message: 'Explictly force to run migrations in production', 16 | type: DataType.Boolean, 17 | optional: true, 18 | }, 19 | { 20 | param: 'dryRun', 21 | message: 'Print SQL queries, instead of running the migrations', 22 | type: DataType.Boolean, 23 | optional: true, 24 | }, 25 | ]) 26 | 27 | export default migrationRun 28 | -------------------------------------------------------------------------------- /src/tasks/commands/lucid/migration/status.ts: -------------------------------------------------------------------------------- 1 | import { DataType } from '../../../types' 2 | import { CommandSteps } from '../../../types/commandSteps' 3 | import InputValidation from '../../../../utilities/inputValidation' 4 | 5 | const migrationStatus = new CommandSteps('Check migrations current status', [ 6 | { 7 | param: 'connection', 8 | message: 'Define a custom database connection', 9 | type: DataType.String, 10 | optional: true, 11 | validateInput: InputValidation.notEmpty, 12 | }, 13 | ]) 14 | 15 | export default migrationStatus 16 | -------------------------------------------------------------------------------- /src/tasks/index.ts: -------------------------------------------------------------------------------- 1 | import Commands from './commands' 2 | import { commands, Disposable, window } from 'vscode' 3 | import { VscodeCommand, CommandOutput } from './types' 4 | import { showCommandOutput } from '../utilities/command' 5 | import { selectWorkspaceFolder } from '../utilities/workspace' 6 | 7 | /** 8 | * Execute the command provided. 9 | * 10 | * @param command Command to execute 11 | */ 12 | async function executeCommand(command: VscodeCommand) { 13 | try { 14 | // Collect user input 15 | const { Config } = await import('../utilities') 16 | const disableOptionalPrompts = Config.tasks.disableOptionalValuePrompts 17 | const { required, optional } = await command.steps.collectInputs(disableOptionalPrompts) 18 | 19 | const message = 'Which workspace folder should the command be executed in?' 20 | const folder = await selectWorkspaceFolder(message) 21 | if (!folder) return 22 | 23 | // Execute command 24 | const output = await command.handle(folder.uri.fsPath, required, optional) 25 | await showCommandOutput(output) 26 | } catch (err) { 27 | await showCatchedError(err) 28 | } 29 | } 30 | 31 | /** 32 | * Register all AdonisJS commands supported. 33 | */ 34 | function registerCommands(): Disposable[] { 35 | return Commands.map(function (command) { 36 | return commands.registerCommand(command.key, async () => await executeCommand(command)) 37 | }) 38 | } 39 | 40 | /** 41 | * Handle any error thrown while exucting an adonis command. 42 | * 43 | * @param {stdout, stderr, message} 44 | */ 45 | async function showCatchedError({ stderr, stdout, message }: CommandOutput & { message: string }) { 46 | let err = stdout ? stdout.trim() : '' 47 | if (err.length === 0) { 48 | err = stderr && stderr.trim().length > 0 ? stderr.trim() : message || '' 49 | } 50 | 51 | await showCommandOutput({ stderr: err, stdout: '' }) 52 | } 53 | 54 | export default registerCommands 55 | -------------------------------------------------------------------------------- /src/tasks/types/commandSteps.ts: -------------------------------------------------------------------------------- 1 | import { CommandStep, DataType } from '.' 2 | import { window } from 'vscode' 3 | 4 | /** 5 | * Input recieved from a series of command steps executed. 6 | */ 7 | type CommandStepsOutput = { 8 | required: { [key: string]: any } 9 | optional: { [key: string]: any } 10 | } 11 | 12 | /** 13 | * Filtered command steps from a collection of command steps. 14 | */ 15 | type FilteredCommandSteps = { 16 | requiredSteps: CommandStep[] 17 | optionalDefaultParams: { [key: string]: any } 18 | } 19 | 20 | export class CommandSteps { 21 | /** 22 | * Create a new collection of command steps. 23 | */ 24 | constructor(public description: string, public steps: CommandStep[]) {} 25 | 26 | /** 27 | * Execute the series of command steps. 28 | * 29 | * If optional steps are disabled, default values for the parameters 30 | * are used. 31 | * 32 | * @param disableOptionalSteps Should command steps that are optional be skipped 33 | */ 34 | public async collectInputs(disableOptionalSteps = false): Promise { 35 | let steps = this.steps 36 | let params: CommandStepsOutput = { 37 | required: {}, 38 | optional: {}, 39 | } 40 | 41 | // If disable is true, optional input prompt are hidden, and adonis 42 | // cli fallsback on in-built default values for optional params. 43 | if (disableOptionalSteps) { 44 | const filtered = CommandSteps._filterOptionalSteps(this.steps) 45 | steps = filtered.requiredSteps 46 | params.optional = filtered.optionalDefaultParams 47 | } 48 | 49 | for (const step of steps) { 50 | let input = await this._collectInputByStepType(step) 51 | if (input === undefined) throw Error('Input prompt exited abruptly.') 52 | if (step.optional) params.optional[step.param] = input 53 | else params.required[step.param] = input 54 | } 55 | 56 | return params 57 | } 58 | 59 | /** 60 | * Filter out command steps, and return only required compulsory steps and the default 61 | * values for all optional steps. 62 | * 63 | * @param steps Command steps to filter. 64 | */ 65 | private static _filterOptionalSteps(steps: CommandStep[]): FilteredCommandSteps { 66 | let result: FilteredCommandSteps = { 67 | optionalDefaultParams: {}, 68 | requiredSteps: [], 69 | } 70 | 71 | return steps.reduce((previous, current) => { 72 | if (current.optional && current.default) { 73 | // If optional, when step is executed, it use the default provided, 74 | // else it will fallback to the default provided by Adonis CLI. 75 | result.optionalDefaultParams[current.param] = current.default 76 | } 77 | 78 | if (!current.optional) { 79 | previous.requiredSteps.push(current) 80 | } 81 | 82 | return previous 83 | }, result) 84 | } 85 | 86 | /** 87 | * Collect user input for a command step. Input type show to user, is 88 | * dependent on the type of the command step. 89 | * 90 | * @param step Command step to collect input for. 91 | */ 92 | private async _collectInputByStepType( 93 | step: CommandStep 94 | ): Promise { 95 | switch (step.type) { 96 | case DataType.String: 97 | case DataType.Integer: 98 | return this._collectInputForStringAndInteger(step) 99 | 100 | case DataType.Boolean: 101 | return this._collectInputForBoolean(step) 102 | 103 | case DataType.Array: 104 | return this._collectInputForArray(step) 105 | 106 | default: 107 | return step.isMultiChoice 108 | ? this._collectMultiChoiceInputForEnum(step) 109 | : this._collectInputForEnum(step) 110 | } 111 | } 112 | 113 | /** 114 | * Collect user input for an command step expecting either a string or an 115 | * integer value. 116 | * 117 | * @param step Command step to collect input for. 118 | */ 119 | private async _collectInputForStringAndInteger(step: CommandStep): Promise { 120 | return window.showInputBox({ 121 | placeHolder: step.message, 122 | value: step.default === undefined ? '' : step.default.toString(), 123 | validateInput: step.validateInput, 124 | }) 125 | } 126 | 127 | /** 128 | * * Collect user input for an command step expecting a boolean value. 129 | * 130 | * @param step Command step to collect input for. 131 | */ 132 | private async _collectInputForBoolean(step: CommandStep): Promise { 133 | const items = ['Yes', 'No'] 134 | const options = { placeHolder: step.message } 135 | const value = await window.showQuickPick(items, options) 136 | if (value === undefined) return false 137 | return value === 'Yes' 138 | } 139 | 140 | /** 141 | * Collect user input for an command step expecting an enum value. 142 | * 143 | * @param step Command step to collect input for. 144 | */ 145 | private async _collectInputForEnum(step: CommandStep): Promise { 146 | const items = Object.values(step.type) 147 | const options = { placeHolder: step.message } 148 | return window.showQuickPick(items, options) 149 | } 150 | 151 | /** 152 | * Collect multichoice user input for an command step from a given 153 | * set of enum values. 154 | * 155 | * @param step Command step to collect input for. 156 | */ 157 | private async _collectMultiChoiceInputForEnum(step: CommandStep): Promise { 158 | const items = Object.values(step.type) 159 | return window.showQuickPick(items, { 160 | placeHolder: step.message, 161 | canPickMany: true, 162 | }) 163 | } 164 | 165 | /** 166 | * Collect multichoice user input for an command step from a given 167 | * set of enum values. 168 | * 169 | * @param step Command step to collect input for. 170 | */ 171 | private async _collectInputForArray(step: CommandStep): Promise { 172 | const input = await this._collectInputForStringAndInteger(step) 173 | return input ? input.split(',').filter((i) => i.length > 0) : [] 174 | } 175 | } 176 | -------------------------------------------------------------------------------- /src/tasks/types/index.ts: -------------------------------------------------------------------------------- 1 | import { CommandSteps } from './commandSteps' 2 | 3 | /** 4 | * Command step data type. 5 | */ 6 | export enum DataType { 7 | Integer = 'integer', 8 | Boolean = 'boolean', 9 | String = 'string', 10 | Array = 'array', 11 | } 12 | 13 | /** 14 | * Type representing any form of enum. 15 | */ 16 | type AnyEnumType = { [key: number]: string } 17 | 18 | /** 19 | * A single cmmmand step that requires displayin a specific type of 20 | * input to recieve data from a user. 21 | */ 22 | export type CommandStep = { 23 | /** 24 | * Parameter name 25 | */ 26 | param: string 27 | 28 | /** 29 | * Message to show for this command step 30 | */ 31 | message: string 32 | 33 | /** 34 | * Data type of input to be inputed by user 35 | */ 36 | type: DataType | AnyEnumType 37 | 38 | /** 39 | * Default value for this command step input 40 | */ 41 | default?: Object 42 | 43 | /** 44 | * Is this paramter optional for the command 45 | */ 46 | optional?: boolean 47 | 48 | /** 49 | * Is this paramter a multichoice value. 50 | * 51 | * This only works when the `type` = `Enum`. 52 | */ 53 | isMultiChoice?: boolean 54 | 55 | /** 56 | * An optional function that will be called to validate input and to give a hint 57 | * to the user. 58 | * 59 | * @param value The current value of the input box. 60 | * @return A human readable string which is presented as diagnostic message. 61 | * Return `undefined`, `null`, or the empty string when 'value' is valid. 62 | */ 63 | validateInput?( 64 | value: string[] | string 65 | ): string | undefined | null | Thenable 66 | } 67 | 68 | /** 69 | * Output after running a vscode command. 70 | */ 71 | export type CommandOutput = { 72 | stdout?: string 73 | stderr?: string 74 | } 75 | 76 | /** 77 | * A wrapper around the vscode command handler 78 | */ 79 | export type VscodeCommand = { 80 | key: string 81 | description: string 82 | steps: CommandSteps 83 | handle: (cwd: string, compulsory: any, optional: any) => Promise 84 | } 85 | 86 | // export interface ICommand { 87 | // collectInputs(): Promise; 88 | // } 89 | 90 | /** 91 | * A command step either to be executed directly on the terminal or 92 | * displaying series of input to recieve data from a user before executing. 93 | */ 94 | // export type CommandSteps = T; 95 | -------------------------------------------------------------------------------- /src/test/runTest.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path' 2 | 3 | import { runTests } from 'vscode-test' 4 | 5 | async function main() { 6 | try { 7 | // The folder containing the Extension Manifest package.json 8 | // Passed to `--extensionDevelopmentPath` 9 | const extensionDevelopmentPath = path.resolve(__dirname, '../../') 10 | 11 | // The path to test runner 12 | // Passed to --extensionTestsPath 13 | const extensionTestsPath = path.resolve(__dirname, './suite/index') 14 | 15 | // Download VS Code, unzip it and run the integration test 16 | await runTests({ 17 | launchArgs: ['--disable-extensions'], 18 | extensionDevelopmentPath, 19 | extensionTestsPath, 20 | }) 21 | } catch (err) { 22 | console.error('Failed to run tests') 23 | process.exit(1) 24 | } 25 | } 26 | 27 | main() 28 | -------------------------------------------------------------------------------- /src/test/suite/index.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path' 2 | import * as Mocha from 'mocha' 3 | import * as glob from 'glob' 4 | 5 | export function run(): Promise { 6 | // Create the mocha test 7 | const mocha = new Mocha({ 8 | ui: 'tdd', 9 | }) 10 | mocha.useColors(true) 11 | 12 | const testsRoot = path.resolve(__dirname, '..') 13 | 14 | return new Promise((c, e) => { 15 | glob('**/**.test.js', { cwd: testsRoot }, (err, files) => { 16 | if (err) { 17 | return e(err) 18 | } 19 | 20 | // Add files to the test suite 21 | files.forEach((f) => mocha.addFile(path.resolve(testsRoot, f))) 22 | 23 | try { 24 | // Run the mocha test 25 | mocha.run((failures) => { 26 | if (failures > 0) { 27 | e(new Error(`${failures} tests failed.`)) 28 | } else { 29 | c() 30 | } 31 | }) 32 | } catch (error) { 33 | e(error) 34 | } 35 | }) 36 | }) 37 | } 38 | -------------------------------------------------------------------------------- /src/utilities/command.ts: -------------------------------------------------------------------------------- 1 | import { VscodeCommand, CommandOutput } from '../tasks/types' 2 | import { CommandSteps } from '../tasks/types/commandSteps' 3 | import { exec as cmdExec } from 'child_process' 4 | import stripAnsi = require('strip-ansi') 5 | import { promisify } from 'util' 6 | import { window } from 'vscode' 7 | import { Config } from '.' 8 | 9 | const exec = promisify(cmdExec) 10 | 11 | /** 12 | * Create a VSCode command. 13 | */ 14 | export function createVscodeCommand( 15 | key: string, 16 | steps: CommandSteps, 17 | baseName: string = 'adonisjs' 18 | ): VscodeCommand { 19 | return { 20 | steps, 21 | description: steps.description, 22 | key: toVscodeCommandKey(baseName, key), 23 | handle: async (cwd: string, compulsory: any = {}, optional: any = {}) => { 24 | compulsory = Object.values(compulsory).join(' ') 25 | optional = adonisOptionalParamsToString(optional) 26 | 27 | return executeAdonisCommand(`${key} ${compulsory} ${optional}`, cwd) 28 | }, 29 | } 30 | } 31 | 32 | /** 33 | * Convert adonis command to corresponding vscode command key in package.json. 34 | * 35 | * @param adonisCommand Adonis command key 36 | */ 37 | function toVscodeCommandKey(vscodeBaseName: string, adonisCommand: string) { 38 | return `${vscodeBaseName}.${adonisCommand.replace(/:/, '.')}` 39 | } 40 | 41 | /** 42 | * Convert adonis command optional parameters to equivalent string. 43 | * 44 | * @param optional Optional parameters 45 | */ 46 | function adonisOptionalParamsToString(optional: {}): string { 47 | return Object.entries(optional) 48 | .map(([key, value]) => (typeof value === 'boolean' ? `--${key}` : `--${key}=${value}`)) 49 | .join(' ') 50 | } 51 | 52 | /** 53 | * Execute an AdonisJS command in specified direcory. 54 | * 55 | * @param command AdonisJS command to execute e.g. make:model 56 | * @param cwd Adonis project directory to excute command in 57 | */ 58 | async function executeAdonisCommand(command: string, cwd: string): Promise { 59 | const adonis = Config.tasks.adonisExecutable 60 | const maxBuffer = Config.tasks.maxBuffer 61 | const cmd = `${adonis} ${command}` 62 | 63 | return exec(cmd, { maxBuffer, cwd, encoding: 'utf8' }) 64 | } 65 | 66 | /** 67 | * Show command output of a command in vscode dialog depending on 68 | * the nature of the output (i.e. either stderr or stdout). 69 | * 70 | * @param { stdout, stderr} 71 | */ 72 | export async function showCommandOutput({ stderr, stdout }: CommandOutput) { 73 | stderr = stderr ? stripAnsi(stderr).replace(/^[✖]\s*\w+\s*/, '') : stderr 74 | stdout = stdout ? stripAnsi(stdout).replace(/^[✔●]\s*\w+\s*/, '') : stdout 75 | 76 | if (stdout) { 77 | await Promise.all( 78 | stdout.split('\n').map((line) => { 79 | return window.showInformationMessage(line) 80 | }) 81 | ) 82 | } 83 | 84 | if (stderr) await window.showErrorMessage(stderr) 85 | } 86 | -------------------------------------------------------------------------------- /src/utilities/config.ts: -------------------------------------------------------------------------------- 1 | import { workspace } from 'vscode' 2 | import { CONFIG_NAME } from './constants' 3 | 4 | /** 5 | * AdonisJS command task configuration. 6 | */ 7 | type TaskConfig = { 8 | /** 9 | * Executable path for Adonis CLI. 10 | */ 11 | adonisExecutable: string 12 | 13 | /** 14 | * Disable showing of prompts for optional fields. All commands will 15 | * be ran with default values. 16 | */ 17 | disableOptionalValuePrompts: boolean 18 | 19 | /** 20 | * Buffer size for stdout and stderr. 21 | */ 22 | maxBuffer: number 23 | } 24 | 25 | /** 26 | * A wrapper around vscode configuration for this extension 27 | */ 28 | class ConfigWrapper { 29 | /** 30 | * Configuration for task related activities. 31 | */ 32 | public static get tasks(): TaskConfig { 33 | return workspace.getConfiguration(CONFIG_NAME).tasks 34 | } 35 | } 36 | 37 | export default ConfigWrapper 38 | -------------------------------------------------------------------------------- /src/utilities/constants.ts: -------------------------------------------------------------------------------- 1 | // Configuration 2 | export const CONFIG_NAME: string = 'adonisjs' 3 | -------------------------------------------------------------------------------- /src/utilities/index.ts: -------------------------------------------------------------------------------- 1 | import * as Constants from './constants' 2 | import Config from './config' 3 | 4 | export { Constants, Config } 5 | -------------------------------------------------------------------------------- /src/utilities/inputValidation.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Set of validation rules available to vscode vscode input component. 3 | */ 4 | class InputValidation { 5 | /** 6 | * Ensure that the input is not empty. 7 | * 8 | * @param value The current value of the input box. 9 | */ 10 | public static notEmpty(value: string | string[]): string | undefined { 11 | const msg = 'Input cannot be empty' 12 | 13 | if ( 14 | (Array.isArray(value) && value.length === 0) || 15 | (typeof value === 'string' && value.trim().length === 0) 16 | ) { 17 | return msg 18 | } 19 | } 20 | 21 | /** 22 | * Ensure the given values exists in a haystack. 23 | * 24 | * @param needles Search values 25 | * @param haystack Haystack to search in. 26 | */ 27 | public static existsIn(needles: string[], haystack: string[]): string | undefined { 28 | for (const needle of needles) { 29 | if (!haystack.includes(needle)) { 30 | return `Invalid input ${needle}. Only "${haystack}" are allowed.` 31 | } 32 | } 33 | } 34 | } 35 | 36 | export default InputValidation 37 | -------------------------------------------------------------------------------- /src/utilities/workspace.ts: -------------------------------------------------------------------------------- 1 | import { workspace, WorkspaceFolder, window } from 'vscode' 2 | 3 | export async function selectWorkspaceFolder(placeHolder: string): Promise { 4 | const workspaceFolders = workspace.workspaceFolders 5 | if (!workspaceFolders) return null 6 | if (workspaceFolders.length === 1) return workspaceFolders[0] 7 | 8 | const items = workspaceFolders.map((w) => w.name) 9 | const choice = await window.showQuickPick(items, { placeHolder }) 10 | return workspaceFolders.find((w) => w.name === choice) || null 11 | } 12 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": ["es6"], 7 | "sourceMap": true, 8 | "rootDir": "src", 9 | "strict": true /* enable all strict type-checking options */ 10 | /* Additional Checks */ 11 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 12 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 13 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 14 | }, 15 | "exclude": ["node_modules", ".vscode-test", "languageServers/html"] 16 | } 17 | -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "rules": { 3 | "no-string-throw": true, 4 | "no-unused-expression": true, 5 | "no-duplicate-variable": true, 6 | "class-name": true, 7 | "semicolon": [true, "always"], 8 | "triple-equals": true 9 | }, 10 | "defaultSeverity": "warning" 11 | } 12 | -------------------------------------------------------------------------------- /vsc-extension-quickstart.md: -------------------------------------------------------------------------------- 1 | # Welcome to your VS Code Extension 2 | 3 | ## What's in the folder 4 | 5 | - This folder contains all of the files necessary for your extension. 6 | - `package.json` - this is the manifest file in which you declare your extension and command. 7 | - The sample plugin registers a command and defines its title and command name. With this information VS Code can show the command in the command palette. It doesn’t yet need to load the plugin. 8 | - `src/extension.ts` - this is the main file where you will provide the implementation of your command. 9 | - The file exports one function, `activate`, which is called the very first time your extension is activated (in this case by executing the command). Inside the `activate` function we call `registerCommand`. 10 | - We pass the function containing the implementation of the command as the second parameter to `registerCommand`. 11 | 12 | ## Get up and running straight away 13 | 14 | - Press `F5` to open a new window with your extension loaded. 15 | - Run your command from the command palette by pressing (`Ctrl+Shift+P` or `Cmd+Shift+P` on Mac) and typing `Hello World`. 16 | - Set breakpoints in your code inside `src/extension.ts` to debug your extension. 17 | - Find output from your extension in the debug console. 18 | 19 | ## Make changes 20 | 21 | - You can relaunch the extension from the debug toolbar after changing code in `src/extension.ts`. 22 | - You can also reload (`Ctrl+R` or `Cmd+R` on Mac) the VS Code window with your extension to load your changes. 23 | 24 | ## Explore the API 25 | 26 | - You can open the full set of our API when you open the file `node_modules/@types/vscode/index.d.ts`. 27 | 28 | ## Run tests 29 | 30 | - Open the debug viewlet (`Ctrl+Shift+D` or `Cmd+Shift+D` on Mac) and from the launch configuration dropdown pick `Extension Tests`. 31 | - Press `F5` to run the tests in a new window with your extension loaded. 32 | - See the output of the test result in the debug console. 33 | - Make changes to `src/test/suite/extension.test.ts` or create new test files inside the `test/suite` folder. 34 | - The provided test runner will only consider files matching the name pattern `**.test.ts`. 35 | - You can create folders inside the `test` folder to structure your tests any way you want. 36 | 37 | ## Go further 38 | 39 | - Reduce the extension size and improve the startup time by [bundling your extension](https://code.visualstudio.com/api/working-with-extensions/bundling-extension). 40 | - [Publish your extension](https://code.visualstudio.com/api/working-with-extensions/publishing-extension) on the VSCode extension marketplace. 41 | - Automate builds by setting up [Continuous Integration](https://code.visualstudio.com/api/working-with-extensions/continuous-integration). 42 | --------------------------------------------------------------------------------