├── .babelrc ├── .eslintrc.json ├── .gitignore ├── .istanbul.yml ├── .travis.yml ├── CHANGELOG.md ├── LICENSE ├── README.md ├── examples ├── bulb.png ├── createStickerSet.js ├── inlineKeyboard.js ├── inlineQuery.js ├── sendFile.js ├── simpleUsage.js └── simpleUsageWithProxy.js ├── package-lock.json ├── package.json ├── spec ├── core │ └── telebotSpec.js └── support │ └── jasmine.json └── src ├── slimbot.js └── telegram.js /.babelrc: -------------------------------------------------------------------------------- 1 | { "presets": ["es2015"] } -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "parserOptions": { 3 | "ecmaVersion": 6, 4 | "sourceType": "module", 5 | } 6 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # https://gist.github.com/octocat/9257657 # 2 | # Compiled source # 3 | ################### 4 | *.com 5 | *.class 6 | *.dll 7 | *.exe 8 | *.o 9 | *.so 10 | 11 | # Packages # 12 | ############ 13 | # it's better to unpack these files and commit the raw source 14 | # git has its own built in compression methods 15 | *.7z 16 | *.dmg 17 | *.gz 18 | *.iso 19 | *.jar 20 | *.rar 21 | *.tar 22 | *.zip 23 | 24 | # Logs and databases # 25 | ###################### 26 | *.log 27 | *.sql 28 | *.sqlite 29 | 30 | # OS generated files # 31 | ###################### 32 | .DS_Store 33 | .DS_Store? 34 | ._* 35 | .Spotlight-V100 36 | .Trashes 37 | ehthumbs.db 38 | Thumbs.db 39 | 40 | node_modules 41 | coverage 42 | .npmignore 43 | yarn.lock 44 | .idea 45 | .coveralls.yml 46 | -------------------------------------------------------------------------------- /.istanbul.yml: -------------------------------------------------------------------------------- 1 | verbose: false 2 | instrumentation: 3 | root: . 4 | extensions: 5 | - .js 6 | default-excludes: true 7 | excludes: ['**/spec/**', '**/examples/**', '**/src/telegram.js'] 8 | embed-source: false 9 | variable: __coverage__ 10 | compact: true 11 | preserve-comments: false 12 | complete-copy: false 13 | save-baseline: false 14 | baseline-file: ./coverage/coverage-baseline.json 15 | include-all-sources: true 16 | include-pid: false 17 | es-modules: false 18 | reporting: 19 | print: summary 20 | reports: 21 | - lcov 22 | dir: ./coverage 23 | watermarks: 24 | statements: [50, 80] 25 | lines: [50, 80] 26 | functions: [50, 80] 27 | branches: [50, 80] 28 | hooks: 29 | hook-run-in-context: false 30 | post-require-hook: null 31 | handle-sigint: false 32 | check: 33 | global: 34 | statements: 0 35 | lines: 0 36 | branches: 0 37 | functions: 0 38 | excludes: [] 39 | each: 40 | statements: 0 41 | lines: 0 42 | branches: 0 43 | functions: 0 44 | excludes: [] -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - "15.4.0" 4 | - "12.10.0" 5 | - "10.16.0" 6 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Slimbot changelog 2 | 3 | ## 20th December 2018 4 | * Merged [PR #27](https://github.com/edisonchee/slimbot/pull/27) from @lgg to add SOCKS5 proxy support 5 | 6 | ## 24th May 2018 7 | * Merged [PR #21](https://github.com/edisonchee/slimbot/pull/21) from @ago to fix ```getUpdates``` offset to prevent losing updates 8 | 9 | ## 10th March 2018 10 | * Merged [PR #15](https://github.com/edisonchee/slimbot/pull/15) from @ago to fix API call parameter for ```pinChatMessage``` 11 | 12 | ## 21st January 2017 13 | * Merged [PR #6](https://github.com/edisonchee/slimbot/pull/6) from @matteocontrini to add callbacks for individual Telegram BOT API calls 14 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2016-2020 Edison Chee 4 | 5 | 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 the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: 6 | 7 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 8 | 9 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 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 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. 10 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | [![Build Status](https://travis-ci.com/edisonchee/slimbot.svg?branch=master)](https://travis-ci.com/edisonchee/slimbot) 2 | [![Coverage Status](https://coveralls.io/repos/github/edisonchee/slimbot/badge.svg?branch=master)](https://coveralls.io/github/edisonchee/slimbot?branch=master) 3 | [![MIT licensed](https://img.shields.io/badge/license-MIT-blue.svg)](https://raw.githubusercontent.com/edisonchee/slimbot/master/LICENSE) 4 | 5 | # Slimbot 6 | 7 | A fuss-free, thin wrapper around Telegram Bot API for Node.js. No frills. 8 | 9 | Updated for [Telegram Bot API 5.1](https://core.telegram.org/bots/api#march-9-2021). 10 | Works with [Node 15.12.0](https://github.com/nodejs/node/releases/tag/v15.12.0). 11 | Runs on latest Node version `15.12.0`. Tested on `10.16.0` and `12.10.0` as well. 12 | 13 | _**Note:** Slimbot patch versions (e.g. x.y.**Z**) do not track or reflect Telegram Bot API changes._ 14 | 15 | ## Resources 16 | * [Release Notes](https://github.com/edisonchee/slimbot/releases) 17 | * [Changelog](https://github.com/edisonchee/slimbot/blob/master/CHANGELOG.md) 18 | * [Examples](https://github.com/edisonchee/slimbot/tree/master/examples) 19 | 20 | * [Slimbot Wiki](https://github.com/edisonchee/slimbot/wiki) 21 | * [Official Telegram Bot API Documentation](https://core.telegram.org/bots/api) 22 | 23 | ## Getting started 24 | 25 | ```javascript 26 | npm i slimbot 27 | ``` 28 | 29 | ```javascript 30 | const Slimbot = require('slimbot'); 31 | const slimbot = new Slimbot('123456789:AA...'); 32 | 33 | // Register listeners 34 | 35 | slimbot.on('message', message => { 36 | slimbot.sendMessage(message.chat.id, 'Message received'); 37 | }); 38 | 39 | // Call API 40 | 41 | slimbot.startPolling(); 42 | ``` 43 | 44 | Now go ahead and type a message to your bot in Telegram. It should reply you with 'Message received' in the chat. Check out all other events you can listen to in the [wiki](https://github.com/edisonchee/slimbot/wiki#events). 45 | 46 | ## How it works 47 | 48 | All methods return a promise. This means you can inspect the returned [objects](https://core.telegram.org/bots/api#available-types) if you want to: 49 | 50 | ```javascript 51 | slimbot.sendMessage('123456789', 'Message received') 52 | .then(message => { 53 | console.log(message); 54 | }); 55 | ``` 56 | 57 | In this case, the ```sendMessage``` method returns a [Message](https://core.telegram.org/bots/api#message) object as stated in the [documentation](https://core.telegram.org/bots/api#sendmessage). 58 | 59 | You can also use callbacks instead of promises: 60 | 61 | ```javascript 62 | const Slimbot = require('./src/slimbot'); 63 | const slimbot = new Slimbot(process.env['TELEGRAM_BOT_TOKEN']); 64 | 65 | function callback(err, obj) { 66 | if (err) { 67 | // handle error 68 | console.log(err); 69 | } 70 | // handle returned object 71 | console.log(obj); 72 | }; 73 | 74 | slimbot.on('message', message => { 75 | slimbot.sendMessage(message.chat.id, 'Message received', callback); 76 | }); 77 | 78 | slimbot.startPolling(callback); 79 | ``` 80 | 81 | ## Examples 82 | 83 | * [Simple Usage](https://github.com/edisonchee/slimbot/blob/master/examples/simpleUsage.js) 84 | * [Sending Files](https://github.com/edisonchee/slimbot/blob/master/examples/sendFile.js) 85 | * [Inline Keyboards](https://github.com/edisonchee/slimbot/blob/master/examples/inlineKeyboard.js) 86 | * [Inline Queries](https://github.com/edisonchee/slimbot/blob/master/examples/inlineQuery.js) 87 | * [Creating Sticker Sets](https://github.com/edisonchee/slimbot/blob/master/examples/createStickerSet.js) 88 | * [Socks5 proxy support](./examples/simpleUsageWithProxy.js) Thanks to @lgg for adding this feature! Merged into the public repo in [PR #27](https://github.com/edisonchee/slimbot/pull/27) 89 | 90 | ## Documentation ([Wiki](https://github.com/edisonchee/slimbot/wiki)) 91 | 92 | Learn more about the implementation details in the [Wiki](https://github.com/edisonchee/slimbot/wiki). Feel free to contribute to the Wiki or add more examples. 93 | 94 | ## Contributing 95 | 96 | Heartfelt thanks to the following folks for making Slimbot better: 97 | [@lgg](https://github.com/lgg) [@ago](https://github.com/ago) [@rpaskin](https://github.com/rpaskin) [@matteocontrini](https://github.com/matteocontrini) [@jakimenko](https://github.com/jakimenko) [@nahanil](https://github.com/nahanil) 98 | 99 | The guiding principle for this library is to be as simple as possible. I put serious thought into adding features to guard against bloat. Nonetheless, I am very open to dialogue and contributions are most welcome. 100 | 101 | If you have built a public bot using this library, send me a PM and I'll feature it here. 102 | -------------------------------------------------------------------------------- /examples/bulb.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/edisonchee/slimbot/c4c986383485464ade67020fd43a6e3c56562bb5/examples/bulb.png -------------------------------------------------------------------------------- /examples/createStickerSet.js: -------------------------------------------------------------------------------- 1 | const Slimbot = require('slimbot'); 2 | const slimbot = new Slimbot(process.env['TELEGRAM_BOT_TOKEN']); 3 | const fs = require('fs'); 4 | 5 | // get your user_id by talking to your bot 6 | let userId = null; 7 | // instructions: https://core.telegram.org/bots/api#createnewstickerset 8 | // Basic formula: 'name_digit_letters_underscores_only' + '_by_' + 'bot_username' (use @yourbotusername without the '@') 9 | let stickerSetName = 'sticker_set_name' + '_by_' + 'your_bot_username'; 10 | // This is the title name that will appear on Telegram after you add the sticker set 11 | let stickerSetTitle = 'sticker set name on Telegram'; 12 | // can be a local file, where you create a read stream object from, or use a file_id or HTTP URL 13 | // refer to sendFile.js example for usage pattern 14 | let stickerFile = fs.createReadStream(__dirname + './bulb.png'); 15 | // actual emoji to replace 16 | let emojis = "😊"; 17 | 18 | slimbot.on('message', (message) => { 19 | console.log('Your user id: ', message.from.id); 20 | userId = message.from.id; 21 | 22 | if (message.text === '/create_sticker_set') { 23 | slimbot.createNewStickerSet( 24 | userId, 25 | stickerSetName, 26 | stickerSetTitle, 27 | stickerFile, 28 | emojis 29 | ) 30 | .then(res => { 31 | console.log(res); 32 | }) 33 | .catch(err => { 34 | console.log(error); 35 | }) 36 | } 37 | }); 38 | 39 | slimbot.startPolling(); -------------------------------------------------------------------------------- /examples/inlineKeyboard.js: -------------------------------------------------------------------------------- 1 | const Slimbot = require('slimbot'); 2 | const slimbot = new Slimbot(process.env['TELEGRAM_BOT_TOKEN']); 3 | 4 | // Register listener 5 | slimbot.on('message', message => { 6 | // define inline keyboard to send to user 7 | let optionalParams = { 8 | parse_mode: 'Markdown', 9 | reply_markup: JSON.stringify({ 10 | inline_keyboard: [[ 11 | { text: 'Hello', callback_data: 'hello' } 12 | ],[ 13 | { text: 'Good', callback_data: 'good' }, 14 | { text: 'Day', callback_data: 'day' } 15 | ],[ 16 | { text: 'How', callback_data: 'how' }, 17 | { text: 'Are', callback_data: 'are' }, 18 | { text: 'You', callback_data: 'you' } 19 | ] 20 | ] 21 | }) 22 | }; 23 | // reply when user sends a message, and send him our inline keyboard as well 24 | slimbot.sendMessage(message.chat.id, 'Message received', optionalParams); 25 | }); 26 | 27 | // Because each inline keyboard button has callback data, you can listen for the callback data and do something with them 28 | 29 | slimbot.on('callback_query', query => { 30 | if (query.data === 'hello') { 31 | slimbot.sendMessage(query.message.chat.id, 'Hello to you too!'); 32 | } 33 | }); 34 | 35 | // Call API 36 | slimbot.startPolling(); 37 | 38 | // Now try talking to your bot, and click on the Hello button. Your bot should reply you with "Hello to you too!". -------------------------------------------------------------------------------- /examples/inlineQuery.js: -------------------------------------------------------------------------------- 1 | const Slimbot = require('slimbot'); 2 | const slimbot = new Slimbot(process.env['TELEGRAM_BOT_TOKEN']); 3 | 4 | // Register listener 5 | // Make sure you enable inline queries with @BotFather first! 6 | // Refer to Telegram Bot API docs for types of InlineQueryResult you can send (https://core.telegram.org/bots/api#inline-mode) 7 | 8 | slimbot.on('inline_query', query => { 9 | console.log(query); 10 | let results = JSON.stringify([{ 11 | 'type': 'article', 12 | 'id': 'ec', 13 | 'title': 'Edison Chee on Medium', 14 | 'description': 'UX Research. UI Design. Web Development', 15 | 'thumb_url': 'http://edisonchee.com/img/favicon.ico', 16 | 'input_message_content': { 17 | 'message_text': 'Featured article: [Rethinking top-level navigation labels](https://blog.gds-gov.tech/rethinking-top-level-navigation-labels-75c9759613af#.ke516y2qw)', 18 | 'parse_mode': 'Markdown', 19 | 'disable_web_page_preview': false 20 | } 21 | }, { 22 | 'type': 'article', 23 | 'id': 'gt', 24 | 'title': 'Singapore GovTech Blog', 25 | 'description': 'Be Happy, Be Awesome!', 26 | 'thumb_url': 'https://cdn-images-1.medium.com/max/82/1*hB4KIovectkFlSXV3NhHUQ.png', 27 | 'input_message_content': { 28 | 'message_text': 'View all posts: [GovTech Blog](https://blog.gds-gov.tech/)', 29 | 'parse_mode': 'Markdown', 30 | 'disable_web_page_preview': false 31 | } 32 | }]); 33 | 34 | slimbot.answerInlineQuery(query.id, results); 35 | }); 36 | 37 | // Call API 38 | slimbot.startPolling(); 39 | 40 | // Now try typing @YourBotName after enabling inline queries with BotFather. You should get a list of links as defined in the results variable. -------------------------------------------------------------------------------- /examples/sendFile.js: -------------------------------------------------------------------------------- 1 | const Slimbot = require('slimbot'); 2 | const slimbot = new Slimbot(process.env['TELEGRAM_BOT_TOKEN']); 3 | const fs = require('fs'); 4 | 5 | // This is a working example that helps you understand how sending files with a Telegram Bot works 6 | // Just copy/paste and run it 7 | 8 | let fileId = 'AgADBQADqacxG2gbbxCWBkgvcmeAgxVPyjIABBlug37DKyhDEU0AAgI'; 9 | let fileURL = 'https://fbatwork.files.wordpress.com/2016/10/govtech-logo.jpg'; 10 | let fileUpload = fs.createReadStream(__dirname + './bulb.png'); 11 | 12 | // Register a listener to start the ball rolling 13 | // Send a message to your bot and it will try to send you 3 images! 14 | slimbot.on('message', (message) => { 15 | // Method 1: Using file_id 16 | slimbot.sendPhoto(message.chat.id, fileId).then(message => { 17 | console.log(message.result.photo); 18 | }); 19 | 20 | // Method 2: Using HTTP URL 21 | slimbot.sendPhoto(message.chat.id, fileURL).then(message => { 22 | console.log(message.result.photo); 23 | }); 24 | 25 | // Method 3: Uploading a file to Telegram's servers 26 | slimbot.sendPhoto(message.chat.id, fileUpload).then(message => { 27 | console.log(message.result.photo); 28 | }); 29 | }); 30 | 31 | // fileId may be expired by the time you read this (I don't know how long Telegram keeps files on its servers) 32 | // If this happens, use Method 3 to send a file, obtain the file_id of the uploaded file and try Method 1 again 33 | 34 | // Call API 35 | slimbot.startPolling(); -------------------------------------------------------------------------------- /examples/simpleUsage.js: -------------------------------------------------------------------------------- 1 | const Slimbot = require('slimbot'); 2 | const slimbot = new Slimbot(process.env['TELEGRAM_BOT_TOKEN']); 3 | 4 | // Register listeners 5 | slimbot.on('message', message => { 6 | // reply when user sends a message 7 | slimbot.sendMessage(message.chat.id, 'Message received'); 8 | }); 9 | 10 | slimbot.on('edited_message', edited_message => { 11 | // reply when user edits a message 12 | slimbot.sendMessage(edited_message.chat.id, 'Message edited'); 13 | }); 14 | 15 | // Call API 16 | slimbot.startPolling(); 17 | 18 | console.log('polling...'); 19 | 20 | setTimeout(() => { 21 | slimbot.stopPolling(); 22 | }, 10000); 23 | -------------------------------------------------------------------------------- /examples/simpleUsageWithProxy.js: -------------------------------------------------------------------------------- 1 | const Slimbot = require('slimbot'); 2 | const socks5proxy = { 3 | socksHost: process.env['SOCKS5_HOST'], //required 4 | socksPort: process.env['SOCKS5_PORT'], //required 5 | socksUsername: process.env['SOCKS5_USER'], //optional 6 | socksPassword: process.env['SOCKS5_PASSWORD'] //optional 7 | }; 8 | const slimbot = new Slimbot(process.env['TELEGRAM_BOT_TOKEN'], socks5proxy); 9 | 10 | // Register listeners 11 | slimbot.on('message', message => { 12 | // reply when user sends a message 13 | slimbot.sendMessage(message.chat.id, 'Message received'); 14 | }); 15 | 16 | slimbot.on('edited_message', edited_message => { 17 | // reply when user edits a message 18 | slimbot.sendMessage(edited_message.chat.id, 'Message edited'); 19 | }); 20 | 21 | // Call API 22 | slimbot.startPolling(); 23 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "slimbot", 3 | "version": "5.1.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "5.1.0", 9 | "license": "MIT", 10 | "dependencies": { 11 | "bluebird": "^3.7.2", 12 | "eventemitter3": "^4.0.7", 13 | "request": "^2.88.2", 14 | "request-promise": "^4.2.6", 15 | "socks5-https-client": "^1.2.1" 16 | }, 17 | "devDependencies": { 18 | "coveralls": "^3.1.0", 19 | "eslint": "^7.22.0", 20 | "handlebars": ">=4.7.7", 21 | "istanbul": "^0.4.5", 22 | "jasmine": "^3.7.0", 23 | "mockery": "^2.1.0" 24 | }, 25 | "engines": { 26 | "node": ">=10.16.0" 27 | } 28 | }, 29 | "node_modules/@babel/code-frame": { 30 | "version": "7.12.11", 31 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 32 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 33 | "dev": true, 34 | "dependencies": { 35 | "@babel/highlight": "^7.10.4" 36 | } 37 | }, 38 | "node_modules/@babel/helper-validator-identifier": { 39 | "version": "7.12.11", 40 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 41 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 42 | "dev": true 43 | }, 44 | "node_modules/@babel/highlight": { 45 | "version": "7.13.10", 46 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.13.10.tgz", 47 | "integrity": "sha512-5aPpe5XQPzflQrFwL1/QoeHkP2MsA4JCntcXHRhEsdsfPVkvPi2w7Qix4iV7t5S/oC9OodGrggd8aco1g3SZFg==", 48 | "dev": true, 49 | "dependencies": { 50 | "@babel/helper-validator-identifier": "^7.12.11", 51 | "chalk": "^2.0.0", 52 | "js-tokens": "^4.0.0" 53 | } 54 | }, 55 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 56 | "version": "3.2.1", 57 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 58 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 59 | "dev": true, 60 | "dependencies": { 61 | "color-convert": "^1.9.0" 62 | }, 63 | "engines": { 64 | "node": ">=4" 65 | } 66 | }, 67 | "node_modules/@babel/highlight/node_modules/chalk": { 68 | "version": "2.4.2", 69 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 70 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 71 | "dev": true, 72 | "dependencies": { 73 | "ansi-styles": "^3.2.1", 74 | "escape-string-regexp": "^1.0.5", 75 | "supports-color": "^5.3.0" 76 | }, 77 | "engines": { 78 | "node": ">=4" 79 | } 80 | }, 81 | "node_modules/@babel/highlight/node_modules/color-convert": { 82 | "version": "1.9.3", 83 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 84 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 85 | "dev": true, 86 | "dependencies": { 87 | "color-name": "1.1.3" 88 | } 89 | }, 90 | "node_modules/@babel/highlight/node_modules/color-name": { 91 | "version": "1.1.3", 92 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 93 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 94 | "dev": true 95 | }, 96 | "node_modules/@eslint/eslintrc": { 97 | "version": "0.4.0", 98 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.0.tgz", 99 | "integrity": "sha512-2ZPCc+uNbjV5ERJr+aKSPRwZgKd2z11x0EgLvb1PURmUrn9QNRXFqje0Ldq454PfAVyaJYyrDvvIKSFP4NnBog==", 100 | "dev": true, 101 | "dependencies": { 102 | "ajv": "^6.12.4", 103 | "debug": "^4.1.1", 104 | "espree": "^7.3.0", 105 | "globals": "^12.1.0", 106 | "ignore": "^4.0.6", 107 | "import-fresh": "^3.2.1", 108 | "js-yaml": "^3.13.1", 109 | "minimatch": "^3.0.4", 110 | "strip-json-comments": "^3.1.1" 111 | }, 112 | "engines": { 113 | "node": "^10.12.0 || >=12.0.0" 114 | } 115 | }, 116 | "node_modules/@eslint/eslintrc/node_modules/globals": { 117 | "version": "12.4.0", 118 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 119 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 120 | "dev": true, 121 | "dependencies": { 122 | "type-fest": "^0.8.1" 123 | }, 124 | "engines": { 125 | "node": ">=8" 126 | }, 127 | "funding": { 128 | "url": "https://github.com/sponsors/sindresorhus" 129 | } 130 | }, 131 | "node_modules/@eslint/eslintrc/node_modules/type-fest": { 132 | "version": "0.8.1", 133 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 134 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 135 | "dev": true, 136 | "engines": { 137 | "node": ">=8" 138 | } 139 | }, 140 | "node_modules/acorn": { 141 | "version": "7.4.1", 142 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 143 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 144 | "dev": true, 145 | "bin": { 146 | "acorn": "bin/acorn" 147 | }, 148 | "engines": { 149 | "node": ">=0.4.0" 150 | } 151 | }, 152 | "node_modules/acorn-jsx": { 153 | "version": "5.3.1", 154 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 155 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 156 | "dev": true, 157 | "peerDependencies": { 158 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 159 | } 160 | }, 161 | "node_modules/ajv": { 162 | "version": "6.12.6", 163 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 164 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 165 | "dependencies": { 166 | "fast-deep-equal": "^3.1.1", 167 | "fast-json-stable-stringify": "^2.0.0", 168 | "json-schema-traverse": "^0.4.1", 169 | "uri-js": "^4.2.2" 170 | }, 171 | "funding": { 172 | "type": "github", 173 | "url": "https://github.com/sponsors/epoberezkin" 174 | } 175 | }, 176 | "node_modules/ajv/node_modules/json-schema-traverse": { 177 | "version": "0.4.1", 178 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 179 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 180 | }, 181 | "node_modules/ansi-colors": { 182 | "version": "4.1.1", 183 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 184 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 185 | "dev": true, 186 | "engines": { 187 | "node": ">=6" 188 | } 189 | }, 190 | "node_modules/ansi-regex": { 191 | "version": "5.0.0", 192 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 193 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 194 | "dev": true, 195 | "engines": { 196 | "node": ">=8" 197 | } 198 | }, 199 | "node_modules/ansi-styles": { 200 | "version": "4.3.0", 201 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 202 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 203 | "dev": true, 204 | "dependencies": { 205 | "color-convert": "^2.0.1" 206 | }, 207 | "engines": { 208 | "node": ">=8" 209 | }, 210 | "funding": { 211 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 212 | } 213 | }, 214 | "node_modules/argparse": { 215 | "version": "1.0.10", 216 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 217 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 218 | "dev": true, 219 | "dependencies": { 220 | "sprintf-js": "~1.0.2" 221 | } 222 | }, 223 | "node_modules/asn1": { 224 | "version": "0.2.4", 225 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 226 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 227 | "dependencies": { 228 | "safer-buffer": "~2.1.0" 229 | } 230 | }, 231 | "node_modules/assert-plus": { 232 | "version": "1.0.0", 233 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 234 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 235 | "engines": { 236 | "node": ">=0.8" 237 | } 238 | }, 239 | "node_modules/astral-regex": { 240 | "version": "2.0.0", 241 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 242 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 243 | "dev": true, 244 | "engines": { 245 | "node": ">=8" 246 | } 247 | }, 248 | "node_modules/asynckit": { 249 | "version": "0.4.0", 250 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 251 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 252 | }, 253 | "node_modules/aws-sign2": { 254 | "version": "0.7.0", 255 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 256 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 257 | "engines": { 258 | "node": "*" 259 | } 260 | }, 261 | "node_modules/aws4": { 262 | "version": "1.9.1", 263 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.1.tgz", 264 | "integrity": "sha512-wMHVg2EOHaMRxbzgFJ9gtjOOCrI80OHLG14rxi28XwOW8ux6IiEbRCGGGqCtdAIg4FQCbW20k9RsT4y3gJlFug==" 265 | }, 266 | "node_modules/balanced-match": { 267 | "version": "1.0.0", 268 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 269 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 270 | "dev": true 271 | }, 272 | "node_modules/bcrypt-pbkdf": { 273 | "version": "1.0.2", 274 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 275 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 276 | "dependencies": { 277 | "tweetnacl": "^0.14.3" 278 | } 279 | }, 280 | "node_modules/bluebird": { 281 | "version": "3.7.2", 282 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 283 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" 284 | }, 285 | "node_modules/brace-expansion": { 286 | "version": "1.1.11", 287 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 288 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 289 | "dev": true, 290 | "dependencies": { 291 | "balanced-match": "^1.0.0", 292 | "concat-map": "0.0.1" 293 | } 294 | }, 295 | "node_modules/callsites": { 296 | "version": "3.1.0", 297 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 298 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 299 | "dev": true, 300 | "engines": { 301 | "node": ">=6" 302 | } 303 | }, 304 | "node_modules/caseless": { 305 | "version": "0.12.0", 306 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 307 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 308 | }, 309 | "node_modules/chalk": { 310 | "version": "4.1.0", 311 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 312 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 313 | "dev": true, 314 | "dependencies": { 315 | "ansi-styles": "^4.1.0", 316 | "supports-color": "^7.1.0" 317 | }, 318 | "engines": { 319 | "node": ">=10" 320 | } 321 | }, 322 | "node_modules/chalk/node_modules/has-flag": { 323 | "version": "4.0.0", 324 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 325 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 326 | "dev": true, 327 | "engines": { 328 | "node": ">=8" 329 | } 330 | }, 331 | "node_modules/chalk/node_modules/supports-color": { 332 | "version": "7.2.0", 333 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 334 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 335 | "dev": true, 336 | "dependencies": { 337 | "has-flag": "^4.0.0" 338 | }, 339 | "engines": { 340 | "node": ">=8" 341 | } 342 | }, 343 | "node_modules/color-convert": { 344 | "version": "2.0.1", 345 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 346 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 347 | "dev": true, 348 | "dependencies": { 349 | "color-name": "~1.1.4" 350 | }, 351 | "engines": { 352 | "node": ">=7.0.0" 353 | } 354 | }, 355 | "node_modules/color-name": { 356 | "version": "1.1.4", 357 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 358 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 359 | "dev": true 360 | }, 361 | "node_modules/combined-stream": { 362 | "version": "1.0.8", 363 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 364 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 365 | "dependencies": { 366 | "delayed-stream": "~1.0.0" 367 | }, 368 | "engines": { 369 | "node": ">= 0.8" 370 | } 371 | }, 372 | "node_modules/commander": { 373 | "version": "2.20.3", 374 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 375 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 376 | "dev": true, 377 | "optional": true 378 | }, 379 | "node_modules/concat-map": { 380 | "version": "0.0.1", 381 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 382 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 383 | "dev": true 384 | }, 385 | "node_modules/core-util-is": { 386 | "version": "1.0.2", 387 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 388 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 389 | }, 390 | "node_modules/coveralls": { 391 | "version": "3.1.0", 392 | "resolved": "https://registry.npmjs.org/coveralls/-/coveralls-3.1.0.tgz", 393 | "integrity": "sha512-sHxOu2ELzW8/NC1UP5XVLbZDzO4S3VxfFye3XYCznopHy02YjNkHcj5bKaVw2O7hVaBdBjEdQGpie4II1mWhuQ==", 394 | "dev": true, 395 | "dependencies": { 396 | "js-yaml": "^3.13.1", 397 | "lcov-parse": "^1.0.0", 398 | "log-driver": "^1.2.7", 399 | "minimist": "^1.2.5", 400 | "request": "^2.88.2" 401 | }, 402 | "bin": { 403 | "coveralls": "bin/coveralls.js" 404 | }, 405 | "engines": { 406 | "node": ">=6" 407 | } 408 | }, 409 | "node_modules/cross-spawn": { 410 | "version": "7.0.3", 411 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 412 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 413 | "dev": true, 414 | "dependencies": { 415 | "path-key": "^3.1.0", 416 | "shebang-command": "^2.0.0", 417 | "which": "^2.0.1" 418 | }, 419 | "engines": { 420 | "node": ">= 8" 421 | } 422 | }, 423 | "node_modules/dashdash": { 424 | "version": "1.14.1", 425 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 426 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 427 | "dependencies": { 428 | "assert-plus": "^1.0.0" 429 | }, 430 | "engines": { 431 | "node": ">=0.10" 432 | } 433 | }, 434 | "node_modules/debug": { 435 | "version": "4.3.1", 436 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 437 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 438 | "dev": true, 439 | "dependencies": { 440 | "ms": "2.1.2" 441 | }, 442 | "engines": { 443 | "node": ">=6.0" 444 | }, 445 | "peerDependenciesMeta": { 446 | "supports-color": { 447 | "optional": true 448 | } 449 | } 450 | }, 451 | "node_modules/deep-is": { 452 | "version": "0.1.3", 453 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 454 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 455 | "dev": true 456 | }, 457 | "node_modules/delayed-stream": { 458 | "version": "1.0.0", 459 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 460 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 461 | "engines": { 462 | "node": ">=0.4.0" 463 | } 464 | }, 465 | "node_modules/doctrine": { 466 | "version": "3.0.0", 467 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 468 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 469 | "dev": true, 470 | "dependencies": { 471 | "esutils": "^2.0.2" 472 | }, 473 | "engines": { 474 | "node": ">=6.0.0" 475 | } 476 | }, 477 | "node_modules/ecc-jsbn": { 478 | "version": "0.1.2", 479 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 480 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 481 | "dependencies": { 482 | "jsbn": "~0.1.0", 483 | "safer-buffer": "^2.1.0" 484 | } 485 | }, 486 | "node_modules/emoji-regex": { 487 | "version": "8.0.0", 488 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 489 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 490 | "dev": true 491 | }, 492 | "node_modules/enquirer": { 493 | "version": "2.3.6", 494 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 495 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 496 | "dev": true, 497 | "dependencies": { 498 | "ansi-colors": "^4.1.1" 499 | }, 500 | "engines": { 501 | "node": ">=8.6" 502 | } 503 | }, 504 | "node_modules/escape-string-regexp": { 505 | "version": "1.0.5", 506 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 507 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 508 | "dev": true, 509 | "engines": { 510 | "node": ">=0.8.0" 511 | } 512 | }, 513 | "node_modules/eslint": { 514 | "version": "7.22.0", 515 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.22.0.tgz", 516 | "integrity": "sha512-3VawOtjSJUQiiqac8MQc+w457iGLfuNGLFn8JmF051tTKbh5/x/0vlcEj8OgDCaw7Ysa2Jn8paGshV7x2abKXg==", 517 | "dev": true, 518 | "dependencies": { 519 | "@babel/code-frame": "7.12.11", 520 | "@eslint/eslintrc": "^0.4.0", 521 | "ajv": "^6.10.0", 522 | "chalk": "^4.0.0", 523 | "cross-spawn": "^7.0.2", 524 | "debug": "^4.0.1", 525 | "doctrine": "^3.0.0", 526 | "enquirer": "^2.3.5", 527 | "eslint-scope": "^5.1.1", 528 | "eslint-utils": "^2.1.0", 529 | "eslint-visitor-keys": "^2.0.0", 530 | "espree": "^7.3.1", 531 | "esquery": "^1.4.0", 532 | "esutils": "^2.0.2", 533 | "file-entry-cache": "^6.0.1", 534 | "functional-red-black-tree": "^1.0.1", 535 | "glob-parent": "^5.0.0", 536 | "globals": "^13.6.0", 537 | "ignore": "^4.0.6", 538 | "import-fresh": "^3.0.0", 539 | "imurmurhash": "^0.1.4", 540 | "is-glob": "^4.0.0", 541 | "js-yaml": "^3.13.1", 542 | "json-stable-stringify-without-jsonify": "^1.0.1", 543 | "levn": "^0.4.1", 544 | "lodash": "^4.17.21", 545 | "minimatch": "^3.0.4", 546 | "natural-compare": "^1.4.0", 547 | "optionator": "^0.9.1", 548 | "progress": "^2.0.0", 549 | "regexpp": "^3.1.0", 550 | "semver": "^7.2.1", 551 | "strip-ansi": "^6.0.0", 552 | "strip-json-comments": "^3.1.0", 553 | "table": "^6.0.4", 554 | "text-table": "^0.2.0", 555 | "v8-compile-cache": "^2.0.3" 556 | }, 557 | "bin": { 558 | "eslint": "bin/eslint.js" 559 | }, 560 | "engines": { 561 | "node": "^10.12.0 || >=12.0.0" 562 | }, 563 | "funding": { 564 | "url": "https://opencollective.com/eslint" 565 | } 566 | }, 567 | "node_modules/eslint-scope": { 568 | "version": "5.1.1", 569 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 570 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 571 | "dev": true, 572 | "dependencies": { 573 | "esrecurse": "^4.3.0", 574 | "estraverse": "^4.1.1" 575 | }, 576 | "engines": { 577 | "node": ">=8.0.0" 578 | } 579 | }, 580 | "node_modules/eslint-utils": { 581 | "version": "2.1.0", 582 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 583 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 584 | "dev": true, 585 | "dependencies": { 586 | "eslint-visitor-keys": "^1.1.0" 587 | }, 588 | "engines": { 589 | "node": ">=6" 590 | } 591 | }, 592 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 593 | "version": "1.3.0", 594 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 595 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 596 | "dev": true, 597 | "engines": { 598 | "node": ">=4" 599 | } 600 | }, 601 | "node_modules/eslint-visitor-keys": { 602 | "version": "2.0.0", 603 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 604 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 605 | "dev": true, 606 | "engines": { 607 | "node": ">=10" 608 | } 609 | }, 610 | "node_modules/espree": { 611 | "version": "7.3.1", 612 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 613 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 614 | "dev": true, 615 | "dependencies": { 616 | "acorn": "^7.4.0", 617 | "acorn-jsx": "^5.3.1", 618 | "eslint-visitor-keys": "^1.3.0" 619 | }, 620 | "engines": { 621 | "node": "^10.12.0 || >=12.0.0" 622 | } 623 | }, 624 | "node_modules/espree/node_modules/eslint-visitor-keys": { 625 | "version": "1.3.0", 626 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 627 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 628 | "dev": true, 629 | "engines": { 630 | "node": ">=4" 631 | } 632 | }, 633 | "node_modules/esprima": { 634 | "version": "4.0.1", 635 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 636 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 637 | "dev": true, 638 | "bin": { 639 | "esparse": "bin/esparse.js", 640 | "esvalidate": "bin/esvalidate.js" 641 | }, 642 | "engines": { 643 | "node": ">=4" 644 | } 645 | }, 646 | "node_modules/esquery": { 647 | "version": "1.4.0", 648 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 649 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 650 | "dev": true, 651 | "dependencies": { 652 | "estraverse": "^5.1.0" 653 | }, 654 | "engines": { 655 | "node": ">=0.10" 656 | } 657 | }, 658 | "node_modules/esquery/node_modules/estraverse": { 659 | "version": "5.2.0", 660 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 661 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 662 | "dev": true, 663 | "engines": { 664 | "node": ">=4.0" 665 | } 666 | }, 667 | "node_modules/esrecurse": { 668 | "version": "4.3.0", 669 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 670 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 671 | "dev": true, 672 | "dependencies": { 673 | "estraverse": "^5.2.0" 674 | }, 675 | "engines": { 676 | "node": ">=4.0" 677 | } 678 | }, 679 | "node_modules/esrecurse/node_modules/estraverse": { 680 | "version": "5.2.0", 681 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 682 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 683 | "dev": true, 684 | "engines": { 685 | "node": ">=4.0" 686 | } 687 | }, 688 | "node_modules/estraverse": { 689 | "version": "4.3.0", 690 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 691 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 692 | "dev": true, 693 | "engines": { 694 | "node": ">=4.0" 695 | } 696 | }, 697 | "node_modules/esutils": { 698 | "version": "2.0.3", 699 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 700 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 701 | "dev": true, 702 | "engines": { 703 | "node": ">=0.10.0" 704 | } 705 | }, 706 | "node_modules/eventemitter3": { 707 | "version": "4.0.7", 708 | "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", 709 | "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==" 710 | }, 711 | "node_modules/extend": { 712 | "version": "3.0.2", 713 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 714 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 715 | }, 716 | "node_modules/extsprintf": { 717 | "version": "1.3.0", 718 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 719 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 720 | "engines": [ 721 | "node >=0.6.0" 722 | ] 723 | }, 724 | "node_modules/fast-deep-equal": { 725 | "version": "3.1.3", 726 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 727 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" 728 | }, 729 | "node_modules/fast-json-stable-stringify": { 730 | "version": "2.0.0", 731 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 732 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 733 | }, 734 | "node_modules/fast-levenshtein": { 735 | "version": "2.0.6", 736 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 737 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 738 | "dev": true 739 | }, 740 | "node_modules/file-entry-cache": { 741 | "version": "6.0.1", 742 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 743 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 744 | "dev": true, 745 | "dependencies": { 746 | "flat-cache": "^3.0.4" 747 | }, 748 | "engines": { 749 | "node": "^10.12.0 || >=12.0.0" 750 | } 751 | }, 752 | "node_modules/flat-cache": { 753 | "version": "3.0.4", 754 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 755 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 756 | "dev": true, 757 | "dependencies": { 758 | "flatted": "^3.1.0", 759 | "rimraf": "^3.0.2" 760 | }, 761 | "engines": { 762 | "node": "^10.12.0 || >=12.0.0" 763 | } 764 | }, 765 | "node_modules/flatted": { 766 | "version": "3.1.1", 767 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 768 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 769 | "dev": true 770 | }, 771 | "node_modules/forever-agent": { 772 | "version": "0.6.1", 773 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 774 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 775 | "engines": { 776 | "node": "*" 777 | } 778 | }, 779 | "node_modules/form-data": { 780 | "version": "2.3.3", 781 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 782 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 783 | "dependencies": { 784 | "asynckit": "^0.4.0", 785 | "combined-stream": "^1.0.6", 786 | "mime-types": "^2.1.12" 787 | }, 788 | "engines": { 789 | "node": ">= 0.12" 790 | } 791 | }, 792 | "node_modules/fs.realpath": { 793 | "version": "1.0.0", 794 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 795 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 796 | "dev": true 797 | }, 798 | "node_modules/functional-red-black-tree": { 799 | "version": "1.0.1", 800 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 801 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 802 | "dev": true 803 | }, 804 | "node_modules/getpass": { 805 | "version": "0.1.7", 806 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 807 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 808 | "dependencies": { 809 | "assert-plus": "^1.0.0" 810 | } 811 | }, 812 | "node_modules/glob": { 813 | "version": "7.1.6", 814 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 815 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 816 | "dev": true, 817 | "dependencies": { 818 | "fs.realpath": "^1.0.0", 819 | "inflight": "^1.0.4", 820 | "inherits": "2", 821 | "minimatch": "^3.0.4", 822 | "once": "^1.3.0", 823 | "path-is-absolute": "^1.0.0" 824 | }, 825 | "engines": { 826 | "node": "*" 827 | }, 828 | "funding": { 829 | "url": "https://github.com/sponsors/isaacs" 830 | } 831 | }, 832 | "node_modules/glob-parent": { 833 | "version": "5.1.1", 834 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 835 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 836 | "dev": true, 837 | "dependencies": { 838 | "is-glob": "^4.0.1" 839 | }, 840 | "engines": { 841 | "node": ">= 6" 842 | } 843 | }, 844 | "node_modules/globals": { 845 | "version": "13.7.0", 846 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.7.0.tgz", 847 | "integrity": "sha512-Aipsz6ZKRxa/xQkZhNg0qIWXT6x6rD46f6x/PCnBomlttdIyAPak4YD9jTmKpZ72uROSMU87qJtcgpgHaVchiA==", 848 | "dev": true, 849 | "dependencies": { 850 | "type-fest": "^0.20.2" 851 | }, 852 | "engines": { 853 | "node": ">=8" 854 | }, 855 | "funding": { 856 | "url": "https://github.com/sponsors/sindresorhus" 857 | } 858 | }, 859 | "node_modules/handlebars": { 860 | "version": "4.7.7", 861 | "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz", 862 | "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==", 863 | "dev": true, 864 | "dependencies": { 865 | "minimist": "^1.2.5", 866 | "neo-async": "^2.6.0", 867 | "source-map": "^0.6.1", 868 | "wordwrap": "^1.0.0" 869 | }, 870 | "bin": { 871 | "handlebars": "bin/handlebars" 872 | }, 873 | "engines": { 874 | "node": ">=0.4.7" 875 | }, 876 | "optionalDependencies": { 877 | "uglify-js": "^3.1.4" 878 | } 879 | }, 880 | "node_modules/har-schema": { 881 | "version": "2.0.0", 882 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 883 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 884 | "engines": { 885 | "node": ">=4" 886 | } 887 | }, 888 | "node_modules/har-validator": { 889 | "version": "5.1.3", 890 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 891 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 892 | "dependencies": { 893 | "ajv": "^6.5.5", 894 | "har-schema": "^2.0.0" 895 | }, 896 | "engines": { 897 | "node": ">=6" 898 | } 899 | }, 900 | "node_modules/has-flag": { 901 | "version": "3.0.0", 902 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 903 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 904 | "dev": true, 905 | "engines": { 906 | "node": ">=4" 907 | } 908 | }, 909 | "node_modules/http-signature": { 910 | "version": "1.2.0", 911 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 912 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 913 | "dependencies": { 914 | "assert-plus": "^1.0.0", 915 | "jsprim": "^1.2.2", 916 | "sshpk": "^1.7.0" 917 | }, 918 | "engines": { 919 | "node": ">=0.8", 920 | "npm": ">=1.3.7" 921 | } 922 | }, 923 | "node_modules/ignore": { 924 | "version": "4.0.6", 925 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 926 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 927 | "dev": true, 928 | "engines": { 929 | "node": ">= 4" 930 | } 931 | }, 932 | "node_modules/import-fresh": { 933 | "version": "3.3.0", 934 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 935 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 936 | "dev": true, 937 | "dependencies": { 938 | "parent-module": "^1.0.0", 939 | "resolve-from": "^4.0.0" 940 | }, 941 | "engines": { 942 | "node": ">=6" 943 | }, 944 | "funding": { 945 | "url": "https://github.com/sponsors/sindresorhus" 946 | } 947 | }, 948 | "node_modules/imurmurhash": { 949 | "version": "0.1.4", 950 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 951 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 952 | "dev": true, 953 | "engines": { 954 | "node": ">=0.8.19" 955 | } 956 | }, 957 | "node_modules/inflight": { 958 | "version": "1.0.6", 959 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 960 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 961 | "dev": true, 962 | "dependencies": { 963 | "once": "^1.3.0", 964 | "wrappy": "1" 965 | } 966 | }, 967 | "node_modules/inherits": { 968 | "version": "2.0.4", 969 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 970 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 971 | "dev": true 972 | }, 973 | "node_modules/ip-address": { 974 | "version": "5.8.9", 975 | "resolved": "https://registry.npmjs.org/ip-address/-/ip-address-5.8.9.tgz", 976 | "integrity": "sha512-7ay355oMN34iXhET1BmCJVsHjOTSItEEIIpOs38qUC23AIhOy+xIPnkrTuEFjeLMrTJ7m8KMXWgWfy/2Vn9sDw==", 977 | "dependencies": { 978 | "jsbn": "1.1.0", 979 | "lodash.find": "^4.6.0", 980 | "lodash.max": "^4.0.1", 981 | "lodash.merge": "^4.6.0", 982 | "lodash.padstart": "^4.6.1", 983 | "lodash.repeat": "^4.1.0", 984 | "sprintf-js": "1.1.0" 985 | }, 986 | "engines": { 987 | "node": ">= 0.10" 988 | } 989 | }, 990 | "node_modules/ip-address/node_modules/jsbn": { 991 | "version": "1.1.0", 992 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz", 993 | "integrity": "sha1-sBMHyym2GKHtJux56RH4A8TaAEA=" 994 | }, 995 | "node_modules/ip-address/node_modules/sprintf-js": { 996 | "version": "1.1.0", 997 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.0.tgz", 998 | "integrity": "sha1-z/yvcC2vZeo5u04PorKZzsGhvkY=" 999 | }, 1000 | "node_modules/is-extglob": { 1001 | "version": "2.1.1", 1002 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1003 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1004 | "dev": true, 1005 | "engines": { 1006 | "node": ">=0.10.0" 1007 | } 1008 | }, 1009 | "node_modules/is-fullwidth-code-point": { 1010 | "version": "3.0.0", 1011 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1012 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1013 | "dev": true, 1014 | "engines": { 1015 | "node": ">=8" 1016 | } 1017 | }, 1018 | "node_modules/is-glob": { 1019 | "version": "4.0.1", 1020 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1021 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1022 | "dev": true, 1023 | "dependencies": { 1024 | "is-extglob": "^2.1.1" 1025 | }, 1026 | "engines": { 1027 | "node": ">=0.10.0" 1028 | } 1029 | }, 1030 | "node_modules/is-typedarray": { 1031 | "version": "1.0.0", 1032 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1033 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 1034 | }, 1035 | "node_modules/isexe": { 1036 | "version": "2.0.0", 1037 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1038 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1039 | "dev": true 1040 | }, 1041 | "node_modules/isstream": { 1042 | "version": "0.1.2", 1043 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1044 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 1045 | }, 1046 | "node_modules/istanbul": { 1047 | "version": "0.4.5", 1048 | "resolved": "https://registry.npmjs.org/istanbul/-/istanbul-0.4.5.tgz", 1049 | "integrity": "sha1-ZcfXPUxNqE1POsMQuRj7C4Azczs=", 1050 | "dev": true, 1051 | "dependencies": { 1052 | "abbrev": "1.0.x", 1053 | "async": "1.x", 1054 | "escodegen": "1.8.x", 1055 | "esprima": "2.7.x", 1056 | "glob": "^5.0.15", 1057 | "handlebars": "^4.0.1", 1058 | "js-yaml": "3.x", 1059 | "mkdirp": "0.5.x", 1060 | "nopt": "3.x", 1061 | "once": "1.x", 1062 | "resolve": "1.1.x", 1063 | "supports-color": "^3.1.0", 1064 | "which": "^1.1.1", 1065 | "wordwrap": "^1.0.0" 1066 | }, 1067 | "bin": { 1068 | "istanbul": "lib/cli.js" 1069 | } 1070 | }, 1071 | "node_modules/istanbul/node_modules/abbrev": { 1072 | "version": "1.0.9", 1073 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.0.9.tgz", 1074 | "integrity": "sha1-kbR5JYinc4wl813W9jdSovh3YTU=", 1075 | "dev": true 1076 | }, 1077 | "node_modules/istanbul/node_modules/amdefine": { 1078 | "version": "1.0.1", 1079 | "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", 1080 | "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", 1081 | "dev": true, 1082 | "optional": true, 1083 | "engines": { 1084 | "node": ">=0.4.2" 1085 | } 1086 | }, 1087 | "node_modules/istanbul/node_modules/async": { 1088 | "version": "1.5.2", 1089 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 1090 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", 1091 | "dev": true 1092 | }, 1093 | "node_modules/istanbul/node_modules/deep-is": { 1094 | "version": "0.1.3", 1095 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 1096 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 1097 | "dev": true 1098 | }, 1099 | "node_modules/istanbul/node_modules/escodegen": { 1100 | "version": "1.8.1", 1101 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.8.1.tgz", 1102 | "integrity": "sha1-WltTr0aTEQvrsIZ6o0MN07cKEBg=", 1103 | "dev": true, 1104 | "dependencies": { 1105 | "esprima": "^2.7.1", 1106 | "estraverse": "^1.9.1", 1107 | "esutils": "^2.0.2", 1108 | "optionator": "^0.8.1" 1109 | }, 1110 | "bin": { 1111 | "escodegen": "bin/escodegen.js", 1112 | "esgenerate": "bin/esgenerate.js" 1113 | }, 1114 | "engines": { 1115 | "node": ">=0.12.0" 1116 | }, 1117 | "optionalDependencies": { 1118 | "source-map": "~0.2.0" 1119 | } 1120 | }, 1121 | "node_modules/istanbul/node_modules/esprima": { 1122 | "version": "2.7.3", 1123 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", 1124 | "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", 1125 | "dev": true, 1126 | "bin": { 1127 | "esparse": "bin/esparse.js", 1128 | "esvalidate": "bin/esvalidate.js" 1129 | }, 1130 | "engines": { 1131 | "node": ">=0.10.0" 1132 | } 1133 | }, 1134 | "node_modules/istanbul/node_modules/estraverse": { 1135 | "version": "1.9.3", 1136 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-1.9.3.tgz", 1137 | "integrity": "sha1-r2fy3JIlgkFZUJJgkaQAXSnJu0Q=", 1138 | "dev": true, 1139 | "engines": { 1140 | "node": ">=0.10.0" 1141 | } 1142 | }, 1143 | "node_modules/istanbul/node_modules/esutils": { 1144 | "version": "2.0.2", 1145 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 1146 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 1147 | "dev": true, 1148 | "engines": { 1149 | "node": ">=0.10.0" 1150 | } 1151 | }, 1152 | "node_modules/istanbul/node_modules/fast-levenshtein": { 1153 | "version": "2.0.6", 1154 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1155 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1156 | "dev": true 1157 | }, 1158 | "node_modules/istanbul/node_modules/glob": { 1159 | "version": "5.0.15", 1160 | "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", 1161 | "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", 1162 | "dev": true, 1163 | "dependencies": { 1164 | "inflight": "^1.0.4", 1165 | "inherits": "2", 1166 | "minimatch": "2 || 3", 1167 | "once": "^1.3.0", 1168 | "path-is-absolute": "^1.0.0" 1169 | }, 1170 | "engines": { 1171 | "node": "*" 1172 | } 1173 | }, 1174 | "node_modules/istanbul/node_modules/has-flag": { 1175 | "version": "1.0.0", 1176 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-1.0.0.tgz", 1177 | "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", 1178 | "dev": true, 1179 | "engines": { 1180 | "node": ">=0.10.0" 1181 | } 1182 | }, 1183 | "node_modules/istanbul/node_modules/isexe": { 1184 | "version": "2.0.0", 1185 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1186 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1187 | "dev": true 1188 | }, 1189 | "node_modules/istanbul/node_modules/js-yaml": { 1190 | "version": "3.13.1", 1191 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1192 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1193 | "dev": true, 1194 | "dependencies": { 1195 | "argparse": "^1.0.7", 1196 | "esprima": "^4.0.0" 1197 | }, 1198 | "bin": { 1199 | "js-yaml": "bin/js-yaml.js" 1200 | } 1201 | }, 1202 | "node_modules/istanbul/node_modules/js-yaml/node_modules/esprima": { 1203 | "version": "4.0.1", 1204 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1205 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1206 | "dev": true, 1207 | "bin": { 1208 | "esparse": "bin/esparse.js", 1209 | "esvalidate": "bin/esvalidate.js" 1210 | }, 1211 | "engines": { 1212 | "node": ">=4" 1213 | } 1214 | }, 1215 | "node_modules/istanbul/node_modules/levn": { 1216 | "version": "0.3.0", 1217 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1218 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1219 | "dev": true, 1220 | "dependencies": { 1221 | "prelude-ls": "~1.1.2", 1222 | "type-check": "~0.3.2" 1223 | }, 1224 | "engines": { 1225 | "node": ">= 0.8.0" 1226 | } 1227 | }, 1228 | "node_modules/istanbul/node_modules/mkdirp": { 1229 | "version": "0.5.1", 1230 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1231 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1232 | "dev": true, 1233 | "dependencies": { 1234 | "minimist": "0.0.8" 1235 | }, 1236 | "bin": { 1237 | "mkdirp": "bin/cmd.js" 1238 | } 1239 | }, 1240 | "node_modules/istanbul/node_modules/mkdirp/node_modules/minimist": { 1241 | "version": "0.0.8", 1242 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1243 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1244 | "dev": true 1245 | }, 1246 | "node_modules/istanbul/node_modules/nopt": { 1247 | "version": "3.0.6", 1248 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", 1249 | "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", 1250 | "dev": true, 1251 | "dependencies": { 1252 | "abbrev": "1" 1253 | }, 1254 | "bin": { 1255 | "nopt": "bin/nopt.js" 1256 | } 1257 | }, 1258 | "node_modules/istanbul/node_modules/optionator": { 1259 | "version": "0.8.2", 1260 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1261 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1262 | "dev": true, 1263 | "dependencies": { 1264 | "deep-is": "~0.1.3", 1265 | "fast-levenshtein": "~2.0.4", 1266 | "levn": "~0.3.0", 1267 | "prelude-ls": "~1.1.2", 1268 | "type-check": "~0.3.2", 1269 | "wordwrap": "~1.0.0" 1270 | }, 1271 | "engines": { 1272 | "node": ">= 0.8.0" 1273 | } 1274 | }, 1275 | "node_modules/istanbul/node_modules/prelude-ls": { 1276 | "version": "1.1.2", 1277 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1278 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1279 | "dev": true, 1280 | "engines": { 1281 | "node": ">= 0.8.0" 1282 | } 1283 | }, 1284 | "node_modules/istanbul/node_modules/source-map": { 1285 | "version": "0.2.0", 1286 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.2.0.tgz", 1287 | "integrity": "sha1-2rc/vPwrqBm03gO9b26qSBZLP50=", 1288 | "dev": true, 1289 | "optional": true, 1290 | "dependencies": { 1291 | "amdefine": ">=0.0.4" 1292 | }, 1293 | "engines": { 1294 | "node": ">=0.8.0" 1295 | } 1296 | }, 1297 | "node_modules/istanbul/node_modules/supports-color": { 1298 | "version": "3.2.3", 1299 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", 1300 | "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", 1301 | "dev": true, 1302 | "dependencies": { 1303 | "has-flag": "^1.0.0" 1304 | }, 1305 | "engines": { 1306 | "node": ">=0.8.0" 1307 | } 1308 | }, 1309 | "node_modules/istanbul/node_modules/type-check": { 1310 | "version": "0.3.2", 1311 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1312 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1313 | "dev": true, 1314 | "dependencies": { 1315 | "prelude-ls": "~1.1.2" 1316 | }, 1317 | "engines": { 1318 | "node": ">= 0.8.0" 1319 | } 1320 | }, 1321 | "node_modules/istanbul/node_modules/which": { 1322 | "version": "1.3.0", 1323 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 1324 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 1325 | "dev": true, 1326 | "dependencies": { 1327 | "isexe": "^2.0.0" 1328 | }, 1329 | "bin": { 1330 | "which": "bin/which" 1331 | } 1332 | }, 1333 | "node_modules/istanbul/node_modules/wordwrap": { 1334 | "version": "1.0.0", 1335 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 1336 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 1337 | "dev": true 1338 | }, 1339 | "node_modules/jasmine": { 1340 | "version": "3.7.0", 1341 | "resolved": "https://registry.npmjs.org/jasmine/-/jasmine-3.7.0.tgz", 1342 | "integrity": "sha512-wlzGQ+cIFzMEsI+wDqmOwvnjTvolLFwlcpYLCqSPPH0prOQaW3P+IzMhHYn934l1imNvw07oCyX+vGUv3wmtSQ==", 1343 | "dev": true, 1344 | "dependencies": { 1345 | "glob": "^7.1.6", 1346 | "jasmine-core": "~3.7.0" 1347 | }, 1348 | "bin": { 1349 | "jasmine": "bin/jasmine.js" 1350 | } 1351 | }, 1352 | "node_modules/jasmine-core": { 1353 | "version": "3.7.1", 1354 | "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-3.7.1.tgz", 1355 | "integrity": "sha512-DH3oYDS/AUvvr22+xUBW62m1Xoy7tUlY1tsxKEJvl5JeJ7q8zd1K5bUwiOxdH+erj6l2vAMM3hV25Xs9/WrmuQ==", 1356 | "dev": true 1357 | }, 1358 | "node_modules/js-tokens": { 1359 | "version": "4.0.0", 1360 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1361 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1362 | "dev": true 1363 | }, 1364 | "node_modules/js-yaml": { 1365 | "version": "3.14.0", 1366 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 1367 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 1368 | "dev": true, 1369 | "dependencies": { 1370 | "argparse": "^1.0.7", 1371 | "esprima": "^4.0.0" 1372 | }, 1373 | "bin": { 1374 | "js-yaml": "bin/js-yaml.js" 1375 | } 1376 | }, 1377 | "node_modules/jsbn": { 1378 | "version": "0.1.1", 1379 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1380 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" 1381 | }, 1382 | "node_modules/json-schema": { 1383 | "version": "0.2.3", 1384 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1385 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 1386 | }, 1387 | "node_modules/json-schema-traverse": { 1388 | "version": "1.0.0", 1389 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 1390 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 1391 | "dev": true 1392 | }, 1393 | "node_modules/json-stable-stringify-without-jsonify": { 1394 | "version": "1.0.1", 1395 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1396 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1397 | "dev": true 1398 | }, 1399 | "node_modules/json-stringify-safe": { 1400 | "version": "5.0.1", 1401 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1402 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 1403 | }, 1404 | "node_modules/jsprim": { 1405 | "version": "1.4.1", 1406 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1407 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1408 | "engines": [ 1409 | "node >=0.6.0" 1410 | ], 1411 | "dependencies": { 1412 | "assert-plus": "1.0.0", 1413 | "extsprintf": "1.3.0", 1414 | "json-schema": "0.2.3", 1415 | "verror": "1.10.0" 1416 | } 1417 | }, 1418 | "node_modules/lcov-parse": { 1419 | "version": "1.0.0", 1420 | "resolved": "https://registry.npmjs.org/lcov-parse/-/lcov-parse-1.0.0.tgz", 1421 | "integrity": "sha1-6w1GtUER68VhrLTECO+TY73I9+A=", 1422 | "dev": true, 1423 | "bin": { 1424 | "lcov-parse": "bin/cli.js" 1425 | } 1426 | }, 1427 | "node_modules/levn": { 1428 | "version": "0.4.1", 1429 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1430 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1431 | "dev": true, 1432 | "dependencies": { 1433 | "prelude-ls": "^1.2.1", 1434 | "type-check": "~0.4.0" 1435 | }, 1436 | "engines": { 1437 | "node": ">= 0.8.0" 1438 | } 1439 | }, 1440 | "node_modules/lodash": { 1441 | "version": "4.17.21", 1442 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1443 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 1444 | }, 1445 | "node_modules/lodash.find": { 1446 | "version": "4.6.0", 1447 | "resolved": "https://registry.npmjs.org/lodash.find/-/lodash.find-4.6.0.tgz", 1448 | "integrity": "sha1-ywcE1Hq3F4n/oN6Ll92Sb7iLE7E=" 1449 | }, 1450 | "node_modules/lodash.max": { 1451 | "version": "4.0.1", 1452 | "resolved": "https://registry.npmjs.org/lodash.max/-/lodash.max-4.0.1.tgz", 1453 | "integrity": "sha1-hzVWbGGLNan3YFILSHrnllivE2o=" 1454 | }, 1455 | "node_modules/lodash.merge": { 1456 | "version": "4.6.2", 1457 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1458 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==" 1459 | }, 1460 | "node_modules/lodash.padstart": { 1461 | "version": "4.6.1", 1462 | "resolved": "https://registry.npmjs.org/lodash.padstart/-/lodash.padstart-4.6.1.tgz", 1463 | "integrity": "sha1-0uPuv/DZ05rVD1y9G1KnvOa7YRs=" 1464 | }, 1465 | "node_modules/lodash.repeat": { 1466 | "version": "4.1.0", 1467 | "resolved": "https://registry.npmjs.org/lodash.repeat/-/lodash.repeat-4.1.0.tgz", 1468 | "integrity": "sha1-/H3oEx2MisB+S0n3T/6CnR8r7EQ=" 1469 | }, 1470 | "node_modules/log-driver": { 1471 | "version": "1.2.7", 1472 | "resolved": "https://registry.npmjs.org/log-driver/-/log-driver-1.2.7.tgz", 1473 | "integrity": "sha512-U7KCmLdqsGHBLeWqYlFA0V0Sl6P08EE1ZrmA9cxjUE0WVqT9qnyVDPz1kzpFEP0jdJuFnasWIfSd7fsaNXkpbg==", 1474 | "dev": true, 1475 | "engines": { 1476 | "node": ">=0.8.6" 1477 | } 1478 | }, 1479 | "node_modules/mime-db": { 1480 | "version": "1.43.0", 1481 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.43.0.tgz", 1482 | "integrity": "sha512-+5dsGEEovYbT8UY9yD7eE4XTc4UwJ1jBYlgaQQF38ENsKR3wj/8q8RFZrF9WIZpB2V1ArTVFUva8sAul1NzRzQ==", 1483 | "engines": { 1484 | "node": ">= 0.6" 1485 | } 1486 | }, 1487 | "node_modules/mime-types": { 1488 | "version": "2.1.26", 1489 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.26.tgz", 1490 | "integrity": "sha512-01paPWYgLrkqAyrlDorC1uDwl2p3qZT7yl806vW7DvDoxwXi46jsjFbg+WdwotBIk6/MbEhO/dh5aZ5sNj/dWQ==", 1491 | "dependencies": { 1492 | "mime-db": "1.43.0" 1493 | }, 1494 | "engines": { 1495 | "node": ">= 0.6" 1496 | } 1497 | }, 1498 | "node_modules/minimatch": { 1499 | "version": "3.0.4", 1500 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1501 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1502 | "dev": true, 1503 | "dependencies": { 1504 | "brace-expansion": "^1.1.7" 1505 | }, 1506 | "engines": { 1507 | "node": "*" 1508 | } 1509 | }, 1510 | "node_modules/minimist": { 1511 | "version": "1.2.5", 1512 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1513 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1514 | "dev": true 1515 | }, 1516 | "node_modules/mockery": { 1517 | "version": "2.1.0", 1518 | "resolved": "https://registry.npmjs.org/mockery/-/mockery-2.1.0.tgz", 1519 | "integrity": "sha512-9VkOmxKlWXoDO/h1jDZaS4lH33aWfRiJiNT/tKj+8OGzrcFDLo8d0syGdbsc3Bc4GvRXPb+NMMvojotmuGJTvA==", 1520 | "dev": true 1521 | }, 1522 | "node_modules/ms": { 1523 | "version": "2.1.2", 1524 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1525 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1526 | "dev": true 1527 | }, 1528 | "node_modules/natural-compare": { 1529 | "version": "1.4.0", 1530 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1531 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1532 | "dev": true 1533 | }, 1534 | "node_modules/neo-async": { 1535 | "version": "2.6.1", 1536 | "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.1.tgz", 1537 | "integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==", 1538 | "dev": true 1539 | }, 1540 | "node_modules/oauth-sign": { 1541 | "version": "0.9.0", 1542 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 1543 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 1544 | "engines": { 1545 | "node": "*" 1546 | } 1547 | }, 1548 | "node_modules/once": { 1549 | "version": "1.4.0", 1550 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1551 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1552 | "dev": true, 1553 | "dependencies": { 1554 | "wrappy": "1" 1555 | } 1556 | }, 1557 | "node_modules/optionator": { 1558 | "version": "0.9.1", 1559 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1560 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1561 | "dev": true, 1562 | "dependencies": { 1563 | "deep-is": "^0.1.3", 1564 | "fast-levenshtein": "^2.0.6", 1565 | "levn": "^0.4.1", 1566 | "prelude-ls": "^1.2.1", 1567 | "type-check": "^0.4.0", 1568 | "word-wrap": "^1.2.3" 1569 | }, 1570 | "engines": { 1571 | "node": ">= 0.8.0" 1572 | } 1573 | }, 1574 | "node_modules/parent-module": { 1575 | "version": "1.0.1", 1576 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1577 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1578 | "dev": true, 1579 | "dependencies": { 1580 | "callsites": "^3.0.0" 1581 | }, 1582 | "engines": { 1583 | "node": ">=6" 1584 | } 1585 | }, 1586 | "node_modules/path-is-absolute": { 1587 | "version": "1.0.1", 1588 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1589 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1590 | "dev": true, 1591 | "engines": { 1592 | "node": ">=0.10.0" 1593 | } 1594 | }, 1595 | "node_modules/path-key": { 1596 | "version": "3.1.1", 1597 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1598 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1599 | "dev": true, 1600 | "engines": { 1601 | "node": ">=8" 1602 | } 1603 | }, 1604 | "node_modules/performance-now": { 1605 | "version": "2.1.0", 1606 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1607 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 1608 | }, 1609 | "node_modules/prelude-ls": { 1610 | "version": "1.2.1", 1611 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1612 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1613 | "dev": true, 1614 | "engines": { 1615 | "node": ">= 0.8.0" 1616 | } 1617 | }, 1618 | "node_modules/progress": { 1619 | "version": "2.0.3", 1620 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1621 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1622 | "dev": true, 1623 | "engines": { 1624 | "node": ">=0.4.0" 1625 | } 1626 | }, 1627 | "node_modules/psl": { 1628 | "version": "1.1.29", 1629 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz", 1630 | "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==" 1631 | }, 1632 | "node_modules/qs": { 1633 | "version": "6.5.2", 1634 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1635 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1636 | "engines": { 1637 | "node": ">=0.6" 1638 | } 1639 | }, 1640 | "node_modules/regexpp": { 1641 | "version": "3.1.0", 1642 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1643 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1644 | "dev": true, 1645 | "engines": { 1646 | "node": ">=8" 1647 | } 1648 | }, 1649 | "node_modules/request": { 1650 | "version": "2.88.2", 1651 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 1652 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 1653 | "dependencies": { 1654 | "aws-sign2": "~0.7.0", 1655 | "aws4": "^1.8.0", 1656 | "caseless": "~0.12.0", 1657 | "combined-stream": "~1.0.6", 1658 | "extend": "~3.0.2", 1659 | "forever-agent": "~0.6.1", 1660 | "form-data": "~2.3.2", 1661 | "har-validator": "~5.1.3", 1662 | "http-signature": "~1.2.0", 1663 | "is-typedarray": "~1.0.0", 1664 | "isstream": "~0.1.2", 1665 | "json-stringify-safe": "~5.0.1", 1666 | "mime-types": "~2.1.19", 1667 | "oauth-sign": "~0.9.0", 1668 | "performance-now": "^2.1.0", 1669 | "qs": "~6.5.2", 1670 | "safe-buffer": "^5.1.2", 1671 | "tough-cookie": "~2.5.0", 1672 | "tunnel-agent": "^0.6.0", 1673 | "uuid": "^3.3.2" 1674 | }, 1675 | "engines": { 1676 | "node": ">= 6" 1677 | } 1678 | }, 1679 | "node_modules/request-promise": { 1680 | "version": "4.2.6", 1681 | "resolved": "https://registry.npmjs.org/request-promise/-/request-promise-4.2.6.tgz", 1682 | "integrity": "sha512-HCHI3DJJUakkOr8fNoCc73E5nU5bqITjOYFMDrKHYOXWXrgD/SBaC7LjwuPymUprRyuF06UK7hd/lMHkmUXglQ==", 1683 | "dependencies": { 1684 | "bluebird": "^3.5.0", 1685 | "request-promise-core": "1.1.4", 1686 | "stealthy-require": "^1.1.1", 1687 | "tough-cookie": "^2.3.3" 1688 | }, 1689 | "engines": { 1690 | "node": ">=0.10.0" 1691 | } 1692 | }, 1693 | "node_modules/request-promise-core": { 1694 | "version": "1.1.4", 1695 | "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.4.tgz", 1696 | "integrity": "sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw==", 1697 | "dependencies": { 1698 | "lodash": "^4.17.19" 1699 | }, 1700 | "engines": { 1701 | "node": ">=0.10.0" 1702 | } 1703 | }, 1704 | "node_modules/require-from-string": { 1705 | "version": "2.0.2", 1706 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 1707 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 1708 | "dev": true, 1709 | "engines": { 1710 | "node": ">=0.10.0" 1711 | } 1712 | }, 1713 | "node_modules/resolve": { 1714 | "version": "1.1.7", 1715 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", 1716 | "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", 1717 | "dev": true 1718 | }, 1719 | "node_modules/resolve-from": { 1720 | "version": "4.0.0", 1721 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1722 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1723 | "dev": true, 1724 | "engines": { 1725 | "node": ">=4" 1726 | } 1727 | }, 1728 | "node_modules/rimraf": { 1729 | "version": "3.0.2", 1730 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1731 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1732 | "dev": true, 1733 | "dependencies": { 1734 | "glob": "^7.1.3" 1735 | }, 1736 | "bin": { 1737 | "rimraf": "bin.js" 1738 | }, 1739 | "funding": { 1740 | "url": "https://github.com/sponsors/isaacs" 1741 | } 1742 | }, 1743 | "node_modules/safe-buffer": { 1744 | "version": "5.2.0", 1745 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", 1746 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==" 1747 | }, 1748 | "node_modules/safer-buffer": { 1749 | "version": "2.1.2", 1750 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1751 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1752 | }, 1753 | "node_modules/semver": { 1754 | "version": "7.3.2", 1755 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 1756 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 1757 | "dev": true, 1758 | "bin": { 1759 | "semver": "bin/semver.js" 1760 | }, 1761 | "engines": { 1762 | "node": ">=10" 1763 | } 1764 | }, 1765 | "node_modules/shebang-command": { 1766 | "version": "2.0.0", 1767 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1768 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1769 | "dev": true, 1770 | "dependencies": { 1771 | "shebang-regex": "^3.0.0" 1772 | }, 1773 | "engines": { 1774 | "node": ">=8" 1775 | } 1776 | }, 1777 | "node_modules/shebang-regex": { 1778 | "version": "3.0.0", 1779 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1780 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1781 | "dev": true, 1782 | "engines": { 1783 | "node": ">=8" 1784 | } 1785 | }, 1786 | "node_modules/slice-ansi": { 1787 | "version": "4.0.0", 1788 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1789 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1790 | "dev": true, 1791 | "dependencies": { 1792 | "ansi-styles": "^4.0.0", 1793 | "astral-regex": "^2.0.0", 1794 | "is-fullwidth-code-point": "^3.0.0" 1795 | }, 1796 | "engines": { 1797 | "node": ">=10" 1798 | }, 1799 | "funding": { 1800 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1801 | } 1802 | }, 1803 | "node_modules/socks5-client": { 1804 | "version": "1.2.6", 1805 | "resolved": "https://registry.npmjs.org/socks5-client/-/socks5-client-1.2.6.tgz", 1806 | "integrity": "sha512-6ly0ZYGQaX8vBZvnRnRKT5yixfFEuQVxvYL5UGb7EFarP2d1yoWRJRBVfLKkBK5nOzX862EhhzOYwgZxRARwlQ==", 1807 | "dependencies": { 1808 | "ip-address": "~5.8.0" 1809 | }, 1810 | "engines": { 1811 | "node": ">= 6.4.0" 1812 | } 1813 | }, 1814 | "node_modules/socks5-https-client": { 1815 | "version": "1.2.1", 1816 | "resolved": "https://registry.npmjs.org/socks5-https-client/-/socks5-https-client-1.2.1.tgz", 1817 | "integrity": "sha512-FbZ/X/2Xq3DAMhuRA4bnN0jy1QxaPTVPLFvyv6CEj0QDKSTdWp9yRxo1JhqXmWKhPQeJyUMajHJB2UjT43pFcw==", 1818 | "dependencies": { 1819 | "socks5-client": "~1.2.3" 1820 | }, 1821 | "engines": { 1822 | "node": ">= 6.4.0" 1823 | } 1824 | }, 1825 | "node_modules/source-map": { 1826 | "version": "0.6.1", 1827 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1828 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1829 | "dev": true, 1830 | "engines": { 1831 | "node": ">=0.10.0" 1832 | } 1833 | }, 1834 | "node_modules/sprintf-js": { 1835 | "version": "1.0.3", 1836 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1837 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1838 | "dev": true 1839 | }, 1840 | "node_modules/sshpk": { 1841 | "version": "1.16.1", 1842 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 1843 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 1844 | "dependencies": { 1845 | "asn1": "~0.2.3", 1846 | "assert-plus": "^1.0.0", 1847 | "bcrypt-pbkdf": "^1.0.0", 1848 | "dashdash": "^1.12.0", 1849 | "ecc-jsbn": "~0.1.1", 1850 | "getpass": "^0.1.1", 1851 | "jsbn": "~0.1.0", 1852 | "safer-buffer": "^2.0.2", 1853 | "tweetnacl": "~0.14.0" 1854 | }, 1855 | "engines": { 1856 | "node": ">=0.10.0" 1857 | } 1858 | }, 1859 | "node_modules/stealthy-require": { 1860 | "version": "1.1.1", 1861 | "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz", 1862 | "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=", 1863 | "engines": { 1864 | "node": ">=0.10.0" 1865 | } 1866 | }, 1867 | "node_modules/string-width": { 1868 | "version": "4.2.2", 1869 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1870 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1871 | "dev": true, 1872 | "dependencies": { 1873 | "emoji-regex": "^8.0.0", 1874 | "is-fullwidth-code-point": "^3.0.0", 1875 | "strip-ansi": "^6.0.0" 1876 | }, 1877 | "engines": { 1878 | "node": ">=8" 1879 | } 1880 | }, 1881 | "node_modules/strip-ansi": { 1882 | "version": "6.0.0", 1883 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1884 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1885 | "dev": true, 1886 | "dependencies": { 1887 | "ansi-regex": "^5.0.0" 1888 | }, 1889 | "engines": { 1890 | "node": ">=8" 1891 | } 1892 | }, 1893 | "node_modules/strip-json-comments": { 1894 | "version": "3.1.1", 1895 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1896 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1897 | "dev": true, 1898 | "engines": { 1899 | "node": ">=8" 1900 | }, 1901 | "funding": { 1902 | "url": "https://github.com/sponsors/sindresorhus" 1903 | } 1904 | }, 1905 | "node_modules/supports-color": { 1906 | "version": "5.5.0", 1907 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1908 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1909 | "dev": true, 1910 | "dependencies": { 1911 | "has-flag": "^3.0.0" 1912 | }, 1913 | "engines": { 1914 | "node": ">=4" 1915 | } 1916 | }, 1917 | "node_modules/table": { 1918 | "version": "6.0.7", 1919 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz", 1920 | "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==", 1921 | "dev": true, 1922 | "dependencies": { 1923 | "ajv": "^7.0.2", 1924 | "lodash": "^4.17.20", 1925 | "slice-ansi": "^4.0.0", 1926 | "string-width": "^4.2.0" 1927 | }, 1928 | "engines": { 1929 | "node": ">=10.0.0" 1930 | } 1931 | }, 1932 | "node_modules/table/node_modules/ajv": { 1933 | "version": "7.2.3", 1934 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.2.3.tgz", 1935 | "integrity": "sha512-idv5WZvKVXDqKralOImQgPM9v6WOdLNa0IY3B3doOjw/YxRGT8I+allIJ6kd7Uaj+SF1xZUSU+nPM5aDNBVtnw==", 1936 | "dev": true, 1937 | "dependencies": { 1938 | "fast-deep-equal": "^3.1.1", 1939 | "json-schema-traverse": "^1.0.0", 1940 | "require-from-string": "^2.0.2", 1941 | "uri-js": "^4.2.2" 1942 | }, 1943 | "funding": { 1944 | "type": "github", 1945 | "url": "https://github.com/sponsors/epoberezkin" 1946 | } 1947 | }, 1948 | "node_modules/text-table": { 1949 | "version": "0.2.0", 1950 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1951 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1952 | "dev": true 1953 | }, 1954 | "node_modules/tough-cookie": { 1955 | "version": "2.5.0", 1956 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 1957 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 1958 | "dependencies": { 1959 | "psl": "^1.1.28", 1960 | "punycode": "^2.1.1" 1961 | }, 1962 | "engines": { 1963 | "node": ">=0.8" 1964 | } 1965 | }, 1966 | "node_modules/tough-cookie/node_modules/punycode": { 1967 | "version": "2.1.1", 1968 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1969 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1970 | "engines": { 1971 | "node": ">=6" 1972 | } 1973 | }, 1974 | "node_modules/tunnel-agent": { 1975 | "version": "0.6.0", 1976 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1977 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1978 | "dependencies": { 1979 | "safe-buffer": "^5.0.1" 1980 | }, 1981 | "engines": { 1982 | "node": "*" 1983 | } 1984 | }, 1985 | "node_modules/tweetnacl": { 1986 | "version": "0.14.5", 1987 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1988 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" 1989 | }, 1990 | "node_modules/type-check": { 1991 | "version": "0.4.0", 1992 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1993 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1994 | "dev": true, 1995 | "dependencies": { 1996 | "prelude-ls": "^1.2.1" 1997 | }, 1998 | "engines": { 1999 | "node": ">= 0.8.0" 2000 | } 2001 | }, 2002 | "node_modules/type-fest": { 2003 | "version": "0.20.2", 2004 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2005 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2006 | "dev": true, 2007 | "engines": { 2008 | "node": ">=10" 2009 | }, 2010 | "funding": { 2011 | "url": "https://github.com/sponsors/sindresorhus" 2012 | } 2013 | }, 2014 | "node_modules/uglify-js": { 2015 | "version": "3.9.1", 2016 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.9.1.tgz", 2017 | "integrity": "sha512-JUPoL1jHsc9fOjVFHdQIhqEEJsQvfKDjlubcCilu8U26uZ73qOg8VsN8O1jbuei44ZPlwL7kmbAdM4tzaUvqnA==", 2018 | "dev": true, 2019 | "optional": true, 2020 | "dependencies": { 2021 | "commander": "~2.20.3" 2022 | }, 2023 | "bin": { 2024 | "uglifyjs": "bin/uglifyjs" 2025 | }, 2026 | "engines": { 2027 | "node": ">=0.8.0" 2028 | } 2029 | }, 2030 | "node_modules/uri-js": { 2031 | "version": "4.2.2", 2032 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2033 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2034 | "dependencies": { 2035 | "punycode": "^2.1.0" 2036 | } 2037 | }, 2038 | "node_modules/uri-js/node_modules/punycode": { 2039 | "version": "2.1.1", 2040 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2041 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2042 | "engines": { 2043 | "node": ">=6" 2044 | } 2045 | }, 2046 | "node_modules/uuid": { 2047 | "version": "3.4.0", 2048 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 2049 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 2050 | "bin": { 2051 | "uuid": "bin/uuid" 2052 | } 2053 | }, 2054 | "node_modules/v8-compile-cache": { 2055 | "version": "2.1.1", 2056 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 2057 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 2058 | "dev": true 2059 | }, 2060 | "node_modules/verror": { 2061 | "version": "1.10.0", 2062 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2063 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2064 | "engines": [ 2065 | "node >=0.6.0" 2066 | ], 2067 | "dependencies": { 2068 | "assert-plus": "^1.0.0", 2069 | "core-util-is": "1.0.2", 2070 | "extsprintf": "^1.2.0" 2071 | } 2072 | }, 2073 | "node_modules/which": { 2074 | "version": "2.0.2", 2075 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2076 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2077 | "dev": true, 2078 | "dependencies": { 2079 | "isexe": "^2.0.0" 2080 | }, 2081 | "bin": { 2082 | "node-which": "bin/node-which" 2083 | }, 2084 | "engines": { 2085 | "node": ">= 8" 2086 | } 2087 | }, 2088 | "node_modules/word-wrap": { 2089 | "version": "1.2.3", 2090 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2091 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2092 | "dev": true, 2093 | "engines": { 2094 | "node": ">=0.10.0" 2095 | } 2096 | }, 2097 | "node_modules/wordwrap": { 2098 | "version": "1.0.0", 2099 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2100 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 2101 | "dev": true 2102 | }, 2103 | "node_modules/wrappy": { 2104 | "version": "1.0.2", 2105 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2106 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2107 | "dev": true 2108 | } 2109 | }, 2110 | "dependencies": { 2111 | "@babel/code-frame": { 2112 | "version": "7.12.11", 2113 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 2114 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 2115 | "dev": true, 2116 | "requires": { 2117 | "@babel/highlight": "^7.10.4" 2118 | } 2119 | }, 2120 | "@babel/helper-validator-identifier": { 2121 | "version": "7.12.11", 2122 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 2123 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 2124 | "dev": true 2125 | }, 2126 | "@babel/highlight": { 2127 | "version": "7.13.10", 2128 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.13.10.tgz", 2129 | "integrity": "sha512-5aPpe5XQPzflQrFwL1/QoeHkP2MsA4JCntcXHRhEsdsfPVkvPi2w7Qix4iV7t5S/oC9OodGrggd8aco1g3SZFg==", 2130 | "dev": true, 2131 | "requires": { 2132 | "@babel/helper-validator-identifier": "^7.12.11", 2133 | "chalk": "^2.0.0", 2134 | "js-tokens": "^4.0.0" 2135 | }, 2136 | "dependencies": { 2137 | "ansi-styles": { 2138 | "version": "3.2.1", 2139 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2140 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2141 | "dev": true, 2142 | "requires": { 2143 | "color-convert": "^1.9.0" 2144 | } 2145 | }, 2146 | "chalk": { 2147 | "version": "2.4.2", 2148 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2149 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2150 | "dev": true, 2151 | "requires": { 2152 | "ansi-styles": "^3.2.1", 2153 | "escape-string-regexp": "^1.0.5", 2154 | "supports-color": "^5.3.0" 2155 | } 2156 | }, 2157 | "color-convert": { 2158 | "version": "1.9.3", 2159 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2160 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2161 | "dev": true, 2162 | "requires": { 2163 | "color-name": "1.1.3" 2164 | } 2165 | }, 2166 | "color-name": { 2167 | "version": "1.1.3", 2168 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2169 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2170 | "dev": true 2171 | } 2172 | } 2173 | }, 2174 | "@eslint/eslintrc": { 2175 | "version": "0.4.0", 2176 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.0.tgz", 2177 | "integrity": "sha512-2ZPCc+uNbjV5ERJr+aKSPRwZgKd2z11x0EgLvb1PURmUrn9QNRXFqje0Ldq454PfAVyaJYyrDvvIKSFP4NnBog==", 2178 | "dev": true, 2179 | "requires": { 2180 | "ajv": "^6.12.4", 2181 | "debug": "^4.1.1", 2182 | "espree": "^7.3.0", 2183 | "globals": "^12.1.0", 2184 | "ignore": "^4.0.6", 2185 | "import-fresh": "^3.2.1", 2186 | "js-yaml": "^3.13.1", 2187 | "minimatch": "^3.0.4", 2188 | "strip-json-comments": "^3.1.1" 2189 | }, 2190 | "dependencies": { 2191 | "globals": { 2192 | "version": "12.4.0", 2193 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 2194 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 2195 | "dev": true, 2196 | "requires": { 2197 | "type-fest": "^0.8.1" 2198 | } 2199 | }, 2200 | "type-fest": { 2201 | "version": "0.8.1", 2202 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2203 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2204 | "dev": true 2205 | } 2206 | } 2207 | }, 2208 | "acorn": { 2209 | "version": "7.4.1", 2210 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 2211 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 2212 | "dev": true 2213 | }, 2214 | "acorn-jsx": { 2215 | "version": "5.3.1", 2216 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 2217 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 2218 | "dev": true, 2219 | "requires": {} 2220 | }, 2221 | "ajv": { 2222 | "version": "6.12.6", 2223 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2224 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2225 | "requires": { 2226 | "fast-deep-equal": "^3.1.1", 2227 | "fast-json-stable-stringify": "^2.0.0", 2228 | "json-schema-traverse": "^0.4.1", 2229 | "uri-js": "^4.2.2" 2230 | }, 2231 | "dependencies": { 2232 | "json-schema-traverse": { 2233 | "version": "0.4.1", 2234 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2235 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 2236 | } 2237 | } 2238 | }, 2239 | "ansi-colors": { 2240 | "version": "4.1.1", 2241 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 2242 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 2243 | "dev": true 2244 | }, 2245 | "ansi-regex": { 2246 | "version": "5.0.0", 2247 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 2248 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 2249 | "dev": true 2250 | }, 2251 | "ansi-styles": { 2252 | "version": "4.3.0", 2253 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2254 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2255 | "dev": true, 2256 | "requires": { 2257 | "color-convert": "^2.0.1" 2258 | } 2259 | }, 2260 | "argparse": { 2261 | "version": "1.0.10", 2262 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 2263 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 2264 | "dev": true, 2265 | "requires": { 2266 | "sprintf-js": "~1.0.2" 2267 | } 2268 | }, 2269 | "asn1": { 2270 | "version": "0.2.4", 2271 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 2272 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 2273 | "requires": { 2274 | "safer-buffer": "~2.1.0" 2275 | } 2276 | }, 2277 | "assert-plus": { 2278 | "version": "1.0.0", 2279 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 2280 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" 2281 | }, 2282 | "astral-regex": { 2283 | "version": "2.0.0", 2284 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 2285 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 2286 | "dev": true 2287 | }, 2288 | "asynckit": { 2289 | "version": "0.4.0", 2290 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 2291 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 2292 | }, 2293 | "aws-sign2": { 2294 | "version": "0.7.0", 2295 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 2296 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" 2297 | }, 2298 | "aws4": { 2299 | "version": "1.9.1", 2300 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.1.tgz", 2301 | "integrity": "sha512-wMHVg2EOHaMRxbzgFJ9gtjOOCrI80OHLG14rxi28XwOW8ux6IiEbRCGGGqCtdAIg4FQCbW20k9RsT4y3gJlFug==" 2302 | }, 2303 | "balanced-match": { 2304 | "version": "1.0.0", 2305 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 2306 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 2307 | "dev": true 2308 | }, 2309 | "bcrypt-pbkdf": { 2310 | "version": "1.0.2", 2311 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 2312 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 2313 | "requires": { 2314 | "tweetnacl": "^0.14.3" 2315 | } 2316 | }, 2317 | "bluebird": { 2318 | "version": "3.7.2", 2319 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 2320 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" 2321 | }, 2322 | "brace-expansion": { 2323 | "version": "1.1.11", 2324 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2325 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2326 | "dev": true, 2327 | "requires": { 2328 | "balanced-match": "^1.0.0", 2329 | "concat-map": "0.0.1" 2330 | } 2331 | }, 2332 | "callsites": { 2333 | "version": "3.1.0", 2334 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2335 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2336 | "dev": true 2337 | }, 2338 | "caseless": { 2339 | "version": "0.12.0", 2340 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 2341 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" 2342 | }, 2343 | "chalk": { 2344 | "version": "4.1.0", 2345 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 2346 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 2347 | "dev": true, 2348 | "requires": { 2349 | "ansi-styles": "^4.1.0", 2350 | "supports-color": "^7.1.0" 2351 | }, 2352 | "dependencies": { 2353 | "has-flag": { 2354 | "version": "4.0.0", 2355 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2356 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2357 | "dev": true 2358 | }, 2359 | "supports-color": { 2360 | "version": "7.2.0", 2361 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2362 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2363 | "dev": true, 2364 | "requires": { 2365 | "has-flag": "^4.0.0" 2366 | } 2367 | } 2368 | } 2369 | }, 2370 | "color-convert": { 2371 | "version": "2.0.1", 2372 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2373 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2374 | "dev": true, 2375 | "requires": { 2376 | "color-name": "~1.1.4" 2377 | } 2378 | }, 2379 | "color-name": { 2380 | "version": "1.1.4", 2381 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2382 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2383 | "dev": true 2384 | }, 2385 | "combined-stream": { 2386 | "version": "1.0.8", 2387 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 2388 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 2389 | "requires": { 2390 | "delayed-stream": "~1.0.0" 2391 | } 2392 | }, 2393 | "commander": { 2394 | "version": "2.20.3", 2395 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 2396 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 2397 | "dev": true, 2398 | "optional": true 2399 | }, 2400 | "concat-map": { 2401 | "version": "0.0.1", 2402 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2403 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 2404 | "dev": true 2405 | }, 2406 | "core-util-is": { 2407 | "version": "1.0.2", 2408 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 2409 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 2410 | }, 2411 | "coveralls": { 2412 | "version": "3.1.0", 2413 | "resolved": "https://registry.npmjs.org/coveralls/-/coveralls-3.1.0.tgz", 2414 | "integrity": "sha512-sHxOu2ELzW8/NC1UP5XVLbZDzO4S3VxfFye3XYCznopHy02YjNkHcj5bKaVw2O7hVaBdBjEdQGpie4II1mWhuQ==", 2415 | "dev": true, 2416 | "requires": { 2417 | "js-yaml": "^3.13.1", 2418 | "lcov-parse": "^1.0.0", 2419 | "log-driver": "^1.2.7", 2420 | "minimist": "^1.2.5", 2421 | "request": "^2.88.2" 2422 | } 2423 | }, 2424 | "cross-spawn": { 2425 | "version": "7.0.3", 2426 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2427 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2428 | "dev": true, 2429 | "requires": { 2430 | "path-key": "^3.1.0", 2431 | "shebang-command": "^2.0.0", 2432 | "which": "^2.0.1" 2433 | } 2434 | }, 2435 | "dashdash": { 2436 | "version": "1.14.1", 2437 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 2438 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 2439 | "requires": { 2440 | "assert-plus": "^1.0.0" 2441 | } 2442 | }, 2443 | "debug": { 2444 | "version": "4.3.1", 2445 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 2446 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 2447 | "dev": true, 2448 | "requires": { 2449 | "ms": "2.1.2" 2450 | } 2451 | }, 2452 | "deep-is": { 2453 | "version": "0.1.3", 2454 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 2455 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 2456 | "dev": true 2457 | }, 2458 | "delayed-stream": { 2459 | "version": "1.0.0", 2460 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 2461 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 2462 | }, 2463 | "doctrine": { 2464 | "version": "3.0.0", 2465 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2466 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2467 | "dev": true, 2468 | "requires": { 2469 | "esutils": "^2.0.2" 2470 | } 2471 | }, 2472 | "ecc-jsbn": { 2473 | "version": "0.1.2", 2474 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 2475 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 2476 | "requires": { 2477 | "jsbn": "~0.1.0", 2478 | "safer-buffer": "^2.1.0" 2479 | } 2480 | }, 2481 | "emoji-regex": { 2482 | "version": "8.0.0", 2483 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2484 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2485 | "dev": true 2486 | }, 2487 | "enquirer": { 2488 | "version": "2.3.6", 2489 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 2490 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 2491 | "dev": true, 2492 | "requires": { 2493 | "ansi-colors": "^4.1.1" 2494 | } 2495 | }, 2496 | "escape-string-regexp": { 2497 | "version": "1.0.5", 2498 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2499 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 2500 | "dev": true 2501 | }, 2502 | "eslint": { 2503 | "version": "7.22.0", 2504 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.22.0.tgz", 2505 | "integrity": "sha512-3VawOtjSJUQiiqac8MQc+w457iGLfuNGLFn8JmF051tTKbh5/x/0vlcEj8OgDCaw7Ysa2Jn8paGshV7x2abKXg==", 2506 | "dev": true, 2507 | "requires": { 2508 | "@babel/code-frame": "7.12.11", 2509 | "@eslint/eslintrc": "^0.4.0", 2510 | "ajv": "^6.10.0", 2511 | "chalk": "^4.0.0", 2512 | "cross-spawn": "^7.0.2", 2513 | "debug": "^4.0.1", 2514 | "doctrine": "^3.0.0", 2515 | "enquirer": "^2.3.5", 2516 | "eslint-scope": "^5.1.1", 2517 | "eslint-utils": "^2.1.0", 2518 | "eslint-visitor-keys": "^2.0.0", 2519 | "espree": "^7.3.1", 2520 | "esquery": "^1.4.0", 2521 | "esutils": "^2.0.2", 2522 | "file-entry-cache": "^6.0.1", 2523 | "functional-red-black-tree": "^1.0.1", 2524 | "glob-parent": "^5.0.0", 2525 | "globals": "^13.6.0", 2526 | "ignore": "^4.0.6", 2527 | "import-fresh": "^3.0.0", 2528 | "imurmurhash": "^0.1.4", 2529 | "is-glob": "^4.0.0", 2530 | "js-yaml": "^3.13.1", 2531 | "json-stable-stringify-without-jsonify": "^1.0.1", 2532 | "levn": "^0.4.1", 2533 | "lodash": "^4.17.21", 2534 | "minimatch": "^3.0.4", 2535 | "natural-compare": "^1.4.0", 2536 | "optionator": "^0.9.1", 2537 | "progress": "^2.0.0", 2538 | "regexpp": "^3.1.0", 2539 | "semver": "^7.2.1", 2540 | "strip-ansi": "^6.0.0", 2541 | "strip-json-comments": "^3.1.0", 2542 | "table": "^6.0.4", 2543 | "text-table": "^0.2.0", 2544 | "v8-compile-cache": "^2.0.3" 2545 | } 2546 | }, 2547 | "eslint-scope": { 2548 | "version": "5.1.1", 2549 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 2550 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 2551 | "dev": true, 2552 | "requires": { 2553 | "esrecurse": "^4.3.0", 2554 | "estraverse": "^4.1.1" 2555 | } 2556 | }, 2557 | "eslint-utils": { 2558 | "version": "2.1.0", 2559 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 2560 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 2561 | "dev": true, 2562 | "requires": { 2563 | "eslint-visitor-keys": "^1.1.0" 2564 | }, 2565 | "dependencies": { 2566 | "eslint-visitor-keys": { 2567 | "version": "1.3.0", 2568 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 2569 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 2570 | "dev": true 2571 | } 2572 | } 2573 | }, 2574 | "eslint-visitor-keys": { 2575 | "version": "2.0.0", 2576 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 2577 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 2578 | "dev": true 2579 | }, 2580 | "espree": { 2581 | "version": "7.3.1", 2582 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 2583 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 2584 | "dev": true, 2585 | "requires": { 2586 | "acorn": "^7.4.0", 2587 | "acorn-jsx": "^5.3.1", 2588 | "eslint-visitor-keys": "^1.3.0" 2589 | }, 2590 | "dependencies": { 2591 | "eslint-visitor-keys": { 2592 | "version": "1.3.0", 2593 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 2594 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 2595 | "dev": true 2596 | } 2597 | } 2598 | }, 2599 | "esprima": { 2600 | "version": "4.0.1", 2601 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2602 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 2603 | "dev": true 2604 | }, 2605 | "esquery": { 2606 | "version": "1.4.0", 2607 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 2608 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 2609 | "dev": true, 2610 | "requires": { 2611 | "estraverse": "^5.1.0" 2612 | }, 2613 | "dependencies": { 2614 | "estraverse": { 2615 | "version": "5.2.0", 2616 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2617 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2618 | "dev": true 2619 | } 2620 | } 2621 | }, 2622 | "esrecurse": { 2623 | "version": "4.3.0", 2624 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2625 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2626 | "dev": true, 2627 | "requires": { 2628 | "estraverse": "^5.2.0" 2629 | }, 2630 | "dependencies": { 2631 | "estraverse": { 2632 | "version": "5.2.0", 2633 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2634 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2635 | "dev": true 2636 | } 2637 | } 2638 | }, 2639 | "estraverse": { 2640 | "version": "4.3.0", 2641 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 2642 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 2643 | "dev": true 2644 | }, 2645 | "esutils": { 2646 | "version": "2.0.3", 2647 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2648 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2649 | "dev": true 2650 | }, 2651 | "eventemitter3": { 2652 | "version": "4.0.7", 2653 | "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", 2654 | "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==" 2655 | }, 2656 | "extend": { 2657 | "version": "3.0.2", 2658 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 2659 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 2660 | }, 2661 | "extsprintf": { 2662 | "version": "1.3.0", 2663 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 2664 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" 2665 | }, 2666 | "fast-deep-equal": { 2667 | "version": "3.1.3", 2668 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2669 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" 2670 | }, 2671 | "fast-json-stable-stringify": { 2672 | "version": "2.0.0", 2673 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 2674 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 2675 | }, 2676 | "fast-levenshtein": { 2677 | "version": "2.0.6", 2678 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2679 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2680 | "dev": true 2681 | }, 2682 | "file-entry-cache": { 2683 | "version": "6.0.1", 2684 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2685 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2686 | "dev": true, 2687 | "requires": { 2688 | "flat-cache": "^3.0.4" 2689 | } 2690 | }, 2691 | "flat-cache": { 2692 | "version": "3.0.4", 2693 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 2694 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 2695 | "dev": true, 2696 | "requires": { 2697 | "flatted": "^3.1.0", 2698 | "rimraf": "^3.0.2" 2699 | } 2700 | }, 2701 | "flatted": { 2702 | "version": "3.1.1", 2703 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 2704 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 2705 | "dev": true 2706 | }, 2707 | "forever-agent": { 2708 | "version": "0.6.1", 2709 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 2710 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" 2711 | }, 2712 | "form-data": { 2713 | "version": "2.3.3", 2714 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 2715 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 2716 | "requires": { 2717 | "asynckit": "^0.4.0", 2718 | "combined-stream": "^1.0.6", 2719 | "mime-types": "^2.1.12" 2720 | } 2721 | }, 2722 | "fs.realpath": { 2723 | "version": "1.0.0", 2724 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2725 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2726 | "dev": true 2727 | }, 2728 | "functional-red-black-tree": { 2729 | "version": "1.0.1", 2730 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 2731 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 2732 | "dev": true 2733 | }, 2734 | "getpass": { 2735 | "version": "0.1.7", 2736 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 2737 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 2738 | "requires": { 2739 | "assert-plus": "^1.0.0" 2740 | } 2741 | }, 2742 | "glob": { 2743 | "version": "7.1.6", 2744 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 2745 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 2746 | "dev": true, 2747 | "requires": { 2748 | "fs.realpath": "^1.0.0", 2749 | "inflight": "^1.0.4", 2750 | "inherits": "2", 2751 | "minimatch": "^3.0.4", 2752 | "once": "^1.3.0", 2753 | "path-is-absolute": "^1.0.0" 2754 | } 2755 | }, 2756 | "glob-parent": { 2757 | "version": "5.1.1", 2758 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 2759 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 2760 | "dev": true, 2761 | "requires": { 2762 | "is-glob": "^4.0.1" 2763 | } 2764 | }, 2765 | "globals": { 2766 | "version": "13.7.0", 2767 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.7.0.tgz", 2768 | "integrity": "sha512-Aipsz6ZKRxa/xQkZhNg0qIWXT6x6rD46f6x/PCnBomlttdIyAPak4YD9jTmKpZ72uROSMU87qJtcgpgHaVchiA==", 2769 | "dev": true, 2770 | "requires": { 2771 | "type-fest": "^0.20.2" 2772 | } 2773 | }, 2774 | "handlebars": { 2775 | "version": "4.7.7", 2776 | "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.7.7.tgz", 2777 | "integrity": "sha512-aAcXm5OAfE/8IXkcZvCepKU3VzW1/39Fb5ZuqMtgI/hT8X2YgoMvBY5dLhq/cpOvw7Lk1nK/UF71aLG/ZnVYRA==", 2778 | "dev": true, 2779 | "requires": { 2780 | "minimist": "^1.2.5", 2781 | "neo-async": "^2.6.0", 2782 | "source-map": "^0.6.1", 2783 | "uglify-js": "^3.1.4", 2784 | "wordwrap": "^1.0.0" 2785 | } 2786 | }, 2787 | "har-schema": { 2788 | "version": "2.0.0", 2789 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 2790 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" 2791 | }, 2792 | "har-validator": { 2793 | "version": "5.1.3", 2794 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 2795 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 2796 | "requires": { 2797 | "ajv": "^6.5.5", 2798 | "har-schema": "^2.0.0" 2799 | } 2800 | }, 2801 | "has-flag": { 2802 | "version": "3.0.0", 2803 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2804 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2805 | "dev": true 2806 | }, 2807 | "http-signature": { 2808 | "version": "1.2.0", 2809 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 2810 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 2811 | "requires": { 2812 | "assert-plus": "^1.0.0", 2813 | "jsprim": "^1.2.2", 2814 | "sshpk": "^1.7.0" 2815 | } 2816 | }, 2817 | "ignore": { 2818 | "version": "4.0.6", 2819 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 2820 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 2821 | "dev": true 2822 | }, 2823 | "import-fresh": { 2824 | "version": "3.3.0", 2825 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2826 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2827 | "dev": true, 2828 | "requires": { 2829 | "parent-module": "^1.0.0", 2830 | "resolve-from": "^4.0.0" 2831 | } 2832 | }, 2833 | "imurmurhash": { 2834 | "version": "0.1.4", 2835 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2836 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2837 | "dev": true 2838 | }, 2839 | "inflight": { 2840 | "version": "1.0.6", 2841 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2842 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2843 | "dev": true, 2844 | "requires": { 2845 | "once": "^1.3.0", 2846 | "wrappy": "1" 2847 | } 2848 | }, 2849 | "inherits": { 2850 | "version": "2.0.4", 2851 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2852 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2853 | "dev": true 2854 | }, 2855 | "ip-address": { 2856 | "version": "5.8.9", 2857 | "resolved": "https://registry.npmjs.org/ip-address/-/ip-address-5.8.9.tgz", 2858 | "integrity": "sha512-7ay355oMN34iXhET1BmCJVsHjOTSItEEIIpOs38qUC23AIhOy+xIPnkrTuEFjeLMrTJ7m8KMXWgWfy/2Vn9sDw==", 2859 | "requires": { 2860 | "jsbn": "1.1.0", 2861 | "lodash.find": "^4.6.0", 2862 | "lodash.max": "^4.0.1", 2863 | "lodash.merge": "^4.6.0", 2864 | "lodash.padstart": "^4.6.1", 2865 | "lodash.repeat": "^4.1.0", 2866 | "sprintf-js": "1.1.0" 2867 | }, 2868 | "dependencies": { 2869 | "jsbn": { 2870 | "version": "1.1.0", 2871 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz", 2872 | "integrity": "sha1-sBMHyym2GKHtJux56RH4A8TaAEA=" 2873 | }, 2874 | "sprintf-js": { 2875 | "version": "1.1.0", 2876 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.0.tgz", 2877 | "integrity": "sha1-z/yvcC2vZeo5u04PorKZzsGhvkY=" 2878 | } 2879 | } 2880 | }, 2881 | "is-extglob": { 2882 | "version": "2.1.1", 2883 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2884 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2885 | "dev": true 2886 | }, 2887 | "is-fullwidth-code-point": { 2888 | "version": "3.0.0", 2889 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2890 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2891 | "dev": true 2892 | }, 2893 | "is-glob": { 2894 | "version": "4.0.1", 2895 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 2896 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 2897 | "dev": true, 2898 | "requires": { 2899 | "is-extglob": "^2.1.1" 2900 | } 2901 | }, 2902 | "is-typedarray": { 2903 | "version": "1.0.0", 2904 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 2905 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 2906 | }, 2907 | "isexe": { 2908 | "version": "2.0.0", 2909 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2910 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2911 | "dev": true 2912 | }, 2913 | "isstream": { 2914 | "version": "0.1.2", 2915 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 2916 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" 2917 | }, 2918 | "istanbul": { 2919 | "version": "0.4.5", 2920 | "resolved": "https://registry.npmjs.org/istanbul/-/istanbul-0.4.5.tgz", 2921 | "integrity": "sha1-ZcfXPUxNqE1POsMQuRj7C4Azczs=", 2922 | "dev": true, 2923 | "requires": { 2924 | "abbrev": "1.0.x", 2925 | "async": "1.x", 2926 | "escodegen": "1.8.x", 2927 | "esprima": "2.7.x", 2928 | "glob": "^5.0.15", 2929 | "handlebars": "^4.0.1", 2930 | "js-yaml": "3.x", 2931 | "mkdirp": "0.5.x", 2932 | "nopt": "3.x", 2933 | "once": "1.x", 2934 | "resolve": "1.1.x", 2935 | "supports-color": "^3.1.0", 2936 | "which": "^1.1.1", 2937 | "wordwrap": "^1.0.0" 2938 | }, 2939 | "dependencies": { 2940 | "abbrev": { 2941 | "version": "1.0.9", 2942 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.0.9.tgz", 2943 | "integrity": "sha1-kbR5JYinc4wl813W9jdSovh3YTU=", 2944 | "dev": true 2945 | }, 2946 | "amdefine": { 2947 | "version": "1.0.1", 2948 | "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", 2949 | "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", 2950 | "dev": true, 2951 | "optional": true 2952 | }, 2953 | "async": { 2954 | "version": "1.5.2", 2955 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 2956 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", 2957 | "dev": true 2958 | }, 2959 | "deep-is": { 2960 | "version": "0.1.3", 2961 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 2962 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 2963 | "dev": true 2964 | }, 2965 | "escodegen": { 2966 | "version": "1.8.1", 2967 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.8.1.tgz", 2968 | "integrity": "sha1-WltTr0aTEQvrsIZ6o0MN07cKEBg=", 2969 | "dev": true, 2970 | "requires": { 2971 | "esprima": "^2.7.1", 2972 | "estraverse": "^1.9.1", 2973 | "esutils": "^2.0.2", 2974 | "optionator": "^0.8.1", 2975 | "source-map": "~0.2.0" 2976 | } 2977 | }, 2978 | "esprima": { 2979 | "version": "2.7.3", 2980 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", 2981 | "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", 2982 | "dev": true 2983 | }, 2984 | "estraverse": { 2985 | "version": "1.9.3", 2986 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-1.9.3.tgz", 2987 | "integrity": "sha1-r2fy3JIlgkFZUJJgkaQAXSnJu0Q=", 2988 | "dev": true 2989 | }, 2990 | "esutils": { 2991 | "version": "2.0.2", 2992 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 2993 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 2994 | "dev": true 2995 | }, 2996 | "fast-levenshtein": { 2997 | "version": "2.0.6", 2998 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2999 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 3000 | "dev": true 3001 | }, 3002 | "glob": { 3003 | "version": "5.0.15", 3004 | "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", 3005 | "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", 3006 | "dev": true, 3007 | "requires": { 3008 | "inflight": "^1.0.4", 3009 | "inherits": "2", 3010 | "minimatch": "2 || 3", 3011 | "once": "^1.3.0", 3012 | "path-is-absolute": "^1.0.0" 3013 | } 3014 | }, 3015 | "has-flag": { 3016 | "version": "1.0.0", 3017 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-1.0.0.tgz", 3018 | "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", 3019 | "dev": true 3020 | }, 3021 | "isexe": { 3022 | "version": "2.0.0", 3023 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 3024 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 3025 | "dev": true 3026 | }, 3027 | "js-yaml": { 3028 | "version": "3.13.1", 3029 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 3030 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 3031 | "dev": true, 3032 | "requires": { 3033 | "argparse": "^1.0.7", 3034 | "esprima": "^4.0.0" 3035 | }, 3036 | "dependencies": { 3037 | "esprima": { 3038 | "version": "4.0.1", 3039 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 3040 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 3041 | "dev": true 3042 | } 3043 | } 3044 | }, 3045 | "levn": { 3046 | "version": "0.3.0", 3047 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 3048 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 3049 | "dev": true, 3050 | "requires": { 3051 | "prelude-ls": "~1.1.2", 3052 | "type-check": "~0.3.2" 3053 | } 3054 | }, 3055 | "mkdirp": { 3056 | "version": "0.5.1", 3057 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 3058 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 3059 | "dev": true, 3060 | "requires": { 3061 | "minimist": "0.0.8" 3062 | }, 3063 | "dependencies": { 3064 | "minimist": { 3065 | "version": "0.0.8", 3066 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 3067 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 3068 | "dev": true 3069 | } 3070 | } 3071 | }, 3072 | "nopt": { 3073 | "version": "3.0.6", 3074 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", 3075 | "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", 3076 | "dev": true, 3077 | "requires": { 3078 | "abbrev": "1" 3079 | } 3080 | }, 3081 | "optionator": { 3082 | "version": "0.8.2", 3083 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 3084 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 3085 | "dev": true, 3086 | "requires": { 3087 | "deep-is": "~0.1.3", 3088 | "fast-levenshtein": "~2.0.4", 3089 | "levn": "~0.3.0", 3090 | "prelude-ls": "~1.1.2", 3091 | "type-check": "~0.3.2", 3092 | "wordwrap": "~1.0.0" 3093 | } 3094 | }, 3095 | "prelude-ls": { 3096 | "version": "1.1.2", 3097 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 3098 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 3099 | "dev": true 3100 | }, 3101 | "source-map": { 3102 | "version": "0.2.0", 3103 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.2.0.tgz", 3104 | "integrity": "sha1-2rc/vPwrqBm03gO9b26qSBZLP50=", 3105 | "dev": true, 3106 | "optional": true, 3107 | "requires": { 3108 | "amdefine": ">=0.0.4" 3109 | } 3110 | }, 3111 | "supports-color": { 3112 | "version": "3.2.3", 3113 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", 3114 | "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", 3115 | "dev": true, 3116 | "requires": { 3117 | "has-flag": "^1.0.0" 3118 | } 3119 | }, 3120 | "type-check": { 3121 | "version": "0.3.2", 3122 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 3123 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 3124 | "dev": true, 3125 | "requires": { 3126 | "prelude-ls": "~1.1.2" 3127 | } 3128 | }, 3129 | "which": { 3130 | "version": "1.3.0", 3131 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 3132 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 3133 | "dev": true, 3134 | "requires": { 3135 | "isexe": "^2.0.0" 3136 | } 3137 | }, 3138 | "wordwrap": { 3139 | "version": "1.0.0", 3140 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 3141 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 3142 | "dev": true 3143 | } 3144 | } 3145 | }, 3146 | "jasmine": { 3147 | "version": "3.7.0", 3148 | "resolved": "https://registry.npmjs.org/jasmine/-/jasmine-3.7.0.tgz", 3149 | "integrity": "sha512-wlzGQ+cIFzMEsI+wDqmOwvnjTvolLFwlcpYLCqSPPH0prOQaW3P+IzMhHYn934l1imNvw07oCyX+vGUv3wmtSQ==", 3150 | "dev": true, 3151 | "requires": { 3152 | "glob": "^7.1.6", 3153 | "jasmine-core": "~3.7.0" 3154 | } 3155 | }, 3156 | "jasmine-core": { 3157 | "version": "3.7.1", 3158 | "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-3.7.1.tgz", 3159 | "integrity": "sha512-DH3oYDS/AUvvr22+xUBW62m1Xoy7tUlY1tsxKEJvl5JeJ7q8zd1K5bUwiOxdH+erj6l2vAMM3hV25Xs9/WrmuQ==", 3160 | "dev": true 3161 | }, 3162 | "js-tokens": { 3163 | "version": "4.0.0", 3164 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 3165 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 3166 | "dev": true 3167 | }, 3168 | "js-yaml": { 3169 | "version": "3.14.0", 3170 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 3171 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 3172 | "dev": true, 3173 | "requires": { 3174 | "argparse": "^1.0.7", 3175 | "esprima": "^4.0.0" 3176 | } 3177 | }, 3178 | "jsbn": { 3179 | "version": "0.1.1", 3180 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 3181 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" 3182 | }, 3183 | "json-schema": { 3184 | "version": "0.2.3", 3185 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 3186 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" 3187 | }, 3188 | "json-schema-traverse": { 3189 | "version": "1.0.0", 3190 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 3191 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 3192 | "dev": true 3193 | }, 3194 | "json-stable-stringify-without-jsonify": { 3195 | "version": "1.0.1", 3196 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 3197 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 3198 | "dev": true 3199 | }, 3200 | "json-stringify-safe": { 3201 | "version": "5.0.1", 3202 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 3203 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" 3204 | }, 3205 | "jsprim": { 3206 | "version": "1.4.1", 3207 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 3208 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 3209 | "requires": { 3210 | "assert-plus": "1.0.0", 3211 | "extsprintf": "1.3.0", 3212 | "json-schema": "0.2.3", 3213 | "verror": "1.10.0" 3214 | } 3215 | }, 3216 | "lcov-parse": { 3217 | "version": "1.0.0", 3218 | "resolved": "https://registry.npmjs.org/lcov-parse/-/lcov-parse-1.0.0.tgz", 3219 | "integrity": "sha1-6w1GtUER68VhrLTECO+TY73I9+A=", 3220 | "dev": true 3221 | }, 3222 | "levn": { 3223 | "version": "0.4.1", 3224 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 3225 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 3226 | "dev": true, 3227 | "requires": { 3228 | "prelude-ls": "^1.2.1", 3229 | "type-check": "~0.4.0" 3230 | } 3231 | }, 3232 | "lodash": { 3233 | "version": "4.17.21", 3234 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 3235 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 3236 | }, 3237 | "lodash.find": { 3238 | "version": "4.6.0", 3239 | "resolved": "https://registry.npmjs.org/lodash.find/-/lodash.find-4.6.0.tgz", 3240 | "integrity": "sha1-ywcE1Hq3F4n/oN6Ll92Sb7iLE7E=" 3241 | }, 3242 | "lodash.max": { 3243 | "version": "4.0.1", 3244 | "resolved": "https://registry.npmjs.org/lodash.max/-/lodash.max-4.0.1.tgz", 3245 | "integrity": "sha1-hzVWbGGLNan3YFILSHrnllivE2o=" 3246 | }, 3247 | "lodash.merge": { 3248 | "version": "4.6.2", 3249 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 3250 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==" 3251 | }, 3252 | "lodash.padstart": { 3253 | "version": "4.6.1", 3254 | "resolved": "https://registry.npmjs.org/lodash.padstart/-/lodash.padstart-4.6.1.tgz", 3255 | "integrity": "sha1-0uPuv/DZ05rVD1y9G1KnvOa7YRs=" 3256 | }, 3257 | "lodash.repeat": { 3258 | "version": "4.1.0", 3259 | "resolved": "https://registry.npmjs.org/lodash.repeat/-/lodash.repeat-4.1.0.tgz", 3260 | "integrity": "sha1-/H3oEx2MisB+S0n3T/6CnR8r7EQ=" 3261 | }, 3262 | "log-driver": { 3263 | "version": "1.2.7", 3264 | "resolved": "https://registry.npmjs.org/log-driver/-/log-driver-1.2.7.tgz", 3265 | "integrity": "sha512-U7KCmLdqsGHBLeWqYlFA0V0Sl6P08EE1ZrmA9cxjUE0WVqT9qnyVDPz1kzpFEP0jdJuFnasWIfSd7fsaNXkpbg==", 3266 | "dev": true 3267 | }, 3268 | "mime-db": { 3269 | "version": "1.43.0", 3270 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.43.0.tgz", 3271 | "integrity": "sha512-+5dsGEEovYbT8UY9yD7eE4XTc4UwJ1jBYlgaQQF38ENsKR3wj/8q8RFZrF9WIZpB2V1ArTVFUva8sAul1NzRzQ==" 3272 | }, 3273 | "mime-types": { 3274 | "version": "2.1.26", 3275 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.26.tgz", 3276 | "integrity": "sha512-01paPWYgLrkqAyrlDorC1uDwl2p3qZT7yl806vW7DvDoxwXi46jsjFbg+WdwotBIk6/MbEhO/dh5aZ5sNj/dWQ==", 3277 | "requires": { 3278 | "mime-db": "1.43.0" 3279 | } 3280 | }, 3281 | "minimatch": { 3282 | "version": "3.0.4", 3283 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 3284 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 3285 | "dev": true, 3286 | "requires": { 3287 | "brace-expansion": "^1.1.7" 3288 | } 3289 | }, 3290 | "minimist": { 3291 | "version": "1.2.5", 3292 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 3293 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 3294 | "dev": true 3295 | }, 3296 | "mockery": { 3297 | "version": "2.1.0", 3298 | "resolved": "https://registry.npmjs.org/mockery/-/mockery-2.1.0.tgz", 3299 | "integrity": "sha512-9VkOmxKlWXoDO/h1jDZaS4lH33aWfRiJiNT/tKj+8OGzrcFDLo8d0syGdbsc3Bc4GvRXPb+NMMvojotmuGJTvA==", 3300 | "dev": true 3301 | }, 3302 | "ms": { 3303 | "version": "2.1.2", 3304 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3305 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3306 | "dev": true 3307 | }, 3308 | "natural-compare": { 3309 | "version": "1.4.0", 3310 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3311 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 3312 | "dev": true 3313 | }, 3314 | "neo-async": { 3315 | "version": "2.6.1", 3316 | "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.1.tgz", 3317 | "integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==", 3318 | "dev": true 3319 | }, 3320 | "oauth-sign": { 3321 | "version": "0.9.0", 3322 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 3323 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==" 3324 | }, 3325 | "once": { 3326 | "version": "1.4.0", 3327 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3328 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 3329 | "dev": true, 3330 | "requires": { 3331 | "wrappy": "1" 3332 | } 3333 | }, 3334 | "optionator": { 3335 | "version": "0.9.1", 3336 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 3337 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 3338 | "dev": true, 3339 | "requires": { 3340 | "deep-is": "^0.1.3", 3341 | "fast-levenshtein": "^2.0.6", 3342 | "levn": "^0.4.1", 3343 | "prelude-ls": "^1.2.1", 3344 | "type-check": "^0.4.0", 3345 | "word-wrap": "^1.2.3" 3346 | } 3347 | }, 3348 | "parent-module": { 3349 | "version": "1.0.1", 3350 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3351 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3352 | "dev": true, 3353 | "requires": { 3354 | "callsites": "^3.0.0" 3355 | } 3356 | }, 3357 | "path-is-absolute": { 3358 | "version": "1.0.1", 3359 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3360 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 3361 | "dev": true 3362 | }, 3363 | "path-key": { 3364 | "version": "3.1.1", 3365 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3366 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3367 | "dev": true 3368 | }, 3369 | "performance-now": { 3370 | "version": "2.1.0", 3371 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 3372 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" 3373 | }, 3374 | "prelude-ls": { 3375 | "version": "1.2.1", 3376 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3377 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3378 | "dev": true 3379 | }, 3380 | "progress": { 3381 | "version": "2.0.3", 3382 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 3383 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 3384 | "dev": true 3385 | }, 3386 | "psl": { 3387 | "version": "1.1.29", 3388 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz", 3389 | "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==" 3390 | }, 3391 | "qs": { 3392 | "version": "6.5.2", 3393 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 3394 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 3395 | }, 3396 | "regexpp": { 3397 | "version": "3.1.0", 3398 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 3399 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 3400 | "dev": true 3401 | }, 3402 | "request": { 3403 | "version": "2.88.2", 3404 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 3405 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 3406 | "requires": { 3407 | "aws-sign2": "~0.7.0", 3408 | "aws4": "^1.8.0", 3409 | "caseless": "~0.12.0", 3410 | "combined-stream": "~1.0.6", 3411 | "extend": "~3.0.2", 3412 | "forever-agent": "~0.6.1", 3413 | "form-data": "~2.3.2", 3414 | "har-validator": "~5.1.3", 3415 | "http-signature": "~1.2.0", 3416 | "is-typedarray": "~1.0.0", 3417 | "isstream": "~0.1.2", 3418 | "json-stringify-safe": "~5.0.1", 3419 | "mime-types": "~2.1.19", 3420 | "oauth-sign": "~0.9.0", 3421 | "performance-now": "^2.1.0", 3422 | "qs": "~6.5.2", 3423 | "safe-buffer": "^5.1.2", 3424 | "tough-cookie": "~2.5.0", 3425 | "tunnel-agent": "^0.6.0", 3426 | "uuid": "^3.3.2" 3427 | } 3428 | }, 3429 | "request-promise": { 3430 | "version": "4.2.6", 3431 | "resolved": "https://registry.npmjs.org/request-promise/-/request-promise-4.2.6.tgz", 3432 | "integrity": "sha512-HCHI3DJJUakkOr8fNoCc73E5nU5bqITjOYFMDrKHYOXWXrgD/SBaC7LjwuPymUprRyuF06UK7hd/lMHkmUXglQ==", 3433 | "requires": { 3434 | "bluebird": "^3.5.0", 3435 | "request-promise-core": "1.1.4", 3436 | "stealthy-require": "^1.1.1", 3437 | "tough-cookie": "^2.3.3" 3438 | } 3439 | }, 3440 | "request-promise-core": { 3441 | "version": "1.1.4", 3442 | "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.4.tgz", 3443 | "integrity": "sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw==", 3444 | "requires": { 3445 | "lodash": "^4.17.19" 3446 | } 3447 | }, 3448 | "require-from-string": { 3449 | "version": "2.0.2", 3450 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 3451 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 3452 | "dev": true 3453 | }, 3454 | "resolve": { 3455 | "version": "1.1.7", 3456 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", 3457 | "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", 3458 | "dev": true 3459 | }, 3460 | "resolve-from": { 3461 | "version": "4.0.0", 3462 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3463 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3464 | "dev": true 3465 | }, 3466 | "rimraf": { 3467 | "version": "3.0.2", 3468 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3469 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3470 | "dev": true, 3471 | "requires": { 3472 | "glob": "^7.1.3" 3473 | } 3474 | }, 3475 | "safe-buffer": { 3476 | "version": "5.2.0", 3477 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", 3478 | "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==" 3479 | }, 3480 | "safer-buffer": { 3481 | "version": "2.1.2", 3482 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 3483 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 3484 | }, 3485 | "semver": { 3486 | "version": "7.3.2", 3487 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz", 3488 | "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==", 3489 | "dev": true 3490 | }, 3491 | "shebang-command": { 3492 | "version": "2.0.0", 3493 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3494 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3495 | "dev": true, 3496 | "requires": { 3497 | "shebang-regex": "^3.0.0" 3498 | } 3499 | }, 3500 | "shebang-regex": { 3501 | "version": "3.0.0", 3502 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3503 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3504 | "dev": true 3505 | }, 3506 | "slice-ansi": { 3507 | "version": "4.0.0", 3508 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 3509 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 3510 | "dev": true, 3511 | "requires": { 3512 | "ansi-styles": "^4.0.0", 3513 | "astral-regex": "^2.0.0", 3514 | "is-fullwidth-code-point": "^3.0.0" 3515 | } 3516 | }, 3517 | "socks5-client": { 3518 | "version": "1.2.6", 3519 | "resolved": "https://registry.npmjs.org/socks5-client/-/socks5-client-1.2.6.tgz", 3520 | "integrity": "sha512-6ly0ZYGQaX8vBZvnRnRKT5yixfFEuQVxvYL5UGb7EFarP2d1yoWRJRBVfLKkBK5nOzX862EhhzOYwgZxRARwlQ==", 3521 | "requires": { 3522 | "ip-address": "~5.8.0" 3523 | } 3524 | }, 3525 | "socks5-https-client": { 3526 | "version": "1.2.1", 3527 | "resolved": "https://registry.npmjs.org/socks5-https-client/-/socks5-https-client-1.2.1.tgz", 3528 | "integrity": "sha512-FbZ/X/2Xq3DAMhuRA4bnN0jy1QxaPTVPLFvyv6CEj0QDKSTdWp9yRxo1JhqXmWKhPQeJyUMajHJB2UjT43pFcw==", 3529 | "requires": { 3530 | "socks5-client": "~1.2.3" 3531 | } 3532 | }, 3533 | "source-map": { 3534 | "version": "0.6.1", 3535 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3536 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3537 | "dev": true 3538 | }, 3539 | "sprintf-js": { 3540 | "version": "1.0.3", 3541 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3542 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 3543 | "dev": true 3544 | }, 3545 | "sshpk": { 3546 | "version": "1.16.1", 3547 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 3548 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 3549 | "requires": { 3550 | "asn1": "~0.2.3", 3551 | "assert-plus": "^1.0.0", 3552 | "bcrypt-pbkdf": "^1.0.0", 3553 | "dashdash": "^1.12.0", 3554 | "ecc-jsbn": "~0.1.1", 3555 | "getpass": "^0.1.1", 3556 | "jsbn": "~0.1.0", 3557 | "safer-buffer": "^2.0.2", 3558 | "tweetnacl": "~0.14.0" 3559 | } 3560 | }, 3561 | "stealthy-require": { 3562 | "version": "1.1.1", 3563 | "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz", 3564 | "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=" 3565 | }, 3566 | "string-width": { 3567 | "version": "4.2.2", 3568 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 3569 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 3570 | "dev": true, 3571 | "requires": { 3572 | "emoji-regex": "^8.0.0", 3573 | "is-fullwidth-code-point": "^3.0.0", 3574 | "strip-ansi": "^6.0.0" 3575 | } 3576 | }, 3577 | "strip-ansi": { 3578 | "version": "6.0.0", 3579 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 3580 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 3581 | "dev": true, 3582 | "requires": { 3583 | "ansi-regex": "^5.0.0" 3584 | } 3585 | }, 3586 | "strip-json-comments": { 3587 | "version": "3.1.1", 3588 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3589 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3590 | "dev": true 3591 | }, 3592 | "supports-color": { 3593 | "version": "5.5.0", 3594 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3595 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3596 | "dev": true, 3597 | "requires": { 3598 | "has-flag": "^3.0.0" 3599 | } 3600 | }, 3601 | "table": { 3602 | "version": "6.0.7", 3603 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz", 3604 | "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==", 3605 | "dev": true, 3606 | "requires": { 3607 | "ajv": "^7.0.2", 3608 | "lodash": "^4.17.20", 3609 | "slice-ansi": "^4.0.0", 3610 | "string-width": "^4.2.0" 3611 | }, 3612 | "dependencies": { 3613 | "ajv": { 3614 | "version": "7.2.3", 3615 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.2.3.tgz", 3616 | "integrity": "sha512-idv5WZvKVXDqKralOImQgPM9v6WOdLNa0IY3B3doOjw/YxRGT8I+allIJ6kd7Uaj+SF1xZUSU+nPM5aDNBVtnw==", 3617 | "dev": true, 3618 | "requires": { 3619 | "fast-deep-equal": "^3.1.1", 3620 | "json-schema-traverse": "^1.0.0", 3621 | "require-from-string": "^2.0.2", 3622 | "uri-js": "^4.2.2" 3623 | } 3624 | } 3625 | } 3626 | }, 3627 | "text-table": { 3628 | "version": "0.2.0", 3629 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3630 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 3631 | "dev": true 3632 | }, 3633 | "tough-cookie": { 3634 | "version": "2.5.0", 3635 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 3636 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 3637 | "requires": { 3638 | "psl": "^1.1.28", 3639 | "punycode": "^2.1.1" 3640 | }, 3641 | "dependencies": { 3642 | "punycode": { 3643 | "version": "2.1.1", 3644 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 3645 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 3646 | } 3647 | } 3648 | }, 3649 | "tunnel-agent": { 3650 | "version": "0.6.0", 3651 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 3652 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 3653 | "requires": { 3654 | "safe-buffer": "^5.0.1" 3655 | } 3656 | }, 3657 | "tweetnacl": { 3658 | "version": "0.14.5", 3659 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 3660 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" 3661 | }, 3662 | "type-check": { 3663 | "version": "0.4.0", 3664 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3665 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3666 | "dev": true, 3667 | "requires": { 3668 | "prelude-ls": "^1.2.1" 3669 | } 3670 | }, 3671 | "type-fest": { 3672 | "version": "0.20.2", 3673 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3674 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3675 | "dev": true 3676 | }, 3677 | "uglify-js": { 3678 | "version": "3.9.1", 3679 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.9.1.tgz", 3680 | "integrity": "sha512-JUPoL1jHsc9fOjVFHdQIhqEEJsQvfKDjlubcCilu8U26uZ73qOg8VsN8O1jbuei44ZPlwL7kmbAdM4tzaUvqnA==", 3681 | "dev": true, 3682 | "optional": true, 3683 | "requires": { 3684 | "commander": "~2.20.3" 3685 | } 3686 | }, 3687 | "uri-js": { 3688 | "version": "4.2.2", 3689 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 3690 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 3691 | "requires": { 3692 | "punycode": "^2.1.0" 3693 | }, 3694 | "dependencies": { 3695 | "punycode": { 3696 | "version": "2.1.1", 3697 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 3698 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 3699 | } 3700 | } 3701 | }, 3702 | "uuid": { 3703 | "version": "3.4.0", 3704 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 3705 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" 3706 | }, 3707 | "v8-compile-cache": { 3708 | "version": "2.1.1", 3709 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz", 3710 | "integrity": "sha512-8OQ9CL+VWyt3JStj7HX7/ciTL2V3Rl1Wf5OL+SNTm0yK1KvtReVulksyeRnCANHHuUxHlQig+JJDlUhBt1NQDQ==", 3711 | "dev": true 3712 | }, 3713 | "verror": { 3714 | "version": "1.10.0", 3715 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 3716 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 3717 | "requires": { 3718 | "assert-plus": "^1.0.0", 3719 | "core-util-is": "1.0.2", 3720 | "extsprintf": "^1.2.0" 3721 | } 3722 | }, 3723 | "which": { 3724 | "version": "2.0.2", 3725 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3726 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3727 | "dev": true, 3728 | "requires": { 3729 | "isexe": "^2.0.0" 3730 | } 3731 | }, 3732 | "word-wrap": { 3733 | "version": "1.2.3", 3734 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3735 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3736 | "dev": true 3737 | }, 3738 | "wordwrap": { 3739 | "version": "1.0.0", 3740 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 3741 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 3742 | "dev": true 3743 | }, 3744 | "wrappy": { 3745 | "version": "1.0.2", 3746 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3747 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3748 | "dev": true 3749 | } 3750 | } 3751 | } 3752 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "slimbot", 3 | "version": "5.1.0", 4 | "description": "Simple and minimal Telegram Bot API for Node.js. No frills.", 5 | "author": "Edison Chee ", 6 | "repository": { 7 | "type": "git", 8 | "url": "git+https://github.com/edisonchee/slimbot.git" 9 | }, 10 | "main": "./src/slimbot.js", 11 | "keywords": [ 12 | "telegram", 13 | "bot", 14 | "api", 15 | "node", 16 | "nodejs" 17 | ], 18 | "engines": { 19 | "node": ">=10.16.0" 20 | }, 21 | "license": "MIT", 22 | "scripts": { 23 | "start": "pm2 start src/index.js --watch", 24 | "test": "istanbul cover jasmine --captureExceptions spec/core/*.js && cat ./coverage/lcov.info | ./node_modules/coveralls/bin/coveralls.js && rm -rf ./coverage" 25 | }, 26 | "dependencies": { 27 | "bluebird": "^3.7.2", 28 | "eventemitter3": "^4.0.7", 29 | "request": "^2.88.2", 30 | "request-promise": "^4.2.6", 31 | "socks5-https-client": "^1.2.1" 32 | }, 33 | "devDependencies": { 34 | "coveralls": "^3.1.0", 35 | "eslint": "^7.22.0", 36 | "handlebars": ">=4.7.7", 37 | "istanbul": "^0.4.5", 38 | "jasmine": "^3.7.0", 39 | "mockery": "^2.1.0" 40 | }, 41 | "bugs": { 42 | "url": "https://github.com/edisonchee/slimbot/issues" 43 | }, 44 | "homepage": "https://github.com/edisonchee/slimbot#readme" 45 | } 46 | -------------------------------------------------------------------------------- /spec/core/telebotSpec.js: -------------------------------------------------------------------------------- 1 | const Bluebird = require('bluebird'); 2 | const mockery = require('mockery'); 3 | let Slimbot; 4 | let slimbot; 5 | 6 | describe('Slimbot', () => { 7 | 8 | beforeEach(() => { 9 | mockery.enable({ 10 | warnOnReplace: false, 11 | warnOnUnregistered: false, 12 | useCleanCache: true 13 | }); 14 | 15 | mockery.registerMock('request-promise', options => { 16 | let response = { 17 | statusCode: 200, 18 | body: '{ "result": ["test"] }', 19 | options: options 20 | }; 21 | return Bluebird.resolve(response); 22 | }); 23 | 24 | Slimbot = require('../../src/slimbot'); 25 | slimbot = new Slimbot('token'); 26 | }); 27 | 28 | afterEach(() => { 29 | mockery.disable(); 30 | mockery.deregisterAll(); 31 | }) 32 | 33 | describe('Core', () => { 34 | describe('instantiating', () => { 35 | it('should throw an error if token is not provided', () => { 36 | expect(() => { const bot = new Slimbot(); }).toThrow(); 37 | }); 38 | }); 39 | 40 | describe('_request', () => { 41 | it('should throw an error if no method provided', done => { 42 | expect(() => { slimbot._request(); }).toThrow(); 43 | expect(() => { slimbot._request(['getMe']); }).toThrow(); 44 | done(); 45 | }); 46 | 47 | it('should return a promise', done => { 48 | expect(typeof slimbot._request('getUpdates').then === 'function').toEqual(true); 49 | done(); 50 | }); 51 | }); 52 | 53 | describe('_processUpdates', () => { 54 | let updates; 55 | let flag; 56 | let payload; 57 | beforeEach(() => { 58 | updates = { 59 | result: [ 60 | { update_id: 1000, message: 'message' }, 61 | { update_id: 1001, edited_message: 'edited_message' }, 62 | { update_id: 1002, channel_post: 'channel_post' }, 63 | { update_id: 1003, edited_channel_post: 'edited_channel_post' }, 64 | { update_id: 1004, callback_query: 'callback_query' }, 65 | { update_id: 1005, inline_query: 'inline_query' }, 66 | { update_id: 1006, chosen_inline_result: 'chosen_inline_result' }, 67 | { update_id: 1007, shipping_query: 'shipping_query' }, 68 | { update_id: 1008, pre_checkout_query: 'pre_checkout_query' }, 69 | { update_id: 1009, poll: 'poll' }, 70 | { update_id: 1010, poll_answer: 'poll_answer' } 71 | ] 72 | }; 73 | }); 74 | 75 | it('should take the id of last update increased by 1 as offset', () => { 76 | slimbot._processUpdates(updates); 77 | expect(slimbot._offset).toEqual(1011); 78 | }); 79 | 80 | it('should emit "message" if update is of type "message"', () => { 81 | slimbot.on('message', data => { 82 | if (data !== undefined) { 83 | flag = true; 84 | payload = data; 85 | }; 86 | }); 87 | slimbot._processUpdates(updates); 88 | expect(flag).toEqual(true); 89 | expect(payload).toEqual('message'); 90 | }); 91 | 92 | it('should emit "edited_message" if update is of type "edited_message"', () => { 93 | slimbot.on('edited_message', data => { 94 | if (data !== undefined) { 95 | flag = true; 96 | payload = data; 97 | }; 98 | }); 99 | slimbot._processUpdates(updates); 100 | expect(flag).toEqual(true); 101 | expect(payload).toEqual('edited_message'); 102 | }); 103 | 104 | it('should emit "channel_post" if update is of type "channel_post"', () => { 105 | slimbot.on('channel_post', data => { 106 | if (data !== undefined) { 107 | flag = true; 108 | payload = data; 109 | }; 110 | }); 111 | slimbot._processUpdates(updates); 112 | expect(flag).toEqual(true); 113 | expect(payload).toEqual('channel_post'); 114 | }); 115 | 116 | it('should emit "edited_channel_post" if update is of type "edited_channel_post"', () => { 117 | slimbot.on('edited_channel_post', data => { 118 | if (data !== undefined) { 119 | flag = true; 120 | payload = data; 121 | }; 122 | }); 123 | slimbot._processUpdates(updates); 124 | expect(flag).toEqual(true); 125 | expect(payload).toEqual('edited_channel_post'); 126 | }); 127 | 128 | it('should emit "callback_query" if update is of type "callback_query"', () => { 129 | slimbot.on('callback_query', data => { 130 | if (data !== undefined) { 131 | flag = true; 132 | payload = data; 133 | }; 134 | }); 135 | slimbot._processUpdates(updates); 136 | expect(flag).toEqual(true); 137 | expect(payload).toEqual('callback_query'); 138 | }); 139 | 140 | it('should emit "inline_query" if update is of type "inline_query"', () => { 141 | slimbot.on('inline_query', data => { 142 | if (data !== undefined) { 143 | flag = true; 144 | payload = data; 145 | }; 146 | }); 147 | slimbot._processUpdates(updates); 148 | expect(flag).toEqual(true); 149 | expect(payload).toEqual('inline_query'); 150 | }); 151 | 152 | it('should emit "chosen_inline_result" if update is of type "chosen_inline_result"', () => { 153 | slimbot.on('chosen_inline_result', data => { 154 | if (data !== undefined) { 155 | flag = true; 156 | payload = data; 157 | }; 158 | }); 159 | slimbot._processUpdates(updates); 160 | expect(flag).toEqual(true); 161 | expect(payload).toEqual('chosen_inline_result'); 162 | }); 163 | 164 | it('should emit "shipping_query" if update is of type "shipping_query"', () => { 165 | slimbot.on('shipping_query', data => { 166 | if (data !== undefined) { 167 | flag = true; 168 | payload = data; 169 | }; 170 | }); 171 | slimbot._processUpdates(updates); 172 | expect(flag).toEqual(true); 173 | expect(payload).toEqual('shipping_query'); 174 | }); 175 | 176 | it('should emit "pre_checkout_query" if update is of type "pre_checkout_query"', () => { 177 | slimbot.on('pre_checkout_query', data => { 178 | if (data !== undefined) { 179 | flag = true; 180 | payload = data; 181 | }; 182 | }); 183 | slimbot._processUpdates(updates); 184 | expect(flag).toEqual(true); 185 | expect(payload).toEqual('pre_checkout_query'); 186 | }); 187 | 188 | it('should emit "poll" if update is of type "poll"', () => { 189 | slimbot.on('poll', data => { 190 | if (data !== undefined) { 191 | flag = true; 192 | payload = data; 193 | }; 194 | }); 195 | slimbot._processUpdates(updates); 196 | expect(flag).toEqual(true); 197 | expect(payload).toEqual('poll'); 198 | }); 199 | 200 | it('should emit "poll_answer" if update is of type "poll_answer"', () => { 201 | slimbot.on('poll_answer', data => { 202 | if (data !== undefined) { 203 | flag = true; 204 | payload = data; 205 | }; 206 | }); 207 | slimbot._processUpdates(updates); 208 | expect(flag).toEqual(true); 209 | expect(payload).toEqual('poll_answer'); 210 | }); 211 | 212 | }); 213 | }); 214 | 215 | // Slimbot API methods 216 | 217 | describe('startPolling', () => { 218 | it('should call slimbot._request', () => { 219 | spyOn(slimbot, '_request').and.returnValue(Bluebird.resolve()); 220 | slimbot.startPolling(); 221 | expect(slimbot._request).toHaveBeenCalled(); 222 | }); 223 | 224 | it('should call slimbot._processUpdates', done => { 225 | spyOn(slimbot, '_request').and.returnValue(Bluebird.resolve({})); 226 | spyOn(slimbot, '_processUpdates'); 227 | slimbot.startPolling().then(() => { 228 | expect(slimbot._processUpdates).toHaveBeenCalled(); 229 | done(); 230 | }); 231 | }); 232 | 233 | it('should store timeout object', done => { 234 | spyOn(slimbot, '_request').and.returnValue(Bluebird.resolve({})); 235 | spyOn(slimbot, '_processUpdates'); 236 | slimbot.startPolling().then(() => { 237 | expect(slimbot._processUpdates).toHaveBeenCalled(); 238 | expect(slimbot._timeout).not.toBe(undefined); 239 | expect(typeof slimbot._timeout.refresh).toBe('function'); 240 | done(); 241 | }); 242 | }); 243 | }); 244 | 245 | describe('stopPolling', () => { 246 | it('should call slimbot.stopPolling', () => { 247 | spyOn(slimbot, 'stopPolling'); 248 | slimbot.stopPolling(); 249 | expect(slimbot.stopPolling).toHaveBeenCalled(); 250 | expect(slimbot._timeout).toBe(undefined); 251 | }); 252 | }); 253 | }); -------------------------------------------------------------------------------- /spec/support/jasmine.json: -------------------------------------------------------------------------------- 1 | { 2 | "spec_dir": "spec", 3 | "spec_files": [ 4 | "**/*[sS]pec.js" 5 | ], 6 | "helpers": [ 7 | "helpers/**/*.js" 8 | ], 9 | "stopSpecOnExpectationFailure": false, 10 | "random": false 11 | } 12 | -------------------------------------------------------------------------------- /src/slimbot.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const EventEmitter = require('eventemitter3'); 4 | const Telegram = require('./telegram'); 5 | 6 | class Slimbot extends Telegram(EventEmitter) { 7 | constructor(token, proxy) { 8 | super(token, proxy); 9 | this._offset = undefined; 10 | this._timeout = undefined; 11 | } 12 | 13 | _processUpdates(updates) { 14 | updates.result.forEach(update => { 15 | this._offset = update.update_id + 1; 16 | let message = update.message; 17 | let editedMessage = update.edited_message; 18 | let channelPost = update.channel_post; 19 | let editedChannelPost = update.edited_channel_post; 20 | let inlineQuery = update.inline_query; 21 | let chosenInlineResult = update.chosen_inline_result; 22 | let callbackQuery = update.callback_query; 23 | let shippingQuery = update.shipping_query; 24 | let preCheckoutQuery = update.pre_checkout_query; 25 | let pollQuery = update.poll; 26 | let pollAnswerQuery = update.poll_answer; 27 | let myChatMember = update.my_chat_member; 28 | let chatMember = update.chat_member; 29 | 30 | if (message) { 31 | this.emit('message', message); 32 | } else if (editedMessage) { 33 | this.emit('edited_message', editedMessage); 34 | } else if (channelPost) { 35 | this.emit('channel_post', channelPost); 36 | } else if (editedChannelPost) { 37 | this.emit('edited_channel_post', editedChannelPost); 38 | } else if (callbackQuery) { 39 | this.emit('callback_query', callbackQuery); 40 | } else if (inlineQuery) { 41 | this.emit('inline_query', inlineQuery); 42 | } else if (chosenInlineResult) { 43 | this.emit('chosen_inline_result', chosenInlineResult); 44 | } else if (shippingQuery) { 45 | this.emit('shipping_query', shippingQuery); 46 | } else if (preCheckoutQuery) { 47 | this.emit('pre_checkout_query', preCheckoutQuery) 48 | } else if (pollQuery) { 49 | this.emit('poll', pollQuery) 50 | } else if (pollAnswerQuery) { 51 | this.emit('poll_answer', pollAnswerQuery) 52 | } else if (myChatMember) { 53 | this.emit('my_chat_member', myChatMember) 54 | } else if (chatMember) { 55 | this.emit('chat_member', chatMember) 56 | } 57 | }); 58 | } 59 | 60 | startPolling(callback) { 61 | return super.getUpdates(this._offset) 62 | .then(updates => { 63 | if (updates !== undefined) { 64 | this._processUpdates(updates); 65 | } 66 | return null; 67 | }) 68 | .catch(error => { 69 | if (callback) { 70 | callback(error); 71 | } 72 | else { 73 | throw error; 74 | } 75 | }) 76 | .finally(() => { 77 | if (this._timeout && typeof this._timeout.refresh === 'function') { 78 | this._timeout.refresh(); 79 | } else { 80 | this._timeout = setTimeout(() => this.startPolling(callback), 100); 81 | } 82 | }); 83 | } 84 | 85 | stopPolling() { 86 | clearTimeout(this._timeout); 87 | } 88 | } 89 | 90 | module.exports = Slimbot; 91 | -------------------------------------------------------------------------------- /src/telegram.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | const EventEmitter = require('eventemitter3'); 3 | const Request = require('request-promise'); 4 | const Agent = require('socks5-https-client/lib/Agent'); 5 | const Stream = require('stream'); 6 | const Path = require('path'); 7 | 8 | const Telegram = EventEmitter => class extends EventEmitter { 9 | constructor(token, proxy) { 10 | super(); 11 | if (token === undefined) { 12 | throw new Error('Please provide a Telegram bot token when instantiating'); 13 | } 14 | this._token = token; 15 | if(proxy !== undefined){ 16 | this._useProxy = true; 17 | this._proxy = proxy; 18 | } 19 | } 20 | 21 | _request(method, params, formData) { 22 | if (arguments.length === 0 || typeof arguments[0] !== 'string') { 23 | throw new Error('Please provide method as a string'); 24 | } 25 | 26 | // the 2nd, 3rd or 4th argument could be a callback 27 | let callback; 28 | if (typeof arguments[3] == 'function') { 29 | callback = arguments[3]; 30 | } else if (typeof arguments[2] == 'function') { 31 | callback = arguments[2]; 32 | formData = null; 33 | } else if (typeof arguments[1] == 'function') { 34 | callback = arguments[1]; 35 | params = null; 36 | } 37 | 38 | let options = { 39 | uri: 'https://api.telegram.org/bot' + this._token + '/' + method, 40 | qs: params, 41 | formData: formData, 42 | simple: false, 43 | resolveWithFullResponse: true, 44 | forever: true 45 | }; 46 | 47 | if(this._useProxy){ 48 | options.strictSSL = true; 49 | options.agentClass = Agent; 50 | options.agentOptions = { 51 | socksHost: this._proxy.socksHost, 52 | socksPort: this._proxy.socksPort 53 | }; 54 | if(this._proxy.socksUsername && this._proxy.socksPassword){ 55 | options.agentOptions.socksUsername = this._proxy.socksUsername; 56 | options.agentOptions.socksPassword = this._proxy.socksPassword; 57 | } 58 | } 59 | 60 | return Request(options) 61 | .then(resp => { 62 | if (resp.statusCode !== 200) { 63 | throw new Error(resp.statusCode + ':\n'+ resp.body); 64 | } 65 | 66 | let updates = JSON.parse(resp.body); 67 | 68 | if (updates.ok) { 69 | if (callback) { 70 | callback(null, updates); 71 | } 72 | 73 | return updates; 74 | } 75 | return null; 76 | }) 77 | .catch(error => { 78 | if (callback) { 79 | callback(error); 80 | } 81 | else { 82 | throw error; 83 | } 84 | }); 85 | } 86 | 87 | getMe(callback) { 88 | return this._request('getMe', callback); 89 | } 90 | 91 | getUpdates(offset, callback) { 92 | let params = { 93 | offset: offset, 94 | timeout: 10 95 | }; 96 | 97 | return this._request('getUpdates', params, callback); 98 | } 99 | 100 | setWebhook(url, optionalParams, callback) { 101 | let params = { 102 | url: url 103 | } 104 | 105 | if (typeof optionalParams == 'function') { 106 | callback = optionalParams; 107 | } else { 108 | Object.assign(params, optionalParams); 109 | } 110 | 111 | return this._request('setWebhook', url, params, callback); 112 | } 113 | 114 | deleteWebhook(optionalParams, callback) { 115 | return this._request('deleteWebhook', optionalParams, callback); 116 | } 117 | 118 | getWebhookInfo(callback) { 119 | return this._request('getWebhookInfo', callback); 120 | } 121 | 122 | logOut(callback) { 123 | return this._request('logOut', callback); 124 | } 125 | 126 | close(callback) { 127 | return this._request('close', callback); 128 | } 129 | 130 | sendMessage(chatId, text, optionalParams, callback) { 131 | let params = { 132 | chat_id: chatId, 133 | text: text 134 | }; 135 | 136 | if (typeof optionalParams == 'function') { 137 | callback = optionalParams; 138 | } else { 139 | Object.assign(params, optionalParams, callback); 140 | } 141 | 142 | return this._request('sendMessage', params, callback); 143 | } 144 | 145 | answerCallbackQuery(callbackQueryId, optionalParams, callback) { 146 | let params = { 147 | callback_query_id: callbackQueryId 148 | }; 149 | 150 | if (typeof optionalParams == 'function') { 151 | callback = optionalParams; 152 | } else { 153 | Object.assign(params, optionalParams); 154 | } 155 | 156 | return this._request('answerCallbackQuery', params, callback); 157 | } 158 | 159 | setMyCommands(commands, callback) { 160 | return this._request('setMyCommands', commands, callback); 161 | } 162 | 163 | getMyCommands() { 164 | return this._request('getMyCommands', callback); 165 | } 166 | 167 | editMessageText(chatId, messageId, text, optionalParams, callback) { 168 | let params = { 169 | chat_id: chatId, 170 | message_id: messageId, 171 | text: text 172 | }; 173 | 174 | if (typeof optionalParams == 'function') { 175 | callback = optionalParams; 176 | } else { 177 | Object.assign(params, optionalParams); 178 | } 179 | 180 | return this._request('editMessageText', params, callback); 181 | } 182 | 183 | editInlineMessageText(inlineMessageId, text, optionalParams, callback) { 184 | let params = { 185 | inline_message_id: inlineMessageId, 186 | text: text 187 | }; 188 | 189 | if (typeof optionalParams == 'function') { 190 | callback = optionalParams; 191 | } else { 192 | Object.assign(params, optionalParams); 193 | } 194 | 195 | return this._request('editMessageText', params, callback); 196 | } 197 | 198 | editMessageCaption(chatId, messageId, caption, optionalParams, callback) { 199 | let params = { 200 | chat_id: chatId, 201 | message_id: messageId, 202 | caption: caption 203 | }; 204 | 205 | if (typeof optionalParams == 'function') { 206 | callback = optionalParams; 207 | } else { 208 | Object.assign(params, optionalParams); 209 | } 210 | 211 | return this._request('editMessageCaption', params, callback); 212 | } 213 | 214 | editInlineMessageCaption(inlineMessagId, caption, optionalParams, callback) { 215 | let params = { 216 | inline_message_id: inlineMessageId, 217 | caption: caption 218 | }; 219 | 220 | if (typeof optionalParams == 'function') { 221 | callback = optionalParams; 222 | } else { 223 | Object.assign(params, optionalParams); 224 | } 225 | 226 | return this._request('editMessageCaption', params, callback); 227 | } 228 | 229 | editMessageMedia(chatId, messageId, media, optionalParams, callback) { 230 | let params = { 231 | chat_id: chatId, 232 | message_id: messageId, 233 | media: media 234 | }; 235 | 236 | if (typeof optionalParams == 'function') { 237 | callback = optionalParams; 238 | } else { 239 | Object.assign(params, optionalParams); 240 | } 241 | 242 | return this._request('editMessageMedia', params, callback); 243 | } 244 | 245 | editInlineMessageMedia(inlineMessageId, media, optionalParams, callback) { 246 | let params = { 247 | inline_message_id: inlineMessageId, 248 | media: media 249 | }; 250 | 251 | if (typeof optionalParams == 'function') { 252 | callback = optionalParams; 253 | } else { 254 | Object.assign(params, optionalParams); 255 | } 256 | 257 | return this._request('editMessageMedia', params, callback); 258 | } 259 | 260 | editMessageReplyMarkup(chatId, messageId, replyMarkup, callback) { 261 | let params = { 262 | chat_id: chatId, 263 | message_id: messageId, 264 | reply_markup: replyMarkup 265 | } 266 | 267 | return this._request('editMessageReplyMarkup', params, callback); 268 | } 269 | 270 | editInlineMessageReplyMarkup(inlineMessageId, replyMarkup, callback) { 271 | let params = { 272 | inline_message_id: inlineMessageId, 273 | reply_markup: replyMarkup 274 | } 275 | 276 | return this._request('editMessageReplyMarkup', params, callback); 277 | } 278 | 279 | deleteMessage(chatId, messageId, callback) { 280 | let params = { 281 | chat_id: chatId, 282 | message_id: messageId 283 | } 284 | 285 | return this._request('deleteMessage', params, callback); 286 | } 287 | 288 | answerInlineQuery(inlineQueryId, results, optionalParams, callback) { 289 | let params = { 290 | inline_query_id: inlineQueryId, 291 | results: results 292 | }; 293 | 294 | if (typeof optionalParams == 'function') { 295 | callback = optionalParams; 296 | } else { 297 | Object.assign(params, optionalParams); 298 | } 299 | 300 | return this._request('answerInlineQuery', params, callback); 301 | } 302 | 303 | forwardMessage(chatId, fromChatId, messageId, optionalParams, callback) { 304 | let params = { 305 | chat_id: chatId, 306 | from_chat_id: fromChatId, 307 | message_id: messageId 308 | } 309 | 310 | if (typeof optionalParams == 'function') { 311 | callback = optionalParams; 312 | } else { 313 | Object.assign(params, optionalParams); 314 | } 315 | 316 | return this._request('forwardMessage', params, callback); 317 | } 318 | 319 | copyMessage(chatId, fromChatId, messageId, optionalParams, callback) { 320 | let params = { 321 | chat_id: chatId, 322 | from_chat_id: fromChatId, 323 | message_id: messageId 324 | } 325 | 326 | if (typeof optionalParams == 'function') { 327 | callback = optionalParams; 328 | } else { 329 | Object.assign(params, optionalParams); 330 | } 331 | 332 | return this._request('copyMessage', params, callback); 333 | } 334 | 335 | sendPhoto(chatId, photo, optionalParams, callback) { 336 | let params; 337 | let formData; 338 | 339 | if (isReadableStream(photo)) { 340 | params = { 341 | chat_id: chatId 342 | }; 343 | formData = { 344 | photo: photo 345 | }; 346 | } else { 347 | params = { 348 | chat_id: chatId, 349 | photo: photo 350 | }; 351 | } 352 | 353 | if (typeof optionalParams == 'function') { 354 | callback = optionalParams; 355 | } else { 356 | Object.assign(params, optionalParams); 357 | } 358 | 359 | return this._request('sendPhoto', params, formData, callback); 360 | } 361 | 362 | sendAudio(chatId, audio, optionalParams, callback) { 363 | let params; 364 | let formData; 365 | 366 | if (isReadableStream(audio)) { 367 | params = { 368 | chat_id: chatId 369 | }; 370 | formData = { 371 | audio: audio 372 | }; 373 | } else { 374 | params = { 375 | chat_id: chatId, 376 | audio: audio 377 | }; 378 | } 379 | 380 | if (typeof optionalParams == 'function') { 381 | callback = optionalParams; 382 | } else { 383 | Object.assign(params, optionalParams); 384 | } 385 | 386 | return this._request('sendAudio', params, formData, callback); 387 | } 388 | 389 | sendDocument(chatId, document, optionalParams, callback) { 390 | let params; 391 | let formData; 392 | 393 | if (isReadableStream(document)) { 394 | params = { 395 | chat_id: chatId 396 | }; 397 | formData = { 398 | document: document 399 | }; 400 | } else { 401 | params = { 402 | chat_id: chatId, 403 | document: document 404 | }; 405 | } 406 | 407 | if (typeof optionalParams == 'function') { 408 | callback = optionalParams; 409 | } else { 410 | Object.assign(params, optionalParams); 411 | } 412 | 413 | return this._request('sendDocument', params, formData, callback); 414 | } 415 | 416 | sendAnimation(chatId, animation, optionalParams, callback) { 417 | let params; 418 | let formData; 419 | 420 | if (isReadableStream(animation)) { 421 | params = { 422 | chat_id: chatId 423 | }; 424 | formData = { 425 | animation: animation 426 | }; 427 | } else { 428 | params = { 429 | chat_id: chatId, 430 | animation: animation 431 | }; 432 | } 433 | 434 | if (typeof optionalParams == 'function') { 435 | callback = optionalParams; 436 | } else { 437 | Object.assign(params, optionalParams); 438 | } 439 | 440 | return this._request('sendAnimation', params, formData, callback); 441 | } 442 | 443 | // Polls 444 | 445 | sendPoll(chatId, question, pollOptions, optionalParams, callback) { 446 | let params = { 447 | chat_id: chatId, 448 | question: question, 449 | options: pollOptions 450 | }; 451 | 452 | if (typeof optionalParams == 'function') { 453 | callback = optionalParams; 454 | } else { 455 | Object.assign(params, optionalParams, callback); 456 | } 457 | 458 | return this._request('sendPoll', params, callback); 459 | } 460 | 461 | stopPoll(chatId, messageId, optionalParams, callback) { 462 | let params = { 463 | chat_id: chatId, 464 | message_id: messageId 465 | }; 466 | 467 | if (typeof optionalParams == 'function') { 468 | callback = optionalParams; 469 | } else { 470 | Object.assign(params, optionalParams, callback); 471 | } 472 | 473 | return this._request('stopPoll', params, callback); 474 | } 475 | 476 | // Stickers 477 | 478 | sendSticker(chatId, sticker, optionalParams, callback) { 479 | let params; 480 | let formData; 481 | 482 | if (isReadableStream(sticker)) { 483 | params = { 484 | chat_id: chatId 485 | }; 486 | formData = { 487 | sticker: sticker 488 | }; 489 | } else { 490 | params = { 491 | chat_id: chatId, 492 | sticker: sticker 493 | }; 494 | } 495 | 496 | if (typeof optionalParams == 'function') { 497 | callback = optionalParams; 498 | } else { 499 | Object.assign(params, optionalParams); 500 | } 501 | 502 | return this._request('sendSticker', params, formData, callback); 503 | } 504 | 505 | getStickerSet(name, callback) { 506 | let params = { 507 | name: name 508 | } 509 | 510 | return this._request('getStickerSet', params, callback); 511 | } 512 | 513 | uploadStickerFile(userId, pngFile, callback) { 514 | let params = { 515 | user_id: userId, 516 | }; 517 | 518 | let formData = { 519 | png_sticker: pngFile 520 | }; 521 | 522 | return this._request('uploadStickerFile', params, formData, callback); 523 | } 524 | 525 | createNewStickerSet(userId, name, title, stickerFile, emojis, optionalParams, callback) { 526 | let params; 527 | let formData; 528 | 529 | if (isReadableStream(stickerFile)) { 530 | // stickerFile is a readableStream, check extension 531 | let ext = Path.extname(stickerFile.path); 532 | 533 | if (ext === '.png') { 534 | params = { 535 | user_id: userId, 536 | name: name, 537 | title: title, 538 | emojis: emojis 539 | }; 540 | formData = { 541 | png_sticker: stickerFile 542 | }; 543 | } else if (ext === '.tgs') { 544 | params = { 545 | user_id: userId, 546 | name: name, 547 | title: title, 548 | emojis: emojis 549 | }; 550 | formData = { 551 | tgs_sticker: stickerFile 552 | }; 553 | } 554 | } else { 555 | // stickerFile is a string, either a file_id or HTTP URL 556 | params = { 557 | user_id: userId, 558 | name: name, 559 | title: title, 560 | png_sticker: stickerFile, 561 | emojis: emojis 562 | }; 563 | } 564 | 565 | if (typeof optionalParams == 'function') { 566 | callback = optionalParams; 567 | } else { 568 | Object.assign(params, optionalParams); 569 | } 570 | 571 | return this._request('createNewStickerSet', params, formData, callback); 572 | } 573 | 574 | addStickerToSet(userId, name, stickerFile, emojis, optionalParams, callback) { 575 | let params; 576 | let formData; 577 | 578 | if (isReadableStream(stickerFile)) { 579 | // stickerFile is a readableStream, check extension 580 | let ext = Path.extname(stickerFile.path); 581 | 582 | if (ext === '.png') { 583 | params = { 584 | user_id: userId, 585 | name: name, 586 | emojis: emojis 587 | }; 588 | formData = { 589 | png_sticker: stickerFile 590 | }; 591 | } else if (ext === '.tgs') { 592 | params = { 593 | user_id: userId, 594 | name: name, 595 | emojis: emojis 596 | }; 597 | formData = { 598 | tgs_sticker: stickerFile 599 | }; 600 | } 601 | } else { 602 | // stickerFile is a string, either a file_id or HTTP URL 603 | params = { 604 | user_id: userId, 605 | name: name, 606 | png_sticker: stickerFile, 607 | emojis: emojis 608 | }; 609 | } 610 | 611 | if (typeof optionalParams == 'function') { 612 | callback = optionalParams; 613 | } else { 614 | Object.assign(params, optionalParams); 615 | } 616 | 617 | return this._request('addStickerToSet', params, formData, callback); 618 | } 619 | 620 | setStickerPositionInSet(sticker, position, callback) { 621 | let params = { 622 | sticker: sticker, 623 | position: position 624 | } 625 | 626 | return this._request('setStickerPositionInSet', params, callback); 627 | } 628 | 629 | deleteStickerFromSet(sticker, callback) { 630 | let params = { 631 | sticker: sticker 632 | } 633 | 634 | return this._request('deleteStickerFromSet', params, callback); 635 | } 636 | 637 | setStickerSetThumb(name, userId, thumbnailFile, callback) { 638 | let params; 639 | let formData; 640 | 641 | if (isReadableStream(thumbnailFile)) { 642 | // thumbnailFile is a readableStream, check extension 643 | let ext = Path.extname(thumbnailFile.path); 644 | 645 | if (ext === '.png') { 646 | params = { 647 | user_id: userId, 648 | name: name 649 | }; 650 | formData = { 651 | thumb: thumbnailFile 652 | }; 653 | } else if (ext === '.tgs') { 654 | params = { 655 | user_id: userId, 656 | name: name 657 | }; 658 | formData = { 659 | thumb: thumbnailFile 660 | }; 661 | } 662 | } else { 663 | // thumbnailFile is a string, either a file_id or HTTP URL 664 | params = { 665 | user_id: userId, 666 | name: name, 667 | thumb: thumbnailFile 668 | }; 669 | } 670 | 671 | return this._request('setStickerSetThumb', params, formData, callback); 672 | } 673 | 674 | sendVideo(chatId, video, optionalParams, callback) { 675 | let params; 676 | let formData; 677 | 678 | if (isReadableStream(video)) { 679 | params = { 680 | chat_id: chatId 681 | }; 682 | formData = { 683 | video: video 684 | }; 685 | } else { 686 | params = { 687 | chat_id: chatId, 688 | video: video 689 | }; 690 | } 691 | 692 | if (typeof optionalParams == 'function') { 693 | callback = optionalParams; 694 | } else { 695 | Object.assign(params, optionalParams); 696 | } 697 | 698 | return this._request('sendVideo', params, formData, callback); 699 | } 700 | 701 | sendVoice(chatId, voice, optionalParams, callback) { 702 | let params; 703 | let formData; 704 | 705 | if (isReadableStream(voice)) { 706 | params = { 707 | chat_id: chatId 708 | }; 709 | formData = { 710 | voice: voice 711 | }; 712 | } else { 713 | params = { 714 | chat_id: chatId, 715 | voice: voice 716 | }; 717 | } 718 | 719 | if (typeof optionalParams == 'function') { 720 | callback = optionalParams; 721 | } else { 722 | Object.assign(params, optionalParams); 723 | } 724 | 725 | return this._request('sendVoice', params, formData, callback); 726 | } 727 | 728 | sendVideoNote(chatId, videoNote, optionalParams, callback) { 729 | let params; 730 | let formData; 731 | 732 | if (isReadableStream(videoNote)) { 733 | params = { 734 | chat_id: chatId 735 | }; 736 | formData = { 737 | video_note: videoNote 738 | }; 739 | } else { 740 | params = { 741 | chat_id: chatId, 742 | video_note: videoNote 743 | }; 744 | } 745 | 746 | if (typeof optionalParams == 'function') { 747 | callback = optionalParams; 748 | } else { 749 | Object.assign(params, optionalParams); 750 | } 751 | 752 | return this._request('sendVideoNote', params, formData, callback); 753 | } 754 | 755 | sendMediaGroup(chatId, media, optionalParams, callback) { 756 | let params = { 757 | chat_id: chatId, 758 | media: media 759 | }; 760 | 761 | if (typeof optionalParams == 'function') { 762 | callback = optionalParams; 763 | } else { 764 | Object.assign(params, optionalParams); 765 | } 766 | 767 | return this._request('sendMediaGroup', params, callback); 768 | } 769 | 770 | sendLocation(chatId, lat, lon, optionalParams, callback) { 771 | let params = { 772 | chat_id: chatId, 773 | latitude: lat, 774 | longitude: lon 775 | }; 776 | 777 | if (typeof optionalParams == 'function') { 778 | callback = optionalParams; 779 | } else { 780 | Object.assign(params, optionalParams); 781 | } 782 | 783 | return this._request('sendLocation', params, callback); 784 | } 785 | 786 | editMessageLiveLocation(chatId, messageId, lat, lon, optionalParams, callback) { 787 | let params = { 788 | chat_id: chatId, 789 | message_id: messageId, 790 | latitude: lat, 791 | longitude: lon 792 | } 793 | 794 | if (typeof optionalParams == 'function') { 795 | callback = optionalParams; 796 | } else { 797 | Object.assign(params, optionalParams); 798 | } 799 | 800 | return this._request('editMessageLiveLocation', params, callback); 801 | } 802 | 803 | editInlineMessageLiveLocation(inlineMessageId, lat, lon, optionalParams, callback) { 804 | let params = { 805 | inline_message_id: inlineMessageId, 806 | latitude: lat, 807 | longitude: lon 808 | } 809 | 810 | if (typeof optionalParams == 'function') { 811 | callback = optionalParams; 812 | } else { 813 | Object.assign(params, optionalParams); 814 | } 815 | 816 | return this._request('editMessageLiveLocation', params, callback); 817 | } 818 | 819 | stopMessageLiveLocation(chatId, messageId, optionalParams, callback) { 820 | let params = { 821 | chat_id: chatId, 822 | message_id: messageId 823 | } 824 | 825 | if (typeof optionalParams == 'function') { 826 | callback = optionalParams; 827 | } else { 828 | Object.assign(params, optionalParams); 829 | } 830 | 831 | return this._request('stopMessageLiveLocation', params, callback); 832 | } 833 | 834 | stopInlineMessageLiveLocation(inlineMessageId, optionalParams, callback) { 835 | let params = { 836 | inline_message_id: inlineMessageId 837 | } 838 | 839 | if (typeof optionalParams == 'function') { 840 | callback = optionalParams; 841 | } else { 842 | Object.assign(params, optionalParams); 843 | } 844 | 845 | return this._request('stopMessageLiveLocation', params, callback); 846 | } 847 | 848 | sendVenue(chatId, lat, lon, title, address, optionalParams, callback) { 849 | let params = { 850 | chat_id: chatId, 851 | latitude: lat, 852 | longitude: lon, 853 | title: title, 854 | address: address 855 | } 856 | 857 | if (typeof optionalParams == 'function') { 858 | callback = optionalParams; 859 | } else { 860 | Object.assign(params, optionalParams); 861 | } 862 | 863 | return this._request('sendVenue', params, callback); 864 | } 865 | 866 | sendContact(chatId, phoneNumber, firstName, optionalParams, callback) { 867 | let params = { 868 | chat_id: chatId, 869 | phone_number: phoneNumber, 870 | first_name: firstName 871 | } 872 | 873 | if (typeof optionalParams == 'function') { 874 | callback = optionalParams; 875 | } else { 876 | Object.assign(params, optionalParams); 877 | } 878 | 879 | return this._request('sendContact', params, callback); 880 | } 881 | 882 | sendDice(chatId, optionalParams, callback) { 883 | let params = { 884 | chat_id: chatId 885 | } 886 | 887 | if (typeof optionalParams == 'function') { 888 | callback = optionalParams; 889 | } else { 890 | Object.assign(params, optionalParams); 891 | } 892 | 893 | return this._request('sendDice', params, callback); 894 | } 895 | 896 | sendChatAction(chatId, action, callback) { 897 | if (typeof action !== 'string') { 898 | throw new Error('sendChatAction method needs a string input'); 899 | } 900 | 901 | let params = { 902 | chat_id: chatId, 903 | action: action 904 | }; 905 | 906 | return this._request('sendChatAction', params, callback); 907 | } 908 | 909 | getUserProfilePhotos(userId, optionalParams, callback) { 910 | let params = { 911 | user_id: userId, 912 | }; 913 | 914 | if (typeof optionalParams == 'function') { 915 | callback = optionalParams; 916 | } else { 917 | Object.assign(params, optionalParams); 918 | } 919 | 920 | return this._request('getUserProfilePhotos', params, callback); 921 | } 922 | 923 | getFile(fileId, callback) { 924 | let params = { 925 | file_id: fileId 926 | }; 927 | 928 | return this._request('getFile', params, callback); 929 | } 930 | 931 | kickChatMember(chatId, userId, optionalParams, callback) { 932 | let params = { 933 | chat_id: chatId, 934 | user_id: userId 935 | }; 936 | 937 | if (typeof optionalParams == 'function') { 938 | callback = optionalParams; 939 | } else { 940 | Object.assign(params, optionalParams); 941 | } 942 | 943 | return this._request('kickChatMember', params, callback); 944 | } 945 | 946 | unbanChatMember(chatId, userId, optionalParams, callback) { 947 | let params = { 948 | chat_id: chatId, 949 | user_id: userId 950 | }; 951 | 952 | if (typeof optionalParams == 'function') { 953 | callback = optionalParams; 954 | } else { 955 | Object.assign(params, optionalParams); 956 | } 957 | 958 | return this._request('unbanChatMember', params, callback); 959 | } 960 | 961 | restrictChatMember(chatId, userId, permissions, optionalParams, callback) { 962 | let params = { 963 | chat_id: chatId, 964 | user_id: userId, 965 | permissions: permissions 966 | } 967 | 968 | if (typeof optionalParams == 'function') { 969 | callback = optionalParams; 970 | } else { 971 | Object.assign(params, optionalParams); 972 | } 973 | 974 | return this._request('restrictChatMember', params, callback); 975 | } 976 | 977 | promoteChatMember(chatId, userId, optionalParams, callback) { 978 | let params = { 979 | chat_id: chatId, 980 | user_id: userId 981 | } 982 | 983 | if (typeof optionalParams == 'function') { 984 | callback = optionalParams; 985 | } else { 986 | Object.assign(params, optionalParams); 987 | } 988 | 989 | return this._request('promoteChatMember', params, callback); 990 | } 991 | 992 | setChatAdministratorCustomTitle(chatId, userId, customTitle, callback) { 993 | let params = { 994 | chat_id: chatId, 995 | user_id: userId, 996 | custom_title: customTitle 997 | } 998 | 999 | return this._request('setChatAdministratorCustomTitle', params, callback); 1000 | } 1001 | 1002 | setChatPermissions(chatId, permissions, callback) { 1003 | let params = { 1004 | chat_id: chatId, 1005 | permissions: permissions 1006 | } 1007 | 1008 | if (typeof optionalParams == 'function') { 1009 | callback = optionalParams; 1010 | } else { 1011 | Object.assign(params, optionalParams); 1012 | } 1013 | 1014 | return this._request('setChatPermissions', params, callback); 1015 | } 1016 | 1017 | exportChatInviteLink(chatId, callback) { 1018 | let params = { 1019 | chat_id: chatId 1020 | } 1021 | 1022 | return this._request('exportChatInviteLink', params, callback); 1023 | } 1024 | 1025 | createChatInviteLink(chatId, optionalParams, callback) { 1026 | let params = { 1027 | chat_id: chatId 1028 | } 1029 | 1030 | if (typeof optionalParams == 'function') { 1031 | callback = optionalParams; 1032 | } else { 1033 | Object.assign(params, optionalParams); 1034 | } 1035 | 1036 | return this._request('createChatInviteLink', params, callback); 1037 | } 1038 | 1039 | editChatInviteLink(chatId, inviteLink, optionalParams, callback) { 1040 | let params = { 1041 | chat_id: chatId, 1042 | invite_link: inviteLink 1043 | } 1044 | 1045 | if (typeof optionalParams == 'function') { 1046 | callback = optionalParams; 1047 | } else { 1048 | Object.assign(params, optionalParams); 1049 | } 1050 | 1051 | return this._request('editChatInviteLink', params, callback); 1052 | } 1053 | 1054 | revokeChatInviteLink(chatId, inviteLink, callback) { 1055 | let params = { 1056 | chat_id: chatId, 1057 | invite_link: inviteLink 1058 | } 1059 | 1060 | return this._request('revokeChatInviteLink', params, callback); 1061 | } 1062 | 1063 | setChatPhoto(chatId, photo, callback) { 1064 | let params = { 1065 | chat_id: chatId 1066 | }; 1067 | 1068 | let formData = { 1069 | photo: photo 1070 | }; 1071 | 1072 | return this._request('setChatPhoto', params, formData, callback); 1073 | } 1074 | 1075 | deleteChatPhoto(chatId, callback) { 1076 | let params = { 1077 | chat_id: chatId 1078 | } 1079 | 1080 | return this._request('deleteChatPhoto', params, callback); 1081 | } 1082 | 1083 | setChatTitle(chatId, title, callback) { 1084 | let params = { 1085 | chat_id: chatId, 1086 | title: title 1087 | } 1088 | 1089 | return this._request('setChatTitle', params, callback); 1090 | } 1091 | 1092 | setChatDescription(chatId, description, callback) { 1093 | let params = { 1094 | chat_id: chatId, 1095 | description: description 1096 | } 1097 | 1098 | return this._request('setChatDescription', params, callback); 1099 | } 1100 | 1101 | pinChatMessage(chatId, messageId, optionalParams, callback) { 1102 | let params = { 1103 | chat_id: chatId, 1104 | message_id: messageId 1105 | } 1106 | 1107 | if (typeof optionalParams == 'function') { 1108 | callback = optionalParams; 1109 | } else { 1110 | Object.assign(params, optionalParams); 1111 | } 1112 | 1113 | return this._request('pinChatMessage', params, callback); 1114 | } 1115 | 1116 | unpinChatMessage(chatId, optionalParams, callback) { 1117 | let params = { 1118 | chat_id: chatId 1119 | } 1120 | 1121 | if (typeof optionalParams == 'function') { 1122 | callback = optionalParams; 1123 | } else { 1124 | Object.assign(params, optionalParams); 1125 | } 1126 | 1127 | return this._request('unpinChatMessage', params, callback); 1128 | } 1129 | 1130 | unpinAllChatMessages(chatId, callback) { 1131 | let params = { 1132 | chat_id: chatId 1133 | } 1134 | 1135 | return this._request('unpinAllChatMessages', params, callback); 1136 | } 1137 | 1138 | leaveChat(chatId, callback) { 1139 | let params = { 1140 | chat_id: chatId 1141 | }; 1142 | 1143 | return this._request('leaveChat', params, callback); 1144 | } 1145 | 1146 | getChat(chatId, callback) { 1147 | let params = { 1148 | chat_id: chatId 1149 | }; 1150 | 1151 | return this._request('getChat', params, callback); 1152 | } 1153 | 1154 | getChatAdministrators(chatId, callback) { 1155 | let params = { 1156 | chat_id: chatId 1157 | }; 1158 | 1159 | return this._request('getChatAdministrators', params, callback); 1160 | } 1161 | 1162 | getChatMembersCount(chatId, callback) { 1163 | let params = { 1164 | chat_id: chatId 1165 | }; 1166 | 1167 | return this._request('getChatMembersCount', params, callback); 1168 | } 1169 | 1170 | getChatMember(chatId, userId, callback) { 1171 | let params = { 1172 | chat_id: chatId, 1173 | user_id: userId 1174 | }; 1175 | 1176 | return this._request('getChatMember', params, callback); 1177 | } 1178 | 1179 | setChatStickerSet(chatId, stickerSetName, callback) { 1180 | let params = { 1181 | chat_id: chatId, 1182 | sticker_set_name: stickerSetName 1183 | } 1184 | 1185 | return this._request('setChatStickerSet', params, callback); 1186 | } 1187 | 1188 | deleteChatStickerSet(chatId, callback) { 1189 | let params = { 1190 | chat_id: chatId 1191 | } 1192 | 1193 | return this._request('deleteChatStickerSet', params, callback); 1194 | } 1195 | 1196 | // Payment 1197 | 1198 | sendInvoice(chatId, title, description, payload, providerToken, startParameter, currency, prices, optionalParams, callback) { 1199 | let params = { 1200 | chat_id: chatId, 1201 | title: title, 1202 | description: description, 1203 | payload: payload, 1204 | provider_token: providerToken, 1205 | start_parameter: startParameter, 1206 | currency: currency, 1207 | prices: prices 1208 | }; 1209 | 1210 | if (typeof optionalParams == 'function') { 1211 | callback = optionalParams; 1212 | } else { 1213 | Object.assign(params, optionalParams); 1214 | } 1215 | 1216 | return this._request('sendInvoice', params, callback); 1217 | } 1218 | 1219 | answerShippingQuery(shippingQueryId, ok, callback) { 1220 | let params = { 1221 | shipping_query_id: shippingQueryId, 1222 | ok: ok 1223 | }; 1224 | 1225 | if (typeof optionalParams == 'function') { 1226 | callback = optionalParams; 1227 | } else { 1228 | Object.assign(params, optionalParams); 1229 | } 1230 | 1231 | return this._request('answerShippingQuery', params, callback); 1232 | } 1233 | 1234 | answerPreCheckoutQuery(preCheckoutQueryId, ok, errorMessage) { 1235 | let params = { 1236 | pre_checkout_query_id: preCheckoutQueryId, 1237 | ok: ok, 1238 | error_message: errorMessage 1239 | }; 1240 | 1241 | return this._request('answerShippingQuery', params, callback); 1242 | } 1243 | 1244 | // Games 1245 | 1246 | sendGame(chatId, gameShortName, optionalParams, callback) { 1247 | let params = { 1248 | chat_id: chatId, 1249 | game_short_name: gameShortName 1250 | }; 1251 | 1252 | if (typeof optionalParams == 'function') { 1253 | callback = optionalParams; 1254 | } else { 1255 | Object.assign(params, optionalParams); 1256 | } 1257 | 1258 | return this._request('sendGame', params, callback); 1259 | } 1260 | 1261 | setGameScore(userId, score, optionalParams, callback) { 1262 | let params = { 1263 | user_id: userId, 1264 | score: score 1265 | } 1266 | 1267 | if (typeof optionalParams == 'function') { 1268 | callback = optionalParams; 1269 | } else { 1270 | Object.assign(params, optionalParams); 1271 | } 1272 | 1273 | return this._request('setGameScore', params, callback); 1274 | } 1275 | 1276 | getGameHighScores(userId, optionalParams, callback) { 1277 | let params = { 1278 | user_id: userId 1279 | }; 1280 | 1281 | if (typeof optionalParams == 'function') { 1282 | callback = optionalParams; 1283 | } else { 1284 | Object.assign(params, optionalParams); 1285 | } 1286 | 1287 | return this._request('getGameHighScores', params, callback); 1288 | } 1289 | } 1290 | 1291 | function isReadableStream(object) { 1292 | return object instanceof Stream.Stream && 1293 | typeof object._read === "function" && 1294 | typeof object._readableState === "object" 1295 | } 1296 | 1297 | module.exports = Telegram; 1298 | --------------------------------------------------------------------------------