├── files ├── srv │ ├── src │ │ ├── index.js │ │ ├── initConfig.js │ │ ├── .eslintrc.json │ │ ├── restore.js │ │ ├── initBackupAndHealtCheck.js │ │ └── lib │ │ │ ├── HealtCheck.js │ │ │ ├── Backup.js │ │ │ └── Config.js │ ├── package.json │ └── package-lock.json ├── tmp │ └── install.txt └── usr │ └── bin │ └── entrypoint.sh ├── clientNetDisableEncryption.bat ├── docker-compose.yml ├── LICENSE ├── .gitignore ├── Dockerfile ├── .github └── workflows │ └── docker-publish.yml └── README.md /files/srv/src/index.js: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /files/tmp/install.txt: -------------------------------------------------------------------------------- 1 | @sSteamCmdForcePlatformType windows 2 | @sSteamCmdForcePlatformBitness 64 3 | force_install_dir /astroneer 4 | login anonymous 5 | app_update 728470 validate 6 | quit 7 | -------------------------------------------------------------------------------- /files/srv/src/initConfig.js: -------------------------------------------------------------------------------- 1 | const AstroServerConfig = require('./lib/Config'); 2 | 3 | (async function initAstroServerConfig() { 4 | const config = AstroServerConfig(); 5 | await config.update(); 6 | 7 | process.exit(0); 8 | }()); 9 | -------------------------------------------------------------------------------- /clientNetDisableEncryption.bat: -------------------------------------------------------------------------------- 1 | @echo off 2 | set "filePath=%LocalAppData%\Astro\Saved\Config\WindowsNoEditor\Engine.ini" 3 | 4 | echo [SystemSettings] >> "%filePath%" 5 | echo net.AllowEncryption=False >> "%filePath%" 6 | 7 | echo Lines added to %filePath% 8 | pause 9 | -------------------------------------------------------------------------------- /files/srv/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "node-asro-server", 3 | "version": "0.0.1", 4 | "description": "", 5 | "main": "src/index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "barumel", 10 | "license": "MIT", 11 | "dependencies": { 12 | "axios": "^1.7.7", 13 | "cli-color": "^2.0.4", 14 | "fs-extra": "^11.2.0", 15 | "glob": "^11.0.0", 16 | "ini": "^5.0.0", 17 | "lodash": "^4.17.21", 18 | "moment": "^2.30.1" 19 | }, 20 | "devDependencies": { 21 | "eslint": "^8.56.0", 22 | "eslint-config-airbnb": "^19.0.4", 23 | "eslint-plugin-import": "^2.29.1" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /docker-compose.yml: -------------------------------------------------------------------------------- 1 | version: '3.1' 2 | 3 | services: 4 | server: 5 | image: "barumel/docker-astroneer-server:latest" 6 | build: 7 | context: ./ 8 | dockerfile: Dockerfile 9 | environment: 10 | - "ASTRO_SERVER_PUBLIC_IP=${ASTRO_SERVER_PUBLIC_IP}" 11 | - "ASTRO_SERVER_DOMAIN_NAME=${ASTRO_SERVER_DOMAIN_NAME}" 12 | - "ASTRO_SERVER_PORT=${ASTRO_SERVER_PORT:-8777}" 13 | - "ASTRO_SERVER_NAME=${ASTRO_SERVER_NAME}" 14 | - "ASTRO_SERVER_PASSWORD=${ASTRO_SERVER_PASSWORD}" 15 | - "ASTRO_SERVER_OWNER_NAME=${ASTRO_SERVER_OWNER_NAME}" 16 | ports: 17 | - ${ASTRO_SERVER_PORT:-8777}:${ASTRO_SERVER_PORT:-8777}/tcp 18 | - ${ASTRO_SERVER_PORT:-8777}:${ASTRO_SERVER_PORT:-8777}/udp 19 | restart: always 20 | volumes: 21 | - astroneer:/astroneer 22 | - steamcmd:/steamcmd 23 | - backup:/backup 24 | 25 | volumes: 26 | astroneer: 27 | steamcmd: 28 | backup: 29 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 Manuel Kipfer 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 | -------------------------------------------------------------------------------- /files/srv/src/.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": [ 3 | "eslint:recommended", 4 | "plugin:import/recommended", 5 | "airbnb" 6 | ], 7 | "env": { 8 | "node": true, 9 | "es6": true 10 | }, 11 | "parserOptions": { 12 | "ecmaVersion": 2020 13 | }, 14 | "rules": { 15 | "no-console": "off", 16 | "strict": [ 17 | "error", 18 | "never" 19 | ], 20 | "object-curly-newline": [ 21 | 1, 22 | { 23 | "ObjectExpression": { 24 | "consistent": true 25 | }, 26 | "ObjectPattern": { 27 | "multiline": true, 28 | "minProperties": 4 29 | }, 30 | "ImportDeclaration": { 31 | "consistent": true 32 | }, 33 | "ExportDeclaration": { 34 | "multiline": true, 35 | "minProperties": 5 36 | } 37 | } 38 | ], 39 | "no-unused-vars": 1, 40 | "no-param-reassign": 1, 41 | "no-undef": "error", 42 | "no-undef-init": "error", 43 | "comma-dangle": 0, 44 | "import/no-useless-path-segments": 1, 45 | "import/no-named-as-default-member": 0, 46 | "import/no-named-as-default": 0 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /files/srv/src/restore.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs-extra'); 2 | const { chain } = require('lodash'); 3 | const moment = require('moment'); 4 | const clc = require('cli-color'); 5 | const { globSync } = require('glob'); 6 | 7 | (async function restore() { 8 | console.log(clc.yellow(`${moment().format()}: Backup(s) to restore found!`)); 9 | 10 | fs.readdirSync('/backup/restore') 11 | .filter((file) => !fs.lstatSync(`/backup/restore/${file}`).isDirectory()) 12 | .forEach((file) => { 13 | const name = chain(file) 14 | .replace('.savegame', '') 15 | .split('$') 16 | .first() 17 | .value(); 18 | 19 | console.log(clc.blue(`${moment().format()}: Backup to restore with name ${name} (${file}) found`)); 20 | console.log(clc.blue(`${moment().format()}: Remove save games starting with ${name} and copy backup to /astroneer/Astro/Saved/SaveGames/`)); 21 | 22 | const target = `/astroneer/Astro/Saved/SaveGames/${name}$${moment().format('YYYY.MM.DD-HH.mm.ss')}.savegame`; 23 | const savegames = globSync(`/astroneer/Astro/Saved/SaveGames/${name}*`); 24 | savegames.forEach((s) => fs.removeSync(s)); 25 | fs.moveSync(`/backup/restore/${file}`, target); 26 | 27 | console.log(clc.green(`${moment().format()}: Current save game with name ${name}* removed...`)); 28 | console.log(clc.green(`${moment().format()}: File ${file} moved to ${target}`)); 29 | }); 30 | 31 | console.log(clc.green(`${moment().format()}: Backup(s) successfully restored!`)); 32 | 33 | process.exit(0); 34 | }()); 35 | -------------------------------------------------------------------------------- /files/srv/src/initBackupAndHealtCheck.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs-extra'); 2 | const clc = require('cli-color'); 3 | const { chain } = require('lodash'); 4 | const moment = require('moment'); 5 | 6 | const Backup = require('./lib/Backup'); 7 | const HealthCheck = require('./lib/HealtCheck'); 8 | 9 | (async function initBackupAndHealtCheck() { 10 | const backup = Backup(); 11 | const healthCheck = HealthCheck(); 12 | 13 | /** 14 | * Callback if the health check failed. 15 | * Copy the latest backup to /backup/restore and exit the process. 16 | * This should restart the container with the copied backup 17 | * 18 | * @param {Array} broken List of broken save game base names (e.G. SAVE_1, SAVE_2...) 19 | * 20 | * @return {[type]} [return description] 21 | */ 22 | function onHealthCheckFailed(broken = []) { 23 | chain(broken) 24 | .map((b) => backup.getLatest(b)) 25 | .compact() 26 | .forEach((b) => { 27 | console.log(clc.blue(`${moment().format()}: Latest backup of ${b.name} is ${b.timestamp}. Copy it to /backup/restore`)); 28 | 29 | fs.copySync(b.path, `/backup/restore/${b.name}`); 30 | }) 31 | .value(); 32 | 33 | console.log(clc.blue(`${moment().format()}: Exit process...`)); 34 | console.log(clc.blue(`${moment().format()}: Be aware that you manually have to restart the container if it is not started with "--restart always"`)); 35 | 36 | process.exit(1); 37 | } 38 | 39 | await backup.init(); 40 | healthCheck.onFailed(onHealthCheckFailed); 41 | await healthCheck.init(); 42 | }()); 43 | -------------------------------------------------------------------------------- /files/usr/bin/entrypoint.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | set -e 3 | 4 | # https://github.com/lloesche/valheim-server-docker/blob/main/valheim-updater#L140 5 | # This works around the `Unable to determine CPU Frequency. Try defining CPU_MHZ.` steamcmd issue (#184). 6 | verify_cpu_mhz() { 7 | local float_regex 8 | local cpu_mhz 9 | float_regex="^([0-9]+\\.?[0-9]*)\$" 10 | cpu_mhz=$(grep "^cpu MHz" /proc/cpuinfo | head -1 | cut -d : -f 2 | xargs) 11 | if [ -n "$cpu_mhz" ] && [[ "$cpu_mhz" =~ $float_regex ]] && [ "${cpu_mhz%.*}" -gt 0 ]; then 12 | echo "Found CPU with $cpu_mhz MHz" 13 | unset CPU_MHZ 14 | else 15 | echo "Unable to determine CPU Frequency - setting a default of 1.5 GHz so steamcmd won't complain" 16 | export CPU_MHZ="1500.000" 17 | fi 18 | } 19 | 20 | # Remove the Xvfb lock file if it exists 21 | echo "REMOVE XVFB LOCK FILE IF IT EXISTS" 22 | rm -rf /tmp/.X99-lock 23 | echo "DONE..." 24 | 25 | verify_cpu_mhz 26 | 27 | echo "UPDATE STEAM CMD" 28 | bash /steamcmd/steamcmd.sh +quit 29 | 30 | echo "UPDATE ASTRO SERVER" 31 | bash /steamcmd/steamcmd.sh +runscript /tmp/install.txt 32 | 33 | # Check for first run 34 | if [ ! -f /astroneer/initialized ]; then 35 | echo "Server seems to run the first time!" 36 | echo "Start the server once to make sure all config files were created..." 37 | 38 | /geproton/proton run /astroneer/Astro/Binaries/Win64/AstroServer-Win64-Shipping.exe 39 | touch /astroneer/initialized 40 | mkdir -p /astroneer/Astro/Saved/SaveGames 41 | 42 | echo "Init done... continue" 43 | fi 44 | 45 | # Check if we have to restore a backup 46 | if [ ! -n "$(find "/backup/restore" -prune -empty)" ]; then 47 | node /srv/src/restore.js 48 | fi 49 | 50 | node /srv/src/initConfig.js 51 | 52 | # https://unix.stackexchange.com/questions/336411/how-can-i-run-two-commands-in-parallel-and-terminate-them-if-one-of-them-termina 53 | /geproton/proton run /astroneer/Astro/Binaries/Win64/AstroServer-Win64-Shipping.exe & p1=$! 54 | node /srv/src/initBackupAndHealtCheck.js & p2=$! 55 | 56 | wait -n 57 | [ "$?" -ge 0 ] || kill "$p1" "$p2" 58 | wait 59 | 60 | echo "D'oh" 61 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | lerna-debug.log* 8 | 9 | # Diagnostic reports (https://nodejs.org/api/report.html) 10 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json 11 | 12 | # Runtime data 13 | pids 14 | *.pid 15 | *.seed 16 | *.pid.lock 17 | 18 | # Directory for instrumented libs generated by jscoverage/JSCover 19 | lib-cov 20 | 21 | # Coverage directory used by tools like istanbul 22 | coverage 23 | *.lcov 24 | 25 | # nyc test coverage 26 | .nyc_output 27 | 28 | # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) 29 | .grunt 30 | 31 | # Bower dependency directory (https://bower.io/) 32 | bower_components 33 | 34 | # node-waf configuration 35 | .lock-wscript 36 | 37 | # Compiled binary addons (https://nodejs.org/api/addons.html) 38 | build/Release 39 | 40 | # Dependency directories 41 | node_modules/ 42 | jspm_packages/ 43 | 44 | # TypeScript v1 declaration files 45 | typings/ 46 | 47 | # TypeScript cache 48 | *.tsbuildinfo 49 | 50 | # Optional npm cache directory 51 | .npm 52 | 53 | # Optional eslint cache 54 | .eslintcache 55 | 56 | # Microbundle cache 57 | .rpt2_cache/ 58 | .rts2_cache_cjs/ 59 | .rts2_cache_es/ 60 | .rts2_cache_umd/ 61 | 62 | # Optional REPL history 63 | .node_repl_history 64 | 65 | # Output of 'npm pack' 66 | *.tgz 67 | 68 | # Yarn Integrity file 69 | .yarn-integrity 70 | 71 | # dotenv environment variables file 72 | .env 73 | .env.test 74 | 75 | # parcel-bundler cache (https://parceljs.org/) 76 | .cache 77 | 78 | # Next.js build output 79 | .next 80 | 81 | # Nuxt.js build / generate output 82 | .nuxt 83 | dist 84 | 85 | # Gatsby files 86 | .cache/ 87 | # Comment in the public line in if your project uses Gatsby and *not* Next.js 88 | # https://nextjs.org/blog/next-9-1#public-directory-support 89 | # public 90 | 91 | # vuepress build output 92 | .vuepress/dist 93 | 94 | # Serverless directories 95 | .serverless/ 96 | 97 | # FuseBox cache 98 | .fusebox/ 99 | 100 | # DynamoDB Local files 101 | .dynamodb/ 102 | 103 | # TernJS port file 104 | .tern-port 105 | -------------------------------------------------------------------------------- /files/srv/src/lib/HealtCheck.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs-extra'); 2 | const { chain, noop, first, size } = require('lodash'); 3 | const clc = require('cli-color'); 4 | const moment = require('moment'); 5 | const path = require('path'); 6 | 7 | function HealthCheck() { 8 | let intervalID; 9 | let callback = noop; 10 | 11 | /** 12 | * Init the health check. 13 | * Not sure why but after running the server for a while, savegames seems to get corrupted. 14 | * In this case, the server creates a new save game file and ignores the existing one. 15 | * Not sure if there is a better solution to detect that problem but now we are 16 | * simply going to count the number of files in the SaveGames folder. 17 | * As there should only be one save game, multiple files indicate 18 | * a potential problem with the old one... 19 | * 20 | * @return void 21 | */ 22 | function init() { 23 | intervalID = setInterval(() => { 24 | // It may take a while until the save game was created... Just log and wait or the next run 25 | if (!fs.existsSync('/astroneer/Astro/Saved/SaveGames')) { 26 | console.log(clc.yellow(`${moment().format()}: Unable to init health check as there are no save game files!`)); 27 | return; 28 | } 29 | 30 | const files = fs.readdirSync('/astroneer/Astro/Saved/SaveGames'); 31 | const broken = chain(files) 32 | .filter((file) => !fs.lstatSync(`/astroneer/Astro/Saved/SaveGames/${file}`).isDirectory()) 33 | .filter((file) => path.extname(file) === '.savegame') 34 | .groupBy((file) => first(file.split('$'))) 35 | .pickBy((f) => size(f) > 1) 36 | .keys() 37 | .value(); 38 | 39 | if (size(broken) > 0) { 40 | console.log(clc.red(`${moment().format()} Multiple save game files with the same name detected (${broken.join(', ')})! This indicates a broken save game...`)); 41 | callback(broken); 42 | } 43 | }, 20000); 44 | 45 | console.log(clc.green(`${moment().format()}: Health check is now running`)); 46 | } 47 | 48 | /** 49 | * Stop the health check 50 | * 51 | * @return void 52 | */ 53 | function stop() { 54 | clearInterval(intervalID); 55 | console.log(clc.green(`${moment().format()}: Health check stopped!`)); 56 | } 57 | 58 | /** 59 | * Register failed callback 60 | * 61 | * @param {Function} cb Callback to execute if the healt check fails 62 | * 63 | * @return void 64 | */ 65 | function onFailed(cb) { 66 | callback = cb; 67 | } 68 | 69 | return Object.freeze({ 70 | init, 71 | stop, 72 | onFailed 73 | }); 74 | } 75 | 76 | module.exports = HealthCheck; 77 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM amd64/debian:bookworm 2 | 3 | ENV DEBIAN_FRONTEND="noninteractive" 4 | ENV GE_PROTON_VERSION="9-18" 5 | ENV STEAMCMD_PATH="/steamcmd" 6 | ENV STEAM_COMPAT_CLIENT_INSTALL_PATH="/steamcmd" 7 | ENV STEAM_COMPAT_DATA_PATH="/steamcmd/steamapps/compatdata/728470" 8 | ENV PROTON_LOG="1 %command%" 9 | ENV PROTON_LOG_DIR="/steamcmd" 10 | 11 | # Add user and create necessary directories 12 | RUN set -ex; \ 13 | useradd --home-dir /home/steam --create-home steam; \ 14 | mkdir -p $STEAM_COMPAT_DATA_PATH; \ 15 | mkdir -p /geproton; \ 16 | mkdir -p /astroneer; \ 17 | mkdir -p /backup; \ 18 | mkdir -p /backup/daily; \ 19 | mkdir -p /backup/restore; 20 | 21 | # Update and install packages 22 | RUN set -ex; \ 23 | dpkg --add-architecture i386; \ 24 | apt-get update; \ 25 | apt-get install -y \ 26 | apt-transport-https \ 27 | ca-certificates \ 28 | software-properties-common \ 29 | wget \ 30 | vim \ 31 | xvfb \ 32 | ca-certificates \ 33 | lib32gcc-s1 \ 34 | winbind \ 35 | curl \ 36 | locales \ 37 | tzdata; 38 | 39 | # Update locales 40 | RUN set -ex; \ 41 | echo "en_US.UTF-8 UTF-8" > /etc/locale.gen; \ 42 | locale-gen en_US.UTF-8; \ 43 | dpkg-reconfigure locales; \ 44 | /usr/sbin/update-locale LANG=en_US.UTF-8; 45 | 46 | # Install nodejs 47 | RUN set -ex; \ 48 | mkdir -p /etc/apt/keyrings; \ 49 | curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg; \ 50 | echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_22.x nodistro main" > /etc/apt/sources.list.d/nodesource.list; \ 51 | apt-get update; \ 52 | apt-get -y install --no-install-recommends nodejs 53 | 54 | # Download steamcmd 55 | RUN set -ex; \ 56 | cd /steamcmd; \ 57 | wget -qO- 'https://steamcdn-a.akamaihd.net/client/installer/steamcmd_linux.tar.gz' | tar zxf -; \ 58 | chmod +x /steamcmd/steamcmd.sh 59 | 60 | # Download and extract proton 61 | RUN curl -sqL "https://github.com/GloriousEggroll/proton-ge-custom/releases/download/GE-Proton${GE_PROTON_VERSION}/GE-Proton${GE_PROTON_VERSION}.tar.gz" | tar zxvf - -C "/geproton" --strip-components=1 62 | 63 | # Copy files and install node modules 64 | COPY ./files/ ./ 65 | RUN rm -rf /srv/node_modules 66 | RUN set -ex; \ 67 | cd /srv; \ 68 | npm install 69 | 70 | # Adjust permissions to make sure the steam user can execute stuff 71 | RUN set -ex; \ 72 | chmod +x /usr/bin/entrypoint.sh; \ 73 | chown -R steam:root /steamcmd; \ 74 | chown -R steam:root /geproton; \ 75 | chown -R steam:root /astroneer; \ 76 | chown -R steam:root /backup; \ 77 | chown -R steam:root /tmp 78 | 79 | WORKDIR /steamcmd 80 | 81 | USER steam 82 | 83 | # ENTRYPOINT ["tail", "-f", "/dev/null"] 84 | 85 | ENTRYPOINT ["/usr/bin/entrypoint.sh"] 86 | 87 | EXPOSE 8777 88 | -------------------------------------------------------------------------------- /.github/workflows/docker-publish.yml: -------------------------------------------------------------------------------- 1 | name: Docker 2 | 3 | # This workflow uses actions that are not certified by GitHub. 4 | # They are provided by a third-party and are governed by 5 | # separate terms of service, privacy policy, and support 6 | # documentation. 7 | 8 | on: 9 | push: 10 | # Publish semver tags as releases. 11 | tags: [ '*.*.*' ] 12 | pull_request: 13 | branches: [ "develop" ] 14 | 15 | env: 16 | # Use docker.io for Docker Hub if empty 17 | REGISTRY: docker.io 18 | # github.repository as / 19 | IMAGE_NAME: ${{ github.repository }} 20 | 21 | 22 | jobs: 23 | build: 24 | 25 | runs-on: ubuntu-latest 26 | permissions: 27 | contents: read 28 | packages: write 29 | # This is used to complete the identity challenge 30 | # with sigstore/fulcio when running outside of PRs. 31 | id-token: write 32 | 33 | steps: 34 | - name: Checkout repository 35 | uses: actions/checkout@v4 36 | 37 | # Install the cosign tool except on PR 38 | # https://github.com/sigstore/cosign-installer 39 | - name: Install cosign 40 | if: github.event_name != 'pull_request' 41 | uses: sigstore/cosign-installer@59acb6260d9c0ba8f4a2f9d9b48431a222b68e20 #v3.5.0 42 | with: 43 | cosign-release: 'v2.2.4' 44 | 45 | # Set up BuildKit Docker container builder to be able to build 46 | # multi-platform images and export cache 47 | # https://github.com/docker/setup-buildx-action 48 | - name: Set up Docker Buildx 49 | uses: docker/setup-buildx-action@f95db51fddba0c2d1ec667646a06c2ce06100226 # v3.0.0 50 | 51 | # Login against a Docker registry except on PR 52 | # https://github.com/docker/login-action 53 | - name: Log into registry ${{ env.REGISTRY }} 54 | if: github.event_name != 'pull_request' 55 | uses: docker/login-action@343f7c4344506bcbf9b4de18042ae17996df046d # v3.0.0 56 | with: 57 | registry: ${{ env.REGISTRY }} 58 | username: ${{ secrets.DOCKERHUB_USERNAME }} 59 | password: ${{ secrets.DOCKERHUB_TOKEN }} 60 | 61 | # Extract metadata (tags, labels) for Docker 62 | # https://github.com/docker/metadata-action 63 | - name: Extract Docker metadata 64 | id: meta 65 | uses: docker/metadata-action@96383f45573cb7f253c731d3b3ab81c87ef81934 # v5.0.0 66 | with: 67 | images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} 68 | 69 | # Build and push Docker image with Buildx (don't push on PR) 70 | # https://github.com/docker/build-push-action 71 | - name: Build and push Docker image 72 | id: build-and-push 73 | uses: docker/build-push-action@0565240e2d4ab88bba5387d719585280857ece09 # v5.0.0 74 | with: 75 | context: . 76 | push: ${{ github.event_name != 'pull_request' }} 77 | tags: ${{ steps.meta.outputs.tags }} 78 | labels: ${{ steps.meta.outputs.labels }} 79 | cache-from: type=gha 80 | cache-to: type=gha,mode=max 81 | 82 | # Sign the resulting Docker image digest except on PRs. 83 | # This will only write to the public Rekor transparency log when the Docker 84 | # repository is public to avoid leaking data. If you would like to publish 85 | # transparency data even for private images, pass --force to cosign below. 86 | # https://github.com/sigstore/cosign 87 | - name: Sign the published Docker image 88 | if: ${{ github.event_name != 'pull_request' }} 89 | env: 90 | # https://docs.github.com/en/actions/security-guides/security-hardening-for-github-actions#using-an-intermediate-environment-variable 91 | TAGS: ${{ steps.meta.outputs.tags }} 92 | DIGEST: ${{ steps.build-and-push.outputs.digest }} 93 | # This step uses the identity token to provision an ephemeral certificate 94 | # against the sigstore community Fulcio instance. 95 | run: echo "${TAGS}" | xargs -I {} cosign sign --yes {}@${DIGEST} 96 | -------------------------------------------------------------------------------- /files/srv/src/lib/Backup.js: -------------------------------------------------------------------------------- 1 | const moment = require('moment'); 2 | const fs = require('fs-extra'); 3 | const { chain, get, first, last, orderBy, compact } = require('lodash'); 4 | const clc = require('cli-color'); 5 | const path = require('path'); 6 | 7 | function Backup() { 8 | let backups = []; 9 | let backupIntervalID; 10 | let cleanupIntervalID; 11 | 12 | /** 13 | * Load current backups from backup dir 14 | * 15 | * @return {[type]} [return description] 16 | */ 17 | function load() { 18 | console.log(clc.blue(`${moment().format()}: Loading current backups from "/backup" and "/backup/daily"`)); 19 | 20 | const daily = fs 21 | .readdirSync('/backup/daily') 22 | .filter((file) => !fs.lstatSync(`/backup/daily/${file}`).isDirectory()) 23 | .map((f) => { 24 | const parts = f.split('$'); 25 | const name = first(parts); 26 | const timestamp = last(parts); 27 | 28 | return { 29 | name, 30 | path: `/backup/daily/${f}`, 31 | timestamp, 32 | type: 'daily' 33 | }; 34 | }); 35 | 36 | const incremental = fs 37 | .readdirSync('/backup') 38 | .filter((file) => !fs.lstatSync(`/backup/${file}`).isDirectory()) 39 | .map((f) => { 40 | const parts = f.split('$'); 41 | const name = first(parts); 42 | const timestamp = last(parts); 43 | 44 | return { 45 | name, 46 | path: `/backup/${f}`, 47 | timestamp, 48 | type: 'incremental' 49 | }; 50 | }); 51 | 52 | return orderBy([...daily, ...incremental], ['timestamp'], ['asc']); 53 | } 54 | 55 | /** 56 | * Init the backup. 57 | * Load current backups from volume and order them by date. 58 | * Then start the backup intervall (10 min) 59 | * 60 | * @return void 61 | */ 62 | function init() { 63 | console.log(clc.blue(`${moment().format()}: Init backup...`)); 64 | 65 | fs.ensureDirSync('/backup/daily'); 66 | fs.ensureDirSync('/backup/restore'); 67 | backups = load(); 68 | 69 | // Run backup every 10 minutes 70 | backupIntervalID = setInterval(() => { 71 | const timestamp = moment().format(); 72 | const files = fs.readdirSync('/astroneer/Astro/Saved/SaveGames'); 73 | 74 | backups = chain(files) 75 | .filter((file) => path.extname(file) === '.savegame') 76 | .reduce((result, file) => { 77 | console.log(clc.blue(`${moment().format()}: Going to create incremental backup of file ${file}...`)); 78 | 79 | const name = first(file.split('$')); 80 | const target = `/backup/${name}$${timestamp}`; 81 | fs.copySync(`/astroneer/Astro/Saved/SaveGames/${file}`, target); 82 | 83 | console.log(clc.green(`${moment().format()}: Incremental backup of file ${file} created!`)); 84 | 85 | return [...result, { 86 | name, 87 | path: target, 88 | timestamp, 89 | type: 'incremental' 90 | }]; 91 | }, backups) 92 | .value(); 93 | }, 600000); 94 | 95 | // Run cleanup every hour 96 | // eslint-disable-next-line no-use-before-define 97 | cleanupIntervalID = setInterval(cleanup, (60 * 60 * 1000)); 98 | 99 | console.log(clc.green(`${moment().format()}: Backup is now running`)); 100 | } 101 | 102 | /** 103 | * Stop the backup 104 | * 105 | * @return void 106 | */ 107 | function stop() { 108 | clearInterval(backupIntervalID); 109 | clearInterval(cleanupIntervalID); 110 | console.log(clc.green(`${moment().format()}: Backup stopped!`)); 111 | } 112 | 113 | /** 114 | * Cleanup old backups 115 | * We are going to keep all the backups from current day and the latest one from prev days 116 | * 117 | * @return void 118 | */ 119 | function cleanup() { 120 | console.log(clc.blue('--------------Cleanup Backups--------------')); 121 | console.log(clc.blue(`${moment().format()}: Running periodic cleanup...`)); 122 | 123 | const items = load(); 124 | const files = chain(items) 125 | .filter((b) => b.type !== 'daily') 126 | .groupBy((b) => moment(b.timestamp).startOf('day').format()) 127 | .omit([moment().startOf('day').format()]) 128 | .reduce((result, b) => { 129 | const ordered = orderBy(b, ['timestamp'], ['asc']); 130 | const index = Math.floor(Math.abs(ordered.length - 1) / 2); 131 | 132 | const mid = get(ordered, index); 133 | const latest = last(ordered); 134 | 135 | const move = [ 136 | ...get(result, 'move', []), 137 | ...compact([mid, latest]) 138 | ]; 139 | 140 | const remove = [ 141 | ...get(result, 'remove', []), 142 | ...b 143 | ]; 144 | 145 | return { 146 | move, 147 | remove 148 | }; 149 | }, {}) 150 | .value(); 151 | 152 | console.log(clc.blue(`${moment().format()}: The following backups will be copied to the daily folder:`)); 153 | console.log(get(files, 'move', [])); 154 | 155 | // Copy daily files 156 | get(files, 'move', []).forEach((b) => fs.copySync(b.path, `/backup/daily/${b.name}$${b.timestamp}`)); 157 | 158 | console.log(clc.blue(`${moment().format()}: The following backups will be removed:`)); 159 | console.log(get(files, 'remove', [])); 160 | 161 | // Remove unused files 162 | get(files, 'remove', []).forEach((b) => fs.removeSync(b.path)); 163 | 164 | // Reload backups 165 | backups = load(); 166 | 167 | console.log(clc.green(`${moment().format()}: Cleanup successful!`)); 168 | } 169 | 170 | /** 171 | * Get the latest backup from backups 172 | * 173 | * @param {String} name Base name of the save game 174 | * 175 | * @return {String} latest Latest backup 176 | */ 177 | function getLatest(name) { 178 | backups = load(); 179 | 180 | return chain(backups) 181 | .filter((backup) => backup.name === name) 182 | .last() 183 | .value(); 184 | } 185 | 186 | return Object.freeze({ 187 | init, 188 | stop, 189 | getLatest, 190 | cleanup 191 | }); 192 | } 193 | 194 | module.exports = Backup; 195 | -------------------------------------------------------------------------------- /files/srv/src/lib/Config.js: -------------------------------------------------------------------------------- 1 | const clc = require('cli-color'); 2 | const fs = require('fs-extra'); 3 | const ini = require('ini'); 4 | const { get, setWith, isNil, pickBy, isEmpty } = require('lodash'); 5 | const axios = require('axios'); 6 | const moment = require('moment'); 7 | const dns = require('dns').promises; 8 | 9 | function AstroServerConfig() { 10 | /** 11 | * Check if the given env var is set and not empty 12 | * 13 | * @param {String} name Var name 14 | * 15 | * @return {Boolean} 16 | */ 17 | function hasEnvVar(name) { 18 | const value = get(process.env, name); 19 | 20 | return !isNil(value) && get(value, 'length', 0) > 0; 21 | } 22 | 23 | /** 24 | * Get a single var from env. 25 | * Return the defaultReturn if var is not set or an empty string 26 | * 27 | * @param {String} name Var name 28 | * @param {String} defaultReturn Default return if nil or empty 29 | * 30 | * @return {String} value Env var value 31 | */ 32 | function getEnvVar(name, defaultReturn = undefined) { 33 | return !hasEnvVar(name) 34 | ? defaultReturn 35 | : get(process.env, name); 36 | } 37 | 38 | /** 39 | * Try to resolve ASTRO_SERVER_DOMAIN_NAME 40 | * 41 | * @return {String} ip IP Address 42 | */ 43 | async function resolveDomainName() { 44 | const domain = getEnvVar('ASTRO_SERVER_DOMAIN_NAME'); 45 | console.log(clc.blue(`${moment().format()}: Try to resolve ${domain}`)); 46 | 47 | try { 48 | const { address } = await dns.lookup(domain, { family: 4 }); 49 | 50 | console.log(clc.blue(`${moment().format()}: Public ip address resolved for ${domain}: ${address}`)); 51 | 52 | return address; 53 | } catch (error) { 54 | console.error(clc.yellow(`${moment().format()}: Unable to resolve ${domain}!`, error)); 55 | 56 | return undefined; 57 | } 58 | } 59 | 60 | /** 61 | * Try to resolve the servers ip address via https://api.ipify.org/ 62 | * 63 | * @return {String} ip IP Address 64 | */ 65 | async function resolvePublicIpAddress() { 66 | console.log(clc.blue(`${moment().format()}: Try to get public ip address from https://api.ipify.org`)); 67 | 68 | try { 69 | const url = 'https://api.ipify.org/'; 70 | 71 | const { data } = await axios({ 72 | url, 73 | headers: { 74 | Accept: 'application/json', 75 | 'Content-Type': 'application/json' 76 | } 77 | }); 78 | 79 | console.log(clc.blue(`${moment().format()}: Public ip address returned from https://api.ipify.org: ${data}`)); 80 | 81 | return data; 82 | } catch (error) { 83 | console.log(clc.yellow(`${moment().format()}: Unable to get public ip address from https://api.ipify.org`, error)); 84 | 85 | return undefined; 86 | } 87 | } 88 | 89 | /** 90 | * Get the service ip address from config or try to resolve it 91 | * 92 | * @return {String} ip IP Address 93 | */ 94 | async function getIpAddress() { 95 | // ASTRO_SERVER_PUBLIC_IP must overrule other values 96 | if (hasEnvVar('ASTRO_SERVER_PUBLIC_IP')) { 97 | return getEnvVar('ASTRO_SERVER_PUBLIC_IP'); 98 | } 99 | 100 | return hasEnvVar('ASTRO_SERVER_DOMAIN_NAME') 101 | ? resolveDomainName() 102 | : resolvePublicIpAddress(); 103 | } 104 | 105 | /** 106 | * Update engine.ini with values from env 107 | * 108 | * @return void 109 | */ 110 | async function updateEngine() { 111 | const engine = ini.decode(fs.readFileSync('/astroneer/Astro/Saved/Config/WindowsServer/Engine.ini', 'utf8')); 112 | 113 | const values = { 114 | ASTRO_SERVER_PORT: getEnvVar('ASTRO_SERVER_PORT', '8777') 115 | }; 116 | 117 | setWith(engine, 'URL.Port', values.ASTRO_SERVER_PORT, Object); 118 | setWith(engine, 'SystemSettings', { 'net.AllowEncryption': 'False' }, Object); 119 | setWith(engine, '/Script/OnlineSubsystemUtils.IpNetDriver', { 120 | MaxClientRate: 1048576, 121 | MaxInternetClientRate: 1048576 122 | }, Object); 123 | 124 | fs.writeFileSync('/astroneer/Astro/Saved/Config/WindowsServer/Engine.ini', ini.encode(engine)); 125 | 126 | return values; 127 | } 128 | 129 | /** 130 | * Update AstroServerSettings with values from env 131 | * 132 | * @return void 133 | */ 134 | async function updateAstroServerSettings() { 135 | const astro = ini.decode(fs.readFileSync('/astroneer/Astro/Saved/Config/WindowsServer/AstroServerSettings.ini', 'utf8')); 136 | 137 | const values = { 138 | ASTRO_SERVER_PUBLIC_IP: await getIpAddress(), 139 | ASTRO_SERVER_NAME: getEnvVar('ASTRO_SERVER_NAME'), 140 | ASTRO_SERVER_OWNER_NAME: getEnvVar('ASTRO_SERVER_OWNER_NAME'), 141 | ASTRO_SERVER_PASSWORD: getEnvVar('ASTRO_SERVER_PASSWORD'), 142 | ASTRO_SERVER_AUTO_SAVE_INTERVAL: getEnvVar('ASTRO_SERVER_AUTO_SAVE_INTERVAL', 60) 143 | }; 144 | 145 | const missing = pickBy(values, (value) => isNil(value)); 146 | if (!isEmpty(missing)) { 147 | console.log(clc.red(`${moment().format()}: One or more required env variables are missing!`, Object.values(missing).join(', '))); 148 | 149 | process.exit(1); 150 | } 151 | 152 | setWith(astro, '/Script/Astro.AstroServerSettings.PublicIP', values.ASTRO_SERVER_PUBLIC_IP, Object); 153 | setWith(astro, '/Script/Astro.AstroServerSettings.ServerName', values.ASTRO_SERVER_NAME, Object); 154 | setWith(astro, '/Script/Astro.AstroServerSettings.OwnerName', values.ASTRO_SERVER_OWNER_NAME, Object); 155 | setWith(astro, '/Script/Astro.AstroServerSettings.ServerPassword', values.ASTRO_SERVER_PASSWORD, Object); 156 | setWith(astro, '/Script/Astro.AstroServerSettings.AutoSaveGameInterval', values.ASTRO_SERVER_AUTO_SAVE_INTERVAL, Object); 157 | setWith(astro, '/Script/Astro.AstroServerSettings.EnableAutoRestart', 'False', Object); 158 | 159 | fs.writeFileSync('/astroneer/Astro/Saved/Config/WindowsServer/AstroServerSettings.ini', ini.encode(astro)); 160 | 161 | return values; 162 | } 163 | 164 | /** 165 | * Update config in ini files 166 | * 167 | * @return void 168 | */ 169 | async function update() { 170 | console.log(clc.blue(`${moment().format()}: Going to update config files with current env variables...`)); 171 | 172 | const { ASTRO_SERVER_PORT } = await updateEngine(); 173 | const { ASTRO_SERVER_PUBLIC_IP } = await updateAstroServerSettings(); 174 | 175 | console.log(clc.green(`${moment().format()}: Successfully updated config files!`)); 176 | console.log(clc.green(`${moment().format()}: -------------------------------------`)); 177 | console.log(clc.blue(`${moment().format()}: Server IP: ${ASTRO_SERVER_PUBLIC_IP}`)); 178 | console.log(clc.blue(`${moment().format()}: Server Port: ${ASTRO_SERVER_PORT}`)); 179 | console.log(clc.blue(`${moment().format()}: Server URI: ${ASTRO_SERVER_PUBLIC_IP}:${ASTRO_SERVER_PORT}`)); 180 | console.log(clc.green(`${moment().format()}: -------------------------------------`)); 181 | } 182 | 183 | return Object.freeze({ 184 | hasEnvVar, 185 | getEnvVar, 186 | resolveDomainName, 187 | resolvePublicIpAddress, 188 | getIpAddress, 189 | update 190 | }); 191 | } 192 | 193 | module.exports = AstroServerConfig; 194 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # docker-astroneer-server 2 | 3 | ## Prerequisites 4 | 5 | ### Client 6 | 7 | #### Disable Encryption 8 | 9 | The current astroneer server implementation uses an encryption algorithm that is not supported by wine's implementation of bcrypt.dll. 10 | Due to this issue, we have to disable encryption on the server side to make things work. 11 | 12 | To be able to connect to the server you will have to disable encryption on the client side as well. 13 | 14 | Locate the Engine.ini file on your file system (usually located under `<>/AppData/Local/Astro/Saved/Config/WindowsNoEditor)` and add the following line to the bottom of the file: 15 | 16 | > win + r %LocalAppData%\Astro\Saved\Config\WindowsNoEditor 17 | 18 | ``` 19 | [SystemSettings] 20 | net.AllowEncryption=False 21 | ``` 22 | 23 | You can do this the terminal directly: 24 | 25 | ```bash 26 | echo [SystemSettings] >> "%LocalAppData%\Astro\Saved\Config\WindowsNoEditor\Engine.ini" 27 | echo net.AllowEncryption=False >> "%LocalAppData%\Astro\Saved\Config\WindowsNoEditor\Engine.ini" 28 | ``` 29 | 30 | Or, you can use the provided .bat file to modify the client config file 31 | 32 | ```bash 33 | clientNetDisableEncryption.bat 34 | ``` 35 | 36 | ### Router / Firewall 37 | 38 | Make sure you configured your router to forward the configured port (default 8777) to your server machine. 39 | 40 | Also open this port on your firewall if you have one. 41 | 42 | There is no general way to do this as it varies depending on the router / firewall used. 43 | 44 | ## Configuration 45 | 46 | The following configuration values are currently available 47 | 48 | | VAR | Required | Default Value | Description | 49 | | ------------------------ | -------- | ------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | 50 | | ASTRO_SERVER_NAME | Yes | | The name or your server. | 51 | | ASTRO_SERVER_PORT | No | 8777 | Custom server port | 52 | | ASTRO_SERVER_PUBLIC_IP | No | | The public ip address (v4) of your server. If left empty, https://api.ipify.org/ will be used to determine your current ip address (recommended). | 53 | | ASTRO_SERVER_DOMAIN_NAME | No | | Optional domain name to resolve the ip for the server.
Only use this if the IP address returned from https://api.ipify.org/ is not correct and your host has a domain name that can be resolved.
Be aware that you can't connect to the server with this domain name, it's just a helper to determine the ip address of your server. You will still have to connect to the server with `<>:<>` | 54 | | ASTRO_SERVER_OWNER_NAME | Yes | | Name or the server owner (Steam username) | 55 | | ASTRO_SERVER_PASSWORD | Yes | | Server password | 56 | 57 | ## Starting the server 58 | 59 | You can use the provided docker-compose.yml to start the server. 60 | 61 | Just create a .env file in the same directory and add the necessary env vars. 62 | 63 | ```Example 64 | # Exampe .env 65 | ASTRO_SERVER_NAME="My Astro Server" 66 | ASTRO_SERVER_PASSWORD="Replace_me_with_a_Password!" 67 | ASTRO_SERVER_OWNER_NAME="Your_Steam_Username" 68 | ``` 69 | 70 | If you want to import an existing save game, do it like described below. 71 | 72 | Then run: 73 | 74 | ``` 75 | docker compose up -d 76 | ``` 77 | 78 | This may take a few minutes if the server runs the first time as it installs the server software via steamcmd and launches the server to make sure all necessary .ini files were created. 79 | 80 | ## Using an existing save game 81 | 82 | You can import an existing save game to the server via the following commands. 83 | 84 | ``` 85 | # Stop the server if it is already running 86 | docker compose down 87 | 88 | # Create the container but do not start it 89 | docker componse create 90 | 91 | # Get the container id via docker ps 92 | docker ps -a 93 | 94 | # Copy the save game to the container's /backup/restore dir 95 | # This will overwrite the automatically created SAVE_1 file. If you want to keep the current save game, make sure you choose a name that does not exist in the SaveGames folder 96 | docker cp MY_SAVE_GAME.savegame <>:/backup/restore/SAVE_1 97 | 98 | 99 | # Start the server 100 | docker compose up -d 101 | ``` 102 | 103 | The server will check the /tmp dir on the first run and copy the save game to the SaveGames folder. 104 | 105 | ## Backups 106 | 107 | Backups are created every 10 minutes under `/backup` (backup volume in docker compose). 108 | 109 | These backups are only kept for the current day and are removed by a cleanup job that periodically runs. 110 | 111 | The latest backup of each day gets moved to `/backup/daily` 112 | 113 | ### Restore a backup 114 | 115 | #### Manually restore 116 | 117 | ```shell 118 | # Copy the backup to the local dir 119 | docker cp <>:/backup/<> ./SAVE_1.savegame 120 | 121 | # Stop the server 122 | docker compose stop 123 | 124 | # Create but don't start the container 125 | docker compose create 126 | 127 | # Get the container id 128 | docker ps -a 129 | 130 | # Copy the backup file 131 | # Adjust the file name to your current active save game name (if you did not create a new save game via UI the default is SAVE_1) 132 | docker cp SAVE_1.savegame <>:/backup/restore/SAVE_1 133 | 134 | # Start the server 135 | docker compose up -d 136 | ``` 137 | 138 | ## Troubleshooting 139 | 140 | ### Cannot connect to the server 141 | 142 | Check if your server ip / port is correct. Currently only IP v4 adresses are supported. It is not possible to join the server via domain name or IP v6. 143 | 144 | Also make sure that you are using your pubic IP address. Connecting via local ip address does not work! You can get the full server uri in the server log. 145 | 146 | Example: `123.456.7.89:8777` 147 | 148 | 149 | 150 | Use the server checker provided by @JoeJoeTV to check if your server shows online [[https://astroservercheck.joejoetv.de/](https://astroservercheck.joejoetv.de/) 151 | 152 | If it is online 153 | 154 | - Check if other people (not in your LAN) can join the server. If so, this indicates an issue with NAT Loopback. 155 | 156 | Your router must support NAT Loopback (Hairpinning) which lets clients 157 | from inside your Network connect to the server via its public IP 158 | address. Some routers don't support this at all, on some you'll have to 159 | enable it first. Check your router manual. 160 | 161 | 162 | 163 | 164 | 165 | If it is not online or has issues 166 | 167 | - Check your router configuration / port forwarding. The server port 168 | (default 8777) must point to the machine the container is running on. 169 | 170 | - Make sure the port is not blocked by a firewall 171 | 172 | ### Discord 173 | 174 | Join the official Astroneer Discord server: [ASTRONEER](https://discord.com/invite/astroneer). 175 | 176 | Check the pinned messages in the self-hosted-talk channel as many common issues already have been solved there. 177 | -------------------------------------------------------------------------------- /files/srv/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "node-asro-server", 3 | "version": "0.0.1", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "node-asro-server", 9 | "version": "0.0.1", 10 | "license": "MIT", 11 | "dependencies": { 12 | "axios": "^1.7.7", 13 | "cli-color": "^2.0.4", 14 | "fs-extra": "^11.2.0", 15 | "glob": "^11.0.0", 16 | "ini": "^5.0.0", 17 | "lodash": "^4.17.21", 18 | "moment": "^2.30.1" 19 | }, 20 | "devDependencies": { 21 | "eslint": "^8.56.0", 22 | "eslint-config-airbnb": "^19.0.4", 23 | "eslint-plugin-import": "^2.29.1" 24 | } 25 | }, 26 | "node_modules/@eslint-community/eslint-utils": { 27 | "version": "4.4.1", 28 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.1.tgz", 29 | "integrity": "sha512-s3O3waFUrMV8P/XaF/+ZTp1X9XBZW1a4B97ZnjQF2KYWaFD2A8KyFBsrsfSjEmjn3RGWAIuvlneuZm3CUK3jbA==", 30 | "dev": true, 31 | "dependencies": { 32 | "eslint-visitor-keys": "^3.4.3" 33 | }, 34 | "engines": { 35 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 36 | }, 37 | "funding": { 38 | "url": "https://opencollective.com/eslint" 39 | }, 40 | "peerDependencies": { 41 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 42 | } 43 | }, 44 | "node_modules/@eslint-community/regexpp": { 45 | "version": "4.12.1", 46 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz", 47 | "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==", 48 | "dev": true, 49 | "engines": { 50 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 51 | } 52 | }, 53 | "node_modules/@eslint/eslintrc": { 54 | "version": "2.1.4", 55 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 56 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 57 | "dev": true, 58 | "dependencies": { 59 | "ajv": "^6.12.4", 60 | "debug": "^4.3.2", 61 | "espree": "^9.6.0", 62 | "globals": "^13.19.0", 63 | "ignore": "^5.2.0", 64 | "import-fresh": "^3.2.1", 65 | "js-yaml": "^4.1.0", 66 | "minimatch": "^3.1.2", 67 | "strip-json-comments": "^3.1.1" 68 | }, 69 | "engines": { 70 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 71 | }, 72 | "funding": { 73 | "url": "https://opencollective.com/eslint" 74 | } 75 | }, 76 | "node_modules/@eslint/js": { 77 | "version": "8.57.1", 78 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.1.tgz", 79 | "integrity": "sha512-d9zaMRSTIKDLhctzH12MtXvJKSSUhaHcjV+2Z+GK+EEY7XKpP5yR4x+N3TAcHTcu963nIr+TMcCb4DBCYX1z6Q==", 80 | "dev": true, 81 | "engines": { 82 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 83 | } 84 | }, 85 | "node_modules/@humanwhocodes/config-array": { 86 | "version": "0.13.0", 87 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.13.0.tgz", 88 | "integrity": "sha512-DZLEEqFWQFiyK6h5YIeynKx7JlvCYWL0cImfSRXZ9l4Sg2efkFGTuFf6vzXjK1cq6IYkU+Eg/JizXw+TD2vRNw==", 89 | "deprecated": "Use @eslint/config-array instead", 90 | "dev": true, 91 | "dependencies": { 92 | "@humanwhocodes/object-schema": "^2.0.3", 93 | "debug": "^4.3.1", 94 | "minimatch": "^3.0.5" 95 | }, 96 | "engines": { 97 | "node": ">=10.10.0" 98 | } 99 | }, 100 | "node_modules/@humanwhocodes/module-importer": { 101 | "version": "1.0.1", 102 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 103 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 104 | "dev": true, 105 | "engines": { 106 | "node": ">=12.22" 107 | }, 108 | "funding": { 109 | "type": "github", 110 | "url": "https://github.com/sponsors/nzakas" 111 | } 112 | }, 113 | "node_modules/@humanwhocodes/object-schema": { 114 | "version": "2.0.3", 115 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", 116 | "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", 117 | "deprecated": "Use @eslint/object-schema instead", 118 | "dev": true 119 | }, 120 | "node_modules/@isaacs/cliui": { 121 | "version": "8.0.2", 122 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", 123 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", 124 | "dependencies": { 125 | "string-width": "^5.1.2", 126 | "string-width-cjs": "npm:string-width@^4.2.0", 127 | "strip-ansi": "^7.0.1", 128 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", 129 | "wrap-ansi": "^8.1.0", 130 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" 131 | }, 132 | "engines": { 133 | "node": ">=12" 134 | } 135 | }, 136 | "node_modules/@isaacs/cliui/node_modules/ansi-regex": { 137 | "version": "6.1.0", 138 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", 139 | "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", 140 | "engines": { 141 | "node": ">=12" 142 | }, 143 | "funding": { 144 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 145 | } 146 | }, 147 | "node_modules/@isaacs/cliui/node_modules/strip-ansi": { 148 | "version": "7.1.0", 149 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 150 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 151 | "dependencies": { 152 | "ansi-regex": "^6.0.1" 153 | }, 154 | "engines": { 155 | "node": ">=12" 156 | }, 157 | "funding": { 158 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 159 | } 160 | }, 161 | "node_modules/@nodelib/fs.scandir": { 162 | "version": "2.1.5", 163 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 164 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 165 | "dev": true, 166 | "dependencies": { 167 | "@nodelib/fs.stat": "2.0.5", 168 | "run-parallel": "^1.1.9" 169 | }, 170 | "engines": { 171 | "node": ">= 8" 172 | } 173 | }, 174 | "node_modules/@nodelib/fs.stat": { 175 | "version": "2.0.5", 176 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 177 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 178 | "dev": true, 179 | "engines": { 180 | "node": ">= 8" 181 | } 182 | }, 183 | "node_modules/@nodelib/fs.walk": { 184 | "version": "1.2.8", 185 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 186 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 187 | "dev": true, 188 | "dependencies": { 189 | "@nodelib/fs.scandir": "2.1.5", 190 | "fastq": "^1.6.0" 191 | }, 192 | "engines": { 193 | "node": ">= 8" 194 | } 195 | }, 196 | "node_modules/@rtsao/scc": { 197 | "version": "1.1.0", 198 | "resolved": "https://registry.npmjs.org/@rtsao/scc/-/scc-1.1.0.tgz", 199 | "integrity": "sha512-zt6OdqaDoOnJ1ZYsCYGt9YmWzDXl4vQdKTyJev62gFhRGKdx7mcT54V9KIjg+d2wi9EXsPvAPKe7i7WjfVWB8g==", 200 | "dev": true 201 | }, 202 | "node_modules/@types/json5": { 203 | "version": "0.0.29", 204 | "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", 205 | "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", 206 | "dev": true 207 | }, 208 | "node_modules/@ungap/structured-clone": { 209 | "version": "1.2.0", 210 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 211 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 212 | "dev": true 213 | }, 214 | "node_modules/acorn": { 215 | "version": "8.14.0", 216 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz", 217 | "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==", 218 | "dev": true, 219 | "bin": { 220 | "acorn": "bin/acorn" 221 | }, 222 | "engines": { 223 | "node": ">=0.4.0" 224 | } 225 | }, 226 | "node_modules/acorn-jsx": { 227 | "version": "5.3.2", 228 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 229 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 230 | "dev": true, 231 | "peerDependencies": { 232 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 233 | } 234 | }, 235 | "node_modules/ajv": { 236 | "version": "6.12.6", 237 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 238 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 239 | "dev": true, 240 | "dependencies": { 241 | "fast-deep-equal": "^3.1.1", 242 | "fast-json-stable-stringify": "^2.0.0", 243 | "json-schema-traverse": "^0.4.1", 244 | "uri-js": "^4.2.2" 245 | }, 246 | "funding": { 247 | "type": "github", 248 | "url": "https://github.com/sponsors/epoberezkin" 249 | } 250 | }, 251 | "node_modules/ansi-regex": { 252 | "version": "5.0.1", 253 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 254 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 255 | "engines": { 256 | "node": ">=8" 257 | } 258 | }, 259 | "node_modules/ansi-styles": { 260 | "version": "4.3.0", 261 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 262 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 263 | "dependencies": { 264 | "color-convert": "^2.0.1" 265 | }, 266 | "engines": { 267 | "node": ">=8" 268 | }, 269 | "funding": { 270 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 271 | } 272 | }, 273 | "node_modules/argparse": { 274 | "version": "2.0.1", 275 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 276 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 277 | "dev": true 278 | }, 279 | "node_modules/aria-query": { 280 | "version": "5.3.2", 281 | "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.3.2.tgz", 282 | "integrity": "sha512-COROpnaoap1E2F000S62r6A60uHZnmlvomhfyT2DlTcrY1OrBKn2UhH7qn5wTC9zMvD0AY7csdPSNwKP+7WiQw==", 283 | "dev": true, 284 | "peer": true, 285 | "engines": { 286 | "node": ">= 0.4" 287 | } 288 | }, 289 | "node_modules/array-buffer-byte-length": { 290 | "version": "1.0.1", 291 | "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", 292 | "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", 293 | "dev": true, 294 | "dependencies": { 295 | "call-bind": "^1.0.5", 296 | "is-array-buffer": "^3.0.4" 297 | }, 298 | "engines": { 299 | "node": ">= 0.4" 300 | }, 301 | "funding": { 302 | "url": "https://github.com/sponsors/ljharb" 303 | } 304 | }, 305 | "node_modules/array-includes": { 306 | "version": "3.1.8", 307 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz", 308 | "integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==", 309 | "dev": true, 310 | "dependencies": { 311 | "call-bind": "^1.0.7", 312 | "define-properties": "^1.2.1", 313 | "es-abstract": "^1.23.2", 314 | "es-object-atoms": "^1.0.0", 315 | "get-intrinsic": "^1.2.4", 316 | "is-string": "^1.0.7" 317 | }, 318 | "engines": { 319 | "node": ">= 0.4" 320 | }, 321 | "funding": { 322 | "url": "https://github.com/sponsors/ljharb" 323 | } 324 | }, 325 | "node_modules/array.prototype.findlast": { 326 | "version": "1.2.5", 327 | "resolved": "https://registry.npmjs.org/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz", 328 | "integrity": "sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==", 329 | "dev": true, 330 | "peer": true, 331 | "dependencies": { 332 | "call-bind": "^1.0.7", 333 | "define-properties": "^1.2.1", 334 | "es-abstract": "^1.23.2", 335 | "es-errors": "^1.3.0", 336 | "es-object-atoms": "^1.0.0", 337 | "es-shim-unscopables": "^1.0.2" 338 | }, 339 | "engines": { 340 | "node": ">= 0.4" 341 | }, 342 | "funding": { 343 | "url": "https://github.com/sponsors/ljharb" 344 | } 345 | }, 346 | "node_modules/array.prototype.findlastindex": { 347 | "version": "1.2.5", 348 | "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.5.tgz", 349 | "integrity": "sha512-zfETvRFA8o7EiNn++N5f/kaCw221hrpGsDmcpndVupkPzEc1Wuf3VgC0qby1BbHs7f5DVYjgtEU2LLh5bqeGfQ==", 350 | "dev": true, 351 | "dependencies": { 352 | "call-bind": "^1.0.7", 353 | "define-properties": "^1.2.1", 354 | "es-abstract": "^1.23.2", 355 | "es-errors": "^1.3.0", 356 | "es-object-atoms": "^1.0.0", 357 | "es-shim-unscopables": "^1.0.2" 358 | }, 359 | "engines": { 360 | "node": ">= 0.4" 361 | }, 362 | "funding": { 363 | "url": "https://github.com/sponsors/ljharb" 364 | } 365 | }, 366 | "node_modules/array.prototype.flat": { 367 | "version": "1.3.2", 368 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", 369 | "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", 370 | "dev": true, 371 | "dependencies": { 372 | "call-bind": "^1.0.2", 373 | "define-properties": "^1.2.0", 374 | "es-abstract": "^1.22.1", 375 | "es-shim-unscopables": "^1.0.0" 376 | }, 377 | "engines": { 378 | "node": ">= 0.4" 379 | }, 380 | "funding": { 381 | "url": "https://github.com/sponsors/ljharb" 382 | } 383 | }, 384 | "node_modules/array.prototype.flatmap": { 385 | "version": "1.3.2", 386 | "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", 387 | "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", 388 | "dev": true, 389 | "dependencies": { 390 | "call-bind": "^1.0.2", 391 | "define-properties": "^1.2.0", 392 | "es-abstract": "^1.22.1", 393 | "es-shim-unscopables": "^1.0.0" 394 | }, 395 | "engines": { 396 | "node": ">= 0.4" 397 | }, 398 | "funding": { 399 | "url": "https://github.com/sponsors/ljharb" 400 | } 401 | }, 402 | "node_modules/array.prototype.tosorted": { 403 | "version": "1.1.4", 404 | "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.4.tgz", 405 | "integrity": "sha512-p6Fx8B7b7ZhL/gmUsAy0D15WhvDccw3mnGNbZpi3pmeJdxtWsj2jEaI4Y6oo3XiHfzuSgPwKc04MYt6KgvC/wA==", 406 | "dev": true, 407 | "peer": true, 408 | "dependencies": { 409 | "call-bind": "^1.0.7", 410 | "define-properties": "^1.2.1", 411 | "es-abstract": "^1.23.3", 412 | "es-errors": "^1.3.0", 413 | "es-shim-unscopables": "^1.0.2" 414 | }, 415 | "engines": { 416 | "node": ">= 0.4" 417 | } 418 | }, 419 | "node_modules/arraybuffer.prototype.slice": { 420 | "version": "1.0.3", 421 | "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", 422 | "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", 423 | "dev": true, 424 | "dependencies": { 425 | "array-buffer-byte-length": "^1.0.1", 426 | "call-bind": "^1.0.5", 427 | "define-properties": "^1.2.1", 428 | "es-abstract": "^1.22.3", 429 | "es-errors": "^1.2.1", 430 | "get-intrinsic": "^1.2.3", 431 | "is-array-buffer": "^3.0.4", 432 | "is-shared-array-buffer": "^1.0.2" 433 | }, 434 | "engines": { 435 | "node": ">= 0.4" 436 | }, 437 | "funding": { 438 | "url": "https://github.com/sponsors/ljharb" 439 | } 440 | }, 441 | "node_modules/ast-types-flow": { 442 | "version": "0.0.8", 443 | "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.8.tgz", 444 | "integrity": "sha512-OH/2E5Fg20h2aPrbe+QL8JZQFko0YZaF+j4mnQ7BGhfavO7OpSLa8a0y9sBwomHdSbkhTS8TQNayBfnW5DwbvQ==", 445 | "dev": true, 446 | "peer": true 447 | }, 448 | "node_modules/asynckit": { 449 | "version": "0.4.0", 450 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 451 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 452 | }, 453 | "node_modules/available-typed-arrays": { 454 | "version": "1.0.7", 455 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", 456 | "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", 457 | "dev": true, 458 | "dependencies": { 459 | "possible-typed-array-names": "^1.0.0" 460 | }, 461 | "engines": { 462 | "node": ">= 0.4" 463 | }, 464 | "funding": { 465 | "url": "https://github.com/sponsors/ljharb" 466 | } 467 | }, 468 | "node_modules/axe-core": { 469 | "version": "4.10.2", 470 | "resolved": "https://registry.npmjs.org/axe-core/-/axe-core-4.10.2.tgz", 471 | "integrity": "sha512-RE3mdQ7P3FRSe7eqCWoeQ/Z9QXrtniSjp1wUjt5nRC3WIpz5rSCve6o3fsZ2aCpJtrZjSZgjwXAoTO5k4tEI0w==", 472 | "dev": true, 473 | "peer": true, 474 | "engines": { 475 | "node": ">=4" 476 | } 477 | }, 478 | "node_modules/axios": { 479 | "version": "1.7.7", 480 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.7.tgz", 481 | "integrity": "sha512-S4kL7XrjgBmvdGut0sN3yJxqYzrDOnivkBiN0OFs6hLiUam3UPvswUo0kqGyhqUZGEOytHyumEdXsAkgCOUf3Q==", 482 | "dependencies": { 483 | "follow-redirects": "^1.15.6", 484 | "form-data": "^4.0.0", 485 | "proxy-from-env": "^1.1.0" 486 | } 487 | }, 488 | "node_modules/axobject-query": { 489 | "version": "4.1.0", 490 | "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-4.1.0.tgz", 491 | "integrity": "sha512-qIj0G9wZbMGNLjLmg1PT6v2mE9AH2zlnADJD/2tC6E00hgmhUOfEB6greHPAfLRSufHqROIUTkw6E+M3lH0PTQ==", 492 | "dev": true, 493 | "peer": true, 494 | "engines": { 495 | "node": ">= 0.4" 496 | } 497 | }, 498 | "node_modules/balanced-match": { 499 | "version": "1.0.2", 500 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 501 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 502 | }, 503 | "node_modules/brace-expansion": { 504 | "version": "1.1.11", 505 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 506 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 507 | "dev": true, 508 | "dependencies": { 509 | "balanced-match": "^1.0.0", 510 | "concat-map": "0.0.1" 511 | } 512 | }, 513 | "node_modules/call-bind": { 514 | "version": "1.0.7", 515 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", 516 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", 517 | "dev": true, 518 | "dependencies": { 519 | "es-define-property": "^1.0.0", 520 | "es-errors": "^1.3.0", 521 | "function-bind": "^1.1.2", 522 | "get-intrinsic": "^1.2.4", 523 | "set-function-length": "^1.2.1" 524 | }, 525 | "engines": { 526 | "node": ">= 0.4" 527 | }, 528 | "funding": { 529 | "url": "https://github.com/sponsors/ljharb" 530 | } 531 | }, 532 | "node_modules/callsites": { 533 | "version": "3.1.0", 534 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 535 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 536 | "dev": true, 537 | "engines": { 538 | "node": ">=6" 539 | } 540 | }, 541 | "node_modules/chalk": { 542 | "version": "4.1.2", 543 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 544 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 545 | "dev": true, 546 | "dependencies": { 547 | "ansi-styles": "^4.1.0", 548 | "supports-color": "^7.1.0" 549 | }, 550 | "engines": { 551 | "node": ">=10" 552 | }, 553 | "funding": { 554 | "url": "https://github.com/chalk/chalk?sponsor=1" 555 | } 556 | }, 557 | "node_modules/cli-color": { 558 | "version": "2.0.4", 559 | "resolved": "https://registry.npmjs.org/cli-color/-/cli-color-2.0.4.tgz", 560 | "integrity": "sha512-zlnpg0jNcibNrO7GG9IeHH7maWFeCz+Ja1wx/7tZNU5ASSSSZ+/qZciM0/LHCYxSdqv5h2sdbQ/PXYdOuetXvA==", 561 | "dependencies": { 562 | "d": "^1.0.1", 563 | "es5-ext": "^0.10.64", 564 | "es6-iterator": "^2.0.3", 565 | "memoizee": "^0.4.15", 566 | "timers-ext": "^0.1.7" 567 | }, 568 | "engines": { 569 | "node": ">=0.10" 570 | } 571 | }, 572 | "node_modules/color-convert": { 573 | "version": "2.0.1", 574 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 575 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 576 | "dependencies": { 577 | "color-name": "~1.1.4" 578 | }, 579 | "engines": { 580 | "node": ">=7.0.0" 581 | } 582 | }, 583 | "node_modules/color-name": { 584 | "version": "1.1.4", 585 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 586 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 587 | }, 588 | "node_modules/combined-stream": { 589 | "version": "1.0.8", 590 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 591 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 592 | "dependencies": { 593 | "delayed-stream": "~1.0.0" 594 | }, 595 | "engines": { 596 | "node": ">= 0.8" 597 | } 598 | }, 599 | "node_modules/concat-map": { 600 | "version": "0.0.1", 601 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 602 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 603 | "dev": true 604 | }, 605 | "node_modules/confusing-browser-globals": { 606 | "version": "1.0.11", 607 | "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.11.tgz", 608 | "integrity": "sha512-JsPKdmh8ZkmnHxDk55FZ1TqVLvEQTvoByJZRN9jzI0UjxK/QgAmsphz7PGtqgPieQZ/CQcHWXCR7ATDNhGe+YA==", 609 | "dev": true 610 | }, 611 | "node_modules/cross-spawn": { 612 | "version": "7.0.5", 613 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.5.tgz", 614 | "integrity": "sha512-ZVJrKKYunU38/76t0RMOulHOnUcbU9GbpWKAOZ0mhjr7CX6FVrH+4FrAapSOekrgFQ3f/8gwMEuIft0aKq6Hug==", 615 | "dependencies": { 616 | "path-key": "^3.1.0", 617 | "shebang-command": "^2.0.0", 618 | "which": "^2.0.1" 619 | }, 620 | "engines": { 621 | "node": ">= 8" 622 | } 623 | }, 624 | "node_modules/d": { 625 | "version": "1.0.2", 626 | "resolved": "https://registry.npmjs.org/d/-/d-1.0.2.tgz", 627 | "integrity": "sha512-MOqHvMWF9/9MX6nza0KgvFH4HpMU0EF5uUDXqX/BtxtU8NfB0QzRtJ8Oe/6SuS4kbhyzVJwjd97EA4PKrzJ8bw==", 628 | "dependencies": { 629 | "es5-ext": "^0.10.64", 630 | "type": "^2.7.2" 631 | }, 632 | "engines": { 633 | "node": ">=0.12" 634 | } 635 | }, 636 | "node_modules/damerau-levenshtein": { 637 | "version": "1.0.8", 638 | "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz", 639 | "integrity": "sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA==", 640 | "dev": true, 641 | "peer": true 642 | }, 643 | "node_modules/data-view-buffer": { 644 | "version": "1.0.1", 645 | "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", 646 | "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", 647 | "dev": true, 648 | "dependencies": { 649 | "call-bind": "^1.0.6", 650 | "es-errors": "^1.3.0", 651 | "is-data-view": "^1.0.1" 652 | }, 653 | "engines": { 654 | "node": ">= 0.4" 655 | }, 656 | "funding": { 657 | "url": "https://github.com/sponsors/ljharb" 658 | } 659 | }, 660 | "node_modules/data-view-byte-length": { 661 | "version": "1.0.1", 662 | "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", 663 | "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", 664 | "dev": true, 665 | "dependencies": { 666 | "call-bind": "^1.0.7", 667 | "es-errors": "^1.3.0", 668 | "is-data-view": "^1.0.1" 669 | }, 670 | "engines": { 671 | "node": ">= 0.4" 672 | }, 673 | "funding": { 674 | "url": "https://github.com/sponsors/ljharb" 675 | } 676 | }, 677 | "node_modules/data-view-byte-offset": { 678 | "version": "1.0.0", 679 | "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", 680 | "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", 681 | "dev": true, 682 | "dependencies": { 683 | "call-bind": "^1.0.6", 684 | "es-errors": "^1.3.0", 685 | "is-data-view": "^1.0.1" 686 | }, 687 | "engines": { 688 | "node": ">= 0.4" 689 | }, 690 | "funding": { 691 | "url": "https://github.com/sponsors/ljharb" 692 | } 693 | }, 694 | "node_modules/debug": { 695 | "version": "4.3.7", 696 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", 697 | "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", 698 | "dev": true, 699 | "dependencies": { 700 | "ms": "^2.1.3" 701 | }, 702 | "engines": { 703 | "node": ">=6.0" 704 | }, 705 | "peerDependenciesMeta": { 706 | "supports-color": { 707 | "optional": true 708 | } 709 | } 710 | }, 711 | "node_modules/deep-is": { 712 | "version": "0.1.4", 713 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 714 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 715 | "dev": true 716 | }, 717 | "node_modules/define-data-property": { 718 | "version": "1.1.4", 719 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", 720 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", 721 | "dev": true, 722 | "dependencies": { 723 | "es-define-property": "^1.0.0", 724 | "es-errors": "^1.3.0", 725 | "gopd": "^1.0.1" 726 | }, 727 | "engines": { 728 | "node": ">= 0.4" 729 | }, 730 | "funding": { 731 | "url": "https://github.com/sponsors/ljharb" 732 | } 733 | }, 734 | "node_modules/define-properties": { 735 | "version": "1.2.1", 736 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", 737 | "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", 738 | "dev": true, 739 | "dependencies": { 740 | "define-data-property": "^1.0.1", 741 | "has-property-descriptors": "^1.0.0", 742 | "object-keys": "^1.1.1" 743 | }, 744 | "engines": { 745 | "node": ">= 0.4" 746 | }, 747 | "funding": { 748 | "url": "https://github.com/sponsors/ljharb" 749 | } 750 | }, 751 | "node_modules/delayed-stream": { 752 | "version": "1.0.0", 753 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 754 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 755 | "engines": { 756 | "node": ">=0.4.0" 757 | } 758 | }, 759 | "node_modules/doctrine": { 760 | "version": "3.0.0", 761 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 762 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 763 | "dev": true, 764 | "dependencies": { 765 | "esutils": "^2.0.2" 766 | }, 767 | "engines": { 768 | "node": ">=6.0.0" 769 | } 770 | }, 771 | "node_modules/eastasianwidth": { 772 | "version": "0.2.0", 773 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 774 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==" 775 | }, 776 | "node_modules/emoji-regex": { 777 | "version": "9.2.2", 778 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 779 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" 780 | }, 781 | "node_modules/es-abstract": { 782 | "version": "1.23.3", 783 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz", 784 | "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==", 785 | "dev": true, 786 | "dependencies": { 787 | "array-buffer-byte-length": "^1.0.1", 788 | "arraybuffer.prototype.slice": "^1.0.3", 789 | "available-typed-arrays": "^1.0.7", 790 | "call-bind": "^1.0.7", 791 | "data-view-buffer": "^1.0.1", 792 | "data-view-byte-length": "^1.0.1", 793 | "data-view-byte-offset": "^1.0.0", 794 | "es-define-property": "^1.0.0", 795 | "es-errors": "^1.3.0", 796 | "es-object-atoms": "^1.0.0", 797 | "es-set-tostringtag": "^2.0.3", 798 | "es-to-primitive": "^1.2.1", 799 | "function.prototype.name": "^1.1.6", 800 | "get-intrinsic": "^1.2.4", 801 | "get-symbol-description": "^1.0.2", 802 | "globalthis": "^1.0.3", 803 | "gopd": "^1.0.1", 804 | "has-property-descriptors": "^1.0.2", 805 | "has-proto": "^1.0.3", 806 | "has-symbols": "^1.0.3", 807 | "hasown": "^2.0.2", 808 | "internal-slot": "^1.0.7", 809 | "is-array-buffer": "^3.0.4", 810 | "is-callable": "^1.2.7", 811 | "is-data-view": "^1.0.1", 812 | "is-negative-zero": "^2.0.3", 813 | "is-regex": "^1.1.4", 814 | "is-shared-array-buffer": "^1.0.3", 815 | "is-string": "^1.0.7", 816 | "is-typed-array": "^1.1.13", 817 | "is-weakref": "^1.0.2", 818 | "object-inspect": "^1.13.1", 819 | "object-keys": "^1.1.1", 820 | "object.assign": "^4.1.5", 821 | "regexp.prototype.flags": "^1.5.2", 822 | "safe-array-concat": "^1.1.2", 823 | "safe-regex-test": "^1.0.3", 824 | "string.prototype.trim": "^1.2.9", 825 | "string.prototype.trimend": "^1.0.8", 826 | "string.prototype.trimstart": "^1.0.8", 827 | "typed-array-buffer": "^1.0.2", 828 | "typed-array-byte-length": "^1.0.1", 829 | "typed-array-byte-offset": "^1.0.2", 830 | "typed-array-length": "^1.0.6", 831 | "unbox-primitive": "^1.0.2", 832 | "which-typed-array": "^1.1.15" 833 | }, 834 | "engines": { 835 | "node": ">= 0.4" 836 | }, 837 | "funding": { 838 | "url": "https://github.com/sponsors/ljharb" 839 | } 840 | }, 841 | "node_modules/es-define-property": { 842 | "version": "1.0.0", 843 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", 844 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", 845 | "dev": true, 846 | "dependencies": { 847 | "get-intrinsic": "^1.2.4" 848 | }, 849 | "engines": { 850 | "node": ">= 0.4" 851 | } 852 | }, 853 | "node_modules/es-errors": { 854 | "version": "1.3.0", 855 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 856 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 857 | "dev": true, 858 | "engines": { 859 | "node": ">= 0.4" 860 | } 861 | }, 862 | "node_modules/es-iterator-helpers": { 863 | "version": "1.2.0", 864 | "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.2.0.tgz", 865 | "integrity": "sha512-tpxqxncxnpw3c93u8n3VOzACmRFoVmWJqbWXvX/JfKbkhBw1oslgPrUfeSt2psuqyEJFD6N/9lg5i7bsKpoq+Q==", 866 | "dev": true, 867 | "peer": true, 868 | "dependencies": { 869 | "call-bind": "^1.0.7", 870 | "define-properties": "^1.2.1", 871 | "es-abstract": "^1.23.3", 872 | "es-errors": "^1.3.0", 873 | "es-set-tostringtag": "^2.0.3", 874 | "function-bind": "^1.1.2", 875 | "get-intrinsic": "^1.2.4", 876 | "globalthis": "^1.0.4", 877 | "gopd": "^1.0.1", 878 | "has-property-descriptors": "^1.0.2", 879 | "has-proto": "^1.0.3", 880 | "has-symbols": "^1.0.3", 881 | "internal-slot": "^1.0.7", 882 | "iterator.prototype": "^1.1.3", 883 | "safe-array-concat": "^1.1.2" 884 | }, 885 | "engines": { 886 | "node": ">= 0.4" 887 | } 888 | }, 889 | "node_modules/es-object-atoms": { 890 | "version": "1.0.0", 891 | "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", 892 | "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", 893 | "dev": true, 894 | "dependencies": { 895 | "es-errors": "^1.3.0" 896 | }, 897 | "engines": { 898 | "node": ">= 0.4" 899 | } 900 | }, 901 | "node_modules/es-set-tostringtag": { 902 | "version": "2.0.3", 903 | "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", 904 | "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", 905 | "dev": true, 906 | "dependencies": { 907 | "get-intrinsic": "^1.2.4", 908 | "has-tostringtag": "^1.0.2", 909 | "hasown": "^2.0.1" 910 | }, 911 | "engines": { 912 | "node": ">= 0.4" 913 | } 914 | }, 915 | "node_modules/es-shim-unscopables": { 916 | "version": "1.0.2", 917 | "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", 918 | "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", 919 | "dev": true, 920 | "dependencies": { 921 | "hasown": "^2.0.0" 922 | } 923 | }, 924 | "node_modules/es-to-primitive": { 925 | "version": "1.2.1", 926 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 927 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 928 | "dev": true, 929 | "dependencies": { 930 | "is-callable": "^1.1.4", 931 | "is-date-object": "^1.0.1", 932 | "is-symbol": "^1.0.2" 933 | }, 934 | "engines": { 935 | "node": ">= 0.4" 936 | }, 937 | "funding": { 938 | "url": "https://github.com/sponsors/ljharb" 939 | } 940 | }, 941 | "node_modules/es5-ext": { 942 | "version": "0.10.64", 943 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.64.tgz", 944 | "integrity": "sha512-p2snDhiLaXe6dahss1LddxqEm+SkuDvV8dnIQG0MWjyHpcMNfXKPE+/Cc0y+PhxJX3A4xGNeFCj5oc0BUh6deg==", 945 | "hasInstallScript": true, 946 | "dependencies": { 947 | "es6-iterator": "^2.0.3", 948 | "es6-symbol": "^3.1.3", 949 | "esniff": "^2.0.1", 950 | "next-tick": "^1.1.0" 951 | }, 952 | "engines": { 953 | "node": ">=0.10" 954 | } 955 | }, 956 | "node_modules/es6-iterator": { 957 | "version": "2.0.3", 958 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 959 | "integrity": "sha512-zw4SRzoUkd+cl+ZoE15A9o1oQd920Bb0iOJMQkQhl3jNc03YqVjAhG7scf9C5KWRU/R13Orf588uCC6525o02g==", 960 | "dependencies": { 961 | "d": "1", 962 | "es5-ext": "^0.10.35", 963 | "es6-symbol": "^3.1.1" 964 | } 965 | }, 966 | "node_modules/es6-symbol": { 967 | "version": "3.1.4", 968 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.4.tgz", 969 | "integrity": "sha512-U9bFFjX8tFiATgtkJ1zg25+KviIXpgRvRHS8sau3GfhVzThRQrOeksPeT0BWW2MNZs1OEWJ1DPXOQMn0KKRkvg==", 970 | "dependencies": { 971 | "d": "^1.0.2", 972 | "ext": "^1.7.0" 973 | }, 974 | "engines": { 975 | "node": ">=0.12" 976 | } 977 | }, 978 | "node_modules/es6-weak-map": { 979 | "version": "2.0.3", 980 | "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.3.tgz", 981 | "integrity": "sha512-p5um32HOTO1kP+w7PRnB+5lQ43Z6muuMuIMffvDN8ZB4GcnjLBV6zGStpbASIMk4DCAvEaamhe2zhyCb/QXXsA==", 982 | "dependencies": { 983 | "d": "1", 984 | "es5-ext": "^0.10.46", 985 | "es6-iterator": "^2.0.3", 986 | "es6-symbol": "^3.1.1" 987 | } 988 | }, 989 | "node_modules/escape-string-regexp": { 990 | "version": "4.0.0", 991 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 992 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 993 | "dev": true, 994 | "engines": { 995 | "node": ">=10" 996 | }, 997 | "funding": { 998 | "url": "https://github.com/sponsors/sindresorhus" 999 | } 1000 | }, 1001 | "node_modules/eslint": { 1002 | "version": "8.57.1", 1003 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.1.tgz", 1004 | "integrity": "sha512-ypowyDxpVSYpkXr9WPv2PAZCtNip1Mv5KTW0SCurXv/9iOpcrH9PaqUElksqEB6pChqHGDRCFTyrZlGhnLNGiA==", 1005 | "deprecated": "This version is no longer supported. Please see https://eslint.org/version-support for other options.", 1006 | "dev": true, 1007 | "dependencies": { 1008 | "@eslint-community/eslint-utils": "^4.2.0", 1009 | "@eslint-community/regexpp": "^4.6.1", 1010 | "@eslint/eslintrc": "^2.1.4", 1011 | "@eslint/js": "8.57.1", 1012 | "@humanwhocodes/config-array": "^0.13.0", 1013 | "@humanwhocodes/module-importer": "^1.0.1", 1014 | "@nodelib/fs.walk": "^1.2.8", 1015 | "@ungap/structured-clone": "^1.2.0", 1016 | "ajv": "^6.12.4", 1017 | "chalk": "^4.0.0", 1018 | "cross-spawn": "^7.0.2", 1019 | "debug": "^4.3.2", 1020 | "doctrine": "^3.0.0", 1021 | "escape-string-regexp": "^4.0.0", 1022 | "eslint-scope": "^7.2.2", 1023 | "eslint-visitor-keys": "^3.4.3", 1024 | "espree": "^9.6.1", 1025 | "esquery": "^1.4.2", 1026 | "esutils": "^2.0.2", 1027 | "fast-deep-equal": "^3.1.3", 1028 | "file-entry-cache": "^6.0.1", 1029 | "find-up": "^5.0.0", 1030 | "glob-parent": "^6.0.2", 1031 | "globals": "^13.19.0", 1032 | "graphemer": "^1.4.0", 1033 | "ignore": "^5.2.0", 1034 | "imurmurhash": "^0.1.4", 1035 | "is-glob": "^4.0.0", 1036 | "is-path-inside": "^3.0.3", 1037 | "js-yaml": "^4.1.0", 1038 | "json-stable-stringify-without-jsonify": "^1.0.1", 1039 | "levn": "^0.4.1", 1040 | "lodash.merge": "^4.6.2", 1041 | "minimatch": "^3.1.2", 1042 | "natural-compare": "^1.4.0", 1043 | "optionator": "^0.9.3", 1044 | "strip-ansi": "^6.0.1", 1045 | "text-table": "^0.2.0" 1046 | }, 1047 | "bin": { 1048 | "eslint": "bin/eslint.js" 1049 | }, 1050 | "engines": { 1051 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1052 | }, 1053 | "funding": { 1054 | "url": "https://opencollective.com/eslint" 1055 | } 1056 | }, 1057 | "node_modules/eslint-config-airbnb": { 1058 | "version": "19.0.4", 1059 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb/-/eslint-config-airbnb-19.0.4.tgz", 1060 | "integrity": "sha512-T75QYQVQX57jiNgpF9r1KegMICE94VYwoFQyMGhrvc+lB8YF2E/M/PYDaQe1AJcWaEgqLE+ErXV1Og/+6Vyzew==", 1061 | "dev": true, 1062 | "dependencies": { 1063 | "eslint-config-airbnb-base": "^15.0.0", 1064 | "object.assign": "^4.1.2", 1065 | "object.entries": "^1.1.5" 1066 | }, 1067 | "engines": { 1068 | "node": "^10.12.0 || ^12.22.0 || ^14.17.0 || >=16.0.0" 1069 | }, 1070 | "peerDependencies": { 1071 | "eslint": "^7.32.0 || ^8.2.0", 1072 | "eslint-plugin-import": "^2.25.3", 1073 | "eslint-plugin-jsx-a11y": "^6.5.1", 1074 | "eslint-plugin-react": "^7.28.0", 1075 | "eslint-plugin-react-hooks": "^4.3.0" 1076 | } 1077 | }, 1078 | "node_modules/eslint-config-airbnb-base": { 1079 | "version": "15.0.0", 1080 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-15.0.0.tgz", 1081 | "integrity": "sha512-xaX3z4ZZIcFLvh2oUNvcX5oEofXda7giYmuplVxoOg5A7EXJMrUyqRgR+mhDhPK8LZ4PttFOBvCYDbX3sUoUig==", 1082 | "dev": true, 1083 | "dependencies": { 1084 | "confusing-browser-globals": "^1.0.10", 1085 | "object.assign": "^4.1.2", 1086 | "object.entries": "^1.1.5", 1087 | "semver": "^6.3.0" 1088 | }, 1089 | "engines": { 1090 | "node": "^10.12.0 || >=12.0.0" 1091 | }, 1092 | "peerDependencies": { 1093 | "eslint": "^7.32.0 || ^8.2.0", 1094 | "eslint-plugin-import": "^2.25.2" 1095 | } 1096 | }, 1097 | "node_modules/eslint-import-resolver-node": { 1098 | "version": "0.3.9", 1099 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz", 1100 | "integrity": "sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g==", 1101 | "dev": true, 1102 | "dependencies": { 1103 | "debug": "^3.2.7", 1104 | "is-core-module": "^2.13.0", 1105 | "resolve": "^1.22.4" 1106 | } 1107 | }, 1108 | "node_modules/eslint-import-resolver-node/node_modules/debug": { 1109 | "version": "3.2.7", 1110 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1111 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1112 | "dev": true, 1113 | "dependencies": { 1114 | "ms": "^2.1.1" 1115 | } 1116 | }, 1117 | "node_modules/eslint-module-utils": { 1118 | "version": "2.12.0", 1119 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.12.0.tgz", 1120 | "integrity": "sha512-wALZ0HFoytlyh/1+4wuZ9FJCD/leWHQzzrxJ8+rebyReSLk7LApMyd3WJaLVoN+D5+WIdJyDK1c6JnE65V4Zyg==", 1121 | "dev": true, 1122 | "dependencies": { 1123 | "debug": "^3.2.7" 1124 | }, 1125 | "engines": { 1126 | "node": ">=4" 1127 | }, 1128 | "peerDependenciesMeta": { 1129 | "eslint": { 1130 | "optional": true 1131 | } 1132 | } 1133 | }, 1134 | "node_modules/eslint-module-utils/node_modules/debug": { 1135 | "version": "3.2.7", 1136 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1137 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1138 | "dev": true, 1139 | "dependencies": { 1140 | "ms": "^2.1.1" 1141 | } 1142 | }, 1143 | "node_modules/eslint-plugin-import": { 1144 | "version": "2.31.0", 1145 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.31.0.tgz", 1146 | "integrity": "sha512-ixmkI62Rbc2/w8Vfxyh1jQRTdRTF52VxwRVHl/ykPAmqG+Nb7/kNn+byLP0LxPgI7zWA16Jt82SybJInmMia3A==", 1147 | "dev": true, 1148 | "dependencies": { 1149 | "@rtsao/scc": "^1.1.0", 1150 | "array-includes": "^3.1.8", 1151 | "array.prototype.findlastindex": "^1.2.5", 1152 | "array.prototype.flat": "^1.3.2", 1153 | "array.prototype.flatmap": "^1.3.2", 1154 | "debug": "^3.2.7", 1155 | "doctrine": "^2.1.0", 1156 | "eslint-import-resolver-node": "^0.3.9", 1157 | "eslint-module-utils": "^2.12.0", 1158 | "hasown": "^2.0.2", 1159 | "is-core-module": "^2.15.1", 1160 | "is-glob": "^4.0.3", 1161 | "minimatch": "^3.1.2", 1162 | "object.fromentries": "^2.0.8", 1163 | "object.groupby": "^1.0.3", 1164 | "object.values": "^1.2.0", 1165 | "semver": "^6.3.1", 1166 | "string.prototype.trimend": "^1.0.8", 1167 | "tsconfig-paths": "^3.15.0" 1168 | }, 1169 | "engines": { 1170 | "node": ">=4" 1171 | }, 1172 | "peerDependencies": { 1173 | "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8 || ^9" 1174 | } 1175 | }, 1176 | "node_modules/eslint-plugin-import/node_modules/debug": { 1177 | "version": "3.2.7", 1178 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1179 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1180 | "dev": true, 1181 | "dependencies": { 1182 | "ms": "^2.1.1" 1183 | } 1184 | }, 1185 | "node_modules/eslint-plugin-import/node_modules/doctrine": { 1186 | "version": "2.1.0", 1187 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1188 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1189 | "dev": true, 1190 | "dependencies": { 1191 | "esutils": "^2.0.2" 1192 | }, 1193 | "engines": { 1194 | "node": ">=0.10.0" 1195 | } 1196 | }, 1197 | "node_modules/eslint-plugin-jsx-a11y": { 1198 | "version": "6.10.2", 1199 | "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.10.2.tgz", 1200 | "integrity": "sha512-scB3nz4WmG75pV8+3eRUQOHZlNSUhFNq37xnpgRkCCELU3XMvXAxLk1eqWWyE22Ki4Q01Fnsw9BA3cJHDPgn2Q==", 1201 | "dev": true, 1202 | "peer": true, 1203 | "dependencies": { 1204 | "aria-query": "^5.3.2", 1205 | "array-includes": "^3.1.8", 1206 | "array.prototype.flatmap": "^1.3.2", 1207 | "ast-types-flow": "^0.0.8", 1208 | "axe-core": "^4.10.0", 1209 | "axobject-query": "^4.1.0", 1210 | "damerau-levenshtein": "^1.0.8", 1211 | "emoji-regex": "^9.2.2", 1212 | "hasown": "^2.0.2", 1213 | "jsx-ast-utils": "^3.3.5", 1214 | "language-tags": "^1.0.9", 1215 | "minimatch": "^3.1.2", 1216 | "object.fromentries": "^2.0.8", 1217 | "safe-regex-test": "^1.0.3", 1218 | "string.prototype.includes": "^2.0.1" 1219 | }, 1220 | "engines": { 1221 | "node": ">=4.0" 1222 | }, 1223 | "peerDependencies": { 1224 | "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8 || ^9" 1225 | } 1226 | }, 1227 | "node_modules/eslint-plugin-react": { 1228 | "version": "7.37.2", 1229 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.37.2.tgz", 1230 | "integrity": "sha512-EsTAnj9fLVr/GZleBLFbj/sSuXeWmp1eXIN60ceYnZveqEaUCyW4X+Vh4WTdUhCkW4xutXYqTXCUSyqD4rB75w==", 1231 | "dev": true, 1232 | "peer": true, 1233 | "dependencies": { 1234 | "array-includes": "^3.1.8", 1235 | "array.prototype.findlast": "^1.2.5", 1236 | "array.prototype.flatmap": "^1.3.2", 1237 | "array.prototype.tosorted": "^1.1.4", 1238 | "doctrine": "^2.1.0", 1239 | "es-iterator-helpers": "^1.1.0", 1240 | "estraverse": "^5.3.0", 1241 | "hasown": "^2.0.2", 1242 | "jsx-ast-utils": "^2.4.1 || ^3.0.0", 1243 | "minimatch": "^3.1.2", 1244 | "object.entries": "^1.1.8", 1245 | "object.fromentries": "^2.0.8", 1246 | "object.values": "^1.2.0", 1247 | "prop-types": "^15.8.1", 1248 | "resolve": "^2.0.0-next.5", 1249 | "semver": "^6.3.1", 1250 | "string.prototype.matchall": "^4.0.11", 1251 | "string.prototype.repeat": "^1.0.0" 1252 | }, 1253 | "engines": { 1254 | "node": ">=4" 1255 | }, 1256 | "peerDependencies": { 1257 | "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8 || ^9.7" 1258 | } 1259 | }, 1260 | "node_modules/eslint-plugin-react-hooks": { 1261 | "version": "4.6.2", 1262 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.2.tgz", 1263 | "integrity": "sha512-QzliNJq4GinDBcD8gPB5v0wh6g8q3SUi6EFF0x8N/BL9PoVs0atuGc47ozMRyOWAKdwaZ5OnbOEa3WR+dSGKuQ==", 1264 | "dev": true, 1265 | "peer": true, 1266 | "engines": { 1267 | "node": ">=10" 1268 | }, 1269 | "peerDependencies": { 1270 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" 1271 | } 1272 | }, 1273 | "node_modules/eslint-plugin-react/node_modules/doctrine": { 1274 | "version": "2.1.0", 1275 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1276 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1277 | "dev": true, 1278 | "peer": true, 1279 | "dependencies": { 1280 | "esutils": "^2.0.2" 1281 | }, 1282 | "engines": { 1283 | "node": ">=0.10.0" 1284 | } 1285 | }, 1286 | "node_modules/eslint-plugin-react/node_modules/resolve": { 1287 | "version": "2.0.0-next.5", 1288 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz", 1289 | "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==", 1290 | "dev": true, 1291 | "peer": true, 1292 | "dependencies": { 1293 | "is-core-module": "^2.13.0", 1294 | "path-parse": "^1.0.7", 1295 | "supports-preserve-symlinks-flag": "^1.0.0" 1296 | }, 1297 | "bin": { 1298 | "resolve": "bin/resolve" 1299 | }, 1300 | "funding": { 1301 | "url": "https://github.com/sponsors/ljharb" 1302 | } 1303 | }, 1304 | "node_modules/eslint-scope": { 1305 | "version": "7.2.2", 1306 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 1307 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 1308 | "dev": true, 1309 | "dependencies": { 1310 | "esrecurse": "^4.3.0", 1311 | "estraverse": "^5.2.0" 1312 | }, 1313 | "engines": { 1314 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1315 | }, 1316 | "funding": { 1317 | "url": "https://opencollective.com/eslint" 1318 | } 1319 | }, 1320 | "node_modules/eslint-visitor-keys": { 1321 | "version": "3.4.3", 1322 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 1323 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 1324 | "dev": true, 1325 | "engines": { 1326 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1327 | }, 1328 | "funding": { 1329 | "url": "https://opencollective.com/eslint" 1330 | } 1331 | }, 1332 | "node_modules/esniff": { 1333 | "version": "2.0.1", 1334 | "resolved": "https://registry.npmjs.org/esniff/-/esniff-2.0.1.tgz", 1335 | "integrity": "sha512-kTUIGKQ/mDPFoJ0oVfcmyJn4iBDRptjNVIzwIFR7tqWXdVI9xfA2RMwY/gbSpJG3lkdWNEjLap/NqVHZiJsdfg==", 1336 | "dependencies": { 1337 | "d": "^1.0.1", 1338 | "es5-ext": "^0.10.62", 1339 | "event-emitter": "^0.3.5", 1340 | "type": "^2.7.2" 1341 | }, 1342 | "engines": { 1343 | "node": ">=0.10" 1344 | } 1345 | }, 1346 | "node_modules/espree": { 1347 | "version": "9.6.1", 1348 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 1349 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 1350 | "dev": true, 1351 | "dependencies": { 1352 | "acorn": "^8.9.0", 1353 | "acorn-jsx": "^5.3.2", 1354 | "eslint-visitor-keys": "^3.4.1" 1355 | }, 1356 | "engines": { 1357 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1358 | }, 1359 | "funding": { 1360 | "url": "https://opencollective.com/eslint" 1361 | } 1362 | }, 1363 | "node_modules/esquery": { 1364 | "version": "1.6.0", 1365 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", 1366 | "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", 1367 | "dev": true, 1368 | "dependencies": { 1369 | "estraverse": "^5.1.0" 1370 | }, 1371 | "engines": { 1372 | "node": ">=0.10" 1373 | } 1374 | }, 1375 | "node_modules/esrecurse": { 1376 | "version": "4.3.0", 1377 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1378 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1379 | "dev": true, 1380 | "dependencies": { 1381 | "estraverse": "^5.2.0" 1382 | }, 1383 | "engines": { 1384 | "node": ">=4.0" 1385 | } 1386 | }, 1387 | "node_modules/estraverse": { 1388 | "version": "5.3.0", 1389 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1390 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1391 | "dev": true, 1392 | "engines": { 1393 | "node": ">=4.0" 1394 | } 1395 | }, 1396 | "node_modules/esutils": { 1397 | "version": "2.0.3", 1398 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1399 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1400 | "dev": true, 1401 | "engines": { 1402 | "node": ">=0.10.0" 1403 | } 1404 | }, 1405 | "node_modules/event-emitter": { 1406 | "version": "0.3.5", 1407 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 1408 | "integrity": "sha512-D9rRn9y7kLPnJ+hMq7S/nhvoKwwvVJahBi2BPmx3bvbsEdK3W9ii8cBSGjP+72/LnM4n6fo3+dkCX5FeTQruXA==", 1409 | "dependencies": { 1410 | "d": "1", 1411 | "es5-ext": "~0.10.14" 1412 | } 1413 | }, 1414 | "node_modules/ext": { 1415 | "version": "1.7.0", 1416 | "resolved": "https://registry.npmjs.org/ext/-/ext-1.7.0.tgz", 1417 | "integrity": "sha512-6hxeJYaL110a9b5TEJSj0gojyHQAmA2ch5Os+ySCiA1QGdS697XWY1pzsrSjqA9LDEEgdB/KypIlR59RcLuHYw==", 1418 | "dependencies": { 1419 | "type": "^2.7.2" 1420 | } 1421 | }, 1422 | "node_modules/fast-deep-equal": { 1423 | "version": "3.1.3", 1424 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1425 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1426 | "dev": true 1427 | }, 1428 | "node_modules/fast-json-stable-stringify": { 1429 | "version": "2.1.0", 1430 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1431 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1432 | "dev": true 1433 | }, 1434 | "node_modules/fast-levenshtein": { 1435 | "version": "2.0.6", 1436 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1437 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1438 | "dev": true 1439 | }, 1440 | "node_modules/fastq": { 1441 | "version": "1.17.1", 1442 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 1443 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 1444 | "dev": true, 1445 | "dependencies": { 1446 | "reusify": "^1.0.4" 1447 | } 1448 | }, 1449 | "node_modules/file-entry-cache": { 1450 | "version": "6.0.1", 1451 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1452 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1453 | "dev": true, 1454 | "dependencies": { 1455 | "flat-cache": "^3.0.4" 1456 | }, 1457 | "engines": { 1458 | "node": "^10.12.0 || >=12.0.0" 1459 | } 1460 | }, 1461 | "node_modules/find-up": { 1462 | "version": "5.0.0", 1463 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1464 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1465 | "dev": true, 1466 | "dependencies": { 1467 | "locate-path": "^6.0.0", 1468 | "path-exists": "^4.0.0" 1469 | }, 1470 | "engines": { 1471 | "node": ">=10" 1472 | }, 1473 | "funding": { 1474 | "url": "https://github.com/sponsors/sindresorhus" 1475 | } 1476 | }, 1477 | "node_modules/flat-cache": { 1478 | "version": "3.2.0", 1479 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 1480 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 1481 | "dev": true, 1482 | "dependencies": { 1483 | "flatted": "^3.2.9", 1484 | "keyv": "^4.5.3", 1485 | "rimraf": "^3.0.2" 1486 | }, 1487 | "engines": { 1488 | "node": "^10.12.0 || >=12.0.0" 1489 | } 1490 | }, 1491 | "node_modules/flatted": { 1492 | "version": "3.3.1", 1493 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 1494 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 1495 | "dev": true 1496 | }, 1497 | "node_modules/follow-redirects": { 1498 | "version": "1.15.9", 1499 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", 1500 | "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", 1501 | "funding": [ 1502 | { 1503 | "type": "individual", 1504 | "url": "https://github.com/sponsors/RubenVerborgh" 1505 | } 1506 | ], 1507 | "engines": { 1508 | "node": ">=4.0" 1509 | }, 1510 | "peerDependenciesMeta": { 1511 | "debug": { 1512 | "optional": true 1513 | } 1514 | } 1515 | }, 1516 | "node_modules/for-each": { 1517 | "version": "0.3.3", 1518 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 1519 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 1520 | "dev": true, 1521 | "dependencies": { 1522 | "is-callable": "^1.1.3" 1523 | } 1524 | }, 1525 | "node_modules/foreground-child": { 1526 | "version": "3.3.0", 1527 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.0.tgz", 1528 | "integrity": "sha512-Ld2g8rrAyMYFXBhEqMz8ZAHBi4J4uS1i/CxGMDnjyFWddMXLVcDp051DZfu+t7+ab7Wv6SMqpWmyFIj5UbfFvg==", 1529 | "dependencies": { 1530 | "cross-spawn": "^7.0.0", 1531 | "signal-exit": "^4.0.1" 1532 | }, 1533 | "engines": { 1534 | "node": ">=14" 1535 | }, 1536 | "funding": { 1537 | "url": "https://github.com/sponsors/isaacs" 1538 | } 1539 | }, 1540 | "node_modules/form-data": { 1541 | "version": "4.0.1", 1542 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz", 1543 | "integrity": "sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==", 1544 | "dependencies": { 1545 | "asynckit": "^0.4.0", 1546 | "combined-stream": "^1.0.8", 1547 | "mime-types": "^2.1.12" 1548 | }, 1549 | "engines": { 1550 | "node": ">= 6" 1551 | } 1552 | }, 1553 | "node_modules/fs-extra": { 1554 | "version": "11.2.0", 1555 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.2.0.tgz", 1556 | "integrity": "sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==", 1557 | "dependencies": { 1558 | "graceful-fs": "^4.2.0", 1559 | "jsonfile": "^6.0.1", 1560 | "universalify": "^2.0.0" 1561 | }, 1562 | "engines": { 1563 | "node": ">=14.14" 1564 | } 1565 | }, 1566 | "node_modules/fs.realpath": { 1567 | "version": "1.0.0", 1568 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1569 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1570 | "dev": true 1571 | }, 1572 | "node_modules/function-bind": { 1573 | "version": "1.1.2", 1574 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 1575 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 1576 | "dev": true, 1577 | "funding": { 1578 | "url": "https://github.com/sponsors/ljharb" 1579 | } 1580 | }, 1581 | "node_modules/function.prototype.name": { 1582 | "version": "1.1.6", 1583 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", 1584 | "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", 1585 | "dev": true, 1586 | "dependencies": { 1587 | "call-bind": "^1.0.2", 1588 | "define-properties": "^1.2.0", 1589 | "es-abstract": "^1.22.1", 1590 | "functions-have-names": "^1.2.3" 1591 | }, 1592 | "engines": { 1593 | "node": ">= 0.4" 1594 | }, 1595 | "funding": { 1596 | "url": "https://github.com/sponsors/ljharb" 1597 | } 1598 | }, 1599 | "node_modules/functions-have-names": { 1600 | "version": "1.2.3", 1601 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", 1602 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", 1603 | "dev": true, 1604 | "funding": { 1605 | "url": "https://github.com/sponsors/ljharb" 1606 | } 1607 | }, 1608 | "node_modules/get-intrinsic": { 1609 | "version": "1.2.4", 1610 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", 1611 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", 1612 | "dev": true, 1613 | "dependencies": { 1614 | "es-errors": "^1.3.0", 1615 | "function-bind": "^1.1.2", 1616 | "has-proto": "^1.0.1", 1617 | "has-symbols": "^1.0.3", 1618 | "hasown": "^2.0.0" 1619 | }, 1620 | "engines": { 1621 | "node": ">= 0.4" 1622 | }, 1623 | "funding": { 1624 | "url": "https://github.com/sponsors/ljharb" 1625 | } 1626 | }, 1627 | "node_modules/get-symbol-description": { 1628 | "version": "1.0.2", 1629 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", 1630 | "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", 1631 | "dev": true, 1632 | "dependencies": { 1633 | "call-bind": "^1.0.5", 1634 | "es-errors": "^1.3.0", 1635 | "get-intrinsic": "^1.2.4" 1636 | }, 1637 | "engines": { 1638 | "node": ">= 0.4" 1639 | }, 1640 | "funding": { 1641 | "url": "https://github.com/sponsors/ljharb" 1642 | } 1643 | }, 1644 | "node_modules/glob": { 1645 | "version": "11.0.0", 1646 | "resolved": "https://registry.npmjs.org/glob/-/glob-11.0.0.tgz", 1647 | "integrity": "sha512-9UiX/Bl6J2yaBbxKoEBRm4Cipxgok8kQYcOPEhScPwebu2I0HoQOuYdIO6S3hLuWoZgpDpwQZMzTFxgpkyT76g==", 1648 | "dependencies": { 1649 | "foreground-child": "^3.1.0", 1650 | "jackspeak": "^4.0.1", 1651 | "minimatch": "^10.0.0", 1652 | "minipass": "^7.1.2", 1653 | "package-json-from-dist": "^1.0.0", 1654 | "path-scurry": "^2.0.0" 1655 | }, 1656 | "bin": { 1657 | "glob": "dist/esm/bin.mjs" 1658 | }, 1659 | "engines": { 1660 | "node": "20 || >=22" 1661 | }, 1662 | "funding": { 1663 | "url": "https://github.com/sponsors/isaacs" 1664 | } 1665 | }, 1666 | "node_modules/glob-parent": { 1667 | "version": "6.0.2", 1668 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1669 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1670 | "dev": true, 1671 | "dependencies": { 1672 | "is-glob": "^4.0.3" 1673 | }, 1674 | "engines": { 1675 | "node": ">=10.13.0" 1676 | } 1677 | }, 1678 | "node_modules/glob/node_modules/brace-expansion": { 1679 | "version": "2.0.1", 1680 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1681 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1682 | "dependencies": { 1683 | "balanced-match": "^1.0.0" 1684 | } 1685 | }, 1686 | "node_modules/glob/node_modules/minimatch": { 1687 | "version": "10.0.1", 1688 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.0.1.tgz", 1689 | "integrity": "sha512-ethXTt3SGGR+95gudmqJ1eNhRO7eGEGIgYA9vnPatK4/etz2MEVDno5GMCibdMTuBMyElzIlgxMna3K94XDIDQ==", 1690 | "dependencies": { 1691 | "brace-expansion": "^2.0.1" 1692 | }, 1693 | "engines": { 1694 | "node": "20 || >=22" 1695 | }, 1696 | "funding": { 1697 | "url": "https://github.com/sponsors/isaacs" 1698 | } 1699 | }, 1700 | "node_modules/globals": { 1701 | "version": "13.24.0", 1702 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 1703 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 1704 | "dev": true, 1705 | "dependencies": { 1706 | "type-fest": "^0.20.2" 1707 | }, 1708 | "engines": { 1709 | "node": ">=8" 1710 | }, 1711 | "funding": { 1712 | "url": "https://github.com/sponsors/sindresorhus" 1713 | } 1714 | }, 1715 | "node_modules/globalthis": { 1716 | "version": "1.0.4", 1717 | "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz", 1718 | "integrity": "sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==", 1719 | "dev": true, 1720 | "dependencies": { 1721 | "define-properties": "^1.2.1", 1722 | "gopd": "^1.0.1" 1723 | }, 1724 | "engines": { 1725 | "node": ">= 0.4" 1726 | }, 1727 | "funding": { 1728 | "url": "https://github.com/sponsors/ljharb" 1729 | } 1730 | }, 1731 | "node_modules/gopd": { 1732 | "version": "1.0.1", 1733 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 1734 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 1735 | "dev": true, 1736 | "dependencies": { 1737 | "get-intrinsic": "^1.1.3" 1738 | }, 1739 | "funding": { 1740 | "url": "https://github.com/sponsors/ljharb" 1741 | } 1742 | }, 1743 | "node_modules/graceful-fs": { 1744 | "version": "4.2.11", 1745 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1746 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 1747 | }, 1748 | "node_modules/graphemer": { 1749 | "version": "1.4.0", 1750 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 1751 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 1752 | "dev": true 1753 | }, 1754 | "node_modules/has-bigints": { 1755 | "version": "1.0.2", 1756 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", 1757 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", 1758 | "dev": true, 1759 | "funding": { 1760 | "url": "https://github.com/sponsors/ljharb" 1761 | } 1762 | }, 1763 | "node_modules/has-flag": { 1764 | "version": "4.0.0", 1765 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1766 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1767 | "dev": true, 1768 | "engines": { 1769 | "node": ">=8" 1770 | } 1771 | }, 1772 | "node_modules/has-property-descriptors": { 1773 | "version": "1.0.2", 1774 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", 1775 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", 1776 | "dev": true, 1777 | "dependencies": { 1778 | "es-define-property": "^1.0.0" 1779 | }, 1780 | "funding": { 1781 | "url": "https://github.com/sponsors/ljharb" 1782 | } 1783 | }, 1784 | "node_modules/has-proto": { 1785 | "version": "1.0.3", 1786 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", 1787 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", 1788 | "dev": true, 1789 | "engines": { 1790 | "node": ">= 0.4" 1791 | }, 1792 | "funding": { 1793 | "url": "https://github.com/sponsors/ljharb" 1794 | } 1795 | }, 1796 | "node_modules/has-symbols": { 1797 | "version": "1.0.3", 1798 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 1799 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 1800 | "dev": true, 1801 | "engines": { 1802 | "node": ">= 0.4" 1803 | }, 1804 | "funding": { 1805 | "url": "https://github.com/sponsors/ljharb" 1806 | } 1807 | }, 1808 | "node_modules/has-tostringtag": { 1809 | "version": "1.0.2", 1810 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", 1811 | "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", 1812 | "dev": true, 1813 | "dependencies": { 1814 | "has-symbols": "^1.0.3" 1815 | }, 1816 | "engines": { 1817 | "node": ">= 0.4" 1818 | }, 1819 | "funding": { 1820 | "url": "https://github.com/sponsors/ljharb" 1821 | } 1822 | }, 1823 | "node_modules/hasown": { 1824 | "version": "2.0.2", 1825 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 1826 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 1827 | "dev": true, 1828 | "dependencies": { 1829 | "function-bind": "^1.1.2" 1830 | }, 1831 | "engines": { 1832 | "node": ">= 0.4" 1833 | } 1834 | }, 1835 | "node_modules/ignore": { 1836 | "version": "5.3.2", 1837 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", 1838 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", 1839 | "dev": true, 1840 | "engines": { 1841 | "node": ">= 4" 1842 | } 1843 | }, 1844 | "node_modules/import-fresh": { 1845 | "version": "3.3.0", 1846 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1847 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1848 | "dev": true, 1849 | "dependencies": { 1850 | "parent-module": "^1.0.0", 1851 | "resolve-from": "^4.0.0" 1852 | }, 1853 | "engines": { 1854 | "node": ">=6" 1855 | }, 1856 | "funding": { 1857 | "url": "https://github.com/sponsors/sindresorhus" 1858 | } 1859 | }, 1860 | "node_modules/imurmurhash": { 1861 | "version": "0.1.4", 1862 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1863 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1864 | "dev": true, 1865 | "engines": { 1866 | "node": ">=0.8.19" 1867 | } 1868 | }, 1869 | "node_modules/inflight": { 1870 | "version": "1.0.6", 1871 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1872 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1873 | "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", 1874 | "dev": true, 1875 | "dependencies": { 1876 | "once": "^1.3.0", 1877 | "wrappy": "1" 1878 | } 1879 | }, 1880 | "node_modules/inherits": { 1881 | "version": "2.0.4", 1882 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1883 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1884 | "dev": true 1885 | }, 1886 | "node_modules/ini": { 1887 | "version": "5.0.0", 1888 | "resolved": "https://registry.npmjs.org/ini/-/ini-5.0.0.tgz", 1889 | "integrity": "sha512-+N0ngpO3e7cRUWOJAS7qw0IZIVc6XPrW4MlFBdD066F2L4k1L6ker3hLqSq7iXxU5tgS4WGkIUElWn5vogAEnw==", 1890 | "engines": { 1891 | "node": "^18.17.0 || >=20.5.0" 1892 | } 1893 | }, 1894 | "node_modules/internal-slot": { 1895 | "version": "1.0.7", 1896 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", 1897 | "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", 1898 | "dev": true, 1899 | "dependencies": { 1900 | "es-errors": "^1.3.0", 1901 | "hasown": "^2.0.0", 1902 | "side-channel": "^1.0.4" 1903 | }, 1904 | "engines": { 1905 | "node": ">= 0.4" 1906 | } 1907 | }, 1908 | "node_modules/is-array-buffer": { 1909 | "version": "3.0.4", 1910 | "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", 1911 | "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", 1912 | "dev": true, 1913 | "dependencies": { 1914 | "call-bind": "^1.0.2", 1915 | "get-intrinsic": "^1.2.1" 1916 | }, 1917 | "engines": { 1918 | "node": ">= 0.4" 1919 | }, 1920 | "funding": { 1921 | "url": "https://github.com/sponsors/ljharb" 1922 | } 1923 | }, 1924 | "node_modules/is-async-function": { 1925 | "version": "2.0.0", 1926 | "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz", 1927 | "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==", 1928 | "dev": true, 1929 | "peer": true, 1930 | "dependencies": { 1931 | "has-tostringtag": "^1.0.0" 1932 | }, 1933 | "engines": { 1934 | "node": ">= 0.4" 1935 | }, 1936 | "funding": { 1937 | "url": "https://github.com/sponsors/ljharb" 1938 | } 1939 | }, 1940 | "node_modules/is-bigint": { 1941 | "version": "1.0.4", 1942 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 1943 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 1944 | "dev": true, 1945 | "dependencies": { 1946 | "has-bigints": "^1.0.1" 1947 | }, 1948 | "funding": { 1949 | "url": "https://github.com/sponsors/ljharb" 1950 | } 1951 | }, 1952 | "node_modules/is-boolean-object": { 1953 | "version": "1.1.2", 1954 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 1955 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 1956 | "dev": true, 1957 | "dependencies": { 1958 | "call-bind": "^1.0.2", 1959 | "has-tostringtag": "^1.0.0" 1960 | }, 1961 | "engines": { 1962 | "node": ">= 0.4" 1963 | }, 1964 | "funding": { 1965 | "url": "https://github.com/sponsors/ljharb" 1966 | } 1967 | }, 1968 | "node_modules/is-callable": { 1969 | "version": "1.2.7", 1970 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 1971 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 1972 | "dev": true, 1973 | "engines": { 1974 | "node": ">= 0.4" 1975 | }, 1976 | "funding": { 1977 | "url": "https://github.com/sponsors/ljharb" 1978 | } 1979 | }, 1980 | "node_modules/is-core-module": { 1981 | "version": "2.15.1", 1982 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz", 1983 | "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==", 1984 | "dev": true, 1985 | "dependencies": { 1986 | "hasown": "^2.0.2" 1987 | }, 1988 | "engines": { 1989 | "node": ">= 0.4" 1990 | }, 1991 | "funding": { 1992 | "url": "https://github.com/sponsors/ljharb" 1993 | } 1994 | }, 1995 | "node_modules/is-data-view": { 1996 | "version": "1.0.1", 1997 | "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", 1998 | "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", 1999 | "dev": true, 2000 | "dependencies": { 2001 | "is-typed-array": "^1.1.13" 2002 | }, 2003 | "engines": { 2004 | "node": ">= 0.4" 2005 | }, 2006 | "funding": { 2007 | "url": "https://github.com/sponsors/ljharb" 2008 | } 2009 | }, 2010 | "node_modules/is-date-object": { 2011 | "version": "1.0.5", 2012 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 2013 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 2014 | "dev": true, 2015 | "dependencies": { 2016 | "has-tostringtag": "^1.0.0" 2017 | }, 2018 | "engines": { 2019 | "node": ">= 0.4" 2020 | }, 2021 | "funding": { 2022 | "url": "https://github.com/sponsors/ljharb" 2023 | } 2024 | }, 2025 | "node_modules/is-extglob": { 2026 | "version": "2.1.1", 2027 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2028 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2029 | "dev": true, 2030 | "engines": { 2031 | "node": ">=0.10.0" 2032 | } 2033 | }, 2034 | "node_modules/is-finalizationregistry": { 2035 | "version": "1.0.2", 2036 | "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz", 2037 | "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==", 2038 | "dev": true, 2039 | "peer": true, 2040 | "dependencies": { 2041 | "call-bind": "^1.0.2" 2042 | }, 2043 | "funding": { 2044 | "url": "https://github.com/sponsors/ljharb" 2045 | } 2046 | }, 2047 | "node_modules/is-fullwidth-code-point": { 2048 | "version": "3.0.0", 2049 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2050 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2051 | "engines": { 2052 | "node": ">=8" 2053 | } 2054 | }, 2055 | "node_modules/is-generator-function": { 2056 | "version": "1.0.10", 2057 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", 2058 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", 2059 | "dev": true, 2060 | "peer": true, 2061 | "dependencies": { 2062 | "has-tostringtag": "^1.0.0" 2063 | }, 2064 | "engines": { 2065 | "node": ">= 0.4" 2066 | }, 2067 | "funding": { 2068 | "url": "https://github.com/sponsors/ljharb" 2069 | } 2070 | }, 2071 | "node_modules/is-glob": { 2072 | "version": "4.0.3", 2073 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2074 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2075 | "dev": true, 2076 | "dependencies": { 2077 | "is-extglob": "^2.1.1" 2078 | }, 2079 | "engines": { 2080 | "node": ">=0.10.0" 2081 | } 2082 | }, 2083 | "node_modules/is-map": { 2084 | "version": "2.0.3", 2085 | "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.3.tgz", 2086 | "integrity": "sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw==", 2087 | "dev": true, 2088 | "peer": true, 2089 | "engines": { 2090 | "node": ">= 0.4" 2091 | }, 2092 | "funding": { 2093 | "url": "https://github.com/sponsors/ljharb" 2094 | } 2095 | }, 2096 | "node_modules/is-negative-zero": { 2097 | "version": "2.0.3", 2098 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", 2099 | "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", 2100 | "dev": true, 2101 | "engines": { 2102 | "node": ">= 0.4" 2103 | }, 2104 | "funding": { 2105 | "url": "https://github.com/sponsors/ljharb" 2106 | } 2107 | }, 2108 | "node_modules/is-number-object": { 2109 | "version": "1.0.7", 2110 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 2111 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 2112 | "dev": true, 2113 | "dependencies": { 2114 | "has-tostringtag": "^1.0.0" 2115 | }, 2116 | "engines": { 2117 | "node": ">= 0.4" 2118 | }, 2119 | "funding": { 2120 | "url": "https://github.com/sponsors/ljharb" 2121 | } 2122 | }, 2123 | "node_modules/is-path-inside": { 2124 | "version": "3.0.3", 2125 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2126 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2127 | "dev": true, 2128 | "engines": { 2129 | "node": ">=8" 2130 | } 2131 | }, 2132 | "node_modules/is-promise": { 2133 | "version": "2.2.2", 2134 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.2.2.tgz", 2135 | "integrity": "sha512-+lP4/6lKUBfQjZ2pdxThZvLUAafmZb8OAxFb8XXtiQmS35INgr85hdOGoEs124ez1FCnZJt6jau/T+alh58QFQ==" 2136 | }, 2137 | "node_modules/is-regex": { 2138 | "version": "1.1.4", 2139 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 2140 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 2141 | "dev": true, 2142 | "dependencies": { 2143 | "call-bind": "^1.0.2", 2144 | "has-tostringtag": "^1.0.0" 2145 | }, 2146 | "engines": { 2147 | "node": ">= 0.4" 2148 | }, 2149 | "funding": { 2150 | "url": "https://github.com/sponsors/ljharb" 2151 | } 2152 | }, 2153 | "node_modules/is-set": { 2154 | "version": "2.0.3", 2155 | "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.3.tgz", 2156 | "integrity": "sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg==", 2157 | "dev": true, 2158 | "peer": true, 2159 | "engines": { 2160 | "node": ">= 0.4" 2161 | }, 2162 | "funding": { 2163 | "url": "https://github.com/sponsors/ljharb" 2164 | } 2165 | }, 2166 | "node_modules/is-shared-array-buffer": { 2167 | "version": "1.0.3", 2168 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", 2169 | "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", 2170 | "dev": true, 2171 | "dependencies": { 2172 | "call-bind": "^1.0.7" 2173 | }, 2174 | "engines": { 2175 | "node": ">= 0.4" 2176 | }, 2177 | "funding": { 2178 | "url": "https://github.com/sponsors/ljharb" 2179 | } 2180 | }, 2181 | "node_modules/is-string": { 2182 | "version": "1.0.7", 2183 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 2184 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 2185 | "dev": true, 2186 | "dependencies": { 2187 | "has-tostringtag": "^1.0.0" 2188 | }, 2189 | "engines": { 2190 | "node": ">= 0.4" 2191 | }, 2192 | "funding": { 2193 | "url": "https://github.com/sponsors/ljharb" 2194 | } 2195 | }, 2196 | "node_modules/is-symbol": { 2197 | "version": "1.0.4", 2198 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 2199 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 2200 | "dev": true, 2201 | "dependencies": { 2202 | "has-symbols": "^1.0.2" 2203 | }, 2204 | "engines": { 2205 | "node": ">= 0.4" 2206 | }, 2207 | "funding": { 2208 | "url": "https://github.com/sponsors/ljharb" 2209 | } 2210 | }, 2211 | "node_modules/is-typed-array": { 2212 | "version": "1.1.13", 2213 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", 2214 | "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", 2215 | "dev": true, 2216 | "dependencies": { 2217 | "which-typed-array": "^1.1.14" 2218 | }, 2219 | "engines": { 2220 | "node": ">= 0.4" 2221 | }, 2222 | "funding": { 2223 | "url": "https://github.com/sponsors/ljharb" 2224 | } 2225 | }, 2226 | "node_modules/is-weakmap": { 2227 | "version": "2.0.2", 2228 | "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.2.tgz", 2229 | "integrity": "sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w==", 2230 | "dev": true, 2231 | "peer": true, 2232 | "engines": { 2233 | "node": ">= 0.4" 2234 | }, 2235 | "funding": { 2236 | "url": "https://github.com/sponsors/ljharb" 2237 | } 2238 | }, 2239 | "node_modules/is-weakref": { 2240 | "version": "1.0.2", 2241 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 2242 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 2243 | "dev": true, 2244 | "dependencies": { 2245 | "call-bind": "^1.0.2" 2246 | }, 2247 | "funding": { 2248 | "url": "https://github.com/sponsors/ljharb" 2249 | } 2250 | }, 2251 | "node_modules/is-weakset": { 2252 | "version": "2.0.3", 2253 | "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.3.tgz", 2254 | "integrity": "sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ==", 2255 | "dev": true, 2256 | "peer": true, 2257 | "dependencies": { 2258 | "call-bind": "^1.0.7", 2259 | "get-intrinsic": "^1.2.4" 2260 | }, 2261 | "engines": { 2262 | "node": ">= 0.4" 2263 | }, 2264 | "funding": { 2265 | "url": "https://github.com/sponsors/ljharb" 2266 | } 2267 | }, 2268 | "node_modules/isarray": { 2269 | "version": "2.0.5", 2270 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", 2271 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", 2272 | "dev": true 2273 | }, 2274 | "node_modules/isexe": { 2275 | "version": "2.0.0", 2276 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2277 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" 2278 | }, 2279 | "node_modules/iterator.prototype": { 2280 | "version": "1.1.3", 2281 | "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.3.tgz", 2282 | "integrity": "sha512-FW5iMbeQ6rBGm/oKgzq2aW4KvAGpxPzYES8N4g4xNXUKpL1mclMvOe+76AcLDTvD+Ze+sOpVhgdAQEKF4L9iGQ==", 2283 | "dev": true, 2284 | "peer": true, 2285 | "dependencies": { 2286 | "define-properties": "^1.2.1", 2287 | "get-intrinsic": "^1.2.1", 2288 | "has-symbols": "^1.0.3", 2289 | "reflect.getprototypeof": "^1.0.4", 2290 | "set-function-name": "^2.0.1" 2291 | }, 2292 | "engines": { 2293 | "node": ">= 0.4" 2294 | } 2295 | }, 2296 | "node_modules/jackspeak": { 2297 | "version": "4.0.2", 2298 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-4.0.2.tgz", 2299 | "integrity": "sha512-bZsjR/iRjl1Nk1UkjGpAzLNfQtzuijhn2g+pbZb98HQ1Gk8vM9hfbxeMBP+M2/UUdwj0RqGG3mlvk2MsAqwvEw==", 2300 | "dependencies": { 2301 | "@isaacs/cliui": "^8.0.2" 2302 | }, 2303 | "engines": { 2304 | "node": "20 || >=22" 2305 | }, 2306 | "funding": { 2307 | "url": "https://github.com/sponsors/isaacs" 2308 | } 2309 | }, 2310 | "node_modules/js-tokens": { 2311 | "version": "4.0.0", 2312 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2313 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2314 | "dev": true, 2315 | "peer": true 2316 | }, 2317 | "node_modules/js-yaml": { 2318 | "version": "4.1.0", 2319 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2320 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2321 | "dev": true, 2322 | "dependencies": { 2323 | "argparse": "^2.0.1" 2324 | }, 2325 | "bin": { 2326 | "js-yaml": "bin/js-yaml.js" 2327 | } 2328 | }, 2329 | "node_modules/json-buffer": { 2330 | "version": "3.0.1", 2331 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2332 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2333 | "dev": true 2334 | }, 2335 | "node_modules/json-schema-traverse": { 2336 | "version": "0.4.1", 2337 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2338 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2339 | "dev": true 2340 | }, 2341 | "node_modules/json-stable-stringify-without-jsonify": { 2342 | "version": "1.0.1", 2343 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2344 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2345 | "dev": true 2346 | }, 2347 | "node_modules/json5": { 2348 | "version": "1.0.2", 2349 | "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", 2350 | "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", 2351 | "dev": true, 2352 | "dependencies": { 2353 | "minimist": "^1.2.0" 2354 | }, 2355 | "bin": { 2356 | "json5": "lib/cli.js" 2357 | } 2358 | }, 2359 | "node_modules/jsonfile": { 2360 | "version": "6.1.0", 2361 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", 2362 | "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", 2363 | "dependencies": { 2364 | "universalify": "^2.0.0" 2365 | }, 2366 | "optionalDependencies": { 2367 | "graceful-fs": "^4.1.6" 2368 | } 2369 | }, 2370 | "node_modules/jsx-ast-utils": { 2371 | "version": "3.3.5", 2372 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz", 2373 | "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==", 2374 | "dev": true, 2375 | "peer": true, 2376 | "dependencies": { 2377 | "array-includes": "^3.1.6", 2378 | "array.prototype.flat": "^1.3.1", 2379 | "object.assign": "^4.1.4", 2380 | "object.values": "^1.1.6" 2381 | }, 2382 | "engines": { 2383 | "node": ">=4.0" 2384 | } 2385 | }, 2386 | "node_modules/keyv": { 2387 | "version": "4.5.4", 2388 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2389 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2390 | "dev": true, 2391 | "dependencies": { 2392 | "json-buffer": "3.0.1" 2393 | } 2394 | }, 2395 | "node_modules/language-subtag-registry": { 2396 | "version": "0.3.23", 2397 | "resolved": "https://registry.npmjs.org/language-subtag-registry/-/language-subtag-registry-0.3.23.tgz", 2398 | "integrity": "sha512-0K65Lea881pHotoGEa5gDlMxt3pctLi2RplBb7Ezh4rRdLEOtgi7n4EwK9lamnUCkKBqaeKRVebTq6BAxSkpXQ==", 2399 | "dev": true, 2400 | "peer": true 2401 | }, 2402 | "node_modules/language-tags": { 2403 | "version": "1.0.9", 2404 | "resolved": "https://registry.npmjs.org/language-tags/-/language-tags-1.0.9.tgz", 2405 | "integrity": "sha512-MbjN408fEndfiQXbFQ1vnd+1NoLDsnQW41410oQBXiyXDMYH5z505juWa4KUE1LqxRC7DgOgZDbKLxHIwm27hA==", 2406 | "dev": true, 2407 | "peer": true, 2408 | "dependencies": { 2409 | "language-subtag-registry": "^0.3.20" 2410 | }, 2411 | "engines": { 2412 | "node": ">=0.10" 2413 | } 2414 | }, 2415 | "node_modules/levn": { 2416 | "version": "0.4.1", 2417 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2418 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2419 | "dev": true, 2420 | "dependencies": { 2421 | "prelude-ls": "^1.2.1", 2422 | "type-check": "~0.4.0" 2423 | }, 2424 | "engines": { 2425 | "node": ">= 0.8.0" 2426 | } 2427 | }, 2428 | "node_modules/locate-path": { 2429 | "version": "6.0.0", 2430 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2431 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2432 | "dev": true, 2433 | "dependencies": { 2434 | "p-locate": "^5.0.0" 2435 | }, 2436 | "engines": { 2437 | "node": ">=10" 2438 | }, 2439 | "funding": { 2440 | "url": "https://github.com/sponsors/sindresorhus" 2441 | } 2442 | }, 2443 | "node_modules/lodash": { 2444 | "version": "4.17.21", 2445 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2446 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 2447 | }, 2448 | "node_modules/lodash.merge": { 2449 | "version": "4.6.2", 2450 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2451 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2452 | "dev": true 2453 | }, 2454 | "node_modules/loose-envify": { 2455 | "version": "1.4.0", 2456 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 2457 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 2458 | "dev": true, 2459 | "peer": true, 2460 | "dependencies": { 2461 | "js-tokens": "^3.0.0 || ^4.0.0" 2462 | }, 2463 | "bin": { 2464 | "loose-envify": "cli.js" 2465 | } 2466 | }, 2467 | "node_modules/lru-cache": { 2468 | "version": "11.0.2", 2469 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-11.0.2.tgz", 2470 | "integrity": "sha512-123qHRfJBmo2jXDbo/a5YOQrJoHF/GNQTLzQ5+IdK5pWpceK17yRc6ozlWd25FxvGKQbIUs91fDFkXmDHTKcyA==", 2471 | "engines": { 2472 | "node": "20 || >=22" 2473 | } 2474 | }, 2475 | "node_modules/lru-queue": { 2476 | "version": "0.1.0", 2477 | "resolved": "https://registry.npmjs.org/lru-queue/-/lru-queue-0.1.0.tgz", 2478 | "integrity": "sha512-BpdYkt9EvGl8OfWHDQPISVpcl5xZthb+XPsbELj5AQXxIC8IriDZIQYjBJPEm5rS420sjZ0TLEzRcq5KdBhYrQ==", 2479 | "dependencies": { 2480 | "es5-ext": "~0.10.2" 2481 | } 2482 | }, 2483 | "node_modules/memoizee": { 2484 | "version": "0.4.17", 2485 | "resolved": "https://registry.npmjs.org/memoizee/-/memoizee-0.4.17.tgz", 2486 | "integrity": "sha512-DGqD7Hjpi/1or4F/aYAspXKNm5Yili0QDAFAY4QYvpqpgiY6+1jOfqpmByzjxbWd/T9mChbCArXAbDAsTm5oXA==", 2487 | "dependencies": { 2488 | "d": "^1.0.2", 2489 | "es5-ext": "^0.10.64", 2490 | "es6-weak-map": "^2.0.3", 2491 | "event-emitter": "^0.3.5", 2492 | "is-promise": "^2.2.2", 2493 | "lru-queue": "^0.1.0", 2494 | "next-tick": "^1.1.0", 2495 | "timers-ext": "^0.1.7" 2496 | }, 2497 | "engines": { 2498 | "node": ">=0.12" 2499 | } 2500 | }, 2501 | "node_modules/mime-db": { 2502 | "version": "1.52.0", 2503 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2504 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 2505 | "engines": { 2506 | "node": ">= 0.6" 2507 | } 2508 | }, 2509 | "node_modules/mime-types": { 2510 | "version": "2.1.35", 2511 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2512 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2513 | "dependencies": { 2514 | "mime-db": "1.52.0" 2515 | }, 2516 | "engines": { 2517 | "node": ">= 0.6" 2518 | } 2519 | }, 2520 | "node_modules/minimatch": { 2521 | "version": "3.1.2", 2522 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2523 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2524 | "dev": true, 2525 | "dependencies": { 2526 | "brace-expansion": "^1.1.7" 2527 | }, 2528 | "engines": { 2529 | "node": "*" 2530 | } 2531 | }, 2532 | "node_modules/minimist": { 2533 | "version": "1.2.8", 2534 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2535 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 2536 | "dev": true, 2537 | "funding": { 2538 | "url": "https://github.com/sponsors/ljharb" 2539 | } 2540 | }, 2541 | "node_modules/minipass": { 2542 | "version": "7.1.2", 2543 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", 2544 | "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", 2545 | "engines": { 2546 | "node": ">=16 || 14 >=14.17" 2547 | } 2548 | }, 2549 | "node_modules/moment": { 2550 | "version": "2.30.1", 2551 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.30.1.tgz", 2552 | "integrity": "sha512-uEmtNhbDOrWPFS+hdjFCBfy9f2YoyzRpwcl+DqpC6taX21FzsTLQVbMV/W7PzNSX6x/bhC1zA3c2UQ5NzH6how==", 2553 | "engines": { 2554 | "node": "*" 2555 | } 2556 | }, 2557 | "node_modules/ms": { 2558 | "version": "2.1.3", 2559 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2560 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2561 | "dev": true 2562 | }, 2563 | "node_modules/natural-compare": { 2564 | "version": "1.4.0", 2565 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2566 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2567 | "dev": true 2568 | }, 2569 | "node_modules/next-tick": { 2570 | "version": "1.1.0", 2571 | "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.1.0.tgz", 2572 | "integrity": "sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ==" 2573 | }, 2574 | "node_modules/object-assign": { 2575 | "version": "4.1.1", 2576 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2577 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 2578 | "dev": true, 2579 | "peer": true, 2580 | "engines": { 2581 | "node": ">=0.10.0" 2582 | } 2583 | }, 2584 | "node_modules/object-inspect": { 2585 | "version": "1.13.3", 2586 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.3.tgz", 2587 | "integrity": "sha512-kDCGIbxkDSXE3euJZZXzc6to7fCrKHNI/hSRQnRuQ+BWjFNzZwiFF8fj/6o2t2G9/jTj8PSIYTfCLelLZEeRpA==", 2588 | "dev": true, 2589 | "engines": { 2590 | "node": ">= 0.4" 2591 | }, 2592 | "funding": { 2593 | "url": "https://github.com/sponsors/ljharb" 2594 | } 2595 | }, 2596 | "node_modules/object-keys": { 2597 | "version": "1.1.1", 2598 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2599 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2600 | "dev": true, 2601 | "engines": { 2602 | "node": ">= 0.4" 2603 | } 2604 | }, 2605 | "node_modules/object.assign": { 2606 | "version": "4.1.5", 2607 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", 2608 | "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", 2609 | "dev": true, 2610 | "dependencies": { 2611 | "call-bind": "^1.0.5", 2612 | "define-properties": "^1.2.1", 2613 | "has-symbols": "^1.0.3", 2614 | "object-keys": "^1.1.1" 2615 | }, 2616 | "engines": { 2617 | "node": ">= 0.4" 2618 | }, 2619 | "funding": { 2620 | "url": "https://github.com/sponsors/ljharb" 2621 | } 2622 | }, 2623 | "node_modules/object.entries": { 2624 | "version": "1.1.8", 2625 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz", 2626 | "integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==", 2627 | "dev": true, 2628 | "dependencies": { 2629 | "call-bind": "^1.0.7", 2630 | "define-properties": "^1.2.1", 2631 | "es-object-atoms": "^1.0.0" 2632 | }, 2633 | "engines": { 2634 | "node": ">= 0.4" 2635 | } 2636 | }, 2637 | "node_modules/object.fromentries": { 2638 | "version": "2.0.8", 2639 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz", 2640 | "integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==", 2641 | "dev": true, 2642 | "dependencies": { 2643 | "call-bind": "^1.0.7", 2644 | "define-properties": "^1.2.1", 2645 | "es-abstract": "^1.23.2", 2646 | "es-object-atoms": "^1.0.0" 2647 | }, 2648 | "engines": { 2649 | "node": ">= 0.4" 2650 | }, 2651 | "funding": { 2652 | "url": "https://github.com/sponsors/ljharb" 2653 | } 2654 | }, 2655 | "node_modules/object.groupby": { 2656 | "version": "1.0.3", 2657 | "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.3.tgz", 2658 | "integrity": "sha512-+Lhy3TQTuzXI5hevh8sBGqbmurHbbIjAi0Z4S63nthVLmLxfbj4T54a4CfZrXIrt9iP4mVAPYMo/v99taj3wjQ==", 2659 | "dev": true, 2660 | "dependencies": { 2661 | "call-bind": "^1.0.7", 2662 | "define-properties": "^1.2.1", 2663 | "es-abstract": "^1.23.2" 2664 | }, 2665 | "engines": { 2666 | "node": ">= 0.4" 2667 | } 2668 | }, 2669 | "node_modules/object.values": { 2670 | "version": "1.2.0", 2671 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz", 2672 | "integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==", 2673 | "dev": true, 2674 | "dependencies": { 2675 | "call-bind": "^1.0.7", 2676 | "define-properties": "^1.2.1", 2677 | "es-object-atoms": "^1.0.0" 2678 | }, 2679 | "engines": { 2680 | "node": ">= 0.4" 2681 | }, 2682 | "funding": { 2683 | "url": "https://github.com/sponsors/ljharb" 2684 | } 2685 | }, 2686 | "node_modules/once": { 2687 | "version": "1.4.0", 2688 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2689 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2690 | "dev": true, 2691 | "dependencies": { 2692 | "wrappy": "1" 2693 | } 2694 | }, 2695 | "node_modules/optionator": { 2696 | "version": "0.9.4", 2697 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", 2698 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", 2699 | "dev": true, 2700 | "dependencies": { 2701 | "deep-is": "^0.1.3", 2702 | "fast-levenshtein": "^2.0.6", 2703 | "levn": "^0.4.1", 2704 | "prelude-ls": "^1.2.1", 2705 | "type-check": "^0.4.0", 2706 | "word-wrap": "^1.2.5" 2707 | }, 2708 | "engines": { 2709 | "node": ">= 0.8.0" 2710 | } 2711 | }, 2712 | "node_modules/p-limit": { 2713 | "version": "3.1.0", 2714 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2715 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2716 | "dev": true, 2717 | "dependencies": { 2718 | "yocto-queue": "^0.1.0" 2719 | }, 2720 | "engines": { 2721 | "node": ">=10" 2722 | }, 2723 | "funding": { 2724 | "url": "https://github.com/sponsors/sindresorhus" 2725 | } 2726 | }, 2727 | "node_modules/p-locate": { 2728 | "version": "5.0.0", 2729 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2730 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2731 | "dev": true, 2732 | "dependencies": { 2733 | "p-limit": "^3.0.2" 2734 | }, 2735 | "engines": { 2736 | "node": ">=10" 2737 | }, 2738 | "funding": { 2739 | "url": "https://github.com/sponsors/sindresorhus" 2740 | } 2741 | }, 2742 | "node_modules/package-json-from-dist": { 2743 | "version": "1.0.1", 2744 | "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.1.tgz", 2745 | "integrity": "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==" 2746 | }, 2747 | "node_modules/parent-module": { 2748 | "version": "1.0.1", 2749 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2750 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2751 | "dev": true, 2752 | "dependencies": { 2753 | "callsites": "^3.0.0" 2754 | }, 2755 | "engines": { 2756 | "node": ">=6" 2757 | } 2758 | }, 2759 | "node_modules/path-exists": { 2760 | "version": "4.0.0", 2761 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2762 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2763 | "dev": true, 2764 | "engines": { 2765 | "node": ">=8" 2766 | } 2767 | }, 2768 | "node_modules/path-is-absolute": { 2769 | "version": "1.0.1", 2770 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2771 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2772 | "dev": true, 2773 | "engines": { 2774 | "node": ">=0.10.0" 2775 | } 2776 | }, 2777 | "node_modules/path-key": { 2778 | "version": "3.1.1", 2779 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2780 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2781 | "engines": { 2782 | "node": ">=8" 2783 | } 2784 | }, 2785 | "node_modules/path-parse": { 2786 | "version": "1.0.7", 2787 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2788 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2789 | "dev": true 2790 | }, 2791 | "node_modules/path-scurry": { 2792 | "version": "2.0.0", 2793 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-2.0.0.tgz", 2794 | "integrity": "sha512-ypGJsmGtdXUOeM5u93TyeIEfEhM6s+ljAhrk5vAvSx8uyY/02OvrZnA0YNGUrPXfpJMgI1ODd3nwz8Npx4O4cg==", 2795 | "dependencies": { 2796 | "lru-cache": "^11.0.0", 2797 | "minipass": "^7.1.2" 2798 | }, 2799 | "engines": { 2800 | "node": "20 || >=22" 2801 | }, 2802 | "funding": { 2803 | "url": "https://github.com/sponsors/isaacs" 2804 | } 2805 | }, 2806 | "node_modules/possible-typed-array-names": { 2807 | "version": "1.0.0", 2808 | "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", 2809 | "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", 2810 | "dev": true, 2811 | "engines": { 2812 | "node": ">= 0.4" 2813 | } 2814 | }, 2815 | "node_modules/prelude-ls": { 2816 | "version": "1.2.1", 2817 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2818 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2819 | "dev": true, 2820 | "engines": { 2821 | "node": ">= 0.8.0" 2822 | } 2823 | }, 2824 | "node_modules/prop-types": { 2825 | "version": "15.8.1", 2826 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", 2827 | "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", 2828 | "dev": true, 2829 | "peer": true, 2830 | "dependencies": { 2831 | "loose-envify": "^1.4.0", 2832 | "object-assign": "^4.1.1", 2833 | "react-is": "^16.13.1" 2834 | } 2835 | }, 2836 | "node_modules/proxy-from-env": { 2837 | "version": "1.1.0", 2838 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 2839 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 2840 | }, 2841 | "node_modules/punycode": { 2842 | "version": "2.3.1", 2843 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2844 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2845 | "dev": true, 2846 | "engines": { 2847 | "node": ">=6" 2848 | } 2849 | }, 2850 | "node_modules/queue-microtask": { 2851 | "version": "1.2.3", 2852 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2853 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2854 | "dev": true, 2855 | "funding": [ 2856 | { 2857 | "type": "github", 2858 | "url": "https://github.com/sponsors/feross" 2859 | }, 2860 | { 2861 | "type": "patreon", 2862 | "url": "https://www.patreon.com/feross" 2863 | }, 2864 | { 2865 | "type": "consulting", 2866 | "url": "https://feross.org/support" 2867 | } 2868 | ] 2869 | }, 2870 | "node_modules/react-is": { 2871 | "version": "16.13.1", 2872 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 2873 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", 2874 | "dev": true, 2875 | "peer": true 2876 | }, 2877 | "node_modules/reflect.getprototypeof": { 2878 | "version": "1.0.6", 2879 | "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.6.tgz", 2880 | "integrity": "sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg==", 2881 | "dev": true, 2882 | "peer": true, 2883 | "dependencies": { 2884 | "call-bind": "^1.0.7", 2885 | "define-properties": "^1.2.1", 2886 | "es-abstract": "^1.23.1", 2887 | "es-errors": "^1.3.0", 2888 | "get-intrinsic": "^1.2.4", 2889 | "globalthis": "^1.0.3", 2890 | "which-builtin-type": "^1.1.3" 2891 | }, 2892 | "engines": { 2893 | "node": ">= 0.4" 2894 | }, 2895 | "funding": { 2896 | "url": "https://github.com/sponsors/ljharb" 2897 | } 2898 | }, 2899 | "node_modules/regexp.prototype.flags": { 2900 | "version": "1.5.3", 2901 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.3.tgz", 2902 | "integrity": "sha512-vqlC04+RQoFalODCbCumG2xIOvapzVMHwsyIGM/SIE8fRhFFsXeH8/QQ+s0T0kDAhKc4k30s73/0ydkHQz6HlQ==", 2903 | "dev": true, 2904 | "dependencies": { 2905 | "call-bind": "^1.0.7", 2906 | "define-properties": "^1.2.1", 2907 | "es-errors": "^1.3.0", 2908 | "set-function-name": "^2.0.2" 2909 | }, 2910 | "engines": { 2911 | "node": ">= 0.4" 2912 | }, 2913 | "funding": { 2914 | "url": "https://github.com/sponsors/ljharb" 2915 | } 2916 | }, 2917 | "node_modules/resolve": { 2918 | "version": "1.22.8", 2919 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 2920 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 2921 | "dev": true, 2922 | "dependencies": { 2923 | "is-core-module": "^2.13.0", 2924 | "path-parse": "^1.0.7", 2925 | "supports-preserve-symlinks-flag": "^1.0.0" 2926 | }, 2927 | "bin": { 2928 | "resolve": "bin/resolve" 2929 | }, 2930 | "funding": { 2931 | "url": "https://github.com/sponsors/ljharb" 2932 | } 2933 | }, 2934 | "node_modules/resolve-from": { 2935 | "version": "4.0.0", 2936 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2937 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2938 | "dev": true, 2939 | "engines": { 2940 | "node": ">=4" 2941 | } 2942 | }, 2943 | "node_modules/reusify": { 2944 | "version": "1.0.4", 2945 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2946 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2947 | "dev": true, 2948 | "engines": { 2949 | "iojs": ">=1.0.0", 2950 | "node": ">=0.10.0" 2951 | } 2952 | }, 2953 | "node_modules/rimraf": { 2954 | "version": "3.0.2", 2955 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2956 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2957 | "deprecated": "Rimraf versions prior to v4 are no longer supported", 2958 | "dev": true, 2959 | "dependencies": { 2960 | "glob": "^7.1.3" 2961 | }, 2962 | "bin": { 2963 | "rimraf": "bin.js" 2964 | }, 2965 | "funding": { 2966 | "url": "https://github.com/sponsors/isaacs" 2967 | } 2968 | }, 2969 | "node_modules/rimraf/node_modules/glob": { 2970 | "version": "7.2.3", 2971 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2972 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2973 | "deprecated": "Glob versions prior to v9 are no longer supported", 2974 | "dev": true, 2975 | "dependencies": { 2976 | "fs.realpath": "^1.0.0", 2977 | "inflight": "^1.0.4", 2978 | "inherits": "2", 2979 | "minimatch": "^3.1.1", 2980 | "once": "^1.3.0", 2981 | "path-is-absolute": "^1.0.0" 2982 | }, 2983 | "engines": { 2984 | "node": "*" 2985 | }, 2986 | "funding": { 2987 | "url": "https://github.com/sponsors/isaacs" 2988 | } 2989 | }, 2990 | "node_modules/run-parallel": { 2991 | "version": "1.2.0", 2992 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2993 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2994 | "dev": true, 2995 | "funding": [ 2996 | { 2997 | "type": "github", 2998 | "url": "https://github.com/sponsors/feross" 2999 | }, 3000 | { 3001 | "type": "patreon", 3002 | "url": "https://www.patreon.com/feross" 3003 | }, 3004 | { 3005 | "type": "consulting", 3006 | "url": "https://feross.org/support" 3007 | } 3008 | ], 3009 | "dependencies": { 3010 | "queue-microtask": "^1.2.2" 3011 | } 3012 | }, 3013 | "node_modules/safe-array-concat": { 3014 | "version": "1.1.2", 3015 | "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", 3016 | "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", 3017 | "dev": true, 3018 | "dependencies": { 3019 | "call-bind": "^1.0.7", 3020 | "get-intrinsic": "^1.2.4", 3021 | "has-symbols": "^1.0.3", 3022 | "isarray": "^2.0.5" 3023 | }, 3024 | "engines": { 3025 | "node": ">=0.4" 3026 | }, 3027 | "funding": { 3028 | "url": "https://github.com/sponsors/ljharb" 3029 | } 3030 | }, 3031 | "node_modules/safe-regex-test": { 3032 | "version": "1.0.3", 3033 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", 3034 | "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", 3035 | "dev": true, 3036 | "dependencies": { 3037 | "call-bind": "^1.0.6", 3038 | "es-errors": "^1.3.0", 3039 | "is-regex": "^1.1.4" 3040 | }, 3041 | "engines": { 3042 | "node": ">= 0.4" 3043 | }, 3044 | "funding": { 3045 | "url": "https://github.com/sponsors/ljharb" 3046 | } 3047 | }, 3048 | "node_modules/semver": { 3049 | "version": "6.3.1", 3050 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 3051 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 3052 | "dev": true, 3053 | "bin": { 3054 | "semver": "bin/semver.js" 3055 | } 3056 | }, 3057 | "node_modules/set-function-length": { 3058 | "version": "1.2.2", 3059 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", 3060 | "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", 3061 | "dev": true, 3062 | "dependencies": { 3063 | "define-data-property": "^1.1.4", 3064 | "es-errors": "^1.3.0", 3065 | "function-bind": "^1.1.2", 3066 | "get-intrinsic": "^1.2.4", 3067 | "gopd": "^1.0.1", 3068 | "has-property-descriptors": "^1.0.2" 3069 | }, 3070 | "engines": { 3071 | "node": ">= 0.4" 3072 | } 3073 | }, 3074 | "node_modules/set-function-name": { 3075 | "version": "2.0.2", 3076 | "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", 3077 | "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", 3078 | "dev": true, 3079 | "dependencies": { 3080 | "define-data-property": "^1.1.4", 3081 | "es-errors": "^1.3.0", 3082 | "functions-have-names": "^1.2.3", 3083 | "has-property-descriptors": "^1.0.2" 3084 | }, 3085 | "engines": { 3086 | "node": ">= 0.4" 3087 | } 3088 | }, 3089 | "node_modules/shebang-command": { 3090 | "version": "2.0.0", 3091 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3092 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3093 | "dependencies": { 3094 | "shebang-regex": "^3.0.0" 3095 | }, 3096 | "engines": { 3097 | "node": ">=8" 3098 | } 3099 | }, 3100 | "node_modules/shebang-regex": { 3101 | "version": "3.0.0", 3102 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3103 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3104 | "engines": { 3105 | "node": ">=8" 3106 | } 3107 | }, 3108 | "node_modules/side-channel": { 3109 | "version": "1.0.6", 3110 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", 3111 | "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", 3112 | "dev": true, 3113 | "dependencies": { 3114 | "call-bind": "^1.0.7", 3115 | "es-errors": "^1.3.0", 3116 | "get-intrinsic": "^1.2.4", 3117 | "object-inspect": "^1.13.1" 3118 | }, 3119 | "engines": { 3120 | "node": ">= 0.4" 3121 | }, 3122 | "funding": { 3123 | "url": "https://github.com/sponsors/ljharb" 3124 | } 3125 | }, 3126 | "node_modules/signal-exit": { 3127 | "version": "4.1.0", 3128 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 3129 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 3130 | "engines": { 3131 | "node": ">=14" 3132 | }, 3133 | "funding": { 3134 | "url": "https://github.com/sponsors/isaacs" 3135 | } 3136 | }, 3137 | "node_modules/string-width": { 3138 | "version": "5.1.2", 3139 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", 3140 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", 3141 | "dependencies": { 3142 | "eastasianwidth": "^0.2.0", 3143 | "emoji-regex": "^9.2.2", 3144 | "strip-ansi": "^7.0.1" 3145 | }, 3146 | "engines": { 3147 | "node": ">=12" 3148 | }, 3149 | "funding": { 3150 | "url": "https://github.com/sponsors/sindresorhus" 3151 | } 3152 | }, 3153 | "node_modules/string-width-cjs": { 3154 | "name": "string-width", 3155 | "version": "4.2.3", 3156 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3157 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3158 | "dependencies": { 3159 | "emoji-regex": "^8.0.0", 3160 | "is-fullwidth-code-point": "^3.0.0", 3161 | "strip-ansi": "^6.0.1" 3162 | }, 3163 | "engines": { 3164 | "node": ">=8" 3165 | } 3166 | }, 3167 | "node_modules/string-width-cjs/node_modules/emoji-regex": { 3168 | "version": "8.0.0", 3169 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3170 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 3171 | }, 3172 | "node_modules/string-width/node_modules/ansi-regex": { 3173 | "version": "6.1.0", 3174 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", 3175 | "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", 3176 | "engines": { 3177 | "node": ">=12" 3178 | }, 3179 | "funding": { 3180 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 3181 | } 3182 | }, 3183 | "node_modules/string-width/node_modules/strip-ansi": { 3184 | "version": "7.1.0", 3185 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 3186 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 3187 | "dependencies": { 3188 | "ansi-regex": "^6.0.1" 3189 | }, 3190 | "engines": { 3191 | "node": ">=12" 3192 | }, 3193 | "funding": { 3194 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 3195 | } 3196 | }, 3197 | "node_modules/string.prototype.includes": { 3198 | "version": "2.0.1", 3199 | "resolved": "https://registry.npmjs.org/string.prototype.includes/-/string.prototype.includes-2.0.1.tgz", 3200 | "integrity": "sha512-o7+c9bW6zpAdJHTtujeePODAhkuicdAryFsfVKwA+wGw89wJ4GTY484WTucM9hLtDEOpOvI+aHnzqnC5lHp4Rg==", 3201 | "dev": true, 3202 | "peer": true, 3203 | "dependencies": { 3204 | "call-bind": "^1.0.7", 3205 | "define-properties": "^1.2.1", 3206 | "es-abstract": "^1.23.3" 3207 | }, 3208 | "engines": { 3209 | "node": ">= 0.4" 3210 | } 3211 | }, 3212 | "node_modules/string.prototype.matchall": { 3213 | "version": "4.0.11", 3214 | "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz", 3215 | "integrity": "sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==", 3216 | "dev": true, 3217 | "peer": true, 3218 | "dependencies": { 3219 | "call-bind": "^1.0.7", 3220 | "define-properties": "^1.2.1", 3221 | "es-abstract": "^1.23.2", 3222 | "es-errors": "^1.3.0", 3223 | "es-object-atoms": "^1.0.0", 3224 | "get-intrinsic": "^1.2.4", 3225 | "gopd": "^1.0.1", 3226 | "has-symbols": "^1.0.3", 3227 | "internal-slot": "^1.0.7", 3228 | "regexp.prototype.flags": "^1.5.2", 3229 | "set-function-name": "^2.0.2", 3230 | "side-channel": "^1.0.6" 3231 | }, 3232 | "engines": { 3233 | "node": ">= 0.4" 3234 | }, 3235 | "funding": { 3236 | "url": "https://github.com/sponsors/ljharb" 3237 | } 3238 | }, 3239 | "node_modules/string.prototype.repeat": { 3240 | "version": "1.0.0", 3241 | "resolved": "https://registry.npmjs.org/string.prototype.repeat/-/string.prototype.repeat-1.0.0.tgz", 3242 | "integrity": "sha512-0u/TldDbKD8bFCQ/4f5+mNRrXwZ8hg2w7ZR8wa16e8z9XpePWl3eGEcUD0OXpEH/VJH/2G3gjUtR3ZOiBe2S/w==", 3243 | "dev": true, 3244 | "peer": true, 3245 | "dependencies": { 3246 | "define-properties": "^1.1.3", 3247 | "es-abstract": "^1.17.5" 3248 | } 3249 | }, 3250 | "node_modules/string.prototype.trim": { 3251 | "version": "1.2.9", 3252 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", 3253 | "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", 3254 | "dev": true, 3255 | "dependencies": { 3256 | "call-bind": "^1.0.7", 3257 | "define-properties": "^1.2.1", 3258 | "es-abstract": "^1.23.0", 3259 | "es-object-atoms": "^1.0.0" 3260 | }, 3261 | "engines": { 3262 | "node": ">= 0.4" 3263 | }, 3264 | "funding": { 3265 | "url": "https://github.com/sponsors/ljharb" 3266 | } 3267 | }, 3268 | "node_modules/string.prototype.trimend": { 3269 | "version": "1.0.8", 3270 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", 3271 | "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", 3272 | "dev": true, 3273 | "dependencies": { 3274 | "call-bind": "^1.0.7", 3275 | "define-properties": "^1.2.1", 3276 | "es-object-atoms": "^1.0.0" 3277 | }, 3278 | "funding": { 3279 | "url": "https://github.com/sponsors/ljharb" 3280 | } 3281 | }, 3282 | "node_modules/string.prototype.trimstart": { 3283 | "version": "1.0.8", 3284 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz", 3285 | "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==", 3286 | "dev": true, 3287 | "dependencies": { 3288 | "call-bind": "^1.0.7", 3289 | "define-properties": "^1.2.1", 3290 | "es-object-atoms": "^1.0.0" 3291 | }, 3292 | "engines": { 3293 | "node": ">= 0.4" 3294 | }, 3295 | "funding": { 3296 | "url": "https://github.com/sponsors/ljharb" 3297 | } 3298 | }, 3299 | "node_modules/strip-ansi": { 3300 | "version": "6.0.1", 3301 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3302 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3303 | "dependencies": { 3304 | "ansi-regex": "^5.0.1" 3305 | }, 3306 | "engines": { 3307 | "node": ">=8" 3308 | } 3309 | }, 3310 | "node_modules/strip-ansi-cjs": { 3311 | "name": "strip-ansi", 3312 | "version": "6.0.1", 3313 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3314 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3315 | "dependencies": { 3316 | "ansi-regex": "^5.0.1" 3317 | }, 3318 | "engines": { 3319 | "node": ">=8" 3320 | } 3321 | }, 3322 | "node_modules/strip-bom": { 3323 | "version": "3.0.0", 3324 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3325 | "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", 3326 | "dev": true, 3327 | "engines": { 3328 | "node": ">=4" 3329 | } 3330 | }, 3331 | "node_modules/strip-json-comments": { 3332 | "version": "3.1.1", 3333 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3334 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3335 | "dev": true, 3336 | "engines": { 3337 | "node": ">=8" 3338 | }, 3339 | "funding": { 3340 | "url": "https://github.com/sponsors/sindresorhus" 3341 | } 3342 | }, 3343 | "node_modules/supports-color": { 3344 | "version": "7.2.0", 3345 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3346 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3347 | "dev": true, 3348 | "dependencies": { 3349 | "has-flag": "^4.0.0" 3350 | }, 3351 | "engines": { 3352 | "node": ">=8" 3353 | } 3354 | }, 3355 | "node_modules/supports-preserve-symlinks-flag": { 3356 | "version": "1.0.0", 3357 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3358 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3359 | "dev": true, 3360 | "engines": { 3361 | "node": ">= 0.4" 3362 | }, 3363 | "funding": { 3364 | "url": "https://github.com/sponsors/ljharb" 3365 | } 3366 | }, 3367 | "node_modules/text-table": { 3368 | "version": "0.2.0", 3369 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3370 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3371 | "dev": true 3372 | }, 3373 | "node_modules/timers-ext": { 3374 | "version": "0.1.8", 3375 | "resolved": "https://registry.npmjs.org/timers-ext/-/timers-ext-0.1.8.tgz", 3376 | "integrity": "sha512-wFH7+SEAcKfJpfLPkrgMPvvwnEtj8W4IurvEyrKsDleXnKLCDw71w8jltvfLa8Rm4qQxxT4jmDBYbJG/z7qoww==", 3377 | "dependencies": { 3378 | "es5-ext": "^0.10.64", 3379 | "next-tick": "^1.1.0" 3380 | }, 3381 | "engines": { 3382 | "node": ">=0.12" 3383 | } 3384 | }, 3385 | "node_modules/tsconfig-paths": { 3386 | "version": "3.15.0", 3387 | "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz", 3388 | "integrity": "sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==", 3389 | "dev": true, 3390 | "dependencies": { 3391 | "@types/json5": "^0.0.29", 3392 | "json5": "^1.0.2", 3393 | "minimist": "^1.2.6", 3394 | "strip-bom": "^3.0.0" 3395 | } 3396 | }, 3397 | "node_modules/type": { 3398 | "version": "2.7.3", 3399 | "resolved": "https://registry.npmjs.org/type/-/type-2.7.3.tgz", 3400 | "integrity": "sha512-8j+1QmAbPvLZow5Qpi6NCaN8FB60p/6x8/vfNqOk/hC+HuvFZhL4+WfekuhQLiqFZXOgQdrs3B+XxEmCc6b3FQ==" 3401 | }, 3402 | "node_modules/type-check": { 3403 | "version": "0.4.0", 3404 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3405 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3406 | "dev": true, 3407 | "dependencies": { 3408 | "prelude-ls": "^1.2.1" 3409 | }, 3410 | "engines": { 3411 | "node": ">= 0.8.0" 3412 | } 3413 | }, 3414 | "node_modules/type-fest": { 3415 | "version": "0.20.2", 3416 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3417 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3418 | "dev": true, 3419 | "engines": { 3420 | "node": ">=10" 3421 | }, 3422 | "funding": { 3423 | "url": "https://github.com/sponsors/sindresorhus" 3424 | } 3425 | }, 3426 | "node_modules/typed-array-buffer": { 3427 | "version": "1.0.2", 3428 | "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", 3429 | "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", 3430 | "dev": true, 3431 | "dependencies": { 3432 | "call-bind": "^1.0.7", 3433 | "es-errors": "^1.3.0", 3434 | "is-typed-array": "^1.1.13" 3435 | }, 3436 | "engines": { 3437 | "node": ">= 0.4" 3438 | } 3439 | }, 3440 | "node_modules/typed-array-byte-length": { 3441 | "version": "1.0.1", 3442 | "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", 3443 | "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", 3444 | "dev": true, 3445 | "dependencies": { 3446 | "call-bind": "^1.0.7", 3447 | "for-each": "^0.3.3", 3448 | "gopd": "^1.0.1", 3449 | "has-proto": "^1.0.3", 3450 | "is-typed-array": "^1.1.13" 3451 | }, 3452 | "engines": { 3453 | "node": ">= 0.4" 3454 | }, 3455 | "funding": { 3456 | "url": "https://github.com/sponsors/ljharb" 3457 | } 3458 | }, 3459 | "node_modules/typed-array-byte-offset": { 3460 | "version": "1.0.2", 3461 | "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", 3462 | "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", 3463 | "dev": true, 3464 | "dependencies": { 3465 | "available-typed-arrays": "^1.0.7", 3466 | "call-bind": "^1.0.7", 3467 | "for-each": "^0.3.3", 3468 | "gopd": "^1.0.1", 3469 | "has-proto": "^1.0.3", 3470 | "is-typed-array": "^1.1.13" 3471 | }, 3472 | "engines": { 3473 | "node": ">= 0.4" 3474 | }, 3475 | "funding": { 3476 | "url": "https://github.com/sponsors/ljharb" 3477 | } 3478 | }, 3479 | "node_modules/typed-array-length": { 3480 | "version": "1.0.6", 3481 | "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz", 3482 | "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==", 3483 | "dev": true, 3484 | "dependencies": { 3485 | "call-bind": "^1.0.7", 3486 | "for-each": "^0.3.3", 3487 | "gopd": "^1.0.1", 3488 | "has-proto": "^1.0.3", 3489 | "is-typed-array": "^1.1.13", 3490 | "possible-typed-array-names": "^1.0.0" 3491 | }, 3492 | "engines": { 3493 | "node": ">= 0.4" 3494 | }, 3495 | "funding": { 3496 | "url": "https://github.com/sponsors/ljharb" 3497 | } 3498 | }, 3499 | "node_modules/unbox-primitive": { 3500 | "version": "1.0.2", 3501 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", 3502 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", 3503 | "dev": true, 3504 | "dependencies": { 3505 | "call-bind": "^1.0.2", 3506 | "has-bigints": "^1.0.2", 3507 | "has-symbols": "^1.0.3", 3508 | "which-boxed-primitive": "^1.0.2" 3509 | }, 3510 | "funding": { 3511 | "url": "https://github.com/sponsors/ljharb" 3512 | } 3513 | }, 3514 | "node_modules/universalify": { 3515 | "version": "2.0.1", 3516 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", 3517 | "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", 3518 | "engines": { 3519 | "node": ">= 10.0.0" 3520 | } 3521 | }, 3522 | "node_modules/uri-js": { 3523 | "version": "4.4.1", 3524 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3525 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3526 | "dev": true, 3527 | "dependencies": { 3528 | "punycode": "^2.1.0" 3529 | } 3530 | }, 3531 | "node_modules/which": { 3532 | "version": "2.0.2", 3533 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3534 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3535 | "dependencies": { 3536 | "isexe": "^2.0.0" 3537 | }, 3538 | "bin": { 3539 | "node-which": "bin/node-which" 3540 | }, 3541 | "engines": { 3542 | "node": ">= 8" 3543 | } 3544 | }, 3545 | "node_modules/which-boxed-primitive": { 3546 | "version": "1.0.2", 3547 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 3548 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 3549 | "dev": true, 3550 | "dependencies": { 3551 | "is-bigint": "^1.0.1", 3552 | "is-boolean-object": "^1.1.0", 3553 | "is-number-object": "^1.0.4", 3554 | "is-string": "^1.0.5", 3555 | "is-symbol": "^1.0.3" 3556 | }, 3557 | "funding": { 3558 | "url": "https://github.com/sponsors/ljharb" 3559 | } 3560 | }, 3561 | "node_modules/which-builtin-type": { 3562 | "version": "1.1.4", 3563 | "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.4.tgz", 3564 | "integrity": "sha512-bppkmBSsHFmIMSl8BO9TbsyzsvGjVoppt8xUiGzwiu/bhDCGxnpOKCxgqj6GuyHE0mINMDecBFPlOm2hzY084w==", 3565 | "dev": true, 3566 | "peer": true, 3567 | "dependencies": { 3568 | "function.prototype.name": "^1.1.6", 3569 | "has-tostringtag": "^1.0.2", 3570 | "is-async-function": "^2.0.0", 3571 | "is-date-object": "^1.0.5", 3572 | "is-finalizationregistry": "^1.0.2", 3573 | "is-generator-function": "^1.0.10", 3574 | "is-regex": "^1.1.4", 3575 | "is-weakref": "^1.0.2", 3576 | "isarray": "^2.0.5", 3577 | "which-boxed-primitive": "^1.0.2", 3578 | "which-collection": "^1.0.2", 3579 | "which-typed-array": "^1.1.15" 3580 | }, 3581 | "engines": { 3582 | "node": ">= 0.4" 3583 | }, 3584 | "funding": { 3585 | "url": "https://github.com/sponsors/ljharb" 3586 | } 3587 | }, 3588 | "node_modules/which-collection": { 3589 | "version": "1.0.2", 3590 | "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.2.tgz", 3591 | "integrity": "sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw==", 3592 | "dev": true, 3593 | "peer": true, 3594 | "dependencies": { 3595 | "is-map": "^2.0.3", 3596 | "is-set": "^2.0.3", 3597 | "is-weakmap": "^2.0.2", 3598 | "is-weakset": "^2.0.3" 3599 | }, 3600 | "engines": { 3601 | "node": ">= 0.4" 3602 | }, 3603 | "funding": { 3604 | "url": "https://github.com/sponsors/ljharb" 3605 | } 3606 | }, 3607 | "node_modules/which-typed-array": { 3608 | "version": "1.1.15", 3609 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", 3610 | "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", 3611 | "dev": true, 3612 | "dependencies": { 3613 | "available-typed-arrays": "^1.0.7", 3614 | "call-bind": "^1.0.7", 3615 | "for-each": "^0.3.3", 3616 | "gopd": "^1.0.1", 3617 | "has-tostringtag": "^1.0.2" 3618 | }, 3619 | "engines": { 3620 | "node": ">= 0.4" 3621 | }, 3622 | "funding": { 3623 | "url": "https://github.com/sponsors/ljharb" 3624 | } 3625 | }, 3626 | "node_modules/word-wrap": { 3627 | "version": "1.2.5", 3628 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", 3629 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", 3630 | "dev": true, 3631 | "engines": { 3632 | "node": ">=0.10.0" 3633 | } 3634 | }, 3635 | "node_modules/wrap-ansi": { 3636 | "version": "8.1.0", 3637 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", 3638 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", 3639 | "dependencies": { 3640 | "ansi-styles": "^6.1.0", 3641 | "string-width": "^5.0.1", 3642 | "strip-ansi": "^7.0.1" 3643 | }, 3644 | "engines": { 3645 | "node": ">=12" 3646 | }, 3647 | "funding": { 3648 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3649 | } 3650 | }, 3651 | "node_modules/wrap-ansi-cjs": { 3652 | "name": "wrap-ansi", 3653 | "version": "7.0.0", 3654 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3655 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3656 | "dependencies": { 3657 | "ansi-styles": "^4.0.0", 3658 | "string-width": "^4.1.0", 3659 | "strip-ansi": "^6.0.0" 3660 | }, 3661 | "engines": { 3662 | "node": ">=10" 3663 | }, 3664 | "funding": { 3665 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3666 | } 3667 | }, 3668 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { 3669 | "version": "8.0.0", 3670 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3671 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 3672 | }, 3673 | "node_modules/wrap-ansi-cjs/node_modules/string-width": { 3674 | "version": "4.2.3", 3675 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3676 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3677 | "dependencies": { 3678 | "emoji-regex": "^8.0.0", 3679 | "is-fullwidth-code-point": "^3.0.0", 3680 | "strip-ansi": "^6.0.1" 3681 | }, 3682 | "engines": { 3683 | "node": ">=8" 3684 | } 3685 | }, 3686 | "node_modules/wrap-ansi/node_modules/ansi-regex": { 3687 | "version": "6.1.0", 3688 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", 3689 | "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", 3690 | "engines": { 3691 | "node": ">=12" 3692 | }, 3693 | "funding": { 3694 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 3695 | } 3696 | }, 3697 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 3698 | "version": "6.2.1", 3699 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", 3700 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", 3701 | "engines": { 3702 | "node": ">=12" 3703 | }, 3704 | "funding": { 3705 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 3706 | } 3707 | }, 3708 | "node_modules/wrap-ansi/node_modules/strip-ansi": { 3709 | "version": "7.1.0", 3710 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 3711 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 3712 | "dependencies": { 3713 | "ansi-regex": "^6.0.1" 3714 | }, 3715 | "engines": { 3716 | "node": ">=12" 3717 | }, 3718 | "funding": { 3719 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 3720 | } 3721 | }, 3722 | "node_modules/wrappy": { 3723 | "version": "1.0.2", 3724 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3725 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3726 | "dev": true 3727 | }, 3728 | "node_modules/yocto-queue": { 3729 | "version": "0.1.0", 3730 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3731 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3732 | "dev": true, 3733 | "engines": { 3734 | "node": ">=10" 3735 | }, 3736 | "funding": { 3737 | "url": "https://github.com/sponsors/sindresorhus" 3738 | } 3739 | } 3740 | } 3741 | } 3742 | --------------------------------------------------------------------------------