├── .dockerignore ├── .github └── workflows │ └── docker-image.yml ├── .gitignore ├── Dockerfile ├── LICENSE ├── README.md ├── client ├── .gitignore ├── README.md ├── babel.config.js ├── package-lock.json ├── package.json ├── public │ ├── favicon.ico │ └── index.html ├── src │ ├── App.vue │ ├── main.js │ └── plugins │ │ └── vuetify.js └── vue.config.js ├── config └── .gitkeep ├── example ├── .gitignore ├── config │ └── .gitkeep └── docker-compose.yml ├── package-lock.json ├── package.json └── server ├── .babelrc ├── .env.example ├── .gitignore ├── package-lock.json ├── package.json ├── public └── .gitkeep └── src └── app.js /.dockerignore: -------------------------------------------------------------------------------- 1 | .idea 2 | client/dist 3 | **/node_modules 4 | npm-debug.log 5 | config 6 | -------------------------------------------------------------------------------- /.github/workflows/docker-image.yml: -------------------------------------------------------------------------------- 1 | name: Docker Image CI 2 | 3 | on: 4 | push: 5 | branches: 6 | - 'main' 7 | - 'develop' 8 | tags: 9 | - 'v[0-9]+.[0-9]+.[0-9]+' 10 | 11 | env: 12 | IMAGE_NAME: ${{ github.repository }} 13 | 14 | jobs: 15 | build-and-push-docker-image: 16 | runs-on: ubuntu-latest 17 | steps: 18 | - 19 | name: Checkout 20 | uses: actions/checkout@v3 21 | - 22 | name: Set up QEMU 23 | uses: docker/setup-qemu-action@v2 24 | - 25 | name: Set up Docker Buildx 26 | uses: docker/setup-buildx-action@v2 27 | - 28 | name: Login to GitHub Container Registry 29 | uses: docker/login-action@v2 30 | with: 31 | registry: ghcr.io 32 | username: ${{ github.actor }} 33 | password: ${{ secrets.GITHUB_TOKEN }} 34 | - 35 | name: Login to Docker Hub 36 | uses: docker/login-action@v2 37 | with: 38 | username: ${{ secrets.DOCKERHUB_USERNAME }} 39 | password: ${{ secrets.DOCKERHUB_TOKEN }} 40 | - 41 | name: Extract Docker metadata 42 | id: meta 43 | uses: docker/metadata-action@v4 44 | with: 45 | images: | 46 | ${{ env.IMAGE_NAME }} 47 | ghcr.io/${{ env.IMAGE_NAME }} 48 | - 49 | name: Build and Push Docker Image 50 | id: build-and-push 51 | uses: docker/build-push-action@v3 52 | with: 53 | push: true 54 | cache-from: type=gha 55 | cache-to: type=gha,mode=max 56 | platforms: linux/amd64,linux/arm64 57 | tags: ${{ steps.meta.outputs.tags }} 58 | labels: ${{ steps.meta.outputs.labels }} 59 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | config/keycloak.json 2 | 3 | .DS_Store 4 | node_modules 5 | /dist 6 | 7 | # local env files 8 | .env.local 9 | .env.*.local 10 | 11 | # Log files 12 | npm-debug.log* 13 | yarn-debug.log* 14 | yarn-error.log* 15 | 16 | # Editor directories and files 17 | .idea 18 | .vscode 19 | *.suo 20 | *.ntvs* 21 | *.njsproj 22 | *.sln 23 | *.sw? 24 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM alpine:3.20 as build-client 2 | RUN apk add --no-cache npm python3 make gcc g++ 3 | WORKDIR /build 4 | COPY client/package*.json ./ 5 | RUN npm ci 6 | COPY client . 7 | RUN npm run build 8 | 9 | FROM alpine:3.20 as build-server 10 | RUN apk add --no-cache npm 11 | WORKDIR /build 12 | COPY server . 13 | RUN npm i --omit=dev 14 | 15 | FROM alpine:3.20 16 | RUN apk add --no-cache nodejs 17 | WORKDIR /app 18 | ENV NODE_ENV=production 19 | EXPOSE 3000 20 | CMD [ "node", "src/app.js" ] 21 | COPY --from=build-server /build . 22 | COPY --from=build-client /build/dist ./public 23 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 D3473R 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # jitsi-keycloak 2 | 3 | ![Build Status](https://img.shields.io/github/actions/workflow/status/d3473r/jitsi-keycloak/docker-image.yml) 4 | ![Latest Version](https://img.shields.io/github/v/tag/d3473r/jitsi-keycloak?label=Latest%20Version) 5 | ![Docker Pulls](https://img.shields.io/docker/pulls/d3473r/jitsi-keycloak) 6 | ![Docker Image Size (tag)](https://img.shields.io/docker/image-size/d3473r/jitsi-keycloak/latest) 7 | 8 | ## Installation 9 | 10 | - `npm install` 11 | 12 | ## Configuration 13 | 14 | ### Keycloak 15 | 16 | - Add a public openid-connect client in your keycloak realm 17 | - Download the `keycloak.json` file for your client and put it in the config directory. 18 | - Allow this app from keycloak (`jitsi-keycloak` running on https://auth.meet.example.com): 19 | 20 | keycloak 21 | 22 | - If you want to have an avatar displayed in jitsi you can add an avatar custom attribute in keycloak to your desired users: 23 | 24 | avatar 25 | 26 | ### Jitsi 27 | 28 | - Set `ENABLE_AUTH=1`, `AUTH_TYPE=jwt` and `JWT_APP_ID=jitsi` in your jitsi environment 29 | - Set `JWT_APP_SECRET` to a random string (e.g. `node -e "console.log(require('crypto').randomBytes(24).toString('base64'));"`) 30 | - To enable an automatic redirect from jitsi to login set the url of this container `TOKEN_AUTH_URL=https://auth.example.com/{room}` 31 | - To enable the guest lobby feature for every new room add `XMPP_MODULES=muc_lobby_rooms,persistent_lobby` and `XMPP_MUC_MODULES=lobby_autostart,token_lobby_bypass`. This will enable these two plugins: https://github.com/jitsi-contrib/prosody-plugins/tree/main/lobby_autostart and https://github.com/jitsi-contrib/prosody-plugins/tree/main/token_lobby_bypass. The `lobby_bypass` attribute is automatically enabled for every logged in user. 32 | 33 | ### Replace the following placeholders in `app.js` or pass them as environment variables: 34 | 35 | - `JITSI_SECRET` with the shared secret from jitsi `JWT_APP_SECRET`. 36 | - `DEFAULT_ROOM` with a default room name e.g. `meeting` 37 | - `JITSI_URL` with the url of your jitsi server e.g. `https://meet.example.com` 38 | 39 | ### (OPTIONAL) Replace the following placeholders in `app.js` or pass them as environment variables: 40 | - `ALLOWED_SUB` with the allowed sub, the default is `*` 41 | - `ALLOWED_ROOM` with the allowed room, the default is `*` 42 | 43 | ## Run 44 | 45 | - `npm run dev` 46 | 47 | ## Build with docker 48 | 49 | - `docker build -t jitsi-keycloak .` 50 | 51 | ## Run with docker 52 | 53 | - `docker run -it --rm -p 3000:3000 -v $(pwd)/config:/config jitsi-keycloak` 54 | 55 | ## Run with docker-compose in example directory 56 | 57 | - `docker-compose up -d` 58 | -------------------------------------------------------------------------------- /client/.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules 3 | /dist 4 | 5 | # local env files 6 | .env.local 7 | .env.*.local 8 | 9 | # Log files 10 | npm-debug.log* 11 | yarn-debug.log* 12 | yarn-error.log* 13 | 14 | # Editor directories and files 15 | .idea 16 | .vscode 17 | *.suo 18 | *.ntvs* 19 | *.njsproj 20 | *.sln 21 | *.sw? 22 | -------------------------------------------------------------------------------- /client/README.md: -------------------------------------------------------------------------------- 1 | # client 2 | 3 | ## Project setup 4 | ``` 5 | npm install 6 | ``` 7 | 8 | ### Compiles and hot-reloads for development 9 | ``` 10 | npm run serve 11 | ``` 12 | 13 | ### Compiles and minifies for production 14 | ``` 15 | npm run build 16 | ``` 17 | 18 | ### Lints and fixes files 19 | ``` 20 | npm run lint 21 | ``` 22 | 23 | ### Customize configuration 24 | See [Configuration Reference](https://cli.vuejs.org/config/). 25 | -------------------------------------------------------------------------------- /client/babel.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | presets: [ 3 | "@vue/cli-plugin-babel/preset" 4 | ] 5 | }; 6 | 7 | -------------------------------------------------------------------------------- /client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "client", 3 | "version": "1.0.0", 4 | "scripts": { 5 | "serve": "vue-cli-service serve", 6 | "build": "vue-cli-service build", 7 | "lint": "vue-cli-service lint" 8 | }, 9 | "dependencies": { 10 | "core-js": "^3.6.4", 11 | "keycloak-js": "^25.0.1", 12 | "uuid": "^9.0.0", 13 | "vue": "^2.6.11", 14 | "vue-router": "^3.4.9", 15 | "vuetify": "^2.6.10" 16 | }, 17 | "devDependencies": { 18 | "@babel/eslint-parser": "^7.19.1", 19 | "@vue/cli": "^5.0.8", 20 | "@vue/cli-plugin-babel": "~5.0.8", 21 | "@vue/cli-plugin-eslint": "~5.0.8", 22 | "@vue/cli-service": "~5.0.8", 23 | "eslint": "^8.22.0", 24 | "eslint-plugin-vue": "^9.3.0", 25 | "sass": "~1.32.12", 26 | "sass-loader": "^8.0.0", 27 | "vue-cli-plugin-vuetify": "~2.4.5", 28 | "vue-template-compiler": "^2.6.11", 29 | "vuetify-loader": "^1.3.0" 30 | }, 31 | "eslintConfig": { 32 | "root": true, 33 | "env": { 34 | "node": true 35 | }, 36 | "extends": [ 37 | "plugin:vue/essential", 38 | "eslint:recommended" 39 | ], 40 | "parserOptions": { 41 | "parser": "@babel/eslint-parser" 42 | }, 43 | "rules": {} 44 | }, 45 | "browserslist": [ 46 | "> 1%", 47 | "last 2 versions" 48 | ] 49 | } 50 | -------------------------------------------------------------------------------- /client/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/d3473r/jitsi-keycloak/c54d21ea142a4a693b6422d3c123b7afb3079ea2/client/public/favicon.ico -------------------------------------------------------------------------------- /client/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | Jitsi Keycloak 9 | 10 | 11 | 12 | 13 | 17 |
18 | 19 |
20 | 21 | 22 | -------------------------------------------------------------------------------- /client/src/App.vue: -------------------------------------------------------------------------------- 1 | 55 | 56 | 127 | 128 | 133 | -------------------------------------------------------------------------------- /client/src/main.js: -------------------------------------------------------------------------------- 1 | import Vue from "vue"; 2 | import VueRouter from "vue-router"; 3 | import App from "./App.vue"; 4 | import vuetify from "./plugins/vuetify"; 5 | import Keycloak from "keycloak-js"; 6 | 7 | Vue.use(VueRouter) 8 | Vue.config.productionTip = false; 9 | 10 | const router = new VueRouter({ 11 | mode: 'history', 12 | routes: [{path: '/:room', component: App}] 13 | }) 14 | 15 | const keycloak = new Keycloak("api/keycloak.json"); 16 | 17 | keycloak.init({onLoad: "login-required", checkLoginIframe: false}).then(() => { 18 | sessionStorage.setItem("vue-token", keycloak.token); 19 | sessionStorage.setItem("vue-refresh-token", keycloak.refreshToken); 20 | 21 | keycloak.loadUserProfile() 22 | .then(profile => { 23 | new Vue({ 24 | vuetify, 25 | router, 26 | render: h => h(App, {props: {keycloak: keycloak, profile: profile}}) 27 | }).$mount("#app"); 28 | 29 | setTimeout(() => { 30 | keycloak.updateToken(70).then(refreshed => { 31 | if (refreshed) { 32 | console.debug("Token refreshed" + refreshed); 33 | } else { 34 | console.warn("Token not refreshed, valid for " 35 | + Math.round(keycloak.tokenParsed.exp + keycloak.timeSkew - new Date().getTime() / 1000) + " seconds"); 36 | } 37 | }).catch(() => { 38 | console.error("Failed to refresh token"); 39 | }); 40 | }, 60000) 41 | }).catch(function () { 42 | console.error("Failed to load user profile"); 43 | }); 44 | }).catch(function() { 45 | alert("Did you configure CORS correctly?") 46 | }); 47 | -------------------------------------------------------------------------------- /client/src/plugins/vuetify.js: -------------------------------------------------------------------------------- 1 | import Vue from "vue"; 2 | import Vuetify from "vuetify/lib"; 3 | 4 | Vue.use(Vuetify); 5 | 6 | export default new Vuetify({}); 7 | -------------------------------------------------------------------------------- /client/vue.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | devServer: { 3 | proxy: { 4 | '^/api': { 5 | target: 'http://localhost:3000', 6 | changeOrigin: true, 7 | logLevel: 'debug' 8 | } 9 | } 10 | }, 11 | transpileDependencies: [ 12 | "vuetify" 13 | ] 14 | }; 15 | -------------------------------------------------------------------------------- /config/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/d3473r/jitsi-keycloak/c54d21ea142a4a693b6422d3c123b7afb3079ea2/config/.gitkeep -------------------------------------------------------------------------------- /example/.gitignore: -------------------------------------------------------------------------------- 1 | config/keycloak.json 2 | -------------------------------------------------------------------------------- /example/config/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/d3473r/jitsi-keycloak/c54d21ea142a4a693b6422d3c123b7afb3079ea2/example/config/.gitkeep -------------------------------------------------------------------------------- /example/docker-compose.yml: -------------------------------------------------------------------------------- 1 | version: '3' 2 | 3 | services: 4 | jitsi-keycloak: 5 | image: ghcr.io/d3473r/jitsi-keycloak 6 | container_name: jitsi-keycloak 7 | restart: unless-stopped 8 | environment: 9 | JITSI_SECRET: 123456789 10 | DEFAULT_ROOM: meeting 11 | JITSI_URL: https://meet.example.com/ 12 | volumes: 13 | - ./config:/config 14 | ports: 15 | - 3000:3000 16 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "jitsi-keycloak", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "jitsi-keycloak", 9 | "version": "1.0.0", 10 | "hasInstallScript": true, 11 | "license": "MIT", 12 | "devDependencies": { 13 | "cpy-cli": "^4.2.0", 14 | "npm-run-all": "^4.1.5" 15 | } 16 | }, 17 | "node_modules/@babel/code-frame": { 18 | "version": "7.18.6", 19 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", 20 | "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", 21 | "dev": true, 22 | "dependencies": { 23 | "@babel/highlight": "^7.18.6" 24 | }, 25 | "engines": { 26 | "node": ">=6.9.0" 27 | } 28 | }, 29 | "node_modules/@babel/helper-validator-identifier": { 30 | "version": "7.19.1", 31 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 32 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 33 | "dev": true, 34 | "engines": { 35 | "node": ">=6.9.0" 36 | } 37 | }, 38 | "node_modules/@babel/highlight": { 39 | "version": "7.18.6", 40 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 41 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 42 | "dev": true, 43 | "dependencies": { 44 | "@babel/helper-validator-identifier": "^7.18.6", 45 | "chalk": "^2.0.0", 46 | "js-tokens": "^4.0.0" 47 | }, 48 | "engines": { 49 | "node": ">=6.9.0" 50 | } 51 | }, 52 | "node_modules/@nodelib/fs.scandir": { 53 | "version": "2.1.5", 54 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 55 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 56 | "dev": true, 57 | "dependencies": { 58 | "@nodelib/fs.stat": "2.0.5", 59 | "run-parallel": "^1.1.9" 60 | }, 61 | "engines": { 62 | "node": ">= 8" 63 | } 64 | }, 65 | "node_modules/@nodelib/fs.stat": { 66 | "version": "2.0.5", 67 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 68 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 69 | "dev": true, 70 | "engines": { 71 | "node": ">= 8" 72 | } 73 | }, 74 | "node_modules/@nodelib/fs.walk": { 75 | "version": "1.2.8", 76 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 77 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 78 | "dev": true, 79 | "dependencies": { 80 | "@nodelib/fs.scandir": "2.1.5", 81 | "fastq": "^1.6.0" 82 | }, 83 | "engines": { 84 | "node": ">= 8" 85 | } 86 | }, 87 | "node_modules/@types/minimist": { 88 | "version": "1.2.2", 89 | "resolved": "https://registry.npmjs.org/@types/minimist/-/minimist-1.2.2.tgz", 90 | "integrity": "sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ==", 91 | "dev": true 92 | }, 93 | "node_modules/@types/normalize-package-data": { 94 | "version": "2.4.1", 95 | "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz", 96 | "integrity": "sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw==", 97 | "dev": true 98 | }, 99 | "node_modules/aggregate-error": { 100 | "version": "4.0.1", 101 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-4.0.1.tgz", 102 | "integrity": "sha512-0poP0T7el6Vq3rstR8Mn4V/IQrpBLO6POkUSrN7RhyY+GF/InCFShQzsQ39T25gkHhLgSLByyAz+Kjb+c2L98w==", 103 | "dev": true, 104 | "dependencies": { 105 | "clean-stack": "^4.0.0", 106 | "indent-string": "^5.0.0" 107 | }, 108 | "engines": { 109 | "node": ">=12" 110 | }, 111 | "funding": { 112 | "url": "https://github.com/sponsors/sindresorhus" 113 | } 114 | }, 115 | "node_modules/ansi-styles": { 116 | "version": "3.2.1", 117 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 118 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 119 | "dev": true, 120 | "dependencies": { 121 | "color-convert": "^1.9.0" 122 | }, 123 | "engines": { 124 | "node": ">=4" 125 | } 126 | }, 127 | "node_modules/arrify": { 128 | "version": "3.0.0", 129 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-3.0.0.tgz", 130 | "integrity": "sha512-tLkvA81vQG/XqE2mjDkGQHoOINtMHtysSnemrmoGe6PydDPMRbVugqyk4A6V/WDWEfm3l+0d8anA9r8cv/5Jaw==", 131 | "dev": true, 132 | "engines": { 133 | "node": ">=12" 134 | }, 135 | "funding": { 136 | "url": "https://github.com/sponsors/sindresorhus" 137 | } 138 | }, 139 | "node_modules/balanced-match": { 140 | "version": "1.0.0", 141 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 142 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 143 | "dev": true 144 | }, 145 | "node_modules/brace-expansion": { 146 | "version": "1.1.11", 147 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 148 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 149 | "dev": true, 150 | "dependencies": { 151 | "balanced-match": "^1.0.0", 152 | "concat-map": "0.0.1" 153 | } 154 | }, 155 | "node_modules/braces": { 156 | "version": "3.0.3", 157 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 158 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 159 | "dev": true, 160 | "dependencies": { 161 | "fill-range": "^7.1.1" 162 | }, 163 | "engines": { 164 | "node": ">=8" 165 | } 166 | }, 167 | "node_modules/call-bind": { 168 | "version": "1.0.0", 169 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.0.tgz", 170 | "integrity": "sha512-AEXsYIyyDY3MCzbwdhzG3Jx1R0J2wetQyUynn6dYHAO+bg8l1k7jwZtRv4ryryFs7EP+NDlikJlVe59jr0cM2w==", 171 | "dev": true, 172 | "dependencies": { 173 | "function-bind": "^1.1.1", 174 | "get-intrinsic": "^1.0.0" 175 | }, 176 | "funding": { 177 | "url": "https://github.com/sponsors/ljharb" 178 | } 179 | }, 180 | "node_modules/camelcase": { 181 | "version": "6.3.0", 182 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 183 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 184 | "dev": true, 185 | "engines": { 186 | "node": ">=10" 187 | }, 188 | "funding": { 189 | "url": "https://github.com/sponsors/sindresorhus" 190 | } 191 | }, 192 | "node_modules/camelcase-keys": { 193 | "version": "7.0.2", 194 | "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-7.0.2.tgz", 195 | "integrity": "sha512-Rjs1H+A9R+Ig+4E/9oyB66UC5Mj9Xq3N//vcLf2WzgdTi/3gUu3Z9KoqmlrEG4VuuLK8wJHofxzdQXz/knhiYg==", 196 | "dev": true, 197 | "dependencies": { 198 | "camelcase": "^6.3.0", 199 | "map-obj": "^4.1.0", 200 | "quick-lru": "^5.1.1", 201 | "type-fest": "^1.2.1" 202 | }, 203 | "engines": { 204 | "node": ">=12" 205 | }, 206 | "funding": { 207 | "url": "https://github.com/sponsors/sindresorhus" 208 | } 209 | }, 210 | "node_modules/chalk": { 211 | "version": "2.4.2", 212 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 213 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 214 | "dev": true, 215 | "dependencies": { 216 | "ansi-styles": "^3.2.1", 217 | "escape-string-regexp": "^1.0.5", 218 | "supports-color": "^5.3.0" 219 | }, 220 | "engines": { 221 | "node": ">=4" 222 | } 223 | }, 224 | "node_modules/clean-stack": { 225 | "version": "4.2.0", 226 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-4.2.0.tgz", 227 | "integrity": "sha512-LYv6XPxoyODi36Dp976riBtSY27VmFo+MKqEU9QCCWyTrdEPDog+RWA7xQWHi6Vbp61j5c4cdzzX1NidnwtUWg==", 228 | "dev": true, 229 | "dependencies": { 230 | "escape-string-regexp": "5.0.0" 231 | }, 232 | "engines": { 233 | "node": ">=12" 234 | }, 235 | "funding": { 236 | "url": "https://github.com/sponsors/sindresorhus" 237 | } 238 | }, 239 | "node_modules/clean-stack/node_modules/escape-string-regexp": { 240 | "version": "5.0.0", 241 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz", 242 | "integrity": "sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==", 243 | "dev": true, 244 | "engines": { 245 | "node": ">=12" 246 | }, 247 | "funding": { 248 | "url": "https://github.com/sponsors/sindresorhus" 249 | } 250 | }, 251 | "node_modules/color-convert": { 252 | "version": "1.9.3", 253 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 254 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 255 | "dev": true, 256 | "dependencies": { 257 | "color-name": "1.1.3" 258 | } 259 | }, 260 | "node_modules/color-name": { 261 | "version": "1.1.3", 262 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 263 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 264 | "dev": true 265 | }, 266 | "node_modules/concat-map": { 267 | "version": "0.0.1", 268 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 269 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 270 | "dev": true 271 | }, 272 | "node_modules/cp-file": { 273 | "version": "9.1.0", 274 | "resolved": "https://registry.npmjs.org/cp-file/-/cp-file-9.1.0.tgz", 275 | "integrity": "sha512-3scnzFj/94eb7y4wyXRWwvzLFaQp87yyfTnChIjlfYrVqp5lVO3E2hIJMeQIltUT0K2ZAB3An1qXcBmwGyvuwA==", 276 | "dev": true, 277 | "dependencies": { 278 | "graceful-fs": "^4.1.2", 279 | "make-dir": "^3.0.0", 280 | "nested-error-stacks": "^2.0.0", 281 | "p-event": "^4.1.0" 282 | }, 283 | "engines": { 284 | "node": ">=10" 285 | }, 286 | "funding": { 287 | "url": "https://github.com/sponsors/sindresorhus" 288 | } 289 | }, 290 | "node_modules/cpy": { 291 | "version": "9.0.1", 292 | "resolved": "https://registry.npmjs.org/cpy/-/cpy-9.0.1.tgz", 293 | "integrity": "sha512-D9U0DR5FjTCN3oMTcFGktanHnAG5l020yvOCR1zKILmAyPP7I/9pl6NFgRbDcmSENtbK1sQLBz1p9HIOlroiNg==", 294 | "dev": true, 295 | "dependencies": { 296 | "arrify": "^3.0.0", 297 | "cp-file": "^9.1.0", 298 | "globby": "^13.1.1", 299 | "junk": "^4.0.0", 300 | "micromatch": "^4.0.4", 301 | "nested-error-stacks": "^2.1.0", 302 | "p-filter": "^3.0.0", 303 | "p-map": "^5.3.0" 304 | }, 305 | "engines": { 306 | "node": "^12.20.0 || ^14.17.0 || >=16.0.0" 307 | }, 308 | "funding": { 309 | "url": "https://github.com/sponsors/sindresorhus" 310 | } 311 | }, 312 | "node_modules/cpy-cli": { 313 | "version": "4.2.0", 314 | "resolved": "https://registry.npmjs.org/cpy-cli/-/cpy-cli-4.2.0.tgz", 315 | "integrity": "sha512-b04b+cbdr29CdpREPKw/itrfjO43Ty0Aj7wRM6M6LoE4GJxZJCk9Xp+Eu1IqztkKh3LxIBt1tDplENsa6KYprg==", 316 | "dev": true, 317 | "dependencies": { 318 | "cpy": "^9.0.0", 319 | "meow": "^10.1.2" 320 | }, 321 | "bin": { 322 | "cpy": "cli.js" 323 | }, 324 | "engines": { 325 | "node": ">=12.20" 326 | }, 327 | "funding": { 328 | "url": "https://github.com/sponsors/sindresorhus" 329 | } 330 | }, 331 | "node_modules/cross-spawn": { 332 | "version": "6.0.6", 333 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.6.tgz", 334 | "integrity": "sha512-VqCUuhcd1iB+dsv8gxPttb5iZh/D0iubSP21g36KXdEuf6I5JiioesUVjpCdHV9MZRUfVFlvwtIUyPfxo5trtw==", 335 | "dev": true, 336 | "license": "MIT", 337 | "dependencies": { 338 | "nice-try": "^1.0.4", 339 | "path-key": "^2.0.1", 340 | "semver": "^5.5.0", 341 | "shebang-command": "^1.2.0", 342 | "which": "^1.2.9" 343 | }, 344 | "engines": { 345 | "node": ">=4.8" 346 | } 347 | }, 348 | "node_modules/cross-spawn/node_modules/semver": { 349 | "version": "5.7.2", 350 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 351 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 352 | "dev": true, 353 | "license": "ISC", 354 | "bin": { 355 | "semver": "bin/semver" 356 | } 357 | }, 358 | "node_modules/decamelize": { 359 | "version": "5.0.1", 360 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-5.0.1.tgz", 361 | "integrity": "sha512-VfxadyCECXgQlkoEAjeghAr5gY3Hf+IKjKb+X8tGVDtveCjN+USwprd2q3QXBR9T1+x2DG0XZF5/w+7HAtSaXA==", 362 | "dev": true, 363 | "engines": { 364 | "node": ">=10" 365 | }, 366 | "funding": { 367 | "url": "https://github.com/sponsors/sindresorhus" 368 | } 369 | }, 370 | "node_modules/decamelize-keys": { 371 | "version": "1.1.1", 372 | "resolved": "https://registry.npmjs.org/decamelize-keys/-/decamelize-keys-1.1.1.tgz", 373 | "integrity": "sha512-WiPxgEirIV0/eIOMcnFBA3/IJZAZqKnwAwWyvvdi4lsr1WCN22nhdf/3db3DoZcUjTV2SqfzIwNyp6y2xs3nmg==", 374 | "dev": true, 375 | "dependencies": { 376 | "decamelize": "^1.1.0", 377 | "map-obj": "^1.0.0" 378 | }, 379 | "engines": { 380 | "node": ">=0.10.0" 381 | }, 382 | "funding": { 383 | "url": "https://github.com/sponsors/sindresorhus" 384 | } 385 | }, 386 | "node_modules/decamelize-keys/node_modules/decamelize": { 387 | "version": "1.2.0", 388 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 389 | "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==", 390 | "dev": true, 391 | "engines": { 392 | "node": ">=0.10.0" 393 | } 394 | }, 395 | "node_modules/decamelize-keys/node_modules/map-obj": { 396 | "version": "1.0.1", 397 | "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", 398 | "integrity": "sha512-7N/q3lyZ+LVCp7PzuxrJr4KMbBE2hW7BT7YNia330OFxIf4d3r5zVpicP2650l7CPN6RM9zOJRl3NGpqSiw3Eg==", 399 | "dev": true, 400 | "engines": { 401 | "node": ">=0.10.0" 402 | } 403 | }, 404 | "node_modules/define-properties": { 405 | "version": "1.1.3", 406 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 407 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 408 | "dev": true, 409 | "dependencies": { 410 | "object-keys": "^1.0.12" 411 | }, 412 | "engines": { 413 | "node": ">= 0.4" 414 | } 415 | }, 416 | "node_modules/dir-glob": { 417 | "version": "3.0.1", 418 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 419 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 420 | "dev": true, 421 | "dependencies": { 422 | "path-type": "^4.0.0" 423 | }, 424 | "engines": { 425 | "node": ">=8" 426 | } 427 | }, 428 | "node_modules/dir-glob/node_modules/path-type": { 429 | "version": "4.0.0", 430 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 431 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 432 | "dev": true, 433 | "engines": { 434 | "node": ">=8" 435 | } 436 | }, 437 | "node_modules/error-ex": { 438 | "version": "1.3.2", 439 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 440 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 441 | "dev": true, 442 | "dependencies": { 443 | "is-arrayish": "^0.2.1" 444 | } 445 | }, 446 | "node_modules/es-abstract": { 447 | "version": "1.17.7", 448 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.7.tgz", 449 | "integrity": "sha512-VBl/gnfcJ7OercKA9MVaegWsBHFjV492syMudcnQZvt/Dw8ezpcOHYZXa/J96O8vx+g4x65YKhxOwDUh63aS5g==", 450 | "dev": true, 451 | "dependencies": { 452 | "es-to-primitive": "^1.2.1", 453 | "function-bind": "^1.1.1", 454 | "has": "^1.0.3", 455 | "has-symbols": "^1.0.1", 456 | "is-callable": "^1.2.2", 457 | "is-regex": "^1.1.1", 458 | "object-inspect": "^1.8.0", 459 | "object-keys": "^1.1.1", 460 | "object.assign": "^4.1.1", 461 | "string.prototype.trimend": "^1.0.1", 462 | "string.prototype.trimstart": "^1.0.1" 463 | }, 464 | "engines": { 465 | "node": ">= 0.4" 466 | }, 467 | "funding": { 468 | "url": "https://github.com/sponsors/ljharb" 469 | } 470 | }, 471 | "node_modules/es-to-primitive": { 472 | "version": "1.2.1", 473 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 474 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 475 | "dev": true, 476 | "dependencies": { 477 | "is-callable": "^1.1.4", 478 | "is-date-object": "^1.0.1", 479 | "is-symbol": "^1.0.2" 480 | }, 481 | "engines": { 482 | "node": ">= 0.4" 483 | }, 484 | "funding": { 485 | "url": "https://github.com/sponsors/ljharb" 486 | } 487 | }, 488 | "node_modules/escape-string-regexp": { 489 | "version": "1.0.5", 490 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 491 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 492 | "dev": true, 493 | "engines": { 494 | "node": ">=0.8.0" 495 | } 496 | }, 497 | "node_modules/fast-glob": { 498 | "version": "3.2.12", 499 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", 500 | "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", 501 | "dev": true, 502 | "dependencies": { 503 | "@nodelib/fs.stat": "^2.0.2", 504 | "@nodelib/fs.walk": "^1.2.3", 505 | "glob-parent": "^5.1.2", 506 | "merge2": "^1.3.0", 507 | "micromatch": "^4.0.4" 508 | }, 509 | "engines": { 510 | "node": ">=8.6.0" 511 | } 512 | }, 513 | "node_modules/fastq": { 514 | "version": "1.13.0", 515 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", 516 | "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", 517 | "dev": true, 518 | "dependencies": { 519 | "reusify": "^1.0.4" 520 | } 521 | }, 522 | "node_modules/fill-range": { 523 | "version": "7.1.1", 524 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 525 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 526 | "dev": true, 527 | "dependencies": { 528 | "to-regex-range": "^5.0.1" 529 | }, 530 | "engines": { 531 | "node": ">=8" 532 | } 533 | }, 534 | "node_modules/find-up": { 535 | "version": "5.0.0", 536 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 537 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 538 | "dev": true, 539 | "dependencies": { 540 | "locate-path": "^6.0.0", 541 | "path-exists": "^4.0.0" 542 | }, 543 | "engines": { 544 | "node": ">=10" 545 | }, 546 | "funding": { 547 | "url": "https://github.com/sponsors/sindresorhus" 548 | } 549 | }, 550 | "node_modules/function-bind": { 551 | "version": "1.1.1", 552 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 553 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 554 | "dev": true 555 | }, 556 | "node_modules/get-intrinsic": { 557 | "version": "1.0.1", 558 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.0.1.tgz", 559 | "integrity": "sha512-ZnWP+AmS1VUaLgTRy47+zKtjTxz+0xMpx3I52i+aalBK1QP19ggLF3Db89KJX7kjfOfP2eoa01qc++GwPgufPg==", 560 | "dev": true, 561 | "dependencies": { 562 | "function-bind": "^1.1.1", 563 | "has": "^1.0.3", 564 | "has-symbols": "^1.0.1" 565 | }, 566 | "funding": { 567 | "url": "https://github.com/sponsors/ljharb" 568 | } 569 | }, 570 | "node_modules/glob-parent": { 571 | "version": "5.1.2", 572 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 573 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 574 | "dev": true, 575 | "dependencies": { 576 | "is-glob": "^4.0.1" 577 | }, 578 | "engines": { 579 | "node": ">= 6" 580 | } 581 | }, 582 | "node_modules/globby": { 583 | "version": "13.1.2", 584 | "resolved": "https://registry.npmjs.org/globby/-/globby-13.1.2.tgz", 585 | "integrity": "sha512-LKSDZXToac40u8Q1PQtZihbNdTYSNMuWe+K5l+oa6KgDzSvVrHXlJy40hUP522RjAIoNLJYBJi7ow+rbFpIhHQ==", 586 | "dev": true, 587 | "dependencies": { 588 | "dir-glob": "^3.0.1", 589 | "fast-glob": "^3.2.11", 590 | "ignore": "^5.2.0", 591 | "merge2": "^1.4.1", 592 | "slash": "^4.0.0" 593 | }, 594 | "engines": { 595 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 596 | }, 597 | "funding": { 598 | "url": "https://github.com/sponsors/sindresorhus" 599 | } 600 | }, 601 | "node_modules/graceful-fs": { 602 | "version": "4.2.4", 603 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 604 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 605 | "dev": true 606 | }, 607 | "node_modules/hard-rejection": { 608 | "version": "2.1.0", 609 | "resolved": "https://registry.npmjs.org/hard-rejection/-/hard-rejection-2.1.0.tgz", 610 | "integrity": "sha512-VIZB+ibDhx7ObhAe7OVtoEbuP4h/MuOTHJ+J8h/eBXotJYl0fBgR72xDFCKgIh22OJZIOVNxBMWuhAr10r8HdA==", 611 | "dev": true, 612 | "engines": { 613 | "node": ">=6" 614 | } 615 | }, 616 | "node_modules/has": { 617 | "version": "1.0.3", 618 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 619 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 620 | "dev": true, 621 | "dependencies": { 622 | "function-bind": "^1.1.1" 623 | }, 624 | "engines": { 625 | "node": ">= 0.4.0" 626 | } 627 | }, 628 | "node_modules/has-flag": { 629 | "version": "3.0.0", 630 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 631 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 632 | "dev": true, 633 | "engines": { 634 | "node": ">=4" 635 | } 636 | }, 637 | "node_modules/has-symbols": { 638 | "version": "1.0.1", 639 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 640 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 641 | "dev": true, 642 | "engines": { 643 | "node": ">= 0.4" 644 | }, 645 | "funding": { 646 | "url": "https://github.com/sponsors/ljharb" 647 | } 648 | }, 649 | "node_modules/hosted-git-info": { 650 | "version": "2.8.9", 651 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 652 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", 653 | "dev": true 654 | }, 655 | "node_modules/ignore": { 656 | "version": "5.2.0", 657 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 658 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 659 | "dev": true, 660 | "engines": { 661 | "node": ">= 4" 662 | } 663 | }, 664 | "node_modules/indent-string": { 665 | "version": "5.0.0", 666 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-5.0.0.tgz", 667 | "integrity": "sha512-m6FAo/spmsW2Ab2fU35JTYwtOKa2yAwXSwgjSv1TJzh4Mh7mC3lzAOVLBprb72XsTrgkEIsl7YrFNAiDiRhIGg==", 668 | "dev": true, 669 | "engines": { 670 | "node": ">=12" 671 | }, 672 | "funding": { 673 | "url": "https://github.com/sponsors/sindresorhus" 674 | } 675 | }, 676 | "node_modules/is-arrayish": { 677 | "version": "0.2.1", 678 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 679 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 680 | "dev": true 681 | }, 682 | "node_modules/is-callable": { 683 | "version": "1.2.2", 684 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.2.tgz", 685 | "integrity": "sha512-dnMqspv5nU3LoewK2N/y7KLtxtakvTuaCsU9FU50/QDmdbHNy/4/JuRtMHqRU22o3q+W89YQndQEeCVwK+3qrA==", 686 | "dev": true, 687 | "engines": { 688 | "node": ">= 0.4" 689 | }, 690 | "funding": { 691 | "url": "https://github.com/sponsors/ljharb" 692 | } 693 | }, 694 | "node_modules/is-core-module": { 695 | "version": "2.11.0", 696 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", 697 | "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", 698 | "dev": true, 699 | "dependencies": { 700 | "has": "^1.0.3" 701 | }, 702 | "funding": { 703 | "url": "https://github.com/sponsors/ljharb" 704 | } 705 | }, 706 | "node_modules/is-date-object": { 707 | "version": "1.0.2", 708 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 709 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 710 | "dev": true, 711 | "engines": { 712 | "node": ">= 0.4" 713 | }, 714 | "funding": { 715 | "url": "https://github.com/sponsors/ljharb" 716 | } 717 | }, 718 | "node_modules/is-extglob": { 719 | "version": "2.1.1", 720 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 721 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 722 | "dev": true, 723 | "engines": { 724 | "node": ">=0.10.0" 725 | } 726 | }, 727 | "node_modules/is-glob": { 728 | "version": "4.0.3", 729 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 730 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 731 | "dev": true, 732 | "dependencies": { 733 | "is-extglob": "^2.1.1" 734 | }, 735 | "engines": { 736 | "node": ">=0.10.0" 737 | } 738 | }, 739 | "node_modules/is-negative-zero": { 740 | "version": "2.0.0", 741 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.0.tgz", 742 | "integrity": "sha1-lVOxIbD6wohp2p7UWeIMdUN4hGE=", 743 | "dev": true, 744 | "engines": { 745 | "node": ">= 0.4" 746 | } 747 | }, 748 | "node_modules/is-number": { 749 | "version": "7.0.0", 750 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 751 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 752 | "dev": true, 753 | "engines": { 754 | "node": ">=0.12.0" 755 | } 756 | }, 757 | "node_modules/is-plain-obj": { 758 | "version": "1.1.0", 759 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", 760 | "integrity": "sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==", 761 | "dev": true, 762 | "engines": { 763 | "node": ">=0.10.0" 764 | } 765 | }, 766 | "node_modules/is-regex": { 767 | "version": "1.1.1", 768 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz", 769 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==", 770 | "dev": true, 771 | "dependencies": { 772 | "has-symbols": "^1.0.1" 773 | }, 774 | "engines": { 775 | "node": ">= 0.4" 776 | }, 777 | "funding": { 778 | "url": "https://github.com/sponsors/ljharb" 779 | } 780 | }, 781 | "node_modules/is-symbol": { 782 | "version": "1.0.3", 783 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 784 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 785 | "dev": true, 786 | "dependencies": { 787 | "has-symbols": "^1.0.1" 788 | }, 789 | "engines": { 790 | "node": ">= 0.4" 791 | }, 792 | "funding": { 793 | "url": "https://github.com/sponsors/ljharb" 794 | } 795 | }, 796 | "node_modules/isexe": { 797 | "version": "2.0.0", 798 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 799 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 800 | "dev": true 801 | }, 802 | "node_modules/js-tokens": { 803 | "version": "4.0.0", 804 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 805 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 806 | "dev": true 807 | }, 808 | "node_modules/json-parse-better-errors": { 809 | "version": "1.0.2", 810 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 811 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 812 | "dev": true 813 | }, 814 | "node_modules/json-parse-even-better-errors": { 815 | "version": "2.3.1", 816 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 817 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", 818 | "dev": true 819 | }, 820 | "node_modules/junk": { 821 | "version": "4.0.0", 822 | "resolved": "https://registry.npmjs.org/junk/-/junk-4.0.0.tgz", 823 | "integrity": "sha512-ojtSU++zLJ3jQG9bAYjg94w+/DOJtRyD7nPaerMFrBhmdVmiV5/exYH5t4uHga4G/95nT6hr1OJoKIFbYbrW5w==", 824 | "dev": true, 825 | "engines": { 826 | "node": ">=12.20" 827 | }, 828 | "funding": { 829 | "url": "https://github.com/sponsors/sindresorhus" 830 | } 831 | }, 832 | "node_modules/kind-of": { 833 | "version": "6.0.3", 834 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", 835 | "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", 836 | "dev": true, 837 | "engines": { 838 | "node": ">=0.10.0" 839 | } 840 | }, 841 | "node_modules/lines-and-columns": { 842 | "version": "1.2.4", 843 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 844 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 845 | "dev": true 846 | }, 847 | "node_modules/load-json-file": { 848 | "version": "4.0.0", 849 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 850 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 851 | "dev": true, 852 | "dependencies": { 853 | "graceful-fs": "^4.1.2", 854 | "parse-json": "^4.0.0", 855 | "pify": "^3.0.0", 856 | "strip-bom": "^3.0.0" 857 | }, 858 | "engines": { 859 | "node": ">=4" 860 | } 861 | }, 862 | "node_modules/load-json-file/node_modules/pify": { 863 | "version": "3.0.0", 864 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 865 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 866 | "dev": true, 867 | "engines": { 868 | "node": ">=4" 869 | } 870 | }, 871 | "node_modules/locate-path": { 872 | "version": "6.0.0", 873 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 874 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 875 | "dev": true, 876 | "dependencies": { 877 | "p-locate": "^5.0.0" 878 | }, 879 | "engines": { 880 | "node": ">=10" 881 | }, 882 | "funding": { 883 | "url": "https://github.com/sponsors/sindresorhus" 884 | } 885 | }, 886 | "node_modules/lru-cache": { 887 | "version": "6.0.0", 888 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 889 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 890 | "dev": true, 891 | "dependencies": { 892 | "yallist": "^4.0.0" 893 | }, 894 | "engines": { 895 | "node": ">=10" 896 | } 897 | }, 898 | "node_modules/make-dir": { 899 | "version": "3.1.0", 900 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 901 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 902 | "dev": true, 903 | "dependencies": { 904 | "semver": "^6.0.0" 905 | }, 906 | "engines": { 907 | "node": ">=8" 908 | }, 909 | "funding": { 910 | "url": "https://github.com/sponsors/sindresorhus" 911 | } 912 | }, 913 | "node_modules/map-obj": { 914 | "version": "4.3.0", 915 | "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-4.3.0.tgz", 916 | "integrity": "sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==", 917 | "dev": true, 918 | "engines": { 919 | "node": ">=8" 920 | }, 921 | "funding": { 922 | "url": "https://github.com/sponsors/sindresorhus" 923 | } 924 | }, 925 | "node_modules/memorystream": { 926 | "version": "0.3.1", 927 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 928 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=", 929 | "dev": true, 930 | "engines": { 931 | "node": ">= 0.10.0" 932 | } 933 | }, 934 | "node_modules/meow": { 935 | "version": "10.1.5", 936 | "resolved": "https://registry.npmjs.org/meow/-/meow-10.1.5.tgz", 937 | "integrity": "sha512-/d+PQ4GKmGvM9Bee/DPa8z3mXs/pkvJE2KEThngVNOqtmljC6K7NMPxtc2JeZYTmpWb9k/TmxjeL18ez3h7vCw==", 938 | "dev": true, 939 | "dependencies": { 940 | "@types/minimist": "^1.2.2", 941 | "camelcase-keys": "^7.0.0", 942 | "decamelize": "^5.0.0", 943 | "decamelize-keys": "^1.1.0", 944 | "hard-rejection": "^2.1.0", 945 | "minimist-options": "4.1.0", 946 | "normalize-package-data": "^3.0.2", 947 | "read-pkg-up": "^8.0.0", 948 | "redent": "^4.0.0", 949 | "trim-newlines": "^4.0.2", 950 | "type-fest": "^1.2.2", 951 | "yargs-parser": "^20.2.9" 952 | }, 953 | "engines": { 954 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 955 | }, 956 | "funding": { 957 | "url": "https://github.com/sponsors/sindresorhus" 958 | } 959 | }, 960 | "node_modules/meow/node_modules/hosted-git-info": { 961 | "version": "4.1.0", 962 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.1.0.tgz", 963 | "integrity": "sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==", 964 | "dev": true, 965 | "dependencies": { 966 | "lru-cache": "^6.0.0" 967 | }, 968 | "engines": { 969 | "node": ">=10" 970 | } 971 | }, 972 | "node_modules/meow/node_modules/normalize-package-data": { 973 | "version": "3.0.3", 974 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-3.0.3.tgz", 975 | "integrity": "sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==", 976 | "dev": true, 977 | "dependencies": { 978 | "hosted-git-info": "^4.0.1", 979 | "is-core-module": "^2.5.0", 980 | "semver": "^7.3.4", 981 | "validate-npm-package-license": "^3.0.1" 982 | }, 983 | "engines": { 984 | "node": ">=10" 985 | } 986 | }, 987 | "node_modules/meow/node_modules/semver": { 988 | "version": "7.6.3", 989 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 990 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 991 | "dev": true, 992 | "license": "ISC", 993 | "bin": { 994 | "semver": "bin/semver.js" 995 | }, 996 | "engines": { 997 | "node": ">=10" 998 | } 999 | }, 1000 | "node_modules/merge2": { 1001 | "version": "1.4.1", 1002 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1003 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1004 | "dev": true, 1005 | "engines": { 1006 | "node": ">= 8" 1007 | } 1008 | }, 1009 | "node_modules/micromatch": { 1010 | "version": "4.0.8", 1011 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", 1012 | "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", 1013 | "dev": true, 1014 | "license": "MIT", 1015 | "dependencies": { 1016 | "braces": "^3.0.3", 1017 | "picomatch": "^2.3.1" 1018 | }, 1019 | "engines": { 1020 | "node": ">=8.6" 1021 | } 1022 | }, 1023 | "node_modules/min-indent": { 1024 | "version": "1.0.1", 1025 | "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", 1026 | "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==", 1027 | "dev": true, 1028 | "engines": { 1029 | "node": ">=4" 1030 | } 1031 | }, 1032 | "node_modules/minimatch": { 1033 | "version": "3.1.2", 1034 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1035 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1036 | "dev": true, 1037 | "dependencies": { 1038 | "brace-expansion": "^1.1.7" 1039 | }, 1040 | "engines": { 1041 | "node": "*" 1042 | } 1043 | }, 1044 | "node_modules/minimist-options": { 1045 | "version": "4.1.0", 1046 | "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-4.1.0.tgz", 1047 | "integrity": "sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A==", 1048 | "dev": true, 1049 | "dependencies": { 1050 | "arrify": "^1.0.1", 1051 | "is-plain-obj": "^1.1.0", 1052 | "kind-of": "^6.0.3" 1053 | }, 1054 | "engines": { 1055 | "node": ">= 6" 1056 | } 1057 | }, 1058 | "node_modules/minimist-options/node_modules/arrify": { 1059 | "version": "1.0.1", 1060 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 1061 | "integrity": "sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==", 1062 | "dev": true, 1063 | "engines": { 1064 | "node": ">=0.10.0" 1065 | } 1066 | }, 1067 | "node_modules/nested-error-stacks": { 1068 | "version": "2.1.1", 1069 | "resolved": "https://registry.npmjs.org/nested-error-stacks/-/nested-error-stacks-2.1.1.tgz", 1070 | "integrity": "sha512-9iN1ka/9zmX1ZvLV9ewJYEk9h7RyRRtqdK0woXcqohu8EWIerfPUjYJPg0ULy0UqP7cslmdGc8xKDJcojlKiaw==", 1071 | "dev": true 1072 | }, 1073 | "node_modules/nice-try": { 1074 | "version": "1.0.5", 1075 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1076 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1077 | "dev": true 1078 | }, 1079 | "node_modules/normalize-package-data": { 1080 | "version": "2.5.0", 1081 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1082 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1083 | "dev": true, 1084 | "dependencies": { 1085 | "hosted-git-info": "^2.1.4", 1086 | "resolve": "^1.10.0", 1087 | "semver": "2 || 3 || 4 || 5", 1088 | "validate-npm-package-license": "^3.0.1" 1089 | } 1090 | }, 1091 | "node_modules/normalize-package-data/node_modules/semver": { 1092 | "version": "5.7.2", 1093 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 1094 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 1095 | "dev": true, 1096 | "license": "ISC", 1097 | "bin": { 1098 | "semver": "bin/semver" 1099 | } 1100 | }, 1101 | "node_modules/npm-run-all": { 1102 | "version": "4.1.5", 1103 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 1104 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 1105 | "dev": true, 1106 | "dependencies": { 1107 | "ansi-styles": "^3.2.1", 1108 | "chalk": "^2.4.1", 1109 | "cross-spawn": "^6.0.5", 1110 | "memorystream": "^0.3.1", 1111 | "minimatch": "^3.0.4", 1112 | "pidtree": "^0.3.0", 1113 | "read-pkg": "^3.0.0", 1114 | "shell-quote": "^1.6.1", 1115 | "string.prototype.padend": "^3.0.0" 1116 | }, 1117 | "bin": { 1118 | "npm-run-all": "bin/npm-run-all/index.js", 1119 | "run-p": "bin/run-p/index.js", 1120 | "run-s": "bin/run-s/index.js" 1121 | }, 1122 | "engines": { 1123 | "node": ">= 4" 1124 | } 1125 | }, 1126 | "node_modules/object-inspect": { 1127 | "version": "1.8.0", 1128 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 1129 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 1130 | "dev": true, 1131 | "funding": { 1132 | "url": "https://github.com/sponsors/ljharb" 1133 | } 1134 | }, 1135 | "node_modules/object-keys": { 1136 | "version": "1.1.1", 1137 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1138 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1139 | "dev": true, 1140 | "engines": { 1141 | "node": ">= 0.4" 1142 | } 1143 | }, 1144 | "node_modules/object.assign": { 1145 | "version": "4.1.2", 1146 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 1147 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 1148 | "dev": true, 1149 | "dependencies": { 1150 | "call-bind": "^1.0.0", 1151 | "define-properties": "^1.1.3", 1152 | "has-symbols": "^1.0.1", 1153 | "object-keys": "^1.1.1" 1154 | }, 1155 | "engines": { 1156 | "node": ">= 0.4" 1157 | }, 1158 | "funding": { 1159 | "url": "https://github.com/sponsors/ljharb" 1160 | } 1161 | }, 1162 | "node_modules/p-event": { 1163 | "version": "4.2.0", 1164 | "resolved": "https://registry.npmjs.org/p-event/-/p-event-4.2.0.tgz", 1165 | "integrity": "sha512-KXatOjCRXXkSePPb1Nbi0p0m+gQAwdlbhi4wQKJPI1HsMQS9g+Sqp2o+QHziPr7eYJyOZet836KoHEVM1mwOrQ==", 1166 | "dev": true, 1167 | "dependencies": { 1168 | "p-timeout": "^3.1.0" 1169 | }, 1170 | "engines": { 1171 | "node": ">=8" 1172 | }, 1173 | "funding": { 1174 | "url": "https://github.com/sponsors/sindresorhus" 1175 | } 1176 | }, 1177 | "node_modules/p-filter": { 1178 | "version": "3.0.0", 1179 | "resolved": "https://registry.npmjs.org/p-filter/-/p-filter-3.0.0.tgz", 1180 | "integrity": "sha512-QtoWLjXAW++uTX67HZQz1dbTpqBfiidsB6VtQUC9iR85S120+s0T5sO6s+B5MLzFcZkrEd/DGMmCjR+f2Qpxwg==", 1181 | "dev": true, 1182 | "dependencies": { 1183 | "p-map": "^5.1.0" 1184 | }, 1185 | "engines": { 1186 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1187 | }, 1188 | "funding": { 1189 | "url": "https://github.com/sponsors/sindresorhus" 1190 | } 1191 | }, 1192 | "node_modules/p-finally": { 1193 | "version": "1.0.0", 1194 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1195 | "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==", 1196 | "dev": true, 1197 | "engines": { 1198 | "node": ">=4" 1199 | } 1200 | }, 1201 | "node_modules/p-limit": { 1202 | "version": "3.1.0", 1203 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1204 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1205 | "dev": true, 1206 | "dependencies": { 1207 | "yocto-queue": "^0.1.0" 1208 | }, 1209 | "engines": { 1210 | "node": ">=10" 1211 | }, 1212 | "funding": { 1213 | "url": "https://github.com/sponsors/sindresorhus" 1214 | } 1215 | }, 1216 | "node_modules/p-locate": { 1217 | "version": "5.0.0", 1218 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1219 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1220 | "dev": true, 1221 | "dependencies": { 1222 | "p-limit": "^3.0.2" 1223 | }, 1224 | "engines": { 1225 | "node": ">=10" 1226 | }, 1227 | "funding": { 1228 | "url": "https://github.com/sponsors/sindresorhus" 1229 | } 1230 | }, 1231 | "node_modules/p-map": { 1232 | "version": "5.5.0", 1233 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-5.5.0.tgz", 1234 | "integrity": "sha512-VFqfGDHlx87K66yZrNdI4YGtD70IRyd+zSvgks6mzHPRNkoKy+9EKP4SFC77/vTTQYmRmti7dvqC+m5jBrBAcg==", 1235 | "dev": true, 1236 | "dependencies": { 1237 | "aggregate-error": "^4.0.0" 1238 | }, 1239 | "engines": { 1240 | "node": ">=12" 1241 | }, 1242 | "funding": { 1243 | "url": "https://github.com/sponsors/sindresorhus" 1244 | } 1245 | }, 1246 | "node_modules/p-timeout": { 1247 | "version": "3.2.0", 1248 | "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-3.2.0.tgz", 1249 | "integrity": "sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==", 1250 | "dev": true, 1251 | "dependencies": { 1252 | "p-finally": "^1.0.0" 1253 | }, 1254 | "engines": { 1255 | "node": ">=8" 1256 | } 1257 | }, 1258 | "node_modules/parse-json": { 1259 | "version": "4.0.0", 1260 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1261 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1262 | "dev": true, 1263 | "dependencies": { 1264 | "error-ex": "^1.3.1", 1265 | "json-parse-better-errors": "^1.0.1" 1266 | }, 1267 | "engines": { 1268 | "node": ">=4" 1269 | } 1270 | }, 1271 | "node_modules/path-exists": { 1272 | "version": "4.0.0", 1273 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1274 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1275 | "dev": true, 1276 | "engines": { 1277 | "node": ">=8" 1278 | } 1279 | }, 1280 | "node_modules/path-key": { 1281 | "version": "2.0.1", 1282 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1283 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1284 | "dev": true, 1285 | "engines": { 1286 | "node": ">=4" 1287 | } 1288 | }, 1289 | "node_modules/path-parse": { 1290 | "version": "1.0.7", 1291 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1292 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1293 | "dev": true 1294 | }, 1295 | "node_modules/path-type": { 1296 | "version": "3.0.0", 1297 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 1298 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 1299 | "dev": true, 1300 | "dependencies": { 1301 | "pify": "^3.0.0" 1302 | }, 1303 | "engines": { 1304 | "node": ">=4" 1305 | } 1306 | }, 1307 | "node_modules/path-type/node_modules/pify": { 1308 | "version": "3.0.0", 1309 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1310 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1311 | "dev": true, 1312 | "engines": { 1313 | "node": ">=4" 1314 | } 1315 | }, 1316 | "node_modules/picomatch": { 1317 | "version": "2.3.1", 1318 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1319 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1320 | "dev": true, 1321 | "engines": { 1322 | "node": ">=8.6" 1323 | }, 1324 | "funding": { 1325 | "url": "https://github.com/sponsors/jonschlinkert" 1326 | } 1327 | }, 1328 | "node_modules/pidtree": { 1329 | "version": "0.3.1", 1330 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 1331 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", 1332 | "dev": true, 1333 | "bin": { 1334 | "pidtree": "bin/pidtree.js" 1335 | }, 1336 | "engines": { 1337 | "node": ">=0.10" 1338 | } 1339 | }, 1340 | "node_modules/queue-microtask": { 1341 | "version": "1.2.3", 1342 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1343 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1344 | "dev": true, 1345 | "funding": [ 1346 | { 1347 | "type": "github", 1348 | "url": "https://github.com/sponsors/feross" 1349 | }, 1350 | { 1351 | "type": "patreon", 1352 | "url": "https://www.patreon.com/feross" 1353 | }, 1354 | { 1355 | "type": "consulting", 1356 | "url": "https://feross.org/support" 1357 | } 1358 | ] 1359 | }, 1360 | "node_modules/quick-lru": { 1361 | "version": "5.1.1", 1362 | "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-5.1.1.tgz", 1363 | "integrity": "sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==", 1364 | "dev": true, 1365 | "engines": { 1366 | "node": ">=10" 1367 | }, 1368 | "funding": { 1369 | "url": "https://github.com/sponsors/sindresorhus" 1370 | } 1371 | }, 1372 | "node_modules/read-pkg": { 1373 | "version": "3.0.0", 1374 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 1375 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 1376 | "dev": true, 1377 | "dependencies": { 1378 | "load-json-file": "^4.0.0", 1379 | "normalize-package-data": "^2.3.2", 1380 | "path-type": "^3.0.0" 1381 | }, 1382 | "engines": { 1383 | "node": ">=4" 1384 | } 1385 | }, 1386 | "node_modules/read-pkg-up": { 1387 | "version": "8.0.0", 1388 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-8.0.0.tgz", 1389 | "integrity": "sha512-snVCqPczksT0HS2EC+SxUndvSzn6LRCwpfSvLrIfR5BKDQQZMaI6jPRC9dYvYFDRAuFEAnkwww8kBBNE/3VvzQ==", 1390 | "dev": true, 1391 | "dependencies": { 1392 | "find-up": "^5.0.0", 1393 | "read-pkg": "^6.0.0", 1394 | "type-fest": "^1.0.1" 1395 | }, 1396 | "engines": { 1397 | "node": ">=12" 1398 | }, 1399 | "funding": { 1400 | "url": "https://github.com/sponsors/sindresorhus" 1401 | } 1402 | }, 1403 | "node_modules/read-pkg-up/node_modules/hosted-git-info": { 1404 | "version": "4.1.0", 1405 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.1.0.tgz", 1406 | "integrity": "sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==", 1407 | "dev": true, 1408 | "dependencies": { 1409 | "lru-cache": "^6.0.0" 1410 | }, 1411 | "engines": { 1412 | "node": ">=10" 1413 | } 1414 | }, 1415 | "node_modules/read-pkg-up/node_modules/normalize-package-data": { 1416 | "version": "3.0.3", 1417 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-3.0.3.tgz", 1418 | "integrity": "sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==", 1419 | "dev": true, 1420 | "dependencies": { 1421 | "hosted-git-info": "^4.0.1", 1422 | "is-core-module": "^2.5.0", 1423 | "semver": "^7.3.4", 1424 | "validate-npm-package-license": "^3.0.1" 1425 | }, 1426 | "engines": { 1427 | "node": ">=10" 1428 | } 1429 | }, 1430 | "node_modules/read-pkg-up/node_modules/parse-json": { 1431 | "version": "5.2.0", 1432 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 1433 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 1434 | "dev": true, 1435 | "dependencies": { 1436 | "@babel/code-frame": "^7.0.0", 1437 | "error-ex": "^1.3.1", 1438 | "json-parse-even-better-errors": "^2.3.0", 1439 | "lines-and-columns": "^1.1.6" 1440 | }, 1441 | "engines": { 1442 | "node": ">=8" 1443 | }, 1444 | "funding": { 1445 | "url": "https://github.com/sponsors/sindresorhus" 1446 | } 1447 | }, 1448 | "node_modules/read-pkg-up/node_modules/read-pkg": { 1449 | "version": "6.0.0", 1450 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-6.0.0.tgz", 1451 | "integrity": "sha512-X1Fu3dPuk/8ZLsMhEj5f4wFAF0DWoK7qhGJvgaijocXxBmSToKfbFtqbxMO7bVjNA1dmE5huAzjXj/ey86iw9Q==", 1452 | "dev": true, 1453 | "dependencies": { 1454 | "@types/normalize-package-data": "^2.4.0", 1455 | "normalize-package-data": "^3.0.2", 1456 | "parse-json": "^5.2.0", 1457 | "type-fest": "^1.0.1" 1458 | }, 1459 | "engines": { 1460 | "node": ">=12" 1461 | }, 1462 | "funding": { 1463 | "url": "https://github.com/sponsors/sindresorhus" 1464 | } 1465 | }, 1466 | "node_modules/read-pkg-up/node_modules/semver": { 1467 | "version": "7.6.3", 1468 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 1469 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 1470 | "dev": true, 1471 | "license": "ISC", 1472 | "bin": { 1473 | "semver": "bin/semver.js" 1474 | }, 1475 | "engines": { 1476 | "node": ">=10" 1477 | } 1478 | }, 1479 | "node_modules/redent": { 1480 | "version": "4.0.0", 1481 | "resolved": "https://registry.npmjs.org/redent/-/redent-4.0.0.tgz", 1482 | "integrity": "sha512-tYkDkVVtYkSVhuQ4zBgfvciymHaeuel+zFKXShfDnFP5SyVEP7qo70Rf1jTOTCx3vGNAbnEi/xFkcfQVMIBWag==", 1483 | "dev": true, 1484 | "dependencies": { 1485 | "indent-string": "^5.0.0", 1486 | "strip-indent": "^4.0.0" 1487 | }, 1488 | "engines": { 1489 | "node": ">=12" 1490 | }, 1491 | "funding": { 1492 | "url": "https://github.com/sponsors/sindresorhus" 1493 | } 1494 | }, 1495 | "node_modules/resolve": { 1496 | "version": "1.19.0", 1497 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.19.0.tgz", 1498 | "integrity": "sha512-rArEXAgsBG4UgRGcynxWIWKFvh/XZCcS8UJdHhwy91zwAvCZIbcs+vAbflgBnNjYMs/i/i+/Ux6IZhML1yPvxg==", 1499 | "dev": true, 1500 | "dependencies": { 1501 | "is-core-module": "^2.1.0", 1502 | "path-parse": "^1.0.6" 1503 | }, 1504 | "funding": { 1505 | "url": "https://github.com/sponsors/ljharb" 1506 | } 1507 | }, 1508 | "node_modules/reusify": { 1509 | "version": "1.0.4", 1510 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1511 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1512 | "dev": true, 1513 | "engines": { 1514 | "iojs": ">=1.0.0", 1515 | "node": ">=0.10.0" 1516 | } 1517 | }, 1518 | "node_modules/run-parallel": { 1519 | "version": "1.2.0", 1520 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1521 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1522 | "dev": true, 1523 | "funding": [ 1524 | { 1525 | "type": "github", 1526 | "url": "https://github.com/sponsors/feross" 1527 | }, 1528 | { 1529 | "type": "patreon", 1530 | "url": "https://www.patreon.com/feross" 1531 | }, 1532 | { 1533 | "type": "consulting", 1534 | "url": "https://feross.org/support" 1535 | } 1536 | ], 1537 | "dependencies": { 1538 | "queue-microtask": "^1.2.2" 1539 | } 1540 | }, 1541 | "node_modules/semver": { 1542 | "version": "6.3.1", 1543 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 1544 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 1545 | "dev": true, 1546 | "license": "ISC", 1547 | "bin": { 1548 | "semver": "bin/semver.js" 1549 | } 1550 | }, 1551 | "node_modules/shebang-command": { 1552 | "version": "1.2.0", 1553 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1554 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1555 | "dev": true, 1556 | "dependencies": { 1557 | "shebang-regex": "^1.0.0" 1558 | }, 1559 | "engines": { 1560 | "node": ">=0.10.0" 1561 | } 1562 | }, 1563 | "node_modules/shebang-regex": { 1564 | "version": "1.0.0", 1565 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1566 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1567 | "dev": true, 1568 | "engines": { 1569 | "node": ">=0.10.0" 1570 | } 1571 | }, 1572 | "node_modules/shell-quote": { 1573 | "version": "1.7.3", 1574 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.3.tgz", 1575 | "integrity": "sha512-Vpfqwm4EnqGdlsBFNmHhxhElJYrdfcxPThu+ryKS5J8L/fhAwLazFZtq+S+TWZ9ANj2piSQLGj6NQg+lKPmxrw==", 1576 | "dev": true 1577 | }, 1578 | "node_modules/slash": { 1579 | "version": "4.0.0", 1580 | "resolved": "https://registry.npmjs.org/slash/-/slash-4.0.0.tgz", 1581 | "integrity": "sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew==", 1582 | "dev": true, 1583 | "engines": { 1584 | "node": ">=12" 1585 | }, 1586 | "funding": { 1587 | "url": "https://github.com/sponsors/sindresorhus" 1588 | } 1589 | }, 1590 | "node_modules/spdx-correct": { 1591 | "version": "3.1.1", 1592 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 1593 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 1594 | "dev": true, 1595 | "dependencies": { 1596 | "spdx-expression-parse": "^3.0.0", 1597 | "spdx-license-ids": "^3.0.0" 1598 | } 1599 | }, 1600 | "node_modules/spdx-exceptions": { 1601 | "version": "2.3.0", 1602 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 1603 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 1604 | "dev": true 1605 | }, 1606 | "node_modules/spdx-expression-parse": { 1607 | "version": "3.0.1", 1608 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 1609 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 1610 | "dev": true, 1611 | "dependencies": { 1612 | "spdx-exceptions": "^2.1.0", 1613 | "spdx-license-ids": "^3.0.0" 1614 | } 1615 | }, 1616 | "node_modules/spdx-license-ids": { 1617 | "version": "3.0.6", 1618 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.6.tgz", 1619 | "integrity": "sha512-+orQK83kyMva3WyPf59k1+Y525csj5JejicWut55zeTWANuN17qSiSLUXWtzHeNWORSvT7GLDJ/E/XiIWoXBTw==", 1620 | "dev": true 1621 | }, 1622 | "node_modules/string.prototype.padend": { 1623 | "version": "3.1.0", 1624 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.0.tgz", 1625 | "integrity": "sha512-3aIv8Ffdp8EZj8iLwREGpQaUZiPyrWrpzMBHvkiSW/bK/EGve9np07Vwy7IJ5waydpGXzQZu/F8Oze2/IWkBaA==", 1626 | "dev": true, 1627 | "dependencies": { 1628 | "define-properties": "^1.1.3", 1629 | "es-abstract": "^1.17.0-next.1" 1630 | }, 1631 | "engines": { 1632 | "node": ">= 0.4" 1633 | }, 1634 | "funding": { 1635 | "url": "https://github.com/sponsors/ljharb" 1636 | } 1637 | }, 1638 | "node_modules/string.prototype.trimend": { 1639 | "version": "1.0.2", 1640 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.2.tgz", 1641 | "integrity": "sha512-8oAG/hi14Z4nOVP0z6mdiVZ/wqjDtWSLygMigTzAb+7aPEDTleeFf+WrF+alzecxIRkckkJVn+dTlwzJXORATw==", 1642 | "dev": true, 1643 | "dependencies": { 1644 | "define-properties": "^1.1.3", 1645 | "es-abstract": "^1.18.0-next.1" 1646 | }, 1647 | "funding": { 1648 | "url": "https://github.com/sponsors/ljharb" 1649 | } 1650 | }, 1651 | "node_modules/string.prototype.trimend/node_modules/es-abstract": { 1652 | "version": "1.18.0-next.1", 1653 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", 1654 | "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", 1655 | "dev": true, 1656 | "dependencies": { 1657 | "es-to-primitive": "^1.2.1", 1658 | "function-bind": "^1.1.1", 1659 | "has": "^1.0.3", 1660 | "has-symbols": "^1.0.1", 1661 | "is-callable": "^1.2.2", 1662 | "is-negative-zero": "^2.0.0", 1663 | "is-regex": "^1.1.1", 1664 | "object-inspect": "^1.8.0", 1665 | "object-keys": "^1.1.1", 1666 | "object.assign": "^4.1.1", 1667 | "string.prototype.trimend": "^1.0.1", 1668 | "string.prototype.trimstart": "^1.0.1" 1669 | }, 1670 | "engines": { 1671 | "node": ">= 0.4" 1672 | }, 1673 | "funding": { 1674 | "url": "https://github.com/sponsors/ljharb" 1675 | } 1676 | }, 1677 | "node_modules/string.prototype.trimstart": { 1678 | "version": "1.0.2", 1679 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.2.tgz", 1680 | "integrity": "sha512-7F6CdBTl5zyu30BJFdzSTlSlLPwODC23Od+iLoVH8X6+3fvDPPuBVVj9iaB1GOsSTSIgVfsfm27R2FGrAPznWg==", 1681 | "dev": true, 1682 | "dependencies": { 1683 | "define-properties": "^1.1.3", 1684 | "es-abstract": "^1.18.0-next.1" 1685 | }, 1686 | "funding": { 1687 | "url": "https://github.com/sponsors/ljharb" 1688 | } 1689 | }, 1690 | "node_modules/string.prototype.trimstart/node_modules/es-abstract": { 1691 | "version": "1.18.0-next.1", 1692 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", 1693 | "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", 1694 | "dev": true, 1695 | "dependencies": { 1696 | "es-to-primitive": "^1.2.1", 1697 | "function-bind": "^1.1.1", 1698 | "has": "^1.0.3", 1699 | "has-symbols": "^1.0.1", 1700 | "is-callable": "^1.2.2", 1701 | "is-negative-zero": "^2.0.0", 1702 | "is-regex": "^1.1.1", 1703 | "object-inspect": "^1.8.0", 1704 | "object-keys": "^1.1.1", 1705 | "object.assign": "^4.1.1", 1706 | "string.prototype.trimend": "^1.0.1", 1707 | "string.prototype.trimstart": "^1.0.1" 1708 | }, 1709 | "engines": { 1710 | "node": ">= 0.4" 1711 | }, 1712 | "funding": { 1713 | "url": "https://github.com/sponsors/ljharb" 1714 | } 1715 | }, 1716 | "node_modules/strip-bom": { 1717 | "version": "3.0.0", 1718 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1719 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1720 | "dev": true, 1721 | "engines": { 1722 | "node": ">=4" 1723 | } 1724 | }, 1725 | "node_modules/strip-indent": { 1726 | "version": "4.0.0", 1727 | "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-4.0.0.tgz", 1728 | "integrity": "sha512-mnVSV2l+Zv6BLpSD/8V87CW/y9EmmbYzGCIavsnsI6/nwn26DwffM/yztm30Z/I2DY9wdS3vXVCMnHDgZaVNoA==", 1729 | "dev": true, 1730 | "dependencies": { 1731 | "min-indent": "^1.0.1" 1732 | }, 1733 | "engines": { 1734 | "node": ">=12" 1735 | }, 1736 | "funding": { 1737 | "url": "https://github.com/sponsors/sindresorhus" 1738 | } 1739 | }, 1740 | "node_modules/supports-color": { 1741 | "version": "5.5.0", 1742 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1743 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1744 | "dev": true, 1745 | "dependencies": { 1746 | "has-flag": "^3.0.0" 1747 | }, 1748 | "engines": { 1749 | "node": ">=4" 1750 | } 1751 | }, 1752 | "node_modules/to-regex-range": { 1753 | "version": "5.0.1", 1754 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1755 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1756 | "dev": true, 1757 | "dependencies": { 1758 | "is-number": "^7.0.0" 1759 | }, 1760 | "engines": { 1761 | "node": ">=8.0" 1762 | } 1763 | }, 1764 | "node_modules/trim-newlines": { 1765 | "version": "4.0.2", 1766 | "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-4.0.2.tgz", 1767 | "integrity": "sha512-GJtWyq9InR/2HRiLZgpIKv+ufIKrVrvjQWEj7PxAXNc5dwbNJkqhAUoAGgzRmULAnoOM5EIpveYd3J2VeSAIew==", 1768 | "dev": true, 1769 | "engines": { 1770 | "node": ">=12" 1771 | }, 1772 | "funding": { 1773 | "url": "https://github.com/sponsors/sindresorhus" 1774 | } 1775 | }, 1776 | "node_modules/type-fest": { 1777 | "version": "1.4.0", 1778 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-1.4.0.tgz", 1779 | "integrity": "sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA==", 1780 | "dev": true, 1781 | "engines": { 1782 | "node": ">=10" 1783 | }, 1784 | "funding": { 1785 | "url": "https://github.com/sponsors/sindresorhus" 1786 | } 1787 | }, 1788 | "node_modules/validate-npm-package-license": { 1789 | "version": "3.0.4", 1790 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1791 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1792 | "dev": true, 1793 | "dependencies": { 1794 | "spdx-correct": "^3.0.0", 1795 | "spdx-expression-parse": "^3.0.0" 1796 | } 1797 | }, 1798 | "node_modules/which": { 1799 | "version": "1.3.1", 1800 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1801 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1802 | "dev": true, 1803 | "dependencies": { 1804 | "isexe": "^2.0.0" 1805 | }, 1806 | "bin": { 1807 | "which": "bin/which" 1808 | } 1809 | }, 1810 | "node_modules/yallist": { 1811 | "version": "4.0.0", 1812 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1813 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1814 | "dev": true 1815 | }, 1816 | "node_modules/yargs-parser": { 1817 | "version": "20.2.9", 1818 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 1819 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 1820 | "dev": true, 1821 | "engines": { 1822 | "node": ">=10" 1823 | } 1824 | }, 1825 | "node_modules/yocto-queue": { 1826 | "version": "0.1.0", 1827 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1828 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1829 | "dev": true, 1830 | "engines": { 1831 | "node": ">=10" 1832 | }, 1833 | "funding": { 1834 | "url": "https://github.com/sponsors/sindresorhus" 1835 | } 1836 | } 1837 | }, 1838 | "dependencies": { 1839 | "@babel/code-frame": { 1840 | "version": "7.18.6", 1841 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", 1842 | "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", 1843 | "dev": true, 1844 | "requires": { 1845 | "@babel/highlight": "^7.18.6" 1846 | } 1847 | }, 1848 | "@babel/helper-validator-identifier": { 1849 | "version": "7.19.1", 1850 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 1851 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 1852 | "dev": true 1853 | }, 1854 | "@babel/highlight": { 1855 | "version": "7.18.6", 1856 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 1857 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 1858 | "dev": true, 1859 | "requires": { 1860 | "@babel/helper-validator-identifier": "^7.18.6", 1861 | "chalk": "^2.0.0", 1862 | "js-tokens": "^4.0.0" 1863 | } 1864 | }, 1865 | "@nodelib/fs.scandir": { 1866 | "version": "2.1.5", 1867 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 1868 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 1869 | "dev": true, 1870 | "requires": { 1871 | "@nodelib/fs.stat": "2.0.5", 1872 | "run-parallel": "^1.1.9" 1873 | } 1874 | }, 1875 | "@nodelib/fs.stat": { 1876 | "version": "2.0.5", 1877 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 1878 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 1879 | "dev": true 1880 | }, 1881 | "@nodelib/fs.walk": { 1882 | "version": "1.2.8", 1883 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 1884 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 1885 | "dev": true, 1886 | "requires": { 1887 | "@nodelib/fs.scandir": "2.1.5", 1888 | "fastq": "^1.6.0" 1889 | } 1890 | }, 1891 | "@types/minimist": { 1892 | "version": "1.2.2", 1893 | "resolved": "https://registry.npmjs.org/@types/minimist/-/minimist-1.2.2.tgz", 1894 | "integrity": "sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ==", 1895 | "dev": true 1896 | }, 1897 | "@types/normalize-package-data": { 1898 | "version": "2.4.1", 1899 | "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz", 1900 | "integrity": "sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw==", 1901 | "dev": true 1902 | }, 1903 | "aggregate-error": { 1904 | "version": "4.0.1", 1905 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-4.0.1.tgz", 1906 | "integrity": "sha512-0poP0T7el6Vq3rstR8Mn4V/IQrpBLO6POkUSrN7RhyY+GF/InCFShQzsQ39T25gkHhLgSLByyAz+Kjb+c2L98w==", 1907 | "dev": true, 1908 | "requires": { 1909 | "clean-stack": "^4.0.0", 1910 | "indent-string": "^5.0.0" 1911 | } 1912 | }, 1913 | "ansi-styles": { 1914 | "version": "3.2.1", 1915 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1916 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1917 | "dev": true, 1918 | "requires": { 1919 | "color-convert": "^1.9.0" 1920 | } 1921 | }, 1922 | "arrify": { 1923 | "version": "3.0.0", 1924 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-3.0.0.tgz", 1925 | "integrity": "sha512-tLkvA81vQG/XqE2mjDkGQHoOINtMHtysSnemrmoGe6PydDPMRbVugqyk4A6V/WDWEfm3l+0d8anA9r8cv/5Jaw==", 1926 | "dev": true 1927 | }, 1928 | "balanced-match": { 1929 | "version": "1.0.0", 1930 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1931 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 1932 | "dev": true 1933 | }, 1934 | "brace-expansion": { 1935 | "version": "1.1.11", 1936 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1937 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1938 | "dev": true, 1939 | "requires": { 1940 | "balanced-match": "^1.0.0", 1941 | "concat-map": "0.0.1" 1942 | } 1943 | }, 1944 | "braces": { 1945 | "version": "3.0.3", 1946 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 1947 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 1948 | "dev": true, 1949 | "requires": { 1950 | "fill-range": "^7.1.1" 1951 | } 1952 | }, 1953 | "call-bind": { 1954 | "version": "1.0.0", 1955 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.0.tgz", 1956 | "integrity": "sha512-AEXsYIyyDY3MCzbwdhzG3Jx1R0J2wetQyUynn6dYHAO+bg8l1k7jwZtRv4ryryFs7EP+NDlikJlVe59jr0cM2w==", 1957 | "dev": true, 1958 | "requires": { 1959 | "function-bind": "^1.1.1", 1960 | "get-intrinsic": "^1.0.0" 1961 | } 1962 | }, 1963 | "camelcase": { 1964 | "version": "6.3.0", 1965 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 1966 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 1967 | "dev": true 1968 | }, 1969 | "camelcase-keys": { 1970 | "version": "7.0.2", 1971 | "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-7.0.2.tgz", 1972 | "integrity": "sha512-Rjs1H+A9R+Ig+4E/9oyB66UC5Mj9Xq3N//vcLf2WzgdTi/3gUu3Z9KoqmlrEG4VuuLK8wJHofxzdQXz/knhiYg==", 1973 | "dev": true, 1974 | "requires": { 1975 | "camelcase": "^6.3.0", 1976 | "map-obj": "^4.1.0", 1977 | "quick-lru": "^5.1.1", 1978 | "type-fest": "^1.2.1" 1979 | } 1980 | }, 1981 | "chalk": { 1982 | "version": "2.4.2", 1983 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1984 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1985 | "dev": true, 1986 | "requires": { 1987 | "ansi-styles": "^3.2.1", 1988 | "escape-string-regexp": "^1.0.5", 1989 | "supports-color": "^5.3.0" 1990 | } 1991 | }, 1992 | "clean-stack": { 1993 | "version": "4.2.0", 1994 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-4.2.0.tgz", 1995 | "integrity": "sha512-LYv6XPxoyODi36Dp976riBtSY27VmFo+MKqEU9QCCWyTrdEPDog+RWA7xQWHi6Vbp61j5c4cdzzX1NidnwtUWg==", 1996 | "dev": true, 1997 | "requires": { 1998 | "escape-string-regexp": "5.0.0" 1999 | }, 2000 | "dependencies": { 2001 | "escape-string-regexp": { 2002 | "version": "5.0.0", 2003 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-5.0.0.tgz", 2004 | "integrity": "sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==", 2005 | "dev": true 2006 | } 2007 | } 2008 | }, 2009 | "color-convert": { 2010 | "version": "1.9.3", 2011 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2012 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2013 | "dev": true, 2014 | "requires": { 2015 | "color-name": "1.1.3" 2016 | } 2017 | }, 2018 | "color-name": { 2019 | "version": "1.1.3", 2020 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2021 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2022 | "dev": true 2023 | }, 2024 | "concat-map": { 2025 | "version": "0.0.1", 2026 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2027 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 2028 | "dev": true 2029 | }, 2030 | "cp-file": { 2031 | "version": "9.1.0", 2032 | "resolved": "https://registry.npmjs.org/cp-file/-/cp-file-9.1.0.tgz", 2033 | "integrity": "sha512-3scnzFj/94eb7y4wyXRWwvzLFaQp87yyfTnChIjlfYrVqp5lVO3E2hIJMeQIltUT0K2ZAB3An1qXcBmwGyvuwA==", 2034 | "dev": true, 2035 | "requires": { 2036 | "graceful-fs": "^4.1.2", 2037 | "make-dir": "^3.0.0", 2038 | "nested-error-stacks": "^2.0.0", 2039 | "p-event": "^4.1.0" 2040 | } 2041 | }, 2042 | "cpy": { 2043 | "version": "9.0.1", 2044 | "resolved": "https://registry.npmjs.org/cpy/-/cpy-9.0.1.tgz", 2045 | "integrity": "sha512-D9U0DR5FjTCN3oMTcFGktanHnAG5l020yvOCR1zKILmAyPP7I/9pl6NFgRbDcmSENtbK1sQLBz1p9HIOlroiNg==", 2046 | "dev": true, 2047 | "requires": { 2048 | "arrify": "^3.0.0", 2049 | "cp-file": "^9.1.0", 2050 | "globby": "^13.1.1", 2051 | "junk": "^4.0.0", 2052 | "micromatch": "^4.0.4", 2053 | "nested-error-stacks": "^2.1.0", 2054 | "p-filter": "^3.0.0", 2055 | "p-map": "^5.3.0" 2056 | } 2057 | }, 2058 | "cpy-cli": { 2059 | "version": "4.2.0", 2060 | "resolved": "https://registry.npmjs.org/cpy-cli/-/cpy-cli-4.2.0.tgz", 2061 | "integrity": "sha512-b04b+cbdr29CdpREPKw/itrfjO43Ty0Aj7wRM6M6LoE4GJxZJCk9Xp+Eu1IqztkKh3LxIBt1tDplENsa6KYprg==", 2062 | "dev": true, 2063 | "requires": { 2064 | "cpy": "^9.0.0", 2065 | "meow": "^10.1.2" 2066 | } 2067 | }, 2068 | "cross-spawn": { 2069 | "version": "6.0.6", 2070 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.6.tgz", 2071 | "integrity": "sha512-VqCUuhcd1iB+dsv8gxPttb5iZh/D0iubSP21g36KXdEuf6I5JiioesUVjpCdHV9MZRUfVFlvwtIUyPfxo5trtw==", 2072 | "dev": true, 2073 | "requires": { 2074 | "nice-try": "^1.0.4", 2075 | "path-key": "^2.0.1", 2076 | "semver": "^5.5.0", 2077 | "shebang-command": "^1.2.0", 2078 | "which": "^1.2.9" 2079 | }, 2080 | "dependencies": { 2081 | "semver": { 2082 | "version": "5.7.2", 2083 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 2084 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 2085 | "dev": true 2086 | } 2087 | } 2088 | }, 2089 | "decamelize": { 2090 | "version": "5.0.1", 2091 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-5.0.1.tgz", 2092 | "integrity": "sha512-VfxadyCECXgQlkoEAjeghAr5gY3Hf+IKjKb+X8tGVDtveCjN+USwprd2q3QXBR9T1+x2DG0XZF5/w+7HAtSaXA==", 2093 | "dev": true 2094 | }, 2095 | "decamelize-keys": { 2096 | "version": "1.1.1", 2097 | "resolved": "https://registry.npmjs.org/decamelize-keys/-/decamelize-keys-1.1.1.tgz", 2098 | "integrity": "sha512-WiPxgEirIV0/eIOMcnFBA3/IJZAZqKnwAwWyvvdi4lsr1WCN22nhdf/3db3DoZcUjTV2SqfzIwNyp6y2xs3nmg==", 2099 | "dev": true, 2100 | "requires": { 2101 | "decamelize": "^1.1.0", 2102 | "map-obj": "^1.0.0" 2103 | }, 2104 | "dependencies": { 2105 | "decamelize": { 2106 | "version": "1.2.0", 2107 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 2108 | "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==", 2109 | "dev": true 2110 | }, 2111 | "map-obj": { 2112 | "version": "1.0.1", 2113 | "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", 2114 | "integrity": "sha512-7N/q3lyZ+LVCp7PzuxrJr4KMbBE2hW7BT7YNia330OFxIf4d3r5zVpicP2650l7CPN6RM9zOJRl3NGpqSiw3Eg==", 2115 | "dev": true 2116 | } 2117 | } 2118 | }, 2119 | "define-properties": { 2120 | "version": "1.1.3", 2121 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 2122 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 2123 | "dev": true, 2124 | "requires": { 2125 | "object-keys": "^1.0.12" 2126 | } 2127 | }, 2128 | "dir-glob": { 2129 | "version": "3.0.1", 2130 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 2131 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 2132 | "dev": true, 2133 | "requires": { 2134 | "path-type": "^4.0.0" 2135 | }, 2136 | "dependencies": { 2137 | "path-type": { 2138 | "version": "4.0.0", 2139 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2140 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2141 | "dev": true 2142 | } 2143 | } 2144 | }, 2145 | "error-ex": { 2146 | "version": "1.3.2", 2147 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 2148 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 2149 | "dev": true, 2150 | "requires": { 2151 | "is-arrayish": "^0.2.1" 2152 | } 2153 | }, 2154 | "es-abstract": { 2155 | "version": "1.17.7", 2156 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.7.tgz", 2157 | "integrity": "sha512-VBl/gnfcJ7OercKA9MVaegWsBHFjV492syMudcnQZvt/Dw8ezpcOHYZXa/J96O8vx+g4x65YKhxOwDUh63aS5g==", 2158 | "dev": true, 2159 | "requires": { 2160 | "es-to-primitive": "^1.2.1", 2161 | "function-bind": "^1.1.1", 2162 | "has": "^1.0.3", 2163 | "has-symbols": "^1.0.1", 2164 | "is-callable": "^1.2.2", 2165 | "is-regex": "^1.1.1", 2166 | "object-inspect": "^1.8.0", 2167 | "object-keys": "^1.1.1", 2168 | "object.assign": "^4.1.1", 2169 | "string.prototype.trimend": "^1.0.1", 2170 | "string.prototype.trimstart": "^1.0.1" 2171 | } 2172 | }, 2173 | "es-to-primitive": { 2174 | "version": "1.2.1", 2175 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 2176 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 2177 | "dev": true, 2178 | "requires": { 2179 | "is-callable": "^1.1.4", 2180 | "is-date-object": "^1.0.1", 2181 | "is-symbol": "^1.0.2" 2182 | } 2183 | }, 2184 | "escape-string-regexp": { 2185 | "version": "1.0.5", 2186 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2187 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 2188 | "dev": true 2189 | }, 2190 | "fast-glob": { 2191 | "version": "3.2.12", 2192 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", 2193 | "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", 2194 | "dev": true, 2195 | "requires": { 2196 | "@nodelib/fs.stat": "^2.0.2", 2197 | "@nodelib/fs.walk": "^1.2.3", 2198 | "glob-parent": "^5.1.2", 2199 | "merge2": "^1.3.0", 2200 | "micromatch": "^4.0.4" 2201 | } 2202 | }, 2203 | "fastq": { 2204 | "version": "1.13.0", 2205 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", 2206 | "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", 2207 | "dev": true, 2208 | "requires": { 2209 | "reusify": "^1.0.4" 2210 | } 2211 | }, 2212 | "fill-range": { 2213 | "version": "7.1.1", 2214 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 2215 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 2216 | "dev": true, 2217 | "requires": { 2218 | "to-regex-range": "^5.0.1" 2219 | } 2220 | }, 2221 | "find-up": { 2222 | "version": "5.0.0", 2223 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2224 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2225 | "dev": true, 2226 | "requires": { 2227 | "locate-path": "^6.0.0", 2228 | "path-exists": "^4.0.0" 2229 | } 2230 | }, 2231 | "function-bind": { 2232 | "version": "1.1.1", 2233 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2234 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 2235 | "dev": true 2236 | }, 2237 | "get-intrinsic": { 2238 | "version": "1.0.1", 2239 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.0.1.tgz", 2240 | "integrity": "sha512-ZnWP+AmS1VUaLgTRy47+zKtjTxz+0xMpx3I52i+aalBK1QP19ggLF3Db89KJX7kjfOfP2eoa01qc++GwPgufPg==", 2241 | "dev": true, 2242 | "requires": { 2243 | "function-bind": "^1.1.1", 2244 | "has": "^1.0.3", 2245 | "has-symbols": "^1.0.1" 2246 | } 2247 | }, 2248 | "glob-parent": { 2249 | "version": "5.1.2", 2250 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2251 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2252 | "dev": true, 2253 | "requires": { 2254 | "is-glob": "^4.0.1" 2255 | } 2256 | }, 2257 | "globby": { 2258 | "version": "13.1.2", 2259 | "resolved": "https://registry.npmjs.org/globby/-/globby-13.1.2.tgz", 2260 | "integrity": "sha512-LKSDZXToac40u8Q1PQtZihbNdTYSNMuWe+K5l+oa6KgDzSvVrHXlJy40hUP522RjAIoNLJYBJi7ow+rbFpIhHQ==", 2261 | "dev": true, 2262 | "requires": { 2263 | "dir-glob": "^3.0.1", 2264 | "fast-glob": "^3.2.11", 2265 | "ignore": "^5.2.0", 2266 | "merge2": "^1.4.1", 2267 | "slash": "^4.0.0" 2268 | } 2269 | }, 2270 | "graceful-fs": { 2271 | "version": "4.2.4", 2272 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 2273 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 2274 | "dev": true 2275 | }, 2276 | "hard-rejection": { 2277 | "version": "2.1.0", 2278 | "resolved": "https://registry.npmjs.org/hard-rejection/-/hard-rejection-2.1.0.tgz", 2279 | "integrity": "sha512-VIZB+ibDhx7ObhAe7OVtoEbuP4h/MuOTHJ+J8h/eBXotJYl0fBgR72xDFCKgIh22OJZIOVNxBMWuhAr10r8HdA==", 2280 | "dev": true 2281 | }, 2282 | "has": { 2283 | "version": "1.0.3", 2284 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2285 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2286 | "dev": true, 2287 | "requires": { 2288 | "function-bind": "^1.1.1" 2289 | } 2290 | }, 2291 | "has-flag": { 2292 | "version": "3.0.0", 2293 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2294 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 2295 | "dev": true 2296 | }, 2297 | "has-symbols": { 2298 | "version": "1.0.1", 2299 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 2300 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 2301 | "dev": true 2302 | }, 2303 | "hosted-git-info": { 2304 | "version": "2.8.9", 2305 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 2306 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", 2307 | "dev": true 2308 | }, 2309 | "ignore": { 2310 | "version": "5.2.0", 2311 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 2312 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 2313 | "dev": true 2314 | }, 2315 | "indent-string": { 2316 | "version": "5.0.0", 2317 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-5.0.0.tgz", 2318 | "integrity": "sha512-m6FAo/spmsW2Ab2fU35JTYwtOKa2yAwXSwgjSv1TJzh4Mh7mC3lzAOVLBprb72XsTrgkEIsl7YrFNAiDiRhIGg==", 2319 | "dev": true 2320 | }, 2321 | "is-arrayish": { 2322 | "version": "0.2.1", 2323 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2324 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 2325 | "dev": true 2326 | }, 2327 | "is-callable": { 2328 | "version": "1.2.2", 2329 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.2.tgz", 2330 | "integrity": "sha512-dnMqspv5nU3LoewK2N/y7KLtxtakvTuaCsU9FU50/QDmdbHNy/4/JuRtMHqRU22o3q+W89YQndQEeCVwK+3qrA==", 2331 | "dev": true 2332 | }, 2333 | "is-core-module": { 2334 | "version": "2.11.0", 2335 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", 2336 | "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", 2337 | "dev": true, 2338 | "requires": { 2339 | "has": "^1.0.3" 2340 | } 2341 | }, 2342 | "is-date-object": { 2343 | "version": "1.0.2", 2344 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 2345 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 2346 | "dev": true 2347 | }, 2348 | "is-extglob": { 2349 | "version": "2.1.1", 2350 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2351 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2352 | "dev": true 2353 | }, 2354 | "is-glob": { 2355 | "version": "4.0.3", 2356 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2357 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2358 | "dev": true, 2359 | "requires": { 2360 | "is-extglob": "^2.1.1" 2361 | } 2362 | }, 2363 | "is-negative-zero": { 2364 | "version": "2.0.0", 2365 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.0.tgz", 2366 | "integrity": "sha1-lVOxIbD6wohp2p7UWeIMdUN4hGE=", 2367 | "dev": true 2368 | }, 2369 | "is-number": { 2370 | "version": "7.0.0", 2371 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2372 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2373 | "dev": true 2374 | }, 2375 | "is-plain-obj": { 2376 | "version": "1.1.0", 2377 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", 2378 | "integrity": "sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==", 2379 | "dev": true 2380 | }, 2381 | "is-regex": { 2382 | "version": "1.1.1", 2383 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz", 2384 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==", 2385 | "dev": true, 2386 | "requires": { 2387 | "has-symbols": "^1.0.1" 2388 | } 2389 | }, 2390 | "is-symbol": { 2391 | "version": "1.0.3", 2392 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 2393 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 2394 | "dev": true, 2395 | "requires": { 2396 | "has-symbols": "^1.0.1" 2397 | } 2398 | }, 2399 | "isexe": { 2400 | "version": "2.0.0", 2401 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2402 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2403 | "dev": true 2404 | }, 2405 | "js-tokens": { 2406 | "version": "4.0.0", 2407 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2408 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2409 | "dev": true 2410 | }, 2411 | "json-parse-better-errors": { 2412 | "version": "1.0.2", 2413 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 2414 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 2415 | "dev": true 2416 | }, 2417 | "json-parse-even-better-errors": { 2418 | "version": "2.3.1", 2419 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 2420 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", 2421 | "dev": true 2422 | }, 2423 | "junk": { 2424 | "version": "4.0.0", 2425 | "resolved": "https://registry.npmjs.org/junk/-/junk-4.0.0.tgz", 2426 | "integrity": "sha512-ojtSU++zLJ3jQG9bAYjg94w+/DOJtRyD7nPaerMFrBhmdVmiV5/exYH5t4uHga4G/95nT6hr1OJoKIFbYbrW5w==", 2427 | "dev": true 2428 | }, 2429 | "kind-of": { 2430 | "version": "6.0.3", 2431 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", 2432 | "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", 2433 | "dev": true 2434 | }, 2435 | "lines-and-columns": { 2436 | "version": "1.2.4", 2437 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 2438 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 2439 | "dev": true 2440 | }, 2441 | "load-json-file": { 2442 | "version": "4.0.0", 2443 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 2444 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 2445 | "dev": true, 2446 | "requires": { 2447 | "graceful-fs": "^4.1.2", 2448 | "parse-json": "^4.0.0", 2449 | "pify": "^3.0.0", 2450 | "strip-bom": "^3.0.0" 2451 | }, 2452 | "dependencies": { 2453 | "pify": { 2454 | "version": "3.0.0", 2455 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 2456 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 2457 | "dev": true 2458 | } 2459 | } 2460 | }, 2461 | "locate-path": { 2462 | "version": "6.0.0", 2463 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2464 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2465 | "dev": true, 2466 | "requires": { 2467 | "p-locate": "^5.0.0" 2468 | } 2469 | }, 2470 | "lru-cache": { 2471 | "version": "6.0.0", 2472 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2473 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2474 | "dev": true, 2475 | "requires": { 2476 | "yallist": "^4.0.0" 2477 | } 2478 | }, 2479 | "make-dir": { 2480 | "version": "3.1.0", 2481 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2482 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2483 | "dev": true, 2484 | "requires": { 2485 | "semver": "^6.0.0" 2486 | } 2487 | }, 2488 | "map-obj": { 2489 | "version": "4.3.0", 2490 | "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-4.3.0.tgz", 2491 | "integrity": "sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==", 2492 | "dev": true 2493 | }, 2494 | "memorystream": { 2495 | "version": "0.3.1", 2496 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 2497 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=", 2498 | "dev": true 2499 | }, 2500 | "meow": { 2501 | "version": "10.1.5", 2502 | "resolved": "https://registry.npmjs.org/meow/-/meow-10.1.5.tgz", 2503 | "integrity": "sha512-/d+PQ4GKmGvM9Bee/DPa8z3mXs/pkvJE2KEThngVNOqtmljC6K7NMPxtc2JeZYTmpWb9k/TmxjeL18ez3h7vCw==", 2504 | "dev": true, 2505 | "requires": { 2506 | "@types/minimist": "^1.2.2", 2507 | "camelcase-keys": "^7.0.0", 2508 | "decamelize": "^5.0.0", 2509 | "decamelize-keys": "^1.1.0", 2510 | "hard-rejection": "^2.1.0", 2511 | "minimist-options": "4.1.0", 2512 | "normalize-package-data": "^3.0.2", 2513 | "read-pkg-up": "^8.0.0", 2514 | "redent": "^4.0.0", 2515 | "trim-newlines": "^4.0.2", 2516 | "type-fest": "^1.2.2", 2517 | "yargs-parser": "^20.2.9" 2518 | }, 2519 | "dependencies": { 2520 | "hosted-git-info": { 2521 | "version": "4.1.0", 2522 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.1.0.tgz", 2523 | "integrity": "sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==", 2524 | "dev": true, 2525 | "requires": { 2526 | "lru-cache": "^6.0.0" 2527 | } 2528 | }, 2529 | "normalize-package-data": { 2530 | "version": "3.0.3", 2531 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-3.0.3.tgz", 2532 | "integrity": "sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==", 2533 | "dev": true, 2534 | "requires": { 2535 | "hosted-git-info": "^4.0.1", 2536 | "is-core-module": "^2.5.0", 2537 | "semver": "^7.3.4", 2538 | "validate-npm-package-license": "^3.0.1" 2539 | } 2540 | }, 2541 | "semver": { 2542 | "version": "7.6.3", 2543 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2544 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2545 | "dev": true 2546 | } 2547 | } 2548 | }, 2549 | "merge2": { 2550 | "version": "1.4.1", 2551 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2552 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2553 | "dev": true 2554 | }, 2555 | "micromatch": { 2556 | "version": "4.0.8", 2557 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", 2558 | "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", 2559 | "dev": true, 2560 | "requires": { 2561 | "braces": "^3.0.3", 2562 | "picomatch": "^2.3.1" 2563 | } 2564 | }, 2565 | "min-indent": { 2566 | "version": "1.0.1", 2567 | "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", 2568 | "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==", 2569 | "dev": true 2570 | }, 2571 | "minimatch": { 2572 | "version": "3.1.2", 2573 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2574 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2575 | "dev": true, 2576 | "requires": { 2577 | "brace-expansion": "^1.1.7" 2578 | } 2579 | }, 2580 | "minimist-options": { 2581 | "version": "4.1.0", 2582 | "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-4.1.0.tgz", 2583 | "integrity": "sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A==", 2584 | "dev": true, 2585 | "requires": { 2586 | "arrify": "^1.0.1", 2587 | "is-plain-obj": "^1.1.0", 2588 | "kind-of": "^6.0.3" 2589 | }, 2590 | "dependencies": { 2591 | "arrify": { 2592 | "version": "1.0.1", 2593 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 2594 | "integrity": "sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==", 2595 | "dev": true 2596 | } 2597 | } 2598 | }, 2599 | "nested-error-stacks": { 2600 | "version": "2.1.1", 2601 | "resolved": "https://registry.npmjs.org/nested-error-stacks/-/nested-error-stacks-2.1.1.tgz", 2602 | "integrity": "sha512-9iN1ka/9zmX1ZvLV9ewJYEk9h7RyRRtqdK0woXcqohu8EWIerfPUjYJPg0ULy0UqP7cslmdGc8xKDJcojlKiaw==", 2603 | "dev": true 2604 | }, 2605 | "nice-try": { 2606 | "version": "1.0.5", 2607 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 2608 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 2609 | "dev": true 2610 | }, 2611 | "normalize-package-data": { 2612 | "version": "2.5.0", 2613 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 2614 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 2615 | "dev": true, 2616 | "requires": { 2617 | "hosted-git-info": "^2.1.4", 2618 | "resolve": "^1.10.0", 2619 | "semver": "2 || 3 || 4 || 5", 2620 | "validate-npm-package-license": "^3.0.1" 2621 | }, 2622 | "dependencies": { 2623 | "semver": { 2624 | "version": "5.7.2", 2625 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 2626 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 2627 | "dev": true 2628 | } 2629 | } 2630 | }, 2631 | "npm-run-all": { 2632 | "version": "4.1.5", 2633 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 2634 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 2635 | "dev": true, 2636 | "requires": { 2637 | "ansi-styles": "^3.2.1", 2638 | "chalk": "^2.4.1", 2639 | "cross-spawn": "^6.0.5", 2640 | "memorystream": "^0.3.1", 2641 | "minimatch": "^3.0.4", 2642 | "pidtree": "^0.3.0", 2643 | "read-pkg": "^3.0.0", 2644 | "shell-quote": "^1.6.1", 2645 | "string.prototype.padend": "^3.0.0" 2646 | } 2647 | }, 2648 | "object-inspect": { 2649 | "version": "1.8.0", 2650 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 2651 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 2652 | "dev": true 2653 | }, 2654 | "object-keys": { 2655 | "version": "1.1.1", 2656 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2657 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2658 | "dev": true 2659 | }, 2660 | "object.assign": { 2661 | "version": "4.1.2", 2662 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 2663 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 2664 | "dev": true, 2665 | "requires": { 2666 | "call-bind": "^1.0.0", 2667 | "define-properties": "^1.1.3", 2668 | "has-symbols": "^1.0.1", 2669 | "object-keys": "^1.1.1" 2670 | } 2671 | }, 2672 | "p-event": { 2673 | "version": "4.2.0", 2674 | "resolved": "https://registry.npmjs.org/p-event/-/p-event-4.2.0.tgz", 2675 | "integrity": "sha512-KXatOjCRXXkSePPb1Nbi0p0m+gQAwdlbhi4wQKJPI1HsMQS9g+Sqp2o+QHziPr7eYJyOZet836KoHEVM1mwOrQ==", 2676 | "dev": true, 2677 | "requires": { 2678 | "p-timeout": "^3.1.0" 2679 | } 2680 | }, 2681 | "p-filter": { 2682 | "version": "3.0.0", 2683 | "resolved": "https://registry.npmjs.org/p-filter/-/p-filter-3.0.0.tgz", 2684 | "integrity": "sha512-QtoWLjXAW++uTX67HZQz1dbTpqBfiidsB6VtQUC9iR85S120+s0T5sO6s+B5MLzFcZkrEd/DGMmCjR+f2Qpxwg==", 2685 | "dev": true, 2686 | "requires": { 2687 | "p-map": "^5.1.0" 2688 | } 2689 | }, 2690 | "p-finally": { 2691 | "version": "1.0.0", 2692 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 2693 | "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==", 2694 | "dev": true 2695 | }, 2696 | "p-limit": { 2697 | "version": "3.1.0", 2698 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2699 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2700 | "dev": true, 2701 | "requires": { 2702 | "yocto-queue": "^0.1.0" 2703 | } 2704 | }, 2705 | "p-locate": { 2706 | "version": "5.0.0", 2707 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2708 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2709 | "dev": true, 2710 | "requires": { 2711 | "p-limit": "^3.0.2" 2712 | } 2713 | }, 2714 | "p-map": { 2715 | "version": "5.5.0", 2716 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-5.5.0.tgz", 2717 | "integrity": "sha512-VFqfGDHlx87K66yZrNdI4YGtD70IRyd+zSvgks6mzHPRNkoKy+9EKP4SFC77/vTTQYmRmti7dvqC+m5jBrBAcg==", 2718 | "dev": true, 2719 | "requires": { 2720 | "aggregate-error": "^4.0.0" 2721 | } 2722 | }, 2723 | "p-timeout": { 2724 | "version": "3.2.0", 2725 | "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-3.2.0.tgz", 2726 | "integrity": "sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==", 2727 | "dev": true, 2728 | "requires": { 2729 | "p-finally": "^1.0.0" 2730 | } 2731 | }, 2732 | "parse-json": { 2733 | "version": "4.0.0", 2734 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 2735 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 2736 | "dev": true, 2737 | "requires": { 2738 | "error-ex": "^1.3.1", 2739 | "json-parse-better-errors": "^1.0.1" 2740 | } 2741 | }, 2742 | "path-exists": { 2743 | "version": "4.0.0", 2744 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2745 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2746 | "dev": true 2747 | }, 2748 | "path-key": { 2749 | "version": "2.0.1", 2750 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2751 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2752 | "dev": true 2753 | }, 2754 | "path-parse": { 2755 | "version": "1.0.7", 2756 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2757 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2758 | "dev": true 2759 | }, 2760 | "path-type": { 2761 | "version": "3.0.0", 2762 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 2763 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 2764 | "dev": true, 2765 | "requires": { 2766 | "pify": "^3.0.0" 2767 | }, 2768 | "dependencies": { 2769 | "pify": { 2770 | "version": "3.0.0", 2771 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 2772 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 2773 | "dev": true 2774 | } 2775 | } 2776 | }, 2777 | "picomatch": { 2778 | "version": "2.3.1", 2779 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2780 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2781 | "dev": true 2782 | }, 2783 | "pidtree": { 2784 | "version": "0.3.1", 2785 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 2786 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", 2787 | "dev": true 2788 | }, 2789 | "queue-microtask": { 2790 | "version": "1.2.3", 2791 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2792 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2793 | "dev": true 2794 | }, 2795 | "quick-lru": { 2796 | "version": "5.1.1", 2797 | "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-5.1.1.tgz", 2798 | "integrity": "sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==", 2799 | "dev": true 2800 | }, 2801 | "read-pkg": { 2802 | "version": "3.0.0", 2803 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 2804 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 2805 | "dev": true, 2806 | "requires": { 2807 | "load-json-file": "^4.0.0", 2808 | "normalize-package-data": "^2.3.2", 2809 | "path-type": "^3.0.0" 2810 | } 2811 | }, 2812 | "read-pkg-up": { 2813 | "version": "8.0.0", 2814 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-8.0.0.tgz", 2815 | "integrity": "sha512-snVCqPczksT0HS2EC+SxUndvSzn6LRCwpfSvLrIfR5BKDQQZMaI6jPRC9dYvYFDRAuFEAnkwww8kBBNE/3VvzQ==", 2816 | "dev": true, 2817 | "requires": { 2818 | "find-up": "^5.0.0", 2819 | "read-pkg": "^6.0.0", 2820 | "type-fest": "^1.0.1" 2821 | }, 2822 | "dependencies": { 2823 | "hosted-git-info": { 2824 | "version": "4.1.0", 2825 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.1.0.tgz", 2826 | "integrity": "sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==", 2827 | "dev": true, 2828 | "requires": { 2829 | "lru-cache": "^6.0.0" 2830 | } 2831 | }, 2832 | "normalize-package-data": { 2833 | "version": "3.0.3", 2834 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-3.0.3.tgz", 2835 | "integrity": "sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==", 2836 | "dev": true, 2837 | "requires": { 2838 | "hosted-git-info": "^4.0.1", 2839 | "is-core-module": "^2.5.0", 2840 | "semver": "^7.3.4", 2841 | "validate-npm-package-license": "^3.0.1" 2842 | } 2843 | }, 2844 | "parse-json": { 2845 | "version": "5.2.0", 2846 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 2847 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 2848 | "dev": true, 2849 | "requires": { 2850 | "@babel/code-frame": "^7.0.0", 2851 | "error-ex": "^1.3.1", 2852 | "json-parse-even-better-errors": "^2.3.0", 2853 | "lines-and-columns": "^1.1.6" 2854 | } 2855 | }, 2856 | "read-pkg": { 2857 | "version": "6.0.0", 2858 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-6.0.0.tgz", 2859 | "integrity": "sha512-X1Fu3dPuk/8ZLsMhEj5f4wFAF0DWoK7qhGJvgaijocXxBmSToKfbFtqbxMO7bVjNA1dmE5huAzjXj/ey86iw9Q==", 2860 | "dev": true, 2861 | "requires": { 2862 | "@types/normalize-package-data": "^2.4.0", 2863 | "normalize-package-data": "^3.0.2", 2864 | "parse-json": "^5.2.0", 2865 | "type-fest": "^1.0.1" 2866 | } 2867 | }, 2868 | "semver": { 2869 | "version": "7.6.3", 2870 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2871 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2872 | "dev": true 2873 | } 2874 | } 2875 | }, 2876 | "redent": { 2877 | "version": "4.0.0", 2878 | "resolved": "https://registry.npmjs.org/redent/-/redent-4.0.0.tgz", 2879 | "integrity": "sha512-tYkDkVVtYkSVhuQ4zBgfvciymHaeuel+zFKXShfDnFP5SyVEP7qo70Rf1jTOTCx3vGNAbnEi/xFkcfQVMIBWag==", 2880 | "dev": true, 2881 | "requires": { 2882 | "indent-string": "^5.0.0", 2883 | "strip-indent": "^4.0.0" 2884 | } 2885 | }, 2886 | "resolve": { 2887 | "version": "1.19.0", 2888 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.19.0.tgz", 2889 | "integrity": "sha512-rArEXAgsBG4UgRGcynxWIWKFvh/XZCcS8UJdHhwy91zwAvCZIbcs+vAbflgBnNjYMs/i/i+/Ux6IZhML1yPvxg==", 2890 | "dev": true, 2891 | "requires": { 2892 | "is-core-module": "^2.1.0", 2893 | "path-parse": "^1.0.6" 2894 | } 2895 | }, 2896 | "reusify": { 2897 | "version": "1.0.4", 2898 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2899 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2900 | "dev": true 2901 | }, 2902 | "run-parallel": { 2903 | "version": "1.2.0", 2904 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2905 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2906 | "dev": true, 2907 | "requires": { 2908 | "queue-microtask": "^1.2.2" 2909 | } 2910 | }, 2911 | "semver": { 2912 | "version": "6.3.1", 2913 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 2914 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 2915 | "dev": true 2916 | }, 2917 | "shebang-command": { 2918 | "version": "1.2.0", 2919 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2920 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2921 | "dev": true, 2922 | "requires": { 2923 | "shebang-regex": "^1.0.0" 2924 | } 2925 | }, 2926 | "shebang-regex": { 2927 | "version": "1.0.0", 2928 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2929 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2930 | "dev": true 2931 | }, 2932 | "shell-quote": { 2933 | "version": "1.7.3", 2934 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.3.tgz", 2935 | "integrity": "sha512-Vpfqwm4EnqGdlsBFNmHhxhElJYrdfcxPThu+ryKS5J8L/fhAwLazFZtq+S+TWZ9ANj2piSQLGj6NQg+lKPmxrw==", 2936 | "dev": true 2937 | }, 2938 | "slash": { 2939 | "version": "4.0.0", 2940 | "resolved": "https://registry.npmjs.org/slash/-/slash-4.0.0.tgz", 2941 | "integrity": "sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew==", 2942 | "dev": true 2943 | }, 2944 | "spdx-correct": { 2945 | "version": "3.1.1", 2946 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 2947 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 2948 | "dev": true, 2949 | "requires": { 2950 | "spdx-expression-parse": "^3.0.0", 2951 | "spdx-license-ids": "^3.0.0" 2952 | } 2953 | }, 2954 | "spdx-exceptions": { 2955 | "version": "2.3.0", 2956 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 2957 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", 2958 | "dev": true 2959 | }, 2960 | "spdx-expression-parse": { 2961 | "version": "3.0.1", 2962 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 2963 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 2964 | "dev": true, 2965 | "requires": { 2966 | "spdx-exceptions": "^2.1.0", 2967 | "spdx-license-ids": "^3.0.0" 2968 | } 2969 | }, 2970 | "spdx-license-ids": { 2971 | "version": "3.0.6", 2972 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.6.tgz", 2973 | "integrity": "sha512-+orQK83kyMva3WyPf59k1+Y525csj5JejicWut55zeTWANuN17qSiSLUXWtzHeNWORSvT7GLDJ/E/XiIWoXBTw==", 2974 | "dev": true 2975 | }, 2976 | "string.prototype.padend": { 2977 | "version": "3.1.0", 2978 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.0.tgz", 2979 | "integrity": "sha512-3aIv8Ffdp8EZj8iLwREGpQaUZiPyrWrpzMBHvkiSW/bK/EGve9np07Vwy7IJ5waydpGXzQZu/F8Oze2/IWkBaA==", 2980 | "dev": true, 2981 | "requires": { 2982 | "define-properties": "^1.1.3", 2983 | "es-abstract": "^1.17.0-next.1" 2984 | } 2985 | }, 2986 | "string.prototype.trimend": { 2987 | "version": "1.0.2", 2988 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.2.tgz", 2989 | "integrity": "sha512-8oAG/hi14Z4nOVP0z6mdiVZ/wqjDtWSLygMigTzAb+7aPEDTleeFf+WrF+alzecxIRkckkJVn+dTlwzJXORATw==", 2990 | "dev": true, 2991 | "requires": { 2992 | "define-properties": "^1.1.3", 2993 | "es-abstract": "^1.18.0-next.1" 2994 | }, 2995 | "dependencies": { 2996 | "es-abstract": { 2997 | "version": "1.18.0-next.1", 2998 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", 2999 | "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", 3000 | "dev": true, 3001 | "requires": { 3002 | "es-to-primitive": "^1.2.1", 3003 | "function-bind": "^1.1.1", 3004 | "has": "^1.0.3", 3005 | "has-symbols": "^1.0.1", 3006 | "is-callable": "^1.2.2", 3007 | "is-negative-zero": "^2.0.0", 3008 | "is-regex": "^1.1.1", 3009 | "object-inspect": "^1.8.0", 3010 | "object-keys": "^1.1.1", 3011 | "object.assign": "^4.1.1", 3012 | "string.prototype.trimend": "^1.0.1", 3013 | "string.prototype.trimstart": "^1.0.1" 3014 | } 3015 | } 3016 | } 3017 | }, 3018 | "string.prototype.trimstart": { 3019 | "version": "1.0.2", 3020 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.2.tgz", 3021 | "integrity": "sha512-7F6CdBTl5zyu30BJFdzSTlSlLPwODC23Od+iLoVH8X6+3fvDPPuBVVj9iaB1GOsSTSIgVfsfm27R2FGrAPznWg==", 3022 | "dev": true, 3023 | "requires": { 3024 | "define-properties": "^1.1.3", 3025 | "es-abstract": "^1.18.0-next.1" 3026 | }, 3027 | "dependencies": { 3028 | "es-abstract": { 3029 | "version": "1.18.0-next.1", 3030 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.18.0-next.1.tgz", 3031 | "integrity": "sha512-I4UGspA0wpZXWENrdA0uHbnhte683t3qT/1VFH9aX2dA5PPSf6QW5HHXf5HImaqPmjXaVeVk4RGWnaylmV7uAA==", 3032 | "dev": true, 3033 | "requires": { 3034 | "es-to-primitive": "^1.2.1", 3035 | "function-bind": "^1.1.1", 3036 | "has": "^1.0.3", 3037 | "has-symbols": "^1.0.1", 3038 | "is-callable": "^1.2.2", 3039 | "is-negative-zero": "^2.0.0", 3040 | "is-regex": "^1.1.1", 3041 | "object-inspect": "^1.8.0", 3042 | "object-keys": "^1.1.1", 3043 | "object.assign": "^4.1.1", 3044 | "string.prototype.trimend": "^1.0.1", 3045 | "string.prototype.trimstart": "^1.0.1" 3046 | } 3047 | } 3048 | } 3049 | }, 3050 | "strip-bom": { 3051 | "version": "3.0.0", 3052 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3053 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 3054 | "dev": true 3055 | }, 3056 | "strip-indent": { 3057 | "version": "4.0.0", 3058 | "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-4.0.0.tgz", 3059 | "integrity": "sha512-mnVSV2l+Zv6BLpSD/8V87CW/y9EmmbYzGCIavsnsI6/nwn26DwffM/yztm30Z/I2DY9wdS3vXVCMnHDgZaVNoA==", 3060 | "dev": true, 3061 | "requires": { 3062 | "min-indent": "^1.0.1" 3063 | } 3064 | }, 3065 | "supports-color": { 3066 | "version": "5.5.0", 3067 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3068 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3069 | "dev": true, 3070 | "requires": { 3071 | "has-flag": "^3.0.0" 3072 | } 3073 | }, 3074 | "to-regex-range": { 3075 | "version": "5.0.1", 3076 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3077 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3078 | "dev": true, 3079 | "requires": { 3080 | "is-number": "^7.0.0" 3081 | } 3082 | }, 3083 | "trim-newlines": { 3084 | "version": "4.0.2", 3085 | "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-4.0.2.tgz", 3086 | "integrity": "sha512-GJtWyq9InR/2HRiLZgpIKv+ufIKrVrvjQWEj7PxAXNc5dwbNJkqhAUoAGgzRmULAnoOM5EIpveYd3J2VeSAIew==", 3087 | "dev": true 3088 | }, 3089 | "type-fest": { 3090 | "version": "1.4.0", 3091 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-1.4.0.tgz", 3092 | "integrity": "sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA==", 3093 | "dev": true 3094 | }, 3095 | "validate-npm-package-license": { 3096 | "version": "3.0.4", 3097 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 3098 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 3099 | "dev": true, 3100 | "requires": { 3101 | "spdx-correct": "^3.0.0", 3102 | "spdx-expression-parse": "^3.0.0" 3103 | } 3104 | }, 3105 | "which": { 3106 | "version": "1.3.1", 3107 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3108 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3109 | "dev": true, 3110 | "requires": { 3111 | "isexe": "^2.0.0" 3112 | } 3113 | }, 3114 | "yallist": { 3115 | "version": "4.0.0", 3116 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3117 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3118 | "dev": true 3119 | }, 3120 | "yargs-parser": { 3121 | "version": "20.2.9", 3122 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 3123 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 3124 | "dev": true 3125 | }, 3126 | "yocto-queue": { 3127 | "version": "0.1.0", 3128 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3129 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3130 | "dev": true 3131 | } 3132 | } 3133 | } 3134 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "jitsi-keycloak", 3 | "version": "1.0.0", 4 | "description": "Jitsi login with keycloak", 5 | "scripts": { 6 | "start": "npm run dev", 7 | "dev": "npm-run-all --parallel dev:client dev:server", 8 | "dev:client": "npm --prefix client run serve", 9 | "dev:server": "npm --prefix server run dev", 10 | "build": "npm-run-all build:client copy", 11 | "build:client": "npm --prefix client run build", 12 | "copy": "cpy --parents --cwd=client/dist ./ ../../server/public", 13 | "install": "npm-run-all install:client install:server", 14 | "install:client": "npm --prefix client install", 15 | "install:server": "npm --prefix server install" 16 | }, 17 | "repository": { 18 | "type": "git", 19 | "url": "git+https://github.com/D3473R/jitsi-keycloak.git" 20 | }, 21 | "author": "Fabian ", 22 | "license": "MIT", 23 | "bugs": { 24 | "url": "https://github.com/D3473R/jitsi-keycloak/issues" 25 | }, 26 | "homepage": "https://github.com/D3473R/jitsi-keycloak#readme", 27 | "devDependencies": { 28 | "cpy-cli": "^4.2.0", 29 | "npm-run-all": "^4.1.5" 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /server/.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": [ 3 | "@babel/preset-env" 4 | ] 5 | } 6 | -------------------------------------------------------------------------------- /server/.env.example: -------------------------------------------------------------------------------- 1 | JITSI_URL= 2 | JITSI_SECRET= 3 | DEFAULT_ROOM= 4 | ALLOWED_SUB=* 5 | ALLOWED_ROOM=* 6 | -------------------------------------------------------------------------------- /server/.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules 3 | /public 4 | 5 | # local env files 6 | .env 7 | .env.local 8 | .env.*.local 9 | 10 | # Log files 11 | npm-debug.log* 12 | yarn-debug.log* 13 | yarn-error.log* 14 | 15 | # Editor directories and files 16 | .idea 17 | .vscode 18 | *.suo 19 | *.ntvs* 20 | *.njsproj 21 | *.sln 22 | *.sw? 23 | -------------------------------------------------------------------------------- /server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "scripts": { 5 | "dev": "nodemon --exec ./node_modules/.bin/babel-node src/app.js", 6 | "start": "NODE_ENV=production node src/app.js" 7 | }, 8 | "dependencies": { 9 | "dotenv": "^16.0.3", 10 | "express": "^4.21.2", 11 | "express-session": "^1.18.1", 12 | "jsonwebtoken": "^9.0.0", 13 | "keycloak-connect": "^21.0.1", 14 | "path": "^0.12.7" 15 | }, 16 | "devDependencies": { 17 | "@babel/core": "^7.8.7", 18 | "@babel/node": "^7.8.7", 19 | "@babel/preset-env": "^7.8.7", 20 | "@types/express": "^4.17.3", 21 | "nodemon": "^2.0.2" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /server/public/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/d3473r/jitsi-keycloak/c54d21ea142a4a693b6422d3c123b7afb3079ea2/server/public/.gitkeep -------------------------------------------------------------------------------- /server/src/app.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | 3 | const path = require("path"); 4 | const crypto = require("crypto"); 5 | const jwt = require('jsonwebtoken'); 6 | const express = require("express"); 7 | const session = require("express-session"); 8 | const Keycloak = require("keycloak-connect"); 9 | require('dotenv').config() 10 | 11 | const PORT = 3000; 12 | 13 | const JITSI_SECRET = process.env.JITSI_SECRET || "JITSI_SECRET"; 14 | const DEFAULT_ROOM = process.env.DEFAULT_ROOM || "DEFAULT_ROOM"; 15 | const JITSI_URL = process.env.JITSI_URL || "JITSI_URL"; 16 | const ALLOWED_SUB = process.env.ALLOWED_SUB || "*"; 17 | const ALLOWED_ROOM = process.env.ALLOWED_ROOM || "*"; 18 | 19 | process.on('SIGINT', () => { 20 | process.exit(); 21 | }); 22 | 23 | const app = express(); 24 | 25 | const memoryStore = new session.MemoryStore(); 26 | const keycloak = new Keycloak({store: memoryStore}, "../config/keycloak.json"); 27 | 28 | app.use(session({ 29 | secret: crypto.randomBytes(24).toString("base64"), 30 | resave: false, 31 | saveUninitialized: true, 32 | store: memoryStore 33 | })); 34 | 35 | const sign = (firstName, lastName, email, avatar, nbf, exp) => { 36 | return jwt.sign({ 37 | "context": { 38 | "user": { 39 | "name": firstName + " " + lastName, 40 | "email": email, 41 | "avatar": avatar, 42 | "lobby_bypass": true 43 | }, 44 | }, 45 | "aud": "jitsi", 46 | "iss": "jitsi", 47 | "nbf": nbf, 48 | "exp": exp, 49 | "sub": ALLOWED_SUB, 50 | "room": ALLOWED_ROOM 51 | }, JITSI_SECRET); 52 | }; 53 | 54 | app.use('/', express.static('public')); 55 | app.get('/:room', function (req, res) { 56 | res.sendFile(req.params[0] ? req.params[0] : 'index.html', {root: './public'}); 57 | }); 58 | app.use(keycloak.middleware()); 59 | 60 | app.get("/api/config", keycloak.protect(), (req, res) => { 61 | let avatar; 62 | 63 | if (req.query.avatar) { 64 | avatar = req.query.avatar; 65 | } 66 | 67 | const profile = req.kauth.grant.access_token.content; 68 | return res.send(JSON.stringify({ 69 | token: sign(profile.given_name, profile.family_name, profile.email, avatar, profile.auth_time, profile.exp), 70 | jitsiUrl: JITSI_URL, 71 | defaultRoom: DEFAULT_ROOM 72 | })); 73 | }); 74 | 75 | app.get("/api/invite", keycloak.protect(), (req, res) => { 76 | return res.send(JSON.stringify({token: sign(req.query.name, "", "", req.query.room)})); 77 | }); 78 | 79 | app.get("/api/keycloak.json", (req, res) => { 80 | return res.sendFile(path.resolve(path.join(__dirname, "../../config/keycloak.json"))); 81 | }); 82 | 83 | app.listen(PORT); 84 | 85 | console.log(`App listening on port: ${PORT}`); 86 | --------------------------------------------------------------------------------