├── .github ├── FUNDING.yml └── workflows │ └── main.yml ├── .gitignore ├── .npmignore ├── .travis.yml ├── README.md ├── cli.js ├── env.json ├── index.js ├── package-lock.json ├── package.json └── test ├── custom.json └── index.js /.github/FUNDING.yml: -------------------------------------------------------------------------------- 1 | # These are supported funding model platforms 2 | 3 | github: [coreybutler] 4 | patreon: coreybutler 5 | open_collective: # Replace with a single Open Collective username 6 | ko_fi: # Replace with a single Ko-fi username 7 | tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel 8 | community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry 9 | liberapay: # Replace with a single Liberapay username 10 | issuehunt: # Replace with a single IssueHunt username 11 | otechie: # Replace with a single Otechie username 12 | custom: # Replace with up to 4 custom sponsorship URLs e.g., ['link1', 'link2'] 13 | -------------------------------------------------------------------------------- /.github/workflows/main.yml: -------------------------------------------------------------------------------- 1 | name: Autotag 2 | 3 | on: 4 | push: 5 | branches: 6 | - master 7 | 8 | jobs: 9 | build: 10 | runs-on: ubuntu-latest 11 | steps: 12 | - uses: actions/checkout@master 13 | 14 | - uses: butlerlogic/action-autotag@stable 15 | id: autotagger 16 | if: success() 17 | with: 18 | GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}" 19 | 20 | # If the new version/tag is a pre-release (i.e. 1.0.0-beta.1), create 21 | # an environment variable indicating it is a prerelease. 22 | - name: Pre-release 23 | if: steps.autotagger.outputs.tagname != '' 24 | run: | 25 | if [[ "${{ steps.autotagger.output.version }}" == *"-"* ]]; then echo "::set-env IS_PRERELEASE=true";else echo "::set-env IS_PRERELEASE=''";fi 26 | 27 | - name: Release 28 | id: create_release 29 | if: steps.autotagger.outputs.tagname != '' 30 | uses: actions/create-release@v1.0.0 31 | env: 32 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} 33 | with: 34 | tag_name: ${{ steps.autotagger.outputs.tagname }} 35 | release_name: ${{ steps.autotagger.outputs.tagname }} 36 | body: ${{ steps.autotagger.outputs.tagmessage }} 37 | draft: false 38 | prerelease: env.IS_PRERELEASE != '' 39 | 40 | - name: Publish to npm 41 | id: publish_npm 42 | if: steps.autotagger.outputs.tagname != '' 43 | uses: author/action-publish@stable 44 | with: 45 | scan: ./ 46 | env: 47 | REGISTRY_TOKEN: ${{ secrets.NPM_REGISTRY_TOKEN }} 48 | 49 | - name: Rollback Release 50 | if: failure() && steps.create_release.outputs.id != '' 51 | uses: author/action-rollback@stable 52 | with: 53 | tag: ${{ steps.autotagger.outputs.tagname }} 54 | env: 55 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .* 2 | _* 3 | !.npmignore 4 | !.gitignore 5 | !.travis.yml 6 | node_modules 7 | *.log 8 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .* 2 | test 3 | node_modules 4 | *.md 5 | *.json 6 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - '8.0.0' 4 | - '10.0.0' 5 | - '12.0.0' 6 | deploy: 7 | provider: npm 8 | email: corey@coreybutler.com 9 | api_key: 10 | secure: X7hf2YSJTmZYuKi/XxpmKqsYE9QcnH71MNsaqKbbB++CxgMVEJtFm9dXdgVFLjBFwxkt1p0icHLK+Ytp1MpyaWL7bmgrUIpF14SEMt8OMRiM0xeA+DlCAAmi2mRKZGJbxfRX//+d9M9jCyOwrMbz8VHzRlg0417/L3xEcuvmyynfQFqFLkBiiwWRc0vt/bhqif3R9uRDkXKS9qVLXirVrBUt67PiABe/eeg487YX/6J9CWxpKH/4/h7CUJs3A79pVi3Vo0TUb8BFcX30Rxpf3fCuBXJYq0PZQY1U6TdWFzDOmVXiOCiawbTI9z0iveIcsBEAxRYP+dIsNUKEfpFedel5tbqEMtPNrRg5/ptiTftQsmg6dvp/1C0ggd1pYTphdGO6tVVJc9Ta9y4Dc5c5D8M3F1dzW7YGqHaHBkqbpYGNgUCp2CX7Ld09szmlFwnWySLn862rUJ0Bs6hfwMn6U7vdcL9z2IX9xgXPvUNvEjdQhCTYGixqh6v6aAyT08+MmYUW0uECqfnav+OPYIoWjXFpFTSqFEdv570jxo+ekF2WImd/SArf5mv9hNxFtOF2vv8lNrsDapkyHmT1x81zk0u0LygVtj3ji4S7uJdkpqSJCoDGHk/gtdzw7nFtlbttQQxx/SK9o8tjbhk1ndQTG/ou8SY891zb7Mrygz+HfeA= 11 | on: 12 | tags: true 13 | repo: coreybutler/localenvironment 14 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Local Environment 2 | 3 | **tl;dr** Create environment variables at runtime from a JSON configuration file, _if one exists_. 4 | 5 | ## Usage 6 | 7 | This module loads environment variables from a configuration file, _if the file exists_. Each attribute will be assigned to the `process.env` object. If the file does not exist, it does nothing (i.e. won't break the script). 8 | 9 | As of version 1.1.0, the module looks for `env.json`, `.env.json`, and `.env` (expects JSON content). It is also possible to look for a file with a different name (see Custom Config section below). It only loads the first file it finds. 10 | 11 | As of version 1.2.0, a command line tool was included, allowing other executables to be run with the local environment variables pre-applied to the runtime (see "Executing Programs" section for details). 12 | 13 | Using the module is extremely simple (one line of JavaScript). Consider the following project directory: 14 | 15 | ```sh 16 | > dir 17 | - env.json 18 | - index.js 19 | ``` 20 | 21 | The `env.json` may look like: 22 | 23 | ```json 24 | { 25 | "MY_VARIABLE_1": "abc", 26 | "MY_VARIABLE_2": "def" 27 | } 28 | ``` 29 | 30 | The `index.js` file would look like: 31 | 32 | ```javascript 33 | require('localenvironment') // <-- This is all the code you need. 34 | import LE from 'localenvironment' // <-- ES Module variation of the line above 35 | 36 | console.log(process.env.MY_VARIABLE_1) 37 | console.log(process.env.MY_VARIABLE_2) 38 | ``` 39 | 40 | _Here's what's happening..._ 41 | 42 | Running this code would output the following: 43 | 44 | ```sh 45 | abc 46 | def 47 | ``` 48 | 49 | The module reads the `env.json` file and applies the variables in such a manner that they are accessible just like any other environment variable. 50 | 51 | Now consider the exact same `index.js` file run in a Docker container _without a config file_: 52 | 53 | ```sh 54 | docker run -e "MY_VARIABLE_1=ghi" -e "MY_VARIABLE_2=jkl" node index.js 55 | ``` 56 | _(This is pseduo code, for illustration purposes)_ 57 | 58 | The output would be: 59 | 60 | ```sh 61 | ghi 62 | jkl 63 | ``` 64 | 65 | The only difference between these examples is the first was configured through a local JSON file and the second was configured through Docker environment variables. The **JavaScript didn't change** from one environment to the other. 66 | 67 | ## Custom File 68 | 69 | As of version 1.1.0, it is possible to tell localenvironment to search for a custom filename. The name of the file can be passed to the module as an argument. 70 | 71 | For example: 72 | 73 | ```javascript 74 | let myEnvironment = require('localenvironment') 75 | myEnvironment.load('/path/to/myconfig.json') 76 | ``` 77 | 78 | ## Additional Features 79 | 80 | The module will return an object of the variables it injected into the environment. 81 | 82 | ```javascript 83 | let myEnvironment = require('localenvironment) 84 | 85 | console.log(myEnvironment) 86 | ``` 87 | 88 | This would output the following: 89 | 90 | ```json 91 | { 92 | "MY_VARIABLE_1": "abc", 93 | "MY_VARIABLE_2": "def" 94 | } 95 | ``` 96 | 97 | This feature can be useful for understanding what was configured by the module and what wasn't. 98 | 99 | ## Executing Programs 100 | 101 | There are occasions where other programs need to be executed from npm scripts, using local environment variables. For example, Cloudflare workers use the `wrangler` executable to create a test environment. The test environment requires an API secret to be available in the environment variables. Instead of embedding this value in an npm script, it can remain in a `env.json` file (which should be in `.gitignore`/not committed), localenvironment can run it with the variable applied dynamically. 102 | 103 | For example, consider a `package.json` file with the following npm script: 104 | 105 | `"test": "CF_API_TOKEN=plaintext_secret wrangler dev --env development"` 106 | 107 | The API token would be committed in plain text in this file, which should be avoided. Instead, assume `env.json` contains the `CF_API_TOKEN` value. This can be applied with the following npm script: 108 | 109 | `"test": "localenvironment wrangler dev --env development"` 110 | 111 | `localenvironment` loads the environment variables from the `env.json` file, then runs the `wrangler dev --env development` command with those environment variables. 112 | 113 | --- 114 | 115 | #### Intended Use 116 | 117 | It's common practice to use a different configurations for development and production. For example, many people use Development API keys when creating on †heir workstation, but Production API keys when running the code on a live server. 118 | 119 | This module allows developers to write one line of code that will run predictably in any environment. 120 | 121 | **The developer's responsibility is to configure environment variables correctly, _not to write conditional logic that manipulates the envionrment_.** 122 | 123 | There are also programs written that function differently _if an environment variable exists_. This module won't fire an error if it doesn't find the `env.json`, so it's easy to manipulate the environment simply by commenting out some code or changing a file name. 124 | 125 | Your mileage will vary, but I've found this to be much simpler than writing shell/batch files and other wrappers to manage environment variables. The pattern is used so often I even [ported it to Golang](https://github.com/coreybutler/go-localenvironment). 126 | 127 | If you came here looking for ways to force-require or detect local environment variables, have a look 128 | at [musthave](https://github.com/coreybutler/musthave) instead. 129 | -------------------------------------------------------------------------------- /cli.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | require(require('path').join(__dirname, 'index.js')) 4 | 5 | const { spawn } = require('child_process') 6 | 7 | const p = spawn(process.argv[2], process.argv.slice(3), { cwd: process.cwd(), env: process.env }) 8 | p.stdout.on('data', d => console.log(d.toString())) 9 | p.stderr.on('data', d => console.error(d.toString())) 10 | -------------------------------------------------------------------------------- /env.json: -------------------------------------------------------------------------------- 1 | { 2 | "env_test": "test" 3 | } 4 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | let environment = {} 2 | const fs = require('fs') 3 | const loadEnvironment = json => { 4 | try { 5 | let env = require(json) 6 | 7 | Object.keys(env).forEach(function (key) { 8 | environment[key] = env[key].toString() 9 | process.env[key] = env[key].toString() 10 | }) 11 | 12 | return null 13 | } catch (e) { 14 | return e 15 | } 16 | } 17 | 18 | for (let route of ['env.json', '.env.json', '.env']) { 19 | filepath = require('path').join(process.cwd(), route) 20 | 21 | if (fs.existsSync(filepath)) { 22 | let err = loadEnvironment(filepath) 23 | if (err !== null) { 24 | console.log('WARNING --> Configuration Problem: ' + e.message) 25 | } else { 26 | break 27 | } 28 | } 29 | } 30 | 31 | environment.load = (filename = null) => { 32 | if (filename === null) { 33 | return 34 | } 35 | 36 | let filepath = require('path').join(process.cwd(), filename) 37 | 38 | if (fs.existsSync(filepath)) { 39 | loadEnvironment(filepath) 40 | } 41 | } 42 | 43 | module.exports = environment 44 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "localenvironment", 3 | "version": "1.2.1", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "1.2.1", 9 | "license": "MIT", 10 | "bin": { 11 | "localenvironment": "cli.js" 12 | }, 13 | "devDependencies": { 14 | "mocha": "^10.2.0" 15 | } 16 | }, 17 | "node_modules/ansi-colors": { 18 | "version": "4.1.1", 19 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 20 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 21 | "dev": true, 22 | "engines": { 23 | "node": ">=6" 24 | } 25 | }, 26 | "node_modules/ansi-regex": { 27 | "version": "5.0.1", 28 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 29 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 30 | "dev": true, 31 | "engines": { 32 | "node": ">=8" 33 | } 34 | }, 35 | "node_modules/ansi-styles": { 36 | "version": "4.3.0", 37 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 38 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 39 | "dev": true, 40 | "dependencies": { 41 | "color-convert": "^2.0.1" 42 | }, 43 | "engines": { 44 | "node": ">=8" 45 | }, 46 | "funding": { 47 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 48 | } 49 | }, 50 | "node_modules/anymatch": { 51 | "version": "3.1.3", 52 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 53 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 54 | "dev": true, 55 | "dependencies": { 56 | "normalize-path": "^3.0.0", 57 | "picomatch": "^2.0.4" 58 | }, 59 | "engines": { 60 | "node": ">= 8" 61 | } 62 | }, 63 | "node_modules/argparse": { 64 | "version": "2.0.1", 65 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 66 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 67 | "dev": true 68 | }, 69 | "node_modules/balanced-match": { 70 | "version": "1.0.2", 71 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 72 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 73 | "dev": true 74 | }, 75 | "node_modules/binary-extensions": { 76 | "version": "2.2.0", 77 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 78 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 79 | "dev": true, 80 | "engines": { 81 | "node": ">=8" 82 | } 83 | }, 84 | "node_modules/brace-expansion": { 85 | "version": "2.0.1", 86 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 87 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 88 | "dev": true, 89 | "dependencies": { 90 | "balanced-match": "^1.0.0" 91 | } 92 | }, 93 | "node_modules/braces": { 94 | "version": "3.0.2", 95 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 96 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 97 | "dev": true, 98 | "dependencies": { 99 | "fill-range": "^7.0.1" 100 | }, 101 | "engines": { 102 | "node": ">=8" 103 | } 104 | }, 105 | "node_modules/browser-stdout": { 106 | "version": "1.3.1", 107 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 108 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 109 | "dev": true 110 | }, 111 | "node_modules/camelcase": { 112 | "version": "6.3.0", 113 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 114 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 115 | "dev": true, 116 | "engines": { 117 | "node": ">=10" 118 | }, 119 | "funding": { 120 | "url": "https://github.com/sponsors/sindresorhus" 121 | } 122 | }, 123 | "node_modules/chalk": { 124 | "version": "4.1.2", 125 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 126 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 127 | "dev": true, 128 | "dependencies": { 129 | "ansi-styles": "^4.1.0", 130 | "supports-color": "^7.1.0" 131 | }, 132 | "engines": { 133 | "node": ">=10" 134 | }, 135 | "funding": { 136 | "url": "https://github.com/chalk/chalk?sponsor=1" 137 | } 138 | }, 139 | "node_modules/chalk/node_modules/supports-color": { 140 | "version": "7.2.0", 141 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 142 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 143 | "dev": true, 144 | "dependencies": { 145 | "has-flag": "^4.0.0" 146 | }, 147 | "engines": { 148 | "node": ">=8" 149 | } 150 | }, 151 | "node_modules/chokidar": { 152 | "version": "3.5.3", 153 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 154 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 155 | "dev": true, 156 | "funding": [ 157 | { 158 | "type": "individual", 159 | "url": "https://paulmillr.com/funding/" 160 | } 161 | ], 162 | "dependencies": { 163 | "anymatch": "~3.1.2", 164 | "braces": "~3.0.2", 165 | "glob-parent": "~5.1.2", 166 | "is-binary-path": "~2.1.0", 167 | "is-glob": "~4.0.1", 168 | "normalize-path": "~3.0.0", 169 | "readdirp": "~3.6.0" 170 | }, 171 | "engines": { 172 | "node": ">= 8.10.0" 173 | }, 174 | "optionalDependencies": { 175 | "fsevents": "~2.3.2" 176 | } 177 | }, 178 | "node_modules/cliui": { 179 | "version": "7.0.4", 180 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 181 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 182 | "dev": true, 183 | "dependencies": { 184 | "string-width": "^4.2.0", 185 | "strip-ansi": "^6.0.0", 186 | "wrap-ansi": "^7.0.0" 187 | } 188 | }, 189 | "node_modules/color-convert": { 190 | "version": "2.0.1", 191 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 192 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 193 | "dev": true, 194 | "dependencies": { 195 | "color-name": "~1.1.4" 196 | }, 197 | "engines": { 198 | "node": ">=7.0.0" 199 | } 200 | }, 201 | "node_modules/color-name": { 202 | "version": "1.1.4", 203 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 204 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 205 | "dev": true 206 | }, 207 | "node_modules/concat-map": { 208 | "version": "0.0.1", 209 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 210 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 211 | "dev": true 212 | }, 213 | "node_modules/debug": { 214 | "version": "4.3.4", 215 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 216 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 217 | "dev": true, 218 | "dependencies": { 219 | "ms": "2.1.2" 220 | }, 221 | "engines": { 222 | "node": ">=6.0" 223 | }, 224 | "peerDependenciesMeta": { 225 | "supports-color": { 226 | "optional": true 227 | } 228 | } 229 | }, 230 | "node_modules/debug/node_modules/ms": { 231 | "version": "2.1.2", 232 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 233 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 234 | "dev": true 235 | }, 236 | "node_modules/decamelize": { 237 | "version": "4.0.0", 238 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 239 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 240 | "dev": true, 241 | "engines": { 242 | "node": ">=10" 243 | }, 244 | "funding": { 245 | "url": "https://github.com/sponsors/sindresorhus" 246 | } 247 | }, 248 | "node_modules/diff": { 249 | "version": "5.0.0", 250 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 251 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 252 | "dev": true, 253 | "engines": { 254 | "node": ">=0.3.1" 255 | } 256 | }, 257 | "node_modules/emoji-regex": { 258 | "version": "8.0.0", 259 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 260 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 261 | "dev": true 262 | }, 263 | "node_modules/escalade": { 264 | "version": "3.1.1", 265 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 266 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 267 | "dev": true, 268 | "engines": { 269 | "node": ">=6" 270 | } 271 | }, 272 | "node_modules/escape-string-regexp": { 273 | "version": "4.0.0", 274 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 275 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 276 | "dev": true, 277 | "engines": { 278 | "node": ">=10" 279 | }, 280 | "funding": { 281 | "url": "https://github.com/sponsors/sindresorhus" 282 | } 283 | }, 284 | "node_modules/fill-range": { 285 | "version": "7.0.1", 286 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 287 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 288 | "dev": true, 289 | "dependencies": { 290 | "to-regex-range": "^5.0.1" 291 | }, 292 | "engines": { 293 | "node": ">=8" 294 | } 295 | }, 296 | "node_modules/find-up": { 297 | "version": "5.0.0", 298 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 299 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 300 | "dev": true, 301 | "dependencies": { 302 | "locate-path": "^6.0.0", 303 | "path-exists": "^4.0.0" 304 | }, 305 | "engines": { 306 | "node": ">=10" 307 | }, 308 | "funding": { 309 | "url": "https://github.com/sponsors/sindresorhus" 310 | } 311 | }, 312 | "node_modules/flat": { 313 | "version": "5.0.2", 314 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 315 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 316 | "dev": true, 317 | "bin": { 318 | "flat": "cli.js" 319 | } 320 | }, 321 | "node_modules/fs.realpath": { 322 | "version": "1.0.0", 323 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 324 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 325 | "dev": true 326 | }, 327 | "node_modules/fsevents": { 328 | "version": "2.3.2", 329 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 330 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 331 | "dev": true, 332 | "hasInstallScript": true, 333 | "optional": true, 334 | "os": [ 335 | "darwin" 336 | ], 337 | "engines": { 338 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 339 | } 340 | }, 341 | "node_modules/get-caller-file": { 342 | "version": "2.0.5", 343 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 344 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 345 | "dev": true, 346 | "engines": { 347 | "node": "6.* || 8.* || >= 10.*" 348 | } 349 | }, 350 | "node_modules/glob": { 351 | "version": "7.2.0", 352 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 353 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 354 | "dev": true, 355 | "dependencies": { 356 | "fs.realpath": "^1.0.0", 357 | "inflight": "^1.0.4", 358 | "inherits": "2", 359 | "minimatch": "^3.0.4", 360 | "once": "^1.3.0", 361 | "path-is-absolute": "^1.0.0" 362 | }, 363 | "engines": { 364 | "node": "*" 365 | }, 366 | "funding": { 367 | "url": "https://github.com/sponsors/isaacs" 368 | } 369 | }, 370 | "node_modules/glob-parent": { 371 | "version": "5.1.2", 372 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 373 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 374 | "dev": true, 375 | "dependencies": { 376 | "is-glob": "^4.0.1" 377 | }, 378 | "engines": { 379 | "node": ">= 6" 380 | } 381 | }, 382 | "node_modules/glob/node_modules/brace-expansion": { 383 | "version": "1.1.11", 384 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 385 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 386 | "dev": true, 387 | "dependencies": { 388 | "balanced-match": "^1.0.0", 389 | "concat-map": "0.0.1" 390 | } 391 | }, 392 | "node_modules/glob/node_modules/minimatch": { 393 | "version": "3.1.2", 394 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 395 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 396 | "dev": true, 397 | "dependencies": { 398 | "brace-expansion": "^1.1.7" 399 | }, 400 | "engines": { 401 | "node": "*" 402 | } 403 | }, 404 | "node_modules/has-flag": { 405 | "version": "4.0.0", 406 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 407 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 408 | "dev": true, 409 | "engines": { 410 | "node": ">=8" 411 | } 412 | }, 413 | "node_modules/he": { 414 | "version": "1.2.0", 415 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 416 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 417 | "dev": true, 418 | "bin": { 419 | "he": "bin/he" 420 | } 421 | }, 422 | "node_modules/inflight": { 423 | "version": "1.0.6", 424 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 425 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 426 | "dev": true, 427 | "dependencies": { 428 | "once": "^1.3.0", 429 | "wrappy": "1" 430 | } 431 | }, 432 | "node_modules/inherits": { 433 | "version": "2.0.4", 434 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 435 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 436 | "dev": true 437 | }, 438 | "node_modules/is-binary-path": { 439 | "version": "2.1.0", 440 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 441 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 442 | "dev": true, 443 | "dependencies": { 444 | "binary-extensions": "^2.0.0" 445 | }, 446 | "engines": { 447 | "node": ">=8" 448 | } 449 | }, 450 | "node_modules/is-extglob": { 451 | "version": "2.1.1", 452 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 453 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 454 | "dev": true, 455 | "engines": { 456 | "node": ">=0.10.0" 457 | } 458 | }, 459 | "node_modules/is-fullwidth-code-point": { 460 | "version": "3.0.0", 461 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 462 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 463 | "dev": true, 464 | "engines": { 465 | "node": ">=8" 466 | } 467 | }, 468 | "node_modules/is-glob": { 469 | "version": "4.0.3", 470 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 471 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 472 | "dev": true, 473 | "dependencies": { 474 | "is-extglob": "^2.1.1" 475 | }, 476 | "engines": { 477 | "node": ">=0.10.0" 478 | } 479 | }, 480 | "node_modules/is-number": { 481 | "version": "7.0.0", 482 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 483 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 484 | "dev": true, 485 | "engines": { 486 | "node": ">=0.12.0" 487 | } 488 | }, 489 | "node_modules/is-plain-obj": { 490 | "version": "2.1.0", 491 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 492 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 493 | "dev": true, 494 | "engines": { 495 | "node": ">=8" 496 | } 497 | }, 498 | "node_modules/is-unicode-supported": { 499 | "version": "0.1.0", 500 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 501 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 502 | "dev": true, 503 | "engines": { 504 | "node": ">=10" 505 | }, 506 | "funding": { 507 | "url": "https://github.com/sponsors/sindresorhus" 508 | } 509 | }, 510 | "node_modules/js-yaml": { 511 | "version": "4.1.0", 512 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 513 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 514 | "dev": true, 515 | "dependencies": { 516 | "argparse": "^2.0.1" 517 | }, 518 | "bin": { 519 | "js-yaml": "bin/js-yaml.js" 520 | } 521 | }, 522 | "node_modules/locate-path": { 523 | "version": "6.0.0", 524 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 525 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 526 | "dev": true, 527 | "dependencies": { 528 | "p-locate": "^5.0.0" 529 | }, 530 | "engines": { 531 | "node": ">=10" 532 | }, 533 | "funding": { 534 | "url": "https://github.com/sponsors/sindresorhus" 535 | } 536 | }, 537 | "node_modules/log-symbols": { 538 | "version": "4.1.0", 539 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 540 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 541 | "dev": true, 542 | "dependencies": { 543 | "chalk": "^4.1.0", 544 | "is-unicode-supported": "^0.1.0" 545 | }, 546 | "engines": { 547 | "node": ">=10" 548 | }, 549 | "funding": { 550 | "url": "https://github.com/sponsors/sindresorhus" 551 | } 552 | }, 553 | "node_modules/minimatch": { 554 | "version": "5.0.1", 555 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 556 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 557 | "dev": true, 558 | "dependencies": { 559 | "brace-expansion": "^2.0.1" 560 | }, 561 | "engines": { 562 | "node": ">=10" 563 | } 564 | }, 565 | "node_modules/mocha": { 566 | "version": "10.2.0", 567 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.2.0.tgz", 568 | "integrity": "sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg==", 569 | "dev": true, 570 | "dependencies": { 571 | "ansi-colors": "4.1.1", 572 | "browser-stdout": "1.3.1", 573 | "chokidar": "3.5.3", 574 | "debug": "4.3.4", 575 | "diff": "5.0.0", 576 | "escape-string-regexp": "4.0.0", 577 | "find-up": "5.0.0", 578 | "glob": "7.2.0", 579 | "he": "1.2.0", 580 | "js-yaml": "4.1.0", 581 | "log-symbols": "4.1.0", 582 | "minimatch": "5.0.1", 583 | "ms": "2.1.3", 584 | "nanoid": "3.3.3", 585 | "serialize-javascript": "6.0.0", 586 | "strip-json-comments": "3.1.1", 587 | "supports-color": "8.1.1", 588 | "workerpool": "6.2.1", 589 | "yargs": "16.2.0", 590 | "yargs-parser": "20.2.4", 591 | "yargs-unparser": "2.0.0" 592 | }, 593 | "bin": { 594 | "_mocha": "bin/_mocha", 595 | "mocha": "bin/mocha.js" 596 | }, 597 | "engines": { 598 | "node": ">= 14.0.0" 599 | }, 600 | "funding": { 601 | "type": "opencollective", 602 | "url": "https://opencollective.com/mochajs" 603 | } 604 | }, 605 | "node_modules/ms": { 606 | "version": "2.1.3", 607 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 608 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 609 | "dev": true 610 | }, 611 | "node_modules/nanoid": { 612 | "version": "3.3.3", 613 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", 614 | "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", 615 | "dev": true, 616 | "bin": { 617 | "nanoid": "bin/nanoid.cjs" 618 | }, 619 | "engines": { 620 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 621 | } 622 | }, 623 | "node_modules/normalize-path": { 624 | "version": "3.0.0", 625 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 626 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 627 | "dev": true, 628 | "engines": { 629 | "node": ">=0.10.0" 630 | } 631 | }, 632 | "node_modules/once": { 633 | "version": "1.4.0", 634 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 635 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 636 | "dev": true, 637 | "dependencies": { 638 | "wrappy": "1" 639 | } 640 | }, 641 | "node_modules/p-limit": { 642 | "version": "3.1.0", 643 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 644 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 645 | "dev": true, 646 | "dependencies": { 647 | "yocto-queue": "^0.1.0" 648 | }, 649 | "engines": { 650 | "node": ">=10" 651 | }, 652 | "funding": { 653 | "url": "https://github.com/sponsors/sindresorhus" 654 | } 655 | }, 656 | "node_modules/p-locate": { 657 | "version": "5.0.0", 658 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 659 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 660 | "dev": true, 661 | "dependencies": { 662 | "p-limit": "^3.0.2" 663 | }, 664 | "engines": { 665 | "node": ">=10" 666 | }, 667 | "funding": { 668 | "url": "https://github.com/sponsors/sindresorhus" 669 | } 670 | }, 671 | "node_modules/path-exists": { 672 | "version": "4.0.0", 673 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 674 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 675 | "dev": true, 676 | "engines": { 677 | "node": ">=8" 678 | } 679 | }, 680 | "node_modules/path-is-absolute": { 681 | "version": "1.0.1", 682 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 683 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 684 | "dev": true, 685 | "engines": { 686 | "node": ">=0.10.0" 687 | } 688 | }, 689 | "node_modules/picomatch": { 690 | "version": "2.3.1", 691 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 692 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 693 | "dev": true, 694 | "engines": { 695 | "node": ">=8.6" 696 | }, 697 | "funding": { 698 | "url": "https://github.com/sponsors/jonschlinkert" 699 | } 700 | }, 701 | "node_modules/randombytes": { 702 | "version": "2.1.0", 703 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 704 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 705 | "dev": true, 706 | "dependencies": { 707 | "safe-buffer": "^5.1.0" 708 | } 709 | }, 710 | "node_modules/readdirp": { 711 | "version": "3.6.0", 712 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 713 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 714 | "dev": true, 715 | "dependencies": { 716 | "picomatch": "^2.2.1" 717 | }, 718 | "engines": { 719 | "node": ">=8.10.0" 720 | } 721 | }, 722 | "node_modules/require-directory": { 723 | "version": "2.1.1", 724 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 725 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 726 | "dev": true, 727 | "engines": { 728 | "node": ">=0.10.0" 729 | } 730 | }, 731 | "node_modules/safe-buffer": { 732 | "version": "5.2.1", 733 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 734 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 735 | "dev": true, 736 | "funding": [ 737 | { 738 | "type": "github", 739 | "url": "https://github.com/sponsors/feross" 740 | }, 741 | { 742 | "type": "patreon", 743 | "url": "https://www.patreon.com/feross" 744 | }, 745 | { 746 | "type": "consulting", 747 | "url": "https://feross.org/support" 748 | } 749 | ] 750 | }, 751 | "node_modules/serialize-javascript": { 752 | "version": "6.0.0", 753 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 754 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 755 | "dev": true, 756 | "dependencies": { 757 | "randombytes": "^2.1.0" 758 | } 759 | }, 760 | "node_modules/string-width": { 761 | "version": "4.2.3", 762 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 763 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 764 | "dev": true, 765 | "dependencies": { 766 | "emoji-regex": "^8.0.0", 767 | "is-fullwidth-code-point": "^3.0.0", 768 | "strip-ansi": "^6.0.1" 769 | }, 770 | "engines": { 771 | "node": ">=8" 772 | } 773 | }, 774 | "node_modules/strip-ansi": { 775 | "version": "6.0.1", 776 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 777 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 778 | "dev": true, 779 | "dependencies": { 780 | "ansi-regex": "^5.0.1" 781 | }, 782 | "engines": { 783 | "node": ">=8" 784 | } 785 | }, 786 | "node_modules/strip-json-comments": { 787 | "version": "3.1.1", 788 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 789 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 790 | "dev": true, 791 | "engines": { 792 | "node": ">=8" 793 | }, 794 | "funding": { 795 | "url": "https://github.com/sponsors/sindresorhus" 796 | } 797 | }, 798 | "node_modules/supports-color": { 799 | "version": "8.1.1", 800 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 801 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 802 | "dev": true, 803 | "dependencies": { 804 | "has-flag": "^4.0.0" 805 | }, 806 | "engines": { 807 | "node": ">=10" 808 | }, 809 | "funding": { 810 | "url": "https://github.com/chalk/supports-color?sponsor=1" 811 | } 812 | }, 813 | "node_modules/to-regex-range": { 814 | "version": "5.0.1", 815 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 816 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 817 | "dev": true, 818 | "dependencies": { 819 | "is-number": "^7.0.0" 820 | }, 821 | "engines": { 822 | "node": ">=8.0" 823 | } 824 | }, 825 | "node_modules/workerpool": { 826 | "version": "6.2.1", 827 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 828 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 829 | "dev": true 830 | }, 831 | "node_modules/wrap-ansi": { 832 | "version": "7.0.0", 833 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 834 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 835 | "dev": true, 836 | "dependencies": { 837 | "ansi-styles": "^4.0.0", 838 | "string-width": "^4.1.0", 839 | "strip-ansi": "^6.0.0" 840 | }, 841 | "engines": { 842 | "node": ">=10" 843 | }, 844 | "funding": { 845 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 846 | } 847 | }, 848 | "node_modules/wrappy": { 849 | "version": "1.0.2", 850 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 851 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 852 | "dev": true 853 | }, 854 | "node_modules/y18n": { 855 | "version": "5.0.8", 856 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 857 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 858 | "dev": true, 859 | "engines": { 860 | "node": ">=10" 861 | } 862 | }, 863 | "node_modules/yargs": { 864 | "version": "16.2.0", 865 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 866 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 867 | "dev": true, 868 | "dependencies": { 869 | "cliui": "^7.0.2", 870 | "escalade": "^3.1.1", 871 | "get-caller-file": "^2.0.5", 872 | "require-directory": "^2.1.1", 873 | "string-width": "^4.2.0", 874 | "y18n": "^5.0.5", 875 | "yargs-parser": "^20.2.2" 876 | }, 877 | "engines": { 878 | "node": ">=10" 879 | } 880 | }, 881 | "node_modules/yargs-parser": { 882 | "version": "20.2.4", 883 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 884 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 885 | "dev": true, 886 | "engines": { 887 | "node": ">=10" 888 | } 889 | }, 890 | "node_modules/yargs-unparser": { 891 | "version": "2.0.0", 892 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 893 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 894 | "dev": true, 895 | "dependencies": { 896 | "camelcase": "^6.0.0", 897 | "decamelize": "^4.0.0", 898 | "flat": "^5.0.2", 899 | "is-plain-obj": "^2.1.0" 900 | }, 901 | "engines": { 902 | "node": ">=10" 903 | } 904 | }, 905 | "node_modules/yocto-queue": { 906 | "version": "0.1.0", 907 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 908 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 909 | "dev": true, 910 | "engines": { 911 | "node": ">=10" 912 | }, 913 | "funding": { 914 | "url": "https://github.com/sponsors/sindresorhus" 915 | } 916 | } 917 | }, 918 | "dependencies": { 919 | "ansi-colors": { 920 | "version": "4.1.1", 921 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 922 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 923 | "dev": true 924 | }, 925 | "ansi-regex": { 926 | "version": "5.0.1", 927 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 928 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 929 | "dev": true 930 | }, 931 | "ansi-styles": { 932 | "version": "4.3.0", 933 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 934 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 935 | "dev": true, 936 | "requires": { 937 | "color-convert": "^2.0.1" 938 | } 939 | }, 940 | "anymatch": { 941 | "version": "3.1.3", 942 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 943 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 944 | "dev": true, 945 | "requires": { 946 | "normalize-path": "^3.0.0", 947 | "picomatch": "^2.0.4" 948 | } 949 | }, 950 | "argparse": { 951 | "version": "2.0.1", 952 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 953 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 954 | "dev": true 955 | }, 956 | "balanced-match": { 957 | "version": "1.0.2", 958 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 959 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 960 | "dev": true 961 | }, 962 | "binary-extensions": { 963 | "version": "2.2.0", 964 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 965 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 966 | "dev": true 967 | }, 968 | "brace-expansion": { 969 | "version": "2.0.1", 970 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 971 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 972 | "dev": true, 973 | "requires": { 974 | "balanced-match": "^1.0.0" 975 | } 976 | }, 977 | "braces": { 978 | "version": "3.0.2", 979 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 980 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 981 | "dev": true, 982 | "requires": { 983 | "fill-range": "^7.0.1" 984 | } 985 | }, 986 | "browser-stdout": { 987 | "version": "1.3.1", 988 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 989 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 990 | "dev": true 991 | }, 992 | "camelcase": { 993 | "version": "6.3.0", 994 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 995 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 996 | "dev": true 997 | }, 998 | "chalk": { 999 | "version": "4.1.2", 1000 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1001 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1002 | "dev": true, 1003 | "requires": { 1004 | "ansi-styles": "^4.1.0", 1005 | "supports-color": "^7.1.0" 1006 | }, 1007 | "dependencies": { 1008 | "supports-color": { 1009 | "version": "7.2.0", 1010 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1011 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1012 | "dev": true, 1013 | "requires": { 1014 | "has-flag": "^4.0.0" 1015 | } 1016 | } 1017 | } 1018 | }, 1019 | "chokidar": { 1020 | "version": "3.5.3", 1021 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 1022 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 1023 | "dev": true, 1024 | "requires": { 1025 | "anymatch": "~3.1.2", 1026 | "braces": "~3.0.2", 1027 | "fsevents": "~2.3.2", 1028 | "glob-parent": "~5.1.2", 1029 | "is-binary-path": "~2.1.0", 1030 | "is-glob": "~4.0.1", 1031 | "normalize-path": "~3.0.0", 1032 | "readdirp": "~3.6.0" 1033 | } 1034 | }, 1035 | "cliui": { 1036 | "version": "7.0.4", 1037 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 1038 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 1039 | "dev": true, 1040 | "requires": { 1041 | "string-width": "^4.2.0", 1042 | "strip-ansi": "^6.0.0", 1043 | "wrap-ansi": "^7.0.0" 1044 | } 1045 | }, 1046 | "color-convert": { 1047 | "version": "2.0.1", 1048 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1049 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1050 | "dev": true, 1051 | "requires": { 1052 | "color-name": "~1.1.4" 1053 | } 1054 | }, 1055 | "color-name": { 1056 | "version": "1.1.4", 1057 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1058 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1059 | "dev": true 1060 | }, 1061 | "concat-map": { 1062 | "version": "0.0.1", 1063 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1064 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1065 | "dev": true 1066 | }, 1067 | "debug": { 1068 | "version": "4.3.4", 1069 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1070 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1071 | "dev": true, 1072 | "requires": { 1073 | "ms": "2.1.2" 1074 | }, 1075 | "dependencies": { 1076 | "ms": { 1077 | "version": "2.1.2", 1078 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1079 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1080 | "dev": true 1081 | } 1082 | } 1083 | }, 1084 | "decamelize": { 1085 | "version": "4.0.0", 1086 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 1087 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 1088 | "dev": true 1089 | }, 1090 | "diff": { 1091 | "version": "5.0.0", 1092 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 1093 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 1094 | "dev": true 1095 | }, 1096 | "emoji-regex": { 1097 | "version": "8.0.0", 1098 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1099 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1100 | "dev": true 1101 | }, 1102 | "escalade": { 1103 | "version": "3.1.1", 1104 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1105 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1106 | "dev": true 1107 | }, 1108 | "escape-string-regexp": { 1109 | "version": "4.0.0", 1110 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1111 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1112 | "dev": true 1113 | }, 1114 | "fill-range": { 1115 | "version": "7.0.1", 1116 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1117 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1118 | "dev": true, 1119 | "requires": { 1120 | "to-regex-range": "^5.0.1" 1121 | } 1122 | }, 1123 | "find-up": { 1124 | "version": "5.0.0", 1125 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1126 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1127 | "dev": true, 1128 | "requires": { 1129 | "locate-path": "^6.0.0", 1130 | "path-exists": "^4.0.0" 1131 | } 1132 | }, 1133 | "flat": { 1134 | "version": "5.0.2", 1135 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1136 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1137 | "dev": true 1138 | }, 1139 | "fs.realpath": { 1140 | "version": "1.0.0", 1141 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1142 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1143 | "dev": true 1144 | }, 1145 | "fsevents": { 1146 | "version": "2.3.2", 1147 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1148 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1149 | "dev": true, 1150 | "optional": true 1151 | }, 1152 | "get-caller-file": { 1153 | "version": "2.0.5", 1154 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1155 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1156 | "dev": true 1157 | }, 1158 | "glob": { 1159 | "version": "7.2.0", 1160 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 1161 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 1162 | "dev": true, 1163 | "requires": { 1164 | "fs.realpath": "^1.0.0", 1165 | "inflight": "^1.0.4", 1166 | "inherits": "2", 1167 | "minimatch": "^3.0.4", 1168 | "once": "^1.3.0", 1169 | "path-is-absolute": "^1.0.0" 1170 | }, 1171 | "dependencies": { 1172 | "brace-expansion": { 1173 | "version": "1.1.11", 1174 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1175 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1176 | "dev": true, 1177 | "requires": { 1178 | "balanced-match": "^1.0.0", 1179 | "concat-map": "0.0.1" 1180 | } 1181 | }, 1182 | "minimatch": { 1183 | "version": "3.1.2", 1184 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1185 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1186 | "dev": true, 1187 | "requires": { 1188 | "brace-expansion": "^1.1.7" 1189 | } 1190 | } 1191 | } 1192 | }, 1193 | "glob-parent": { 1194 | "version": "5.1.2", 1195 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1196 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1197 | "dev": true, 1198 | "requires": { 1199 | "is-glob": "^4.0.1" 1200 | } 1201 | }, 1202 | "has-flag": { 1203 | "version": "4.0.0", 1204 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1205 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1206 | "dev": true 1207 | }, 1208 | "he": { 1209 | "version": "1.2.0", 1210 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1211 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1212 | "dev": true 1213 | }, 1214 | "inflight": { 1215 | "version": "1.0.6", 1216 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1217 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1218 | "dev": true, 1219 | "requires": { 1220 | "once": "^1.3.0", 1221 | "wrappy": "1" 1222 | } 1223 | }, 1224 | "inherits": { 1225 | "version": "2.0.4", 1226 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1227 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1228 | "dev": true 1229 | }, 1230 | "is-binary-path": { 1231 | "version": "2.1.0", 1232 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1233 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1234 | "dev": true, 1235 | "requires": { 1236 | "binary-extensions": "^2.0.0" 1237 | } 1238 | }, 1239 | "is-extglob": { 1240 | "version": "2.1.1", 1241 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1242 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1243 | "dev": true 1244 | }, 1245 | "is-fullwidth-code-point": { 1246 | "version": "3.0.0", 1247 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1248 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1249 | "dev": true 1250 | }, 1251 | "is-glob": { 1252 | "version": "4.0.3", 1253 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1254 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1255 | "dev": true, 1256 | "requires": { 1257 | "is-extglob": "^2.1.1" 1258 | } 1259 | }, 1260 | "is-number": { 1261 | "version": "7.0.0", 1262 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1263 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1264 | "dev": true 1265 | }, 1266 | "is-plain-obj": { 1267 | "version": "2.1.0", 1268 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1269 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1270 | "dev": true 1271 | }, 1272 | "is-unicode-supported": { 1273 | "version": "0.1.0", 1274 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1275 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1276 | "dev": true 1277 | }, 1278 | "js-yaml": { 1279 | "version": "4.1.0", 1280 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1281 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1282 | "dev": true, 1283 | "requires": { 1284 | "argparse": "^2.0.1" 1285 | } 1286 | }, 1287 | "locate-path": { 1288 | "version": "6.0.0", 1289 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1290 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1291 | "dev": true, 1292 | "requires": { 1293 | "p-locate": "^5.0.0" 1294 | } 1295 | }, 1296 | "log-symbols": { 1297 | "version": "4.1.0", 1298 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1299 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1300 | "dev": true, 1301 | "requires": { 1302 | "chalk": "^4.1.0", 1303 | "is-unicode-supported": "^0.1.0" 1304 | } 1305 | }, 1306 | "minimatch": { 1307 | "version": "5.0.1", 1308 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 1309 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 1310 | "dev": true, 1311 | "requires": { 1312 | "brace-expansion": "^2.0.1" 1313 | } 1314 | }, 1315 | "mocha": { 1316 | "version": "10.2.0", 1317 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.2.0.tgz", 1318 | "integrity": "sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg==", 1319 | "dev": true, 1320 | "requires": { 1321 | "ansi-colors": "4.1.1", 1322 | "browser-stdout": "1.3.1", 1323 | "chokidar": "3.5.3", 1324 | "debug": "4.3.4", 1325 | "diff": "5.0.0", 1326 | "escape-string-regexp": "4.0.0", 1327 | "find-up": "5.0.0", 1328 | "glob": "7.2.0", 1329 | "he": "1.2.0", 1330 | "js-yaml": "4.1.0", 1331 | "log-symbols": "4.1.0", 1332 | "minimatch": "5.0.1", 1333 | "ms": "2.1.3", 1334 | "nanoid": "3.3.3", 1335 | "serialize-javascript": "6.0.0", 1336 | "strip-json-comments": "3.1.1", 1337 | "supports-color": "8.1.1", 1338 | "workerpool": "6.2.1", 1339 | "yargs": "16.2.0", 1340 | "yargs-parser": "20.2.4", 1341 | "yargs-unparser": "2.0.0" 1342 | } 1343 | }, 1344 | "ms": { 1345 | "version": "2.1.3", 1346 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1347 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1348 | "dev": true 1349 | }, 1350 | "nanoid": { 1351 | "version": "3.3.3", 1352 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", 1353 | "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", 1354 | "dev": true 1355 | }, 1356 | "normalize-path": { 1357 | "version": "3.0.0", 1358 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1359 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1360 | "dev": true 1361 | }, 1362 | "once": { 1363 | "version": "1.4.0", 1364 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1365 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1366 | "dev": true, 1367 | "requires": { 1368 | "wrappy": "1" 1369 | } 1370 | }, 1371 | "p-limit": { 1372 | "version": "3.1.0", 1373 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1374 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1375 | "dev": true, 1376 | "requires": { 1377 | "yocto-queue": "^0.1.0" 1378 | } 1379 | }, 1380 | "p-locate": { 1381 | "version": "5.0.0", 1382 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1383 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1384 | "dev": true, 1385 | "requires": { 1386 | "p-limit": "^3.0.2" 1387 | } 1388 | }, 1389 | "path-exists": { 1390 | "version": "4.0.0", 1391 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1392 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1393 | "dev": true 1394 | }, 1395 | "path-is-absolute": { 1396 | "version": "1.0.1", 1397 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1398 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1399 | "dev": true 1400 | }, 1401 | "picomatch": { 1402 | "version": "2.3.1", 1403 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1404 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1405 | "dev": true 1406 | }, 1407 | "randombytes": { 1408 | "version": "2.1.0", 1409 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1410 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1411 | "dev": true, 1412 | "requires": { 1413 | "safe-buffer": "^5.1.0" 1414 | } 1415 | }, 1416 | "readdirp": { 1417 | "version": "3.6.0", 1418 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1419 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1420 | "dev": true, 1421 | "requires": { 1422 | "picomatch": "^2.2.1" 1423 | } 1424 | }, 1425 | "require-directory": { 1426 | "version": "2.1.1", 1427 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1428 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1429 | "dev": true 1430 | }, 1431 | "safe-buffer": { 1432 | "version": "5.2.1", 1433 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1434 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1435 | "dev": true 1436 | }, 1437 | "serialize-javascript": { 1438 | "version": "6.0.0", 1439 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1440 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1441 | "dev": true, 1442 | "requires": { 1443 | "randombytes": "^2.1.0" 1444 | } 1445 | }, 1446 | "string-width": { 1447 | "version": "4.2.3", 1448 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1449 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1450 | "dev": true, 1451 | "requires": { 1452 | "emoji-regex": "^8.0.0", 1453 | "is-fullwidth-code-point": "^3.0.0", 1454 | "strip-ansi": "^6.0.1" 1455 | } 1456 | }, 1457 | "strip-ansi": { 1458 | "version": "6.0.1", 1459 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1460 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1461 | "dev": true, 1462 | "requires": { 1463 | "ansi-regex": "^5.0.1" 1464 | } 1465 | }, 1466 | "strip-json-comments": { 1467 | "version": "3.1.1", 1468 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1469 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1470 | "dev": true 1471 | }, 1472 | "supports-color": { 1473 | "version": "8.1.1", 1474 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1475 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1476 | "dev": true, 1477 | "requires": { 1478 | "has-flag": "^4.0.0" 1479 | } 1480 | }, 1481 | "to-regex-range": { 1482 | "version": "5.0.1", 1483 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1484 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1485 | "dev": true, 1486 | "requires": { 1487 | "is-number": "^7.0.0" 1488 | } 1489 | }, 1490 | "workerpool": { 1491 | "version": "6.2.1", 1492 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 1493 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 1494 | "dev": true 1495 | }, 1496 | "wrap-ansi": { 1497 | "version": "7.0.0", 1498 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1499 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1500 | "dev": true, 1501 | "requires": { 1502 | "ansi-styles": "^4.0.0", 1503 | "string-width": "^4.1.0", 1504 | "strip-ansi": "^6.0.0" 1505 | } 1506 | }, 1507 | "wrappy": { 1508 | "version": "1.0.2", 1509 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1510 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1511 | "dev": true 1512 | }, 1513 | "y18n": { 1514 | "version": "5.0.8", 1515 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1516 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1517 | "dev": true 1518 | }, 1519 | "yargs": { 1520 | "version": "16.2.0", 1521 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1522 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1523 | "dev": true, 1524 | "requires": { 1525 | "cliui": "^7.0.2", 1526 | "escalade": "^3.1.1", 1527 | "get-caller-file": "^2.0.5", 1528 | "require-directory": "^2.1.1", 1529 | "string-width": "^4.2.0", 1530 | "y18n": "^5.0.5", 1531 | "yargs-parser": "^20.2.2" 1532 | } 1533 | }, 1534 | "yargs-parser": { 1535 | "version": "20.2.4", 1536 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1537 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1538 | "dev": true 1539 | }, 1540 | "yargs-unparser": { 1541 | "version": "2.0.0", 1542 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1543 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1544 | "dev": true, 1545 | "requires": { 1546 | "camelcase": "^6.0.0", 1547 | "decamelize": "^4.0.0", 1548 | "flat": "^5.0.2", 1549 | "is-plain-obj": "^2.1.0" 1550 | } 1551 | }, 1552 | "yocto-queue": { 1553 | "version": "0.1.0", 1554 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1555 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1556 | "dev": true 1557 | } 1558 | } 1559 | } 1560 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "localenvironment", 3 | "version": "1.2.1", 4 | "description": "Apply environment variables if they exist in env.json.", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "mocha --ui tdd test" 8 | }, 9 | "bin": { 10 | "localenvironment": "cli.js" 11 | }, 12 | "repository": { 13 | "type": "git", 14 | "url": "github.com:coreybutler/localenvironment.git" 15 | }, 16 | "keywords": [ 17 | "environment", 18 | "local", 19 | "configuration", 20 | "config", 21 | "variables" 22 | ], 23 | "author": "Corey Butler ", 24 | "license": "MIT", 25 | "devDependencies": { 26 | "mocha": "^10.2.0" 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /test/custom.json: -------------------------------------------------------------------------------- 1 | { 2 | "customized": "custom test" 3 | } -------------------------------------------------------------------------------- /test/index.js: -------------------------------------------------------------------------------- 1 | var assert = require('assert'); 2 | 3 | suite('localenvironment',function(){ 4 | test('Load JSON attributes from recognized files.',function(){ 5 | var vars = require('../') 6 | 7 | assert.ok(process.env.env_test === "test", "Failed. Expected to find process.env.env_test with a value of \"test\".") 8 | assert.ok(vars.hasOwnProperty('env_test'), "Failed. Expected to find env_test in the result of the require statement.") 9 | }) 10 | 11 | test('Load JSON attributes from custom JSON file.', function () { 12 | var local = require('../') 13 | local.load('./test/custom.json') 14 | 15 | assert.ok(process.env.customized === "custom test", "Failed. Expected to find process.env.customized with a value of \"custom test\".") 16 | assert.ok(local.hasOwnProperty('customized'), "Failed. Expected to find customized in the result of the require statement.") 17 | }) 18 | }) 19 | --------------------------------------------------------------------------------