├── .eslintrc.json ├── .github └── workflows │ ├── npm-publish-github-packages.yml │ └── npm-publish.yml ├── .gitignore ├── README.md ├── lib └── index.js ├── package-lock.json ├── package.json └── test └── index.test.js /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "es6": false, 4 | "node": true, 5 | "jasmine": true 6 | }, 7 | "extends": "eslint:recommended", 8 | "parserOptions": { 9 | }, 10 | "rules": { 11 | "no-else-return": "error", 12 | "no-multi-spaces": "error", 13 | "no-whitespace-before-property": "error", 14 | "camelcase": "error", 15 | "new-cap": "error", 16 | "no-console": "off", 17 | "no-control-regex": "off", 18 | "comma-dangle": "error", 19 | "indent": [ 20 | "error", 21 | 4, 22 | { 23 | "SwitchCase": 1 24 | } 25 | ], 26 | "quotes": [ 27 | "error", 28 | "single" 29 | ], 30 | "semi": [ 31 | "error", 32 | "always" 33 | ] 34 | } 35 | } -------------------------------------------------------------------------------- /.github/workflows/npm-publish-github-packages.yml: -------------------------------------------------------------------------------- 1 | # This workflow will run tests using node and then publish a package to GitHub Packages when a release is created 2 | # For more information see: https://docs.github.com/en/actions/publishing-packages/publishing-nodejs-packages 3 | 4 | name: Node.js Package 5 | 6 | on: 7 | release: 8 | types: [created] 9 | 10 | jobs: 11 | build: 12 | runs-on: ubuntu-latest 13 | steps: 14 | - uses: actions/checkout@v3 15 | - uses: actions/setup-node@v3 16 | with: 17 | node-version: 16 18 | - run: npm ci 19 | - run: npm test 20 | 21 | publish-gpr: 22 | needs: build 23 | runs-on: ubuntu-latest 24 | permissions: 25 | contents: read 26 | packages: write 27 | steps: 28 | - uses: actions/checkout@v3 29 | - uses: actions/setup-node@v3 30 | with: 31 | node-version: 16 32 | registry-url: https://npm.pkg.github.com/ 33 | - run: npm ci 34 | - run: npm publish 35 | env: 36 | NODE_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}} 37 | -------------------------------------------------------------------------------- /.github/workflows/npm-publish.yml: -------------------------------------------------------------------------------- 1 | # This workflow will run tests using node and then publish a package to GitHub Packages when a release is created 2 | # For more information see: https://docs.github.com/en/actions/publishing-packages/publishing-nodejs-packages 3 | 4 | name: Node.js NPM Package 5 | 6 | on: 7 | release: 8 | types: [created] 9 | 10 | jobs: 11 | build: 12 | runs-on: ubuntu-latest 13 | steps: 14 | - uses: actions/checkout@v3 15 | - uses: actions/setup-node@v3 16 | with: 17 | node-version: 16 18 | - run: npm ci 19 | - run: npm test 20 | 21 | publish-npm: 22 | needs: build 23 | runs-on: ubuntu-latest 24 | steps: 25 | - uses: actions/checkout@v3 26 | - uses: actions/setup-node@v3 27 | with: 28 | node-version: 16 29 | registry-url: https://registry.npmjs.org/ 30 | - run: npm ci 31 | - run: npm publish 32 | env: 33 | NODE_AUTH_TOKEN: ${{secrets.npm_token}} 34 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .idea/ 2 | node_modules/ 3 | coverage/ 4 | */**/*.log -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # beautify-tracejs 2 | Make the javascript stack trace of error more friendly and readable with colorful and code snippet. 3 | 4 | ## How to use 5 | ### Install 6 | ```npm install beautify-tracejs``` 7 | 8 | ### Example usage 9 | ``` 10 | beautify = require('beautify-tracejs'); 11 | beautify.register(); 12 | 13 | let err = new Error("test"); 14 | console.log(err.stack); 15 | 16 | beautify.unregister(); 17 | 18 | 19 | ``` 20 | 21 | ## How it works 22 | V8 engine in nodejs provides the Error.prepareStackTrace api to allow us customizing the stack trace of an error. 23 | 24 | This library will hook into this api add more features into the stack trace string: 25 | - Add a code snippet directly into stack trace --> in case logging into file, a code snippet can help sysadmin easily detect and troubleshoot problem. 26 | - Add colorful string into console log console.log(err.stack) --> this will help developers quickly see the problem. 27 | 28 | 29 | My project is inspired from other projects. I also borrow the source code and ideas from these projects. 30 | 31 | These projects are no longer actively developed. I want to add more features in future to help Javascript developer. 32 | 33 | - https://pypi.org/project/pretty-traceback/ 34 | - https://github.com/mjpizz/better-stack-traces 35 | - https://github.com/vitaly-t/manakin 36 | - https://github.com/shinnn/neat-stack 37 | 38 | ## Result 39 | ```javascript 40 | Error: Stack trace before beautify-tracejs register 41 | at Context. (/Users/stefanlee/projects/beautify-tracejs/test/index.test.js:8:21) 42 | at callFn (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runnable.js:366:21) 43 | at Runnable.run (/Users/stefanlee/projects/beautify-tracejs/Waiting for the debugger to disconnect... 44 | node_modules/mocha/lib/runnable.js:354:5) 45 | at Runner.runTest (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:666:10) 46 | at /Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:789:12 47 | at next (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:581:14) 48 | at /Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:591:7 49 | at next (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:474:14) 50 | at Immediate._onImmediate (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:559:5) 51 | at process.processImmediate (node:internal/timers:478:21) 52 | at process.callbackTrampoline (node:internal/async_hooks:130:17) 53 | ``` 54 | 55 | ```javascript 56 | Error: Stack trace after beautify-tracejs register 57 | at Context. (/Users/stefanlee/projects/beautify-tracejs/test/index.test.js:13:19) 58 | ──────────────────────────────────────────────────────────────────────────────────────────────────────────── 59 | 10 » beautify.register() 60 | 11 » 61 | 12 » let randomStr = "ThatTrackSourceCode" 62 | 13 » let err = new Error("Stack trace after beautify-tracejs register"); 63 | •••••••••••••••••••••••• 64 | 14 » 65 | 15 » console.log(err) 66 | 16 » 67 | 68 | at /Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runnable.js:366:21 69 | at Test.run (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runnable.js:354:5) 70 | at Runner.runTest (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:666:10) 71 | at /Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:789:12 72 | at /Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:581:14 73 | at /Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:591:7 74 | at /Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:474:14 75 | at Immediate._onImmediate (/Users/stefanlee/projects/beautify-tracejs/node_modules/mocha/lib/runner.js:559:5) 76 | at process. (node:internal/timers:478:21) 77 | at process. (node:internal/async_hooks:130:17) 78 | ``` 79 | -------------------------------------------------------------------------------- /lib/index.js: -------------------------------------------------------------------------------- 1 | ;(function () { 2 | 3 | let SEPARTE_CHAR = "•"; 4 | let MORE_CHAR = "…"; 5 | let DASH_CHAR = "─"; 6 | let ERROR_FILE_NOT_FOUND = "ENOENT"; 7 | let NOOP = function() {}; 8 | let DEFAULT_COLLAB_LIB_REGEX = /node_modules/; 9 | 10 | function repeatStr(str, num) { 11 | return new Array(num).join(str) + str; 12 | } 13 | 14 | function BeautifyTraceJS(error, frames, opt) { 15 | 16 | this._outCache = null; 17 | this._fileCache = {}; 18 | 19 | opt = opt || { 20 | "before": 3, 21 | "after": 3, 22 | "libs": /node_modules/, 23 | "maxColumns": 80, 24 | "indent": 4, 25 | "gutter": " » " 26 | 27 | } 28 | 29 | this._collapseLibraries = opt.libs; 30 | this._linesBefore = opt.before; 31 | this._linesAfter = opt.after; 32 | this._maxColumns = opt.maxColumns; 33 | this._outputPrefix = repeatStr(" ", opt.indent); 34 | this._gutterContent = opt.gutter; 35 | 36 | var req = opt.require || (typeof require === "undefined" ? NOOP : require); 37 | var win = opt.window || (typeof window === "undefined" ? {} : window); 38 | this._fs = opt.fs || req("fs") || win.fs; 39 | } 40 | 41 | BeautifyTraceJS.prototype = { 42 | 43 | prepareStackTrace: function prepareStackTrace(error, frames) { 44 | this._outCache = this._outCache || this._format(error, frames); 45 | return this._outCache; 46 | }, 47 | 48 | _shouldCollapse: function _shouldCollapse(fileName) { 49 | if (this._collapseLibraries) { 50 | if (this._collapseLibraries.test) { 51 | return this._collapseLibraries.test(fileName); 52 | } else { 53 | return DEFAULT_COLLAB_LIB_REGEX.test(fileName); 54 | } 55 | } else { 56 | return false; 57 | } 58 | }, 59 | 60 | _readCode: function _readCode(fileName) { 61 | let code = this._fileCache[fileName]; 62 | if (!code) { 63 | code = this._fs.readFileSync(fileName).toString(); 64 | this._fileCache[fileName] = code; 65 | } 66 | return code; 67 | }, 68 | 69 | _formatCodeLine: function _formatCodeLine(lineNumber, line, maxLineNumber) { 70 | let pad = maxLineNumber.toString().length - lineNumber.toString().length; 71 | let padding = ""; 72 | while (pad-- > 0) { 73 | padding += " "; 74 | } 75 | if (line.length > this._maxColumns) { 76 | line = line.slice(0, this._maxColumns - 1) + MORE_CHAR; 77 | } 78 | return padding + lineNumber + this._gutterContent + line; 79 | }, 80 | 81 | _formatCodeArrow: function _formatCodeArrow(lineNumber, columnNumber, maxLineNumber) { 82 | let length = (this._gutterContent + maxLineNumber).length + columnNumber; 83 | return repeatStr(SEPARTE_CHAR, length); 84 | }, 85 | 86 | _formatContext: function _formatContext(fileName, lineNumber, columnNumber) { 87 | let code = ""; 88 | try { 89 | code = this._readCode(fileName); 90 | } catch(err) { 91 | if (err.code === ERROR_FILE_NOT_FOUND) { 92 | throw err; 93 | } 94 | return this._outputPrefix + err.toString(); 95 | } 96 | 97 | // Figure out the lines of context before and after. 98 | let lines = code.split("\n"); 99 | let preLines = lines.slice(lineNumber - this._linesBefore - 1, lineNumber); 100 | let postLines = lines.slice(lineNumber, lineNumber + this._linesAfter); 101 | 102 | // Collect formatted versions of all the lines. Render 103 | let formattedLines = []; 104 | let maxLineNumber = lineNumber + this._linesAfter; 105 | let currentLineNumber = lineNumber - this._linesBefore; 106 | function renderLines(lines) { 107 | while (lines.length) { 108 | formattedLines.push(this._formatCodeLine( 109 | currentLineNumber++, 110 | lines.shift(), 111 | maxLineNumber 112 | )); 113 | } 114 | } 115 | renderLines.call(this, preLines); 116 | formattedLines.push(this._formatCodeArrow( 117 | currentLineNumber - 1, 118 | columnNumber, 119 | maxLineNumber 120 | )); 121 | renderLines.call(this, postLines); 122 | 123 | return this._outputPrefix + formattedLines.join("\n" + this._outputPrefix); 124 | }, 125 | 126 | _format: function _format(error, frames) { 127 | let lines = []; 128 | try { 129 | lines.push(error.toString()); 130 | } catch (e) { 131 | try { 132 | lines.push(""); 133 | } catch (ee) { 134 | lines.push(""); 135 | } 136 | } 137 | for (let i = 0; i < frames.length; i++) { 138 | let frame = frames[i]; 139 | let line; 140 | try { 141 | line = this._formatFrame(frame); 142 | } catch (e) { 143 | try { 144 | line = ""; 145 | } catch (ee) { 146 | // Any code that reaches this point is seriously nasty! 147 | line = ""; 148 | } 149 | } 150 | lines.push(line); 151 | } 152 | return lines.join("\n"); 153 | }, 154 | 155 | _formatFrame: function _formatFrame(frame) { 156 | let fileLocation = ""; 157 | let context = null; 158 | if (frame.isNative()) { 159 | fileLocation = "native"; 160 | } else if (frame.isEval()) { 161 | fileLocation = "eval at " + frame.getEvalOrigin(); 162 | } else { 163 | let fileName = frame.getFileName(); 164 | if (fileName) { 165 | fileLocation += fileName; 166 | let lineNumber = frame.getLineNumber(); 167 | if (lineNumber != null) { 168 | fileLocation += ":" + lineNumber; 169 | let columnNumber = frame.getColumnNumber(); 170 | if (columnNumber) { 171 | fileLocation += ":" + columnNumber; 172 | } 173 | try { 174 | if (this._shouldCollapse(fileName)) { 175 | context = null; 176 | } else { 177 | context = this._formatContext(fileName, lineNumber, columnNumber); 178 | } 179 | } catch(err) { 180 | if (err.code === ERROR_FILE_NOT_FOUND) { 181 | context = null; 182 | } else { 183 | context = err; 184 | } 185 | } 186 | } 187 | } 188 | } 189 | if (!fileLocation) { 190 | fileLocation = "unknown source"; 191 | } 192 | let line = ""; 193 | let functionFrame = frame.getFunction() 194 | let functionName = functionFrame !== undefined ? functionFrame.name : ""; 195 | 196 | let methodName = frame.getMethodName(); 197 | let addPrefix = true; 198 | let isConstructor = frame.isConstructor(); 199 | let isMethodCall = !(frame.isToplevel() || isConstructor); 200 | if (isMethodCall) { 201 | line += frame.getTypeName() + "."; 202 | if (functionName) { 203 | line += functionName; 204 | if (methodName && (methodName != functionName)) { 205 | line += " [as " + methodName + "]"; 206 | } 207 | } else { 208 | line += methodName || ""; 209 | } 210 | } else if (isConstructor) { 211 | line += "new " + (functionName || ""); 212 | } else if (functionName) { 213 | line += functionName; 214 | } else { 215 | line += fileLocation; 216 | addPrefix = false; 217 | } 218 | if (addPrefix) { 219 | line += " (" + fileLocation + ")"; 220 | } 221 | line = "at " + line; 222 | if (context) { 223 | let underline = this._outputPrefix + line.replace(/./g, DASH_CHAR); 224 | let betterLine = [line, underline, context].join("\n"); 225 | return this._outputPrefix + betterLine + "\n"; 226 | } else { 227 | return this._outputPrefix + line; 228 | } 229 | } 230 | 231 | }; 232 | 233 | let installations = []; 234 | 235 | function register(callback) { 236 | if (typeof callback !== "function") { 237 | let options = callback; 238 | callback = function(error, frames) { 239 | return new BeautifyTraceJS(options).prepareStackTrace(error, frames); 240 | }; 241 | } 242 | if (Error.prepareStackTrace) { 243 | installations.push(Error.prepareStackTrace) 244 | } 245 | Error.prepareStackTrace = callback; 246 | } 247 | 248 | function unregister() { 249 | if (Error.prepareStackTrace) { 250 | delete Error.prepareStackTrace; 251 | } 252 | if (installations.length) { 253 | Error.prepareStackTrace = installations.pop(); 254 | } 255 | } 256 | 257 | // Export for browser and node. 258 | let exp = typeof exports === "undefined" ? (this.BeautifyTraceJS = {}) : exports; 259 | exp.register = register; 260 | exp.unregister = unregister; 261 | exp.BeautifyTraceJS = BeautifyTraceJS; 262 | 263 | }).call(this); -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "beautify-tracejs", 3 | "version": "1.0.2", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "beautify-tracejs", 9 | "version": "1.0.2", 10 | "license": "ISC", 11 | "devDependencies": { 12 | "mocha": "^10.2.0", 13 | "request": "^2.88.2" 14 | }, 15 | "engines": { 16 | "node": ">=0.12", 17 | "npm": ">=1.4" 18 | } 19 | }, 20 | "node_modules/ajv": { 21 | "version": "6.12.6", 22 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 23 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 24 | "dev": true, 25 | "dependencies": { 26 | "fast-deep-equal": "^3.1.1", 27 | "fast-json-stable-stringify": "^2.0.0", 28 | "json-schema-traverse": "^0.4.1", 29 | "uri-js": "^4.2.2" 30 | }, 31 | "funding": { 32 | "type": "github", 33 | "url": "https://github.com/sponsors/epoberezkin" 34 | } 35 | }, 36 | "node_modules/ansi-colors": { 37 | "version": "4.1.1", 38 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 39 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 40 | "dev": true, 41 | "engines": { 42 | "node": ">=6" 43 | } 44 | }, 45 | "node_modules/ansi-regex": { 46 | "version": "5.0.1", 47 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 48 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 49 | "dev": true, 50 | "engines": { 51 | "node": ">=8" 52 | } 53 | }, 54 | "node_modules/ansi-styles": { 55 | "version": "4.3.0", 56 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 57 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 58 | "dev": true, 59 | "dependencies": { 60 | "color-convert": "^2.0.1" 61 | }, 62 | "engines": { 63 | "node": ">=8" 64 | }, 65 | "funding": { 66 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 67 | } 68 | }, 69 | "node_modules/anymatch": { 70 | "version": "3.1.3", 71 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 72 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 73 | "dev": true, 74 | "dependencies": { 75 | "normalize-path": "^3.0.0", 76 | "picomatch": "^2.0.4" 77 | }, 78 | "engines": { 79 | "node": ">= 8" 80 | } 81 | }, 82 | "node_modules/argparse": { 83 | "version": "2.0.1", 84 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 85 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 86 | "dev": true 87 | }, 88 | "node_modules/asn1": { 89 | "version": "0.2.6", 90 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.6.tgz", 91 | "integrity": "sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ==", 92 | "dev": true, 93 | "dependencies": { 94 | "safer-buffer": "~2.1.0" 95 | } 96 | }, 97 | "node_modules/assert-plus": { 98 | "version": "1.0.0", 99 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 100 | "integrity": "sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw==", 101 | "dev": true, 102 | "engines": { 103 | "node": ">=0.8" 104 | } 105 | }, 106 | "node_modules/asynckit": { 107 | "version": "0.4.0", 108 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 109 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", 110 | "dev": true 111 | }, 112 | "node_modules/aws-sign2": { 113 | "version": "0.7.0", 114 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 115 | "integrity": "sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA==", 116 | "dev": true, 117 | "engines": { 118 | "node": "*" 119 | } 120 | }, 121 | "node_modules/aws4": { 122 | "version": "1.12.0", 123 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.12.0.tgz", 124 | "integrity": "sha512-NmWvPnx0F1SfrQbYwOi7OeaNGokp9XhzNioJ/CSBs8Qa4vxug81mhJEAVZwxXuBmYB5KDRfMq/F3RR0BIU7sWg==", 125 | "dev": true 126 | }, 127 | "node_modules/balanced-match": { 128 | "version": "1.0.2", 129 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 130 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 131 | "dev": true 132 | }, 133 | "node_modules/bcrypt-pbkdf": { 134 | "version": "1.0.2", 135 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 136 | "integrity": "sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w==", 137 | "dev": true, 138 | "dependencies": { 139 | "tweetnacl": "^0.14.3" 140 | } 141 | }, 142 | "node_modules/binary-extensions": { 143 | "version": "2.2.0", 144 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 145 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 146 | "dev": true, 147 | "engines": { 148 | "node": ">=8" 149 | } 150 | }, 151 | "node_modules/brace-expansion": { 152 | "version": "2.0.1", 153 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 154 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 155 | "dev": true, 156 | "dependencies": { 157 | "balanced-match": "^1.0.0" 158 | } 159 | }, 160 | "node_modules/braces": { 161 | "version": "3.0.2", 162 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 163 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 164 | "dev": true, 165 | "dependencies": { 166 | "fill-range": "^7.0.1" 167 | }, 168 | "engines": { 169 | "node": ">=8" 170 | } 171 | }, 172 | "node_modules/browser-stdout": { 173 | "version": "1.3.1", 174 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 175 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 176 | "dev": true 177 | }, 178 | "node_modules/camelcase": { 179 | "version": "6.3.0", 180 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 181 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 182 | "dev": true, 183 | "engines": { 184 | "node": ">=10" 185 | }, 186 | "funding": { 187 | "url": "https://github.com/sponsors/sindresorhus" 188 | } 189 | }, 190 | "node_modules/caseless": { 191 | "version": "0.12.0", 192 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 193 | "integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==", 194 | "dev": true 195 | }, 196 | "node_modules/chalk": { 197 | "version": "4.1.2", 198 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 199 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 200 | "dev": true, 201 | "dependencies": { 202 | "ansi-styles": "^4.1.0", 203 | "supports-color": "^7.1.0" 204 | }, 205 | "engines": { 206 | "node": ">=10" 207 | }, 208 | "funding": { 209 | "url": "https://github.com/chalk/chalk?sponsor=1" 210 | } 211 | }, 212 | "node_modules/chalk/node_modules/supports-color": { 213 | "version": "7.2.0", 214 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 215 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 216 | "dev": true, 217 | "dependencies": { 218 | "has-flag": "^4.0.0" 219 | }, 220 | "engines": { 221 | "node": ">=8" 222 | } 223 | }, 224 | "node_modules/chokidar": { 225 | "version": "3.5.3", 226 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 227 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 228 | "dev": true, 229 | "funding": [ 230 | { 231 | "type": "individual", 232 | "url": "https://paulmillr.com/funding/" 233 | } 234 | ], 235 | "dependencies": { 236 | "anymatch": "~3.1.2", 237 | "braces": "~3.0.2", 238 | "glob-parent": "~5.1.2", 239 | "is-binary-path": "~2.1.0", 240 | "is-glob": "~4.0.1", 241 | "normalize-path": "~3.0.0", 242 | "readdirp": "~3.6.0" 243 | }, 244 | "engines": { 245 | "node": ">= 8.10.0" 246 | }, 247 | "optionalDependencies": { 248 | "fsevents": "~2.3.2" 249 | } 250 | }, 251 | "node_modules/cliui": { 252 | "version": "7.0.4", 253 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 254 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 255 | "dev": true, 256 | "dependencies": { 257 | "string-width": "^4.2.0", 258 | "strip-ansi": "^6.0.0", 259 | "wrap-ansi": "^7.0.0" 260 | } 261 | }, 262 | "node_modules/color-convert": { 263 | "version": "2.0.1", 264 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 265 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 266 | "dev": true, 267 | "dependencies": { 268 | "color-name": "~1.1.4" 269 | }, 270 | "engines": { 271 | "node": ">=7.0.0" 272 | } 273 | }, 274 | "node_modules/color-name": { 275 | "version": "1.1.4", 276 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 277 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 278 | "dev": true 279 | }, 280 | "node_modules/combined-stream": { 281 | "version": "1.0.8", 282 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 283 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 284 | "dev": true, 285 | "dependencies": { 286 | "delayed-stream": "~1.0.0" 287 | }, 288 | "engines": { 289 | "node": ">= 0.8" 290 | } 291 | }, 292 | "node_modules/concat-map": { 293 | "version": "0.0.1", 294 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 295 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 296 | "dev": true 297 | }, 298 | "node_modules/core-util-is": { 299 | "version": "1.0.2", 300 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 301 | "integrity": "sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ==", 302 | "dev": true 303 | }, 304 | "node_modules/dashdash": { 305 | "version": "1.14.1", 306 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 307 | "integrity": "sha512-jRFi8UDGo6j+odZiEpjazZaWqEal3w/basFjQHQEwVtZJGDpxbH1MeYluwCS8Xq5wmLJooDlMgvVarmWfGM44g==", 308 | "dev": true, 309 | "dependencies": { 310 | "assert-plus": "^1.0.0" 311 | }, 312 | "engines": { 313 | "node": ">=0.10" 314 | } 315 | }, 316 | "node_modules/debug": { 317 | "version": "4.3.4", 318 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 319 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 320 | "dev": true, 321 | "dependencies": { 322 | "ms": "2.1.2" 323 | }, 324 | "engines": { 325 | "node": ">=6.0" 326 | }, 327 | "peerDependenciesMeta": { 328 | "supports-color": { 329 | "optional": true 330 | } 331 | } 332 | }, 333 | "node_modules/debug/node_modules/ms": { 334 | "version": "2.1.2", 335 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 336 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 337 | "dev": true 338 | }, 339 | "node_modules/decamelize": { 340 | "version": "4.0.0", 341 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 342 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 343 | "dev": true, 344 | "engines": { 345 | "node": ">=10" 346 | }, 347 | "funding": { 348 | "url": "https://github.com/sponsors/sindresorhus" 349 | } 350 | }, 351 | "node_modules/delayed-stream": { 352 | "version": "1.0.0", 353 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 354 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 355 | "dev": true, 356 | "engines": { 357 | "node": ">=0.4.0" 358 | } 359 | }, 360 | "node_modules/diff": { 361 | "version": "5.0.0", 362 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 363 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 364 | "dev": true, 365 | "engines": { 366 | "node": ">=0.3.1" 367 | } 368 | }, 369 | "node_modules/ecc-jsbn": { 370 | "version": "0.1.2", 371 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 372 | "integrity": "sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw==", 373 | "dev": true, 374 | "dependencies": { 375 | "jsbn": "~0.1.0", 376 | "safer-buffer": "^2.1.0" 377 | } 378 | }, 379 | "node_modules/emoji-regex": { 380 | "version": "8.0.0", 381 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 382 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 383 | "dev": true 384 | }, 385 | "node_modules/escalade": { 386 | "version": "3.1.1", 387 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 388 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 389 | "dev": true, 390 | "engines": { 391 | "node": ">=6" 392 | } 393 | }, 394 | "node_modules/escape-string-regexp": { 395 | "version": "4.0.0", 396 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 397 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 398 | "dev": true, 399 | "engines": { 400 | "node": ">=10" 401 | }, 402 | "funding": { 403 | "url": "https://github.com/sponsors/sindresorhus" 404 | } 405 | }, 406 | "node_modules/extend": { 407 | "version": "3.0.2", 408 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 409 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 410 | "dev": true 411 | }, 412 | "node_modules/extsprintf": { 413 | "version": "1.3.0", 414 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 415 | "integrity": "sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g==", 416 | "dev": true, 417 | "engines": [ 418 | "node >=0.6.0" 419 | ] 420 | }, 421 | "node_modules/fast-deep-equal": { 422 | "version": "3.1.3", 423 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 424 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 425 | "dev": true 426 | }, 427 | "node_modules/fast-json-stable-stringify": { 428 | "version": "2.1.0", 429 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 430 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 431 | "dev": true 432 | }, 433 | "node_modules/fill-range": { 434 | "version": "7.0.1", 435 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 436 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 437 | "dev": true, 438 | "dependencies": { 439 | "to-regex-range": "^5.0.1" 440 | }, 441 | "engines": { 442 | "node": ">=8" 443 | } 444 | }, 445 | "node_modules/find-up": { 446 | "version": "5.0.0", 447 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 448 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 449 | "dev": true, 450 | "dependencies": { 451 | "locate-path": "^6.0.0", 452 | "path-exists": "^4.0.0" 453 | }, 454 | "engines": { 455 | "node": ">=10" 456 | }, 457 | "funding": { 458 | "url": "https://github.com/sponsors/sindresorhus" 459 | } 460 | }, 461 | "node_modules/flat": { 462 | "version": "5.0.2", 463 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 464 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 465 | "dev": true, 466 | "bin": { 467 | "flat": "cli.js" 468 | } 469 | }, 470 | "node_modules/forever-agent": { 471 | "version": "0.6.1", 472 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 473 | "integrity": "sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw==", 474 | "dev": true, 475 | "engines": { 476 | "node": "*" 477 | } 478 | }, 479 | "node_modules/form-data": { 480 | "version": "2.3.3", 481 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 482 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 483 | "dev": true, 484 | "dependencies": { 485 | "asynckit": "^0.4.0", 486 | "combined-stream": "^1.0.6", 487 | "mime-types": "^2.1.12" 488 | }, 489 | "engines": { 490 | "node": ">= 0.12" 491 | } 492 | }, 493 | "node_modules/fs.realpath": { 494 | "version": "1.0.0", 495 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 496 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 497 | "dev": true 498 | }, 499 | "node_modules/fsevents": { 500 | "version": "2.3.2", 501 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 502 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 503 | "dev": true, 504 | "hasInstallScript": true, 505 | "optional": true, 506 | "os": [ 507 | "darwin" 508 | ], 509 | "engines": { 510 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 511 | } 512 | }, 513 | "node_modules/get-caller-file": { 514 | "version": "2.0.5", 515 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 516 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 517 | "dev": true, 518 | "engines": { 519 | "node": "6.* || 8.* || >= 10.*" 520 | } 521 | }, 522 | "node_modules/getpass": { 523 | "version": "0.1.7", 524 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 525 | "integrity": "sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng==", 526 | "dev": true, 527 | "dependencies": { 528 | "assert-plus": "^1.0.0" 529 | } 530 | }, 531 | "node_modules/glob": { 532 | "version": "7.2.0", 533 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 534 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 535 | "dev": true, 536 | "dependencies": { 537 | "fs.realpath": "^1.0.0", 538 | "inflight": "^1.0.4", 539 | "inherits": "2", 540 | "minimatch": "^3.0.4", 541 | "once": "^1.3.0", 542 | "path-is-absolute": "^1.0.0" 543 | }, 544 | "engines": { 545 | "node": "*" 546 | }, 547 | "funding": { 548 | "url": "https://github.com/sponsors/isaacs" 549 | } 550 | }, 551 | "node_modules/glob-parent": { 552 | "version": "5.1.2", 553 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 554 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 555 | "dev": true, 556 | "dependencies": { 557 | "is-glob": "^4.0.1" 558 | }, 559 | "engines": { 560 | "node": ">= 6" 561 | } 562 | }, 563 | "node_modules/glob/node_modules/brace-expansion": { 564 | "version": "1.1.11", 565 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 566 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 567 | "dev": true, 568 | "dependencies": { 569 | "balanced-match": "^1.0.0", 570 | "concat-map": "0.0.1" 571 | } 572 | }, 573 | "node_modules/glob/node_modules/minimatch": { 574 | "version": "3.1.2", 575 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 576 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 577 | "dev": true, 578 | "dependencies": { 579 | "brace-expansion": "^1.1.7" 580 | }, 581 | "engines": { 582 | "node": "*" 583 | } 584 | }, 585 | "node_modules/har-schema": { 586 | "version": "2.0.0", 587 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 588 | "integrity": "sha512-Oqluz6zhGX8cyRaTQlFMPw80bSJVG2x/cFb8ZPhUILGgHka9SsokCCOQgpveePerqidZOrT14ipqfJb7ILcW5Q==", 589 | "dev": true, 590 | "engines": { 591 | "node": ">=4" 592 | } 593 | }, 594 | "node_modules/har-validator": { 595 | "version": "5.1.5", 596 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz", 597 | "integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==", 598 | "deprecated": "this library is no longer supported", 599 | "dev": true, 600 | "dependencies": { 601 | "ajv": "^6.12.3", 602 | "har-schema": "^2.0.0" 603 | }, 604 | "engines": { 605 | "node": ">=6" 606 | } 607 | }, 608 | "node_modules/has-flag": { 609 | "version": "4.0.0", 610 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 611 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 612 | "dev": true, 613 | "engines": { 614 | "node": ">=8" 615 | } 616 | }, 617 | "node_modules/he": { 618 | "version": "1.2.0", 619 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 620 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 621 | "dev": true, 622 | "bin": { 623 | "he": "bin/he" 624 | } 625 | }, 626 | "node_modules/http-signature": { 627 | "version": "1.2.0", 628 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 629 | "integrity": "sha512-CAbnr6Rz4CYQkLYUtSNXxQPUH2gK8f3iWexVlsnMeD+GjlsQ0Xsy1cOX+mN3dtxYomRy21CiOzU8Uhw6OwncEQ==", 630 | "dev": true, 631 | "dependencies": { 632 | "assert-plus": "^1.0.0", 633 | "jsprim": "^1.2.2", 634 | "sshpk": "^1.7.0" 635 | }, 636 | "engines": { 637 | "node": ">=0.8", 638 | "npm": ">=1.3.7" 639 | } 640 | }, 641 | "node_modules/inflight": { 642 | "version": "1.0.6", 643 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 644 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 645 | "dev": true, 646 | "dependencies": { 647 | "once": "^1.3.0", 648 | "wrappy": "1" 649 | } 650 | }, 651 | "node_modules/inherits": { 652 | "version": "2.0.4", 653 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 654 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 655 | "dev": true 656 | }, 657 | "node_modules/is-binary-path": { 658 | "version": "2.1.0", 659 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 660 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 661 | "dev": true, 662 | "dependencies": { 663 | "binary-extensions": "^2.0.0" 664 | }, 665 | "engines": { 666 | "node": ">=8" 667 | } 668 | }, 669 | "node_modules/is-extglob": { 670 | "version": "2.1.1", 671 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 672 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 673 | "dev": true, 674 | "engines": { 675 | "node": ">=0.10.0" 676 | } 677 | }, 678 | "node_modules/is-fullwidth-code-point": { 679 | "version": "3.0.0", 680 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 681 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 682 | "dev": true, 683 | "engines": { 684 | "node": ">=8" 685 | } 686 | }, 687 | "node_modules/is-glob": { 688 | "version": "4.0.3", 689 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 690 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 691 | "dev": true, 692 | "dependencies": { 693 | "is-extglob": "^2.1.1" 694 | }, 695 | "engines": { 696 | "node": ">=0.10.0" 697 | } 698 | }, 699 | "node_modules/is-number": { 700 | "version": "7.0.0", 701 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 702 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 703 | "dev": true, 704 | "engines": { 705 | "node": ">=0.12.0" 706 | } 707 | }, 708 | "node_modules/is-plain-obj": { 709 | "version": "2.1.0", 710 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 711 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 712 | "dev": true, 713 | "engines": { 714 | "node": ">=8" 715 | } 716 | }, 717 | "node_modules/is-typedarray": { 718 | "version": "1.0.0", 719 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 720 | "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==", 721 | "dev": true 722 | }, 723 | "node_modules/is-unicode-supported": { 724 | "version": "0.1.0", 725 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 726 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 727 | "dev": true, 728 | "engines": { 729 | "node": ">=10" 730 | }, 731 | "funding": { 732 | "url": "https://github.com/sponsors/sindresorhus" 733 | } 734 | }, 735 | "node_modules/isstream": { 736 | "version": "0.1.2", 737 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 738 | "integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==", 739 | "dev": true 740 | }, 741 | "node_modules/js-yaml": { 742 | "version": "4.1.0", 743 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 744 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 745 | "dev": true, 746 | "dependencies": { 747 | "argparse": "^2.0.1" 748 | }, 749 | "bin": { 750 | "js-yaml": "bin/js-yaml.js" 751 | } 752 | }, 753 | "node_modules/jsbn": { 754 | "version": "0.1.1", 755 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 756 | "integrity": "sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg==", 757 | "dev": true 758 | }, 759 | "node_modules/json-schema": { 760 | "version": "0.4.0", 761 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.4.0.tgz", 762 | "integrity": "sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==", 763 | "dev": true 764 | }, 765 | "node_modules/json-schema-traverse": { 766 | "version": "0.4.1", 767 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 768 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 769 | "dev": true 770 | }, 771 | "node_modules/json-stringify-safe": { 772 | "version": "5.0.1", 773 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 774 | "integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==", 775 | "dev": true 776 | }, 777 | "node_modules/jsprim": { 778 | "version": "1.4.2", 779 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.2.tgz", 780 | "integrity": "sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw==", 781 | "dev": true, 782 | "dependencies": { 783 | "assert-plus": "1.0.0", 784 | "extsprintf": "1.3.0", 785 | "json-schema": "0.4.0", 786 | "verror": "1.10.0" 787 | }, 788 | "engines": { 789 | "node": ">=0.6.0" 790 | } 791 | }, 792 | "node_modules/locate-path": { 793 | "version": "6.0.0", 794 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 795 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 796 | "dev": true, 797 | "dependencies": { 798 | "p-locate": "^5.0.0" 799 | }, 800 | "engines": { 801 | "node": ">=10" 802 | }, 803 | "funding": { 804 | "url": "https://github.com/sponsors/sindresorhus" 805 | } 806 | }, 807 | "node_modules/log-symbols": { 808 | "version": "4.1.0", 809 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 810 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 811 | "dev": true, 812 | "dependencies": { 813 | "chalk": "^4.1.0", 814 | "is-unicode-supported": "^0.1.0" 815 | }, 816 | "engines": { 817 | "node": ">=10" 818 | }, 819 | "funding": { 820 | "url": "https://github.com/sponsors/sindresorhus" 821 | } 822 | }, 823 | "node_modules/mime-db": { 824 | "version": "1.52.0", 825 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 826 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 827 | "dev": true, 828 | "engines": { 829 | "node": ">= 0.6" 830 | } 831 | }, 832 | "node_modules/mime-types": { 833 | "version": "2.1.35", 834 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 835 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 836 | "dev": true, 837 | "dependencies": { 838 | "mime-db": "1.52.0" 839 | }, 840 | "engines": { 841 | "node": ">= 0.6" 842 | } 843 | }, 844 | "node_modules/minimatch": { 845 | "version": "5.0.1", 846 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 847 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 848 | "dev": true, 849 | "dependencies": { 850 | "brace-expansion": "^2.0.1" 851 | }, 852 | "engines": { 853 | "node": ">=10" 854 | } 855 | }, 856 | "node_modules/mocha": { 857 | "version": "10.2.0", 858 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.2.0.tgz", 859 | "integrity": "sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg==", 860 | "dev": true, 861 | "dependencies": { 862 | "ansi-colors": "4.1.1", 863 | "browser-stdout": "1.3.1", 864 | "chokidar": "3.5.3", 865 | "debug": "4.3.4", 866 | "diff": "5.0.0", 867 | "escape-string-regexp": "4.0.0", 868 | "find-up": "5.0.0", 869 | "glob": "7.2.0", 870 | "he": "1.2.0", 871 | "js-yaml": "4.1.0", 872 | "log-symbols": "4.1.0", 873 | "minimatch": "5.0.1", 874 | "ms": "2.1.3", 875 | "nanoid": "3.3.3", 876 | "serialize-javascript": "6.0.0", 877 | "strip-json-comments": "3.1.1", 878 | "supports-color": "8.1.1", 879 | "workerpool": "6.2.1", 880 | "yargs": "16.2.0", 881 | "yargs-parser": "20.2.4", 882 | "yargs-unparser": "2.0.0" 883 | }, 884 | "bin": { 885 | "_mocha": "bin/_mocha", 886 | "mocha": "bin/mocha.js" 887 | }, 888 | "engines": { 889 | "node": ">= 14.0.0" 890 | }, 891 | "funding": { 892 | "type": "opencollective", 893 | "url": "https://opencollective.com/mochajs" 894 | } 895 | }, 896 | "node_modules/ms": { 897 | "version": "2.1.3", 898 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 899 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 900 | "dev": true 901 | }, 902 | "node_modules/nanoid": { 903 | "version": "3.3.3", 904 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", 905 | "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", 906 | "dev": true, 907 | "bin": { 908 | "nanoid": "bin/nanoid.cjs" 909 | }, 910 | "engines": { 911 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 912 | } 913 | }, 914 | "node_modules/normalize-path": { 915 | "version": "3.0.0", 916 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 917 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 918 | "dev": true, 919 | "engines": { 920 | "node": ">=0.10.0" 921 | } 922 | }, 923 | "node_modules/oauth-sign": { 924 | "version": "0.9.0", 925 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 926 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 927 | "dev": true, 928 | "engines": { 929 | "node": "*" 930 | } 931 | }, 932 | "node_modules/once": { 933 | "version": "1.4.0", 934 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 935 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 936 | "dev": true, 937 | "dependencies": { 938 | "wrappy": "1" 939 | } 940 | }, 941 | "node_modules/p-limit": { 942 | "version": "3.1.0", 943 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 944 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 945 | "dev": true, 946 | "dependencies": { 947 | "yocto-queue": "^0.1.0" 948 | }, 949 | "engines": { 950 | "node": ">=10" 951 | }, 952 | "funding": { 953 | "url": "https://github.com/sponsors/sindresorhus" 954 | } 955 | }, 956 | "node_modules/p-locate": { 957 | "version": "5.0.0", 958 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 959 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 960 | "dev": true, 961 | "dependencies": { 962 | "p-limit": "^3.0.2" 963 | }, 964 | "engines": { 965 | "node": ">=10" 966 | }, 967 | "funding": { 968 | "url": "https://github.com/sponsors/sindresorhus" 969 | } 970 | }, 971 | "node_modules/path-exists": { 972 | "version": "4.0.0", 973 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 974 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 975 | "dev": true, 976 | "engines": { 977 | "node": ">=8" 978 | } 979 | }, 980 | "node_modules/path-is-absolute": { 981 | "version": "1.0.1", 982 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 983 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 984 | "dev": true, 985 | "engines": { 986 | "node": ">=0.10.0" 987 | } 988 | }, 989 | "node_modules/performance-now": { 990 | "version": "2.1.0", 991 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 992 | "integrity": "sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow==", 993 | "dev": true 994 | }, 995 | "node_modules/picomatch": { 996 | "version": "2.3.1", 997 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 998 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 999 | "dev": true, 1000 | "engines": { 1001 | "node": ">=8.6" 1002 | }, 1003 | "funding": { 1004 | "url": "https://github.com/sponsors/jonschlinkert" 1005 | } 1006 | }, 1007 | "node_modules/psl": { 1008 | "version": "1.9.0", 1009 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", 1010 | "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", 1011 | "dev": true 1012 | }, 1013 | "node_modules/punycode": { 1014 | "version": "2.3.0", 1015 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 1016 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 1017 | "dev": true, 1018 | "engines": { 1019 | "node": ">=6" 1020 | } 1021 | }, 1022 | "node_modules/qs": { 1023 | "version": "6.5.3", 1024 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.3.tgz", 1025 | "integrity": "sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA==", 1026 | "dev": true, 1027 | "engines": { 1028 | "node": ">=0.6" 1029 | } 1030 | }, 1031 | "node_modules/randombytes": { 1032 | "version": "2.1.0", 1033 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1034 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1035 | "dev": true, 1036 | "dependencies": { 1037 | "safe-buffer": "^5.1.0" 1038 | } 1039 | }, 1040 | "node_modules/readdirp": { 1041 | "version": "3.6.0", 1042 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1043 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1044 | "dev": true, 1045 | "dependencies": { 1046 | "picomatch": "^2.2.1" 1047 | }, 1048 | "engines": { 1049 | "node": ">=8.10.0" 1050 | } 1051 | }, 1052 | "node_modules/request": { 1053 | "version": "2.88.2", 1054 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", 1055 | "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", 1056 | "deprecated": "request has been deprecated, see https://github.com/request/request/issues/3142", 1057 | "dev": true, 1058 | "dependencies": { 1059 | "aws-sign2": "~0.7.0", 1060 | "aws4": "^1.8.0", 1061 | "caseless": "~0.12.0", 1062 | "combined-stream": "~1.0.6", 1063 | "extend": "~3.0.2", 1064 | "forever-agent": "~0.6.1", 1065 | "form-data": "~2.3.2", 1066 | "har-validator": "~5.1.3", 1067 | "http-signature": "~1.2.0", 1068 | "is-typedarray": "~1.0.0", 1069 | "isstream": "~0.1.2", 1070 | "json-stringify-safe": "~5.0.1", 1071 | "mime-types": "~2.1.19", 1072 | "oauth-sign": "~0.9.0", 1073 | "performance-now": "^2.1.0", 1074 | "qs": "~6.5.2", 1075 | "safe-buffer": "^5.1.2", 1076 | "tough-cookie": "~2.5.0", 1077 | "tunnel-agent": "^0.6.0", 1078 | "uuid": "^3.3.2" 1079 | }, 1080 | "engines": { 1081 | "node": ">= 6" 1082 | } 1083 | }, 1084 | "node_modules/require-directory": { 1085 | "version": "2.1.1", 1086 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1087 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1088 | "dev": true, 1089 | "engines": { 1090 | "node": ">=0.10.0" 1091 | } 1092 | }, 1093 | "node_modules/safe-buffer": { 1094 | "version": "5.2.1", 1095 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1096 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1097 | "dev": true, 1098 | "funding": [ 1099 | { 1100 | "type": "github", 1101 | "url": "https://github.com/sponsors/feross" 1102 | }, 1103 | { 1104 | "type": "patreon", 1105 | "url": "https://www.patreon.com/feross" 1106 | }, 1107 | { 1108 | "type": "consulting", 1109 | "url": "https://feross.org/support" 1110 | } 1111 | ] 1112 | }, 1113 | "node_modules/safer-buffer": { 1114 | "version": "2.1.2", 1115 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1116 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1117 | "dev": true 1118 | }, 1119 | "node_modules/serialize-javascript": { 1120 | "version": "6.0.0", 1121 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1122 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1123 | "dev": true, 1124 | "dependencies": { 1125 | "randombytes": "^2.1.0" 1126 | } 1127 | }, 1128 | "node_modules/sshpk": { 1129 | "version": "1.17.0", 1130 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.17.0.tgz", 1131 | "integrity": "sha512-/9HIEs1ZXGhSPE8X6Ccm7Nam1z8KcoCqPdI7ecm1N33EzAetWahvQWVqLZtaZQ+IDKX4IyA2o0gBzqIMkAagHQ==", 1132 | "dev": true, 1133 | "dependencies": { 1134 | "asn1": "~0.2.3", 1135 | "assert-plus": "^1.0.0", 1136 | "bcrypt-pbkdf": "^1.0.0", 1137 | "dashdash": "^1.12.0", 1138 | "ecc-jsbn": "~0.1.1", 1139 | "getpass": "^0.1.1", 1140 | "jsbn": "~0.1.0", 1141 | "safer-buffer": "^2.0.2", 1142 | "tweetnacl": "~0.14.0" 1143 | }, 1144 | "bin": { 1145 | "sshpk-conv": "bin/sshpk-conv", 1146 | "sshpk-sign": "bin/sshpk-sign", 1147 | "sshpk-verify": "bin/sshpk-verify" 1148 | }, 1149 | "engines": { 1150 | "node": ">=0.10.0" 1151 | } 1152 | }, 1153 | "node_modules/string-width": { 1154 | "version": "4.2.3", 1155 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1156 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1157 | "dev": true, 1158 | "dependencies": { 1159 | "emoji-regex": "^8.0.0", 1160 | "is-fullwidth-code-point": "^3.0.0", 1161 | "strip-ansi": "^6.0.1" 1162 | }, 1163 | "engines": { 1164 | "node": ">=8" 1165 | } 1166 | }, 1167 | "node_modules/strip-ansi": { 1168 | "version": "6.0.1", 1169 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1170 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1171 | "dev": true, 1172 | "dependencies": { 1173 | "ansi-regex": "^5.0.1" 1174 | }, 1175 | "engines": { 1176 | "node": ">=8" 1177 | } 1178 | }, 1179 | "node_modules/strip-json-comments": { 1180 | "version": "3.1.1", 1181 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1182 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1183 | "dev": true, 1184 | "engines": { 1185 | "node": ">=8" 1186 | }, 1187 | "funding": { 1188 | "url": "https://github.com/sponsors/sindresorhus" 1189 | } 1190 | }, 1191 | "node_modules/supports-color": { 1192 | "version": "8.1.1", 1193 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1194 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1195 | "dev": true, 1196 | "dependencies": { 1197 | "has-flag": "^4.0.0" 1198 | }, 1199 | "engines": { 1200 | "node": ">=10" 1201 | }, 1202 | "funding": { 1203 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1204 | } 1205 | }, 1206 | "node_modules/to-regex-range": { 1207 | "version": "5.0.1", 1208 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1209 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1210 | "dev": true, 1211 | "dependencies": { 1212 | "is-number": "^7.0.0" 1213 | }, 1214 | "engines": { 1215 | "node": ">=8.0" 1216 | } 1217 | }, 1218 | "node_modules/tough-cookie": { 1219 | "version": "2.5.0", 1220 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", 1221 | "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", 1222 | "dev": true, 1223 | "dependencies": { 1224 | "psl": "^1.1.28", 1225 | "punycode": "^2.1.1" 1226 | }, 1227 | "engines": { 1228 | "node": ">=0.8" 1229 | } 1230 | }, 1231 | "node_modules/tunnel-agent": { 1232 | "version": "0.6.0", 1233 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1234 | "integrity": "sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==", 1235 | "dev": true, 1236 | "dependencies": { 1237 | "safe-buffer": "^5.0.1" 1238 | }, 1239 | "engines": { 1240 | "node": "*" 1241 | } 1242 | }, 1243 | "node_modules/tweetnacl": { 1244 | "version": "0.14.5", 1245 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1246 | "integrity": "sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA==", 1247 | "dev": true 1248 | }, 1249 | "node_modules/uri-js": { 1250 | "version": "4.4.1", 1251 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1252 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1253 | "dev": true, 1254 | "dependencies": { 1255 | "punycode": "^2.1.0" 1256 | } 1257 | }, 1258 | "node_modules/uuid": { 1259 | "version": "3.4.0", 1260 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 1261 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 1262 | "deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.", 1263 | "dev": true, 1264 | "bin": { 1265 | "uuid": "bin/uuid" 1266 | } 1267 | }, 1268 | "node_modules/verror": { 1269 | "version": "1.10.0", 1270 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1271 | "integrity": "sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw==", 1272 | "dev": true, 1273 | "engines": [ 1274 | "node >=0.6.0" 1275 | ], 1276 | "dependencies": { 1277 | "assert-plus": "^1.0.0", 1278 | "core-util-is": "1.0.2", 1279 | "extsprintf": "^1.2.0" 1280 | } 1281 | }, 1282 | "node_modules/workerpool": { 1283 | "version": "6.2.1", 1284 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 1285 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 1286 | "dev": true 1287 | }, 1288 | "node_modules/wrap-ansi": { 1289 | "version": "7.0.0", 1290 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1291 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1292 | "dev": true, 1293 | "dependencies": { 1294 | "ansi-styles": "^4.0.0", 1295 | "string-width": "^4.1.0", 1296 | "strip-ansi": "^6.0.0" 1297 | }, 1298 | "engines": { 1299 | "node": ">=10" 1300 | }, 1301 | "funding": { 1302 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1303 | } 1304 | }, 1305 | "node_modules/wrappy": { 1306 | "version": "1.0.2", 1307 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1308 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1309 | "dev": true 1310 | }, 1311 | "node_modules/y18n": { 1312 | "version": "5.0.8", 1313 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1314 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1315 | "dev": true, 1316 | "engines": { 1317 | "node": ">=10" 1318 | } 1319 | }, 1320 | "node_modules/yargs": { 1321 | "version": "16.2.0", 1322 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1323 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1324 | "dev": true, 1325 | "dependencies": { 1326 | "cliui": "^7.0.2", 1327 | "escalade": "^3.1.1", 1328 | "get-caller-file": "^2.0.5", 1329 | "require-directory": "^2.1.1", 1330 | "string-width": "^4.2.0", 1331 | "y18n": "^5.0.5", 1332 | "yargs-parser": "^20.2.2" 1333 | }, 1334 | "engines": { 1335 | "node": ">=10" 1336 | } 1337 | }, 1338 | "node_modules/yargs-parser": { 1339 | "version": "20.2.4", 1340 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1341 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1342 | "dev": true, 1343 | "engines": { 1344 | "node": ">=10" 1345 | } 1346 | }, 1347 | "node_modules/yargs-unparser": { 1348 | "version": "2.0.0", 1349 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1350 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1351 | "dev": true, 1352 | "dependencies": { 1353 | "camelcase": "^6.0.0", 1354 | "decamelize": "^4.0.0", 1355 | "flat": "^5.0.2", 1356 | "is-plain-obj": "^2.1.0" 1357 | }, 1358 | "engines": { 1359 | "node": ">=10" 1360 | } 1361 | }, 1362 | "node_modules/yocto-queue": { 1363 | "version": "0.1.0", 1364 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1365 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1366 | "dev": true, 1367 | "engines": { 1368 | "node": ">=10" 1369 | }, 1370 | "funding": { 1371 | "url": "https://github.com/sponsors/sindresorhus" 1372 | } 1373 | } 1374 | } 1375 | } 1376 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "beautify-tracejs", 3 | "version": "1.0.2", 4 | "description": "Make the javascript stack trace more beauty and readable with colorful and code snippet", 5 | "main": "lib/index.js", 6 | "scripts": { 7 | "test": "mocha test/index.test.js" 8 | }, 9 | "files": [ 10 | "lib" 11 | ], 12 | "repository": { 13 | "type": "git", 14 | "url": "git+https://github.com/stefanleesg/beautify-tracejs.git" 15 | }, 16 | "keywords": [ 17 | "stack", 18 | "trace", 19 | "beautify", 20 | "pretty", 21 | "color", 22 | "snippet", 23 | "javascript" 24 | ], 25 | "engines": { 26 | "node": ">=0.12", 27 | "npm": ">=1.4" 28 | }, 29 | "author": "Stefan Lee", 30 | "license": "ISC", 31 | "bugs": { 32 | "url": "https://github.com/stefanleesg/beautify-tracejs/issues" 33 | }, 34 | "homepage": "https://github.com/stefanleesg/beautify-tracejs#readme", 35 | "devDependencies": { 36 | "mocha": "^10.2.0", 37 | "request": "^2.88.2" 38 | } 39 | } 40 | -------------------------------------------------------------------------------- /test/index.test.js: -------------------------------------------------------------------------------- 1 | const beautify = require('../lib/index.js'); 2 | const assert = require('assert').strict; 3 | 4 | 5 | describe("Test beautify-tracejs", function() { 6 | it("test beautify-tracejs can read source file", function() { 7 | 8 | console.log(new Error("Stack trace before beautify-tracejs register")) 9 | 10 | beautify.register() 11 | 12 | let randomStr = "ThatTrackSourceCode" 13 | let err = new Error("Stack trace after beautify-tracejs register"); 14 | 15 | console.log(err) 16 | 17 | assert.ok(err.stack.includes(randomStr)) 18 | 19 | beautify.unregister() 20 | }); 21 | }); --------------------------------------------------------------------------------