├── .eslintrc.json ├── .github └── workflows │ └── release.yaml ├── .gitignore ├── LICENSE ├── README.md ├── docs └── jsdoc.json ├── package-lock.json ├── package.json └── src ├── client ├── Client.js └── ClientUser.js ├── constants ├── defaultClientSettings.js └── index.js ├── index.js ├── managers ├── BaseManager.js └── ConversationManager.js ├── structures ├── BaseConversation.js ├── ExtMap.js ├── GroupConversation.js ├── Message.js └── UserConversation.js └── util ├── debugLog.js ├── deepMerge.js └── index.js /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "es2020": true, 4 | "node": true, 5 | "commonjs": true 6 | }, 7 | "extends": "eslint:recommended", 8 | "rules": { 9 | "accessor-pairs": "error", 10 | "arrow-body-style": "error", 11 | "arrow-parens": [ 12 | "error", 13 | "as-needed" 14 | ], 15 | "arrow-spacing": [ 16 | "error", 17 | { 18 | "after": true, 19 | "before": true 20 | } 21 | ], 22 | "block-scoped-var": "error", 23 | "brace-style": [ 24 | "error", 25 | "1tbs" 26 | ], 27 | "callback-return": "error", 28 | "camelcase": "off", 29 | "class-methods-use-this": "error", 30 | "comma-dangle": "error", 31 | "comma-spacing": [ 32 | "error", 33 | { 34 | "after": true, 35 | "before": false 36 | } 37 | ], 38 | "comma-style": [ 39 | "error", 40 | "last" 41 | ], 42 | "dot-notation": "error", 43 | "eqeqeq": "error", 44 | "func-call-spacing": "error", 45 | "func-name-matching": "error", 46 | "function-paren-newline": "error", 47 | "global-require": "off", 48 | "guard-for-in": "error", 49 | "handle-callback-err": "error", 50 | "id-blacklist": "error", 51 | "id-length": "off", 52 | "id-match": "error", 53 | "implicit-arrow-linebreak": [ 54 | "error", 55 | "beside" 56 | ], 57 | "indent": "off", 58 | "indent-legacy": "off", 59 | "init-declarations": "off", 60 | "jsx-quotes": "error", 61 | "key-spacing": "error", 62 | "keyword-spacing": [ 63 | "error", 64 | { 65 | "after": true, 66 | "before": true 67 | } 68 | ], 69 | "max-len": "off", 70 | "new-cap": "off", 71 | "new-parens": "error", 72 | "newline-after-var": "off", 73 | "newline-before-return": "off", 74 | "newline-per-chained-call": "off", 75 | "no-alert": "error", 76 | "no-array-constructor": "error", 77 | "no-buffer-constructor": "error", 78 | "no-caller": "error", 79 | "no-catch-shadow": "error", 80 | "no-confusing-arrow": "off", 81 | "no-duplicate-imports": "error", 82 | "no-else-return": "off", 83 | "no-empty": "off", 84 | "no-eq-null": "error", 85 | "no-eval": "error", 86 | "no-extra-bind": "error", 87 | "no-extra-label": "error", 88 | "no-floating-decimal": "error", 89 | "no-implicit-globals": "error", 90 | "no-implied-eval": "error", 91 | "no-invalid-this": "error", 92 | "no-iterator": "error", 93 | "no-label-var": "error", 94 | "no-labels": "error", 95 | "no-lonely-if": "error", 96 | "no-loop-func": "off", 97 | "no-magic-numbers": "off", 98 | "no-mixed-requires": "error", 99 | "no-multi-spaces": "error", 100 | "no-multi-str": "error", 101 | "no-multiple-empty-lines": "error", 102 | "no-native-reassign": "error", 103 | "no-negated-condition": "off", 104 | "no-negated-in-lhs": "error", 105 | "no-new": "error", 106 | "no-new-func": "error", 107 | "no-new-object": "error", 108 | "no-new-require": "error", 109 | "no-new-wrappers": "error", 110 | "no-octal-escape": "error", 111 | "no-process-env": "error", 112 | "no-proto": "error", 113 | "no-restricted-globals": "error", 114 | "no-restricted-imports": "error", 115 | "no-restricted-modules": "error", 116 | "no-restricted-properties": "error", 117 | "no-restricted-syntax": "error", 118 | "no-return-assign": [ 119 | "error", 120 | "except-parens" 121 | ], 122 | "no-script-url": "error", 123 | "no-self-compare": "error", 124 | "no-sequences": "error", 125 | "no-shadow": "error", 126 | "no-shadow-restricted-names": "error", 127 | "no-spaced-func": "error", 128 | "no-sync": "error", 129 | "no-tabs": "error", 130 | "no-template-curly-in-string": "error", 131 | "no-ternary": "off", 132 | "no-throw-literal": "error", 133 | "no-trailing-spaces": "error", 134 | "no-undef": "error", 135 | "no-undef-init": "error", 136 | "no-unmodified-loop-condition": "error", 137 | "no-unneeded-ternary": "error", 138 | "no-unused-vars": ["error", {"args": "none"}], 139 | "no-useless-call": "error", 140 | "no-useless-computed-key": "error", 141 | "no-useless-concat": "error", 142 | "no-useless-constructor": "error", 143 | "no-useless-rename": "error", 144 | "no-useless-return": "error", 145 | "no-var": "error", 146 | "no-void": "error", 147 | "no-whitespace-before-property": "error", 148 | "no-with": "error", 149 | "nonblock-statement-body-position": "error", 150 | "object-curly-spacing": "error", 151 | "object-property-newline": "error", 152 | "one-var": "off", 153 | "one-var-declaration-per-line": "error", 154 | "operator-assignment": "error", 155 | "operator-linebreak": "error", 156 | "padded-blocks": "off", 157 | "padding-line-between-statements": "error", 158 | "prefer-const": "error", 159 | "prefer-numeric-literals": "error", 160 | "prefer-promise-reject-errors": "error", 161 | "prefer-spread": "error", 162 | "quote-props": "off", 163 | "quotes": [ 164 | "error", 165 | "double" 166 | ], 167 | "radix": "off", 168 | "require-await": "error", 169 | "rest-spread-spacing": "error", 170 | "semi": "error", 171 | "semi-spacing": "error", 172 | "semi-style": [ 173 | "error", 174 | "last" 175 | ], 176 | "sort-imports": "off", 177 | "sort-keys": "off", 178 | "space-before-blocks": "error", 179 | "space-before-function-paren": "off", 180 | "space-in-parens": [ 181 | "error", 182 | "never" 183 | ], 184 | "space-infix-ops": "error", 185 | "space-unary-ops": "error", 186 | "strict": [ 187 | "error", 188 | "global" 189 | ], 190 | "switch-colon-spacing": "error", 191 | "symbol-description": "error", 192 | "template-curly-spacing": "error", 193 | "template-tag-spacing": "error", 194 | "unicode-bom": [ 195 | "error", 196 | "never" 197 | ], 198 | "yield-star-spacing": "error" 199 | } 200 | } 201 | -------------------------------------------------------------------------------- /.github/workflows/release.yaml: -------------------------------------------------------------------------------- 1 | name: On Release 2 | on: 3 | workflow_dispatch: 4 | release: 5 | types: [published] 6 | 7 | jobs: 8 | deploy: 9 | name: GitHub Pages 10 | runs-on: ubuntu-20.04 11 | strategy: 12 | matrix: 13 | node-version: [14.x] 14 | steps: 15 | - name: Checkout Repository 16 | uses: actions/checkout@v2 17 | with: 18 | submodules: true 19 | - name: Use Node.js ${{ matrix.node-version }} 20 | uses: actions/setup-node@v1 21 | with: 22 | node-version: ${{ matrix.node-version }} 23 | - run: npm ci 24 | - run: npm run docs:build 25 | - name: Deploy Pages 26 | uses: peaceiris/actions-gh-pages@v3 27 | with: 28 | github_token: ${{ secrets.GITHUB_TOKEN }} 29 | publish_dir: ./docs/out 30 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | 6 | # Runtime data 7 | pids 8 | *.pid 9 | *.seed 10 | 11 | # Directory for instrumented libs generated by jscoverage/JSCover 12 | lib-cov 13 | 14 | # Coverage directory used by tools like istanbul 15 | coverage 16 | 17 | # nyc test coverage 18 | .nyc_output 19 | 20 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 21 | .grunt 22 | 23 | # node-waf configuration 24 | .lock-wscript 25 | 26 | # Compiled binary addons (http://nodejs.org/api/addons.html) 27 | build/Release 28 | 29 | # Dependency directories 30 | node_modules 31 | jspm_packages 32 | 33 | # Optional npm cache directory 34 | .npm 35 | 36 | # Optional REPL history 37 | .node_repl_history 38 | 39 | # Documentation output 40 | docs/out 41 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License 2 | 3 | Copyright (c) 2021 Vietbao Tran (TapuCosmo) 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in 13 | all copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 21 | THE SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Signal-Bot 2 | 3 | A library for creating bots that interact with the Signal application. Not affiliated with the Signal project or Open Whisper Systems. 4 | 5 | Install with `npm install signal-bot`. 6 | 7 | Currently only works on Linux, with Node.js >=14.0.0. 8 | 9 | This library requires a working installation of [signal-cli](https://github.com/AsamK/signal-cli) 10 | running in daemon mode with the phone number you want to use. 11 | Use [this Python script](https://gist.github.com/Vic3198/f0c9e17ef3d70e7b8c066bfd8cf4db2d) for an easy installation process. 12 | 13 | Tested on v0.7.2 of signal-cli. 14 | 15 | [View Documentation](https://tapucosmo.github.io/signal-bot/) 16 | 17 | ## Example Usage 18 | 19 | ### Basic Commands 20 | 21 | ```js 22 | const {Client} = require("signal-bot"); 23 | 24 | const bot = new Client(); 25 | 26 | const prefix = "!"; 27 | 28 | bot.on("message", msg => { 29 | if (!msg.content.startsWith(prefix)) return; 30 | const command = msg.content.slice(prefix.length); 31 | 32 | if (command === "hello") { 33 | msg.conversation.sendMessage("Hello World!"); 34 | } else if (command === "whoami") { 35 | msg.conversation.sendMessage(`You are ${msg.author.id}`); 36 | } 37 | }); 38 | 39 | bot.connect(); 40 | ``` 41 | 42 | Send the bot `!hello` and it should respond with `Hello World!`. 43 | 44 | Send the bot `!whoami` and it should respond with `You are `. 45 | 46 | ## Missing Features 47 | 48 | * signal-cli D-Bus missing features: 49 | - Group conversation invite event 50 | - Group conversation leave event 51 | - Reactions 52 | - Stickers 53 | * Contact management 54 | * Additional user/group member information/profiles 55 | * Group conversation member list 56 | * Group conversation admin functions 57 | -------------------------------------------------------------------------------- /docs/jsdoc.json: -------------------------------------------------------------------------------- 1 | { 2 | "opts": { 3 | "recurse": true, 4 | "encoding": "utf8", 5 | "template": "node_modules/docdash", 6 | "destination": "./docs/out/" 7 | }, 8 | "plugins": [ 9 | "plugins/markdown" 10 | ], 11 | "templates": { 12 | "default": { 13 | "cleverLinks": true, 14 | "includeDate": false 15 | }, 16 | "docdash": { 17 | "typedefs": true, 18 | "openGraph": { 19 | "title": "signal-bot Documentation", 20 | "type": "website", 21 | "site_name": "signal-bot", 22 | "url": "" 23 | }, 24 | "meta": { 25 | "title": "signal-bot Documentation", 26 | "description": "A library for creating bots that interact with the Signal application. Not affiliated with the Signal project or Open Whisper Systems.", 27 | "keyword": "signal bot client" 28 | } 29 | } 30 | }, 31 | "source": { 32 | "include": [ 33 | "./src/", 34 | "./README.md" 35 | ], 36 | "includePattern": ".+\\.js$" 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "signal-bot", 3 | "version": "0.0.1", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "0.0.1", 9 | "license": "MIT", 10 | "dependencies": { 11 | "dbus-next": "^0.9.1" 12 | }, 13 | "devDependencies": { 14 | "docdash": "^1.2.0", 15 | "eslint": "^7.17.0", 16 | "jsdoc": "^3.6.6" 17 | } 18 | }, 19 | "node_modules/@babel/code-frame": { 20 | "version": "7.12.11", 21 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 22 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 23 | "dev": true, 24 | "dependencies": { 25 | "@babel/highlight": "^7.10.4" 26 | } 27 | }, 28 | "node_modules/@babel/helper-validator-identifier": { 29 | "version": "7.12.11", 30 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 31 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 32 | "dev": true 33 | }, 34 | "node_modules/@babel/highlight": { 35 | "version": "7.10.4", 36 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 37 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 38 | "dev": true, 39 | "dependencies": { 40 | "@babel/helper-validator-identifier": "^7.10.4", 41 | "chalk": "^2.0.0", 42 | "js-tokens": "^4.0.0" 43 | } 44 | }, 45 | "node_modules/@babel/highlight/node_modules/ansi-styles": { 46 | "version": "3.2.1", 47 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 48 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 49 | "dev": true, 50 | "dependencies": { 51 | "color-convert": "^1.9.0" 52 | }, 53 | "engines": { 54 | "node": ">=4" 55 | } 56 | }, 57 | "node_modules/@babel/highlight/node_modules/chalk": { 58 | "version": "2.4.2", 59 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 60 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 61 | "dev": true, 62 | "dependencies": { 63 | "ansi-styles": "^3.2.1", 64 | "escape-string-regexp": "^1.0.5", 65 | "supports-color": "^5.3.0" 66 | }, 67 | "engines": { 68 | "node": ">=4" 69 | } 70 | }, 71 | "node_modules/@babel/highlight/node_modules/color-convert": { 72 | "version": "1.9.3", 73 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 74 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 75 | "dev": true, 76 | "dependencies": { 77 | "color-name": "1.1.3" 78 | } 79 | }, 80 | "node_modules/@babel/highlight/node_modules/color-name": { 81 | "version": "1.1.3", 82 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 83 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 84 | "dev": true 85 | }, 86 | "node_modules/@babel/highlight/node_modules/has-flag": { 87 | "version": "3.0.0", 88 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 89 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 90 | "dev": true, 91 | "engines": { 92 | "node": ">=4" 93 | } 94 | }, 95 | "node_modules/@babel/highlight/node_modules/supports-color": { 96 | "version": "5.5.0", 97 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 98 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 99 | "dev": true, 100 | "dependencies": { 101 | "has-flag": "^3.0.0" 102 | }, 103 | "engines": { 104 | "node": ">=4" 105 | } 106 | }, 107 | "node_modules/@babel/parser": { 108 | "version": "7.12.11", 109 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.12.11.tgz", 110 | "integrity": "sha512-N3UxG+uuF4CMYoNj8AhnbAcJF0PiuJ9KHuy1lQmkYsxTer/MAH9UBNHsBoAX/4s6NvlDD047No8mYVGGzLL4hg==", 111 | "dev": true, 112 | "bin": { 113 | "parser": "bin/babel-parser.js" 114 | }, 115 | "engines": { 116 | "node": ">=6.0.0" 117 | } 118 | }, 119 | "node_modules/@eslint/eslintrc": { 120 | "version": "0.2.2", 121 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.2.2.tgz", 122 | "integrity": "sha512-EfB5OHNYp1F4px/LI/FEnGylop7nOqkQ1LRzCM0KccA2U8tvV8w01KBv37LbO7nW4H+YhKyo2LcJhRwjjV17QQ==", 123 | "dev": true, 124 | "dependencies": { 125 | "ajv": "^6.12.4", 126 | "debug": "^4.1.1", 127 | "espree": "^7.3.0", 128 | "globals": "^12.1.0", 129 | "ignore": "^4.0.6", 130 | "import-fresh": "^3.2.1", 131 | "js-yaml": "^3.13.1", 132 | "lodash": "^4.17.19", 133 | "minimatch": "^3.0.4", 134 | "strip-json-comments": "^3.1.1" 135 | }, 136 | "engines": { 137 | "node": "^10.12.0 || >=12.0.0" 138 | } 139 | }, 140 | "node_modules/@nornagon/put": { 141 | "version": "0.0.8", 142 | "resolved": "https://registry.npmjs.org/@nornagon/put/-/put-0.0.8.tgz", 143 | "integrity": "sha512-ugvXJjwF5ldtUpa7D95kruNJ41yFQDEKyF5CW4TgKJnh+W/zmlBzXXeKTyqIgwMFrkePN2JqOBqcF0M0oOunow==", 144 | "engines": { 145 | "node": ">=0.3.0" 146 | } 147 | }, 148 | "node_modules/abstract-socket": { 149 | "version": "2.1.1", 150 | "resolved": "https://registry.npmjs.org/abstract-socket/-/abstract-socket-2.1.1.tgz", 151 | "integrity": "sha512-YZJizsvS1aBua5Gd01woe4zuyYBGgSMeqDOB6/ChwdTI904KP6QGtJswXl4hcqWxbz86hQBe++HWV0hF1aGUtA==", 152 | "hasInstallScript": true, 153 | "optional": true, 154 | "os": [ 155 | "linux" 156 | ], 157 | "dependencies": { 158 | "bindings": "^1.2.1", 159 | "nan": "^2.12.1" 160 | }, 161 | "engines": { 162 | "node": ">=4.0.0" 163 | } 164 | }, 165 | "node_modules/acorn": { 166 | "version": "7.4.1", 167 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 168 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 169 | "dev": true, 170 | "bin": { 171 | "acorn": "bin/acorn" 172 | }, 173 | "engines": { 174 | "node": ">=0.4.0" 175 | } 176 | }, 177 | "node_modules/acorn-jsx": { 178 | "version": "5.3.1", 179 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 180 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 181 | "dev": true, 182 | "peerDependencies": { 183 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 184 | } 185 | }, 186 | "node_modules/ajv": { 187 | "version": "6.12.6", 188 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 189 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 190 | "dev": true, 191 | "dependencies": { 192 | "fast-deep-equal": "^3.1.1", 193 | "fast-json-stable-stringify": "^2.0.0", 194 | "json-schema-traverse": "^0.4.1", 195 | "uri-js": "^4.2.2" 196 | }, 197 | "funding": { 198 | "type": "github", 199 | "url": "https://github.com/sponsors/epoberezkin" 200 | } 201 | }, 202 | "node_modules/ansi-colors": { 203 | "version": "4.1.1", 204 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 205 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 206 | "dev": true, 207 | "engines": { 208 | "node": ">=6" 209 | } 210 | }, 211 | "node_modules/ansi-regex": { 212 | "version": "5.0.0", 213 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 214 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 215 | "dev": true, 216 | "engines": { 217 | "node": ">=8" 218 | } 219 | }, 220 | "node_modules/ansi-styles": { 221 | "version": "4.3.0", 222 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 223 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 224 | "dev": true, 225 | "dependencies": { 226 | "color-convert": "^2.0.1" 227 | }, 228 | "engines": { 229 | "node": ">=8" 230 | }, 231 | "funding": { 232 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 233 | } 234 | }, 235 | "node_modules/argparse": { 236 | "version": "1.0.10", 237 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 238 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 239 | "dev": true, 240 | "dependencies": { 241 | "sprintf-js": "~1.0.2" 242 | } 243 | }, 244 | "node_modules/astral-regex": { 245 | "version": "2.0.0", 246 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 247 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 248 | "dev": true, 249 | "engines": { 250 | "node": ">=8" 251 | } 252 | }, 253 | "node_modules/balanced-match": { 254 | "version": "1.0.0", 255 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 256 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 257 | "dev": true 258 | }, 259 | "node_modules/bindings": { 260 | "version": "1.5.0", 261 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", 262 | "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", 263 | "optional": true, 264 | "dependencies": { 265 | "file-uri-to-path": "1.0.0" 266 | } 267 | }, 268 | "node_modules/bluebird": { 269 | "version": "3.7.2", 270 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 271 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", 272 | "dev": true 273 | }, 274 | "node_modules/brace-expansion": { 275 | "version": "1.1.11", 276 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 277 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 278 | "dev": true, 279 | "dependencies": { 280 | "balanced-match": "^1.0.0", 281 | "concat-map": "0.0.1" 282 | } 283 | }, 284 | "node_modules/callsites": { 285 | "version": "3.1.0", 286 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 287 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 288 | "dev": true, 289 | "engines": { 290 | "node": ">=6" 291 | } 292 | }, 293 | "node_modules/catharsis": { 294 | "version": "0.8.11", 295 | "resolved": "https://registry.npmjs.org/catharsis/-/catharsis-0.8.11.tgz", 296 | "integrity": "sha512-a+xUyMV7hD1BrDQA/3iPV7oc+6W26BgVJO05PGEoatMyIuPScQKsde6i3YorWX1qs+AZjnJ18NqdKoCtKiNh1g==", 297 | "dev": true, 298 | "dependencies": { 299 | "lodash": "^4.17.14" 300 | }, 301 | "engines": { 302 | "node": ">= 8" 303 | } 304 | }, 305 | "node_modules/chalk": { 306 | "version": "4.1.0", 307 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 308 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 309 | "dev": true, 310 | "dependencies": { 311 | "ansi-styles": "^4.1.0", 312 | "supports-color": "^7.1.0" 313 | }, 314 | "engines": { 315 | "node": ">=10" 316 | }, 317 | "funding": { 318 | "url": "https://github.com/chalk/chalk?sponsor=1" 319 | } 320 | }, 321 | "node_modules/color-convert": { 322 | "version": "2.0.1", 323 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 324 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 325 | "dev": true, 326 | "dependencies": { 327 | "color-name": "~1.1.4" 328 | }, 329 | "engines": { 330 | "node": ">=7.0.0" 331 | } 332 | }, 333 | "node_modules/color-name": { 334 | "version": "1.1.4", 335 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 336 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 337 | "dev": true 338 | }, 339 | "node_modules/concat-map": { 340 | "version": "0.0.1", 341 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 342 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 343 | "dev": true 344 | }, 345 | "node_modules/cross-spawn": { 346 | "version": "7.0.3", 347 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 348 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 349 | "dev": true, 350 | "dependencies": { 351 | "path-key": "^3.1.0", 352 | "shebang-command": "^2.0.0", 353 | "which": "^2.0.1" 354 | }, 355 | "engines": { 356 | "node": ">= 8" 357 | } 358 | }, 359 | "node_modules/dbus-next": { 360 | "version": "0.9.1", 361 | "resolved": "https://registry.npmjs.org/dbus-next/-/dbus-next-0.9.1.tgz", 362 | "integrity": "sha512-HTFKjrcNcjdjNlZR+/5LlUHBw13d+ZHQA51tfn8xUzm3WYi7uWQ99M8M4bttATCth3l4G/fxu3XC97JZ5K0oSQ==", 363 | "dependencies": { 364 | "@nornagon/put": "0.0.8", 365 | "abstract-socket": "^2.0.0", 366 | "event-stream": "3.3.4", 367 | "hexy": "^0.2.10", 368 | "jsbi": "^2.0.5", 369 | "long": "^4.0.0", 370 | "safe-buffer": "^5.1.1", 371 | "xml2js": "^0.4.17" 372 | }, 373 | "optionalDependencies": { 374 | "abstract-socket": "^2.0.0" 375 | } 376 | }, 377 | "node_modules/debug": { 378 | "version": "4.3.1", 379 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 380 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 381 | "dev": true, 382 | "dependencies": { 383 | "ms": "2.1.2" 384 | }, 385 | "engines": { 386 | "node": ">=6.0" 387 | }, 388 | "peerDependenciesMeta": { 389 | "supports-color": { 390 | "optional": true 391 | } 392 | } 393 | }, 394 | "node_modules/deep-is": { 395 | "version": "0.1.3", 396 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 397 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 398 | "dev": true 399 | }, 400 | "node_modules/docdash": { 401 | "version": "1.2.0", 402 | "resolved": "https://registry.npmjs.org/docdash/-/docdash-1.2.0.tgz", 403 | "integrity": "sha512-IYZbgYthPTspgqYeciRJNPhSwL51yer7HAwDXhF5p+H7mTDbPvY3PCk/QDjNxdPCpWkaJVFC4t7iCNB/t9E5Kw==", 404 | "dev": true 405 | }, 406 | "node_modules/doctrine": { 407 | "version": "3.0.0", 408 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 409 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 410 | "dev": true, 411 | "dependencies": { 412 | "esutils": "^2.0.2" 413 | }, 414 | "engines": { 415 | "node": ">=6.0.0" 416 | } 417 | }, 418 | "node_modules/duplexer": { 419 | "version": "0.1.2", 420 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", 421 | "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==" 422 | }, 423 | "node_modules/emoji-regex": { 424 | "version": "8.0.0", 425 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 426 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 427 | "dev": true 428 | }, 429 | "node_modules/enquirer": { 430 | "version": "2.3.6", 431 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 432 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 433 | "dev": true, 434 | "dependencies": { 435 | "ansi-colors": "^4.1.1" 436 | }, 437 | "engines": { 438 | "node": ">=8.6" 439 | } 440 | }, 441 | "node_modules/entities": { 442 | "version": "2.0.3", 443 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.0.3.tgz", 444 | "integrity": "sha512-MyoZ0jgnLvB2X3Lg5HqpFmn1kybDiIfEQmKzTb5apr51Rb+T3KdmMiqa70T+bhGnyv7bQ6WMj2QMHpGMmlrUYQ==", 445 | "dev": true 446 | }, 447 | "node_modules/escape-string-regexp": { 448 | "version": "1.0.5", 449 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 450 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 451 | "dev": true, 452 | "engines": { 453 | "node": ">=0.8.0" 454 | } 455 | }, 456 | "node_modules/eslint": { 457 | "version": "7.17.0", 458 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.17.0.tgz", 459 | "integrity": "sha512-zJk08MiBgwuGoxes5sSQhOtibZ75pz0J35XTRlZOk9xMffhpA9BTbQZxoXZzOl5zMbleShbGwtw+1kGferfFwQ==", 460 | "dev": true, 461 | "dependencies": { 462 | "@babel/code-frame": "^7.0.0", 463 | "@eslint/eslintrc": "^0.2.2", 464 | "ajv": "^6.10.0", 465 | "chalk": "^4.0.0", 466 | "cross-spawn": "^7.0.2", 467 | "debug": "^4.0.1", 468 | "doctrine": "^3.0.0", 469 | "enquirer": "^2.3.5", 470 | "eslint-scope": "^5.1.1", 471 | "eslint-utils": "^2.1.0", 472 | "eslint-visitor-keys": "^2.0.0", 473 | "espree": "^7.3.1", 474 | "esquery": "^1.2.0", 475 | "esutils": "^2.0.2", 476 | "file-entry-cache": "^6.0.0", 477 | "functional-red-black-tree": "^1.0.1", 478 | "glob-parent": "^5.0.0", 479 | "globals": "^12.1.0", 480 | "ignore": "^4.0.6", 481 | "import-fresh": "^3.0.0", 482 | "imurmurhash": "^0.1.4", 483 | "is-glob": "^4.0.0", 484 | "js-yaml": "^3.13.1", 485 | "json-stable-stringify-without-jsonify": "^1.0.1", 486 | "levn": "^0.4.1", 487 | "lodash": "^4.17.19", 488 | "minimatch": "^3.0.4", 489 | "natural-compare": "^1.4.0", 490 | "optionator": "^0.9.1", 491 | "progress": "^2.0.0", 492 | "regexpp": "^3.1.0", 493 | "semver": "^7.2.1", 494 | "strip-ansi": "^6.0.0", 495 | "strip-json-comments": "^3.1.0", 496 | "table": "^6.0.4", 497 | "text-table": "^0.2.0", 498 | "v8-compile-cache": "^2.0.3" 499 | }, 500 | "bin": { 501 | "eslint": "bin/eslint.js" 502 | }, 503 | "engines": { 504 | "node": "^10.12.0 || >=12.0.0" 505 | }, 506 | "funding": { 507 | "url": "https://opencollective.com/eslint" 508 | } 509 | }, 510 | "node_modules/eslint-scope": { 511 | "version": "5.1.1", 512 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 513 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 514 | "dev": true, 515 | "dependencies": { 516 | "esrecurse": "^4.3.0", 517 | "estraverse": "^4.1.1" 518 | }, 519 | "engines": { 520 | "node": ">=8.0.0" 521 | } 522 | }, 523 | "node_modules/eslint-utils": { 524 | "version": "2.1.0", 525 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 526 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 527 | "dev": true, 528 | "dependencies": { 529 | "eslint-visitor-keys": "^1.1.0" 530 | }, 531 | "engines": { 532 | "node": ">=6" 533 | }, 534 | "funding": { 535 | "url": "https://github.com/sponsors/mysticatea" 536 | } 537 | }, 538 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 539 | "version": "1.3.0", 540 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 541 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 542 | "dev": true, 543 | "engines": { 544 | "node": ">=4" 545 | } 546 | }, 547 | "node_modules/eslint-visitor-keys": { 548 | "version": "2.0.0", 549 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 550 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 551 | "dev": true, 552 | "engines": { 553 | "node": ">=10" 554 | } 555 | }, 556 | "node_modules/espree": { 557 | "version": "7.3.1", 558 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 559 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 560 | "dev": true, 561 | "dependencies": { 562 | "acorn": "^7.4.0", 563 | "acorn-jsx": "^5.3.1", 564 | "eslint-visitor-keys": "^1.3.0" 565 | }, 566 | "engines": { 567 | "node": "^10.12.0 || >=12.0.0" 568 | } 569 | }, 570 | "node_modules/espree/node_modules/eslint-visitor-keys": { 571 | "version": "1.3.0", 572 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 573 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 574 | "dev": true, 575 | "engines": { 576 | "node": ">=4" 577 | } 578 | }, 579 | "node_modules/esprima": { 580 | "version": "4.0.1", 581 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 582 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 583 | "dev": true, 584 | "bin": { 585 | "esparse": "bin/esparse.js", 586 | "esvalidate": "bin/esvalidate.js" 587 | }, 588 | "engines": { 589 | "node": ">=4" 590 | } 591 | }, 592 | "node_modules/esquery": { 593 | "version": "1.3.1", 594 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 595 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 596 | "dev": true, 597 | "dependencies": { 598 | "estraverse": "^5.1.0" 599 | }, 600 | "engines": { 601 | "node": ">=0.10" 602 | } 603 | }, 604 | "node_modules/esquery/node_modules/estraverse": { 605 | "version": "5.2.0", 606 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 607 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 608 | "dev": true, 609 | "engines": { 610 | "node": ">=4.0" 611 | } 612 | }, 613 | "node_modules/esrecurse": { 614 | "version": "4.3.0", 615 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 616 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 617 | "dev": true, 618 | "dependencies": { 619 | "estraverse": "^5.2.0" 620 | }, 621 | "engines": { 622 | "node": ">=4.0" 623 | } 624 | }, 625 | "node_modules/esrecurse/node_modules/estraverse": { 626 | "version": "5.2.0", 627 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 628 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 629 | "dev": true, 630 | "engines": { 631 | "node": ">=4.0" 632 | } 633 | }, 634 | "node_modules/estraverse": { 635 | "version": "4.3.0", 636 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 637 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 638 | "dev": true, 639 | "engines": { 640 | "node": ">=4.0" 641 | } 642 | }, 643 | "node_modules/esutils": { 644 | "version": "2.0.3", 645 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 646 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 647 | "dev": true, 648 | "engines": { 649 | "node": ">=0.10.0" 650 | } 651 | }, 652 | "node_modules/event-stream": { 653 | "version": "3.3.4", 654 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 655 | "integrity": "sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=", 656 | "dependencies": { 657 | "duplexer": "~0.1.1", 658 | "from": "~0", 659 | "map-stream": "~0.1.0", 660 | "pause-stream": "0.0.11", 661 | "split": "0.3", 662 | "stream-combiner": "~0.0.4", 663 | "through": "~2.3.1" 664 | } 665 | }, 666 | "node_modules/fast-deep-equal": { 667 | "version": "3.1.3", 668 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 669 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 670 | "dev": true 671 | }, 672 | "node_modules/fast-json-stable-stringify": { 673 | "version": "2.1.0", 674 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 675 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 676 | "dev": true 677 | }, 678 | "node_modules/fast-levenshtein": { 679 | "version": "2.0.6", 680 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 681 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 682 | "dev": true 683 | }, 684 | "node_modules/file-entry-cache": { 685 | "version": "6.0.0", 686 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.0.tgz", 687 | "integrity": "sha512-fqoO76jZ3ZnYrXLDRxBR1YvOvc0k844kcOg40bgsPrE25LAb/PDqTY+ho64Xh2c8ZXgIKldchCFHczG2UVRcWA==", 688 | "dev": true, 689 | "dependencies": { 690 | "flat-cache": "^3.0.4" 691 | }, 692 | "engines": { 693 | "node": "^10.12.0 || >=12.0.0" 694 | } 695 | }, 696 | "node_modules/file-uri-to-path": { 697 | "version": "1.0.0", 698 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", 699 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", 700 | "optional": true 701 | }, 702 | "node_modules/flat-cache": { 703 | "version": "3.0.4", 704 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 705 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 706 | "dev": true, 707 | "dependencies": { 708 | "flatted": "^3.1.0", 709 | "rimraf": "^3.0.2" 710 | }, 711 | "engines": { 712 | "node": "^10.12.0 || >=12.0.0" 713 | } 714 | }, 715 | "node_modules/flatted": { 716 | "version": "3.1.0", 717 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.0.tgz", 718 | "integrity": "sha512-tW+UkmtNg/jv9CSofAKvgVcO7c2URjhTdW1ZTkcAritblu8tajiYy7YisnIflEwtKssCtOxpnBRoCB7iap0/TA==", 719 | "dev": true 720 | }, 721 | "node_modules/from": { 722 | "version": "0.1.7", 723 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 724 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=" 725 | }, 726 | "node_modules/fs.realpath": { 727 | "version": "1.0.0", 728 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 729 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 730 | "dev": true 731 | }, 732 | "node_modules/functional-red-black-tree": { 733 | "version": "1.0.1", 734 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 735 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 736 | "dev": true 737 | }, 738 | "node_modules/glob": { 739 | "version": "7.1.6", 740 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 741 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 742 | "dev": true, 743 | "dependencies": { 744 | "fs.realpath": "^1.0.0", 745 | "inflight": "^1.0.4", 746 | "inherits": "2", 747 | "minimatch": "^3.0.4", 748 | "once": "^1.3.0", 749 | "path-is-absolute": "^1.0.0" 750 | }, 751 | "engines": { 752 | "node": "*" 753 | }, 754 | "funding": { 755 | "url": "https://github.com/sponsors/isaacs" 756 | } 757 | }, 758 | "node_modules/glob-parent": { 759 | "version": "5.1.1", 760 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 761 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 762 | "dev": true, 763 | "dependencies": { 764 | "is-glob": "^4.0.1" 765 | }, 766 | "engines": { 767 | "node": ">= 6" 768 | } 769 | }, 770 | "node_modules/globals": { 771 | "version": "12.4.0", 772 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 773 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 774 | "dev": true, 775 | "dependencies": { 776 | "type-fest": "^0.8.1" 777 | }, 778 | "engines": { 779 | "node": ">=8" 780 | }, 781 | "funding": { 782 | "url": "https://github.com/sponsors/sindresorhus" 783 | } 784 | }, 785 | "node_modules/graceful-fs": { 786 | "version": "4.2.4", 787 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 788 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 789 | "dev": true 790 | }, 791 | "node_modules/has-flag": { 792 | "version": "4.0.0", 793 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 794 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 795 | "dev": true, 796 | "engines": { 797 | "node": ">=8" 798 | } 799 | }, 800 | "node_modules/hexy": { 801 | "version": "0.2.11", 802 | "resolved": "https://registry.npmjs.org/hexy/-/hexy-0.2.11.tgz", 803 | "integrity": "sha512-ciq6hFsSG/Bpt2DmrZJtv+56zpPdnq+NQ4ijEFrveKN0ZG1mhl/LdT1NQZ9se6ty1fACcI4d4vYqC9v8EYpH2A==", 804 | "bin": { 805 | "hexy": "bin/hexy_cmd.js" 806 | } 807 | }, 808 | "node_modules/ignore": { 809 | "version": "4.0.6", 810 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 811 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 812 | "dev": true, 813 | "engines": { 814 | "node": ">= 4" 815 | } 816 | }, 817 | "node_modules/import-fresh": { 818 | "version": "3.3.0", 819 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 820 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 821 | "dev": true, 822 | "dependencies": { 823 | "parent-module": "^1.0.0", 824 | "resolve-from": "^4.0.0" 825 | }, 826 | "engines": { 827 | "node": ">=6" 828 | }, 829 | "funding": { 830 | "url": "https://github.com/sponsors/sindresorhus" 831 | } 832 | }, 833 | "node_modules/imurmurhash": { 834 | "version": "0.1.4", 835 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 836 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 837 | "dev": true, 838 | "engines": { 839 | "node": ">=0.8.19" 840 | } 841 | }, 842 | "node_modules/inflight": { 843 | "version": "1.0.6", 844 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 845 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 846 | "dev": true, 847 | "dependencies": { 848 | "once": "^1.3.0", 849 | "wrappy": "1" 850 | } 851 | }, 852 | "node_modules/inherits": { 853 | "version": "2.0.4", 854 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 855 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 856 | "dev": true 857 | }, 858 | "node_modules/is-extglob": { 859 | "version": "2.1.1", 860 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 861 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 862 | "dev": true, 863 | "engines": { 864 | "node": ">=0.10.0" 865 | } 866 | }, 867 | "node_modules/is-fullwidth-code-point": { 868 | "version": "3.0.0", 869 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 870 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 871 | "dev": true, 872 | "engines": { 873 | "node": ">=8" 874 | } 875 | }, 876 | "node_modules/is-glob": { 877 | "version": "4.0.1", 878 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 879 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 880 | "dev": true, 881 | "dependencies": { 882 | "is-extglob": "^2.1.1" 883 | }, 884 | "engines": { 885 | "node": ">=0.10.0" 886 | } 887 | }, 888 | "node_modules/isexe": { 889 | "version": "2.0.0", 890 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 891 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 892 | "dev": true 893 | }, 894 | "node_modules/js-tokens": { 895 | "version": "4.0.0", 896 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 897 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 898 | "dev": true 899 | }, 900 | "node_modules/js-yaml": { 901 | "version": "3.14.1", 902 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 903 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 904 | "dev": true, 905 | "dependencies": { 906 | "argparse": "^1.0.7", 907 | "esprima": "^4.0.0" 908 | }, 909 | "bin": { 910 | "js-yaml": "bin/js-yaml.js" 911 | } 912 | }, 913 | "node_modules/js2xmlparser": { 914 | "version": "4.0.1", 915 | "resolved": "https://registry.npmjs.org/js2xmlparser/-/js2xmlparser-4.0.1.tgz", 916 | "integrity": "sha512-KrPTolcw6RocpYjdC7pL7v62e55q7qOMHvLX1UCLc5AAS8qeJ6nukarEJAF2KL2PZxlbGueEbINqZR2bDe/gUw==", 917 | "dev": true, 918 | "dependencies": { 919 | "xmlcreate": "^2.0.3" 920 | } 921 | }, 922 | "node_modules/jsbi": { 923 | "version": "2.0.5", 924 | "resolved": "https://registry.npmjs.org/jsbi/-/jsbi-2.0.5.tgz", 925 | "integrity": "sha512-TzO/62Hxeb26QMb4IGlI/5X+QLr9Uqp1FPkwp2+KOICW+Q+vSuFj61c8pkT6wAns4WcK56X7CmSHhJeDGWOqxQ==" 926 | }, 927 | "node_modules/jsdoc": { 928 | "version": "3.6.6", 929 | "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-3.6.6.tgz", 930 | "integrity": "sha512-znR99e1BHeyEkSvgDDpX0sTiTu+8aQyDl9DawrkOGZTTW8hv0deIFXx87114zJ7gRaDZKVQD/4tr1ifmJp9xhQ==", 931 | "dev": true, 932 | "dependencies": { 933 | "@babel/parser": "^7.9.4", 934 | "bluebird": "^3.7.2", 935 | "catharsis": "^0.8.11", 936 | "escape-string-regexp": "^2.0.0", 937 | "js2xmlparser": "^4.0.1", 938 | "klaw": "^3.0.0", 939 | "markdown-it": "^10.0.0", 940 | "markdown-it-anchor": "^5.2.7", 941 | "marked": "^0.8.2", 942 | "mkdirp": "^1.0.4", 943 | "requizzle": "^0.2.3", 944 | "strip-json-comments": "^3.1.0", 945 | "taffydb": "2.6.2", 946 | "underscore": "~1.10.2" 947 | }, 948 | "bin": { 949 | "jsdoc": "jsdoc.js" 950 | }, 951 | "engines": { 952 | "node": ">=8.15.0" 953 | } 954 | }, 955 | "node_modules/jsdoc/node_modules/escape-string-regexp": { 956 | "version": "2.0.0", 957 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 958 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 959 | "dev": true, 960 | "engines": { 961 | "node": ">=8" 962 | } 963 | }, 964 | "node_modules/json-schema-traverse": { 965 | "version": "0.4.1", 966 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 967 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 968 | "dev": true 969 | }, 970 | "node_modules/json-stable-stringify-without-jsonify": { 971 | "version": "1.0.1", 972 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 973 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 974 | "dev": true 975 | }, 976 | "node_modules/klaw": { 977 | "version": "3.0.0", 978 | "resolved": "https://registry.npmjs.org/klaw/-/klaw-3.0.0.tgz", 979 | "integrity": "sha512-0Fo5oir+O9jnXu5EefYbVK+mHMBeEVEy2cmctR1O1NECcCkPRreJKrS6Qt/j3KC2C148Dfo9i3pCmCMsdqGr0g==", 980 | "dev": true, 981 | "dependencies": { 982 | "graceful-fs": "^4.1.9" 983 | } 984 | }, 985 | "node_modules/levn": { 986 | "version": "0.4.1", 987 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 988 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 989 | "dev": true, 990 | "dependencies": { 991 | "prelude-ls": "^1.2.1", 992 | "type-check": "~0.4.0" 993 | }, 994 | "engines": { 995 | "node": ">= 0.8.0" 996 | } 997 | }, 998 | "node_modules/linkify-it": { 999 | "version": "2.2.0", 1000 | "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-2.2.0.tgz", 1001 | "integrity": "sha512-GnAl/knGn+i1U/wjBz3akz2stz+HrHLsxMwHQGofCDfPvlf+gDKN58UtfmUquTY4/MXeE2x7k19KQmeoZi94Iw==", 1002 | "dev": true, 1003 | "dependencies": { 1004 | "uc.micro": "^1.0.1" 1005 | } 1006 | }, 1007 | "node_modules/lodash": { 1008 | "version": "4.17.20", 1009 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", 1010 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==", 1011 | "dev": true 1012 | }, 1013 | "node_modules/long": { 1014 | "version": "4.0.0", 1015 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1016 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 1017 | }, 1018 | "node_modules/lru-cache": { 1019 | "version": "6.0.0", 1020 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1021 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1022 | "dev": true, 1023 | "dependencies": { 1024 | "yallist": "^4.0.0" 1025 | }, 1026 | "engines": { 1027 | "node": ">=10" 1028 | } 1029 | }, 1030 | "node_modules/map-stream": { 1031 | "version": "0.1.0", 1032 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 1033 | "integrity": "sha1-5WqpTEyAVaFkBKBnS3jyFffI4ZQ=" 1034 | }, 1035 | "node_modules/markdown-it": { 1036 | "version": "10.0.0", 1037 | "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-10.0.0.tgz", 1038 | "integrity": "sha512-YWOP1j7UbDNz+TumYP1kpwnP0aEa711cJjrAQrzd0UXlbJfc5aAq0F/PZHjiioqDC1NKgvIMX+o+9Bk7yuM2dg==", 1039 | "dev": true, 1040 | "dependencies": { 1041 | "argparse": "^1.0.7", 1042 | "entities": "~2.0.0", 1043 | "linkify-it": "^2.0.0", 1044 | "mdurl": "^1.0.1", 1045 | "uc.micro": "^1.0.5" 1046 | }, 1047 | "bin": { 1048 | "markdown-it": "bin/markdown-it.js" 1049 | } 1050 | }, 1051 | "node_modules/markdown-it-anchor": { 1052 | "version": "5.3.0", 1053 | "resolved": "https://registry.npmjs.org/markdown-it-anchor/-/markdown-it-anchor-5.3.0.tgz", 1054 | "integrity": "sha512-/V1MnLL/rgJ3jkMWo84UR+K+jF1cxNG1a+KwqeXqTIJ+jtA8aWSHuigx8lTzauiIjBDbwF3NcWQMotd0Dm39jA==", 1055 | "dev": true, 1056 | "peerDependencies": { 1057 | "markdown-it": "*" 1058 | } 1059 | }, 1060 | "node_modules/marked": { 1061 | "version": "0.8.2", 1062 | "resolved": "https://registry.npmjs.org/marked/-/marked-0.8.2.tgz", 1063 | "integrity": "sha512-EGwzEeCcLniFX51DhTpmTom+dSA/MG/OBUDjnWtHbEnjAH180VzUeAw+oE4+Zv+CoYBWyRlYOTR0N8SO9R1PVw==", 1064 | "dev": true, 1065 | "bin": { 1066 | "marked": "bin/marked" 1067 | }, 1068 | "engines": { 1069 | "node": ">= 8.16.2" 1070 | } 1071 | }, 1072 | "node_modules/mdurl": { 1073 | "version": "1.0.1", 1074 | "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz", 1075 | "integrity": "sha1-/oWy7HWlkDfyrf7BAP1sYBdhFS4=", 1076 | "dev": true 1077 | }, 1078 | "node_modules/minimatch": { 1079 | "version": "3.0.4", 1080 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1081 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1082 | "dev": true, 1083 | "dependencies": { 1084 | "brace-expansion": "^1.1.7" 1085 | }, 1086 | "engines": { 1087 | "node": "*" 1088 | } 1089 | }, 1090 | "node_modules/mkdirp": { 1091 | "version": "1.0.4", 1092 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1093 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1094 | "dev": true, 1095 | "bin": { 1096 | "mkdirp": "bin/cmd.js" 1097 | }, 1098 | "engines": { 1099 | "node": ">=10" 1100 | } 1101 | }, 1102 | "node_modules/ms": { 1103 | "version": "2.1.2", 1104 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1105 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1106 | "dev": true 1107 | }, 1108 | "node_modules/nan": { 1109 | "version": "2.14.2", 1110 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz", 1111 | "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==", 1112 | "optional": true 1113 | }, 1114 | "node_modules/natural-compare": { 1115 | "version": "1.4.0", 1116 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1117 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1118 | "dev": true 1119 | }, 1120 | "node_modules/once": { 1121 | "version": "1.4.0", 1122 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1123 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1124 | "dev": true, 1125 | "dependencies": { 1126 | "wrappy": "1" 1127 | } 1128 | }, 1129 | "node_modules/optionator": { 1130 | "version": "0.9.1", 1131 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1132 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1133 | "dev": true, 1134 | "dependencies": { 1135 | "deep-is": "^0.1.3", 1136 | "fast-levenshtein": "^2.0.6", 1137 | "levn": "^0.4.1", 1138 | "prelude-ls": "^1.2.1", 1139 | "type-check": "^0.4.0", 1140 | "word-wrap": "^1.2.3" 1141 | }, 1142 | "engines": { 1143 | "node": ">= 0.8.0" 1144 | } 1145 | }, 1146 | "node_modules/parent-module": { 1147 | "version": "1.0.1", 1148 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1149 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1150 | "dev": true, 1151 | "dependencies": { 1152 | "callsites": "^3.0.0" 1153 | }, 1154 | "engines": { 1155 | "node": ">=6" 1156 | } 1157 | }, 1158 | "node_modules/path-is-absolute": { 1159 | "version": "1.0.1", 1160 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1161 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1162 | "dev": true, 1163 | "engines": { 1164 | "node": ">=0.10.0" 1165 | } 1166 | }, 1167 | "node_modules/path-key": { 1168 | "version": "3.1.1", 1169 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1170 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1171 | "dev": true, 1172 | "engines": { 1173 | "node": ">=8" 1174 | } 1175 | }, 1176 | "node_modules/pause-stream": { 1177 | "version": "0.0.11", 1178 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1179 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 1180 | "dependencies": { 1181 | "through": "~2.3" 1182 | } 1183 | }, 1184 | "node_modules/prelude-ls": { 1185 | "version": "1.2.1", 1186 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1187 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1188 | "dev": true, 1189 | "engines": { 1190 | "node": ">= 0.8.0" 1191 | } 1192 | }, 1193 | "node_modules/progress": { 1194 | "version": "2.0.3", 1195 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1196 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1197 | "dev": true, 1198 | "engines": { 1199 | "node": ">=0.4.0" 1200 | } 1201 | }, 1202 | "node_modules/punycode": { 1203 | "version": "2.1.1", 1204 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1205 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1206 | "dev": true, 1207 | "engines": { 1208 | "node": ">=6" 1209 | } 1210 | }, 1211 | "node_modules/regexpp": { 1212 | "version": "3.1.0", 1213 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 1214 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 1215 | "dev": true, 1216 | "engines": { 1217 | "node": ">=8" 1218 | }, 1219 | "funding": { 1220 | "url": "https://github.com/sponsors/mysticatea" 1221 | } 1222 | }, 1223 | "node_modules/require-from-string": { 1224 | "version": "2.0.2", 1225 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 1226 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 1227 | "dev": true, 1228 | "engines": { 1229 | "node": ">=0.10.0" 1230 | } 1231 | }, 1232 | "node_modules/requizzle": { 1233 | "version": "0.2.3", 1234 | "resolved": "https://registry.npmjs.org/requizzle/-/requizzle-0.2.3.tgz", 1235 | "integrity": "sha512-YanoyJjykPxGHii0fZP0uUPEXpvqfBDxWV7s6GKAiiOsiqhX6vHNyW3Qzdmqp/iq/ExbhaGbVrjB4ruEVSM4GQ==", 1236 | "dev": true, 1237 | "dependencies": { 1238 | "lodash": "^4.17.14" 1239 | } 1240 | }, 1241 | "node_modules/resolve-from": { 1242 | "version": "4.0.0", 1243 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1244 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1245 | "dev": true, 1246 | "engines": { 1247 | "node": ">=4" 1248 | } 1249 | }, 1250 | "node_modules/rimraf": { 1251 | "version": "3.0.2", 1252 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1253 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1254 | "dev": true, 1255 | "dependencies": { 1256 | "glob": "^7.1.3" 1257 | }, 1258 | "bin": { 1259 | "rimraf": "bin.js" 1260 | }, 1261 | "funding": { 1262 | "url": "https://github.com/sponsors/isaacs" 1263 | } 1264 | }, 1265 | "node_modules/safe-buffer": { 1266 | "version": "5.2.1", 1267 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1268 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1269 | "funding": [ 1270 | { 1271 | "type": "github", 1272 | "url": "https://github.com/sponsors/feross" 1273 | }, 1274 | { 1275 | "type": "patreon", 1276 | "url": "https://www.patreon.com/feross" 1277 | }, 1278 | { 1279 | "type": "consulting", 1280 | "url": "https://feross.org/support" 1281 | } 1282 | ] 1283 | }, 1284 | "node_modules/sax": { 1285 | "version": "1.2.4", 1286 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 1287 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 1288 | }, 1289 | "node_modules/semver": { 1290 | "version": "7.3.4", 1291 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", 1292 | "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", 1293 | "dev": true, 1294 | "dependencies": { 1295 | "lru-cache": "^6.0.0" 1296 | }, 1297 | "bin": { 1298 | "semver": "bin/semver.js" 1299 | }, 1300 | "engines": { 1301 | "node": ">=10" 1302 | } 1303 | }, 1304 | "node_modules/shebang-command": { 1305 | "version": "2.0.0", 1306 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1307 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1308 | "dev": true, 1309 | "dependencies": { 1310 | "shebang-regex": "^3.0.0" 1311 | }, 1312 | "engines": { 1313 | "node": ">=8" 1314 | } 1315 | }, 1316 | "node_modules/shebang-regex": { 1317 | "version": "3.0.0", 1318 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1319 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1320 | "dev": true, 1321 | "engines": { 1322 | "node": ">=8" 1323 | } 1324 | }, 1325 | "node_modules/slice-ansi": { 1326 | "version": "4.0.0", 1327 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1328 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1329 | "dev": true, 1330 | "dependencies": { 1331 | "ansi-styles": "^4.0.0", 1332 | "astral-regex": "^2.0.0", 1333 | "is-fullwidth-code-point": "^3.0.0" 1334 | }, 1335 | "engines": { 1336 | "node": ">=10" 1337 | }, 1338 | "funding": { 1339 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1340 | } 1341 | }, 1342 | "node_modules/split": { 1343 | "version": "0.3.3", 1344 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 1345 | "integrity": "sha1-zQ7qXmOiEd//frDwkcQTPi0N0o8=", 1346 | "dependencies": { 1347 | "through": "2" 1348 | }, 1349 | "engines": { 1350 | "node": "*" 1351 | } 1352 | }, 1353 | "node_modules/sprintf-js": { 1354 | "version": "1.0.3", 1355 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1356 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1357 | "dev": true 1358 | }, 1359 | "node_modules/stream-combiner": { 1360 | "version": "0.0.4", 1361 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 1362 | "integrity": "sha1-TV5DPBhSYd3mI8o/RMWGvPXErRQ=", 1363 | "dependencies": { 1364 | "duplexer": "~0.1.1" 1365 | } 1366 | }, 1367 | "node_modules/string-width": { 1368 | "version": "4.2.0", 1369 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1370 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1371 | "dev": true, 1372 | "dependencies": { 1373 | "emoji-regex": "^8.0.0", 1374 | "is-fullwidth-code-point": "^3.0.0", 1375 | "strip-ansi": "^6.0.0" 1376 | }, 1377 | "engines": { 1378 | "node": ">=8" 1379 | } 1380 | }, 1381 | "node_modules/strip-ansi": { 1382 | "version": "6.0.0", 1383 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1384 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1385 | "dev": true, 1386 | "dependencies": { 1387 | "ansi-regex": "^5.0.0" 1388 | }, 1389 | "engines": { 1390 | "node": ">=8" 1391 | } 1392 | }, 1393 | "node_modules/strip-json-comments": { 1394 | "version": "3.1.1", 1395 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1396 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1397 | "dev": true, 1398 | "engines": { 1399 | "node": ">=8" 1400 | }, 1401 | "funding": { 1402 | "url": "https://github.com/sponsors/sindresorhus" 1403 | } 1404 | }, 1405 | "node_modules/supports-color": { 1406 | "version": "7.2.0", 1407 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1408 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1409 | "dev": true, 1410 | "dependencies": { 1411 | "has-flag": "^4.0.0" 1412 | }, 1413 | "engines": { 1414 | "node": ">=8" 1415 | } 1416 | }, 1417 | "node_modules/table": { 1418 | "version": "6.0.7", 1419 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz", 1420 | "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==", 1421 | "dev": true, 1422 | "dependencies": { 1423 | "ajv": "^7.0.2", 1424 | "lodash": "^4.17.20", 1425 | "slice-ansi": "^4.0.0", 1426 | "string-width": "^4.2.0" 1427 | }, 1428 | "engines": { 1429 | "node": ">=10.0.0" 1430 | } 1431 | }, 1432 | "node_modules/table/node_modules/ajv": { 1433 | "version": "7.0.3", 1434 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.0.3.tgz", 1435 | "integrity": "sha512-R50QRlXSxqXcQP5SvKUrw8VZeypvo12i2IX0EeR5PiZ7bEKeHWgzgo264LDadUsCU42lTJVhFikTqJwNeH34gQ==", 1436 | "dev": true, 1437 | "dependencies": { 1438 | "fast-deep-equal": "^3.1.1", 1439 | "json-schema-traverse": "^1.0.0", 1440 | "require-from-string": "^2.0.2", 1441 | "uri-js": "^4.2.2" 1442 | }, 1443 | "funding": { 1444 | "type": "github", 1445 | "url": "https://github.com/sponsors/epoberezkin" 1446 | } 1447 | }, 1448 | "node_modules/table/node_modules/json-schema-traverse": { 1449 | "version": "1.0.0", 1450 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 1451 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 1452 | "dev": true 1453 | }, 1454 | "node_modules/taffydb": { 1455 | "version": "2.6.2", 1456 | "resolved": "https://registry.npmjs.org/taffydb/-/taffydb-2.6.2.tgz", 1457 | "integrity": "sha1-fLy2S1oUG2ou/CxdLGe04VCyomg=", 1458 | "dev": true 1459 | }, 1460 | "node_modules/text-table": { 1461 | "version": "0.2.0", 1462 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1463 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1464 | "dev": true 1465 | }, 1466 | "node_modules/through": { 1467 | "version": "2.3.8", 1468 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1469 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 1470 | }, 1471 | "node_modules/type-check": { 1472 | "version": "0.4.0", 1473 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1474 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1475 | "dev": true, 1476 | "dependencies": { 1477 | "prelude-ls": "^1.2.1" 1478 | }, 1479 | "engines": { 1480 | "node": ">= 0.8.0" 1481 | } 1482 | }, 1483 | "node_modules/type-fest": { 1484 | "version": "0.8.1", 1485 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1486 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1487 | "dev": true, 1488 | "engines": { 1489 | "node": ">=8" 1490 | } 1491 | }, 1492 | "node_modules/uc.micro": { 1493 | "version": "1.0.6", 1494 | "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz", 1495 | "integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==", 1496 | "dev": true 1497 | }, 1498 | "node_modules/underscore": { 1499 | "version": "1.10.2", 1500 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.10.2.tgz", 1501 | "integrity": "sha512-N4P+Q/BuyuEKFJ43B9gYuOj4TQUHXX+j2FqguVOpjkssLUUrnJofCcBccJSCoeturDoZU6GorDTHSvUDlSQbTg==", 1502 | "dev": true 1503 | }, 1504 | "node_modules/uri-js": { 1505 | "version": "4.4.1", 1506 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1507 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1508 | "dev": true, 1509 | "dependencies": { 1510 | "punycode": "^2.1.0" 1511 | } 1512 | }, 1513 | "node_modules/v8-compile-cache": { 1514 | "version": "2.2.0", 1515 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.2.0.tgz", 1516 | "integrity": "sha512-gTpR5XQNKFwOd4clxfnhaqvfqMpqEwr4tOtCyz4MtYZX2JYhfr1JvBFKdS+7K/9rfpZR3VLX+YWBbKoxCgS43Q==", 1517 | "dev": true 1518 | }, 1519 | "node_modules/which": { 1520 | "version": "2.0.2", 1521 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1522 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1523 | "dev": true, 1524 | "dependencies": { 1525 | "isexe": "^2.0.0" 1526 | }, 1527 | "bin": { 1528 | "node-which": "bin/node-which" 1529 | }, 1530 | "engines": { 1531 | "node": ">= 8" 1532 | } 1533 | }, 1534 | "node_modules/word-wrap": { 1535 | "version": "1.2.3", 1536 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1537 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1538 | "dev": true, 1539 | "engines": { 1540 | "node": ">=0.10.0" 1541 | } 1542 | }, 1543 | "node_modules/wrappy": { 1544 | "version": "1.0.2", 1545 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1546 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1547 | "dev": true 1548 | }, 1549 | "node_modules/xml2js": { 1550 | "version": "0.4.23", 1551 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz", 1552 | "integrity": "sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug==", 1553 | "dependencies": { 1554 | "sax": ">=0.6.0", 1555 | "xmlbuilder": "~11.0.0" 1556 | }, 1557 | "engines": { 1558 | "node": ">=4.0.0" 1559 | } 1560 | }, 1561 | "node_modules/xmlbuilder": { 1562 | "version": "11.0.1", 1563 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz", 1564 | "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==", 1565 | "engines": { 1566 | "node": ">=4.0" 1567 | } 1568 | }, 1569 | "node_modules/xmlcreate": { 1570 | "version": "2.0.3", 1571 | "resolved": "https://registry.npmjs.org/xmlcreate/-/xmlcreate-2.0.3.tgz", 1572 | "integrity": "sha512-HgS+X6zAztGa9zIK3Y3LXuJes33Lz9x+YyTxgrkIdabu2vqcGOWwdfCpf1hWLRrd553wd4QCDf6BBO6FfdsRiQ==", 1573 | "dev": true 1574 | }, 1575 | "node_modules/yallist": { 1576 | "version": "4.0.0", 1577 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1578 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1579 | "dev": true 1580 | } 1581 | }, 1582 | "dependencies": { 1583 | "@babel/code-frame": { 1584 | "version": "7.12.11", 1585 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", 1586 | "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", 1587 | "dev": true, 1588 | "requires": { 1589 | "@babel/highlight": "^7.10.4" 1590 | } 1591 | }, 1592 | "@babel/helper-validator-identifier": { 1593 | "version": "7.12.11", 1594 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.12.11.tgz", 1595 | "integrity": "sha512-np/lG3uARFybkoHokJUmf1QfEvRVCPbmQeUQpKow5cQ3xWrV9i3rUHodKDJPQfTVX61qKi+UdYk8kik84n7XOw==", 1596 | "dev": true 1597 | }, 1598 | "@babel/highlight": { 1599 | "version": "7.10.4", 1600 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 1601 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 1602 | "dev": true, 1603 | "requires": { 1604 | "@babel/helper-validator-identifier": "^7.10.4", 1605 | "chalk": "^2.0.0", 1606 | "js-tokens": "^4.0.0" 1607 | }, 1608 | "dependencies": { 1609 | "ansi-styles": { 1610 | "version": "3.2.1", 1611 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1612 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1613 | "dev": true, 1614 | "requires": { 1615 | "color-convert": "^1.9.0" 1616 | } 1617 | }, 1618 | "chalk": { 1619 | "version": "2.4.2", 1620 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1621 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1622 | "dev": true, 1623 | "requires": { 1624 | "ansi-styles": "^3.2.1", 1625 | "escape-string-regexp": "^1.0.5", 1626 | "supports-color": "^5.3.0" 1627 | } 1628 | }, 1629 | "color-convert": { 1630 | "version": "1.9.3", 1631 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1632 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1633 | "dev": true, 1634 | "requires": { 1635 | "color-name": "1.1.3" 1636 | } 1637 | }, 1638 | "color-name": { 1639 | "version": "1.1.3", 1640 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1641 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 1642 | "dev": true 1643 | }, 1644 | "has-flag": { 1645 | "version": "3.0.0", 1646 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1647 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1648 | "dev": true 1649 | }, 1650 | "supports-color": { 1651 | "version": "5.5.0", 1652 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1653 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1654 | "dev": true, 1655 | "requires": { 1656 | "has-flag": "^3.0.0" 1657 | } 1658 | } 1659 | } 1660 | }, 1661 | "@babel/parser": { 1662 | "version": "7.12.11", 1663 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.12.11.tgz", 1664 | "integrity": "sha512-N3UxG+uuF4CMYoNj8AhnbAcJF0PiuJ9KHuy1lQmkYsxTer/MAH9UBNHsBoAX/4s6NvlDD047No8mYVGGzLL4hg==", 1665 | "dev": true 1666 | }, 1667 | "@eslint/eslintrc": { 1668 | "version": "0.2.2", 1669 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.2.2.tgz", 1670 | "integrity": "sha512-EfB5OHNYp1F4px/LI/FEnGylop7nOqkQ1LRzCM0KccA2U8tvV8w01KBv37LbO7nW4H+YhKyo2LcJhRwjjV17QQ==", 1671 | "dev": true, 1672 | "requires": { 1673 | "ajv": "^6.12.4", 1674 | "debug": "^4.1.1", 1675 | "espree": "^7.3.0", 1676 | "globals": "^12.1.0", 1677 | "ignore": "^4.0.6", 1678 | "import-fresh": "^3.2.1", 1679 | "js-yaml": "^3.13.1", 1680 | "lodash": "^4.17.19", 1681 | "minimatch": "^3.0.4", 1682 | "strip-json-comments": "^3.1.1" 1683 | } 1684 | }, 1685 | "@nornagon/put": { 1686 | "version": "0.0.8", 1687 | "resolved": "https://registry.npmjs.org/@nornagon/put/-/put-0.0.8.tgz", 1688 | "integrity": "sha512-ugvXJjwF5ldtUpa7D95kruNJ41yFQDEKyF5CW4TgKJnh+W/zmlBzXXeKTyqIgwMFrkePN2JqOBqcF0M0oOunow==" 1689 | }, 1690 | "abstract-socket": { 1691 | "version": "2.1.1", 1692 | "resolved": "https://registry.npmjs.org/abstract-socket/-/abstract-socket-2.1.1.tgz", 1693 | "integrity": "sha512-YZJizsvS1aBua5Gd01woe4zuyYBGgSMeqDOB6/ChwdTI904KP6QGtJswXl4hcqWxbz86hQBe++HWV0hF1aGUtA==", 1694 | "optional": true, 1695 | "requires": { 1696 | "bindings": "^1.2.1", 1697 | "nan": "^2.12.1" 1698 | } 1699 | }, 1700 | "acorn": { 1701 | "version": "7.4.1", 1702 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 1703 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 1704 | "dev": true 1705 | }, 1706 | "acorn-jsx": { 1707 | "version": "5.3.1", 1708 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", 1709 | "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", 1710 | "dev": true, 1711 | "requires": {} 1712 | }, 1713 | "ajv": { 1714 | "version": "6.12.6", 1715 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1716 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1717 | "dev": true, 1718 | "requires": { 1719 | "fast-deep-equal": "^3.1.1", 1720 | "fast-json-stable-stringify": "^2.0.0", 1721 | "json-schema-traverse": "^0.4.1", 1722 | "uri-js": "^4.2.2" 1723 | } 1724 | }, 1725 | "ansi-colors": { 1726 | "version": "4.1.1", 1727 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 1728 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 1729 | "dev": true 1730 | }, 1731 | "ansi-regex": { 1732 | "version": "5.0.0", 1733 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1734 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 1735 | "dev": true 1736 | }, 1737 | "ansi-styles": { 1738 | "version": "4.3.0", 1739 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1740 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1741 | "dev": true, 1742 | "requires": { 1743 | "color-convert": "^2.0.1" 1744 | } 1745 | }, 1746 | "argparse": { 1747 | "version": "1.0.10", 1748 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 1749 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 1750 | "dev": true, 1751 | "requires": { 1752 | "sprintf-js": "~1.0.2" 1753 | } 1754 | }, 1755 | "astral-regex": { 1756 | "version": "2.0.0", 1757 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 1758 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 1759 | "dev": true 1760 | }, 1761 | "balanced-match": { 1762 | "version": "1.0.0", 1763 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1764 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 1765 | "dev": true 1766 | }, 1767 | "bindings": { 1768 | "version": "1.5.0", 1769 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", 1770 | "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", 1771 | "optional": true, 1772 | "requires": { 1773 | "file-uri-to-path": "1.0.0" 1774 | } 1775 | }, 1776 | "bluebird": { 1777 | "version": "3.7.2", 1778 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", 1779 | "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", 1780 | "dev": true 1781 | }, 1782 | "brace-expansion": { 1783 | "version": "1.1.11", 1784 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1785 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1786 | "dev": true, 1787 | "requires": { 1788 | "balanced-match": "^1.0.0", 1789 | "concat-map": "0.0.1" 1790 | } 1791 | }, 1792 | "callsites": { 1793 | "version": "3.1.0", 1794 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1795 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1796 | "dev": true 1797 | }, 1798 | "catharsis": { 1799 | "version": "0.8.11", 1800 | "resolved": "https://registry.npmjs.org/catharsis/-/catharsis-0.8.11.tgz", 1801 | "integrity": "sha512-a+xUyMV7hD1BrDQA/3iPV7oc+6W26BgVJO05PGEoatMyIuPScQKsde6i3YorWX1qs+AZjnJ18NqdKoCtKiNh1g==", 1802 | "dev": true, 1803 | "requires": { 1804 | "lodash": "^4.17.14" 1805 | } 1806 | }, 1807 | "chalk": { 1808 | "version": "4.1.0", 1809 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1810 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1811 | "dev": true, 1812 | "requires": { 1813 | "ansi-styles": "^4.1.0", 1814 | "supports-color": "^7.1.0" 1815 | } 1816 | }, 1817 | "color-convert": { 1818 | "version": "2.0.1", 1819 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1820 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1821 | "dev": true, 1822 | "requires": { 1823 | "color-name": "~1.1.4" 1824 | } 1825 | }, 1826 | "color-name": { 1827 | "version": "1.1.4", 1828 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1829 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1830 | "dev": true 1831 | }, 1832 | "concat-map": { 1833 | "version": "0.0.1", 1834 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1835 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1836 | "dev": true 1837 | }, 1838 | "cross-spawn": { 1839 | "version": "7.0.3", 1840 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1841 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1842 | "dev": true, 1843 | "requires": { 1844 | "path-key": "^3.1.0", 1845 | "shebang-command": "^2.0.0", 1846 | "which": "^2.0.1" 1847 | } 1848 | }, 1849 | "dbus-next": { 1850 | "version": "0.9.1", 1851 | "resolved": "https://registry.npmjs.org/dbus-next/-/dbus-next-0.9.1.tgz", 1852 | "integrity": "sha512-HTFKjrcNcjdjNlZR+/5LlUHBw13d+ZHQA51tfn8xUzm3WYi7uWQ99M8M4bttATCth3l4G/fxu3XC97JZ5K0oSQ==", 1853 | "requires": { 1854 | "@nornagon/put": "0.0.8", 1855 | "abstract-socket": "^2.0.0", 1856 | "event-stream": "3.3.4", 1857 | "hexy": "^0.2.10", 1858 | "jsbi": "^2.0.5", 1859 | "long": "^4.0.0", 1860 | "safe-buffer": "^5.1.1", 1861 | "xml2js": "^0.4.17" 1862 | } 1863 | }, 1864 | "debug": { 1865 | "version": "4.3.1", 1866 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz", 1867 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==", 1868 | "dev": true, 1869 | "requires": { 1870 | "ms": "2.1.2" 1871 | } 1872 | }, 1873 | "deep-is": { 1874 | "version": "0.1.3", 1875 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 1876 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 1877 | "dev": true 1878 | }, 1879 | "docdash": { 1880 | "version": "1.2.0", 1881 | "resolved": "https://registry.npmjs.org/docdash/-/docdash-1.2.0.tgz", 1882 | "integrity": "sha512-IYZbgYthPTspgqYeciRJNPhSwL51yer7HAwDXhF5p+H7mTDbPvY3PCk/QDjNxdPCpWkaJVFC4t7iCNB/t9E5Kw==", 1883 | "dev": true 1884 | }, 1885 | "doctrine": { 1886 | "version": "3.0.0", 1887 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1888 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1889 | "dev": true, 1890 | "requires": { 1891 | "esutils": "^2.0.2" 1892 | } 1893 | }, 1894 | "duplexer": { 1895 | "version": "0.1.2", 1896 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", 1897 | "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==" 1898 | }, 1899 | "emoji-regex": { 1900 | "version": "8.0.0", 1901 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1902 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1903 | "dev": true 1904 | }, 1905 | "enquirer": { 1906 | "version": "2.3.6", 1907 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 1908 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 1909 | "dev": true, 1910 | "requires": { 1911 | "ansi-colors": "^4.1.1" 1912 | } 1913 | }, 1914 | "entities": { 1915 | "version": "2.0.3", 1916 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.0.3.tgz", 1917 | "integrity": "sha512-MyoZ0jgnLvB2X3Lg5HqpFmn1kybDiIfEQmKzTb5apr51Rb+T3KdmMiqa70T+bhGnyv7bQ6WMj2QMHpGMmlrUYQ==", 1918 | "dev": true 1919 | }, 1920 | "escape-string-regexp": { 1921 | "version": "1.0.5", 1922 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1923 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1924 | "dev": true 1925 | }, 1926 | "eslint": { 1927 | "version": "7.17.0", 1928 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.17.0.tgz", 1929 | "integrity": "sha512-zJk08MiBgwuGoxes5sSQhOtibZ75pz0J35XTRlZOk9xMffhpA9BTbQZxoXZzOl5zMbleShbGwtw+1kGferfFwQ==", 1930 | "dev": true, 1931 | "requires": { 1932 | "@babel/code-frame": "^7.0.0", 1933 | "@eslint/eslintrc": "^0.2.2", 1934 | "ajv": "^6.10.0", 1935 | "chalk": "^4.0.0", 1936 | "cross-spawn": "^7.0.2", 1937 | "debug": "^4.0.1", 1938 | "doctrine": "^3.0.0", 1939 | "enquirer": "^2.3.5", 1940 | "eslint-scope": "^5.1.1", 1941 | "eslint-utils": "^2.1.0", 1942 | "eslint-visitor-keys": "^2.0.0", 1943 | "espree": "^7.3.1", 1944 | "esquery": "^1.2.0", 1945 | "esutils": "^2.0.2", 1946 | "file-entry-cache": "^6.0.0", 1947 | "functional-red-black-tree": "^1.0.1", 1948 | "glob-parent": "^5.0.0", 1949 | "globals": "^12.1.0", 1950 | "ignore": "^4.0.6", 1951 | "import-fresh": "^3.0.0", 1952 | "imurmurhash": "^0.1.4", 1953 | "is-glob": "^4.0.0", 1954 | "js-yaml": "^3.13.1", 1955 | "json-stable-stringify-without-jsonify": "^1.0.1", 1956 | "levn": "^0.4.1", 1957 | "lodash": "^4.17.19", 1958 | "minimatch": "^3.0.4", 1959 | "natural-compare": "^1.4.0", 1960 | "optionator": "^0.9.1", 1961 | "progress": "^2.0.0", 1962 | "regexpp": "^3.1.0", 1963 | "semver": "^7.2.1", 1964 | "strip-ansi": "^6.0.0", 1965 | "strip-json-comments": "^3.1.0", 1966 | "table": "^6.0.4", 1967 | "text-table": "^0.2.0", 1968 | "v8-compile-cache": "^2.0.3" 1969 | } 1970 | }, 1971 | "eslint-scope": { 1972 | "version": "5.1.1", 1973 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 1974 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 1975 | "dev": true, 1976 | "requires": { 1977 | "esrecurse": "^4.3.0", 1978 | "estraverse": "^4.1.1" 1979 | } 1980 | }, 1981 | "eslint-utils": { 1982 | "version": "2.1.0", 1983 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", 1984 | "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", 1985 | "dev": true, 1986 | "requires": { 1987 | "eslint-visitor-keys": "^1.1.0" 1988 | }, 1989 | "dependencies": { 1990 | "eslint-visitor-keys": { 1991 | "version": "1.3.0", 1992 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 1993 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 1994 | "dev": true 1995 | } 1996 | } 1997 | }, 1998 | "eslint-visitor-keys": { 1999 | "version": "2.0.0", 2000 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.0.0.tgz", 2001 | "integrity": "sha512-QudtT6av5WXels9WjIM7qz1XD1cWGvX4gGXvp/zBn9nXG02D0utdU3Em2m/QjTnrsk6bBjmCygl3rmj118msQQ==", 2002 | "dev": true 2003 | }, 2004 | "espree": { 2005 | "version": "7.3.1", 2006 | "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", 2007 | "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", 2008 | "dev": true, 2009 | "requires": { 2010 | "acorn": "^7.4.0", 2011 | "acorn-jsx": "^5.3.1", 2012 | "eslint-visitor-keys": "^1.3.0" 2013 | }, 2014 | "dependencies": { 2015 | "eslint-visitor-keys": { 2016 | "version": "1.3.0", 2017 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 2018 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 2019 | "dev": true 2020 | } 2021 | } 2022 | }, 2023 | "esprima": { 2024 | "version": "4.0.1", 2025 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2026 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 2027 | "dev": true 2028 | }, 2029 | "esquery": { 2030 | "version": "1.3.1", 2031 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.3.1.tgz", 2032 | "integrity": "sha512-olpvt9QG0vniUBZspVRN6lwB7hOZoTRtT+jzR+tS4ffYx2mzbw+z0XCOk44aaLYKApNX5nMm+E+P6o25ip/DHQ==", 2033 | "dev": true, 2034 | "requires": { 2035 | "estraverse": "^5.1.0" 2036 | }, 2037 | "dependencies": { 2038 | "estraverse": { 2039 | "version": "5.2.0", 2040 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2041 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2042 | "dev": true 2043 | } 2044 | } 2045 | }, 2046 | "esrecurse": { 2047 | "version": "4.3.0", 2048 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2049 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2050 | "dev": true, 2051 | "requires": { 2052 | "estraverse": "^5.2.0" 2053 | }, 2054 | "dependencies": { 2055 | "estraverse": { 2056 | "version": "5.2.0", 2057 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.2.0.tgz", 2058 | "integrity": "sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==", 2059 | "dev": true 2060 | } 2061 | } 2062 | }, 2063 | "estraverse": { 2064 | "version": "4.3.0", 2065 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 2066 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 2067 | "dev": true 2068 | }, 2069 | "esutils": { 2070 | "version": "2.0.3", 2071 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2072 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2073 | "dev": true 2074 | }, 2075 | "event-stream": { 2076 | "version": "3.3.4", 2077 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 2078 | "integrity": "sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=", 2079 | "requires": { 2080 | "duplexer": "~0.1.1", 2081 | "from": "~0", 2082 | "map-stream": "~0.1.0", 2083 | "pause-stream": "0.0.11", 2084 | "split": "0.3", 2085 | "stream-combiner": "~0.0.4", 2086 | "through": "~2.3.1" 2087 | } 2088 | }, 2089 | "fast-deep-equal": { 2090 | "version": "3.1.3", 2091 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2092 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2093 | "dev": true 2094 | }, 2095 | "fast-json-stable-stringify": { 2096 | "version": "2.1.0", 2097 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2098 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2099 | "dev": true 2100 | }, 2101 | "fast-levenshtein": { 2102 | "version": "2.0.6", 2103 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2104 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2105 | "dev": true 2106 | }, 2107 | "file-entry-cache": { 2108 | "version": "6.0.0", 2109 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.0.tgz", 2110 | "integrity": "sha512-fqoO76jZ3ZnYrXLDRxBR1YvOvc0k844kcOg40bgsPrE25LAb/PDqTY+ho64Xh2c8ZXgIKldchCFHczG2UVRcWA==", 2111 | "dev": true, 2112 | "requires": { 2113 | "flat-cache": "^3.0.4" 2114 | } 2115 | }, 2116 | "file-uri-to-path": { 2117 | "version": "1.0.0", 2118 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", 2119 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", 2120 | "optional": true 2121 | }, 2122 | "flat-cache": { 2123 | "version": "3.0.4", 2124 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 2125 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 2126 | "dev": true, 2127 | "requires": { 2128 | "flatted": "^3.1.0", 2129 | "rimraf": "^3.0.2" 2130 | } 2131 | }, 2132 | "flatted": { 2133 | "version": "3.1.0", 2134 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.0.tgz", 2135 | "integrity": "sha512-tW+UkmtNg/jv9CSofAKvgVcO7c2URjhTdW1ZTkcAritblu8tajiYy7YisnIflEwtKssCtOxpnBRoCB7iap0/TA==", 2136 | "dev": true 2137 | }, 2138 | "from": { 2139 | "version": "0.1.7", 2140 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 2141 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=" 2142 | }, 2143 | "fs.realpath": { 2144 | "version": "1.0.0", 2145 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2146 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2147 | "dev": true 2148 | }, 2149 | "functional-red-black-tree": { 2150 | "version": "1.0.1", 2151 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 2152 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 2153 | "dev": true 2154 | }, 2155 | "glob": { 2156 | "version": "7.1.6", 2157 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 2158 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 2159 | "dev": true, 2160 | "requires": { 2161 | "fs.realpath": "^1.0.0", 2162 | "inflight": "^1.0.4", 2163 | "inherits": "2", 2164 | "minimatch": "^3.0.4", 2165 | "once": "^1.3.0", 2166 | "path-is-absolute": "^1.0.0" 2167 | } 2168 | }, 2169 | "glob-parent": { 2170 | "version": "5.1.1", 2171 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 2172 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 2173 | "dev": true, 2174 | "requires": { 2175 | "is-glob": "^4.0.1" 2176 | } 2177 | }, 2178 | "globals": { 2179 | "version": "12.4.0", 2180 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.4.0.tgz", 2181 | "integrity": "sha512-BWICuzzDvDoH54NHKCseDanAhE3CeDorgDL5MT6LMXXj2WCnd9UC2szdk4AWLfjdgNBCXLUanXYcpBBKOSWGwg==", 2182 | "dev": true, 2183 | "requires": { 2184 | "type-fest": "^0.8.1" 2185 | } 2186 | }, 2187 | "graceful-fs": { 2188 | "version": "4.2.4", 2189 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 2190 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 2191 | "dev": true 2192 | }, 2193 | "has-flag": { 2194 | "version": "4.0.0", 2195 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2196 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2197 | "dev": true 2198 | }, 2199 | "hexy": { 2200 | "version": "0.2.11", 2201 | "resolved": "https://registry.npmjs.org/hexy/-/hexy-0.2.11.tgz", 2202 | "integrity": "sha512-ciq6hFsSG/Bpt2DmrZJtv+56zpPdnq+NQ4ijEFrveKN0ZG1mhl/LdT1NQZ9se6ty1fACcI4d4vYqC9v8EYpH2A==" 2203 | }, 2204 | "ignore": { 2205 | "version": "4.0.6", 2206 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 2207 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 2208 | "dev": true 2209 | }, 2210 | "import-fresh": { 2211 | "version": "3.3.0", 2212 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2213 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2214 | "dev": true, 2215 | "requires": { 2216 | "parent-module": "^1.0.0", 2217 | "resolve-from": "^4.0.0" 2218 | } 2219 | }, 2220 | "imurmurhash": { 2221 | "version": "0.1.4", 2222 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2223 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2224 | "dev": true 2225 | }, 2226 | "inflight": { 2227 | "version": "1.0.6", 2228 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2229 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2230 | "dev": true, 2231 | "requires": { 2232 | "once": "^1.3.0", 2233 | "wrappy": "1" 2234 | } 2235 | }, 2236 | "inherits": { 2237 | "version": "2.0.4", 2238 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2239 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2240 | "dev": true 2241 | }, 2242 | "is-extglob": { 2243 | "version": "2.1.1", 2244 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2245 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2246 | "dev": true 2247 | }, 2248 | "is-fullwidth-code-point": { 2249 | "version": "3.0.0", 2250 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2251 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2252 | "dev": true 2253 | }, 2254 | "is-glob": { 2255 | "version": "4.0.1", 2256 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 2257 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 2258 | "dev": true, 2259 | "requires": { 2260 | "is-extglob": "^2.1.1" 2261 | } 2262 | }, 2263 | "isexe": { 2264 | "version": "2.0.0", 2265 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2266 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2267 | "dev": true 2268 | }, 2269 | "js-tokens": { 2270 | "version": "4.0.0", 2271 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2272 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2273 | "dev": true 2274 | }, 2275 | "js-yaml": { 2276 | "version": "3.14.1", 2277 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2278 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2279 | "dev": true, 2280 | "requires": { 2281 | "argparse": "^1.0.7", 2282 | "esprima": "^4.0.0" 2283 | } 2284 | }, 2285 | "js2xmlparser": { 2286 | "version": "4.0.1", 2287 | "resolved": "https://registry.npmjs.org/js2xmlparser/-/js2xmlparser-4.0.1.tgz", 2288 | "integrity": "sha512-KrPTolcw6RocpYjdC7pL7v62e55q7qOMHvLX1UCLc5AAS8qeJ6nukarEJAF2KL2PZxlbGueEbINqZR2bDe/gUw==", 2289 | "dev": true, 2290 | "requires": { 2291 | "xmlcreate": "^2.0.3" 2292 | } 2293 | }, 2294 | "jsbi": { 2295 | "version": "2.0.5", 2296 | "resolved": "https://registry.npmjs.org/jsbi/-/jsbi-2.0.5.tgz", 2297 | "integrity": "sha512-TzO/62Hxeb26QMb4IGlI/5X+QLr9Uqp1FPkwp2+KOICW+Q+vSuFj61c8pkT6wAns4WcK56X7CmSHhJeDGWOqxQ==" 2298 | }, 2299 | "jsdoc": { 2300 | "version": "3.6.6", 2301 | "resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-3.6.6.tgz", 2302 | "integrity": "sha512-znR99e1BHeyEkSvgDDpX0sTiTu+8aQyDl9DawrkOGZTTW8hv0deIFXx87114zJ7gRaDZKVQD/4tr1ifmJp9xhQ==", 2303 | "dev": true, 2304 | "requires": { 2305 | "@babel/parser": "^7.9.4", 2306 | "bluebird": "^3.7.2", 2307 | "catharsis": "^0.8.11", 2308 | "escape-string-regexp": "^2.0.0", 2309 | "js2xmlparser": "^4.0.1", 2310 | "klaw": "^3.0.0", 2311 | "markdown-it": "^10.0.0", 2312 | "markdown-it-anchor": "^5.2.7", 2313 | "marked": "^0.8.2", 2314 | "mkdirp": "^1.0.4", 2315 | "requizzle": "^0.2.3", 2316 | "strip-json-comments": "^3.1.0", 2317 | "taffydb": "2.6.2", 2318 | "underscore": "~1.10.2" 2319 | }, 2320 | "dependencies": { 2321 | "escape-string-regexp": { 2322 | "version": "2.0.0", 2323 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 2324 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 2325 | "dev": true 2326 | } 2327 | } 2328 | }, 2329 | "json-schema-traverse": { 2330 | "version": "0.4.1", 2331 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2332 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2333 | "dev": true 2334 | }, 2335 | "json-stable-stringify-without-jsonify": { 2336 | "version": "1.0.1", 2337 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2338 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2339 | "dev": true 2340 | }, 2341 | "klaw": { 2342 | "version": "3.0.0", 2343 | "resolved": "https://registry.npmjs.org/klaw/-/klaw-3.0.0.tgz", 2344 | "integrity": "sha512-0Fo5oir+O9jnXu5EefYbVK+mHMBeEVEy2cmctR1O1NECcCkPRreJKrS6Qt/j3KC2C148Dfo9i3pCmCMsdqGr0g==", 2345 | "dev": true, 2346 | "requires": { 2347 | "graceful-fs": "^4.1.9" 2348 | } 2349 | }, 2350 | "levn": { 2351 | "version": "0.4.1", 2352 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2353 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2354 | "dev": true, 2355 | "requires": { 2356 | "prelude-ls": "^1.2.1", 2357 | "type-check": "~0.4.0" 2358 | } 2359 | }, 2360 | "linkify-it": { 2361 | "version": "2.2.0", 2362 | "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-2.2.0.tgz", 2363 | "integrity": "sha512-GnAl/knGn+i1U/wjBz3akz2stz+HrHLsxMwHQGofCDfPvlf+gDKN58UtfmUquTY4/MXeE2x7k19KQmeoZi94Iw==", 2364 | "dev": true, 2365 | "requires": { 2366 | "uc.micro": "^1.0.1" 2367 | } 2368 | }, 2369 | "lodash": { 2370 | "version": "4.17.20", 2371 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", 2372 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==", 2373 | "dev": true 2374 | }, 2375 | "long": { 2376 | "version": "4.0.0", 2377 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 2378 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 2379 | }, 2380 | "lru-cache": { 2381 | "version": "6.0.0", 2382 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2383 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2384 | "dev": true, 2385 | "requires": { 2386 | "yallist": "^4.0.0" 2387 | } 2388 | }, 2389 | "map-stream": { 2390 | "version": "0.1.0", 2391 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 2392 | "integrity": "sha1-5WqpTEyAVaFkBKBnS3jyFffI4ZQ=" 2393 | }, 2394 | "markdown-it": { 2395 | "version": "10.0.0", 2396 | "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-10.0.0.tgz", 2397 | "integrity": "sha512-YWOP1j7UbDNz+TumYP1kpwnP0aEa711cJjrAQrzd0UXlbJfc5aAq0F/PZHjiioqDC1NKgvIMX+o+9Bk7yuM2dg==", 2398 | "dev": true, 2399 | "requires": { 2400 | "argparse": "^1.0.7", 2401 | "entities": "~2.0.0", 2402 | "linkify-it": "^2.0.0", 2403 | "mdurl": "^1.0.1", 2404 | "uc.micro": "^1.0.5" 2405 | } 2406 | }, 2407 | "markdown-it-anchor": { 2408 | "version": "5.3.0", 2409 | "resolved": "https://registry.npmjs.org/markdown-it-anchor/-/markdown-it-anchor-5.3.0.tgz", 2410 | "integrity": "sha512-/V1MnLL/rgJ3jkMWo84UR+K+jF1cxNG1a+KwqeXqTIJ+jtA8aWSHuigx8lTzauiIjBDbwF3NcWQMotd0Dm39jA==", 2411 | "dev": true, 2412 | "requires": {} 2413 | }, 2414 | "marked": { 2415 | "version": "0.8.2", 2416 | "resolved": "https://registry.npmjs.org/marked/-/marked-0.8.2.tgz", 2417 | "integrity": "sha512-EGwzEeCcLniFX51DhTpmTom+dSA/MG/OBUDjnWtHbEnjAH180VzUeAw+oE4+Zv+CoYBWyRlYOTR0N8SO9R1PVw==", 2418 | "dev": true 2419 | }, 2420 | "mdurl": { 2421 | "version": "1.0.1", 2422 | "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz", 2423 | "integrity": "sha1-/oWy7HWlkDfyrf7BAP1sYBdhFS4=", 2424 | "dev": true 2425 | }, 2426 | "minimatch": { 2427 | "version": "3.0.4", 2428 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2429 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2430 | "dev": true, 2431 | "requires": { 2432 | "brace-expansion": "^1.1.7" 2433 | } 2434 | }, 2435 | "mkdirp": { 2436 | "version": "1.0.4", 2437 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 2438 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 2439 | "dev": true 2440 | }, 2441 | "ms": { 2442 | "version": "2.1.2", 2443 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2444 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2445 | "dev": true 2446 | }, 2447 | "nan": { 2448 | "version": "2.14.2", 2449 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.2.tgz", 2450 | "integrity": "sha512-M2ufzIiINKCuDfBSAUr1vWQ+vuVcA9kqx8JJUsbQi6yf1uGRyb7HfpdfUr5qLXf3B/t8dPvcjhKMmlfnP47EzQ==", 2451 | "optional": true 2452 | }, 2453 | "natural-compare": { 2454 | "version": "1.4.0", 2455 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2456 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2457 | "dev": true 2458 | }, 2459 | "once": { 2460 | "version": "1.4.0", 2461 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2462 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2463 | "dev": true, 2464 | "requires": { 2465 | "wrappy": "1" 2466 | } 2467 | }, 2468 | "optionator": { 2469 | "version": "0.9.1", 2470 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2471 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2472 | "dev": true, 2473 | "requires": { 2474 | "deep-is": "^0.1.3", 2475 | "fast-levenshtein": "^2.0.6", 2476 | "levn": "^0.4.1", 2477 | "prelude-ls": "^1.2.1", 2478 | "type-check": "^0.4.0", 2479 | "word-wrap": "^1.2.3" 2480 | } 2481 | }, 2482 | "parent-module": { 2483 | "version": "1.0.1", 2484 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2485 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2486 | "dev": true, 2487 | "requires": { 2488 | "callsites": "^3.0.0" 2489 | } 2490 | }, 2491 | "path-is-absolute": { 2492 | "version": "1.0.1", 2493 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2494 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2495 | "dev": true 2496 | }, 2497 | "path-key": { 2498 | "version": "3.1.1", 2499 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2500 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2501 | "dev": true 2502 | }, 2503 | "pause-stream": { 2504 | "version": "0.0.11", 2505 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 2506 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 2507 | "requires": { 2508 | "through": "~2.3" 2509 | } 2510 | }, 2511 | "prelude-ls": { 2512 | "version": "1.2.1", 2513 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2514 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2515 | "dev": true 2516 | }, 2517 | "progress": { 2518 | "version": "2.0.3", 2519 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2520 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2521 | "dev": true 2522 | }, 2523 | "punycode": { 2524 | "version": "2.1.1", 2525 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2526 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2527 | "dev": true 2528 | }, 2529 | "regexpp": { 2530 | "version": "3.1.0", 2531 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.1.0.tgz", 2532 | "integrity": "sha512-ZOIzd8yVsQQA7j8GCSlPGXwg5PfmA1mrq0JP4nGhh54LaKN3xdai/vHUDu74pKwV8OxseMS65u2NImosQcSD0Q==", 2533 | "dev": true 2534 | }, 2535 | "require-from-string": { 2536 | "version": "2.0.2", 2537 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", 2538 | "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", 2539 | "dev": true 2540 | }, 2541 | "requizzle": { 2542 | "version": "0.2.3", 2543 | "resolved": "https://registry.npmjs.org/requizzle/-/requizzle-0.2.3.tgz", 2544 | "integrity": "sha512-YanoyJjykPxGHii0fZP0uUPEXpvqfBDxWV7s6GKAiiOsiqhX6vHNyW3Qzdmqp/iq/ExbhaGbVrjB4ruEVSM4GQ==", 2545 | "dev": true, 2546 | "requires": { 2547 | "lodash": "^4.17.14" 2548 | } 2549 | }, 2550 | "resolve-from": { 2551 | "version": "4.0.0", 2552 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2553 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2554 | "dev": true 2555 | }, 2556 | "rimraf": { 2557 | "version": "3.0.2", 2558 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2559 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2560 | "dev": true, 2561 | "requires": { 2562 | "glob": "^7.1.3" 2563 | } 2564 | }, 2565 | "safe-buffer": { 2566 | "version": "5.2.1", 2567 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2568 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2569 | }, 2570 | "sax": { 2571 | "version": "1.2.4", 2572 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 2573 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 2574 | }, 2575 | "semver": { 2576 | "version": "7.3.4", 2577 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz", 2578 | "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==", 2579 | "dev": true, 2580 | "requires": { 2581 | "lru-cache": "^6.0.0" 2582 | } 2583 | }, 2584 | "shebang-command": { 2585 | "version": "2.0.0", 2586 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2587 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2588 | "dev": true, 2589 | "requires": { 2590 | "shebang-regex": "^3.0.0" 2591 | } 2592 | }, 2593 | "shebang-regex": { 2594 | "version": "3.0.0", 2595 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2596 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2597 | "dev": true 2598 | }, 2599 | "slice-ansi": { 2600 | "version": "4.0.0", 2601 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 2602 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 2603 | "dev": true, 2604 | "requires": { 2605 | "ansi-styles": "^4.0.0", 2606 | "astral-regex": "^2.0.0", 2607 | "is-fullwidth-code-point": "^3.0.0" 2608 | } 2609 | }, 2610 | "split": { 2611 | "version": "0.3.3", 2612 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 2613 | "integrity": "sha1-zQ7qXmOiEd//frDwkcQTPi0N0o8=", 2614 | "requires": { 2615 | "through": "2" 2616 | } 2617 | }, 2618 | "sprintf-js": { 2619 | "version": "1.0.3", 2620 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2621 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2622 | "dev": true 2623 | }, 2624 | "stream-combiner": { 2625 | "version": "0.0.4", 2626 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 2627 | "integrity": "sha1-TV5DPBhSYd3mI8o/RMWGvPXErRQ=", 2628 | "requires": { 2629 | "duplexer": "~0.1.1" 2630 | } 2631 | }, 2632 | "string-width": { 2633 | "version": "4.2.0", 2634 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 2635 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 2636 | "dev": true, 2637 | "requires": { 2638 | "emoji-regex": "^8.0.0", 2639 | "is-fullwidth-code-point": "^3.0.0", 2640 | "strip-ansi": "^6.0.0" 2641 | } 2642 | }, 2643 | "strip-ansi": { 2644 | "version": "6.0.0", 2645 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2646 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2647 | "dev": true, 2648 | "requires": { 2649 | "ansi-regex": "^5.0.0" 2650 | } 2651 | }, 2652 | "strip-json-comments": { 2653 | "version": "3.1.1", 2654 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2655 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2656 | "dev": true 2657 | }, 2658 | "supports-color": { 2659 | "version": "7.2.0", 2660 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2661 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2662 | "dev": true, 2663 | "requires": { 2664 | "has-flag": "^4.0.0" 2665 | } 2666 | }, 2667 | "table": { 2668 | "version": "6.0.7", 2669 | "resolved": "https://registry.npmjs.org/table/-/table-6.0.7.tgz", 2670 | "integrity": "sha512-rxZevLGTUzWna/qBLObOe16kB2RTnnbhciwgPbMMlazz1yZGVEgnZK762xyVdVznhqxrfCeBMmMkgOOaPwjH7g==", 2671 | "dev": true, 2672 | "requires": { 2673 | "ajv": "^7.0.2", 2674 | "lodash": "^4.17.20", 2675 | "slice-ansi": "^4.0.0", 2676 | "string-width": "^4.2.0" 2677 | }, 2678 | "dependencies": { 2679 | "ajv": { 2680 | "version": "7.0.3", 2681 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-7.0.3.tgz", 2682 | "integrity": "sha512-R50QRlXSxqXcQP5SvKUrw8VZeypvo12i2IX0EeR5PiZ7bEKeHWgzgo264LDadUsCU42lTJVhFikTqJwNeH34gQ==", 2683 | "dev": true, 2684 | "requires": { 2685 | "fast-deep-equal": "^3.1.1", 2686 | "json-schema-traverse": "^1.0.0", 2687 | "require-from-string": "^2.0.2", 2688 | "uri-js": "^4.2.2" 2689 | } 2690 | }, 2691 | "json-schema-traverse": { 2692 | "version": "1.0.0", 2693 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", 2694 | "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", 2695 | "dev": true 2696 | } 2697 | } 2698 | }, 2699 | "taffydb": { 2700 | "version": "2.6.2", 2701 | "resolved": "https://registry.npmjs.org/taffydb/-/taffydb-2.6.2.tgz", 2702 | "integrity": "sha1-fLy2S1oUG2ou/CxdLGe04VCyomg=", 2703 | "dev": true 2704 | }, 2705 | "text-table": { 2706 | "version": "0.2.0", 2707 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2708 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2709 | "dev": true 2710 | }, 2711 | "through": { 2712 | "version": "2.3.8", 2713 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2714 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 2715 | }, 2716 | "type-check": { 2717 | "version": "0.4.0", 2718 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2719 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2720 | "dev": true, 2721 | "requires": { 2722 | "prelude-ls": "^1.2.1" 2723 | } 2724 | }, 2725 | "type-fest": { 2726 | "version": "0.8.1", 2727 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2728 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2729 | "dev": true 2730 | }, 2731 | "uc.micro": { 2732 | "version": "1.0.6", 2733 | "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz", 2734 | "integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==", 2735 | "dev": true 2736 | }, 2737 | "underscore": { 2738 | "version": "1.10.2", 2739 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.10.2.tgz", 2740 | "integrity": "sha512-N4P+Q/BuyuEKFJ43B9gYuOj4TQUHXX+j2FqguVOpjkssLUUrnJofCcBccJSCoeturDoZU6GorDTHSvUDlSQbTg==", 2741 | "dev": true 2742 | }, 2743 | "uri-js": { 2744 | "version": "4.4.1", 2745 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2746 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2747 | "dev": true, 2748 | "requires": { 2749 | "punycode": "^2.1.0" 2750 | } 2751 | }, 2752 | "v8-compile-cache": { 2753 | "version": "2.2.0", 2754 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.2.0.tgz", 2755 | "integrity": "sha512-gTpR5XQNKFwOd4clxfnhaqvfqMpqEwr4tOtCyz4MtYZX2JYhfr1JvBFKdS+7K/9rfpZR3VLX+YWBbKoxCgS43Q==", 2756 | "dev": true 2757 | }, 2758 | "which": { 2759 | "version": "2.0.2", 2760 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2761 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2762 | "dev": true, 2763 | "requires": { 2764 | "isexe": "^2.0.0" 2765 | } 2766 | }, 2767 | "word-wrap": { 2768 | "version": "1.2.3", 2769 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2770 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2771 | "dev": true 2772 | }, 2773 | "wrappy": { 2774 | "version": "1.0.2", 2775 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2776 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2777 | "dev": true 2778 | }, 2779 | "xml2js": { 2780 | "version": "0.4.23", 2781 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz", 2782 | "integrity": "sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug==", 2783 | "requires": { 2784 | "sax": ">=0.6.0", 2785 | "xmlbuilder": "~11.0.0" 2786 | } 2787 | }, 2788 | "xmlbuilder": { 2789 | "version": "11.0.1", 2790 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz", 2791 | "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==" 2792 | }, 2793 | "xmlcreate": { 2794 | "version": "2.0.3", 2795 | "resolved": "https://registry.npmjs.org/xmlcreate/-/xmlcreate-2.0.3.tgz", 2796 | "integrity": "sha512-HgS+X6zAztGa9zIK3Y3LXuJes33Lz9x+YyTxgrkIdabu2vqcGOWwdfCpf1hWLRrd553wd4QCDf6BBO6FfdsRiQ==", 2797 | "dev": true 2798 | }, 2799 | "yallist": { 2800 | "version": "4.0.0", 2801 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2802 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2803 | "dev": true 2804 | } 2805 | } 2806 | } 2807 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "signal-bot", 3 | "version": "0.0.1", 4 | "description": "A library for creating bots that interact with the Signal application. Not affiliated with the Signal project or Open Whisper Systems.", 5 | "main": "./src/index.js", 6 | "scripts": { 7 | "docs:build": "jsdoc -c ./docs/jsdoc.json" 8 | }, 9 | "homepage": "https://github.com/TapuCosmo/signal-bot#readme", 10 | "bugs": { 11 | "url": "https://github.com/TapuCosmo/signal-bot/issues" 12 | }, 13 | "repository": { 14 | "type": "git", 15 | "url": "https://github.com/TapuCosmo/signal-bot.git" 16 | }, 17 | "keywords": [ 18 | "signal", 19 | "bot", 20 | "client" 21 | ], 22 | "author": "Vietbao Tran (TapuCosmo)", 23 | "license": "MIT", 24 | "dependencies": { 25 | "dbus-next": "^0.9.1" 26 | }, 27 | "devDependencies": { 28 | "docdash": "^1.2.0", 29 | "eslint": "^7.17.0", 30 | "jsdoc": "^3.6.6" 31 | }, 32 | "engines": { 33 | "node": ">=14.0.0" 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /src/client/Client.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const EventEmitter = require("events"); 4 | 5 | const dbus = require("dbus-next"); 6 | 7 | const {defaultClientSettings} = require("../constants"); 8 | const {debugLog, deepMerge} = require("../util"); 9 | const ClientUser = require("./ClientUser.js"); 10 | const ConversationManager = require("../managers/ConversationManager.js"); 11 | const Message = require("../structures/Message.js"); 12 | 13 | /** 14 | * Signal bot client class. 15 | * @extends EventEmitter 16 | */ 17 | class Client extends EventEmitter { 18 | /** 19 | * Construct a Client. 20 | * @param {Object} [settings] - The settings for the Client. 21 | * @param {Object} [settings.dbus] - D-Bus settings. 22 | * @param {number} [settings.dbus.connectionCheckInterval=5000] - How frequently the connection should be checked, in milliseconds. 23 | * @param {string} [settings.dbus.destination=org.asamk.Signal] - D-Bus destination for signal-cli daemon. 24 | * @param {string} [settings.dbus.type=system] - D-Bus type. Can be `system` or `session`. 25 | */ 26 | constructor(settings = {}) { 27 | super(); 28 | this.settings = deepMerge(settings, defaultClientSettings); 29 | if (typeof this.settings.dbus?.connectionCheckInterval !== "number") { 30 | throw new TypeError(`Bad Client settings.dbus.connectionCheckInterval: ${this.settings.dbus?.connectionCheckInterval}`); 31 | } 32 | if (typeof this.settings.dbus?.destination !== "string") { 33 | throw new TypeError(`Bad Client settings.dbus.destination: ${this.settings.dbus?.destination}`); 34 | } 35 | if (!["system", "session"].includes(this.settings.dbus?.type)) { 36 | throw new TypeError(`Bad Client settings.dbus.destination: ${this.settings.dbus?.destination}`); 37 | } 38 | this._user = new ClientUser({ 39 | client: this 40 | }); 41 | this._conversations = new ConversationManager(this); 42 | } 43 | 44 | /** 45 | * The ClientUser belonging to this Client. 46 | * @type {ClientUser} 47 | * @readonly 48 | */ 49 | get user() { 50 | return this._user; 51 | } 52 | 53 | /** 54 | * The ConversationManager belonging to this Client. 55 | * @type {ConversationManager} 56 | * @readonly 57 | */ 58 | get conversations() { 59 | return this._conversations; 60 | } 61 | 62 | /** 63 | * Connect to the signal-cli daemon over D-Bus. 64 | * @return {Promise} 65 | */ 66 | async connect() { 67 | if (this.settings.dbus.type === "session") { 68 | this._bus = dbus.sessionBus(); 69 | } else { 70 | this._bus = dbus.systemBus(); 71 | } 72 | const interfaces = await this._bus.getProxyObject( 73 | this.settings.dbus.destination, 74 | "/org/asamk/Signal" 75 | ); 76 | this._busInterface = interfaces.getInterface("org.asamk.Signal"); 77 | 78 | /** 79 | * Disconnect event. 80 | * Fires when the D-Bus connection is disconnected. 81 | * The `connect` method must be called again afterwards in order to reconnect. 82 | * @event Client#disconnect 83 | */ 84 | // Hacky way of testing connection since dbus-next does not emit an event on disconnect. 85 | this._connectionCheckInterval = setInterval(async () => { 86 | try { 87 | await this.user.getRegistrationStatus(); 88 | } catch (e) { 89 | if (this.settings.debug) { 90 | debugLog("Disconnect"); 91 | } 92 | clearInterval(this._connectionCheckInterval); 93 | this._bus.disconnect(); 94 | this._busInterface.removeAllListeners(); 95 | this.emit("disconnect"); 96 | } 97 | }, this.settings.dbus.connectionCheckInterval); 98 | 99 | /** 100 | * Error event. 101 | * Fires when an error occurs. 102 | * @event Client#error 103 | * @type {Error} 104 | */ 105 | this._busInterface.on("error", e => { 106 | if (this.settings.debug) { 107 | debugLog(`Error: ${e}`); 108 | } 109 | this.emit("error", e); 110 | }); 111 | 112 | /** 113 | * Message event. 114 | * Fires when a message is received. 115 | * @event Client#message 116 | * @type {Message} 117 | */ 118 | this._busInterface.on("MessageReceived", (timestamp, authorID, groupID, content, attachments) => { 119 | if (this.settings.debug) { 120 | debugLog(`MessageReceived: ${timestamp}, ${authorID}, ${groupID?.toString?.("base64")}, ${content}, ${JSON.stringify(attachments)}`); 121 | } 122 | const conversationID = groupID.length ? groupID.toString("base64") : authorID; 123 | let conversation = this.conversations.cache.get(conversationID); 124 | if (!conversation) { 125 | conversation = this.conversations.from(conversationID); 126 | this.conversations._addToCache(conversation); 127 | } 128 | const message = new Message({ 129 | client: this, 130 | // D-Bus lib returns BigInt, which is unnecessary and not compatible with Date() 131 | timestamp: Number(timestamp), 132 | authorID, 133 | conversation, 134 | attachments, 135 | content 136 | }); 137 | 138 | this.emit("message", message); 139 | }); 140 | 141 | // Hacky workaround for dbus-next not handling multiple input signatures well. 142 | this._busInterface.$methods 143 | .filter(method => method.name === "sendMessage") 144 | .forEach(method => (method.inSignature = "sasas")); 145 | } 146 | } 147 | 148 | module.exports = Client; 149 | -------------------------------------------------------------------------------- /src/client/ClientUser.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | /** 4 | * The user that is being used by the client. 5 | */ 6 | class ClientUser { 7 | /** 8 | * Constructs an instance of ClientUser. For internal use only. 9 | * @param {Object} data 10 | * @param {Object} data.client 11 | * @hideconstructor 12 | */ 13 | constructor(data) { 14 | this._client = data.client; 15 | } 16 | 17 | /** 18 | * The Client that this instance belongs to. 19 | * @type {Client} 20 | * @readonly 21 | */ 22 | get client() { 23 | return this._client; 24 | } 25 | 26 | /** 27 | * Check if the client user is registered. 28 | * Should always return `true`. 29 | * @return {Promise} 30 | */ 31 | async getRegistrationStatus() { 32 | return await this.client._busInterface.isRegistered(); 33 | } 34 | } 35 | 36 | module.exports = ClientUser; 37 | -------------------------------------------------------------------------------- /src/constants/defaultClientSettings.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | module.exports = { 4 | dbus: { 5 | connectionCheckInterval: 5000, 6 | destination: "org.asamk.Signal", 7 | type: "system" 8 | }, 9 | debug: false 10 | }; 11 | -------------------------------------------------------------------------------- /src/constants/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | module.exports = { 4 | defaultClientSettings: require("./defaultClientSettings.js") 5 | }; 6 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | module.exports = { 4 | Client: require("./client/Client.js") 5 | }; 6 | -------------------------------------------------------------------------------- /src/managers/BaseManager.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const ExtMap = require("../structures/ExtMap.js"); 4 | 5 | /** 6 | * BaseManager class. 7 | * @param {Client} - client 8 | * @hideconstructor 9 | */ 10 | class BaseManager { 11 | constructor(client) { 12 | this._client = client; 13 | this._cache = new ExtMap(); 14 | } 15 | 16 | /** 17 | * The client belonging to the manager. 18 | * @type {Client} 19 | * @readonly 20 | */ 21 | get client() { 22 | return this._client; 23 | } 24 | 25 | /** 26 | * The cache belonging to the manager. 27 | * @type {ExtMap} 28 | * @readonly 29 | */ 30 | get cache() { 31 | return this._cache; 32 | } 33 | } 34 | 35 | module.exports = BaseManager; 36 | -------------------------------------------------------------------------------- /src/managers/ConversationManager.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const BaseManager = require("./BaseManager.js"); 4 | const GroupConversation = require("../structures/GroupConversation.js"); 5 | const UserConversation = require("../structures/UserConversation.js"); 6 | 7 | /** 8 | * ConversationManager class. 9 | * @extends BaseManager 10 | * @hideconstructor 11 | */ 12 | class ConversationManager extends BaseManager { 13 | /** 14 | * The cache belonging to this ConversationManager. 15 | * Keys are conversation IDs. 16 | * @type {ExtMap} 17 | * @name ConversationManager#cache 18 | */ 19 | 20 | /** 21 | * Adds a conversation to the cache. 22 | * @param {(UserConversation|GroupConversation)} conversation 23 | * @private 24 | */ 25 | _addToCache(conversation) { 26 | this.cache.set(conversation.id, conversation); 27 | } 28 | 29 | /** 30 | * Converts a conversation ID to a Conversation. 31 | * No checks are done to see if the ID is actually valid or available. 32 | * @param {string} id - The conversation ID. 33 | * @return {(UserConversation|GroupConversation)} 34 | */ 35 | from(id) { 36 | if (ConversationManager._idToConversationType(id) === "group") { 37 | return new GroupConversation({ 38 | client: this.client, 39 | id: id 40 | }); 41 | } 42 | return new UserConversation({ 43 | client: this.client, 44 | id: id 45 | }); 46 | } 47 | 48 | /** 49 | * Fetches a conversation. 50 | * Currently cannot fetch uncached UserConversation. 51 | * @param {string} id - The conversation ID. 52 | * @retrun {Promise<(UserConversation|GroupConversation|null)>} 53 | */ 54 | async fetchConversation(id) { 55 | const cached = this.cache.get(id); 56 | if (cached) return cached; 57 | if (ConversationManager._idToConversationType(id) === "user") return null; 58 | await this.fetchGroupConversations(); 59 | return this.cache.get(id) || null; 60 | } 61 | 62 | /** 63 | * Fetches group conversations. 64 | * Unfortunately signal-cli currently does not have a similar method 65 | * for user conversations. 66 | * @return {Promise>} 67 | */ 68 | async fetchGroupConversations() { 69 | const groupIDs = await this.client._busInterface.getGroupIds(); 70 | groupIDs.forEach(gid => { 71 | // Convert from Buffer to base64 72 | const base64ID = gid.toString("base64"); 73 | this.cache.set( 74 | base64ID, 75 | new GroupConversation({ 76 | client: this.client, 77 | id: base64ID 78 | }) 79 | ); 80 | }); 81 | return this.cache; 82 | } 83 | 84 | static _idToConversationType(id) { 85 | // Encoded group IDs should be over 40 characters. 86 | // Hopefully usernames will have a max limit of no more than 32. 87 | return id.length > 32 ? "group" : "user"; 88 | } 89 | } 90 | 91 | module.exports = ConversationManager; 92 | -------------------------------------------------------------------------------- /src/structures/BaseConversation.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | /** 4 | * BaseConversation structure. 5 | */ 6 | class BaseConversation { 7 | /** 8 | * Constructs an instance of BaseConversation. For internal use only. 9 | * @param {Object} data 10 | * @param {Object} data.client 11 | * @param {string} data.id 12 | * @hideconstructor 13 | */ 14 | constructor(data = {}) { 15 | this._client = data.client; 16 | this._id = data.id; 17 | } 18 | 19 | /** 20 | * The Client that this instance belongs to. 21 | * @type {Client} 22 | * @readonly 23 | */ 24 | get client() { 25 | return this._client; 26 | } 27 | 28 | /** 29 | * The ID of the conversation. 30 | * @type {string} 31 | * @readonly 32 | */ 33 | get id() { 34 | return this._id; 35 | } 36 | } 37 | 38 | module.exports = BaseConversation; 39 | -------------------------------------------------------------------------------- /src/structures/ExtMap.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | /** 4 | * An extension of the native Map class with convenience features. 5 | */ 6 | class ExtMap extends Map { 7 | /** 8 | * Finds the first value where the callback returns a truthy value. 9 | * Arguments equivalent to Array.find. 10 | */ 11 | find(...args) { 12 | return this.array().find(...args); 13 | } 14 | 15 | /** 16 | * Finds all values where the callback returns a truthy value. 17 | * Arguments equivalent to Array.filter. 18 | */ 19 | filter(...args) { 20 | return this.array().filter(...args); 21 | } 22 | 23 | /** 24 | * Returns an Array of all values. 25 | */ 26 | array() { 27 | return [...this.values()]; 28 | } 29 | } 30 | 31 | module.exports = ExtMap; 32 | -------------------------------------------------------------------------------- /src/structures/GroupConversation.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const BaseConversation = require("./BaseConversation.js"); 4 | 5 | /** 6 | * GroupConversation structure. 7 | * @extends BaseConversation 8 | * @hideconstructor 9 | */ 10 | class GroupConversation extends BaseConversation { 11 | /** 12 | * The type of the conversation. 13 | * Returns `group`. 14 | * @type {string} 15 | * @readonly 16 | */ 17 | // eslint-disable-next-line class-methods-use-this 18 | get type() { 19 | return "group"; 20 | } 21 | 22 | /** 23 | * The conversation ID in buffer form. 24 | * @type {string} 25 | * @readonly 26 | * @private 27 | */ 28 | get _idBuffer() { 29 | return Buffer.from(this.id, "base64"); 30 | } 31 | 32 | /** 33 | * Accept an invitation to the group conversation. 34 | * 35 | * Note that this will fail if you have not created a user profile yet. 36 | * You will need to stop the signal-cli service and run the following command: 37 | * `sudo signal-cli -u --config /var/lib/signal-cli updateProfile --name "" --remove-avatar`. 38 | * See the [signal-cli docs](https://github.com/AsamK/signal-cli/blob/master/man/signal-cli.1.adoc#updateprofile) for more information. 39 | * @return {Promise} 40 | */ 41 | async acceptInvitation() { 42 | await this.client._busInterface.updateGroup(this._idBuffer, "", [], ""); 43 | } 44 | 45 | /** 46 | * Send a message to the conversation. 47 | * @param {string} content - The text content to send. 48 | * @param {Array} [attachments] - An array of file paths of attachments to send. 49 | * @return {Promise} timestamp - The timestamp of the sent message. 50 | */ 51 | async sendMessage(content, attachments = []) { 52 | const conversation = this._idBuffer; 53 | const timestamp = await this.client._busInterface.sendGroupMessage(content, attachments, conversation); 54 | return Number(timestamp); 55 | } 56 | } 57 | 58 | module.exports = GroupConversation; 59 | -------------------------------------------------------------------------------- /src/structures/Message.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | /** 4 | * Message structure. 5 | */ 6 | class Message { 7 | /** 8 | * Constructs an instance of Message. For internal use only. 9 | * @param {Object} data 10 | * @param {Object} data.client 11 | * @param {number} data.timestamp 12 | * @param {string} data.authorID 13 | * @param {(UserConversation|GroupConversation)} data.conversation 14 | * @param {Array} data.attachments 15 | * @param {string} data.content 16 | * @hideconstructor 17 | */ 18 | constructor(data = {}) { 19 | this._client = data.client; 20 | this._timestamp = data.timestamp; 21 | this._author = { 22 | id: data.authorID 23 | }; 24 | this._conversation = data.conversation; 25 | this._attachments = data.attachments || []; 26 | this._content = data.content || ""; 27 | } 28 | 29 | /** 30 | * The Client that this instance belongs to. 31 | * @type {Client} 32 | * @readonly 33 | */ 34 | get client() { 35 | return this._client; 36 | } 37 | 38 | /** 39 | * The timestamp of the message, in milliseconds since the Unix epoch. 40 | * @type {number} 41 | * @readonly 42 | */ 43 | get timestamp() { 44 | return this._timestamp; 45 | } 46 | 47 | /** 48 | * The author of the message. 49 | * An object with only the `id` property. 50 | * @type {Object} 51 | * @readonly 52 | */ 53 | get author() { 54 | return this._author; 55 | } 56 | 57 | /** 58 | * The conversation that the message was sent in. Can be a UserConversation or GroupConversation. 59 | * @type {(UserConversation|GroupConversation)} 60 | * @readonly 61 | */ 62 | get conversation() { 63 | return this._conversation; 64 | } 65 | 66 | /** 67 | * The attachments that were sent with the message. 68 | * signal-cli automatically downloads attachments. 69 | * Returns an array of absolute file paths. 70 | * @type {Array} 71 | * @readonly 72 | */ 73 | get attachments() { 74 | return this._attachments; 75 | } 76 | 77 | /** 78 | * The text content of the message. 79 | * @type {string} 80 | * @readonly 81 | */ 82 | get content() { 83 | return this._content; 84 | } 85 | } 86 | 87 | module.exports = Message; 88 | -------------------------------------------------------------------------------- /src/structures/UserConversation.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const BaseConversation = require("./BaseConversation.js"); 4 | 5 | /** 6 | * UserConversation structure. 7 | * @extends BaseConversation 8 | * @hideconstructor 9 | */ 10 | class UserConversation extends BaseConversation { 11 | /** 12 | * The type of the conversation. 13 | * Returns `user`. 14 | * @type {string} 15 | * @readonly 16 | */ 17 | // eslint-disable-next-line class-methods-use-this 18 | get type() { 19 | return "user"; 20 | } 21 | 22 | /** 23 | * Send a message to the conversation. 24 | * @param {string} content - The text content to send. 25 | * @param {Array} [attachments] - An array of file paths of attachments to send. 26 | * @return {Promise} timestamp - The timestamp of the sent message. 27 | */ 28 | async sendMessage(content, attachments = []) { 29 | const conversation = [this.id]; 30 | const timestamp = await this.client._busInterface.sendMessage(content, attachments, conversation); 31 | return Number(timestamp); 32 | } 33 | 34 | /** 35 | * Reset the session keys for the conversation. 36 | * This method should rarely need to be used. 37 | * @return {Promise} 38 | */ 39 | async resetSession() { 40 | const conversation = [this.id]; 41 | await this.client._busInterface.sendEndSessionMessage(conversation); 42 | } 43 | } 44 | 45 | module.exports = UserConversation; 46 | -------------------------------------------------------------------------------- /src/util/debugLog.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | function debugLog(str) { 4 | console.log(`[DEBUG] ${str}`); 5 | } 6 | 7 | module.exports = debugLog; 8 | -------------------------------------------------------------------------------- /src/util/deepMerge.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | function deepMerge(target, source) { 4 | for (const key of Object.keys(source)) { 5 | if (!target[key]) { 6 | target[key] = source[key]; 7 | } else if ( 8 | typeof target[key] === "object" && 9 | typeof source[key] === "object" 10 | ) { 11 | deepMerge(target[key], source[key]); 12 | } 13 | } 14 | return target; 15 | } 16 | 17 | module.exports = deepMerge; 18 | -------------------------------------------------------------------------------- /src/util/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | module.exports = { 4 | debugLog: require("./debugLog.js"), 5 | deepMerge: require("./deepMerge.js") 6 | }; 7 | --------------------------------------------------------------------------------