├── .eslintrc.json ├── .gitignore ├── .test ├── runTest.ts └── suite │ ├── extension.test.ts │ ├── extensionRuns.ts │ └── index.ts ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── DOCUMENTATION ├── contributions │ ├── bugReport.md │ ├── contributing.md │ └── featureRequest.md └── images │ ├── add_request.gif │ ├── icon.png │ ├── tropicRPC.png │ └── update_config.gif ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── prettierrc.js ├── src ├── extension.ts └── modules │ ├── client │ ├── displayOutputMessage.ts │ ├── getRootProjectDir.ts │ ├── onSaveCb.ts │ ├── sendgRPCRequest.ts │ ├── throttleOnSave.ts │ └── validateConfigFileInputs.ts │ └── commands │ ├── activateAndDeactivateCommand.ts │ ├── configTemplate.ts │ └── createConfigFileCommand.ts └── tsconfig.json /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "parser": "@typescript-eslint/parser", 4 | "parserOptions": { 5 | "ecmaVersion": 6, 6 | "sourceType": "module" 7 | }, 8 | "plugins": [ 9 | "@typescript-eslint" 10 | ], 11 | "rules": { 12 | "@typescript-eslint/class-name-casing": "warn", 13 | "@typescript-eslint/semi": "warn", 14 | "curly": "warn", 15 | "eqeqeq": "warn", 16 | "no-throw-literal": "warn", 17 | "semi": "off" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | .vscode-test/ 4 | *.vsix 5 | .DS_Store 6 | vsc-extension-quickstart.md 7 | exREADME.md 8 | # Logs 9 | logs 10 | *.log 11 | npm-debug.log* 12 | yarn-debug.log* 13 | yarn-error.log* 14 | 15 | # Runtime data 16 | pids 17 | *.pid 18 | *.seed 19 | *.pid.lock 20 | 21 | # Directory for instrumented libs generated by jscoverage/JSCover 22 | lib-cov 23 | 24 | # Coverage directory used by tools like istanbul 25 | coverage 26 | 27 | # nyc test coverage 28 | .nyc_output 29 | 30 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 31 | .grunt 32 | 33 | # Bower dependency directory (https://bower.io/) 34 | bower_components 35 | 36 | # node-waf configuration 37 | .lock-wscript 38 | 39 | # Compiled binary addons (https://nodejs.org/api/addons.html) 40 | build/Release 41 | 42 | # Dependency directories 43 | node_modules/ 44 | jspm_packages/ 45 | 46 | # TypeScript v1 declaration files 47 | typings/ 48 | 49 | # Optional npm cache directory 50 | .npm 51 | 52 | # Optional eslint cache 53 | .eslintcache 54 | 55 | # Optional REPL history 56 | .node_repl_history 57 | 58 | # Output of 'npm pack' 59 | *.tgz 60 | 61 | # Yarn Integrity file 62 | .yarn-integrity 63 | 64 | # dotenv environment variables file 65 | .env 66 | 67 | # next.js build output 68 | .next -------------------------------------------------------------------------------- /.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({ extensionDevelopmentPath, extensionTestsPath }); 17 | } catch (err) { 18 | console.error('Failed to run tests'); 19 | process.exit(1); 20 | } 21 | } 22 | 23 | main(); 24 | -------------------------------------------------------------------------------- /.test/suite/extension.test.ts: -------------------------------------------------------------------------------- 1 | import * as assert from 'assert'; 2 | 3 | // You can import and use all API from the 'vscode' module 4 | // as well as import your extension to test it 5 | import * as vscode from 'vscode'; 6 | // import * as myExtension from '../../extension'; 7 | 8 | suite('Extension Test Suite', () => { 9 | vscode.window.showInformationMessage('Start all tests.'); 10 | 11 | test('Sample test', () => { 12 | assert.equal(-1, [1, 2, 3].indexOf(5)); 13 | assert.equal(-1, [1, 2, 3].indexOf(0)); 14 | }); 15 | }); 16 | -------------------------------------------------------------------------------- /.test/suite/extensionRuns.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Shahrukh Khan, Roseanne Demasco, Steve Canavan 3 | * @functionality : Implementing chai tests for throttle functionality 4 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 5 | * * */ 6 | 7 | import { expect } from 'chai'; 8 | 9 | const displayOutputMessage = require('../../src/modules/client/displayOutputMessage'); 10 | const sendgRPCRequest = require('../../src/modules/client/sendgRPCRequest'); 11 | const throttle = require('../../src/modules/client/throttleOnSave'); 12 | 13 | describe('Testing all functions', function () { 14 | describe('Testing displayOutputMessage', function () { 15 | it('should be a function', function () { 16 | expect(typeof displayOutputMessage).to.equal('function'); 17 | }); 18 | }); 19 | describe('Testing sendgRPCRequest', function () { 20 | it('should be a function', function () { 21 | expect(typeof sendgRPCRequest).to.equal('function'); 22 | }); 23 | }); 24 | describe('Testing throttle', function () { 25 | it('should be a function', function () { 26 | expect(typeof throttle).to.equal('function'); 27 | }); 28 | const add = (num1: number, num2: number): number => num1 + num2; 29 | const throttledAdd = throttle(add, 1000); 30 | it('should return a function', function () { 31 | expect(typeof throttledAdd).to.equal('function'); 32 | }); 33 | describe('Testing function returned (throttledAdd) from throttle', function () { 34 | it('should invoke add the first time', function () { 35 | const firstResult = throttledAdd(1, 2); 36 | expect(firstResult).not.to.equal(undefined); 37 | }); 38 | it('should return undefined if immediately invoked again', function () { 39 | const secondResult = throttledAdd(2, 3); 40 | expect(secondResult).to.equal(undefined); 41 | }); 42 | it('should invoke add after designated delay', function (done) { 43 | setTimeout(() => { 44 | try { 45 | const secondResult = throttledAdd(2, 3); 46 | expect(secondResult).not.to.equal(undefined); 47 | done(); 48 | } catch (e) { 49 | done(e); 50 | } 51 | }, 1001); 52 | }); 53 | }); 54 | }); 55 | }); 56 | -------------------------------------------------------------------------------- /.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 | color: true 10 | }); 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 (err) { 33 | console.error(err); 34 | e(err); 35 | } 36 | }); 37 | }); 38 | } 39 | -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See http://go.microsoft.com/fwlink/?LinkId=827846 3 | // for the documentation about the extensions.json format 4 | "recommendations": [ 5 | "dbaeumer.vscode-eslint" 6 | ] 7 | } 8 | -------------------------------------------------------------------------------- /.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": [ 14 | "--extensionDevelopmentPath=${workspaceFolder}" 15 | ], 16 | "outFiles": [ 17 | "${workspaceFolder}/out/**/*.js" 18 | ], 19 | "preLaunchTask": "${defaultBuildTask}" 20 | }, 21 | { 22 | "name": "Extension Tests", 23 | "type": "extensionHost", 24 | "request": "launch", 25 | "runtimeExecutable": "${execPath}", 26 | "args": [ 27 | "--extensionDevelopmentPath=${workspaceFolder}", 28 | "--extensionTestsPath=${workspaceFolder}/out/test/suite/index" 29 | ], 30 | "outFiles": [ 31 | "${workspaceFolder}/out/test/**/*.js" 32 | ], 33 | "preLaunchTask": "${defaultBuildTask}" 34 | } 35 | ] 36 | } 37 | -------------------------------------------------------------------------------- /.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 | } -------------------------------------------------------------------------------- /.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 | } 21 | -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/test/** 4 | src/** 5 | .gitignore 6 | vsc-extension-quickstart.md 7 | **/tsconfig.json 8 | **/.eslintrc.json 9 | **/*.map 10 | **/*.ts 11 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | All notable changes to the "tropic" 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 -------------------------------------------------------------------------------- /DOCUMENTATION/contributions/bugReport.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: Bug report 3 | about: Create a report to help us improve 4 | title: "[BUG] " 5 | labels: '' 6 | assignees: '' 7 | 8 | --- 9 | 10 | **Describe the bug** 11 | A clear and concise description of what the bug is. 12 | 13 | **To Reproduce** 14 | Steps to reproduce the behavior: 15 | 1. Go to '...' 16 | 2. Click on '....' 17 | 3. Scroll down to '....' 18 | 4. See error 19 | 20 | **Expected behavior** 21 | A clear and concise description of what you expected to happen. 22 | 23 | **Screenshots** 24 | If applicable, add screenshots to help explain your problem. 25 | 26 | **Desktop (please complete the following information):** 27 | - OS: [e.g. iOS] 28 | - Version [e.g. 22] 29 | - VS Code Version 30 | 31 | **Additional context** 32 | Add any other context about the problem here. 33 | -------------------------------------------------------------------------------- /DOCUMENTATION/contributions/contributing.md: -------------------------------------------------------------------------------- 1 | ## Contributing to tropicRPC 2 | We would appreciate any input on making tropicRPC better. To contribute for any bugs please follow the instructions below. 3 | 4 | ### Reporting a bug 5 | Discussing the current state of the code 6 | Submitting a fix 7 | Proposing new features 8 | We Develop with Github 9 | We use Github to host code, to track issues and feature requests, as well as accept pull requests. 10 | 11 | All Code Changes Happen Through Pull Requests 12 | Pull requests are the best way to propose changes to tropicRPC. We actively welcome your pull requests: 13 | 14 | Fork the repo and create your branch from dev. 15 | If you've added code that should be tested, add tests. 16 | If you've changed APIs, update the documentation. 17 | Ensure the test suite passes. 18 | Make sure your code lints. 19 | Issue that pull request! 20 | Any contributions you make will be under the MIT Software License 21 | In short, when you submit code changes, your submissions are understood to be under the same that covers the project. Feel free to contact the maintainers if that's a concern. 22 | 23 | ### Report bugs using Github's issues 24 | We use GitHub issues to track public bugs. Report a bug by opening a new issue; it's that easy! 25 | 26 | Write bug reports with detail, background, and sample code 27 | Great Bug Reports tend to have: 28 | 29 | ### A quick summary and/or background 30 | Steps to reproduce 31 | Be specific! 32 | Give sample code if you can. Include sample code that anyone can run to reproduce what you are experiencing 33 | What you expected would happen 34 | What actually happens 35 | Notes (possibly including why you think this might be happening, or stuff you tried that didn't work) 36 | People love thorough bug reports. I'm not even kidding. 37 | 38 | ### Use a Consistent Coding Style (Airbnb) 39 | We have our included our eslint setup in this repo to make this as painless as possible. Please also install the VS Code [Eslint](https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint) extension. 40 | 41 | #### License 42 | By contributing, you agree that your contributions will be licensed under its MIT License. 43 | 44 | #### References 45 | This document was adapted from the open-source contribution guidelines for Facebook's Draft -------------------------------------------------------------------------------- /DOCUMENTATION/contributions/featureRequest.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: Feature request 3 | about: Suggest an idea for this project 4 | title: '' 5 | labels: '' 6 | assignees: '' 7 | 8 | --- 9 | 10 | **Is your feature request related to a problem? Please describe.** 11 | 12 | A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] 13 | 14 | 15 | **Describe the solution you'd like** 16 | 17 | A clear and concise description of what you want to happen. 18 | 19 | 20 | **Describe alternatives you've considered** 21 | 22 | A clear and concise description of any alternative solutions or features you've considered. 23 | 24 | 25 | **Additional context** 26 | 27 | Add any other context or screenshots about the feature request here. 28 | 29 | -------------------------------------------------------------------------------- /DOCUMENTATION/images/add_request.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/oslabs-beta/tropicRPC/a5fcaf4e6db1829d6fece6ecf1d5e802d5496f3b/DOCUMENTATION/images/add_request.gif -------------------------------------------------------------------------------- /DOCUMENTATION/images/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/oslabs-beta/tropicRPC/a5fcaf4e6db1829d6fece6ecf1d5e802d5496f3b/DOCUMENTATION/images/icon.png -------------------------------------------------------------------------------- /DOCUMENTATION/images/tropicRPC.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/oslabs-beta/tropicRPC/a5fcaf4e6db1829d6fece6ecf1d5e802d5496f3b/DOCUMENTATION/images/tropicRPC.png -------------------------------------------------------------------------------- /DOCUMENTATION/images/update_config.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/oslabs-beta/tropicRPC/a5fcaf4e6db1829d6fece6ecf1d5e802d5496f3b/DOCUMENTATION/images/update_config.gif -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | Copyright (c) 2020 tropicRPC 3 | 4 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in 5 | the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 6 | the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: 7 | 8 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 9 | 10 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 11 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 12 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 13 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |
2 | 3 |
4 | 5 | ## What is tropicRPC? :pineapple: 6 | 7 | A Visual Studio Code extension that provides gRPC Remote Procedure Call (gRPC) API endpoint testing. 8 | 9 | ## Core Features :zap: 10 | 11 | - Starts your gRPC server 12 | - Generates a configuration file within the open VS Code project to be populated with the user's server and request information 13 | - On save, tropicRPC will make a remote procedure call (RPC) from an auto-generated client 14 | - tropicRPC supports the following RPC types: 15 | - unary 16 | - client-streaming 17 | - server-streaming 18 | - bidirectional streaming 19 | - The server response is displayed in the VS Code tropicRPC output channel 20 | 21 | ## Getting Started 22 | 23 | ### **Installation** 24 | 25 | tropicRPC can be installed from the VS Code Extensions Marketplace [here](https://marketplace.visualstudio.com/items?itemName=tropicRPC.tropicrpc). 26 | 27 | ### **Setting up the config file** 28 | 29 | Open the command palette in VS Code (Cmd/Ctrl + Shift + P) and select `tropicRPC: Create Config File`. A default config file will be generated. Follow the instructions in the config object to update the entry, portNumber, ipAddress, protoFile, and protoPackage. 30 | 31 |
32 | config demo gif 33 |
34 | 35 | ### **tropicRPC's mock API** 36 | 37 | A mock gRPC API was built for testing tropicRPC during development. This mock API is open-sourced for users to test the tropicRPC extension. It's available in this [GitHub repository](https://github.com/tropicRPC/Mock-gRPC-API). 38 | 39 | ## Write Your First tropicRPC gRPC Request 40 | 41 | 1. Search for tropicRPC using the VS Code Command Palette (Cmd/Ctrl + Shift + P) and run the `tropicRPC: Activate` command. 42 | 43 | 2. In the 'request' object, set the values of the 'service', 'method', and 'message' properties appropriately. 44 | 45 | 3. On every config file save, tropicRPC will send the request(s) and display your server results in the output channel. 46 | - For unary and server-streaming RPCs, add fields as properties on request object 47 | - For client-streaming and bidirectional RPCs, add each stream as an object nested under the request object 48 | 49 | ```javascript 50 | // add config details here 51 | const config = { 52 | // OPTIONAL: change './server/index.js' to the relative path from the root directory to the file that starts your server 53 | // or '' if you do not need tropicRPC to start your server 54 | entry: './server/index.js', 55 | 56 | // OPTIONAL: change 3000 to the port number on which your server runs 57 | portNumber: 3000, 58 | 59 | // OPTIONAL: populate '' with the IP address of your server (exclude portNumber) 60 | ipAddress: '', 61 | 62 | // change './demo.proto' to the relative path from the root directory to your proto file 63 | protoFile: 'src/proto/demo.proto', 64 | 65 | // change 'protoPackage' to your proto package's name 66 | protoPackage: 'protoPackage', 67 | }; 68 | 69 | // after activating tropicRPC extension, add request(s) here and save this file to execute 70 | const requests = { 71 | // customize your request values below 72 | request1: { 73 | service: 'serviceName', 74 | method: 'unaryMethod', 75 | message: { 76 | field1: 0, 77 | field2: 'Hello World', 78 | }, 79 | }, 80 | Request2: { 81 | service: 'serviceName', 82 | method: 'clientStreamingMethod', 83 | message: { 84 | 0: { 85 | field1: 0, 86 | field2: 'Hello World', 87 | }, 88 | 1: { 89 | field1: 1, 90 | field2: 'Bye World', 91 | }, 92 | }, 93 | }, 94 | // add additional request objects below, as necessary, using the above format 95 | }; 96 | ``` 97 | 98 |
99 | request demo gif 100 |
101 | 102 | ## Ending Your tropicRPC Session 103 | 104 | When you are ready to end your session, search for tropicRPC using the VS Code Command Palette (Cmd/Ctrl + Shift + P) and run the `tropicRPC: Deactivate` command. Deactivating the extension will stop your server. 105 | 106 | ## Troubleshooting: Changing Your Server Path 107 | 108 | After initially setting your server path, any additional updates to the path will require the extension to be deactivated and then reactivated for changes to take effect. 109 | 110 | ## Future Features :tropical_drink: 111 | 112 | - [ ] Support for additional metadata in request 113 | - [ ] Predictive text for services and methods 114 | - [ ] Schema / service method preview via hovering 115 | - [ ] Auto-identification of gRPC requests 116 | - [ ] Historical log of all requests and responses 117 | 118 | ## Built By :yellow_heart: 119 | 120 | - [Ed Chow](https://github.com/edkchow) 121 | - [Joyce Lo](https://github.com/joycelo) 122 | - [Roseanne Damasco](https://github.com/rosedamasco) 123 | - [Shahrukh Khan](https://github.com/ShahruKhanHub) 124 | - [Steve Canavan](https://github.com/stevencanavan) 125 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "tropicrpc", 3 | "version": "0.1.0", 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/core": { 17 | "version": "7.11.1", 18 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.11.1.tgz", 19 | "integrity": "sha512-XqF7F6FWQdKGGWAzGELL+aCO1p+lRY5Tj5/tbT3St1G8NaH70jhhDIKknIZaDans0OQBG5wRAldROLHSt44BgQ==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/code-frame": "^7.10.4", 23 | "@babel/generator": "^7.11.0", 24 | "@babel/helper-module-transforms": "^7.11.0", 25 | "@babel/helpers": "^7.10.4", 26 | "@babel/parser": "^7.11.1", 27 | "@babel/template": "^7.10.4", 28 | "@babel/traverse": "^7.11.0", 29 | "@babel/types": "^7.11.0", 30 | "convert-source-map": "^1.7.0", 31 | "debug": "^4.1.0", 32 | "gensync": "^1.0.0-beta.1", 33 | "json5": "^2.1.2", 34 | "lodash": "^4.17.19", 35 | "resolve": "^1.3.2", 36 | "semver": "^5.4.1", 37 | "source-map": "^0.5.0" 38 | }, 39 | "dependencies": { 40 | "semver": { 41 | "version": "5.7.1", 42 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 43 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 44 | "dev": true 45 | } 46 | } 47 | }, 48 | "@babel/generator": { 49 | "version": "7.11.0", 50 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.11.0.tgz", 51 | "integrity": "sha512-fEm3Uzw7Mc9Xi//qU20cBKatTfs2aOtKqmvy/Vm7RkJEGFQ4xc9myCfbXxqK//ZS8MR/ciOHw6meGASJuKmDfQ==", 52 | "dev": true, 53 | "requires": { 54 | "@babel/types": "^7.11.0", 55 | "jsesc": "^2.5.1", 56 | "source-map": "^0.5.0" 57 | } 58 | }, 59 | "@babel/helper-function-name": { 60 | "version": "7.10.4", 61 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz", 62 | "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==", 63 | "dev": true, 64 | "requires": { 65 | "@babel/helper-get-function-arity": "^7.10.4", 66 | "@babel/template": "^7.10.4", 67 | "@babel/types": "^7.10.4" 68 | } 69 | }, 70 | "@babel/helper-get-function-arity": { 71 | "version": "7.10.4", 72 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz", 73 | "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==", 74 | "dev": true, 75 | "requires": { 76 | "@babel/types": "^7.10.4" 77 | } 78 | }, 79 | "@babel/helper-member-expression-to-functions": { 80 | "version": "7.11.0", 81 | "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.11.0.tgz", 82 | "integrity": "sha512-JbFlKHFntRV5qKw3YC0CvQnDZ4XMwgzzBbld7Ly4Mj4cbFy3KywcR8NtNctRToMWJOVvLINJv525Gd6wwVEx/Q==", 83 | "dev": true, 84 | "requires": { 85 | "@babel/types": "^7.11.0" 86 | } 87 | }, 88 | "@babel/helper-module-imports": { 89 | "version": "7.10.4", 90 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.10.4.tgz", 91 | "integrity": "sha512-nEQJHqYavI217oD9+s5MUBzk6x1IlvoS9WTPfgG43CbMEeStE0v+r+TucWdx8KFGowPGvyOkDT9+7DHedIDnVw==", 92 | "dev": true, 93 | "requires": { 94 | "@babel/types": "^7.10.4" 95 | } 96 | }, 97 | "@babel/helper-module-transforms": { 98 | "version": "7.11.0", 99 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.11.0.tgz", 100 | "integrity": "sha512-02EVu8COMuTRO1TAzdMtpBPbe6aQ1w/8fePD2YgQmxZU4gpNWaL9gK3Jp7dxlkUlUCJOTaSeA+Hrm1BRQwqIhg==", 101 | "dev": true, 102 | "requires": { 103 | "@babel/helper-module-imports": "^7.10.4", 104 | "@babel/helper-replace-supers": "^7.10.4", 105 | "@babel/helper-simple-access": "^7.10.4", 106 | "@babel/helper-split-export-declaration": "^7.11.0", 107 | "@babel/template": "^7.10.4", 108 | "@babel/types": "^7.11.0", 109 | "lodash": "^4.17.19" 110 | } 111 | }, 112 | "@babel/helper-optimise-call-expression": { 113 | "version": "7.10.4", 114 | "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.10.4.tgz", 115 | "integrity": "sha512-n3UGKY4VXwXThEiKrgRAoVPBMqeoPgHVqiHZOanAJCG9nQUL2pLRQirUzl0ioKclHGpGqRgIOkgcIJaIWLpygg==", 116 | "dev": true, 117 | "requires": { 118 | "@babel/types": "^7.10.4" 119 | } 120 | }, 121 | "@babel/helper-replace-supers": { 122 | "version": "7.10.4", 123 | "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.10.4.tgz", 124 | "integrity": "sha512-sPxZfFXocEymYTdVK1UNmFPBN+Hv5mJkLPsYWwGBxZAxaWfFu+xqp7b6qWD0yjNuNL2VKc6L5M18tOXUP7NU0A==", 125 | "dev": true, 126 | "requires": { 127 | "@babel/helper-member-expression-to-functions": "^7.10.4", 128 | "@babel/helper-optimise-call-expression": "^7.10.4", 129 | "@babel/traverse": "^7.10.4", 130 | "@babel/types": "^7.10.4" 131 | } 132 | }, 133 | "@babel/helper-simple-access": { 134 | "version": "7.10.4", 135 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.10.4.tgz", 136 | "integrity": "sha512-0fMy72ej/VEvF8ULmX6yb5MtHG4uH4Dbd6I/aHDb/JVg0bbivwt9Wg+h3uMvX+QSFtwr5MeItvazbrc4jtRAXw==", 137 | "dev": true, 138 | "requires": { 139 | "@babel/template": "^7.10.4", 140 | "@babel/types": "^7.10.4" 141 | } 142 | }, 143 | "@babel/helper-split-export-declaration": { 144 | "version": "7.11.0", 145 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.11.0.tgz", 146 | "integrity": "sha512-74Vejvp6mHkGE+m+k5vHY93FX2cAtrw1zXrZXRlG4l410Nm9PxfEiVTn1PjDPV5SnmieiueY4AFg2xqhNFuuZg==", 147 | "dev": true, 148 | "requires": { 149 | "@babel/types": "^7.11.0" 150 | } 151 | }, 152 | "@babel/helper-validator-identifier": { 153 | "version": "7.10.4", 154 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 155 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", 156 | "dev": true 157 | }, 158 | "@babel/helpers": { 159 | "version": "7.10.4", 160 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.10.4.tgz", 161 | "integrity": "sha512-L2gX/XeUONeEbI78dXSrJzGdz4GQ+ZTA/aazfUsFaWjSe95kiCuOZ5HsXvkiw3iwF+mFHSRUfJU8t6YavocdXA==", 162 | "dev": true, 163 | "requires": { 164 | "@babel/template": "^7.10.4", 165 | "@babel/traverse": "^7.10.4", 166 | "@babel/types": "^7.10.4" 167 | } 168 | }, 169 | "@babel/highlight": { 170 | "version": "7.10.4", 171 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 172 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 173 | "dev": true, 174 | "requires": { 175 | "@babel/helper-validator-identifier": "^7.10.4", 176 | "chalk": "^2.0.0", 177 | "js-tokens": "^4.0.0" 178 | } 179 | }, 180 | "@babel/parser": { 181 | "version": "7.11.2", 182 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.11.2.tgz", 183 | "integrity": "sha512-Vuj/+7vLo6l1Vi7uuO+1ngCDNeVmNbTngcJFKCR/oEtz8tKz0CJxZEGmPt9KcIloZhOZ3Zit6xbpXT2MDlS9Vw==", 184 | "dev": true 185 | }, 186 | "@babel/template": { 187 | "version": "7.10.4", 188 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.10.4.tgz", 189 | "integrity": "sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==", 190 | "dev": true, 191 | "requires": { 192 | "@babel/code-frame": "^7.10.4", 193 | "@babel/parser": "^7.10.4", 194 | "@babel/types": "^7.10.4" 195 | } 196 | }, 197 | "@babel/traverse": { 198 | "version": "7.11.0", 199 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.11.0.tgz", 200 | "integrity": "sha512-ZB2V+LskoWKNpMq6E5UUCrjtDUh5IOTAyIl0dTjIEoXum/iKWkoIEKIRDnUucO6f+2FzNkE0oD4RLKoPIufDtg==", 201 | "dev": true, 202 | "requires": { 203 | "@babel/code-frame": "^7.10.4", 204 | "@babel/generator": "^7.11.0", 205 | "@babel/helper-function-name": "^7.10.4", 206 | "@babel/helper-split-export-declaration": "^7.11.0", 207 | "@babel/parser": "^7.11.0", 208 | "@babel/types": "^7.11.0", 209 | "debug": "^4.1.0", 210 | "globals": "^11.1.0", 211 | "lodash": "^4.17.19" 212 | }, 213 | "dependencies": { 214 | "globals": { 215 | "version": "11.12.0", 216 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 217 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 218 | "dev": true 219 | } 220 | } 221 | }, 222 | "@babel/types": { 223 | "version": "7.11.0", 224 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.11.0.tgz", 225 | "integrity": "sha512-O53yME4ZZI0jO1EVGtF1ePGl0LHirG4P1ibcD80XyzZcKhcMFeCXmh4Xb1ifGBIV233Qg12x4rBfQgA+tmOukA==", 226 | "dev": true, 227 | "requires": { 228 | "@babel/helper-validator-identifier": "^7.10.4", 229 | "lodash": "^4.17.19", 230 | "to-fast-properties": "^2.0.0" 231 | } 232 | }, 233 | "@grpc/grpc-js": { 234 | "version": "1.1.2", 235 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.1.2.tgz", 236 | "integrity": "sha512-k2u86Bkm/3xrjUaSWeIyzXScBt/cC8uE7BznR0cpueQi11R33W6qfJdMrkrsmSHirp5likR55JSXUrcWG6ybHA==", 237 | "requires": { 238 | "semver": "^6.2.0" 239 | }, 240 | "dependencies": { 241 | "semver": { 242 | "version": "6.3.0", 243 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 244 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 245 | } 246 | } 247 | }, 248 | "@grpc/proto-loader": { 249 | "version": "0.5.5", 250 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.5.5.tgz", 251 | "integrity": "sha512-WwN9jVNdHRQoOBo9FDH7qU+mgfjPc8GygPYms3M+y3fbQLfnCe/Kv/E01t7JRgnrsOHH8euvSbed3mIalXhwqQ==", 252 | "requires": { 253 | "lodash.camelcase": "^4.3.0", 254 | "protobufjs": "^6.8.6" 255 | } 256 | }, 257 | "@istanbuljs/load-nyc-config": { 258 | "version": "1.1.0", 259 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", 260 | "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", 261 | "dev": true, 262 | "requires": { 263 | "camelcase": "^5.3.1", 264 | "find-up": "^4.1.0", 265 | "get-package-type": "^0.1.0", 266 | "js-yaml": "^3.13.1", 267 | "resolve-from": "^5.0.0" 268 | }, 269 | "dependencies": { 270 | "find-up": { 271 | "version": "4.1.0", 272 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 273 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 274 | "dev": true, 275 | "requires": { 276 | "locate-path": "^5.0.0", 277 | "path-exists": "^4.0.0" 278 | } 279 | }, 280 | "locate-path": { 281 | "version": "5.0.0", 282 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 283 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 284 | "dev": true, 285 | "requires": { 286 | "p-locate": "^4.1.0" 287 | } 288 | }, 289 | "p-locate": { 290 | "version": "4.1.0", 291 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 292 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 293 | "dev": true, 294 | "requires": { 295 | "p-limit": "^2.2.0" 296 | } 297 | }, 298 | "path-exists": { 299 | "version": "4.0.0", 300 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 301 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 302 | "dev": true 303 | }, 304 | "resolve-from": { 305 | "version": "5.0.0", 306 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 307 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 308 | "dev": true 309 | } 310 | } 311 | }, 312 | "@istanbuljs/schema": { 313 | "version": "0.1.2", 314 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.2.tgz", 315 | "integrity": "sha512-tsAQNx32a8CoFhjhijUIhI4kccIAgmGhy8LZMZgGfmXcpMbPRUqn5LWmgRttILi6yeGmBJd2xsPkFMs0PzgPCw==", 316 | "dev": true 317 | }, 318 | "@protobufjs/aspromise": { 319 | "version": "1.1.2", 320 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 321 | "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=" 322 | }, 323 | "@protobufjs/base64": { 324 | "version": "1.1.2", 325 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 326 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" 327 | }, 328 | "@protobufjs/codegen": { 329 | "version": "2.0.4", 330 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 331 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" 332 | }, 333 | "@protobufjs/eventemitter": { 334 | "version": "1.1.0", 335 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 336 | "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=" 337 | }, 338 | "@protobufjs/fetch": { 339 | "version": "1.1.0", 340 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 341 | "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", 342 | "requires": { 343 | "@protobufjs/aspromise": "^1.1.1", 344 | "@protobufjs/inquire": "^1.1.0" 345 | } 346 | }, 347 | "@protobufjs/float": { 348 | "version": "1.0.2", 349 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 350 | "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=" 351 | }, 352 | "@protobufjs/inquire": { 353 | "version": "1.1.0", 354 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 355 | "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=" 356 | }, 357 | "@protobufjs/path": { 358 | "version": "1.1.2", 359 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 360 | "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=" 361 | }, 362 | "@protobufjs/pool": { 363 | "version": "1.1.0", 364 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 365 | "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=" 366 | }, 367 | "@protobufjs/utf8": { 368 | "version": "1.1.0", 369 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 370 | "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=" 371 | }, 372 | "@types/chai": { 373 | "version": "4.2.12", 374 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.2.12.tgz", 375 | "integrity": "sha512-aN5IAC8QNtSUdQzxu7lGBgYAOuU1tmRU4c9dIq5OKGf/SBVjXo+ffM2wEjudAWbgpOhy60nLoAGH1xm8fpCKFQ==", 376 | "dev": true 377 | }, 378 | "@types/color-name": { 379 | "version": "1.1.1", 380 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 381 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 382 | "dev": true 383 | }, 384 | "@types/eslint-visitor-keys": { 385 | "version": "1.0.0", 386 | "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 387 | "integrity": "sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag==", 388 | "dev": true 389 | }, 390 | "@types/glob": { 391 | "version": "7.1.3", 392 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.3.tgz", 393 | "integrity": "sha512-SEYeGAIQIQX8NN6LDKprLjbrd5dARM5EXsd8GI/A5l0apYI1fGMWgPHSe4ZKL4eozlAyI+doUE9XbYS4xCkQ1w==", 394 | "dev": true, 395 | "requires": { 396 | "@types/minimatch": "*", 397 | "@types/node": "*" 398 | } 399 | }, 400 | "@types/json-schema": { 401 | "version": "7.0.5", 402 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.5.tgz", 403 | "integrity": "sha512-7+2BITlgjgDhH0vvwZU/HZJVyk+2XUlvxXe8dFMedNX/aMkaOq++rMAFXc0tM7ij15QaWlbdQASBR9dihi+bDQ==", 404 | "dev": true 405 | }, 406 | "@types/long": { 407 | "version": "4.0.1", 408 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", 409 | "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==" 410 | }, 411 | "@types/minimatch": { 412 | "version": "3.0.3", 413 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", 414 | "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==", 415 | "dev": true 416 | }, 417 | "@types/mocha": { 418 | "version": "7.0.2", 419 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-7.0.2.tgz", 420 | "integrity": "sha512-ZvO2tAcjmMi8V/5Z3JsyofMe3hasRcaw88cto5etSVMwVQfeivGAlEYmaQgceUSVYFofVjT+ioHsATjdWcFt1w==", 421 | "dev": true 422 | }, 423 | "@types/node": { 424 | "version": "13.13.14", 425 | "resolved": "https://registry.npmjs.org/@types/node/-/node-13.13.14.tgz", 426 | "integrity": "sha512-Az3QsOt1U/K1pbCQ0TXGELTuTkPLOiFIQf3ILzbOyo0FqgV9SxRnxbxM5QlAveERZMHpZY+7u3Jz2tKyl+yg6g==" 427 | }, 428 | "@types/vscode": { 429 | "version": "1.47.0", 430 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.47.0.tgz", 431 | "integrity": "sha512-nJA37ykkz9FYA0ZOQUSc3OZnhuzEW2vUhUEo4MiduUo82jGwwcLfyvmgd/Q7b0WrZAAceojGhZybg319L24bTA==", 432 | "dev": true 433 | }, 434 | "@typescript-eslint/eslint-plugin": { 435 | "version": "2.34.0", 436 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.34.0.tgz", 437 | "integrity": "sha512-4zY3Z88rEE99+CNvTbXSyovv2z9PNOVffTWD2W8QF5s2prBQtwN2zadqERcrHpcR7O/+KMI3fcTAmUUhK/iQcQ==", 438 | "dev": true, 439 | "requires": { 440 | "@typescript-eslint/experimental-utils": "2.34.0", 441 | "functional-red-black-tree": "^1.0.1", 442 | "regexpp": "^3.0.0", 443 | "tsutils": "^3.17.1" 444 | } 445 | }, 446 | "@typescript-eslint/experimental-utils": { 447 | "version": "2.34.0", 448 | "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-2.34.0.tgz", 449 | "integrity": "sha512-eS6FTkq+wuMJ+sgtuNTtcqavWXqsflWcfBnlYhg/nS4aZ1leewkXGbvBhaapn1q6qf4M71bsR1tez5JTRMuqwA==", 450 | "dev": true, 451 | "requires": { 452 | "@types/json-schema": "^7.0.3", 453 | "@typescript-eslint/typescript-estree": "2.34.0", 454 | "eslint-scope": "^5.0.0", 455 | "eslint-utils": "^2.0.0" 456 | } 457 | }, 458 | "@typescript-eslint/parser": { 459 | "version": "2.34.0", 460 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-2.34.0.tgz", 461 | "integrity": "sha512-03ilO0ucSD0EPTw2X4PntSIRFtDPWjrVq7C3/Z3VQHRC7+13YB55rcJI3Jt+YgeHbjUdJPcPa7b23rXCBokuyA==", 462 | "dev": true, 463 | "requires": { 464 | "@types/eslint-visitor-keys": "^1.0.0", 465 | "@typescript-eslint/experimental-utils": "2.34.0", 466 | "@typescript-eslint/typescript-estree": "2.34.0", 467 | "eslint-visitor-keys": "^1.1.0" 468 | } 469 | }, 470 | "@typescript-eslint/typescript-estree": { 471 | "version": "2.34.0", 472 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-2.34.0.tgz", 473 | "integrity": "sha512-OMAr+nJWKdlVM9LOqCqh3pQQPwxHAN7Du8DR6dmwCrAmxtiXQnhHJ6tBNtf+cggqfo51SG/FCwnKhXCIM7hnVg==", 474 | "dev": true, 475 | "requires": { 476 | "debug": "^4.1.1", 477 | "eslint-visitor-keys": "^1.1.0", 478 | "glob": "^7.1.6", 479 | "is-glob": "^4.0.1", 480 | "lodash": "^4.17.15", 481 | "semver": "^7.3.2", 482 | "tsutils": "^3.17.1" 483 | } 484 | }, 485 | "acorn": { 486 | "version": "7.3.1", 487 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.3.1.tgz", 488 | "integrity": "sha512-tLc0wSnatxAQHVHUapaHdz72pi9KUyHjq5KyHjGg9Y8Ifdc79pTh2XvI6I1/chZbnM7QtNKzh66ooDogPZSleA==", 489 | "dev": true 490 | }, 491 | "acorn-jsx": { 492 | "version": "5.2.0", 493 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.2.0.tgz", 494 | "integrity": "sha512-HiUX/+K2YpkpJ+SzBffkM/AQ2YE03S0U1kjTLVpoJdhZMOWy8qvXVN9JdLqv2QsaQ6MPYQIuNmwD8zOiYUofLQ==", 495 | "dev": true 496 | }, 497 | "agent-base": { 498 | "version": "4.3.0", 499 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-4.3.0.tgz", 500 | "integrity": "sha512-salcGninV0nPrwpGNn4VTXBb1SOuXQBiqbrNXoeizJsHrsL6ERFM2Ne3JUSBWRE6aeNJI2ROP/WEEIDUiDe3cg==", 501 | "dev": true, 502 | "requires": { 503 | "es6-promisify": "^5.0.0" 504 | } 505 | }, 506 | "aggregate-error": { 507 | "version": "3.0.1", 508 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.0.1.tgz", 509 | "integrity": "sha512-quoaXsZ9/BLNae5yiNoUz+Nhkwz83GhWwtYFglcjEQB2NDHCIpApbqXxIFnm4Pq/Nvhrsq5sYJFyohrrxnTGAA==", 510 | "dev": true, 511 | "requires": { 512 | "clean-stack": "^2.0.0", 513 | "indent-string": "^4.0.0" 514 | } 515 | }, 516 | "ajv": { 517 | "version": "6.12.3", 518 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.3.tgz", 519 | "integrity": "sha512-4K0cK3L1hsqk9xIb2z9vs/XU+PGJZ9PNpJRDS9YLzmNdX6jmVPfamLvTJr0aDAusnHyCHO6MjzlkAsgtqp9teA==", 520 | "dev": true, 521 | "requires": { 522 | "fast-deep-equal": "^3.1.1", 523 | "fast-json-stable-stringify": "^2.0.0", 524 | "json-schema-traverse": "^0.4.1", 525 | "uri-js": "^4.2.2" 526 | } 527 | }, 528 | "ansi-colors": { 529 | "version": "3.2.3", 530 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 531 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 532 | "dev": true 533 | }, 534 | "ansi-escapes": { 535 | "version": "4.3.1", 536 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz", 537 | "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==", 538 | "dev": true, 539 | "requires": { 540 | "type-fest": "^0.11.0" 541 | }, 542 | "dependencies": { 543 | "type-fest": { 544 | "version": "0.11.0", 545 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz", 546 | "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==", 547 | "dev": true 548 | } 549 | } 550 | }, 551 | "ansi-regex": { 552 | "version": "5.0.0", 553 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 554 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 555 | "dev": true 556 | }, 557 | "ansi-styles": { 558 | "version": "3.2.1", 559 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 560 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 561 | "dev": true, 562 | "requires": { 563 | "color-convert": "^1.9.0" 564 | } 565 | }, 566 | "anymatch": { 567 | "version": "3.1.1", 568 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 569 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 570 | "dev": true, 571 | "requires": { 572 | "normalize-path": "^3.0.0", 573 | "picomatch": "^2.0.4" 574 | } 575 | }, 576 | "append-transform": { 577 | "version": "2.0.0", 578 | "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-2.0.0.tgz", 579 | "integrity": "sha512-7yeyCEurROLQJFv5Xj4lEGTy0borxepjFv1g22oAdqFu//SrAlDl1O1Nxx15SH1RoliUml6p8dwJW9jvZughhg==", 580 | "dev": true, 581 | "requires": { 582 | "default-require-extensions": "^3.0.0" 583 | } 584 | }, 585 | "archy": { 586 | "version": "1.0.0", 587 | "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", 588 | "integrity": "sha1-+cjBN1fMHde8N5rHeyxipcKGjEA=", 589 | "dev": true 590 | }, 591 | "arg": { 592 | "version": "4.1.3", 593 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 594 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 595 | "dev": true 596 | }, 597 | "argparse": { 598 | "version": "1.0.10", 599 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 600 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 601 | "dev": true, 602 | "requires": { 603 | "sprintf-js": "~1.0.2" 604 | } 605 | }, 606 | "assertion-error": { 607 | "version": "1.1.0", 608 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 609 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 610 | "dev": true 611 | }, 612 | "astral-regex": { 613 | "version": "1.0.0", 614 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 615 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 616 | "dev": true 617 | }, 618 | "balanced-match": { 619 | "version": "1.0.0", 620 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 621 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 622 | "dev": true 623 | }, 624 | "big.js": { 625 | "version": "5.2.2", 626 | "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", 627 | "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", 628 | "dev": true 629 | }, 630 | "binary-extensions": { 631 | "version": "2.1.0", 632 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz", 633 | "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==", 634 | "dev": true 635 | }, 636 | "brace-expansion": { 637 | "version": "1.1.11", 638 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 639 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 640 | "dev": true, 641 | "requires": { 642 | "balanced-match": "^1.0.0", 643 | "concat-map": "0.0.1" 644 | } 645 | }, 646 | "braces": { 647 | "version": "3.0.2", 648 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 649 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 650 | "dev": true, 651 | "requires": { 652 | "fill-range": "^7.0.1" 653 | } 654 | }, 655 | "browser-stdout": { 656 | "version": "1.3.1", 657 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 658 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 659 | "dev": true 660 | }, 661 | "buffer-from": { 662 | "version": "1.1.1", 663 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 664 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 665 | "dev": true 666 | }, 667 | "caching-transform": { 668 | "version": "4.0.0", 669 | "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-4.0.0.tgz", 670 | "integrity": "sha512-kpqOvwXnjjN44D89K5ccQC+RUrsy7jB/XLlRrx0D7/2HNcTPqzsb6XgYoErwko6QsV184CA2YgS1fxDiiDZMWA==", 671 | "dev": true, 672 | "requires": { 673 | "hasha": "^5.0.0", 674 | "make-dir": "^3.0.0", 675 | "package-hash": "^4.0.0", 676 | "write-file-atomic": "^3.0.0" 677 | } 678 | }, 679 | "callsites": { 680 | "version": "3.1.0", 681 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 682 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 683 | "dev": true 684 | }, 685 | "camelcase": { 686 | "version": "5.3.1", 687 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 688 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 689 | "dev": true 690 | }, 691 | "chai": { 692 | "version": "4.2.0", 693 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", 694 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", 695 | "dev": true, 696 | "requires": { 697 | "assertion-error": "^1.1.0", 698 | "check-error": "^1.0.2", 699 | "deep-eql": "^3.0.1", 700 | "get-func-name": "^2.0.0", 701 | "pathval": "^1.1.0", 702 | "type-detect": "^4.0.5" 703 | } 704 | }, 705 | "chalk": { 706 | "version": "2.4.2", 707 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 708 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 709 | "dev": true, 710 | "requires": { 711 | "ansi-styles": "^3.2.1", 712 | "escape-string-regexp": "^1.0.5", 713 | "supports-color": "^5.3.0" 714 | } 715 | }, 716 | "chardet": { 717 | "version": "0.7.0", 718 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 719 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 720 | "dev": true 721 | }, 722 | "check-error": { 723 | "version": "1.0.2", 724 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 725 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 726 | "dev": true 727 | }, 728 | "chokidar": { 729 | "version": "3.3.0", 730 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.0.tgz", 731 | "integrity": "sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A==", 732 | "dev": true, 733 | "requires": { 734 | "anymatch": "~3.1.1", 735 | "braces": "~3.0.2", 736 | "fsevents": "~2.1.1", 737 | "glob-parent": "~5.1.0", 738 | "is-binary-path": "~2.1.0", 739 | "is-glob": "~4.0.1", 740 | "normalize-path": "~3.0.0", 741 | "readdirp": "~3.2.0" 742 | } 743 | }, 744 | "clean-stack": { 745 | "version": "2.2.0", 746 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 747 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 748 | "dev": true 749 | }, 750 | "cli-cursor": { 751 | "version": "3.1.0", 752 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 753 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 754 | "dev": true, 755 | "requires": { 756 | "restore-cursor": "^3.1.0" 757 | } 758 | }, 759 | "cli-width": { 760 | "version": "3.0.0", 761 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz", 762 | "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==", 763 | "dev": true 764 | }, 765 | "cliui": { 766 | "version": "5.0.0", 767 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 768 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 769 | "dev": true, 770 | "requires": { 771 | "string-width": "^3.1.0", 772 | "strip-ansi": "^5.2.0", 773 | "wrap-ansi": "^5.1.0" 774 | }, 775 | "dependencies": { 776 | "emoji-regex": { 777 | "version": "7.0.3", 778 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 779 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 780 | "dev": true 781 | }, 782 | "is-fullwidth-code-point": { 783 | "version": "2.0.0", 784 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 785 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 786 | "dev": true 787 | }, 788 | "string-width": { 789 | "version": "3.1.0", 790 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 791 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 792 | "dev": true, 793 | "requires": { 794 | "emoji-regex": "^7.0.1", 795 | "is-fullwidth-code-point": "^2.0.0", 796 | "strip-ansi": "^5.1.0" 797 | } 798 | } 799 | } 800 | }, 801 | "color-convert": { 802 | "version": "1.9.3", 803 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 804 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 805 | "dev": true, 806 | "requires": { 807 | "color-name": "1.1.3" 808 | } 809 | }, 810 | "color-name": { 811 | "version": "1.1.3", 812 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 813 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 814 | "dev": true 815 | }, 816 | "commondir": { 817 | "version": "1.0.1", 818 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 819 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 820 | "dev": true 821 | }, 822 | "concat-map": { 823 | "version": "0.0.1", 824 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 825 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 826 | "dev": true 827 | }, 828 | "convert-source-map": { 829 | "version": "1.7.0", 830 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", 831 | "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", 832 | "dev": true, 833 | "requires": { 834 | "safe-buffer": "~5.1.1" 835 | } 836 | }, 837 | "core-util-is": { 838 | "version": "1.0.2", 839 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 840 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 841 | "dev": true 842 | }, 843 | "cross-spawn": { 844 | "version": "6.0.5", 845 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 846 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 847 | "dev": true, 848 | "requires": { 849 | "nice-try": "^1.0.4", 850 | "path-key": "^2.0.1", 851 | "semver": "^5.5.0", 852 | "shebang-command": "^1.2.0", 853 | "which": "^1.2.9" 854 | }, 855 | "dependencies": { 856 | "semver": { 857 | "version": "5.7.1", 858 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 859 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 860 | "dev": true 861 | } 862 | } 863 | }, 864 | "debug": { 865 | "version": "4.1.1", 866 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 867 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 868 | "dev": true, 869 | "requires": { 870 | "ms": "^2.1.1" 871 | } 872 | }, 873 | "decamelize": { 874 | "version": "1.2.0", 875 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 876 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 877 | "dev": true 878 | }, 879 | "deep-eql": { 880 | "version": "3.0.1", 881 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 882 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 883 | "dev": true, 884 | "requires": { 885 | "type-detect": "^4.0.0" 886 | } 887 | }, 888 | "deep-is": { 889 | "version": "0.1.3", 890 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 891 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 892 | "dev": true 893 | }, 894 | "default-require-extensions": { 895 | "version": "3.0.0", 896 | "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-3.0.0.tgz", 897 | "integrity": "sha512-ek6DpXq/SCpvjhpFsLFRVtIxJCRw6fUR42lYMVZuUMK7n8eMz4Uh5clckdBjEpLhn/gEBZo7hDJnJcwdKLKQjg==", 898 | "dev": true, 899 | "requires": { 900 | "strip-bom": "^4.0.0" 901 | } 902 | }, 903 | "define-properties": { 904 | "version": "1.1.3", 905 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 906 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 907 | "dev": true, 908 | "requires": { 909 | "object-keys": "^1.0.12" 910 | } 911 | }, 912 | "diff": { 913 | "version": "3.5.0", 914 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 915 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 916 | "dev": true 917 | }, 918 | "doctrine": { 919 | "version": "3.0.0", 920 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 921 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 922 | "dev": true, 923 | "requires": { 924 | "esutils": "^2.0.2" 925 | } 926 | }, 927 | "emoji-regex": { 928 | "version": "8.0.0", 929 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 930 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 931 | "dev": true 932 | }, 933 | "emojis-list": { 934 | "version": "3.0.0", 935 | "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz", 936 | "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==", 937 | "dev": true 938 | }, 939 | "enhanced-resolve": { 940 | "version": "4.3.0", 941 | "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-4.3.0.tgz", 942 | "integrity": "sha512-3e87LvavsdxyoCfGusJnrZ5G8SLPOFeHSNpZI/ATL9a5leXo2k0w6MKnbqhdBad9qTobSfB20Ld7UmgoNbAZkQ==", 943 | "dev": true, 944 | "requires": { 945 | "graceful-fs": "^4.1.2", 946 | "memory-fs": "^0.5.0", 947 | "tapable": "^1.0.0" 948 | } 949 | }, 950 | "errno": { 951 | "version": "0.1.7", 952 | "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz", 953 | "integrity": "sha512-MfrRBDWzIWifgq6tJj60gkAwtLNb6sQPlcFrSOflcP1aFmmruKQ2wRnze/8V6kgyz7H3FF8Npzv78mZ7XLLflg==", 954 | "dev": true, 955 | "requires": { 956 | "prr": "~1.0.1" 957 | } 958 | }, 959 | "es-abstract": { 960 | "version": "1.17.6", 961 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.6.tgz", 962 | "integrity": "sha512-Fr89bON3WFyUi5EvAeI48QTWX0AyekGgLA8H+c+7fbfCkJwRWRMLd8CQedNEyJuoYYhmtEqY92pgte1FAhBlhw==", 963 | "dev": true, 964 | "requires": { 965 | "es-to-primitive": "^1.2.1", 966 | "function-bind": "^1.1.1", 967 | "has": "^1.0.3", 968 | "has-symbols": "^1.0.1", 969 | "is-callable": "^1.2.0", 970 | "is-regex": "^1.1.0", 971 | "object-inspect": "^1.7.0", 972 | "object-keys": "^1.1.1", 973 | "object.assign": "^4.1.0", 974 | "string.prototype.trimend": "^1.0.1", 975 | "string.prototype.trimstart": "^1.0.1" 976 | } 977 | }, 978 | "es-to-primitive": { 979 | "version": "1.2.1", 980 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 981 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 982 | "dev": true, 983 | "requires": { 984 | "is-callable": "^1.1.4", 985 | "is-date-object": "^1.0.1", 986 | "is-symbol": "^1.0.2" 987 | } 988 | }, 989 | "es6-error": { 990 | "version": "4.1.1", 991 | "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", 992 | "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", 993 | "dev": true 994 | }, 995 | "es6-promise": { 996 | "version": "4.2.8", 997 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", 998 | "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", 999 | "dev": true 1000 | }, 1001 | "es6-promisify": { 1002 | "version": "5.0.0", 1003 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz", 1004 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 1005 | "dev": true, 1006 | "requires": { 1007 | "es6-promise": "^4.0.3" 1008 | } 1009 | }, 1010 | "escape-string-regexp": { 1011 | "version": "1.0.5", 1012 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1013 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1014 | "dev": true 1015 | }, 1016 | "eslint": { 1017 | "version": "6.8.0", 1018 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", 1019 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", 1020 | "dev": true, 1021 | "requires": { 1022 | "@babel/code-frame": "^7.0.0", 1023 | "ajv": "^6.10.0", 1024 | "chalk": "^2.1.0", 1025 | "cross-spawn": "^6.0.5", 1026 | "debug": "^4.0.1", 1027 | "doctrine": "^3.0.0", 1028 | "eslint-scope": "^5.0.0", 1029 | "eslint-utils": "^1.4.3", 1030 | "eslint-visitor-keys": "^1.1.0", 1031 | "espree": "^6.1.2", 1032 | "esquery": "^1.0.1", 1033 | "esutils": "^2.0.2", 1034 | "file-entry-cache": "^5.0.1", 1035 | "functional-red-black-tree": "^1.0.1", 1036 | "glob-parent": "^5.0.0", 1037 | "globals": "^12.1.0", 1038 | "ignore": "^4.0.6", 1039 | "import-fresh": "^3.0.0", 1040 | "imurmurhash": "^0.1.4", 1041 | "inquirer": "^7.0.0", 1042 | "is-glob": "^4.0.0", 1043 | "js-yaml": "^3.13.1", 1044 | "json-stable-stringify-without-jsonify": "^1.0.1", 1045 | "levn": "^0.3.0", 1046 | "lodash": "^4.17.14", 1047 | "minimatch": "^3.0.4", 1048 | "mkdirp": "^0.5.1", 1049 | "natural-compare": "^1.4.0", 1050 | "optionator": "^0.8.3", 1051 | "progress": "^2.0.0", 1052 | "regexpp": "^2.0.1", 1053 | "semver": "^6.1.2", 1054 | "strip-ansi": "^5.2.0", 1055 | "strip-json-comments": "^3.0.1", 1056 | "table": "^5.2.3", 1057 | "text-table": "^0.2.0", 1058 | "v8-compile-cache": "^2.0.3" 1059 | }, 1060 | "dependencies": { 1061 | "eslint-utils": { 1062 | "version": "1.4.3", 1063 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 1064 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 1065 | "dev": true, 1066 | "requires": { 1067 | "eslint-visitor-keys": "^1.1.0" 1068 | } 1069 | }, 1070 | "regexpp": { 1071 | "version": "2.0.1", 1072 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1073 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1074 | "dev": true 1075 | }, 1076 | "semver": { 1077 | "version": "6.3.0", 1078 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1079 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1080 | "dev": true 1081 | } 1082 | } 1083 | }, 1084 | "eslint-plugin-mocha": { 1085 | "version": "7.0.1", 1086 | "resolved": "https://registry.npmjs.org/eslint-plugin-mocha/-/eslint-plugin-mocha-7.0.1.tgz", 1087 | "integrity": "sha512-zkQRW9UigRaayGm/pK9TD5RjccKXSgQksNtpsXbG9b6L5I+jNx7m98VUbZ4w1H1ArlNA+K7IOH+z8TscN6sOYg==", 1088 | "dev": true, 1089 | "requires": { 1090 | "eslint-utils": "^2.0.0", 1091 | "ramda": "^0.27.0" 1092 | } 1093 | }, 1094 | "eslint-scope": { 1095 | "version": "5.1.0", 1096 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.0.tgz", 1097 | "integrity": "sha512-iiGRvtxWqgtx5m8EyQUJihBloE4EnYeGE/bz1wSPwJE6tZuJUtHlhqDM4Xj2ukE8Dyy1+HCZ4hE0fzIVMzb58w==", 1098 | "dev": true, 1099 | "requires": { 1100 | "esrecurse": "^4.1.0", 1101 | "estraverse": "^4.1.1" 1102 | } 1103 | }, 1104 | "eslint-utils": { 1105 | "version": "2.1.0", 1106 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 1107 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 1108 | "dev": true, 1109 | "requires": { 1110 | "eslint-visitor-keys": "^1.1.0" 1111 | } 1112 | }, 1113 | "eslint-visitor-keys": { 1114 | "version": "1.3.0", 1115 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1116 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1117 | "dev": true 1118 | }, 1119 | "espree": { 1120 | "version": "6.2.1", 1121 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.2.1.tgz", 1122 | "integrity": "sha512-ysCxRQY3WaXJz9tdbWOwuWr5Y/XrPTGX9Kiz3yoUXwW0VZ4w30HTkQLaGx/+ttFjF8i+ACbArnB4ce68a9m5hw==", 1123 | "dev": true, 1124 | "requires": { 1125 | "acorn": "^7.1.1", 1126 | "acorn-jsx": "^5.2.0", 1127 | "eslint-visitor-keys": "^1.1.0" 1128 | } 1129 | }, 1130 | "esprima": { 1131 | "version": "4.0.1", 1132 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1133 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1134 | "dev": true 1135 | }, 1136 | "esquery": { 1137 | "version": "1.3.1", 1138 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 1139 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 1140 | "dev": true, 1141 | "requires": { 1142 | "estraverse": "^5.1.0" 1143 | }, 1144 | "dependencies": { 1145 | "estraverse": { 1146 | "version": "5.1.0", 1147 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.1.0.tgz", 1148 | "integrity": "sha512-FyohXK+R0vE+y1nHLoBM7ZTyqRpqAlhdZHCWIWEviFLiGB8b04H6bQs8G+XTthacvT8VuwvteiP7RJSxMs8UEw==", 1149 | "dev": true 1150 | } 1151 | } 1152 | }, 1153 | "esrecurse": { 1154 | "version": "4.2.1", 1155 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 1156 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 1157 | "dev": true, 1158 | "requires": { 1159 | "estraverse": "^4.1.0" 1160 | } 1161 | }, 1162 | "estraverse": { 1163 | "version": "4.3.0", 1164 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1165 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1166 | "dev": true 1167 | }, 1168 | "esutils": { 1169 | "version": "2.0.3", 1170 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1171 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1172 | "dev": true 1173 | }, 1174 | "external-editor": { 1175 | "version": "3.1.0", 1176 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 1177 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 1178 | "dev": true, 1179 | "requires": { 1180 | "chardet": "^0.7.0", 1181 | "iconv-lite": "^0.4.24", 1182 | "tmp": "^0.0.33" 1183 | } 1184 | }, 1185 | "fast-deep-equal": { 1186 | "version": "3.1.3", 1187 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1188 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1189 | "dev": true 1190 | }, 1191 | "fast-json-stable-stringify": { 1192 | "version": "2.1.0", 1193 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1194 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1195 | "dev": true 1196 | }, 1197 | "fast-levenshtein": { 1198 | "version": "2.0.6", 1199 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1200 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1201 | "dev": true 1202 | }, 1203 | "figures": { 1204 | "version": "3.2.0", 1205 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", 1206 | "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", 1207 | "dev": true, 1208 | "requires": { 1209 | "escape-string-regexp": "^1.0.5" 1210 | } 1211 | }, 1212 | "file-entry-cache": { 1213 | "version": "5.0.1", 1214 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 1215 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 1216 | "dev": true, 1217 | "requires": { 1218 | "flat-cache": "^2.0.1" 1219 | } 1220 | }, 1221 | "fill-range": { 1222 | "version": "7.0.1", 1223 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1224 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1225 | "dev": true, 1226 | "requires": { 1227 | "to-regex-range": "^5.0.1" 1228 | } 1229 | }, 1230 | "find-cache-dir": { 1231 | "version": "3.3.1", 1232 | "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.1.tgz", 1233 | "integrity": "sha512-t2GDMt3oGC/v+BMwzmllWDuJF/xcDtE5j/fCGbqDD7OLuJkj0cfh1YSA5VKPvwMeLFLNDBkwOKZ2X85jGLVftQ==", 1234 | "dev": true, 1235 | "requires": { 1236 | "commondir": "^1.0.1", 1237 | "make-dir": "^3.0.2", 1238 | "pkg-dir": "^4.1.0" 1239 | } 1240 | }, 1241 | "find-up": { 1242 | "version": "3.0.0", 1243 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 1244 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 1245 | "dev": true, 1246 | "requires": { 1247 | "locate-path": "^3.0.0" 1248 | } 1249 | }, 1250 | "flat": { 1251 | "version": "4.1.0", 1252 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 1253 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 1254 | "dev": true, 1255 | "requires": { 1256 | "is-buffer": "~2.0.3" 1257 | } 1258 | }, 1259 | "flat-cache": { 1260 | "version": "2.0.1", 1261 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 1262 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 1263 | "dev": true, 1264 | "requires": { 1265 | "flatted": "^2.0.0", 1266 | "rimraf": "2.6.3", 1267 | "write": "1.0.3" 1268 | } 1269 | }, 1270 | "flatted": { 1271 | "version": "2.0.2", 1272 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.2.tgz", 1273 | "integrity": "sha512-r5wGx7YeOwNWNlCA0wQ86zKyDLMQr+/RB8xy74M4hTphfmjlijTSSXGuH8rnvKZnfT9i+75zmd8jcKdMR4O6jA==", 1274 | "dev": true 1275 | }, 1276 | "foreground-child": { 1277 | "version": "2.0.0", 1278 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", 1279 | "integrity": "sha512-dCIq9FpEcyQyXKCkyzmlPTFNgrCzPudOe+mhvJU5zAtlBnGVy2yKxtfsxK2tQBThwq225jcvBjpw1Gr40uzZCA==", 1280 | "dev": true, 1281 | "requires": { 1282 | "cross-spawn": "^7.0.0", 1283 | "signal-exit": "^3.0.2" 1284 | }, 1285 | "dependencies": { 1286 | "cross-spawn": { 1287 | "version": "7.0.3", 1288 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1289 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1290 | "dev": true, 1291 | "requires": { 1292 | "path-key": "^3.1.0", 1293 | "shebang-command": "^2.0.0", 1294 | "which": "^2.0.1" 1295 | } 1296 | }, 1297 | "path-key": { 1298 | "version": "3.1.1", 1299 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1300 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1301 | "dev": true 1302 | }, 1303 | "shebang-command": { 1304 | "version": "2.0.0", 1305 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1306 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1307 | "dev": true, 1308 | "requires": { 1309 | "shebang-regex": "^3.0.0" 1310 | } 1311 | }, 1312 | "shebang-regex": { 1313 | "version": "3.0.0", 1314 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1315 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1316 | "dev": true 1317 | }, 1318 | "which": { 1319 | "version": "2.0.2", 1320 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1321 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1322 | "dev": true, 1323 | "requires": { 1324 | "isexe": "^2.0.0" 1325 | } 1326 | } 1327 | } 1328 | }, 1329 | "fromentries": { 1330 | "version": "1.2.1", 1331 | "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.2.1.tgz", 1332 | "integrity": "sha512-Xu2Qh8yqYuDhQGOhD5iJGninErSfI9A3FrriD3tjUgV5VbJFeH8vfgZ9HnC6jWN80QDVNQK5vmxRAmEAp7Mevw==", 1333 | "dev": true 1334 | }, 1335 | "fs.realpath": { 1336 | "version": "1.0.0", 1337 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1338 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1339 | "dev": true 1340 | }, 1341 | "fsevents": { 1342 | "version": "2.1.3", 1343 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 1344 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 1345 | "dev": true, 1346 | "optional": true 1347 | }, 1348 | "function-bind": { 1349 | "version": "1.1.1", 1350 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1351 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1352 | "dev": true 1353 | }, 1354 | "functional-red-black-tree": { 1355 | "version": "1.0.1", 1356 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1357 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1358 | "dev": true 1359 | }, 1360 | "gensync": { 1361 | "version": "1.0.0-beta.1", 1362 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.1.tgz", 1363 | "integrity": "sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==", 1364 | "dev": true 1365 | }, 1366 | "get-caller-file": { 1367 | "version": "2.0.5", 1368 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1369 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1370 | "dev": true 1371 | }, 1372 | "get-func-name": { 1373 | "version": "2.0.0", 1374 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 1375 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 1376 | "dev": true 1377 | }, 1378 | "get-package-type": { 1379 | "version": "0.1.0", 1380 | "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", 1381 | "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", 1382 | "dev": true 1383 | }, 1384 | "glob": { 1385 | "version": "7.1.6", 1386 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1387 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1388 | "dev": true, 1389 | "requires": { 1390 | "fs.realpath": "^1.0.0", 1391 | "inflight": "^1.0.4", 1392 | "inherits": "2", 1393 | "minimatch": "^3.0.4", 1394 | "once": "^1.3.0", 1395 | "path-is-absolute": "^1.0.0" 1396 | } 1397 | }, 1398 | "glob-parent": { 1399 | "version": "5.1.1", 1400 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 1401 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 1402 | "dev": true, 1403 | "requires": { 1404 | "is-glob": "^4.0.1" 1405 | } 1406 | }, 1407 | "globals": { 1408 | "version": "12.4.0", 1409 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 1410 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 1411 | "dev": true, 1412 | "requires": { 1413 | "type-fest": "^0.8.1" 1414 | } 1415 | }, 1416 | "graceful-fs": { 1417 | "version": "4.2.4", 1418 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 1419 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 1420 | "dev": true 1421 | }, 1422 | "growl": { 1423 | "version": "1.10.5", 1424 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1425 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1426 | "dev": true 1427 | }, 1428 | "has": { 1429 | "version": "1.0.3", 1430 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1431 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1432 | "dev": true, 1433 | "requires": { 1434 | "function-bind": "^1.1.1" 1435 | } 1436 | }, 1437 | "has-flag": { 1438 | "version": "3.0.0", 1439 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1440 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1441 | "dev": true 1442 | }, 1443 | "has-symbols": { 1444 | "version": "1.0.1", 1445 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1446 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1447 | "dev": true 1448 | }, 1449 | "hasha": { 1450 | "version": "5.2.0", 1451 | "resolved": "https://registry.npmjs.org/hasha/-/hasha-5.2.0.tgz", 1452 | "integrity": "sha512-2W+jKdQbAdSIrggA8Q35Br8qKadTrqCTC8+XZvBWepKDK6m9XkX6Iz1a2yh2KP01kzAR/dpuMeUnocoLYDcskw==", 1453 | "dev": true, 1454 | "requires": { 1455 | "is-stream": "^2.0.0", 1456 | "type-fest": "^0.8.0" 1457 | } 1458 | }, 1459 | "he": { 1460 | "version": "1.2.0", 1461 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1462 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1463 | "dev": true 1464 | }, 1465 | "html-escaper": { 1466 | "version": "2.0.2", 1467 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1468 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1469 | "dev": true 1470 | }, 1471 | "http-proxy-agent": { 1472 | "version": "2.1.0", 1473 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-2.1.0.tgz", 1474 | "integrity": "sha512-qwHbBLV7WviBl0rQsOzH6o5lwyOIvwp/BdFnvVxXORldu5TmjFfjzBcWUWS5kWAZhmv+JtiDhSuQCp4sBfbIgg==", 1475 | "dev": true, 1476 | "requires": { 1477 | "agent-base": "4", 1478 | "debug": "3.1.0" 1479 | }, 1480 | "dependencies": { 1481 | "debug": { 1482 | "version": "3.1.0", 1483 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1484 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1485 | "dev": true, 1486 | "requires": { 1487 | "ms": "2.0.0" 1488 | } 1489 | }, 1490 | "ms": { 1491 | "version": "2.0.0", 1492 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1493 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1494 | "dev": true 1495 | } 1496 | } 1497 | }, 1498 | "https-proxy-agent": { 1499 | "version": "2.2.4", 1500 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-2.2.4.tgz", 1501 | "integrity": "sha512-OmvfoQ53WLjtA9HeYP9RNrWMJzzAz1JGaSFr1nijg0PVR1JaD/xbJq1mdEIIlxGpXp9eSe/O2LgU9DJmTPd0Eg==", 1502 | "dev": true, 1503 | "requires": { 1504 | "agent-base": "^4.3.0", 1505 | "debug": "^3.1.0" 1506 | }, 1507 | "dependencies": { 1508 | "debug": { 1509 | "version": "3.2.6", 1510 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1511 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1512 | "dev": true, 1513 | "requires": { 1514 | "ms": "^2.1.1" 1515 | } 1516 | } 1517 | } 1518 | }, 1519 | "iconv-lite": { 1520 | "version": "0.4.24", 1521 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1522 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1523 | "dev": true, 1524 | "requires": { 1525 | "safer-buffer": ">= 2.1.2 < 3" 1526 | } 1527 | }, 1528 | "ignore": { 1529 | "version": "4.0.6", 1530 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1531 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1532 | "dev": true 1533 | }, 1534 | "import-fresh": { 1535 | "version": "3.2.1", 1536 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 1537 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 1538 | "dev": true, 1539 | "requires": { 1540 | "parent-module": "^1.0.0", 1541 | "resolve-from": "^4.0.0" 1542 | } 1543 | }, 1544 | "imurmurhash": { 1545 | "version": "0.1.4", 1546 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1547 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1548 | "dev": true 1549 | }, 1550 | "indent-string": { 1551 | "version": "4.0.0", 1552 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 1553 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 1554 | "dev": true 1555 | }, 1556 | "inflight": { 1557 | "version": "1.0.6", 1558 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1559 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1560 | "dev": true, 1561 | "requires": { 1562 | "once": "^1.3.0", 1563 | "wrappy": "1" 1564 | } 1565 | }, 1566 | "inherits": { 1567 | "version": "2.0.4", 1568 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1569 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1570 | "dev": true 1571 | }, 1572 | "inquirer": { 1573 | "version": "7.3.2", 1574 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.3.2.tgz", 1575 | "integrity": "sha512-DF4osh1FM6l0RJc5YWYhSDB6TawiBRlbV9Cox8MWlidU218Tb7fm3lQTULyUJDfJ0tjbzl0W4q651mrCCEM55w==", 1576 | "dev": true, 1577 | "requires": { 1578 | "ansi-escapes": "^4.2.1", 1579 | "chalk": "^4.1.0", 1580 | "cli-cursor": "^3.1.0", 1581 | "cli-width": "^3.0.0", 1582 | "external-editor": "^3.0.3", 1583 | "figures": "^3.0.0", 1584 | "lodash": "^4.17.16", 1585 | "mute-stream": "0.0.8", 1586 | "run-async": "^2.4.0", 1587 | "rxjs": "^6.6.0", 1588 | "string-width": "^4.1.0", 1589 | "strip-ansi": "^6.0.0", 1590 | "through": "^2.3.6" 1591 | }, 1592 | "dependencies": { 1593 | "ansi-styles": { 1594 | "version": "4.2.1", 1595 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 1596 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 1597 | "dev": true, 1598 | "requires": { 1599 | "@types/color-name": "^1.1.1", 1600 | "color-convert": "^2.0.1" 1601 | } 1602 | }, 1603 | "chalk": { 1604 | "version": "4.1.0", 1605 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1606 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1607 | "dev": true, 1608 | "requires": { 1609 | "ansi-styles": "^4.1.0", 1610 | "supports-color": "^7.1.0" 1611 | } 1612 | }, 1613 | "color-convert": { 1614 | "version": "2.0.1", 1615 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1616 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1617 | "dev": true, 1618 | "requires": { 1619 | "color-name": "~1.1.4" 1620 | } 1621 | }, 1622 | "color-name": { 1623 | "version": "1.1.4", 1624 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1625 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1626 | "dev": true 1627 | }, 1628 | "has-flag": { 1629 | "version": "4.0.0", 1630 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1631 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1632 | "dev": true 1633 | }, 1634 | "strip-ansi": { 1635 | "version": "6.0.0", 1636 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1637 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1638 | "dev": true, 1639 | "requires": { 1640 | "ansi-regex": "^5.0.0" 1641 | } 1642 | }, 1643 | "supports-color": { 1644 | "version": "7.1.0", 1645 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1646 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1647 | "dev": true, 1648 | "requires": { 1649 | "has-flag": "^4.0.0" 1650 | } 1651 | } 1652 | } 1653 | }, 1654 | "is-binary-path": { 1655 | "version": "2.1.0", 1656 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1657 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1658 | "dev": true, 1659 | "requires": { 1660 | "binary-extensions": "^2.0.0" 1661 | } 1662 | }, 1663 | "is-buffer": { 1664 | "version": "2.0.4", 1665 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1666 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1667 | "dev": true 1668 | }, 1669 | "is-callable": { 1670 | "version": "1.2.0", 1671 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.0.tgz", 1672 | "integrity": "sha512-pyVD9AaGLxtg6srb2Ng6ynWJqkHU9bEM087AKck0w8QwDarTfNcpIYoU8x8Hv2Icm8u6kFJM18Dag8lyqGkviw==", 1673 | "dev": true 1674 | }, 1675 | "is-date-object": { 1676 | "version": "1.0.2", 1677 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1678 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1679 | "dev": true 1680 | }, 1681 | "is-extglob": { 1682 | "version": "2.1.1", 1683 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1684 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1685 | "dev": true 1686 | }, 1687 | "is-fullwidth-code-point": { 1688 | "version": "3.0.0", 1689 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1690 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1691 | "dev": true 1692 | }, 1693 | "is-glob": { 1694 | "version": "4.0.1", 1695 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1696 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1697 | "dev": true, 1698 | "requires": { 1699 | "is-extglob": "^2.1.1" 1700 | } 1701 | }, 1702 | "is-number": { 1703 | "version": "7.0.0", 1704 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1705 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1706 | "dev": true 1707 | }, 1708 | "is-regex": { 1709 | "version": "1.1.0", 1710 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.0.tgz", 1711 | "integrity": "sha512-iI97M8KTWID2la5uYXlkbSDQIg4F6o1sYboZKKTDpnDQMLtUL86zxhgDet3Q2SriaYsyGqZ6Mn2SjbRKeLHdqw==", 1712 | "dev": true, 1713 | "requires": { 1714 | "has-symbols": "^1.0.1" 1715 | } 1716 | }, 1717 | "is-stream": { 1718 | "version": "2.0.0", 1719 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz", 1720 | "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==", 1721 | "dev": true 1722 | }, 1723 | "is-symbol": { 1724 | "version": "1.0.3", 1725 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1726 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1727 | "dev": true, 1728 | "requires": { 1729 | "has-symbols": "^1.0.1" 1730 | } 1731 | }, 1732 | "is-typedarray": { 1733 | "version": "1.0.0", 1734 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1735 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1736 | "dev": true 1737 | }, 1738 | "is-windows": { 1739 | "version": "1.0.2", 1740 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1741 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1742 | "dev": true 1743 | }, 1744 | "isarray": { 1745 | "version": "1.0.0", 1746 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1747 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1748 | "dev": true 1749 | }, 1750 | "isexe": { 1751 | "version": "2.0.0", 1752 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1753 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1754 | "dev": true 1755 | }, 1756 | "istanbul-lib-coverage": { 1757 | "version": "3.0.0", 1758 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz", 1759 | "integrity": "sha512-UiUIqxMgRDET6eR+o5HbfRYP1l0hqkWOs7vNxC/mggutCMUIhWMm8gAHb8tHlyfD3/l6rlgNA5cKdDzEAf6hEg==", 1760 | "dev": true 1761 | }, 1762 | "istanbul-lib-hook": { 1763 | "version": "3.0.0", 1764 | "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-3.0.0.tgz", 1765 | "integrity": "sha512-Pt/uge1Q9s+5VAZ+pCo16TYMWPBIl+oaNIjgLQxcX0itS6ueeaA+pEfThZpH8WxhFgCiEb8sAJY6MdUKgiIWaQ==", 1766 | "dev": true, 1767 | "requires": { 1768 | "append-transform": "^2.0.0" 1769 | } 1770 | }, 1771 | "istanbul-lib-instrument": { 1772 | "version": "4.0.3", 1773 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz", 1774 | "integrity": "sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==", 1775 | "dev": true, 1776 | "requires": { 1777 | "@babel/core": "^7.7.5", 1778 | "@istanbuljs/schema": "^0.1.2", 1779 | "istanbul-lib-coverage": "^3.0.0", 1780 | "semver": "^6.3.0" 1781 | }, 1782 | "dependencies": { 1783 | "semver": { 1784 | "version": "6.3.0", 1785 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1786 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1787 | "dev": true 1788 | } 1789 | } 1790 | }, 1791 | "istanbul-lib-processinfo": { 1792 | "version": "2.0.2", 1793 | "resolved": "https://registry.npmjs.org/istanbul-lib-processinfo/-/istanbul-lib-processinfo-2.0.2.tgz", 1794 | "integrity": "sha512-kOwpa7z9hme+IBPZMzQ5vdQj8srYgAtaRqeI48NGmAQ+/5yKiHLV0QbYqQpxsdEF0+w14SoB8YbnHKcXE2KnYw==", 1795 | "dev": true, 1796 | "requires": { 1797 | "archy": "^1.0.0", 1798 | "cross-spawn": "^7.0.0", 1799 | "istanbul-lib-coverage": "^3.0.0-alpha.1", 1800 | "make-dir": "^3.0.0", 1801 | "p-map": "^3.0.0", 1802 | "rimraf": "^3.0.0", 1803 | "uuid": "^3.3.3" 1804 | }, 1805 | "dependencies": { 1806 | "cross-spawn": { 1807 | "version": "7.0.3", 1808 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1809 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1810 | "dev": true, 1811 | "requires": { 1812 | "path-key": "^3.1.0", 1813 | "shebang-command": "^2.0.0", 1814 | "which": "^2.0.1" 1815 | } 1816 | }, 1817 | "path-key": { 1818 | "version": "3.1.1", 1819 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1820 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1821 | "dev": true 1822 | }, 1823 | "rimraf": { 1824 | "version": "3.0.2", 1825 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1826 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1827 | "dev": true, 1828 | "requires": { 1829 | "glob": "^7.1.3" 1830 | } 1831 | }, 1832 | "shebang-command": { 1833 | "version": "2.0.0", 1834 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1835 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1836 | "dev": true, 1837 | "requires": { 1838 | "shebang-regex": "^3.0.0" 1839 | } 1840 | }, 1841 | "shebang-regex": { 1842 | "version": "3.0.0", 1843 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1844 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1845 | "dev": true 1846 | }, 1847 | "which": { 1848 | "version": "2.0.2", 1849 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1850 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1851 | "dev": true, 1852 | "requires": { 1853 | "isexe": "^2.0.0" 1854 | } 1855 | } 1856 | } 1857 | }, 1858 | "istanbul-lib-report": { 1859 | "version": "3.0.0", 1860 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1861 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 1862 | "dev": true, 1863 | "requires": { 1864 | "istanbul-lib-coverage": "^3.0.0", 1865 | "make-dir": "^3.0.0", 1866 | "supports-color": "^7.1.0" 1867 | }, 1868 | "dependencies": { 1869 | "has-flag": { 1870 | "version": "4.0.0", 1871 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1872 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1873 | "dev": true 1874 | }, 1875 | "supports-color": { 1876 | "version": "7.1.0", 1877 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1878 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1879 | "dev": true, 1880 | "requires": { 1881 | "has-flag": "^4.0.0" 1882 | } 1883 | } 1884 | } 1885 | }, 1886 | "istanbul-lib-source-maps": { 1887 | "version": "4.0.0", 1888 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.0.tgz", 1889 | "integrity": "sha512-c16LpFRkR8vQXyHZ5nLpY35JZtzj1PQY1iZmesUbf1FZHbIupcWfjgOXBY9YHkLEQ6puz1u4Dgj6qmU/DisrZg==", 1890 | "dev": true, 1891 | "requires": { 1892 | "debug": "^4.1.1", 1893 | "istanbul-lib-coverage": "^3.0.0", 1894 | "source-map": "^0.6.1" 1895 | }, 1896 | "dependencies": { 1897 | "source-map": { 1898 | "version": "0.6.1", 1899 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1900 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1901 | "dev": true 1902 | } 1903 | } 1904 | }, 1905 | "istanbul-reports": { 1906 | "version": "3.0.2", 1907 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.0.2.tgz", 1908 | "integrity": "sha512-9tZvz7AiR3PEDNGiV9vIouQ/EAcqMXFmkcA1CDFTwOB98OZVDL0PH9glHotf5Ugp6GCOTypfzGWI/OqjWNCRUw==", 1909 | "dev": true, 1910 | "requires": { 1911 | "html-escaper": "^2.0.0", 1912 | "istanbul-lib-report": "^3.0.0" 1913 | } 1914 | }, 1915 | "js-tokens": { 1916 | "version": "4.0.0", 1917 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1918 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1919 | "dev": true 1920 | }, 1921 | "js-yaml": { 1922 | "version": "3.14.0", 1923 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 1924 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 1925 | "dev": true, 1926 | "requires": { 1927 | "argparse": "^1.0.7", 1928 | "esprima": "^4.0.0" 1929 | } 1930 | }, 1931 | "jsesc": { 1932 | "version": "2.5.2", 1933 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1934 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1935 | "dev": true 1936 | }, 1937 | "json-schema-traverse": { 1938 | "version": "0.4.1", 1939 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1940 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1941 | "dev": true 1942 | }, 1943 | "json-stable-stringify-without-jsonify": { 1944 | "version": "1.0.1", 1945 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1946 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1947 | "dev": true 1948 | }, 1949 | "json5": { 1950 | "version": "2.1.3", 1951 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", 1952 | "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", 1953 | "dev": true, 1954 | "requires": { 1955 | "minimist": "^1.2.5" 1956 | } 1957 | }, 1958 | "levn": { 1959 | "version": "0.3.0", 1960 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1961 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1962 | "dev": true, 1963 | "requires": { 1964 | "prelude-ls": "~1.1.2", 1965 | "type-check": "~0.3.2" 1966 | } 1967 | }, 1968 | "loader-utils": { 1969 | "version": "1.4.0", 1970 | "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.4.0.tgz", 1971 | "integrity": "sha512-qH0WSMBtn/oHuwjy/NucEgbx5dbxxnxup9s4PVXJUDHZBQY+s0NWA9rJf53RBnQZxfch7euUui7hpoAPvALZdA==", 1972 | "dev": true, 1973 | "requires": { 1974 | "big.js": "^5.2.2", 1975 | "emojis-list": "^3.0.0", 1976 | "json5": "^1.0.1" 1977 | }, 1978 | "dependencies": { 1979 | "json5": { 1980 | "version": "1.0.1", 1981 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", 1982 | "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", 1983 | "dev": true, 1984 | "requires": { 1985 | "minimist": "^1.2.0" 1986 | } 1987 | } 1988 | } 1989 | }, 1990 | "locate-path": { 1991 | "version": "3.0.0", 1992 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1993 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1994 | "dev": true, 1995 | "requires": { 1996 | "p-locate": "^3.0.0", 1997 | "path-exists": "^3.0.0" 1998 | } 1999 | }, 2000 | "lodash": { 2001 | "version": "4.17.19", 2002 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 2003 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 2004 | "dev": true 2005 | }, 2006 | "lodash.camelcase": { 2007 | "version": "4.3.0", 2008 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 2009 | "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=" 2010 | }, 2011 | "lodash.flattendeep": { 2012 | "version": "4.4.0", 2013 | "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", 2014 | "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=", 2015 | "dev": true 2016 | }, 2017 | "log-symbols": { 2018 | "version": "3.0.0", 2019 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-3.0.0.tgz", 2020 | "integrity": "sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ==", 2021 | "dev": true, 2022 | "requires": { 2023 | "chalk": "^2.4.2" 2024 | } 2025 | }, 2026 | "long": { 2027 | "version": "4.0.0", 2028 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 2029 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 2030 | }, 2031 | "make-dir": { 2032 | "version": "3.1.0", 2033 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2034 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2035 | "dev": true, 2036 | "requires": { 2037 | "semver": "^6.0.0" 2038 | }, 2039 | "dependencies": { 2040 | "semver": { 2041 | "version": "6.3.0", 2042 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2043 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2044 | "dev": true 2045 | } 2046 | } 2047 | }, 2048 | "make-error": { 2049 | "version": "1.3.6", 2050 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 2051 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 2052 | "dev": true 2053 | }, 2054 | "memory-fs": { 2055 | "version": "0.5.0", 2056 | "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.5.0.tgz", 2057 | "integrity": "sha512-jA0rdU5KoQMC0e6ppoNRtpp6vjFq6+NY7r8hywnC7V+1Xj/MtHwGIbB1QaK/dunyjWteJzmkpd7ooeWg10T7GA==", 2058 | "dev": true, 2059 | "requires": { 2060 | "errno": "^0.1.3", 2061 | "readable-stream": "^2.0.1" 2062 | } 2063 | }, 2064 | "micromatch": { 2065 | "version": "4.0.2", 2066 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz", 2067 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==", 2068 | "dev": true, 2069 | "requires": { 2070 | "braces": "^3.0.1", 2071 | "picomatch": "^2.0.5" 2072 | } 2073 | }, 2074 | "mimic-fn": { 2075 | "version": "2.1.0", 2076 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2077 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2078 | "dev": true 2079 | }, 2080 | "minimatch": { 2081 | "version": "3.0.4", 2082 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2083 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2084 | "dev": true, 2085 | "requires": { 2086 | "brace-expansion": "^1.1.7" 2087 | } 2088 | }, 2089 | "minimist": { 2090 | "version": "1.2.5", 2091 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 2092 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 2093 | "dev": true 2094 | }, 2095 | "mkdirp": { 2096 | "version": "0.5.5", 2097 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 2098 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 2099 | "dev": true, 2100 | "requires": { 2101 | "minimist": "^1.2.5" 2102 | } 2103 | }, 2104 | "mocha": { 2105 | "version": "7.2.0", 2106 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-7.2.0.tgz", 2107 | "integrity": "sha512-O9CIypScywTVpNaRrCAgoUnJgozpIofjKUYmJhiCIJMiuYnLI6otcb1/kpW9/n/tJODHGZ7i8aLQoDVsMtOKQQ==", 2108 | "dev": true, 2109 | "requires": { 2110 | "ansi-colors": "3.2.3", 2111 | "browser-stdout": "1.3.1", 2112 | "chokidar": "3.3.0", 2113 | "debug": "3.2.6", 2114 | "diff": "3.5.0", 2115 | "escape-string-regexp": "1.0.5", 2116 | "find-up": "3.0.0", 2117 | "glob": "7.1.3", 2118 | "growl": "1.10.5", 2119 | "he": "1.2.0", 2120 | "js-yaml": "3.13.1", 2121 | "log-symbols": "3.0.0", 2122 | "minimatch": "3.0.4", 2123 | "mkdirp": "0.5.5", 2124 | "ms": "2.1.1", 2125 | "node-environment-flags": "1.0.6", 2126 | "object.assign": "4.1.0", 2127 | "strip-json-comments": "2.0.1", 2128 | "supports-color": "6.0.0", 2129 | "which": "1.3.1", 2130 | "wide-align": "1.1.3", 2131 | "yargs": "13.3.2", 2132 | "yargs-parser": "13.1.2", 2133 | "yargs-unparser": "1.6.0" 2134 | }, 2135 | "dependencies": { 2136 | "debug": { 2137 | "version": "3.2.6", 2138 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 2139 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 2140 | "dev": true, 2141 | "requires": { 2142 | "ms": "^2.1.1" 2143 | } 2144 | }, 2145 | "glob": { 2146 | "version": "7.1.3", 2147 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 2148 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 2149 | "dev": true, 2150 | "requires": { 2151 | "fs.realpath": "^1.0.0", 2152 | "inflight": "^1.0.4", 2153 | "inherits": "2", 2154 | "minimatch": "^3.0.4", 2155 | "once": "^1.3.0", 2156 | "path-is-absolute": "^1.0.0" 2157 | } 2158 | }, 2159 | "js-yaml": { 2160 | "version": "3.13.1", 2161 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 2162 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 2163 | "dev": true, 2164 | "requires": { 2165 | "argparse": "^1.0.7", 2166 | "esprima": "^4.0.0" 2167 | } 2168 | }, 2169 | "ms": { 2170 | "version": "2.1.1", 2171 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2172 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 2173 | "dev": true 2174 | }, 2175 | "strip-json-comments": { 2176 | "version": "2.0.1", 2177 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2178 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2179 | "dev": true 2180 | }, 2181 | "supports-color": { 2182 | "version": "6.0.0", 2183 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 2184 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 2185 | "dev": true, 2186 | "requires": { 2187 | "has-flag": "^3.0.0" 2188 | } 2189 | } 2190 | } 2191 | }, 2192 | "ms": { 2193 | "version": "2.1.2", 2194 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2195 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2196 | "dev": true 2197 | }, 2198 | "mute-stream": { 2199 | "version": "0.0.8", 2200 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 2201 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 2202 | "dev": true 2203 | }, 2204 | "natural-compare": { 2205 | "version": "1.4.0", 2206 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2207 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2208 | "dev": true 2209 | }, 2210 | "nice-try": { 2211 | "version": "1.0.5", 2212 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 2213 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 2214 | "dev": true 2215 | }, 2216 | "node-environment-flags": { 2217 | "version": "1.0.6", 2218 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.6.tgz", 2219 | "integrity": "sha512-5Evy2epuL+6TM0lCQGpFIj6KwiEsGh1SrHUhTbNX+sLbBtjidPZFAnVK9y5yU1+h//RitLbRHTIMyxQPtxMdHw==", 2220 | "dev": true, 2221 | "requires": { 2222 | "object.getownpropertydescriptors": "^2.0.3", 2223 | "semver": "^5.7.0" 2224 | }, 2225 | "dependencies": { 2226 | "semver": { 2227 | "version": "5.7.1", 2228 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2229 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 2230 | "dev": true 2231 | } 2232 | } 2233 | }, 2234 | "node-preload": { 2235 | "version": "0.2.1", 2236 | "resolved": "https://registry.npmjs.org/node-preload/-/node-preload-0.2.1.tgz", 2237 | "integrity": "sha512-RM5oyBy45cLEoHqCeh+MNuFAxO0vTFBLskvQbOKnEE7YTTSN4tbN8QWDIPQ6L+WvKsB/qLEGpYe2ZZ9d4W9OIQ==", 2238 | "dev": true, 2239 | "requires": { 2240 | "process-on-spawn": "^1.0.0" 2241 | } 2242 | }, 2243 | "normalize-path": { 2244 | "version": "3.0.0", 2245 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2246 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2247 | "dev": true 2248 | }, 2249 | "nyc": { 2250 | "version": "15.1.0", 2251 | "resolved": "https://registry.npmjs.org/nyc/-/nyc-15.1.0.tgz", 2252 | "integrity": "sha512-jMW04n9SxKdKi1ZMGhvUTHBN0EICCRkHemEoE5jm6mTYcqcdas0ATzgUgejlQUHMvpnOZqGB5Xxsv9KxJW1j8A==", 2253 | "dev": true, 2254 | "requires": { 2255 | "@istanbuljs/load-nyc-config": "^1.0.0", 2256 | "@istanbuljs/schema": "^0.1.2", 2257 | "caching-transform": "^4.0.0", 2258 | "convert-source-map": "^1.7.0", 2259 | "decamelize": "^1.2.0", 2260 | "find-cache-dir": "^3.2.0", 2261 | "find-up": "^4.1.0", 2262 | "foreground-child": "^2.0.0", 2263 | "get-package-type": "^0.1.0", 2264 | "glob": "^7.1.6", 2265 | "istanbul-lib-coverage": "^3.0.0", 2266 | "istanbul-lib-hook": "^3.0.0", 2267 | "istanbul-lib-instrument": "^4.0.0", 2268 | "istanbul-lib-processinfo": "^2.0.2", 2269 | "istanbul-lib-report": "^3.0.0", 2270 | "istanbul-lib-source-maps": "^4.0.0", 2271 | "istanbul-reports": "^3.0.2", 2272 | "make-dir": "^3.0.0", 2273 | "node-preload": "^0.2.1", 2274 | "p-map": "^3.0.0", 2275 | "process-on-spawn": "^1.0.0", 2276 | "resolve-from": "^5.0.0", 2277 | "rimraf": "^3.0.0", 2278 | "signal-exit": "^3.0.2", 2279 | "spawn-wrap": "^2.0.0", 2280 | "test-exclude": "^6.0.0", 2281 | "yargs": "^15.0.2" 2282 | }, 2283 | "dependencies": { 2284 | "ansi-styles": { 2285 | "version": "4.2.1", 2286 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 2287 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 2288 | "dev": true, 2289 | "requires": { 2290 | "@types/color-name": "^1.1.1", 2291 | "color-convert": "^2.0.1" 2292 | } 2293 | }, 2294 | "cliui": { 2295 | "version": "6.0.0", 2296 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", 2297 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 2298 | "dev": true, 2299 | "requires": { 2300 | "string-width": "^4.2.0", 2301 | "strip-ansi": "^6.0.0", 2302 | "wrap-ansi": "^6.2.0" 2303 | } 2304 | }, 2305 | "color-convert": { 2306 | "version": "2.0.1", 2307 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2308 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2309 | "dev": true, 2310 | "requires": { 2311 | "color-name": "~1.1.4" 2312 | } 2313 | }, 2314 | "color-name": { 2315 | "version": "1.1.4", 2316 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2317 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2318 | "dev": true 2319 | }, 2320 | "find-up": { 2321 | "version": "4.1.0", 2322 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2323 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2324 | "dev": true, 2325 | "requires": { 2326 | "locate-path": "^5.0.0", 2327 | "path-exists": "^4.0.0" 2328 | } 2329 | }, 2330 | "locate-path": { 2331 | "version": "5.0.0", 2332 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2333 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2334 | "dev": true, 2335 | "requires": { 2336 | "p-locate": "^4.1.0" 2337 | } 2338 | }, 2339 | "p-locate": { 2340 | "version": "4.1.0", 2341 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2342 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2343 | "dev": true, 2344 | "requires": { 2345 | "p-limit": "^2.2.0" 2346 | } 2347 | }, 2348 | "path-exists": { 2349 | "version": "4.0.0", 2350 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2351 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2352 | "dev": true 2353 | }, 2354 | "resolve-from": { 2355 | "version": "5.0.0", 2356 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 2357 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 2358 | "dev": true 2359 | }, 2360 | "rimraf": { 2361 | "version": "3.0.2", 2362 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2363 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2364 | "dev": true, 2365 | "requires": { 2366 | "glob": "^7.1.3" 2367 | } 2368 | }, 2369 | "strip-ansi": { 2370 | "version": "6.0.0", 2371 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2372 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2373 | "dev": true, 2374 | "requires": { 2375 | "ansi-regex": "^5.0.0" 2376 | } 2377 | }, 2378 | "wrap-ansi": { 2379 | "version": "6.2.0", 2380 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 2381 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 2382 | "dev": true, 2383 | "requires": { 2384 | "ansi-styles": "^4.0.0", 2385 | "string-width": "^4.1.0", 2386 | "strip-ansi": "^6.0.0" 2387 | } 2388 | }, 2389 | "yargs": { 2390 | "version": "15.4.1", 2391 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", 2392 | "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", 2393 | "dev": true, 2394 | "requires": { 2395 | "cliui": "^6.0.0", 2396 | "decamelize": "^1.2.0", 2397 | "find-up": "^4.1.0", 2398 | "get-caller-file": "^2.0.1", 2399 | "require-directory": "^2.1.1", 2400 | "require-main-filename": "^2.0.0", 2401 | "set-blocking": "^2.0.0", 2402 | "string-width": "^4.2.0", 2403 | "which-module": "^2.0.0", 2404 | "y18n": "^4.0.0", 2405 | "yargs-parser": "^18.1.2" 2406 | } 2407 | }, 2408 | "yargs-parser": { 2409 | "version": "18.1.3", 2410 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", 2411 | "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", 2412 | "dev": true, 2413 | "requires": { 2414 | "camelcase": "^5.0.0", 2415 | "decamelize": "^1.2.0" 2416 | } 2417 | } 2418 | } 2419 | }, 2420 | "object-inspect": { 2421 | "version": "1.8.0", 2422 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 2423 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 2424 | "dev": true 2425 | }, 2426 | "object-keys": { 2427 | "version": "1.1.1", 2428 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2429 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2430 | "dev": true 2431 | }, 2432 | "object.assign": { 2433 | "version": "4.1.0", 2434 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 2435 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 2436 | "dev": true, 2437 | "requires": { 2438 | "define-properties": "^1.1.2", 2439 | "function-bind": "^1.1.1", 2440 | "has-symbols": "^1.0.0", 2441 | "object-keys": "^1.0.11" 2442 | } 2443 | }, 2444 | "object.getownpropertydescriptors": { 2445 | "version": "2.1.0", 2446 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", 2447 | "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", 2448 | "dev": true, 2449 | "requires": { 2450 | "define-properties": "^1.1.3", 2451 | "es-abstract": "^1.17.0-next.1" 2452 | } 2453 | }, 2454 | "once": { 2455 | "version": "1.4.0", 2456 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2457 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2458 | "dev": true, 2459 | "requires": { 2460 | "wrappy": "1" 2461 | } 2462 | }, 2463 | "onetime": { 2464 | "version": "5.1.0", 2465 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 2466 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 2467 | "dev": true, 2468 | "requires": { 2469 | "mimic-fn": "^2.1.0" 2470 | } 2471 | }, 2472 | "optionator": { 2473 | "version": "0.8.3", 2474 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 2475 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 2476 | "dev": true, 2477 | "requires": { 2478 | "deep-is": "~0.1.3", 2479 | "fast-levenshtein": "~2.0.6", 2480 | "levn": "~0.3.0", 2481 | "prelude-ls": "~1.1.2", 2482 | "type-check": "~0.3.2", 2483 | "word-wrap": "~1.2.3" 2484 | } 2485 | }, 2486 | "os-tmpdir": { 2487 | "version": "1.0.2", 2488 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2489 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 2490 | "dev": true 2491 | }, 2492 | "p-limit": { 2493 | "version": "2.3.0", 2494 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2495 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2496 | "dev": true, 2497 | "requires": { 2498 | "p-try": "^2.0.0" 2499 | } 2500 | }, 2501 | "p-locate": { 2502 | "version": "3.0.0", 2503 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2504 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2505 | "dev": true, 2506 | "requires": { 2507 | "p-limit": "^2.0.0" 2508 | } 2509 | }, 2510 | "p-map": { 2511 | "version": "3.0.0", 2512 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", 2513 | "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", 2514 | "dev": true, 2515 | "requires": { 2516 | "aggregate-error": "^3.0.0" 2517 | } 2518 | }, 2519 | "p-try": { 2520 | "version": "2.2.0", 2521 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 2522 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 2523 | "dev": true 2524 | }, 2525 | "package-hash": { 2526 | "version": "4.0.0", 2527 | "resolved": "https://registry.npmjs.org/package-hash/-/package-hash-4.0.0.tgz", 2528 | "integrity": "sha512-whdkPIooSu/bASggZ96BWVvZTRMOFxnyUG5PnTSGKoJE2gd5mbVNmR2Nj20QFzxYYgAXpoqC+AiXzl+UMRh7zQ==", 2529 | "dev": true, 2530 | "requires": { 2531 | "graceful-fs": "^4.1.15", 2532 | "hasha": "^5.0.0", 2533 | "lodash.flattendeep": "^4.4.0", 2534 | "release-zalgo": "^1.0.0" 2535 | } 2536 | }, 2537 | "parent-module": { 2538 | "version": "1.0.1", 2539 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2540 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2541 | "dev": true, 2542 | "requires": { 2543 | "callsites": "^3.0.0" 2544 | } 2545 | }, 2546 | "path-exists": { 2547 | "version": "3.0.0", 2548 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2549 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2550 | "dev": true 2551 | }, 2552 | "path-is-absolute": { 2553 | "version": "1.0.1", 2554 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2555 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2556 | "dev": true 2557 | }, 2558 | "path-key": { 2559 | "version": "2.0.1", 2560 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2561 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2562 | "dev": true 2563 | }, 2564 | "path-parse": { 2565 | "version": "1.0.6", 2566 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2567 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 2568 | "dev": true 2569 | }, 2570 | "pathval": { 2571 | "version": "1.1.0", 2572 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz", 2573 | "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=", 2574 | "dev": true 2575 | }, 2576 | "picomatch": { 2577 | "version": "2.2.2", 2578 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 2579 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 2580 | "dev": true 2581 | }, 2582 | "pkg-dir": { 2583 | "version": "4.2.0", 2584 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 2585 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 2586 | "dev": true, 2587 | "requires": { 2588 | "find-up": "^4.0.0" 2589 | }, 2590 | "dependencies": { 2591 | "find-up": { 2592 | "version": "4.1.0", 2593 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2594 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2595 | "dev": true, 2596 | "requires": { 2597 | "locate-path": "^5.0.0", 2598 | "path-exists": "^4.0.0" 2599 | } 2600 | }, 2601 | "locate-path": { 2602 | "version": "5.0.0", 2603 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2604 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2605 | "dev": true, 2606 | "requires": { 2607 | "p-locate": "^4.1.0" 2608 | } 2609 | }, 2610 | "p-locate": { 2611 | "version": "4.1.0", 2612 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2613 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2614 | "dev": true, 2615 | "requires": { 2616 | "p-limit": "^2.2.0" 2617 | } 2618 | }, 2619 | "path-exists": { 2620 | "version": "4.0.0", 2621 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2622 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2623 | "dev": true 2624 | } 2625 | } 2626 | }, 2627 | "prelude-ls": { 2628 | "version": "1.1.2", 2629 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2630 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2631 | "dev": true 2632 | }, 2633 | "process-nextick-args": { 2634 | "version": "2.0.1", 2635 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2636 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2637 | "dev": true 2638 | }, 2639 | "process-on-spawn": { 2640 | "version": "1.0.0", 2641 | "resolved": "https://registry.npmjs.org/process-on-spawn/-/process-on-spawn-1.0.0.tgz", 2642 | "integrity": "sha512-1WsPDsUSMmZH5LeMLegqkPDrsGgsWwk1Exipy2hvB0o/F0ASzbpIctSCcZIK1ykJvtTJULEH+20WOFjMvGnCTg==", 2643 | "dev": true, 2644 | "requires": { 2645 | "fromentries": "^1.2.0" 2646 | } 2647 | }, 2648 | "progress": { 2649 | "version": "2.0.3", 2650 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2651 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2652 | "dev": true 2653 | }, 2654 | "protobufjs": { 2655 | "version": "6.10.1", 2656 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.10.1.tgz", 2657 | "integrity": "sha512-pb8kTchL+1Ceg4lFd5XUpK8PdWacbvV5SK2ULH2ebrYtl4GjJmS24m6CKME67jzV53tbJxHlnNOSqQHbTsR9JQ==", 2658 | "requires": { 2659 | "@protobufjs/aspromise": "^1.1.2", 2660 | "@protobufjs/base64": "^1.1.2", 2661 | "@protobufjs/codegen": "^2.0.4", 2662 | "@protobufjs/eventemitter": "^1.1.0", 2663 | "@protobufjs/fetch": "^1.1.0", 2664 | "@protobufjs/float": "^1.0.2", 2665 | "@protobufjs/inquire": "^1.1.0", 2666 | "@protobufjs/path": "^1.1.2", 2667 | "@protobufjs/pool": "^1.1.0", 2668 | "@protobufjs/utf8": "^1.1.0", 2669 | "@types/long": "^4.0.1", 2670 | "@types/node": "^13.7.0", 2671 | "long": "^4.0.0" 2672 | } 2673 | }, 2674 | "prr": { 2675 | "version": "1.0.1", 2676 | "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", 2677 | "integrity": "sha1-0/wRS6BplaRexok/SEzrHXj19HY=", 2678 | "dev": true 2679 | }, 2680 | "punycode": { 2681 | "version": "2.1.1", 2682 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2683 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2684 | "dev": true 2685 | }, 2686 | "ramda": { 2687 | "version": "0.27.1", 2688 | "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.27.1.tgz", 2689 | "integrity": "sha512-PgIdVpn5y5Yns8vqb8FzBUEYn98V3xcPgawAkkgj0YJ0qDsnHCiNmZYfOGMgOvoB0eWFLpYbhxUR3mxfDIMvpw==", 2690 | "dev": true 2691 | }, 2692 | "readable-stream": { 2693 | "version": "2.3.7", 2694 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 2695 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 2696 | "dev": true, 2697 | "requires": { 2698 | "core-util-is": "~1.0.0", 2699 | "inherits": "~2.0.3", 2700 | "isarray": "~1.0.0", 2701 | "process-nextick-args": "~2.0.0", 2702 | "safe-buffer": "~5.1.1", 2703 | "string_decoder": "~1.1.1", 2704 | "util-deprecate": "~1.0.1" 2705 | } 2706 | }, 2707 | "readdirp": { 2708 | "version": "3.2.0", 2709 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.2.0.tgz", 2710 | "integrity": "sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ==", 2711 | "dev": true, 2712 | "requires": { 2713 | "picomatch": "^2.0.4" 2714 | } 2715 | }, 2716 | "regexpp": { 2717 | "version": "3.1.0", 2718 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 2719 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 2720 | "dev": true 2721 | }, 2722 | "release-zalgo": { 2723 | "version": "1.0.0", 2724 | "resolved": "https://registry.npmjs.org/release-zalgo/-/release-zalgo-1.0.0.tgz", 2725 | "integrity": "sha1-CXALflB0Mpc5Mw5TXFqQ+2eFFzA=", 2726 | "dev": true, 2727 | "requires": { 2728 | "es6-error": "^4.0.1" 2729 | } 2730 | }, 2731 | "require-directory": { 2732 | "version": "2.1.1", 2733 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2734 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2735 | "dev": true 2736 | }, 2737 | "require-main-filename": { 2738 | "version": "2.0.0", 2739 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 2740 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 2741 | "dev": true 2742 | }, 2743 | "resolve": { 2744 | "version": "1.17.0", 2745 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 2746 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 2747 | "dev": true, 2748 | "requires": { 2749 | "path-parse": "^1.0.6" 2750 | } 2751 | }, 2752 | "resolve-from": { 2753 | "version": "4.0.0", 2754 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2755 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2756 | "dev": true 2757 | }, 2758 | "restore-cursor": { 2759 | "version": "3.1.0", 2760 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 2761 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 2762 | "dev": true, 2763 | "requires": { 2764 | "onetime": "^5.1.0", 2765 | "signal-exit": "^3.0.2" 2766 | } 2767 | }, 2768 | "rimraf": { 2769 | "version": "2.6.3", 2770 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 2771 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 2772 | "dev": true, 2773 | "requires": { 2774 | "glob": "^7.1.3" 2775 | } 2776 | }, 2777 | "run-async": { 2778 | "version": "2.4.1", 2779 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz", 2780 | "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==", 2781 | "dev": true 2782 | }, 2783 | "rxjs": { 2784 | "version": "6.6.0", 2785 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.0.tgz", 2786 | "integrity": "sha512-3HMA8z/Oz61DUHe+SdOiQyzIf4tOx5oQHmMir7IZEu6TMqCLHT4LRcmNaUS0NwOz8VLvmmBduMsoaUvMaIiqzg==", 2787 | "dev": true, 2788 | "requires": { 2789 | "tslib": "^1.9.0" 2790 | } 2791 | }, 2792 | "safe-buffer": { 2793 | "version": "5.1.2", 2794 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2795 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2796 | "dev": true 2797 | }, 2798 | "safer-buffer": { 2799 | "version": "2.1.2", 2800 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2801 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2802 | "dev": true 2803 | }, 2804 | "semver": { 2805 | "version": "7.3.2", 2806 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 2807 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 2808 | "dev": true 2809 | }, 2810 | "set-blocking": { 2811 | "version": "2.0.0", 2812 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2813 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 2814 | "dev": true 2815 | }, 2816 | "shebang-command": { 2817 | "version": "1.2.0", 2818 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2819 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2820 | "dev": true, 2821 | "requires": { 2822 | "shebang-regex": "^1.0.0" 2823 | } 2824 | }, 2825 | "shebang-regex": { 2826 | "version": "1.0.0", 2827 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2828 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2829 | "dev": true 2830 | }, 2831 | "signal-exit": { 2832 | "version": "3.0.3", 2833 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 2834 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==", 2835 | "dev": true 2836 | }, 2837 | "slice-ansi": { 2838 | "version": "2.1.0", 2839 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2840 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2841 | "dev": true, 2842 | "requires": { 2843 | "ansi-styles": "^3.2.0", 2844 | "astral-regex": "^1.0.0", 2845 | "is-fullwidth-code-point": "^2.0.0" 2846 | }, 2847 | "dependencies": { 2848 | "is-fullwidth-code-point": { 2849 | "version": "2.0.0", 2850 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2851 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2852 | "dev": true 2853 | } 2854 | } 2855 | }, 2856 | "source-map": { 2857 | "version": "0.5.7", 2858 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2859 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2860 | "dev": true 2861 | }, 2862 | "source-map-support": { 2863 | "version": "0.5.19", 2864 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz", 2865 | "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", 2866 | "dev": true, 2867 | "requires": { 2868 | "buffer-from": "^1.0.0", 2869 | "source-map": "^0.6.0" 2870 | }, 2871 | "dependencies": { 2872 | "source-map": { 2873 | "version": "0.6.1", 2874 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2875 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2876 | "dev": true 2877 | } 2878 | } 2879 | }, 2880 | "spawn-wrap": { 2881 | "version": "2.0.0", 2882 | "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-2.0.0.tgz", 2883 | "integrity": "sha512-EeajNjfN9zMnULLwhZZQU3GWBoFNkbngTUPfaawT4RkMiviTxcX0qfhVbGey39mfctfDHkWtuecgQ8NJcyQWHg==", 2884 | "dev": true, 2885 | "requires": { 2886 | "foreground-child": "^2.0.0", 2887 | "is-windows": "^1.0.2", 2888 | "make-dir": "^3.0.0", 2889 | "rimraf": "^3.0.0", 2890 | "signal-exit": "^3.0.2", 2891 | "which": "^2.0.1" 2892 | }, 2893 | "dependencies": { 2894 | "rimraf": { 2895 | "version": "3.0.2", 2896 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2897 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2898 | "dev": true, 2899 | "requires": { 2900 | "glob": "^7.1.3" 2901 | } 2902 | }, 2903 | "which": { 2904 | "version": "2.0.2", 2905 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2906 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2907 | "dev": true, 2908 | "requires": { 2909 | "isexe": "^2.0.0" 2910 | } 2911 | } 2912 | } 2913 | }, 2914 | "sprintf-js": { 2915 | "version": "1.0.3", 2916 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2917 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2918 | "dev": true 2919 | }, 2920 | "string-width": { 2921 | "version": "4.2.0", 2922 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 2923 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 2924 | "dev": true, 2925 | "requires": { 2926 | "emoji-regex": "^8.0.0", 2927 | "is-fullwidth-code-point": "^3.0.0", 2928 | "strip-ansi": "^6.0.0" 2929 | }, 2930 | "dependencies": { 2931 | "strip-ansi": { 2932 | "version": "6.0.0", 2933 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2934 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2935 | "dev": true, 2936 | "requires": { 2937 | "ansi-regex": "^5.0.0" 2938 | } 2939 | } 2940 | } 2941 | }, 2942 | "string.prototype.trimend": { 2943 | "version": "1.0.1", 2944 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 2945 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 2946 | "dev": true, 2947 | "requires": { 2948 | "define-properties": "^1.1.3", 2949 | "es-abstract": "^1.17.5" 2950 | } 2951 | }, 2952 | "string.prototype.trimstart": { 2953 | "version": "1.0.1", 2954 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 2955 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 2956 | "dev": true, 2957 | "requires": { 2958 | "define-properties": "^1.1.3", 2959 | "es-abstract": "^1.17.5" 2960 | } 2961 | }, 2962 | "string_decoder": { 2963 | "version": "1.1.1", 2964 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2965 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2966 | "dev": true, 2967 | "requires": { 2968 | "safe-buffer": "~5.1.0" 2969 | } 2970 | }, 2971 | "strip-ansi": { 2972 | "version": "5.2.0", 2973 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2974 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2975 | "dev": true, 2976 | "requires": { 2977 | "ansi-regex": "^4.1.0" 2978 | }, 2979 | "dependencies": { 2980 | "ansi-regex": { 2981 | "version": "4.1.0", 2982 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2983 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2984 | "dev": true 2985 | } 2986 | } 2987 | }, 2988 | "strip-bom": { 2989 | "version": "4.0.0", 2990 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 2991 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 2992 | "dev": true 2993 | }, 2994 | "strip-json-comments": { 2995 | "version": "3.1.1", 2996 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2997 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2998 | "dev": true 2999 | }, 3000 | "supports-color": { 3001 | "version": "5.5.0", 3002 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3003 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3004 | "dev": true, 3005 | "requires": { 3006 | "has-flag": "^3.0.0" 3007 | } 3008 | }, 3009 | "table": { 3010 | "version": "5.4.6", 3011 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 3012 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 3013 | "dev": true, 3014 | "requires": { 3015 | "ajv": "^6.10.2", 3016 | "lodash": "^4.17.14", 3017 | "slice-ansi": "^2.1.0", 3018 | "string-width": "^3.0.0" 3019 | }, 3020 | "dependencies": { 3021 | "emoji-regex": { 3022 | "version": "7.0.3", 3023 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 3024 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 3025 | "dev": true 3026 | }, 3027 | "is-fullwidth-code-point": { 3028 | "version": "2.0.0", 3029 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3030 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3031 | "dev": true 3032 | }, 3033 | "string-width": { 3034 | "version": "3.1.0", 3035 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3036 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3037 | "dev": true, 3038 | "requires": { 3039 | "emoji-regex": "^7.0.1", 3040 | "is-fullwidth-code-point": "^2.0.0", 3041 | "strip-ansi": "^5.1.0" 3042 | } 3043 | } 3044 | } 3045 | }, 3046 | "tapable": { 3047 | "version": "1.1.3", 3048 | "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.3.tgz", 3049 | "integrity": "sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA==", 3050 | "dev": true 3051 | }, 3052 | "test-exclude": { 3053 | "version": "6.0.0", 3054 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 3055 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 3056 | "dev": true, 3057 | "requires": { 3058 | "@istanbuljs/schema": "^0.1.2", 3059 | "glob": "^7.1.4", 3060 | "minimatch": "^3.0.4" 3061 | } 3062 | }, 3063 | "text-table": { 3064 | "version": "0.2.0", 3065 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3066 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 3067 | "dev": true 3068 | }, 3069 | "through": { 3070 | "version": "2.3.8", 3071 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3072 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3073 | "dev": true 3074 | }, 3075 | "tmp": { 3076 | "version": "0.0.33", 3077 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 3078 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 3079 | "dev": true, 3080 | "requires": { 3081 | "os-tmpdir": "~1.0.2" 3082 | } 3083 | }, 3084 | "to-fast-properties": { 3085 | "version": "2.0.0", 3086 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 3087 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 3088 | "dev": true 3089 | }, 3090 | "to-regex-range": { 3091 | "version": "5.0.1", 3092 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3093 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3094 | "dev": true, 3095 | "requires": { 3096 | "is-number": "^7.0.0" 3097 | } 3098 | }, 3099 | "ts-loader": { 3100 | "version": "8.0.2", 3101 | "resolved": "https://registry.npmjs.org/ts-loader/-/ts-loader-8.0.2.tgz", 3102 | "integrity": "sha512-oYT7wOTUawYXQ8XIDsRhziyW0KUEV38jISYlE+9adP6tDtG+O5GkRe4QKQXrHVH4mJJ88DysvEtvGP65wMLlhg==", 3103 | "dev": true, 3104 | "requires": { 3105 | "chalk": "^2.3.0", 3106 | "enhanced-resolve": "^4.0.0", 3107 | "loader-utils": "^1.0.2", 3108 | "micromatch": "^4.0.0", 3109 | "semver": "^6.0.0" 3110 | }, 3111 | "dependencies": { 3112 | "semver": { 3113 | "version": "6.3.0", 3114 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 3115 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 3116 | "dev": true 3117 | } 3118 | } 3119 | }, 3120 | "ts-node": { 3121 | "version": "8.10.2", 3122 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.10.2.tgz", 3123 | "integrity": "sha512-ISJJGgkIpDdBhWVu3jufsWpK3Rzo7bdiIXJjQc0ynKxVOVcg2oIrf2H2cejminGrptVc6q6/uynAHNCuWGbpVA==", 3124 | "dev": true, 3125 | "requires": { 3126 | "arg": "^4.1.0", 3127 | "diff": "^4.0.1", 3128 | "make-error": "^1.1.1", 3129 | "source-map-support": "^0.5.17", 3130 | "yn": "3.1.1" 3131 | }, 3132 | "dependencies": { 3133 | "diff": { 3134 | "version": "4.0.2", 3135 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 3136 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 3137 | "dev": true 3138 | } 3139 | } 3140 | }, 3141 | "tslib": { 3142 | "version": "1.13.0", 3143 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.13.0.tgz", 3144 | "integrity": "sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q==", 3145 | "dev": true 3146 | }, 3147 | "tsutils": { 3148 | "version": "3.17.1", 3149 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", 3150 | "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", 3151 | "dev": true, 3152 | "requires": { 3153 | "tslib": "^1.8.1" 3154 | } 3155 | }, 3156 | "type-check": { 3157 | "version": "0.3.2", 3158 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 3159 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 3160 | "dev": true, 3161 | "requires": { 3162 | "prelude-ls": "~1.1.2" 3163 | } 3164 | }, 3165 | "type-detect": { 3166 | "version": "4.0.8", 3167 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3168 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3169 | "dev": true 3170 | }, 3171 | "type-fest": { 3172 | "version": "0.8.1", 3173 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 3174 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 3175 | "dev": true 3176 | }, 3177 | "typedarray-to-buffer": { 3178 | "version": "3.1.5", 3179 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 3180 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 3181 | "dev": true, 3182 | "requires": { 3183 | "is-typedarray": "^1.0.0" 3184 | } 3185 | }, 3186 | "typescript": { 3187 | "version": "3.9.7", 3188 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.7.tgz", 3189 | "integrity": "sha512-BLbiRkiBzAwsjut4x/dsibSTB6yWpwT5qWmC2OfuCg3GgVQCSgMs4vEctYPhsaGtd0AeuuHMkjZ2h2WG8MSzRw==", 3190 | "dev": true 3191 | }, 3192 | "uri-js": { 3193 | "version": "4.2.2", 3194 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 3195 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 3196 | "dev": true, 3197 | "requires": { 3198 | "punycode": "^2.1.0" 3199 | } 3200 | }, 3201 | "util-deprecate": { 3202 | "version": "1.0.2", 3203 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3204 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 3205 | "dev": true 3206 | }, 3207 | "uuid": { 3208 | "version": "3.4.0", 3209 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 3210 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 3211 | "dev": true 3212 | }, 3213 | "v8-compile-cache": { 3214 | "version": "2.1.1", 3215 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 3216 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 3217 | "dev": true 3218 | }, 3219 | "vscode-test": { 3220 | "version": "1.4.0", 3221 | "resolved": "https://registry.npmjs.org/vscode-test/-/vscode-test-1.4.0.tgz", 3222 | "integrity": "sha512-Jt7HNGvSE0+++Tvtq5wc4hiXLIr2OjDShz/gbAfM/mahQpy4rKBnmOK33D+MR67ATWviQhl+vpmU3p/qwSH/Pg==", 3223 | "dev": true, 3224 | "requires": { 3225 | "http-proxy-agent": "^2.1.0", 3226 | "https-proxy-agent": "^2.2.4", 3227 | "rimraf": "^2.6.3" 3228 | } 3229 | }, 3230 | "which": { 3231 | "version": "1.3.1", 3232 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3233 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3234 | "dev": true, 3235 | "requires": { 3236 | "isexe": "^2.0.0" 3237 | } 3238 | }, 3239 | "which-module": { 3240 | "version": "2.0.0", 3241 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 3242 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 3243 | "dev": true 3244 | }, 3245 | "wide-align": { 3246 | "version": "1.1.3", 3247 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 3248 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 3249 | "dev": true, 3250 | "requires": { 3251 | "string-width": "^1.0.2 || 2" 3252 | }, 3253 | "dependencies": { 3254 | "ansi-regex": { 3255 | "version": "3.0.0", 3256 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 3257 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 3258 | "dev": true 3259 | }, 3260 | "is-fullwidth-code-point": { 3261 | "version": "2.0.0", 3262 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3263 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3264 | "dev": true 3265 | }, 3266 | "string-width": { 3267 | "version": "2.1.1", 3268 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3269 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3270 | "dev": true, 3271 | "requires": { 3272 | "is-fullwidth-code-point": "^2.0.0", 3273 | "strip-ansi": "^4.0.0" 3274 | } 3275 | }, 3276 | "strip-ansi": { 3277 | "version": "4.0.0", 3278 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3279 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3280 | "dev": true, 3281 | "requires": { 3282 | "ansi-regex": "^3.0.0" 3283 | } 3284 | } 3285 | } 3286 | }, 3287 | "word-wrap": { 3288 | "version": "1.2.3", 3289 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3290 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3291 | "dev": true 3292 | }, 3293 | "wrap-ansi": { 3294 | "version": "5.1.0", 3295 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 3296 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 3297 | "dev": true, 3298 | "requires": { 3299 | "ansi-styles": "^3.2.0", 3300 | "string-width": "^3.0.0", 3301 | "strip-ansi": "^5.0.0" 3302 | }, 3303 | "dependencies": { 3304 | "emoji-regex": { 3305 | "version": "7.0.3", 3306 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 3307 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 3308 | "dev": true 3309 | }, 3310 | "is-fullwidth-code-point": { 3311 | "version": "2.0.0", 3312 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3313 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3314 | "dev": true 3315 | }, 3316 | "string-width": { 3317 | "version": "3.1.0", 3318 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3319 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3320 | "dev": true, 3321 | "requires": { 3322 | "emoji-regex": "^7.0.1", 3323 | "is-fullwidth-code-point": "^2.0.0", 3324 | "strip-ansi": "^5.1.0" 3325 | } 3326 | } 3327 | } 3328 | }, 3329 | "wrappy": { 3330 | "version": "1.0.2", 3331 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3332 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3333 | "dev": true 3334 | }, 3335 | "write": { 3336 | "version": "1.0.3", 3337 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 3338 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 3339 | "dev": true, 3340 | "requires": { 3341 | "mkdirp": "^0.5.1" 3342 | } 3343 | }, 3344 | "write-file-atomic": { 3345 | "version": "3.0.3", 3346 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 3347 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 3348 | "dev": true, 3349 | "requires": { 3350 | "imurmurhash": "^0.1.4", 3351 | "is-typedarray": "^1.0.0", 3352 | "signal-exit": "^3.0.2", 3353 | "typedarray-to-buffer": "^3.1.5" 3354 | } 3355 | }, 3356 | "y18n": { 3357 | "version": "4.0.0", 3358 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 3359 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 3360 | "dev": true 3361 | }, 3362 | "yargs": { 3363 | "version": "13.3.2", 3364 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 3365 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 3366 | "dev": true, 3367 | "requires": { 3368 | "cliui": "^5.0.0", 3369 | "find-up": "^3.0.0", 3370 | "get-caller-file": "^2.0.1", 3371 | "require-directory": "^2.1.1", 3372 | "require-main-filename": "^2.0.0", 3373 | "set-blocking": "^2.0.0", 3374 | "string-width": "^3.0.0", 3375 | "which-module": "^2.0.0", 3376 | "y18n": "^4.0.0", 3377 | "yargs-parser": "^13.1.2" 3378 | }, 3379 | "dependencies": { 3380 | "emoji-regex": { 3381 | "version": "7.0.3", 3382 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 3383 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 3384 | "dev": true 3385 | }, 3386 | "is-fullwidth-code-point": { 3387 | "version": "2.0.0", 3388 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3389 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3390 | "dev": true 3391 | }, 3392 | "string-width": { 3393 | "version": "3.1.0", 3394 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3395 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3396 | "dev": true, 3397 | "requires": { 3398 | "emoji-regex": "^7.0.1", 3399 | "is-fullwidth-code-point": "^2.0.0", 3400 | "strip-ansi": "^5.1.0" 3401 | } 3402 | } 3403 | } 3404 | }, 3405 | "yargs-parser": { 3406 | "version": "13.1.2", 3407 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 3408 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 3409 | "dev": true, 3410 | "requires": { 3411 | "camelcase": "^5.0.0", 3412 | "decamelize": "^1.2.0" 3413 | } 3414 | }, 3415 | "yargs-unparser": { 3416 | "version": "1.6.0", 3417 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.0.tgz", 3418 | "integrity": "sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw==", 3419 | "dev": true, 3420 | "requires": { 3421 | "flat": "^4.1.0", 3422 | "lodash": "^4.17.15", 3423 | "yargs": "^13.3.0" 3424 | } 3425 | }, 3426 | "yn": { 3427 | "version": "3.1.1", 3428 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 3429 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 3430 | "dev": true 3431 | } 3432 | } 3433 | } 3434 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "tropicrpc", 3 | "displayName": "tropicRPC", 4 | "description": "A gRPC API endpoint testing tool.", 5 | "version": "0.1.0", 6 | "publisher": "tropicRPC", 7 | "repository": { 8 | "type": "git", 9 | "url": "https://github.com/oslabs-beta/tropicRPC" 10 | }, 11 | "icon": "DOCUMENTATION/images/icon.png", 12 | "engines": { 13 | "vscode": "^1.47.0" 14 | }, 15 | "categories": [ 16 | "Other" 17 | ], 18 | "activationEvents": [ 19 | "onCommand:tropic.createConfigFile", 20 | "onCommand:tropic.activateTropic", 21 | "onCommand:tropic.deactivateTropic" 22 | ], 23 | "main": "./out/extension.js", 24 | "contributes": { 25 | "commands": [ 26 | { 27 | "command": "tropic.createConfigFile", 28 | "title": "tropicRPC: Create Config File" 29 | }, 30 | { 31 | "command": "tropic.activateTropic", 32 | "title": "tropicRPC: Activate" 33 | }, 34 | { 35 | "command": "tropic.deactivateTropic", 36 | "title": "tropicRPC: Deactivate" 37 | } 38 | ] 39 | }, 40 | "scripts": { 41 | "vscode:prepublish": "npm run compile", 42 | "compile": "tsc -p ./", 43 | "lint": "eslint src --ext ts", 44 | "watch": "tsc -watch -p ./", 45 | "pretest": "npm run compile && npm run lint", 46 | "test": "mocha -r ts-node/register .test/suite/extensionRuns.ts" 47 | }, 48 | "devDependencies": { 49 | "@types/chai": "^4.2.12", 50 | "@types/glob": "^7.1.1", 51 | "@types/mocha": "^7.0.2", 52 | "@types/node": "^13.11.0", 53 | "@types/vscode": "^1.47.0", 54 | "@typescript-eslint/eslint-plugin": "^2.30.0", 55 | "@typescript-eslint/parser": "^2.30.0", 56 | "chai": "^4.2.0", 57 | "eslint": "^6.8.0", 58 | "eslint-plugin-mocha": "^7.0.1", 59 | "glob": "^7.1.6", 60 | "mocha": "^7.1.2", 61 | "ts-loader": "^8.0.2", 62 | "ts-node": "^8.10.2", 63 | "typescript": "^3.9.7", 64 | "vscode-test": "^1.3.0" 65 | }, 66 | "dependencies": { 67 | "@grpc/grpc-js": "^1.1.2", 68 | "@grpc/proto-loader": "^0.5.5" 69 | } 70 | } 71 | -------------------------------------------------------------------------------- /prettierrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | printWidth: 80, 3 | singleQuote: true, 4 | trailingComma: "es5", 5 | }; 6 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | 3 | const createConfigFileCb = require('./modules/commands/createConfigFileCommand'); 4 | const { 5 | activateTropicCb, 6 | deactivateTropicCb, 7 | } = require('./modules/commands/activateAndDeactivateCommand'); 8 | 9 | // this method is called when your extension is activated 10 | // your extension is activated the very first time the command is executed 11 | export function activate(context: vscode.ExtensionContext) { 12 | /************************************************************** 13 | * Command: Create configuration file in the user's project 14 | **************************************************************/ 15 | // vscode.commands.registerCommand: binds a command id to a handler function 16 | const createConfigFile = vscode.commands.registerCommand( 17 | 'tropic.createConfigFile', 18 | createConfigFileCb 19 | ); 20 | 21 | /************************************************************** 22 | * Command: Activate tropicRPC functionality 23 | **************************************************************/ 24 | const activateTropic = vscode.commands.registerCommand('tropic.activateTropic', activateTropicCb); 25 | 26 | /************************************************************** 27 | * Command: Deactivate tropicRPC functionality 28 | **************************************************************/ 29 | const deactivateTropic = vscode.commands.registerCommand( 30 | 'tropic.deactivateTropic', 31 | deactivateTropicCb 32 | ); 33 | 34 | context.subscriptions.push(createConfigFile, activateTropic, deactivateTropic); 35 | } 36 | -------------------------------------------------------------------------------- /src/modules/client/displayOutputMessage.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Roseanne Damasco; July 29, 2020 3 | * @function : displays request and corresponding server result in tropicRPC output channel 4 | * @param : {object} tropicChannel - reference to tropicRPC's output channel 5 | * @param : {string} service - service of gRPC request 6 | * @param : {string} method - method of gRPC request 7 | * @param : {object} message - body of gRPC request 8 | * @param : {string} responseStr - server response message 9 | * @returns : null 10 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 11 | * * */ 12 | 13 | import * as vscode from 'vscode'; 14 | 15 | const displayOuptMessage: Function = ( 16 | tropicChannel: vscode.OutputChannel, 17 | service: string, 18 | method: string, 19 | message: object, 20 | responseStr: string 21 | ) => { 22 | // generate formatted request message string 23 | const requestStr: string = JSON.stringify( 24 | { 25 | service, 26 | method, 27 | message, 28 | }, 29 | null, 30 | 2 31 | ); 32 | 33 | // focus output to tropicRPC channel, and display request input 34 | const outputTemplate: string = `------------------------\n\nSUBMITTED REQUEST \n${requestStr}\n\nSERVER RESPONSE \n${responseStr}\n\n`; 35 | tropicChannel.show(true); 36 | tropicChannel.append(outputTemplate); 37 | return null; 38 | }; 39 | 40 | module.exports = displayOuptMessage; 41 | -------------------------------------------------------------------------------- /src/modules/client/getRootProjectDir.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Roseanne Damasco July 16, 2020 3 | * @function : get root directory path 4 | * @param : none 5 | * @returns : {string} root directory absolute path 6 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 7 | */ 8 | 9 | import * as vscode from 'vscode'; 10 | 11 | const fs = require('fs'); 12 | 13 | const getRootProjectDir: Function = (): string => { 14 | const workspaceFolders: readonly vscode.WorkspaceFolder[] | undefined = vscode.workspace.workspaceFolders; 15 | const currOpenFile: vscode.TextEditor | undefined = vscode.window.activeTextEditor; 16 | // Confirm that a project is open 17 | if (workspaceFolders === undefined) { 18 | vscode.window.showInformationMessage('Please open a project.'); 19 | return ''; 20 | } 21 | // Confirm that a file is open 22 | if (currOpenFile === undefined) { 23 | vscode.window.showInformationMessage('Please open a file.'); 24 | return ''; 25 | } 26 | // Get the paths for the main folder and open file 27 | const currWorkspacePath: string = workspaceFolders[0].uri.fsPath; 28 | const currFilePath: string = currOpenFile.document.uri.fsPath; 29 | 30 | const workspaceArr: Array = currWorkspacePath.split('/'); 31 | const fileArr: Array = currFilePath.split('/'); 32 | 33 | // Traverse through folders between main folder and open file 34 | // return the folder path where package.json file exists 35 | let rootProjPath: Array = workspaceArr; 36 | for (let i = rootProjPath.length; i < fileArr.length; i += 1) { 37 | const lookingFor: string = `${rootProjPath.join('/')}/package.json`; 38 | if (fs.existsSync(lookingFor)) { 39 | return rootProjPath.join('/'); 40 | } 41 | rootProjPath.push(fileArr[i]); 42 | } 43 | 44 | // if a package.json file cannot be found, inform user and return null; 45 | vscode.window.showInformationMessage('A root folder was not found.'); 46 | return ''; 47 | }; 48 | 49 | module.exports = getRootProjectDir; 50 | -------------------------------------------------------------------------------- /src/modules/client/onSaveCb.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Joyce Lo, Shahrukh Khan; July 18, 2020 3 | * @author : Joyce Lo, Roseanne Damasco, Steve Canavan; July 20, 2020 4 | * @author : Steve Canavan; July 30, 2020 5 | * @function : executes the config file, which exports grpc server and proto file data, to be processed 6 | * @param : {TextDocument} document - file that was saved 7 | * @param : {OutputChannel} tropicChannel - output channel for VS Code extension 8 | * @param : {string} tropicConfigPath - path to tropicRPC config file 9 | * @param : {string} rootDir - path to user's project root directory 10 | * @returns : null 11 | * @changelog : ## Steve Canavan, July 30, 2020, passes config file inputs to validateConfigFileInputs function 12 | * ## returns null and exits the on save function is validateConfigFileInputs returns false 13 | * * */ 14 | 15 | // access the VS Code API 16 | import * as vscode from 'vscode'; 17 | 18 | // require in fs, path, and getRootProjectDir function/module 19 | const fs = require('fs'); 20 | const path = require('path'); 21 | const sendgRPCRequest = require('./sendgRPCRequest'); 22 | const validateConfigFileInputs = require('./validateConfigFileInputs'); 23 | 24 | const onSave: Function = ( 25 | document: vscode.TextDocument, 26 | tropicChannel: vscode.OutputChannel, 27 | tropicConfigPath: string, 28 | rootDir: string 29 | ) => { 30 | //check if TextDocument is not the config file 31 | if (document.uri.fsPath !== tropicConfigPath) { 32 | // if config file does not exist in file system, display message instructing user to create config file 33 | if (!fs.existsSync(tropicConfigPath)) { 34 | vscode.window.showInformationMessage( 35 | 'tropicRPC is Active. Please create a config file, or deactivate tropicRPC.' 36 | ); 37 | } 38 | // exit function 39 | return null; 40 | } 41 | 42 | // declare variables and corresponding data types to reference user inputs in config file 43 | let portNumber: number; 44 | let ipAddress: string; 45 | let protoFile: string; 46 | let protoPackage: string; 47 | interface Request { 48 | service: string; 49 | method: string; 50 | message: {}; 51 | } 52 | let requestsArr: Array; 53 | 54 | // show and clear tropicRPC output channel 55 | tropicChannel.show(true); 56 | tropicChannel.clear(); 57 | 58 | // by default, after requiring in a file/module, the require method maintains a cache of the file/module 59 | // to account for any subsequent updates to config file, need to invalidate the cache by deleting it 60 | // if cache is not invalidated, every call to require would result in the same initial output 61 | delete require.cache[tropicConfigPath]; 62 | // get config and request objects from config file 63 | const { config, requests } = require(`${tropicConfigPath}`); 64 | 65 | // assign variables to value of user inputs in config file 66 | ipAddress = config.ipAddress; 67 | portNumber = config.portNumber; 68 | protoFile = path.resolve(rootDir, config.protoFile); 69 | protoPackage = config.protoPackage; 70 | requestsArr = Object.values(requests); 71 | 72 | // check for valid proto files, ip addresses, and port numbers 73 | if (!validateConfigFileInputs(ipAddress, portNumber, protoFile)) { 74 | return null; 75 | } 76 | 77 | tropicChannel.append('tropicRPC Results:\n\n'); 78 | // send each request to gRPC handler 79 | requestsArr.forEach((request: Request) => 80 | sendgRPCRequest( 81 | portNumber, 82 | ipAddress, 83 | protoFile, 84 | protoPackage, 85 | request.service, 86 | request.method, 87 | request.message, 88 | tropicChannel 89 | ) 90 | ); 91 | 92 | return null; 93 | }; 94 | 95 | // export onSave function 96 | module.exports = onSave; 97 | -------------------------------------------------------------------------------- /src/modules/client/sendgRPCRequest.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Ed Chow, Shahrukh Khan; July 20, 2020 3 | * @function : executes gRPC request submitted by user 4 | * @param : {number} port - port of user's running server 5 | * @param : {string} ipAddress - IP address of user's running server 6 | * @param : {string} protoFilePath - absolute path to user's protofile 7 | * @param : {string} protoPackage - proto package name 8 | * @param : {string} service - service of gRPC to call 9 | * @param : {string} method - method of gRPC endpoint to invoke 10 | * @param : {object} message - body of request to send 11 | * @param : {object} tropicChannel - reference to tropicRPC's output channel 12 | * @returns : null 13 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 14 | * ## Steve Canavan, July 29, 2020, added functionality to include calls to server IP addresses 15 | * ## Ed Chow, July 29, 2020, added client streaming functionality 16 | * ## Roseanne, July 29, 2020, error handling for protopackage, service, and method inputs, 17 | * and modularized displaying output message 18 | * ## Ed Chow, Joyce Lo, Shahrukh Khan, July 30, 2020, added bi-directional streaming functionality 19 | * * */ 20 | 21 | import * as vscode from 'vscode'; 22 | const grpc = require('@grpc/grpc-js'); 23 | const protoLoader = require('@grpc/proto-loader'); 24 | const displayOutputMessage = require('./displayOutputMessage'); 25 | 26 | const sendgRPCRequest: Function = ( 27 | port: number, 28 | ipAddress: string, 29 | protoFilePath: string, 30 | protoPackage: string, 31 | service: string, 32 | method: string, 33 | message: any, 34 | tropicChannel: vscode.OutputChannel 35 | ) => { 36 | // read proto file and save as package definition (protocol buffer) 37 | // protoLoader compiles proto files into JS object 38 | const packageDef = protoLoader.loadSync(`${protoFilePath}`, {}); 39 | 40 | // read package definition and save packages in a gRPC object 41 | const grpcObject = grpc.loadPackageDefinition(packageDef); 42 | 43 | // confirm that inputted protoPackage exist in proto file 44 | if (!grpcObject.hasOwnProperty(protoPackage)) { 45 | // if not, inform user of error 46 | const errorMessage: string = `ERROR: Proto package '${protoPackage}' was not found in your proto file\n\n`; 47 | displayOutputMessage(tropicChannel, service, method, message, errorMessage); 48 | return null; 49 | } 50 | 51 | // confirm that inputted service exists in proto package 52 | if (!packageDef.hasOwnProperty(`${protoPackage}.${service}`)) { 53 | // if not, inform user of error 54 | const errorMessage: string = `ERROR: Service '${service}' was not found in '${protoPackage}'\n\n`; 55 | displayOutputMessage(tropicChannel, service, method, message, errorMessage); 56 | return null; 57 | } 58 | 59 | // get the specific package object that we want to work with 60 | const userPackage = grpcObject[`${protoPackage}`]; 61 | 62 | // confirm that inputted method exists in service 63 | if (!packageDef[`${protoPackage}.${service}`][method]) { 64 | // if not, inform user that method is not included in their specified service 65 | const errorMessage: string = `ERROR: Method '${method}' was not found in '${service}' service\n\n`; 66 | displayOutputMessage(tropicChannel, service, method, message, errorMessage); 67 | return null; 68 | } 69 | 70 | // create a connection to the gRPC server, for a specific service 71 | // return an object with all of the methods within that service, and save as client 72 | // grpc.credentials.createInsecure(): communication will be in plain text, i.e. non-encrypted 73 | const client = new userPackage[service]( 74 | ipAddress ? ipAddress + ':' + port : `localhost:${port}`, 75 | grpc.credentials.createInsecure() 76 | ); 77 | 78 | // unary type 79 | const call = client[`${method}`]( 80 | message, 81 | (err: { code: number; details: string }, response: any) => { 82 | if (err) { 83 | console.log(typeof err); 84 | const errorMessage: string = `ERROR: CODE ${err.code} - ${err.details}`; 85 | displayOutputMessage(tropicChannel, service, method, message, errorMessage); 86 | return null; 87 | } 88 | 89 | // generate formatted response message string 90 | const responseStr: string = JSON.stringify(response, null, 2); 91 | 92 | // display response in tropicRPC output channel 93 | displayOutputMessage(tropicChannel, service, method, message, responseStr); 94 | 95 | // exit function 96 | return null; 97 | } 98 | ); 99 | 100 | const callMethodDefinition = call.call.methodDefinition; 101 | const isRequestStream = callMethodDefinition.requestStream; 102 | const isResponseStream = callMethodDefinition.responseStream; 103 | 104 | // bidirectional streaming: handled by client + server streaming 105 | 106 | // client streaming 107 | if (isRequestStream) { 108 | // write to call object the messages client wants to stream 109 | const keys: Array = Object.keys(message); 110 | for (let i = 0; i < keys.length; i += 1) { 111 | call.write(message[keys[i]]); 112 | } 113 | call.end(); 114 | } 115 | 116 | // server streaming 117 | if (isResponseStream) { 118 | call.on('data', (data: any) => { 119 | // generate formatted response message string 120 | const responseStr: string = JSON.stringify(data, null, 2); 121 | 122 | // display response in tropicRPC output channel 123 | displayOutputMessage(tropicChannel, service, method, message, responseStr); 124 | // exit function 125 | return null; 126 | }); 127 | } 128 | }; 129 | 130 | module.exports = sendgRPCRequest; 131 | -------------------------------------------------------------------------------- /src/modules/client/throttleOnSave.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Steve Canavan, Ed Chow; August 1, 2020 3 | * @function : throttles execution of inputted function by inputted delay time 4 | * @param : {Function} fn - function to be throttled 5 | * @param : {number} delay - time that has to pass before passed in function gets executed 6 | * @returns : {Function} throttledFn - a function that checks elapsed time since last invocation 7 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 8 | * * */ 9 | 10 | const throttle: Function = (fn: Function, delay: number): Function => { 11 | let last: number = 0; 12 | return function throttledFn(...args: any[]) { 13 | const now: number = new Date().getTime(); 14 | if (now - last < delay) { 15 | return; 16 | } 17 | last = now; 18 | return fn(...args); 19 | }; 20 | }; 21 | 22 | module.exports = throttle; 23 | -------------------------------------------------------------------------------- /src/modules/client/validateConfigFileInputs.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Steve Canavan; July 30, 2020 3 | * @function : checks for correct format of server info and existence of proto files 4 | * @param : {number} portNumber - port of user's running server 5 | * @param : {string} ipAddress - IP address of user's running server 6 | * @param : {string} protoFile - absolute path to user's protofile 7 | * @returns : boolean 8 | * @changelog : ## Steve Canavan, July 30, 2020, checks for correct format of ipAddress and portNumber, and existence of proto file. 9 | * * */ 10 | 11 | import * as vscode from 'vscode'; 12 | const fs = require('fs'); 13 | 14 | const validateConfigFileInputs: Function = ( 15 | ipAddress: string, 16 | portNumber: number, 17 | protoFile: string 18 | ): boolean => { 19 | // check if ipAddress format is valid 20 | if ( 21 | !/^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?).(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?).(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?).(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)+$/.test( 22 | ipAddress 23 | ) && 24 | ipAddress 25 | ) { 26 | vscode.window.showErrorMessage(`Please update '${ipAddress}' to be a valid IP address`); 27 | return false; 28 | } 29 | 30 | // check if port number format is valid 31 | if ( 32 | !/^()([1-9]|[1-5]?[0-9]{2,4}|6[1-4][0-9]{3}|65[1-4][0-9]{2}|655[1-2][0-9]|6553[1-5])$/.test( 33 | `${portNumber}` 34 | ) 35 | ) { 36 | vscode.window.showErrorMessage(`Please update ${portNumber} to be a valid port number.`); 37 | return false; 38 | } 39 | 40 | // check if proto file exists at protoFile path 41 | if (!fs.existsSync(protoFile)) { 42 | vscode.window.showErrorMessage(`Proto file does not exist at '${protoFile}'`); 43 | return false; 44 | } 45 | 46 | // return true if all if statements evaluate to false 47 | return true; 48 | }; 49 | module.exports = validateConfigFileInputs; 50 | -------------------------------------------------------------------------------- /src/modules/commands/activateAndDeactivateCommand.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Steve Canavan, Roseanne Damasco, Joyce Lo, Ed Chow, Shahrukh Khan; July 20, 2020 3 | * @function : checks user workspace for config file, starts server, initalizes tropicRPC output channel, initializes on save listener 4 | * @param : none 5 | * @returns : null 6 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 7 | * * */ 8 | 9 | import * as vscode from 'vscode'; 10 | import { ChildProcess, spawn } from 'child_process'; 11 | 12 | // save listener, child process, and output channel are declared globally within this file, 13 | // to be accessible by activate and deactivate functions 14 | let saveListener: vscode.Disposable; 15 | let serverProcess: ChildProcess; 16 | let serverIsTurnedOn: boolean; 17 | const tropicChannel: vscode.OutputChannel = vscode.window.createOutputChannel('tropicRPC'); 18 | 19 | // require in necessary files/modules 20 | const fs = require('fs'); 21 | const path = require('path'); 22 | const getRootProjectDir = require('../client/getRootProjectDir'); 23 | const onSaveCb = require('../client/onSaveCb'); 24 | const throttle = require('../client/throttleOnSave'); 25 | 26 | const activateTropicCb: Function = () => { 27 | // create variable to reference root path of user's project 28 | const rootDir: string = getRootProjectDir(); 29 | // create variable to reference config file path 30 | const tropicConfigPath: string = `${rootDir}/.tropicRPC.config.js`; 31 | 32 | // if config file does not exist in file system, display message instructing user to create config file 33 | if (!fs.existsSync(tropicConfigPath)) { 34 | vscode.window.showInformationMessage('Please create a config file.'); 35 | // exit function 36 | return null; 37 | } 38 | 39 | // start up user's server, if server path was provided 40 | delete require.cache[tropicConfigPath]; 41 | const { config } = require(tropicConfigPath); 42 | const serverPath: string = path.resolve(rootDir, config.entry); 43 | if (config.entry) { 44 | // confirm that the serverPath leads to a valid file 45 | if (fs.existsSync(serverPath)) { 46 | // start the server with node 47 | serverProcess = spawn('node', [serverPath], { cwd: rootDir }); 48 | serverIsTurnedOn = true; 49 | // if an error is reported, inform user 50 | if (serverProcess.stderr) { 51 | serverProcess.stderr.on('data', (data) => { 52 | serverIsTurnedOn = false; 53 | vscode.window.showErrorMessage( 54 | `Error starting your gRPC server. Please try manually starting it.` 55 | ); 56 | }); 57 | } 58 | 59 | // inform user that server is starting 60 | setTimeout(() => { 61 | if (serverIsTurnedOn) { 62 | vscode.window.showInformationMessage('gRPC server has been started.'); 63 | } 64 | }, 2500); 65 | } else { 66 | vscode.window.showErrorMessage('Error in server path. Server was not started by tropicRPC.'); 67 | } 68 | } 69 | 70 | // open the output channel 71 | // focus on output channel and clear off any previous responses 72 | tropicChannel.show(true); 73 | tropicChannel.clear(); 74 | tropicChannel.append( 75 | 'tropicRPC is active. \nAdd requests to config file and save to view responses.' 76 | ); 77 | 78 | const throttleOnSave: Function = throttle(onSaveCb, 2000); 79 | 80 | // start listening for saves 81 | // saveListener invokes onSaveCb 82 | // logic for sending gRPC request goes inside onSaveCb 83 | saveListener = vscode.workspace.onDidSaveTextDocument((document: vscode.TextDocument) => { 84 | throttleOnSave(document, tropicChannel, tropicConfigPath, rootDir); 85 | }); 86 | // exit function 87 | return null; 88 | }; 89 | 90 | /** 91 | * @author : Steve Canavan, Roseanne Damasco, Joyce Lo, Ed Chow, Shahrukh Khan; July 20, 2020 92 | * @function : disposes of the save listener, turns off user server if tropicRPC turned it on, hides and clears tropicRPC output channel 93 | * @param : none 94 | * @returns : null 95 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 96 | * * */ 97 | 98 | const deactivateTropicCb: Function = () => { 99 | // dispose of saveListener 100 | if (saveListener) { 101 | saveListener.dispose(); 102 | } 103 | 104 | // close opened server 105 | if (serverIsTurnedOn) { 106 | const killServerProcess: ChildProcess = spawn('kill', [`${serverProcess.pid}`]); 107 | setTimeout(() => { 108 | killServerProcess.kill('SIGINT'); 109 | serverIsTurnedOn = false; 110 | vscode.window.showInformationMessage(`gRPC server has been shut off.`); 111 | }, 1000); 112 | } 113 | 114 | vscode.window.showInformationMessage(`tropicRPC is deactivated`); 115 | 116 | // hide and clear tropicRPC output channel 117 | tropicChannel.hide(); 118 | tropicChannel.clear(); 119 | 120 | // exit function 121 | return null; 122 | }; 123 | 124 | // export functions to extension.ts 125 | module.exports = { activateTropicCb, deactivateTropicCb }; 126 | -------------------------------------------------------------------------------- /src/modules/commands/configTemplate.ts: -------------------------------------------------------------------------------- 1 | // add config details here 2 | const config = { 3 | // OPTIONAL: change './server/index.js' to the relative path from the root directory to the file that starts your server 4 | // or '' if you do not need tropicRPC to start your server 5 | entry: './server/index.js', 6 | 7 | // OPTIONAL: change 3000 to the port number on which your server runs 8 | portNumber: 3000, 9 | 10 | // OPTIONAL: populate '' with the IP address of your server (exclude portNumber) 11 | ipAddress: '', 12 | 13 | // change './demo.proto' to the relative path from the root directory to your proto file 14 | protoFile: 'src/proto/demo.proto', 15 | 16 | // change 'protoPackage' to your proto package's name 17 | protoPackage: 'protoPackage', 18 | }; 19 | 20 | // after activating tropicRPC extension, add request(s) here and save this file to execute 21 | const requests = { 22 | // customize your request values below 23 | request1: { 24 | service: 'serviceName', 25 | method: 'methodName', 26 | message: {}, 27 | }, 28 | // add additional request objects below, as necessary, using the above format 29 | }; 30 | 31 | module.exports = { config, requests }; 32 | -------------------------------------------------------------------------------- /src/modules/commands/createConfigFileCommand.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author : Ed Chow, Joyce Lo, Shah Khan, Steve Canavan July 16, 2020 3 | * @function : creates config file 4 | * @param : none 5 | * @returns : null 6 | * @changelog : ##WHOEVER CHANGES THE FILE, date, details 7 | */ 8 | 9 | import * as vscode from 'vscode'; 10 | 11 | const fs = require('fs'); 12 | const path = require('path'); 13 | const getRootProjectDir = require('../client/getRootProjectDir'); 14 | 15 | const createConfigFile: Function = () => { 16 | const tropicConfigPath: string = `${getRootProjectDir()}/.tropicRPC.config.js`; 17 | 18 | // if the tropicRPC.config.js file already exists in the root directory 19 | // then display message indicating the file already exists 20 | if (fs.existsSync(tropicConfigPath)) { 21 | vscode.window.showInformationMessage( 22 | `A tropicRPC configuration file already exists at ${tropicConfigPath}` 23 | ); 24 | 25 | // exit out 26 | return null; 27 | } 28 | 29 | // reading data from the config template 30 | // configTemplate file: make sure development file is in .ts format 31 | // it will be a .js file on client side, as indicated below 32 | const templateFile: string = fs.readFileSync( 33 | path.resolve(__dirname, './configTemplate.js'), 34 | 'utf8' 35 | ); 36 | 37 | // write template configuration file to new file on client side 38 | fs.writeFileSync(tropicConfigPath, templateFile, 'utf8'); 39 | 40 | // open new file in VS Code 41 | vscode.workspace.openTextDocument(tropicConfigPath).then((doc: vscode.TextDocument) => { 42 | // after opening new file, need to make it the focus 43 | vscode.window.showTextDocument(doc); 44 | }); 45 | }; 46 | 47 | module.exports = createConfigFile; 48 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": "src", 11 | "strict": true /* enable all strict type-checking options */ 12 | /* Additional Checks */ 13 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 14 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 15 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 16 | }, 17 | "exclude": [ 18 | "node_modules", 19 | ".vscode-test" 20 | ] 21 | } 22 | --------------------------------------------------------------------------------