├── .github └── workflows │ ├── e2e.yml │ └── jest.yml ├── .gitignore ├── .npmignore ├── LICENSE ├── build ├── Dockerfile └── build.sh ├── package-lock.json ├── package.json ├── php-files ├── exts │ └── opcache.so ├── lib │ ├── libbrotlicommon.so.1 │ ├── libbrotlidec.so.1 │ ├── libcrypt.so.2 │ ├── libfreetype.so.6 │ ├── libgraphite2.so.3 │ ├── libharfbuzz.so.0 │ ├── libonig.so.5 │ ├── libpng16.so.16 │ ├── libsqlite3.so.0 │ └── libzip.so.5 ├── php └── php.ini ├── readme.md ├── src ├── index.js └── plugins.js └── tests ├── e2e ├── Dockerfile ├── build-test.sh ├── index.php ├── local.sh ├── router.php ├── rss.png ├── run-test.sh ├── static.css └── test.js ├── index.test.js └── plugins.test.js /.github/workflows/e2e.yml: -------------------------------------------------------------------------------- 1 | name: e2e Tests 2 | on: [push, pull_request] 3 | jobs: 4 | jest: 5 | name: e2e tests 6 | runs-on: ubuntu-latest 7 | steps: 8 | 9 | - name: Checkout 10 | uses: actions/checkout@v3 11 | 12 | - run: ./build-test.sh 13 | working-directory: ./tests/e2e 14 | 15 | - run: ./run-test.sh 16 | working-directory: ./tests/e2e 17 | 18 | - name: Check body is returned 19 | run: curl -XPOST "http://localhost:9000/2015-03-31/functions/function/invocations" -d '{"path":"/hi"}' | jq -e 'has("body")' 20 | 21 | - name: Check binary file is handled correctly 22 | run: curl -XPOST "http://localhost:9000/2015-03-31/functions/function/invocations" -d '{"path":"/rss.png"}' | jq -e '.headers["x-serverlesswp-binary"] == "true"' 23 | 24 | - name: Check preRequest plugin 25 | run: | 26 | curl -XPOST "http://localhost:9000/2015-03-31/functions/function/invocations" -d '{"path":"/index.php", "preRequestPlugin": "1"}' | jq -e '.body == "Foo"' 27 | 28 | - name: Check postRequest plugin 29 | run: | 30 | curl -XPOST "http://localhost:9000/2015-03-31/functions/function/invocations" -d '{"path":"/index.php", "postRequestPlugin": "1"}' | jq -e '.statusCode == 201' 31 | 32 | - run: docker stop serverlesswp-test; docker rm serverlesswp-test 33 | 34 | - run: ./run-test.sh 35 | working-directory: ./tests/e2e 36 | env: 37 | HOST: "Vercel" 38 | 39 | - name: Check if Vercel cookies are correct 40 | run: curl -XPOST "http://localhost:9000/2015-03-31/functions/function/invocations" -d '{"path":"/hi"}' | jq -e 'if (.headers["set-cookie"] | length == 2) then true else false end' 41 | 42 | - run: docker stop serverlesswp-test; docker rm serverlesswp-test 43 | 44 | - run: ./run-test.sh 45 | working-directory: ./tests/e2e 46 | env: 47 | HOST: "Netlify" 48 | 49 | - name: Check if Netlify cookies are correct 50 | run: curl -XPOST "http://localhost:9000/2015-03-31/functions/function/invocations" -d '{"path":"/hi"}' | jq -e 'if (.multiValueHeaders["set-cookie"] | length == 2) then true else false end' 51 | 52 | - run: docker stop serverlesswp-test; docker rm serverlesswp-test 53 | 54 | - run: ./run-test.sh 55 | working-directory: ./tests/e2e 56 | env: 57 | HOST: "AWS" 58 | 59 | - name: Check if AWS cookies are correct 60 | run: curl -XPOST "http://localhost:9000/2015-03-31/functions/function/invocations" -d '{"path":"/hi"}' | jq -e 'if (.cookies | length == 2) then true else false end' -------------------------------------------------------------------------------- /.github/workflows/jest.yml: -------------------------------------------------------------------------------- 1 | name: Jest Tests 2 | on: [push, pull_request] 3 | jobs: 4 | jest: 5 | name: Jest tests 6 | runs-on: ubuntu-latest 7 | steps: 8 | 9 | - name: Checkout 10 | uses: actions/checkout@v3 11 | 12 | - uses: actions/setup-node@v3 13 | with: 14 | node-version: 16 15 | cache: 'npm' 16 | cache-dependency-path: 'package-lock.json' 17 | 18 | - run: npm ci 19 | 20 | - run: npm run test -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .github/ 2 | build/ -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2023 Mitch MacKenzie 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 | -------------------------------------------------------------------------------- /build/Dockerfile: -------------------------------------------------------------------------------- 1 | FROM amazonlinux:2023 2 | ARG PHP_VERSION=8.1.32 3 | 4 | RUN yum -y groups install "Development tools" \ 5 | && yum -y install \ 6 | libxml2-devel \ 7 | libzip-devel \ 8 | libcurl-devel \ 9 | openssl-devel \ 10 | bzip2-devel \ 11 | gd-devel \ 12 | libjpeg-devel \ 13 | libexif \ 14 | libexif-devel \ 15 | oniguruma-devel 16 | 17 | RUN curl -L https://dev.mysql.com/get/mysql80-community-release-el9-1.noarch.rpm --create-dirs -o /work/mysql80-community-release-el9-1.noarch.rpm 18 | RUN dnf install /work/mysql80-community-release-el9-1.noarch.rpm -y 19 | RUN rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2023 20 | RUN dnf -y install mysql-devel 21 | 22 | WORKDIR /sqlite 23 | RUN curl https://www.sqlite.org/2023/sqlite-autoconf-3420000.tar.gz | tar xzf - 24 | WORKDIR sqlite-autoconf-3420000 25 | RUN ./configure --libdir=/usr/lib64 --prefix=/usr 26 | RUN make 27 | RUN make install 28 | 29 | WORKDIR /work 30 | 31 | RUN curl -L http://ca3.php.net/get/php-${PHP_VERSION}.tar.bz2/from/this/mirror --create-dirs -o /work/php.tar.bz2 32 | 33 | RUN tar -jxvf php.tar.bz2 \ 34 | && mkdir php-81-bin 35 | 36 | WORKDIR /work/php-${PHP_VERSION} 37 | 38 | RUN ./configure \ 39 | --prefix=/work/php-81-bin/ \ 40 | --enable-shared=no \ 41 | --enable-static=yes \ 42 | --without-pear \ 43 | --enable-json \ 44 | --with-openssl \ 45 | --with-curl \ 46 | --with-libxml \ 47 | --enable-simplexml \ 48 | --enable-xml \ 49 | --enable-gd \ 50 | --with-mhash \ 51 | --enable-exif \ 52 | --with-freetype \ 53 | --enable-mbstring \ 54 | --enable-sockets \ 55 | --enable-pdo \ 56 | --with-pdo-mysql \ 57 | --enable-tokenizer \ 58 | --with-zip \ 59 | --with-mysqli \ 60 | --with-bz2 \ 61 | --with-zlib \ 62 | --with-gettext \ 63 | --enable-opcache 64 | 65 | RUN make install -j4 -------------------------------------------------------------------------------- /build/build.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | 3 | rm ../php-files/php ../php-files/exts/* ../php-files/lib/* 4 | 5 | docker build -t lambda-php81 . 6 | container=$(docker create lambda-php81) 7 | 8 | docker -D cp $container:/work/php-81-bin/bin/php ../php-files/php 9 | docker -D cp $container:/work/php-81-bin/lib/php/extensions/no-debug-non-zts-20210902/opcache.so ../php-files/exts/ 10 | 11 | docker -D cp -L $container:/usr/lib64/libsqlite3.so.0.8.6 ../php-files/lib/libsqlite3.so.0 12 | docker -D cp -L $container:/usr/lib64/libcrypt.so.2 ../php-files/lib/libcrypt.so.2 13 | docker -D cp -L $container:/usr/lib64/libpng16.so.16 ../php-files/lib/libpng16.so.16 14 | docker -D cp -L $container:/usr/lib64/libfreetype.so.6 ../php-files/lib/libfreetype.so.6 15 | docker -D cp -L $container:/usr/lib64/libonig.so.5 ../php-files/lib/libonig.so.5 16 | docker -D cp -L $container:/usr/lib64/libzip.so.5 ../php-files/lib/libzip.so.5 17 | docker -D cp -L $container:/usr/lib64/libharfbuzz.so.0 ../php-files/lib/libharfbuzz.so.0 18 | docker -D cp -L $container:/usr/lib64/libbrotlidec.so.1 ../php-files/lib/libbrotlidec.so.1 19 | docker -D cp -L $container:/usr/lib64/libgraphite2.so.3 ../php-files/lib/libgraphite2.so.3 20 | docker -D cp -L $container:/usr/lib64/libbrotlicommon.so.1 ../php-files/lib/libbrotlicommon.so.1 21 | 22 | docker rm $container 23 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "serverlesswp", 3 | "version": "0.2.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "serverlesswp", 9 | "version": "0.2.0", 10 | "license": "MIT", 11 | "dependencies": { 12 | "isbinaryfile": "^5.0.0", 13 | "wait-on": "^7.0.1" 14 | }, 15 | "devDependencies": { 16 | "jest": "^29.5.0" 17 | } 18 | }, 19 | "node_modules/@ampproject/remapping": { 20 | "version": "2.2.1", 21 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 22 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 23 | "dev": true, 24 | "dependencies": { 25 | "@jridgewell/gen-mapping": "^0.3.0", 26 | "@jridgewell/trace-mapping": "^0.3.9" 27 | }, 28 | "engines": { 29 | "node": ">=6.0.0" 30 | } 31 | }, 32 | "node_modules/@babel/code-frame": { 33 | "version": "7.26.2", 34 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz", 35 | "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==", 36 | "dev": true, 37 | "dependencies": { 38 | "@babel/helper-validator-identifier": "^7.25.9", 39 | "js-tokens": "^4.0.0", 40 | "picocolors": "^1.0.0" 41 | }, 42 | "engines": { 43 | "node": ">=6.9.0" 44 | } 45 | }, 46 | "node_modules/@babel/compat-data": { 47 | "version": "7.22.9", 48 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", 49 | "integrity": "sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==", 50 | "dev": true, 51 | "engines": { 52 | "node": ">=6.9.0" 53 | } 54 | }, 55 | "node_modules/@babel/core": { 56 | "version": "7.22.9", 57 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.9.tgz", 58 | "integrity": "sha512-G2EgeufBcYw27U4hhoIwFcgc1XU7TlXJ3mv04oOv1WCuo900U/anZSPzEqNjwdjgffkk2Gs0AN0dW1CKVLcG7w==", 59 | "dev": true, 60 | "dependencies": { 61 | "@ampproject/remapping": "^2.2.0", 62 | "@babel/code-frame": "^7.22.5", 63 | "@babel/generator": "^7.22.9", 64 | "@babel/helper-compilation-targets": "^7.22.9", 65 | "@babel/helper-module-transforms": "^7.22.9", 66 | "@babel/helpers": "^7.22.6", 67 | "@babel/parser": "^7.22.7", 68 | "@babel/template": "^7.22.5", 69 | "@babel/traverse": "^7.22.8", 70 | "@babel/types": "^7.22.5", 71 | "convert-source-map": "^1.7.0", 72 | "debug": "^4.1.0", 73 | "gensync": "^1.0.0-beta.2", 74 | "json5": "^2.2.2", 75 | "semver": "^6.3.1" 76 | }, 77 | "engines": { 78 | "node": ">=6.9.0" 79 | }, 80 | "funding": { 81 | "type": "opencollective", 82 | "url": "https://opencollective.com/babel" 83 | } 84 | }, 85 | "node_modules/@babel/core/node_modules/convert-source-map": { 86 | "version": "1.9.0", 87 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 88 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", 89 | "dev": true 90 | }, 91 | "node_modules/@babel/generator": { 92 | "version": "7.26.5", 93 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.26.5.tgz", 94 | "integrity": "sha512-2caSP6fN9I7HOe6nqhtft7V4g7/V/gfDsC3Ag4W7kEzzvRGKqiv0pu0HogPiZ3KaVSoNDhUws6IJjDjpfmYIXw==", 95 | "dev": true, 96 | "dependencies": { 97 | "@babel/parser": "^7.26.5", 98 | "@babel/types": "^7.26.5", 99 | "@jridgewell/gen-mapping": "^0.3.5", 100 | "@jridgewell/trace-mapping": "^0.3.25", 101 | "jsesc": "^3.0.2" 102 | }, 103 | "engines": { 104 | "node": ">=6.9.0" 105 | } 106 | }, 107 | "node_modules/@babel/helper-compilation-targets": { 108 | "version": "7.22.9", 109 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.9.tgz", 110 | "integrity": "sha512-7qYrNM6HjpnPHJbopxmb8hSPoZ0gsX8IvUS32JGVoy+pU9e5N0nLr1VjJoR6kA4d9dmGLxNYOjeB8sUDal2WMw==", 111 | "dev": true, 112 | "dependencies": { 113 | "@babel/compat-data": "^7.22.9", 114 | "@babel/helper-validator-option": "^7.22.5", 115 | "browserslist": "^4.21.9", 116 | "lru-cache": "^5.1.1", 117 | "semver": "^6.3.1" 118 | }, 119 | "engines": { 120 | "node": ">=6.9.0" 121 | }, 122 | "peerDependencies": { 123 | "@babel/core": "^7.0.0" 124 | } 125 | }, 126 | "node_modules/@babel/helper-environment-visitor": { 127 | "version": "7.22.5", 128 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz", 129 | "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==", 130 | "dev": true, 131 | "engines": { 132 | "node": ">=6.9.0" 133 | } 134 | }, 135 | "node_modules/@babel/helper-module-imports": { 136 | "version": "7.22.5", 137 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz", 138 | "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==", 139 | "dev": true, 140 | "dependencies": { 141 | "@babel/types": "^7.22.5" 142 | }, 143 | "engines": { 144 | "node": ">=6.9.0" 145 | } 146 | }, 147 | "node_modules/@babel/helper-module-transforms": { 148 | "version": "7.22.9", 149 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.9.tgz", 150 | "integrity": "sha512-t+WA2Xn5K+rTeGtC8jCsdAH52bjggG5TKRuRrAGNM/mjIbO4GxvlLMFOEz9wXY5I2XQ60PMFsAG2WIcG82dQMQ==", 151 | "dev": true, 152 | "dependencies": { 153 | "@babel/helper-environment-visitor": "^7.22.5", 154 | "@babel/helper-module-imports": "^7.22.5", 155 | "@babel/helper-simple-access": "^7.22.5", 156 | "@babel/helper-split-export-declaration": "^7.22.6", 157 | "@babel/helper-validator-identifier": "^7.22.5" 158 | }, 159 | "engines": { 160 | "node": ">=6.9.0" 161 | }, 162 | "peerDependencies": { 163 | "@babel/core": "^7.0.0" 164 | } 165 | }, 166 | "node_modules/@babel/helper-plugin-utils": { 167 | "version": "7.22.5", 168 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", 169 | "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", 170 | "dev": true, 171 | "engines": { 172 | "node": ">=6.9.0" 173 | } 174 | }, 175 | "node_modules/@babel/helper-simple-access": { 176 | "version": "7.22.5", 177 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", 178 | "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", 179 | "dev": true, 180 | "dependencies": { 181 | "@babel/types": "^7.22.5" 182 | }, 183 | "engines": { 184 | "node": ">=6.9.0" 185 | } 186 | }, 187 | "node_modules/@babel/helper-split-export-declaration": { 188 | "version": "7.22.6", 189 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", 190 | "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", 191 | "dev": true, 192 | "dependencies": { 193 | "@babel/types": "^7.22.5" 194 | }, 195 | "engines": { 196 | "node": ">=6.9.0" 197 | } 198 | }, 199 | "node_modules/@babel/helper-string-parser": { 200 | "version": "7.25.9", 201 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz", 202 | "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==", 203 | "dev": true, 204 | "engines": { 205 | "node": ">=6.9.0" 206 | } 207 | }, 208 | "node_modules/@babel/helper-validator-identifier": { 209 | "version": "7.25.9", 210 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz", 211 | "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==", 212 | "dev": true, 213 | "engines": { 214 | "node": ">=6.9.0" 215 | } 216 | }, 217 | "node_modules/@babel/helper-validator-option": { 218 | "version": "7.22.5", 219 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz", 220 | "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==", 221 | "dev": true, 222 | "engines": { 223 | "node": ">=6.9.0" 224 | } 225 | }, 226 | "node_modules/@babel/helpers": { 227 | "version": "7.22.6", 228 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.6.tgz", 229 | "integrity": "sha512-YjDs6y/fVOYFV8hAf1rxd1QvR9wJe1pDBZ2AREKq/SDayfPzgk0PBnVuTCE5X1acEpMMNOVUqoe+OwiZGJ+OaA==", 230 | "dev": true, 231 | "dependencies": { 232 | "@babel/template": "^7.22.5", 233 | "@babel/traverse": "^7.22.6", 234 | "@babel/types": "^7.22.5" 235 | }, 236 | "engines": { 237 | "node": ">=6.9.0" 238 | } 239 | }, 240 | "node_modules/@babel/parser": { 241 | "version": "7.26.7", 242 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.7.tgz", 243 | "integrity": "sha512-kEvgGGgEjRUutvdVvZhbn/BxVt+5VSpwXz1j3WYXQbXDo8KzFOPNG2GQbdAiNq8g6wn1yKk7C/qrke03a84V+w==", 244 | "dev": true, 245 | "dependencies": { 246 | "@babel/types": "^7.26.7" 247 | }, 248 | "bin": { 249 | "parser": "bin/babel-parser.js" 250 | }, 251 | "engines": { 252 | "node": ">=6.0.0" 253 | } 254 | }, 255 | "node_modules/@babel/plugin-syntax-async-generators": { 256 | "version": "7.8.4", 257 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", 258 | "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", 259 | "dev": true, 260 | "dependencies": { 261 | "@babel/helper-plugin-utils": "^7.8.0" 262 | }, 263 | "peerDependencies": { 264 | "@babel/core": "^7.0.0-0" 265 | } 266 | }, 267 | "node_modules/@babel/plugin-syntax-bigint": { 268 | "version": "7.8.3", 269 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", 270 | "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", 271 | "dev": true, 272 | "dependencies": { 273 | "@babel/helper-plugin-utils": "^7.8.0" 274 | }, 275 | "peerDependencies": { 276 | "@babel/core": "^7.0.0-0" 277 | } 278 | }, 279 | "node_modules/@babel/plugin-syntax-class-properties": { 280 | "version": "7.12.13", 281 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", 282 | "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", 283 | "dev": true, 284 | "dependencies": { 285 | "@babel/helper-plugin-utils": "^7.12.13" 286 | }, 287 | "peerDependencies": { 288 | "@babel/core": "^7.0.0-0" 289 | } 290 | }, 291 | "node_modules/@babel/plugin-syntax-import-meta": { 292 | "version": "7.10.4", 293 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", 294 | "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", 295 | "dev": true, 296 | "dependencies": { 297 | "@babel/helper-plugin-utils": "^7.10.4" 298 | }, 299 | "peerDependencies": { 300 | "@babel/core": "^7.0.0-0" 301 | } 302 | }, 303 | "node_modules/@babel/plugin-syntax-json-strings": { 304 | "version": "7.8.3", 305 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", 306 | "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", 307 | "dev": true, 308 | "dependencies": { 309 | "@babel/helper-plugin-utils": "^7.8.0" 310 | }, 311 | "peerDependencies": { 312 | "@babel/core": "^7.0.0-0" 313 | } 314 | }, 315 | "node_modules/@babel/plugin-syntax-jsx": { 316 | "version": "7.22.5", 317 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.22.5.tgz", 318 | "integrity": "sha512-gvyP4hZrgrs/wWMaocvxZ44Hw0b3W8Pe+cMxc8V1ULQ07oh8VNbIRaoD1LRZVTvD+0nieDKjfgKg89sD7rrKrg==", 319 | "dev": true, 320 | "dependencies": { 321 | "@babel/helper-plugin-utils": "^7.22.5" 322 | }, 323 | "engines": { 324 | "node": ">=6.9.0" 325 | }, 326 | "peerDependencies": { 327 | "@babel/core": "^7.0.0-0" 328 | } 329 | }, 330 | "node_modules/@babel/plugin-syntax-logical-assignment-operators": { 331 | "version": "7.10.4", 332 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", 333 | "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", 334 | "dev": true, 335 | "dependencies": { 336 | "@babel/helper-plugin-utils": "^7.10.4" 337 | }, 338 | "peerDependencies": { 339 | "@babel/core": "^7.0.0-0" 340 | } 341 | }, 342 | "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { 343 | "version": "7.8.3", 344 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", 345 | "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", 346 | "dev": true, 347 | "dependencies": { 348 | "@babel/helper-plugin-utils": "^7.8.0" 349 | }, 350 | "peerDependencies": { 351 | "@babel/core": "^7.0.0-0" 352 | } 353 | }, 354 | "node_modules/@babel/plugin-syntax-numeric-separator": { 355 | "version": "7.10.4", 356 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", 357 | "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", 358 | "dev": true, 359 | "dependencies": { 360 | "@babel/helper-plugin-utils": "^7.10.4" 361 | }, 362 | "peerDependencies": { 363 | "@babel/core": "^7.0.0-0" 364 | } 365 | }, 366 | "node_modules/@babel/plugin-syntax-object-rest-spread": { 367 | "version": "7.8.3", 368 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", 369 | "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", 370 | "dev": true, 371 | "dependencies": { 372 | "@babel/helper-plugin-utils": "^7.8.0" 373 | }, 374 | "peerDependencies": { 375 | "@babel/core": "^7.0.0-0" 376 | } 377 | }, 378 | "node_modules/@babel/plugin-syntax-optional-catch-binding": { 379 | "version": "7.8.3", 380 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", 381 | "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", 382 | "dev": true, 383 | "dependencies": { 384 | "@babel/helper-plugin-utils": "^7.8.0" 385 | }, 386 | "peerDependencies": { 387 | "@babel/core": "^7.0.0-0" 388 | } 389 | }, 390 | "node_modules/@babel/plugin-syntax-optional-chaining": { 391 | "version": "7.8.3", 392 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", 393 | "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", 394 | "dev": true, 395 | "dependencies": { 396 | "@babel/helper-plugin-utils": "^7.8.0" 397 | }, 398 | "peerDependencies": { 399 | "@babel/core": "^7.0.0-0" 400 | } 401 | }, 402 | "node_modules/@babel/plugin-syntax-top-level-await": { 403 | "version": "7.14.5", 404 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", 405 | "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", 406 | "dev": true, 407 | "dependencies": { 408 | "@babel/helper-plugin-utils": "^7.14.5" 409 | }, 410 | "engines": { 411 | "node": ">=6.9.0" 412 | }, 413 | "peerDependencies": { 414 | "@babel/core": "^7.0.0-0" 415 | } 416 | }, 417 | "node_modules/@babel/plugin-syntax-typescript": { 418 | "version": "7.22.5", 419 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.22.5.tgz", 420 | "integrity": "sha512-1mS2o03i7t1c6VzH6fdQ3OA8tcEIxwG18zIPRp+UY1Ihv6W+XZzBCVxExF9upussPXJ0xE9XRHwMoNs1ep/nRQ==", 421 | "dev": true, 422 | "dependencies": { 423 | "@babel/helper-plugin-utils": "^7.22.5" 424 | }, 425 | "engines": { 426 | "node": ">=6.9.0" 427 | }, 428 | "peerDependencies": { 429 | "@babel/core": "^7.0.0-0" 430 | } 431 | }, 432 | "node_modules/@babel/template": { 433 | "version": "7.25.9", 434 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.9.tgz", 435 | "integrity": "sha512-9DGttpmPvIxBb/2uwpVo3dqJ+O6RooAFOS+lB+xDqoE2PVCE8nfoHMdZLpfCQRLwvohzXISPZcgxt80xLfsuwg==", 436 | "dev": true, 437 | "dependencies": { 438 | "@babel/code-frame": "^7.25.9", 439 | "@babel/parser": "^7.25.9", 440 | "@babel/types": "^7.25.9" 441 | }, 442 | "engines": { 443 | "node": ">=6.9.0" 444 | } 445 | }, 446 | "node_modules/@babel/traverse": { 447 | "version": "7.26.7", 448 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.26.7.tgz", 449 | "integrity": "sha512-1x1sgeyRLC3r5fQOM0/xtQKsYjyxmFjaOrLJNtZ81inNjyJHGIolTULPiSc/2qe1/qfpFLisLQYFnnZl7QoedA==", 450 | "dev": true, 451 | "dependencies": { 452 | "@babel/code-frame": "^7.26.2", 453 | "@babel/generator": "^7.26.5", 454 | "@babel/parser": "^7.26.7", 455 | "@babel/template": "^7.25.9", 456 | "@babel/types": "^7.26.7", 457 | "debug": "^4.3.1", 458 | "globals": "^11.1.0" 459 | }, 460 | "engines": { 461 | "node": ">=6.9.0" 462 | } 463 | }, 464 | "node_modules/@babel/types": { 465 | "version": "7.26.7", 466 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.7.tgz", 467 | "integrity": "sha512-t8kDRGrKXyp6+tjUh7hw2RLyclsW4TRoRvRHtSyAX9Bb5ldlFh+90YAYY6awRXrlB4G5G2izNeGySpATlFzmOg==", 468 | "dev": true, 469 | "dependencies": { 470 | "@babel/helper-string-parser": "^7.25.9", 471 | "@babel/helper-validator-identifier": "^7.25.9" 472 | }, 473 | "engines": { 474 | "node": ">=6.9.0" 475 | } 476 | }, 477 | "node_modules/@bcoe/v8-coverage": { 478 | "version": "0.2.3", 479 | "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", 480 | "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", 481 | "dev": true 482 | }, 483 | "node_modules/@hapi/hoek": { 484 | "version": "9.3.0", 485 | "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", 486 | "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==" 487 | }, 488 | "node_modules/@hapi/topo": { 489 | "version": "5.1.0", 490 | "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", 491 | "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", 492 | "dependencies": { 493 | "@hapi/hoek": "^9.0.0" 494 | } 495 | }, 496 | "node_modules/@istanbuljs/load-nyc-config": { 497 | "version": "1.1.0", 498 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", 499 | "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", 500 | "dev": true, 501 | "dependencies": { 502 | "camelcase": "^5.3.1", 503 | "find-up": "^4.1.0", 504 | "get-package-type": "^0.1.0", 505 | "js-yaml": "^3.13.1", 506 | "resolve-from": "^5.0.0" 507 | }, 508 | "engines": { 509 | "node": ">=8" 510 | } 511 | }, 512 | "node_modules/@istanbuljs/schema": { 513 | "version": "0.1.3", 514 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", 515 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", 516 | "dev": true, 517 | "engines": { 518 | "node": ">=8" 519 | } 520 | }, 521 | "node_modules/@jest/console": { 522 | "version": "29.6.1", 523 | "resolved": "https://registry.npmjs.org/@jest/console/-/console-29.6.1.tgz", 524 | "integrity": "sha512-Aj772AYgwTSr5w8qnyoJ0eDYvN6bMsH3ORH1ivMotrInHLKdUz6BDlaEXHdM6kODaBIkNIyQGzsMvRdOv7VG7Q==", 525 | "dev": true, 526 | "dependencies": { 527 | "@jest/types": "^29.6.1", 528 | "@types/node": "*", 529 | "chalk": "^4.0.0", 530 | "jest-message-util": "^29.6.1", 531 | "jest-util": "^29.6.1", 532 | "slash": "^3.0.0" 533 | }, 534 | "engines": { 535 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 536 | } 537 | }, 538 | "node_modules/@jest/core": { 539 | "version": "29.6.1", 540 | "resolved": "https://registry.npmjs.org/@jest/core/-/core-29.6.1.tgz", 541 | "integrity": "sha512-CcowHypRSm5oYQ1obz1wfvkjZZ2qoQlrKKvlfPwh5jUXVU12TWr2qMeH8chLMuTFzHh5a1g2yaqlqDICbr+ukQ==", 542 | "dev": true, 543 | "dependencies": { 544 | "@jest/console": "^29.6.1", 545 | "@jest/reporters": "^29.6.1", 546 | "@jest/test-result": "^29.6.1", 547 | "@jest/transform": "^29.6.1", 548 | "@jest/types": "^29.6.1", 549 | "@types/node": "*", 550 | "ansi-escapes": "^4.2.1", 551 | "chalk": "^4.0.0", 552 | "ci-info": "^3.2.0", 553 | "exit": "^0.1.2", 554 | "graceful-fs": "^4.2.9", 555 | "jest-changed-files": "^29.5.0", 556 | "jest-config": "^29.6.1", 557 | "jest-haste-map": "^29.6.1", 558 | "jest-message-util": "^29.6.1", 559 | "jest-regex-util": "^29.4.3", 560 | "jest-resolve": "^29.6.1", 561 | "jest-resolve-dependencies": "^29.6.1", 562 | "jest-runner": "^29.6.1", 563 | "jest-runtime": "^29.6.1", 564 | "jest-snapshot": "^29.6.1", 565 | "jest-util": "^29.6.1", 566 | "jest-validate": "^29.6.1", 567 | "jest-watcher": "^29.6.1", 568 | "micromatch": "^4.0.4", 569 | "pretty-format": "^29.6.1", 570 | "slash": "^3.0.0", 571 | "strip-ansi": "^6.0.0" 572 | }, 573 | "engines": { 574 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 575 | }, 576 | "peerDependencies": { 577 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 578 | }, 579 | "peerDependenciesMeta": { 580 | "node-notifier": { 581 | "optional": true 582 | } 583 | } 584 | }, 585 | "node_modules/@jest/environment": { 586 | "version": "29.6.1", 587 | "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-29.6.1.tgz", 588 | "integrity": "sha512-RMMXx4ws+Gbvw3DfLSuo2cfQlK7IwGbpuEWXCqyYDcqYTI+9Ju3a5hDnXaxjNsa6uKh9PQF2v+qg+RLe63tz5A==", 589 | "dev": true, 590 | "dependencies": { 591 | "@jest/fake-timers": "^29.6.1", 592 | "@jest/types": "^29.6.1", 593 | "@types/node": "*", 594 | "jest-mock": "^29.6.1" 595 | }, 596 | "engines": { 597 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 598 | } 599 | }, 600 | "node_modules/@jest/expect": { 601 | "version": "29.6.1", 602 | "resolved": "https://registry.npmjs.org/@jest/expect/-/expect-29.6.1.tgz", 603 | "integrity": "sha512-N5xlPrAYaRNyFgVf2s9Uyyvr795jnB6rObuPx4QFvNJz8aAjpZUDfO4bh5G/xuplMID8PrnuF1+SfSyDxhsgYg==", 604 | "dev": true, 605 | "dependencies": { 606 | "expect": "^29.6.1", 607 | "jest-snapshot": "^29.6.1" 608 | }, 609 | "engines": { 610 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 611 | } 612 | }, 613 | "node_modules/@jest/expect-utils": { 614 | "version": "29.6.1", 615 | "resolved": "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-29.6.1.tgz", 616 | "integrity": "sha512-o319vIf5pEMx0LmzSxxkYYxo4wrRLKHq9dP1yJU7FoPTB0LfAKSz8SWD6D/6U3v/O52t9cF5t+MeJiRsfk7zMw==", 617 | "dev": true, 618 | "dependencies": { 619 | "jest-get-type": "^29.4.3" 620 | }, 621 | "engines": { 622 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 623 | } 624 | }, 625 | "node_modules/@jest/fake-timers": { 626 | "version": "29.6.1", 627 | "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-29.6.1.tgz", 628 | "integrity": "sha512-RdgHgbXyosCDMVYmj7lLpUwXA4c69vcNzhrt69dJJdf8azUrpRh3ckFCaTPNjsEeRi27Cig0oKDGxy5j7hOgHg==", 629 | "dev": true, 630 | "dependencies": { 631 | "@jest/types": "^29.6.1", 632 | "@sinonjs/fake-timers": "^10.0.2", 633 | "@types/node": "*", 634 | "jest-message-util": "^29.6.1", 635 | "jest-mock": "^29.6.1", 636 | "jest-util": "^29.6.1" 637 | }, 638 | "engines": { 639 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 640 | } 641 | }, 642 | "node_modules/@jest/globals": { 643 | "version": "29.6.1", 644 | "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-29.6.1.tgz", 645 | "integrity": "sha512-2VjpaGy78JY9n9370H8zGRCFbYVWwjY6RdDMhoJHa1sYfwe6XM/azGN0SjY8kk7BOZApIejQ1BFPyH7FPG0w3A==", 646 | "dev": true, 647 | "dependencies": { 648 | "@jest/environment": "^29.6.1", 649 | "@jest/expect": "^29.6.1", 650 | "@jest/types": "^29.6.1", 651 | "jest-mock": "^29.6.1" 652 | }, 653 | "engines": { 654 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 655 | } 656 | }, 657 | "node_modules/@jest/reporters": { 658 | "version": "29.6.1", 659 | "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-29.6.1.tgz", 660 | "integrity": "sha512-9zuaI9QKr9JnoZtFQlw4GREQbxgmNYXU6QuWtmuODvk5nvPUeBYapVR/VYMyi2WSx3jXTLJTJji8rN6+Cm4+FA==", 661 | "dev": true, 662 | "dependencies": { 663 | "@bcoe/v8-coverage": "^0.2.3", 664 | "@jest/console": "^29.6.1", 665 | "@jest/test-result": "^29.6.1", 666 | "@jest/transform": "^29.6.1", 667 | "@jest/types": "^29.6.1", 668 | "@jridgewell/trace-mapping": "^0.3.18", 669 | "@types/node": "*", 670 | "chalk": "^4.0.0", 671 | "collect-v8-coverage": "^1.0.0", 672 | "exit": "^0.1.2", 673 | "glob": "^7.1.3", 674 | "graceful-fs": "^4.2.9", 675 | "istanbul-lib-coverage": "^3.0.0", 676 | "istanbul-lib-instrument": "^5.1.0", 677 | "istanbul-lib-report": "^3.0.0", 678 | "istanbul-lib-source-maps": "^4.0.0", 679 | "istanbul-reports": "^3.1.3", 680 | "jest-message-util": "^29.6.1", 681 | "jest-util": "^29.6.1", 682 | "jest-worker": "^29.6.1", 683 | "slash": "^3.0.0", 684 | "string-length": "^4.0.1", 685 | "strip-ansi": "^6.0.0", 686 | "v8-to-istanbul": "^9.0.1" 687 | }, 688 | "engines": { 689 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 690 | }, 691 | "peerDependencies": { 692 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 693 | }, 694 | "peerDependenciesMeta": { 695 | "node-notifier": { 696 | "optional": true 697 | } 698 | } 699 | }, 700 | "node_modules/@jest/schemas": { 701 | "version": "29.6.0", 702 | "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.0.tgz", 703 | "integrity": "sha512-rxLjXyJBTL4LQeJW3aKo0M/+GkCOXsO+8i9Iu7eDb6KwtP65ayoDsitrdPBtujxQ88k4wI2FNYfa6TOGwSn6cQ==", 704 | "dev": true, 705 | "dependencies": { 706 | "@sinclair/typebox": "^0.27.8" 707 | }, 708 | "engines": { 709 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 710 | } 711 | }, 712 | "node_modules/@jest/source-map": { 713 | "version": "29.6.0", 714 | "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-29.6.0.tgz", 715 | "integrity": "sha512-oA+I2SHHQGxDCZpbrsCQSoMLb3Bz547JnM+jUr9qEbuw0vQlWZfpPS7CO9J7XiwKicEz9OFn/IYoLkkiUD7bzA==", 716 | "dev": true, 717 | "dependencies": { 718 | "@jridgewell/trace-mapping": "^0.3.18", 719 | "callsites": "^3.0.0", 720 | "graceful-fs": "^4.2.9" 721 | }, 722 | "engines": { 723 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 724 | } 725 | }, 726 | "node_modules/@jest/test-result": { 727 | "version": "29.6.1", 728 | "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-29.6.1.tgz", 729 | "integrity": "sha512-Ynr13ZRcpX6INak0TPUukU8GWRfm/vAytE3JbJNGAvINySWYdfE7dGZMbk36oVuK4CigpbhMn8eg1dixZ7ZJOw==", 730 | "dev": true, 731 | "dependencies": { 732 | "@jest/console": "^29.6.1", 733 | "@jest/types": "^29.6.1", 734 | "@types/istanbul-lib-coverage": "^2.0.0", 735 | "collect-v8-coverage": "^1.0.0" 736 | }, 737 | "engines": { 738 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 739 | } 740 | }, 741 | "node_modules/@jest/test-sequencer": { 742 | "version": "29.6.1", 743 | "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-29.6.1.tgz", 744 | "integrity": "sha512-oBkC36PCDf/wb6dWeQIhaviU0l5u6VCsXa119yqdUosYAt7/FbQU2M2UoziO3igj/HBDEgp57ONQ3fm0v9uyyg==", 745 | "dev": true, 746 | "dependencies": { 747 | "@jest/test-result": "^29.6.1", 748 | "graceful-fs": "^4.2.9", 749 | "jest-haste-map": "^29.6.1", 750 | "slash": "^3.0.0" 751 | }, 752 | "engines": { 753 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 754 | } 755 | }, 756 | "node_modules/@jest/transform": { 757 | "version": "29.6.1", 758 | "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-29.6.1.tgz", 759 | "integrity": "sha512-URnTneIU3ZjRSaf906cvf6Hpox3hIeJXRnz3VDSw5/X93gR8ycdfSIEy19FlVx8NFmpN7fe3Gb1xF+NjXaQLWg==", 760 | "dev": true, 761 | "dependencies": { 762 | "@babel/core": "^7.11.6", 763 | "@jest/types": "^29.6.1", 764 | "@jridgewell/trace-mapping": "^0.3.18", 765 | "babel-plugin-istanbul": "^6.1.1", 766 | "chalk": "^4.0.0", 767 | "convert-source-map": "^2.0.0", 768 | "fast-json-stable-stringify": "^2.1.0", 769 | "graceful-fs": "^4.2.9", 770 | "jest-haste-map": "^29.6.1", 771 | "jest-regex-util": "^29.4.3", 772 | "jest-util": "^29.6.1", 773 | "micromatch": "^4.0.4", 774 | "pirates": "^4.0.4", 775 | "slash": "^3.0.0", 776 | "write-file-atomic": "^4.0.2" 777 | }, 778 | "engines": { 779 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 780 | } 781 | }, 782 | "node_modules/@jest/types": { 783 | "version": "29.6.1", 784 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-29.6.1.tgz", 785 | "integrity": "sha512-tPKQNMPuXgvdOn2/Lg9HNfUvjYVGolt04Hp03f5hAk878uwOLikN+JzeLY0HcVgKgFl9Hs3EIqpu3WX27XNhnw==", 786 | "dev": true, 787 | "dependencies": { 788 | "@jest/schemas": "^29.6.0", 789 | "@types/istanbul-lib-coverage": "^2.0.0", 790 | "@types/istanbul-reports": "^3.0.0", 791 | "@types/node": "*", 792 | "@types/yargs": "^17.0.8", 793 | "chalk": "^4.0.0" 794 | }, 795 | "engines": { 796 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 797 | } 798 | }, 799 | "node_modules/@jridgewell/gen-mapping": { 800 | "version": "0.3.8", 801 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.8.tgz", 802 | "integrity": "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA==", 803 | "dev": true, 804 | "dependencies": { 805 | "@jridgewell/set-array": "^1.2.1", 806 | "@jridgewell/sourcemap-codec": "^1.4.10", 807 | "@jridgewell/trace-mapping": "^0.3.24" 808 | }, 809 | "engines": { 810 | "node": ">=6.0.0" 811 | } 812 | }, 813 | "node_modules/@jridgewell/resolve-uri": { 814 | "version": "3.1.0", 815 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 816 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 817 | "dev": true, 818 | "engines": { 819 | "node": ">=6.0.0" 820 | } 821 | }, 822 | "node_modules/@jridgewell/set-array": { 823 | "version": "1.2.1", 824 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 825 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 826 | "dev": true, 827 | "engines": { 828 | "node": ">=6.0.0" 829 | } 830 | }, 831 | "node_modules/@jridgewell/sourcemap-codec": { 832 | "version": "1.4.15", 833 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 834 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 835 | "dev": true 836 | }, 837 | "node_modules/@jridgewell/trace-mapping": { 838 | "version": "0.3.25", 839 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 840 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 841 | "dev": true, 842 | "dependencies": { 843 | "@jridgewell/resolve-uri": "^3.1.0", 844 | "@jridgewell/sourcemap-codec": "^1.4.14" 845 | } 846 | }, 847 | "node_modules/@sideway/address": { 848 | "version": "4.1.5", 849 | "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.5.tgz", 850 | "integrity": "sha512-IqO/DUQHUkPeixNQ8n0JA6102hT9CmaljNTPmQ1u8MEhBo/R4Q8eKLN/vGZxuebwOroDB4cbpjheD4+/sKFK4Q==", 851 | "dependencies": { 852 | "@hapi/hoek": "^9.0.0" 853 | } 854 | }, 855 | "node_modules/@sideway/formula": { 856 | "version": "3.0.1", 857 | "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.1.tgz", 858 | "integrity": "sha512-/poHZJJVjx3L+zVD6g9KgHfYnb443oi7wLu/XKojDviHy6HOEOA6z1Trk5aR1dGcmPenJEgb2sK2I80LeS3MIg==" 859 | }, 860 | "node_modules/@sideway/pinpoint": { 861 | "version": "2.0.0", 862 | "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", 863 | "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==" 864 | }, 865 | "node_modules/@sinclair/typebox": { 866 | "version": "0.27.8", 867 | "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", 868 | "integrity": "sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==", 869 | "dev": true 870 | }, 871 | "node_modules/@sinonjs/commons": { 872 | "version": "3.0.0", 873 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.0.tgz", 874 | "integrity": "sha512-jXBtWAF4vmdNmZgD5FoKsVLv3rPgDnLgPbU84LIJ3otV44vJlDRokVng5v8NFJdCf/da9legHcKaRuZs4L7faA==", 875 | "dev": true, 876 | "dependencies": { 877 | "type-detect": "4.0.8" 878 | } 879 | }, 880 | "node_modules/@sinonjs/fake-timers": { 881 | "version": "10.3.0", 882 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-10.3.0.tgz", 883 | "integrity": "sha512-V4BG07kuYSUkTCSBHG8G8TNhM+F19jXFWnQtzj+we8DrkpSBCee9Z3Ms8yiGer/dlmhe35/Xdgyo3/0rQKg7YA==", 884 | "dev": true, 885 | "dependencies": { 886 | "@sinonjs/commons": "^3.0.0" 887 | } 888 | }, 889 | "node_modules/@types/babel__core": { 890 | "version": "7.20.1", 891 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.1.tgz", 892 | "integrity": "sha512-aACu/U/omhdk15O4Nfb+fHgH/z3QsfQzpnvRZhYhThms83ZnAOZz7zZAWO7mn2yyNQaA4xTO8GLK3uqFU4bYYw==", 893 | "dev": true, 894 | "dependencies": { 895 | "@babel/parser": "^7.20.7", 896 | "@babel/types": "^7.20.7", 897 | "@types/babel__generator": "*", 898 | "@types/babel__template": "*", 899 | "@types/babel__traverse": "*" 900 | } 901 | }, 902 | "node_modules/@types/babel__generator": { 903 | "version": "7.6.4", 904 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", 905 | "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", 906 | "dev": true, 907 | "dependencies": { 908 | "@babel/types": "^7.0.0" 909 | } 910 | }, 911 | "node_modules/@types/babel__template": { 912 | "version": "7.4.1", 913 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", 914 | "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", 915 | "dev": true, 916 | "dependencies": { 917 | "@babel/parser": "^7.1.0", 918 | "@babel/types": "^7.0.0" 919 | } 920 | }, 921 | "node_modules/@types/babel__traverse": { 922 | "version": "7.20.1", 923 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.1.tgz", 924 | "integrity": "sha512-MitHFXnhtgwsGZWtT68URpOvLN4EREih1u3QtQiN4VdAxWKRVvGCSvw/Qth0M0Qq3pJpnGOu5JaM/ydK7OGbqg==", 925 | "dev": true, 926 | "dependencies": { 927 | "@babel/types": "^7.20.7" 928 | } 929 | }, 930 | "node_modules/@types/graceful-fs": { 931 | "version": "4.1.6", 932 | "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.6.tgz", 933 | "integrity": "sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw==", 934 | "dev": true, 935 | "dependencies": { 936 | "@types/node": "*" 937 | } 938 | }, 939 | "node_modules/@types/istanbul-lib-coverage": { 940 | "version": "2.0.4", 941 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", 942 | "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", 943 | "dev": true 944 | }, 945 | "node_modules/@types/istanbul-lib-report": { 946 | "version": "3.0.0", 947 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 948 | "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", 949 | "dev": true, 950 | "dependencies": { 951 | "@types/istanbul-lib-coverage": "*" 952 | } 953 | }, 954 | "node_modules/@types/istanbul-reports": { 955 | "version": "3.0.1", 956 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", 957 | "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", 958 | "dev": true, 959 | "dependencies": { 960 | "@types/istanbul-lib-report": "*" 961 | } 962 | }, 963 | "node_modules/@types/node": { 964 | "version": "20.4.4", 965 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.4.4.tgz", 966 | "integrity": "sha512-CukZhumInROvLq3+b5gLev+vgpsIqC2D0deQr/yS1WnxvmYLlJXZpaQrQiseMY+6xusl79E04UjWoqyr+t1/Ew==", 967 | "dev": true 968 | }, 969 | "node_modules/@types/prettier": { 970 | "version": "2.7.3", 971 | "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.3.tgz", 972 | "integrity": "sha512-+68kP9yzs4LMp7VNh8gdzMSPZFL44MLGqiHWvttYJe+6qnuVr4Ek9wSBQoveqY/r+LwjCcU29kNVkidwim+kYA==", 973 | "dev": true 974 | }, 975 | "node_modules/@types/stack-utils": { 976 | "version": "2.0.1", 977 | "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", 978 | "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", 979 | "dev": true 980 | }, 981 | "node_modules/@types/yargs": { 982 | "version": "17.0.24", 983 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.24.tgz", 984 | "integrity": "sha512-6i0aC7jV6QzQB8ne1joVZ0eSFIstHsCrobmOtghM11yGlH0j43FKL2UhWdELkyps0zuf7qVTUVCCR+tgSlyLLw==", 985 | "dev": true, 986 | "dependencies": { 987 | "@types/yargs-parser": "*" 988 | } 989 | }, 990 | "node_modules/@types/yargs-parser": { 991 | "version": "21.0.0", 992 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", 993 | "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", 994 | "dev": true 995 | }, 996 | "node_modules/ansi-escapes": { 997 | "version": "4.3.2", 998 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 999 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 1000 | "dev": true, 1001 | "dependencies": { 1002 | "type-fest": "^0.21.3" 1003 | }, 1004 | "engines": { 1005 | "node": ">=8" 1006 | }, 1007 | "funding": { 1008 | "url": "https://github.com/sponsors/sindresorhus" 1009 | } 1010 | }, 1011 | "node_modules/ansi-regex": { 1012 | "version": "5.0.1", 1013 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1014 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1015 | "dev": true, 1016 | "engines": { 1017 | "node": ">=8" 1018 | } 1019 | }, 1020 | "node_modules/ansi-styles": { 1021 | "version": "4.3.0", 1022 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1023 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1024 | "dev": true, 1025 | "dependencies": { 1026 | "color-convert": "^2.0.1" 1027 | }, 1028 | "engines": { 1029 | "node": ">=8" 1030 | }, 1031 | "funding": { 1032 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1033 | } 1034 | }, 1035 | "node_modules/anymatch": { 1036 | "version": "3.1.3", 1037 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1038 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1039 | "dev": true, 1040 | "dependencies": { 1041 | "normalize-path": "^3.0.0", 1042 | "picomatch": "^2.0.4" 1043 | }, 1044 | "engines": { 1045 | "node": ">= 8" 1046 | } 1047 | }, 1048 | "node_modules/argparse": { 1049 | "version": "1.0.10", 1050 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 1051 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 1052 | "dev": true, 1053 | "dependencies": { 1054 | "sprintf-js": "~1.0.2" 1055 | } 1056 | }, 1057 | "node_modules/asynckit": { 1058 | "version": "0.4.0", 1059 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 1060 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 1061 | }, 1062 | "node_modules/axios": { 1063 | "version": "1.7.9", 1064 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.9.tgz", 1065 | "integrity": "sha512-LhLcE7Hbiryz8oMDdDptSrWowmB4Bl6RCt6sIJKpRB4XtVf0iEgewX3au/pJqm+Py1kCASkb/FFKjxQaLtxJvw==", 1066 | "dependencies": { 1067 | "follow-redirects": "^1.15.6", 1068 | "form-data": "^4.0.0", 1069 | "proxy-from-env": "^1.1.0" 1070 | } 1071 | }, 1072 | "node_modules/babel-jest": { 1073 | "version": "29.6.1", 1074 | "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.6.1.tgz", 1075 | "integrity": "sha512-qu+3bdPEQC6KZSPz+4Fyjbga5OODNcp49j6GKzG1EKbkfyJBxEYGVUmVGpwCSeGouG52R4EgYMLb6p9YeEEQ4A==", 1076 | "dev": true, 1077 | "dependencies": { 1078 | "@jest/transform": "^29.6.1", 1079 | "@types/babel__core": "^7.1.14", 1080 | "babel-plugin-istanbul": "^6.1.1", 1081 | "babel-preset-jest": "^29.5.0", 1082 | "chalk": "^4.0.0", 1083 | "graceful-fs": "^4.2.9", 1084 | "slash": "^3.0.0" 1085 | }, 1086 | "engines": { 1087 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1088 | }, 1089 | "peerDependencies": { 1090 | "@babel/core": "^7.8.0" 1091 | } 1092 | }, 1093 | "node_modules/babel-plugin-istanbul": { 1094 | "version": "6.1.1", 1095 | "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", 1096 | "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", 1097 | "dev": true, 1098 | "dependencies": { 1099 | "@babel/helper-plugin-utils": "^7.0.0", 1100 | "@istanbuljs/load-nyc-config": "^1.0.0", 1101 | "@istanbuljs/schema": "^0.1.2", 1102 | "istanbul-lib-instrument": "^5.0.4", 1103 | "test-exclude": "^6.0.0" 1104 | }, 1105 | "engines": { 1106 | "node": ">=8" 1107 | } 1108 | }, 1109 | "node_modules/babel-plugin-jest-hoist": { 1110 | "version": "29.5.0", 1111 | "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-29.5.0.tgz", 1112 | "integrity": "sha512-zSuuuAlTMT4mzLj2nPnUm6fsE6270vdOfnpbJ+RmruU75UhLFvL0N2NgI7xpeS7NaB6hGqmd5pVpGTDYvi4Q3w==", 1113 | "dev": true, 1114 | "dependencies": { 1115 | "@babel/template": "^7.3.3", 1116 | "@babel/types": "^7.3.3", 1117 | "@types/babel__core": "^7.1.14", 1118 | "@types/babel__traverse": "^7.0.6" 1119 | }, 1120 | "engines": { 1121 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1122 | } 1123 | }, 1124 | "node_modules/babel-preset-current-node-syntax": { 1125 | "version": "1.0.1", 1126 | "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", 1127 | "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", 1128 | "dev": true, 1129 | "dependencies": { 1130 | "@babel/plugin-syntax-async-generators": "^7.8.4", 1131 | "@babel/plugin-syntax-bigint": "^7.8.3", 1132 | "@babel/plugin-syntax-class-properties": "^7.8.3", 1133 | "@babel/plugin-syntax-import-meta": "^7.8.3", 1134 | "@babel/plugin-syntax-json-strings": "^7.8.3", 1135 | "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", 1136 | "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", 1137 | "@babel/plugin-syntax-numeric-separator": "^7.8.3", 1138 | "@babel/plugin-syntax-object-rest-spread": "^7.8.3", 1139 | "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", 1140 | "@babel/plugin-syntax-optional-chaining": "^7.8.3", 1141 | "@babel/plugin-syntax-top-level-await": "^7.8.3" 1142 | }, 1143 | "peerDependencies": { 1144 | "@babel/core": "^7.0.0" 1145 | } 1146 | }, 1147 | "node_modules/babel-preset-jest": { 1148 | "version": "29.5.0", 1149 | "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-29.5.0.tgz", 1150 | "integrity": "sha512-JOMloxOqdiBSxMAzjRaH023/vvcaSaec49zvg+2LmNsktC7ei39LTJGw02J+9uUtTZUq6xbLyJ4dxe9sSmIuAg==", 1151 | "dev": true, 1152 | "dependencies": { 1153 | "babel-plugin-jest-hoist": "^29.5.0", 1154 | "babel-preset-current-node-syntax": "^1.0.0" 1155 | }, 1156 | "engines": { 1157 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1158 | }, 1159 | "peerDependencies": { 1160 | "@babel/core": "^7.0.0" 1161 | } 1162 | }, 1163 | "node_modules/balanced-match": { 1164 | "version": "1.0.2", 1165 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1166 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1167 | "dev": true 1168 | }, 1169 | "node_modules/brace-expansion": { 1170 | "version": "1.1.11", 1171 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1172 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1173 | "dev": true, 1174 | "dependencies": { 1175 | "balanced-match": "^1.0.0", 1176 | "concat-map": "0.0.1" 1177 | } 1178 | }, 1179 | "node_modules/braces": { 1180 | "version": "3.0.3", 1181 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 1182 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 1183 | "dev": true, 1184 | "dependencies": { 1185 | "fill-range": "^7.1.1" 1186 | }, 1187 | "engines": { 1188 | "node": ">=8" 1189 | } 1190 | }, 1191 | "node_modules/browserslist": { 1192 | "version": "4.21.9", 1193 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.9.tgz", 1194 | "integrity": "sha512-M0MFoZzbUrRU4KNfCrDLnvyE7gub+peetoTid3TBIqtunaDJyXlwhakT+/VkvSXcfIzFfK/nkCs4nmyTmxdNSg==", 1195 | "dev": true, 1196 | "funding": [ 1197 | { 1198 | "type": "opencollective", 1199 | "url": "https://opencollective.com/browserslist" 1200 | }, 1201 | { 1202 | "type": "tidelift", 1203 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1204 | }, 1205 | { 1206 | "type": "github", 1207 | "url": "https://github.com/sponsors/ai" 1208 | } 1209 | ], 1210 | "dependencies": { 1211 | "caniuse-lite": "^1.0.30001503", 1212 | "electron-to-chromium": "^1.4.431", 1213 | "node-releases": "^2.0.12", 1214 | "update-browserslist-db": "^1.0.11" 1215 | }, 1216 | "bin": { 1217 | "browserslist": "cli.js" 1218 | }, 1219 | "engines": { 1220 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1221 | } 1222 | }, 1223 | "node_modules/bser": { 1224 | "version": "2.1.1", 1225 | "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", 1226 | "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", 1227 | "dev": true, 1228 | "dependencies": { 1229 | "node-int64": "^0.4.0" 1230 | } 1231 | }, 1232 | "node_modules/buffer-from": { 1233 | "version": "1.1.2", 1234 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1235 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 1236 | "dev": true 1237 | }, 1238 | "node_modules/callsites": { 1239 | "version": "3.1.0", 1240 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1241 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1242 | "dev": true, 1243 | "engines": { 1244 | "node": ">=6" 1245 | } 1246 | }, 1247 | "node_modules/camelcase": { 1248 | "version": "5.3.1", 1249 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 1250 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 1251 | "dev": true, 1252 | "engines": { 1253 | "node": ">=6" 1254 | } 1255 | }, 1256 | "node_modules/caniuse-lite": { 1257 | "version": "1.0.30001517", 1258 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001517.tgz", 1259 | "integrity": "sha512-Vdhm5S11DaFVLlyiKu4hiUTkpZu+y1KA/rZZqVQfOD5YdDT/eQKlkt7NaE0WGOFgX32diqt9MiP9CAiFeRklaA==", 1260 | "dev": true, 1261 | "funding": [ 1262 | { 1263 | "type": "opencollective", 1264 | "url": "https://opencollective.com/browserslist" 1265 | }, 1266 | { 1267 | "type": "tidelift", 1268 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1269 | }, 1270 | { 1271 | "type": "github", 1272 | "url": "https://github.com/sponsors/ai" 1273 | } 1274 | ] 1275 | }, 1276 | "node_modules/chalk": { 1277 | "version": "4.1.2", 1278 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1279 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1280 | "dev": true, 1281 | "dependencies": { 1282 | "ansi-styles": "^4.1.0", 1283 | "supports-color": "^7.1.0" 1284 | }, 1285 | "engines": { 1286 | "node": ">=10" 1287 | }, 1288 | "funding": { 1289 | "url": "https://github.com/chalk/chalk?sponsor=1" 1290 | } 1291 | }, 1292 | "node_modules/char-regex": { 1293 | "version": "1.0.2", 1294 | "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", 1295 | "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", 1296 | "dev": true, 1297 | "engines": { 1298 | "node": ">=10" 1299 | } 1300 | }, 1301 | "node_modules/ci-info": { 1302 | "version": "3.8.0", 1303 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", 1304 | "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", 1305 | "dev": true, 1306 | "funding": [ 1307 | { 1308 | "type": "github", 1309 | "url": "https://github.com/sponsors/sibiraj-s" 1310 | } 1311 | ], 1312 | "engines": { 1313 | "node": ">=8" 1314 | } 1315 | }, 1316 | "node_modules/cjs-module-lexer": { 1317 | "version": "1.2.3", 1318 | "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.3.tgz", 1319 | "integrity": "sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ==", 1320 | "dev": true 1321 | }, 1322 | "node_modules/cliui": { 1323 | "version": "8.0.1", 1324 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 1325 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 1326 | "dev": true, 1327 | "dependencies": { 1328 | "string-width": "^4.2.0", 1329 | "strip-ansi": "^6.0.1", 1330 | "wrap-ansi": "^7.0.0" 1331 | }, 1332 | "engines": { 1333 | "node": ">=12" 1334 | } 1335 | }, 1336 | "node_modules/co": { 1337 | "version": "4.6.0", 1338 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 1339 | "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", 1340 | "dev": true, 1341 | "engines": { 1342 | "iojs": ">= 1.0.0", 1343 | "node": ">= 0.12.0" 1344 | } 1345 | }, 1346 | "node_modules/collect-v8-coverage": { 1347 | "version": "1.0.2", 1348 | "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.2.tgz", 1349 | "integrity": "sha512-lHl4d5/ONEbLlJvaJNtsF/Lz+WvB07u2ycqTYbdrq7UypDXailES4valYb2eWiJFxZlVmpGekfqoxQhzyFdT4Q==", 1350 | "dev": true 1351 | }, 1352 | "node_modules/color-convert": { 1353 | "version": "2.0.1", 1354 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1355 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1356 | "dev": true, 1357 | "dependencies": { 1358 | "color-name": "~1.1.4" 1359 | }, 1360 | "engines": { 1361 | "node": ">=7.0.0" 1362 | } 1363 | }, 1364 | "node_modules/color-name": { 1365 | "version": "1.1.4", 1366 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1367 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1368 | "dev": true 1369 | }, 1370 | "node_modules/combined-stream": { 1371 | "version": "1.0.8", 1372 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1373 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1374 | "dependencies": { 1375 | "delayed-stream": "~1.0.0" 1376 | }, 1377 | "engines": { 1378 | "node": ">= 0.8" 1379 | } 1380 | }, 1381 | "node_modules/concat-map": { 1382 | "version": "0.0.1", 1383 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1384 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1385 | "dev": true 1386 | }, 1387 | "node_modules/convert-source-map": { 1388 | "version": "2.0.0", 1389 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1390 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1391 | "dev": true 1392 | }, 1393 | "node_modules/cross-spawn": { 1394 | "version": "7.0.6", 1395 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", 1396 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", 1397 | "dev": true, 1398 | "dependencies": { 1399 | "path-key": "^3.1.0", 1400 | "shebang-command": "^2.0.0", 1401 | "which": "^2.0.1" 1402 | }, 1403 | "engines": { 1404 | "node": ">= 8" 1405 | } 1406 | }, 1407 | "node_modules/debug": { 1408 | "version": "4.3.4", 1409 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1410 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1411 | "dev": true, 1412 | "dependencies": { 1413 | "ms": "2.1.2" 1414 | }, 1415 | "engines": { 1416 | "node": ">=6.0" 1417 | }, 1418 | "peerDependenciesMeta": { 1419 | "supports-color": { 1420 | "optional": true 1421 | } 1422 | } 1423 | }, 1424 | "node_modules/dedent": { 1425 | "version": "0.7.0", 1426 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", 1427 | "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", 1428 | "dev": true 1429 | }, 1430 | "node_modules/deepmerge": { 1431 | "version": "4.3.1", 1432 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", 1433 | "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", 1434 | "dev": true, 1435 | "engines": { 1436 | "node": ">=0.10.0" 1437 | } 1438 | }, 1439 | "node_modules/delayed-stream": { 1440 | "version": "1.0.0", 1441 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1442 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 1443 | "engines": { 1444 | "node": ">=0.4.0" 1445 | } 1446 | }, 1447 | "node_modules/detect-newline": { 1448 | "version": "3.1.0", 1449 | "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", 1450 | "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", 1451 | "dev": true, 1452 | "engines": { 1453 | "node": ">=8" 1454 | } 1455 | }, 1456 | "node_modules/diff-sequences": { 1457 | "version": "29.4.3", 1458 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.4.3.tgz", 1459 | "integrity": "sha512-ofrBgwpPhCD85kMKtE9RYFFq6OC1A89oW2vvgWZNCwxrUpRUILopY7lsYyMDSjc8g6U6aiO0Qubg6r4Wgt5ZnA==", 1460 | "dev": true, 1461 | "engines": { 1462 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1463 | } 1464 | }, 1465 | "node_modules/electron-to-chromium": { 1466 | "version": "1.4.469", 1467 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.469.tgz", 1468 | "integrity": "sha512-HRN9XQjElxJBrdDky5iiUUr3eDwXGTg6Cp4IV8MuNc8VqMkYSneSnIe6poFKx9PsNzkudCgaWCBVxwDqirwQWQ==", 1469 | "dev": true 1470 | }, 1471 | "node_modules/emittery": { 1472 | "version": "0.13.1", 1473 | "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.13.1.tgz", 1474 | "integrity": "sha512-DeWwawk6r5yR9jFgnDKYt4sLS0LmHJJi3ZOnb5/JdbYwj3nW+FxQnHIjhBKz8YLC7oRNPVM9NQ47I3CVx34eqQ==", 1475 | "dev": true, 1476 | "engines": { 1477 | "node": ">=12" 1478 | }, 1479 | "funding": { 1480 | "url": "https://github.com/sindresorhus/emittery?sponsor=1" 1481 | } 1482 | }, 1483 | "node_modules/emoji-regex": { 1484 | "version": "8.0.0", 1485 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1486 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1487 | "dev": true 1488 | }, 1489 | "node_modules/error-ex": { 1490 | "version": "1.3.2", 1491 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 1492 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 1493 | "dev": true, 1494 | "dependencies": { 1495 | "is-arrayish": "^0.2.1" 1496 | } 1497 | }, 1498 | "node_modules/escalade": { 1499 | "version": "3.1.1", 1500 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1501 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1502 | "dev": true, 1503 | "engines": { 1504 | "node": ">=6" 1505 | } 1506 | }, 1507 | "node_modules/escape-string-regexp": { 1508 | "version": "2.0.0", 1509 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 1510 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 1511 | "dev": true, 1512 | "engines": { 1513 | "node": ">=8" 1514 | } 1515 | }, 1516 | "node_modules/esprima": { 1517 | "version": "4.0.1", 1518 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1519 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1520 | "dev": true, 1521 | "bin": { 1522 | "esparse": "bin/esparse.js", 1523 | "esvalidate": "bin/esvalidate.js" 1524 | }, 1525 | "engines": { 1526 | "node": ">=4" 1527 | } 1528 | }, 1529 | "node_modules/execa": { 1530 | "version": "5.1.1", 1531 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 1532 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 1533 | "dev": true, 1534 | "dependencies": { 1535 | "cross-spawn": "^7.0.3", 1536 | "get-stream": "^6.0.0", 1537 | "human-signals": "^2.1.0", 1538 | "is-stream": "^2.0.0", 1539 | "merge-stream": "^2.0.0", 1540 | "npm-run-path": "^4.0.1", 1541 | "onetime": "^5.1.2", 1542 | "signal-exit": "^3.0.3", 1543 | "strip-final-newline": "^2.0.0" 1544 | }, 1545 | "engines": { 1546 | "node": ">=10" 1547 | }, 1548 | "funding": { 1549 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 1550 | } 1551 | }, 1552 | "node_modules/exit": { 1553 | "version": "0.1.2", 1554 | "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", 1555 | "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", 1556 | "dev": true, 1557 | "engines": { 1558 | "node": ">= 0.8.0" 1559 | } 1560 | }, 1561 | "node_modules/expect": { 1562 | "version": "29.6.1", 1563 | "resolved": "https://registry.npmjs.org/expect/-/expect-29.6.1.tgz", 1564 | "integrity": "sha512-XEdDLonERCU1n9uR56/Stx9OqojaLAQtZf9PrCHH9Hl8YXiEIka3H4NXJ3NOIBmQJTg7+j7buh34PMHfJujc8g==", 1565 | "dev": true, 1566 | "dependencies": { 1567 | "@jest/expect-utils": "^29.6.1", 1568 | "@types/node": "*", 1569 | "jest-get-type": "^29.4.3", 1570 | "jest-matcher-utils": "^29.6.1", 1571 | "jest-message-util": "^29.6.1", 1572 | "jest-util": "^29.6.1" 1573 | }, 1574 | "engines": { 1575 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1576 | } 1577 | }, 1578 | "node_modules/fast-json-stable-stringify": { 1579 | "version": "2.1.0", 1580 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1581 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1582 | "dev": true 1583 | }, 1584 | "node_modules/fb-watchman": { 1585 | "version": "2.0.2", 1586 | "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", 1587 | "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", 1588 | "dev": true, 1589 | "dependencies": { 1590 | "bser": "2.1.1" 1591 | } 1592 | }, 1593 | "node_modules/fill-range": { 1594 | "version": "7.1.1", 1595 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 1596 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 1597 | "dev": true, 1598 | "dependencies": { 1599 | "to-regex-range": "^5.0.1" 1600 | }, 1601 | "engines": { 1602 | "node": ">=8" 1603 | } 1604 | }, 1605 | "node_modules/find-up": { 1606 | "version": "4.1.0", 1607 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 1608 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 1609 | "dev": true, 1610 | "dependencies": { 1611 | "locate-path": "^5.0.0", 1612 | "path-exists": "^4.0.0" 1613 | }, 1614 | "engines": { 1615 | "node": ">=8" 1616 | } 1617 | }, 1618 | "node_modules/follow-redirects": { 1619 | "version": "1.15.9", 1620 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", 1621 | "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", 1622 | "funding": [ 1623 | { 1624 | "type": "individual", 1625 | "url": "https://github.com/sponsors/RubenVerborgh" 1626 | } 1627 | ], 1628 | "engines": { 1629 | "node": ">=4.0" 1630 | }, 1631 | "peerDependenciesMeta": { 1632 | "debug": { 1633 | "optional": true 1634 | } 1635 | } 1636 | }, 1637 | "node_modules/form-data": { 1638 | "version": "4.0.1", 1639 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz", 1640 | "integrity": "sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==", 1641 | "dependencies": { 1642 | "asynckit": "^0.4.0", 1643 | "combined-stream": "^1.0.8", 1644 | "mime-types": "^2.1.12" 1645 | }, 1646 | "engines": { 1647 | "node": ">= 6" 1648 | } 1649 | }, 1650 | "node_modules/fs.realpath": { 1651 | "version": "1.0.0", 1652 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1653 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1654 | "dev": true 1655 | }, 1656 | "node_modules/fsevents": { 1657 | "version": "2.3.2", 1658 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1659 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1660 | "dev": true, 1661 | "hasInstallScript": true, 1662 | "optional": true, 1663 | "os": [ 1664 | "darwin" 1665 | ], 1666 | "engines": { 1667 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1668 | } 1669 | }, 1670 | "node_modules/function-bind": { 1671 | "version": "1.1.1", 1672 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1673 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1674 | "dev": true 1675 | }, 1676 | "node_modules/gensync": { 1677 | "version": "1.0.0-beta.2", 1678 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 1679 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 1680 | "dev": true, 1681 | "engines": { 1682 | "node": ">=6.9.0" 1683 | } 1684 | }, 1685 | "node_modules/get-caller-file": { 1686 | "version": "2.0.5", 1687 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1688 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1689 | "dev": true, 1690 | "engines": { 1691 | "node": "6.* || 8.* || >= 10.*" 1692 | } 1693 | }, 1694 | "node_modules/get-package-type": { 1695 | "version": "0.1.0", 1696 | "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", 1697 | "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", 1698 | "dev": true, 1699 | "engines": { 1700 | "node": ">=8.0.0" 1701 | } 1702 | }, 1703 | "node_modules/get-stream": { 1704 | "version": "6.0.1", 1705 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1706 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1707 | "dev": true, 1708 | "engines": { 1709 | "node": ">=10" 1710 | }, 1711 | "funding": { 1712 | "url": "https://github.com/sponsors/sindresorhus" 1713 | } 1714 | }, 1715 | "node_modules/glob": { 1716 | "version": "7.2.3", 1717 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1718 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1719 | "dev": true, 1720 | "dependencies": { 1721 | "fs.realpath": "^1.0.0", 1722 | "inflight": "^1.0.4", 1723 | "inherits": "2", 1724 | "minimatch": "^3.1.1", 1725 | "once": "^1.3.0", 1726 | "path-is-absolute": "^1.0.0" 1727 | }, 1728 | "engines": { 1729 | "node": "*" 1730 | }, 1731 | "funding": { 1732 | "url": "https://github.com/sponsors/isaacs" 1733 | } 1734 | }, 1735 | "node_modules/globals": { 1736 | "version": "11.12.0", 1737 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1738 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1739 | "dev": true, 1740 | "engines": { 1741 | "node": ">=4" 1742 | } 1743 | }, 1744 | "node_modules/graceful-fs": { 1745 | "version": "4.2.11", 1746 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1747 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1748 | "dev": true 1749 | }, 1750 | "node_modules/has": { 1751 | "version": "1.0.3", 1752 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1753 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1754 | "dev": true, 1755 | "dependencies": { 1756 | "function-bind": "^1.1.1" 1757 | }, 1758 | "engines": { 1759 | "node": ">= 0.4.0" 1760 | } 1761 | }, 1762 | "node_modules/has-flag": { 1763 | "version": "4.0.0", 1764 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1765 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1766 | "dev": true, 1767 | "engines": { 1768 | "node": ">=8" 1769 | } 1770 | }, 1771 | "node_modules/html-escaper": { 1772 | "version": "2.0.2", 1773 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1774 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1775 | "dev": true 1776 | }, 1777 | "node_modules/human-signals": { 1778 | "version": "2.1.0", 1779 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 1780 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 1781 | "dev": true, 1782 | "engines": { 1783 | "node": ">=10.17.0" 1784 | } 1785 | }, 1786 | "node_modules/import-local": { 1787 | "version": "3.1.0", 1788 | "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", 1789 | "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", 1790 | "dev": true, 1791 | "dependencies": { 1792 | "pkg-dir": "^4.2.0", 1793 | "resolve-cwd": "^3.0.0" 1794 | }, 1795 | "bin": { 1796 | "import-local-fixture": "fixtures/cli.js" 1797 | }, 1798 | "engines": { 1799 | "node": ">=8" 1800 | }, 1801 | "funding": { 1802 | "url": "https://github.com/sponsors/sindresorhus" 1803 | } 1804 | }, 1805 | "node_modules/imurmurhash": { 1806 | "version": "0.1.4", 1807 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1808 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1809 | "dev": true, 1810 | "engines": { 1811 | "node": ">=0.8.19" 1812 | } 1813 | }, 1814 | "node_modules/inflight": { 1815 | "version": "1.0.6", 1816 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1817 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1818 | "dev": true, 1819 | "dependencies": { 1820 | "once": "^1.3.0", 1821 | "wrappy": "1" 1822 | } 1823 | }, 1824 | "node_modules/inherits": { 1825 | "version": "2.0.4", 1826 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1827 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1828 | "dev": true 1829 | }, 1830 | "node_modules/is-arrayish": { 1831 | "version": "0.2.1", 1832 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1833 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", 1834 | "dev": true 1835 | }, 1836 | "node_modules/is-core-module": { 1837 | "version": "2.12.1", 1838 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", 1839 | "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", 1840 | "dev": true, 1841 | "dependencies": { 1842 | "has": "^1.0.3" 1843 | }, 1844 | "funding": { 1845 | "url": "https://github.com/sponsors/ljharb" 1846 | } 1847 | }, 1848 | "node_modules/is-fullwidth-code-point": { 1849 | "version": "3.0.0", 1850 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1851 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1852 | "dev": true, 1853 | "engines": { 1854 | "node": ">=8" 1855 | } 1856 | }, 1857 | "node_modules/is-generator-fn": { 1858 | "version": "2.1.0", 1859 | "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", 1860 | "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", 1861 | "dev": true, 1862 | "engines": { 1863 | "node": ">=6" 1864 | } 1865 | }, 1866 | "node_modules/is-number": { 1867 | "version": "7.0.0", 1868 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1869 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1870 | "dev": true, 1871 | "engines": { 1872 | "node": ">=0.12.0" 1873 | } 1874 | }, 1875 | "node_modules/is-stream": { 1876 | "version": "2.0.1", 1877 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 1878 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 1879 | "dev": true, 1880 | "engines": { 1881 | "node": ">=8" 1882 | }, 1883 | "funding": { 1884 | "url": "https://github.com/sponsors/sindresorhus" 1885 | } 1886 | }, 1887 | "node_modules/isbinaryfile": { 1888 | "version": "5.0.0", 1889 | "resolved": "https://registry.npmjs.org/isbinaryfile/-/isbinaryfile-5.0.0.tgz", 1890 | "integrity": "sha512-UDdnyGvMajJUWCkib7Cei/dvyJrrvo4FIrsvSFWdPpXSUorzXrDJ0S+X5Q4ZlasfPjca4yqCNNsjbCeiy8FFeg==", 1891 | "engines": { 1892 | "node": ">= 14.0.0" 1893 | }, 1894 | "funding": { 1895 | "url": "https://github.com/sponsors/gjtorikian/" 1896 | } 1897 | }, 1898 | "node_modules/isexe": { 1899 | "version": "2.0.0", 1900 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1901 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1902 | "dev": true 1903 | }, 1904 | "node_modules/istanbul-lib-coverage": { 1905 | "version": "3.2.0", 1906 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", 1907 | "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", 1908 | "dev": true, 1909 | "engines": { 1910 | "node": ">=8" 1911 | } 1912 | }, 1913 | "node_modules/istanbul-lib-instrument": { 1914 | "version": "5.2.1", 1915 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", 1916 | "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", 1917 | "dev": true, 1918 | "dependencies": { 1919 | "@babel/core": "^7.12.3", 1920 | "@babel/parser": "^7.14.7", 1921 | "@istanbuljs/schema": "^0.1.2", 1922 | "istanbul-lib-coverage": "^3.2.0", 1923 | "semver": "^6.3.0" 1924 | }, 1925 | "engines": { 1926 | "node": ">=8" 1927 | } 1928 | }, 1929 | "node_modules/istanbul-lib-report": { 1930 | "version": "3.0.0", 1931 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1932 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 1933 | "dev": true, 1934 | "dependencies": { 1935 | "istanbul-lib-coverage": "^3.0.0", 1936 | "make-dir": "^3.0.0", 1937 | "supports-color": "^7.1.0" 1938 | }, 1939 | "engines": { 1940 | "node": ">=8" 1941 | } 1942 | }, 1943 | "node_modules/istanbul-lib-source-maps": { 1944 | "version": "4.0.1", 1945 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", 1946 | "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", 1947 | "dev": true, 1948 | "dependencies": { 1949 | "debug": "^4.1.1", 1950 | "istanbul-lib-coverage": "^3.0.0", 1951 | "source-map": "^0.6.1" 1952 | }, 1953 | "engines": { 1954 | "node": ">=10" 1955 | } 1956 | }, 1957 | "node_modules/istanbul-reports": { 1958 | "version": "3.1.5", 1959 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", 1960 | "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", 1961 | "dev": true, 1962 | "dependencies": { 1963 | "html-escaper": "^2.0.0", 1964 | "istanbul-lib-report": "^3.0.0" 1965 | }, 1966 | "engines": { 1967 | "node": ">=8" 1968 | } 1969 | }, 1970 | "node_modules/jest": { 1971 | "version": "29.6.1", 1972 | "resolved": "https://registry.npmjs.org/jest/-/jest-29.6.1.tgz", 1973 | "integrity": "sha512-Nirw5B4nn69rVUZtemCQhwxOBhm0nsp3hmtF4rzCeWD7BkjAXRIji7xWQfnTNbz9g0aVsBX6aZK3n+23LM6uDw==", 1974 | "dev": true, 1975 | "dependencies": { 1976 | "@jest/core": "^29.6.1", 1977 | "@jest/types": "^29.6.1", 1978 | "import-local": "^3.0.2", 1979 | "jest-cli": "^29.6.1" 1980 | }, 1981 | "bin": { 1982 | "jest": "bin/jest.js" 1983 | }, 1984 | "engines": { 1985 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1986 | }, 1987 | "peerDependencies": { 1988 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 1989 | }, 1990 | "peerDependenciesMeta": { 1991 | "node-notifier": { 1992 | "optional": true 1993 | } 1994 | } 1995 | }, 1996 | "node_modules/jest-changed-files": { 1997 | "version": "29.5.0", 1998 | "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-29.5.0.tgz", 1999 | "integrity": "sha512-IFG34IUMUaNBIxjQXF/iu7g6EcdMrGRRxaUSw92I/2g2YC6vCdTltl4nHvt7Ci5nSJwXIkCu8Ka1DKF+X7Z1Ag==", 2000 | "dev": true, 2001 | "dependencies": { 2002 | "execa": "^5.0.0", 2003 | "p-limit": "^3.1.0" 2004 | }, 2005 | "engines": { 2006 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2007 | } 2008 | }, 2009 | "node_modules/jest-circus": { 2010 | "version": "29.6.1", 2011 | "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-29.6.1.tgz", 2012 | "integrity": "sha512-tPbYLEiBU4MYAL2XoZme/bgfUeotpDBd81lgHLCbDZZFaGmECk0b+/xejPFtmiBP87GgP/y4jplcRpbH+fgCzQ==", 2013 | "dev": true, 2014 | "dependencies": { 2015 | "@jest/environment": "^29.6.1", 2016 | "@jest/expect": "^29.6.1", 2017 | "@jest/test-result": "^29.6.1", 2018 | "@jest/types": "^29.6.1", 2019 | "@types/node": "*", 2020 | "chalk": "^4.0.0", 2021 | "co": "^4.6.0", 2022 | "dedent": "^0.7.0", 2023 | "is-generator-fn": "^2.0.0", 2024 | "jest-each": "^29.6.1", 2025 | "jest-matcher-utils": "^29.6.1", 2026 | "jest-message-util": "^29.6.1", 2027 | "jest-runtime": "^29.6.1", 2028 | "jest-snapshot": "^29.6.1", 2029 | "jest-util": "^29.6.1", 2030 | "p-limit": "^3.1.0", 2031 | "pretty-format": "^29.6.1", 2032 | "pure-rand": "^6.0.0", 2033 | "slash": "^3.0.0", 2034 | "stack-utils": "^2.0.3" 2035 | }, 2036 | "engines": { 2037 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2038 | } 2039 | }, 2040 | "node_modules/jest-cli": { 2041 | "version": "29.6.1", 2042 | "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-29.6.1.tgz", 2043 | "integrity": "sha512-607dSgTA4ODIN6go9w6xY3EYkyPFGicx51a69H7yfvt7lN53xNswEVLovq+E77VsTRi5fWprLH0yl4DJgE8Ing==", 2044 | "dev": true, 2045 | "dependencies": { 2046 | "@jest/core": "^29.6.1", 2047 | "@jest/test-result": "^29.6.1", 2048 | "@jest/types": "^29.6.1", 2049 | "chalk": "^4.0.0", 2050 | "exit": "^0.1.2", 2051 | "graceful-fs": "^4.2.9", 2052 | "import-local": "^3.0.2", 2053 | "jest-config": "^29.6.1", 2054 | "jest-util": "^29.6.1", 2055 | "jest-validate": "^29.6.1", 2056 | "prompts": "^2.0.1", 2057 | "yargs": "^17.3.1" 2058 | }, 2059 | "bin": { 2060 | "jest": "bin/jest.js" 2061 | }, 2062 | "engines": { 2063 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2064 | }, 2065 | "peerDependencies": { 2066 | "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" 2067 | }, 2068 | "peerDependenciesMeta": { 2069 | "node-notifier": { 2070 | "optional": true 2071 | } 2072 | } 2073 | }, 2074 | "node_modules/jest-config": { 2075 | "version": "29.6.1", 2076 | "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-29.6.1.tgz", 2077 | "integrity": "sha512-XdjYV2fy2xYixUiV2Wc54t3Z4oxYPAELUzWnV6+mcbq0rh742X2p52pii5A3oeRzYjLnQxCsZmp0qpI6klE2cQ==", 2078 | "dev": true, 2079 | "dependencies": { 2080 | "@babel/core": "^7.11.6", 2081 | "@jest/test-sequencer": "^29.6.1", 2082 | "@jest/types": "^29.6.1", 2083 | "babel-jest": "^29.6.1", 2084 | "chalk": "^4.0.0", 2085 | "ci-info": "^3.2.0", 2086 | "deepmerge": "^4.2.2", 2087 | "glob": "^7.1.3", 2088 | "graceful-fs": "^4.2.9", 2089 | "jest-circus": "^29.6.1", 2090 | "jest-environment-node": "^29.6.1", 2091 | "jest-get-type": "^29.4.3", 2092 | "jest-regex-util": "^29.4.3", 2093 | "jest-resolve": "^29.6.1", 2094 | "jest-runner": "^29.6.1", 2095 | "jest-util": "^29.6.1", 2096 | "jest-validate": "^29.6.1", 2097 | "micromatch": "^4.0.4", 2098 | "parse-json": "^5.2.0", 2099 | "pretty-format": "^29.6.1", 2100 | "slash": "^3.0.0", 2101 | "strip-json-comments": "^3.1.1" 2102 | }, 2103 | "engines": { 2104 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2105 | }, 2106 | "peerDependencies": { 2107 | "@types/node": "*", 2108 | "ts-node": ">=9.0.0" 2109 | }, 2110 | "peerDependenciesMeta": { 2111 | "@types/node": { 2112 | "optional": true 2113 | }, 2114 | "ts-node": { 2115 | "optional": true 2116 | } 2117 | } 2118 | }, 2119 | "node_modules/jest-diff": { 2120 | "version": "29.6.1", 2121 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-29.6.1.tgz", 2122 | "integrity": "sha512-FsNCvinvl8oVxpNLttNQX7FAq7vR+gMDGj90tiP7siWw1UdakWUGqrylpsYrpvj908IYckm5Y0Q7azNAozU1Kg==", 2123 | "dev": true, 2124 | "dependencies": { 2125 | "chalk": "^4.0.0", 2126 | "diff-sequences": "^29.4.3", 2127 | "jest-get-type": "^29.4.3", 2128 | "pretty-format": "^29.6.1" 2129 | }, 2130 | "engines": { 2131 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2132 | } 2133 | }, 2134 | "node_modules/jest-docblock": { 2135 | "version": "29.4.3", 2136 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-29.4.3.tgz", 2137 | "integrity": "sha512-fzdTftThczeSD9nZ3fzA/4KkHtnmllawWrXO69vtI+L9WjEIuXWs4AmyME7lN5hU7dB0sHhuPfcKofRsUb/2Fg==", 2138 | "dev": true, 2139 | "dependencies": { 2140 | "detect-newline": "^3.0.0" 2141 | }, 2142 | "engines": { 2143 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2144 | } 2145 | }, 2146 | "node_modules/jest-each": { 2147 | "version": "29.6.1", 2148 | "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-29.6.1.tgz", 2149 | "integrity": "sha512-n5eoj5eiTHpKQCAVcNTT7DRqeUmJ01hsAL0Q1SMiBHcBcvTKDELixQOGMCpqhbIuTcfC4kMfSnpmDqRgRJcLNQ==", 2150 | "dev": true, 2151 | "dependencies": { 2152 | "@jest/types": "^29.6.1", 2153 | "chalk": "^4.0.0", 2154 | "jest-get-type": "^29.4.3", 2155 | "jest-util": "^29.6.1", 2156 | "pretty-format": "^29.6.1" 2157 | }, 2158 | "engines": { 2159 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2160 | } 2161 | }, 2162 | "node_modules/jest-environment-node": { 2163 | "version": "29.6.1", 2164 | "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-29.6.1.tgz", 2165 | "integrity": "sha512-ZNIfAiE+foBog24W+2caIldl4Irh8Lx1PUhg/GZ0odM1d/h2qORAsejiFc7zb+SEmYPn1yDZzEDSU5PmDkmVLQ==", 2166 | "dev": true, 2167 | "dependencies": { 2168 | "@jest/environment": "^29.6.1", 2169 | "@jest/fake-timers": "^29.6.1", 2170 | "@jest/types": "^29.6.1", 2171 | "@types/node": "*", 2172 | "jest-mock": "^29.6.1", 2173 | "jest-util": "^29.6.1" 2174 | }, 2175 | "engines": { 2176 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2177 | } 2178 | }, 2179 | "node_modules/jest-get-type": { 2180 | "version": "29.4.3", 2181 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-29.4.3.tgz", 2182 | "integrity": "sha512-J5Xez4nRRMjk8emnTpWrlkyb9pfRQQanDrvWHhsR1+VUfbwxi30eVcZFlcdGInRibU4G5LwHXpI7IRHU0CY+gg==", 2183 | "dev": true, 2184 | "engines": { 2185 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2186 | } 2187 | }, 2188 | "node_modules/jest-haste-map": { 2189 | "version": "29.6.1", 2190 | "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-29.6.1.tgz", 2191 | "integrity": "sha512-0m7f9PZXxOCk1gRACiVgX85knUKPKLPg4oRCjLoqIm9brTHXaorMA0JpmtmVkQiT8nmXyIVoZd/nnH1cfC33ig==", 2192 | "dev": true, 2193 | "dependencies": { 2194 | "@jest/types": "^29.6.1", 2195 | "@types/graceful-fs": "^4.1.3", 2196 | "@types/node": "*", 2197 | "anymatch": "^3.0.3", 2198 | "fb-watchman": "^2.0.0", 2199 | "graceful-fs": "^4.2.9", 2200 | "jest-regex-util": "^29.4.3", 2201 | "jest-util": "^29.6.1", 2202 | "jest-worker": "^29.6.1", 2203 | "micromatch": "^4.0.4", 2204 | "walker": "^1.0.8" 2205 | }, 2206 | "engines": { 2207 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2208 | }, 2209 | "optionalDependencies": { 2210 | "fsevents": "^2.3.2" 2211 | } 2212 | }, 2213 | "node_modules/jest-leak-detector": { 2214 | "version": "29.6.1", 2215 | "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-29.6.1.tgz", 2216 | "integrity": "sha512-OrxMNyZirpOEwkF3UHnIkAiZbtkBWiye+hhBweCHkVbCgyEy71Mwbb5zgeTNYWJBi1qgDVfPC1IwO9dVEeTLwQ==", 2217 | "dev": true, 2218 | "dependencies": { 2219 | "jest-get-type": "^29.4.3", 2220 | "pretty-format": "^29.6.1" 2221 | }, 2222 | "engines": { 2223 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2224 | } 2225 | }, 2226 | "node_modules/jest-matcher-utils": { 2227 | "version": "29.6.1", 2228 | "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-29.6.1.tgz", 2229 | "integrity": "sha512-SLaztw9d2mfQQKHmJXKM0HCbl2PPVld/t9Xa6P9sgiExijviSp7TnZZpw2Fpt+OI3nwUO/slJbOfzfUMKKC5QA==", 2230 | "dev": true, 2231 | "dependencies": { 2232 | "chalk": "^4.0.0", 2233 | "jest-diff": "^29.6.1", 2234 | "jest-get-type": "^29.4.3", 2235 | "pretty-format": "^29.6.1" 2236 | }, 2237 | "engines": { 2238 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2239 | } 2240 | }, 2241 | "node_modules/jest-message-util": { 2242 | "version": "29.6.1", 2243 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-29.6.1.tgz", 2244 | "integrity": "sha512-KoAW2zAmNSd3Gk88uJ56qXUWbFk787QKmjjJVOjtGFmmGSZgDBrlIL4AfQw1xyMYPNVD7dNInfIbur9B2rd/wQ==", 2245 | "dev": true, 2246 | "dependencies": { 2247 | "@babel/code-frame": "^7.12.13", 2248 | "@jest/types": "^29.6.1", 2249 | "@types/stack-utils": "^2.0.0", 2250 | "chalk": "^4.0.0", 2251 | "graceful-fs": "^4.2.9", 2252 | "micromatch": "^4.0.4", 2253 | "pretty-format": "^29.6.1", 2254 | "slash": "^3.0.0", 2255 | "stack-utils": "^2.0.3" 2256 | }, 2257 | "engines": { 2258 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2259 | } 2260 | }, 2261 | "node_modules/jest-mock": { 2262 | "version": "29.6.1", 2263 | "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-29.6.1.tgz", 2264 | "integrity": "sha512-brovyV9HBkjXAEdRooaTQK42n8usKoSRR3gihzUpYeV/vwqgSoNfrksO7UfSACnPmxasO/8TmHM3w9Hp3G1dgw==", 2265 | "dev": true, 2266 | "dependencies": { 2267 | "@jest/types": "^29.6.1", 2268 | "@types/node": "*", 2269 | "jest-util": "^29.6.1" 2270 | }, 2271 | "engines": { 2272 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2273 | } 2274 | }, 2275 | "node_modules/jest-pnp-resolver": { 2276 | "version": "1.2.3", 2277 | "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", 2278 | "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", 2279 | "dev": true, 2280 | "engines": { 2281 | "node": ">=6" 2282 | }, 2283 | "peerDependencies": { 2284 | "jest-resolve": "*" 2285 | }, 2286 | "peerDependenciesMeta": { 2287 | "jest-resolve": { 2288 | "optional": true 2289 | } 2290 | } 2291 | }, 2292 | "node_modules/jest-regex-util": { 2293 | "version": "29.4.3", 2294 | "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-29.4.3.tgz", 2295 | "integrity": "sha512-O4FglZaMmWXbGHSQInfXewIsd1LMn9p3ZXB/6r4FOkyhX2/iP/soMG98jGvk/A3HAN78+5VWcBGO0BJAPRh4kg==", 2296 | "dev": true, 2297 | "engines": { 2298 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2299 | } 2300 | }, 2301 | "node_modules/jest-resolve": { 2302 | "version": "29.6.1", 2303 | "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-29.6.1.tgz", 2304 | "integrity": "sha512-AeRkyS8g37UyJiP9w3mmI/VXU/q8l/IH52vj/cDAyScDcemRbSBhfX/NMYIGilQgSVwsjxrCHf3XJu4f+lxCMg==", 2305 | "dev": true, 2306 | "dependencies": { 2307 | "chalk": "^4.0.0", 2308 | "graceful-fs": "^4.2.9", 2309 | "jest-haste-map": "^29.6.1", 2310 | "jest-pnp-resolver": "^1.2.2", 2311 | "jest-util": "^29.6.1", 2312 | "jest-validate": "^29.6.1", 2313 | "resolve": "^1.20.0", 2314 | "resolve.exports": "^2.0.0", 2315 | "slash": "^3.0.0" 2316 | }, 2317 | "engines": { 2318 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2319 | } 2320 | }, 2321 | "node_modules/jest-resolve-dependencies": { 2322 | "version": "29.6.1", 2323 | "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-29.6.1.tgz", 2324 | "integrity": "sha512-BbFvxLXtcldaFOhNMXmHRWx1nXQO5LoXiKSGQcA1LxxirYceZT6ch8KTE1bK3X31TNG/JbkI7OkS/ABexVahiw==", 2325 | "dev": true, 2326 | "dependencies": { 2327 | "jest-regex-util": "^29.4.3", 2328 | "jest-snapshot": "^29.6.1" 2329 | }, 2330 | "engines": { 2331 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2332 | } 2333 | }, 2334 | "node_modules/jest-runner": { 2335 | "version": "29.6.1", 2336 | "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-29.6.1.tgz", 2337 | "integrity": "sha512-tw0wb2Q9yhjAQ2w8rHRDxteryyIck7gIzQE4Reu3JuOBpGp96xWgF0nY8MDdejzrLCZKDcp8JlZrBN/EtkQvPQ==", 2338 | "dev": true, 2339 | "dependencies": { 2340 | "@jest/console": "^29.6.1", 2341 | "@jest/environment": "^29.6.1", 2342 | "@jest/test-result": "^29.6.1", 2343 | "@jest/transform": "^29.6.1", 2344 | "@jest/types": "^29.6.1", 2345 | "@types/node": "*", 2346 | "chalk": "^4.0.0", 2347 | "emittery": "^0.13.1", 2348 | "graceful-fs": "^4.2.9", 2349 | "jest-docblock": "^29.4.3", 2350 | "jest-environment-node": "^29.6.1", 2351 | "jest-haste-map": "^29.6.1", 2352 | "jest-leak-detector": "^29.6.1", 2353 | "jest-message-util": "^29.6.1", 2354 | "jest-resolve": "^29.6.1", 2355 | "jest-runtime": "^29.6.1", 2356 | "jest-util": "^29.6.1", 2357 | "jest-watcher": "^29.6.1", 2358 | "jest-worker": "^29.6.1", 2359 | "p-limit": "^3.1.0", 2360 | "source-map-support": "0.5.13" 2361 | }, 2362 | "engines": { 2363 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2364 | } 2365 | }, 2366 | "node_modules/jest-runtime": { 2367 | "version": "29.6.1", 2368 | "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-29.6.1.tgz", 2369 | "integrity": "sha512-D6/AYOA+Lhs5e5il8+5pSLemjtJezUr+8zx+Sn8xlmOux3XOqx4d8l/2udBea8CRPqqrzhsKUsN/gBDE/IcaPQ==", 2370 | "dev": true, 2371 | "dependencies": { 2372 | "@jest/environment": "^29.6.1", 2373 | "@jest/fake-timers": "^29.6.1", 2374 | "@jest/globals": "^29.6.1", 2375 | "@jest/source-map": "^29.6.0", 2376 | "@jest/test-result": "^29.6.1", 2377 | "@jest/transform": "^29.6.1", 2378 | "@jest/types": "^29.6.1", 2379 | "@types/node": "*", 2380 | "chalk": "^4.0.0", 2381 | "cjs-module-lexer": "^1.0.0", 2382 | "collect-v8-coverage": "^1.0.0", 2383 | "glob": "^7.1.3", 2384 | "graceful-fs": "^4.2.9", 2385 | "jest-haste-map": "^29.6.1", 2386 | "jest-message-util": "^29.6.1", 2387 | "jest-mock": "^29.6.1", 2388 | "jest-regex-util": "^29.4.3", 2389 | "jest-resolve": "^29.6.1", 2390 | "jest-snapshot": "^29.6.1", 2391 | "jest-util": "^29.6.1", 2392 | "slash": "^3.0.0", 2393 | "strip-bom": "^4.0.0" 2394 | }, 2395 | "engines": { 2396 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2397 | } 2398 | }, 2399 | "node_modules/jest-snapshot": { 2400 | "version": "29.6.1", 2401 | "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-29.6.1.tgz", 2402 | "integrity": "sha512-G4UQE1QQ6OaCgfY+A0uR1W2AY0tGXUPQpoUClhWHq1Xdnx1H6JOrC2nH5lqnOEqaDgbHFgIwZ7bNq24HpB180A==", 2403 | "dev": true, 2404 | "dependencies": { 2405 | "@babel/core": "^7.11.6", 2406 | "@babel/generator": "^7.7.2", 2407 | "@babel/plugin-syntax-jsx": "^7.7.2", 2408 | "@babel/plugin-syntax-typescript": "^7.7.2", 2409 | "@babel/types": "^7.3.3", 2410 | "@jest/expect-utils": "^29.6.1", 2411 | "@jest/transform": "^29.6.1", 2412 | "@jest/types": "^29.6.1", 2413 | "@types/prettier": "^2.1.5", 2414 | "babel-preset-current-node-syntax": "^1.0.0", 2415 | "chalk": "^4.0.0", 2416 | "expect": "^29.6.1", 2417 | "graceful-fs": "^4.2.9", 2418 | "jest-diff": "^29.6.1", 2419 | "jest-get-type": "^29.4.3", 2420 | "jest-matcher-utils": "^29.6.1", 2421 | "jest-message-util": "^29.6.1", 2422 | "jest-util": "^29.6.1", 2423 | "natural-compare": "^1.4.0", 2424 | "pretty-format": "^29.6.1", 2425 | "semver": "^7.5.3" 2426 | }, 2427 | "engines": { 2428 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2429 | } 2430 | }, 2431 | "node_modules/jest-snapshot/node_modules/lru-cache": { 2432 | "version": "6.0.0", 2433 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2434 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2435 | "dev": true, 2436 | "dependencies": { 2437 | "yallist": "^4.0.0" 2438 | }, 2439 | "engines": { 2440 | "node": ">=10" 2441 | } 2442 | }, 2443 | "node_modules/jest-snapshot/node_modules/semver": { 2444 | "version": "7.5.4", 2445 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 2446 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 2447 | "dev": true, 2448 | "dependencies": { 2449 | "lru-cache": "^6.0.0" 2450 | }, 2451 | "bin": { 2452 | "semver": "bin/semver.js" 2453 | }, 2454 | "engines": { 2455 | "node": ">=10" 2456 | } 2457 | }, 2458 | "node_modules/jest-snapshot/node_modules/yallist": { 2459 | "version": "4.0.0", 2460 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2461 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2462 | "dev": true 2463 | }, 2464 | "node_modules/jest-util": { 2465 | "version": "29.6.1", 2466 | "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-29.6.1.tgz", 2467 | "integrity": "sha512-NRFCcjc+/uO3ijUVyNOQJluf8PtGCe/W6cix36+M3cTFgiYqFOOW5MgN4JOOcvbUhcKTYVd1CvHz/LWi8d16Mg==", 2468 | "dev": true, 2469 | "dependencies": { 2470 | "@jest/types": "^29.6.1", 2471 | "@types/node": "*", 2472 | "chalk": "^4.0.0", 2473 | "ci-info": "^3.2.0", 2474 | "graceful-fs": "^4.2.9", 2475 | "picomatch": "^2.2.3" 2476 | }, 2477 | "engines": { 2478 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2479 | } 2480 | }, 2481 | "node_modules/jest-validate": { 2482 | "version": "29.6.1", 2483 | "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-29.6.1.tgz", 2484 | "integrity": "sha512-r3Ds69/0KCN4vx4sYAbGL1EVpZ7MSS0vLmd3gV78O+NAx3PDQQukRU5hNHPXlyqCgFY8XUk7EuTMLugh0KzahA==", 2485 | "dev": true, 2486 | "dependencies": { 2487 | "@jest/types": "^29.6.1", 2488 | "camelcase": "^6.2.0", 2489 | "chalk": "^4.0.0", 2490 | "jest-get-type": "^29.4.3", 2491 | "leven": "^3.1.0", 2492 | "pretty-format": "^29.6.1" 2493 | }, 2494 | "engines": { 2495 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2496 | } 2497 | }, 2498 | "node_modules/jest-validate/node_modules/camelcase": { 2499 | "version": "6.3.0", 2500 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 2501 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 2502 | "dev": true, 2503 | "engines": { 2504 | "node": ">=10" 2505 | }, 2506 | "funding": { 2507 | "url": "https://github.com/sponsors/sindresorhus" 2508 | } 2509 | }, 2510 | "node_modules/jest-watcher": { 2511 | "version": "29.6.1", 2512 | "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-29.6.1.tgz", 2513 | "integrity": "sha512-d4wpjWTS7HEZPaaj8m36QiaP856JthRZkrgcIY/7ISoUWPIillrXM23WPboZVLbiwZBt4/qn2Jke84Sla6JhFA==", 2514 | "dev": true, 2515 | "dependencies": { 2516 | "@jest/test-result": "^29.6.1", 2517 | "@jest/types": "^29.6.1", 2518 | "@types/node": "*", 2519 | "ansi-escapes": "^4.2.1", 2520 | "chalk": "^4.0.0", 2521 | "emittery": "^0.13.1", 2522 | "jest-util": "^29.6.1", 2523 | "string-length": "^4.0.1" 2524 | }, 2525 | "engines": { 2526 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2527 | } 2528 | }, 2529 | "node_modules/jest-worker": { 2530 | "version": "29.6.1", 2531 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-29.6.1.tgz", 2532 | "integrity": "sha512-U+Wrbca7S8ZAxAe9L6nb6g8kPdia5hj32Puu5iOqBCMTMWFHXuK6dOV2IFrpedbTV8fjMFLdWNttQTBL6u2MRA==", 2533 | "dev": true, 2534 | "dependencies": { 2535 | "@types/node": "*", 2536 | "jest-util": "^29.6.1", 2537 | "merge-stream": "^2.0.0", 2538 | "supports-color": "^8.0.0" 2539 | }, 2540 | "engines": { 2541 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2542 | } 2543 | }, 2544 | "node_modules/jest-worker/node_modules/supports-color": { 2545 | "version": "8.1.1", 2546 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2547 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2548 | "dev": true, 2549 | "dependencies": { 2550 | "has-flag": "^4.0.0" 2551 | }, 2552 | "engines": { 2553 | "node": ">=10" 2554 | }, 2555 | "funding": { 2556 | "url": "https://github.com/chalk/supports-color?sponsor=1" 2557 | } 2558 | }, 2559 | "node_modules/joi": { 2560 | "version": "17.13.3", 2561 | "resolved": "https://registry.npmjs.org/joi/-/joi-17.13.3.tgz", 2562 | "integrity": "sha512-otDA4ldcIx+ZXsKHWmp0YizCweVRZG96J10b0FevjfuncLO1oX59THoAmHkNubYJ+9gWsYsp5k8v4ib6oDv1fA==", 2563 | "dependencies": { 2564 | "@hapi/hoek": "^9.3.0", 2565 | "@hapi/topo": "^5.1.0", 2566 | "@sideway/address": "^4.1.5", 2567 | "@sideway/formula": "^3.0.1", 2568 | "@sideway/pinpoint": "^2.0.0" 2569 | } 2570 | }, 2571 | "node_modules/js-tokens": { 2572 | "version": "4.0.0", 2573 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2574 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2575 | "dev": true 2576 | }, 2577 | "node_modules/js-yaml": { 2578 | "version": "3.14.1", 2579 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2580 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2581 | "dev": true, 2582 | "dependencies": { 2583 | "argparse": "^1.0.7", 2584 | "esprima": "^4.0.0" 2585 | }, 2586 | "bin": { 2587 | "js-yaml": "bin/js-yaml.js" 2588 | } 2589 | }, 2590 | "node_modules/jsesc": { 2591 | "version": "3.1.0", 2592 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", 2593 | "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", 2594 | "dev": true, 2595 | "bin": { 2596 | "jsesc": "bin/jsesc" 2597 | }, 2598 | "engines": { 2599 | "node": ">=6" 2600 | } 2601 | }, 2602 | "node_modules/json-parse-even-better-errors": { 2603 | "version": "2.3.1", 2604 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 2605 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", 2606 | "dev": true 2607 | }, 2608 | "node_modules/json5": { 2609 | "version": "2.2.3", 2610 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 2611 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 2612 | "dev": true, 2613 | "bin": { 2614 | "json5": "lib/cli.js" 2615 | }, 2616 | "engines": { 2617 | "node": ">=6" 2618 | } 2619 | }, 2620 | "node_modules/kleur": { 2621 | "version": "3.0.3", 2622 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", 2623 | "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", 2624 | "dev": true, 2625 | "engines": { 2626 | "node": ">=6" 2627 | } 2628 | }, 2629 | "node_modules/leven": { 2630 | "version": "3.1.0", 2631 | "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", 2632 | "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", 2633 | "dev": true, 2634 | "engines": { 2635 | "node": ">=6" 2636 | } 2637 | }, 2638 | "node_modules/lines-and-columns": { 2639 | "version": "1.2.4", 2640 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 2641 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 2642 | "dev": true 2643 | }, 2644 | "node_modules/locate-path": { 2645 | "version": "5.0.0", 2646 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2647 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2648 | "dev": true, 2649 | "dependencies": { 2650 | "p-locate": "^4.1.0" 2651 | }, 2652 | "engines": { 2653 | "node": ">=8" 2654 | } 2655 | }, 2656 | "node_modules/lodash": { 2657 | "version": "4.17.21", 2658 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2659 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 2660 | }, 2661 | "node_modules/lru-cache": { 2662 | "version": "5.1.1", 2663 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2664 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2665 | "dev": true, 2666 | "dependencies": { 2667 | "yallist": "^3.0.2" 2668 | } 2669 | }, 2670 | "node_modules/make-dir": { 2671 | "version": "3.1.0", 2672 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2673 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2674 | "dev": true, 2675 | "dependencies": { 2676 | "semver": "^6.0.0" 2677 | }, 2678 | "engines": { 2679 | "node": ">=8" 2680 | }, 2681 | "funding": { 2682 | "url": "https://github.com/sponsors/sindresorhus" 2683 | } 2684 | }, 2685 | "node_modules/makeerror": { 2686 | "version": "1.0.12", 2687 | "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", 2688 | "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", 2689 | "dev": true, 2690 | "dependencies": { 2691 | "tmpl": "1.0.5" 2692 | } 2693 | }, 2694 | "node_modules/merge-stream": { 2695 | "version": "2.0.0", 2696 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2697 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2698 | "dev": true 2699 | }, 2700 | "node_modules/micromatch": { 2701 | "version": "4.0.8", 2702 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", 2703 | "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", 2704 | "dev": true, 2705 | "dependencies": { 2706 | "braces": "^3.0.3", 2707 | "picomatch": "^2.3.1" 2708 | }, 2709 | "engines": { 2710 | "node": ">=8.6" 2711 | } 2712 | }, 2713 | "node_modules/mime-db": { 2714 | "version": "1.52.0", 2715 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2716 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 2717 | "engines": { 2718 | "node": ">= 0.6" 2719 | } 2720 | }, 2721 | "node_modules/mime-types": { 2722 | "version": "2.1.35", 2723 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2724 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2725 | "dependencies": { 2726 | "mime-db": "1.52.0" 2727 | }, 2728 | "engines": { 2729 | "node": ">= 0.6" 2730 | } 2731 | }, 2732 | "node_modules/mimic-fn": { 2733 | "version": "2.1.0", 2734 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2735 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2736 | "dev": true, 2737 | "engines": { 2738 | "node": ">=6" 2739 | } 2740 | }, 2741 | "node_modules/minimatch": { 2742 | "version": "3.1.2", 2743 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2744 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2745 | "dev": true, 2746 | "dependencies": { 2747 | "brace-expansion": "^1.1.7" 2748 | }, 2749 | "engines": { 2750 | "node": "*" 2751 | } 2752 | }, 2753 | "node_modules/minimist": { 2754 | "version": "1.2.8", 2755 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2756 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 2757 | "funding": { 2758 | "url": "https://github.com/sponsors/ljharb" 2759 | } 2760 | }, 2761 | "node_modules/ms": { 2762 | "version": "2.1.2", 2763 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2764 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2765 | "dev": true 2766 | }, 2767 | "node_modules/natural-compare": { 2768 | "version": "1.4.0", 2769 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2770 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2771 | "dev": true 2772 | }, 2773 | "node_modules/node-int64": { 2774 | "version": "0.4.0", 2775 | "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", 2776 | "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", 2777 | "dev": true 2778 | }, 2779 | "node_modules/node-releases": { 2780 | "version": "2.0.13", 2781 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz", 2782 | "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==", 2783 | "dev": true 2784 | }, 2785 | "node_modules/normalize-path": { 2786 | "version": "3.0.0", 2787 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2788 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2789 | "dev": true, 2790 | "engines": { 2791 | "node": ">=0.10.0" 2792 | } 2793 | }, 2794 | "node_modules/npm-run-path": { 2795 | "version": "4.0.1", 2796 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 2797 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 2798 | "dev": true, 2799 | "dependencies": { 2800 | "path-key": "^3.0.0" 2801 | }, 2802 | "engines": { 2803 | "node": ">=8" 2804 | } 2805 | }, 2806 | "node_modules/once": { 2807 | "version": "1.4.0", 2808 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2809 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2810 | "dev": true, 2811 | "dependencies": { 2812 | "wrappy": "1" 2813 | } 2814 | }, 2815 | "node_modules/onetime": { 2816 | "version": "5.1.2", 2817 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 2818 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 2819 | "dev": true, 2820 | "dependencies": { 2821 | "mimic-fn": "^2.1.0" 2822 | }, 2823 | "engines": { 2824 | "node": ">=6" 2825 | }, 2826 | "funding": { 2827 | "url": "https://github.com/sponsors/sindresorhus" 2828 | } 2829 | }, 2830 | "node_modules/p-limit": { 2831 | "version": "3.1.0", 2832 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2833 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2834 | "dev": true, 2835 | "dependencies": { 2836 | "yocto-queue": "^0.1.0" 2837 | }, 2838 | "engines": { 2839 | "node": ">=10" 2840 | }, 2841 | "funding": { 2842 | "url": "https://github.com/sponsors/sindresorhus" 2843 | } 2844 | }, 2845 | "node_modules/p-locate": { 2846 | "version": "4.1.0", 2847 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2848 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2849 | "dev": true, 2850 | "dependencies": { 2851 | "p-limit": "^2.2.0" 2852 | }, 2853 | "engines": { 2854 | "node": ">=8" 2855 | } 2856 | }, 2857 | "node_modules/p-locate/node_modules/p-limit": { 2858 | "version": "2.3.0", 2859 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2860 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2861 | "dev": true, 2862 | "dependencies": { 2863 | "p-try": "^2.0.0" 2864 | }, 2865 | "engines": { 2866 | "node": ">=6" 2867 | }, 2868 | "funding": { 2869 | "url": "https://github.com/sponsors/sindresorhus" 2870 | } 2871 | }, 2872 | "node_modules/p-try": { 2873 | "version": "2.2.0", 2874 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 2875 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 2876 | "dev": true, 2877 | "engines": { 2878 | "node": ">=6" 2879 | } 2880 | }, 2881 | "node_modules/parse-json": { 2882 | "version": "5.2.0", 2883 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 2884 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 2885 | "dev": true, 2886 | "dependencies": { 2887 | "@babel/code-frame": "^7.0.0", 2888 | "error-ex": "^1.3.1", 2889 | "json-parse-even-better-errors": "^2.3.0", 2890 | "lines-and-columns": "^1.1.6" 2891 | }, 2892 | "engines": { 2893 | "node": ">=8" 2894 | }, 2895 | "funding": { 2896 | "url": "https://github.com/sponsors/sindresorhus" 2897 | } 2898 | }, 2899 | "node_modules/path-exists": { 2900 | "version": "4.0.0", 2901 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2902 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2903 | "dev": true, 2904 | "engines": { 2905 | "node": ">=8" 2906 | } 2907 | }, 2908 | "node_modules/path-is-absolute": { 2909 | "version": "1.0.1", 2910 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2911 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2912 | "dev": true, 2913 | "engines": { 2914 | "node": ">=0.10.0" 2915 | } 2916 | }, 2917 | "node_modules/path-key": { 2918 | "version": "3.1.1", 2919 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2920 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2921 | "dev": true, 2922 | "engines": { 2923 | "node": ">=8" 2924 | } 2925 | }, 2926 | "node_modules/path-parse": { 2927 | "version": "1.0.7", 2928 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2929 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2930 | "dev": true 2931 | }, 2932 | "node_modules/picocolors": { 2933 | "version": "1.0.0", 2934 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2935 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 2936 | "dev": true 2937 | }, 2938 | "node_modules/picomatch": { 2939 | "version": "2.3.1", 2940 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2941 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2942 | "dev": true, 2943 | "engines": { 2944 | "node": ">=8.6" 2945 | }, 2946 | "funding": { 2947 | "url": "https://github.com/sponsors/jonschlinkert" 2948 | } 2949 | }, 2950 | "node_modules/pirates": { 2951 | "version": "4.0.6", 2952 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", 2953 | "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", 2954 | "dev": true, 2955 | "engines": { 2956 | "node": ">= 6" 2957 | } 2958 | }, 2959 | "node_modules/pkg-dir": { 2960 | "version": "4.2.0", 2961 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 2962 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 2963 | "dev": true, 2964 | "dependencies": { 2965 | "find-up": "^4.0.0" 2966 | }, 2967 | "engines": { 2968 | "node": ">=8" 2969 | } 2970 | }, 2971 | "node_modules/pretty-format": { 2972 | "version": "29.6.1", 2973 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.6.1.tgz", 2974 | "integrity": "sha512-7jRj+yXO0W7e4/tSJKoR7HRIHLPPjtNaUGG2xxKQnGvPNRkgWcQ0AZX6P4KBRJN4FcTBWb3sa7DVUJmocYuoog==", 2975 | "dev": true, 2976 | "dependencies": { 2977 | "@jest/schemas": "^29.6.0", 2978 | "ansi-styles": "^5.0.0", 2979 | "react-is": "^18.0.0" 2980 | }, 2981 | "engines": { 2982 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2983 | } 2984 | }, 2985 | "node_modules/pretty-format/node_modules/ansi-styles": { 2986 | "version": "5.2.0", 2987 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 2988 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 2989 | "dev": true, 2990 | "engines": { 2991 | "node": ">=10" 2992 | }, 2993 | "funding": { 2994 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2995 | } 2996 | }, 2997 | "node_modules/prompts": { 2998 | "version": "2.4.2", 2999 | "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", 3000 | "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", 3001 | "dev": true, 3002 | "dependencies": { 3003 | "kleur": "^3.0.3", 3004 | "sisteransi": "^1.0.5" 3005 | }, 3006 | "engines": { 3007 | "node": ">= 6" 3008 | } 3009 | }, 3010 | "node_modules/proxy-from-env": { 3011 | "version": "1.1.0", 3012 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 3013 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 3014 | }, 3015 | "node_modules/pure-rand": { 3016 | "version": "6.0.2", 3017 | "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.2.tgz", 3018 | "integrity": "sha512-6Yg0ekpKICSjPswYOuC5sku/TSWaRYlA0qsXqJgM/d/4pLPHPuTxK7Nbf7jFKzAeedUhR8C7K9Uv63FBsSo8xQ==", 3019 | "dev": true, 3020 | "funding": [ 3021 | { 3022 | "type": "individual", 3023 | "url": "https://github.com/sponsors/dubzzz" 3024 | }, 3025 | { 3026 | "type": "opencollective", 3027 | "url": "https://opencollective.com/fast-check" 3028 | } 3029 | ] 3030 | }, 3031 | "node_modules/react-is": { 3032 | "version": "18.2.0", 3033 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", 3034 | "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==", 3035 | "dev": true 3036 | }, 3037 | "node_modules/require-directory": { 3038 | "version": "2.1.1", 3039 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3040 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 3041 | "dev": true, 3042 | "engines": { 3043 | "node": ">=0.10.0" 3044 | } 3045 | }, 3046 | "node_modules/resolve": { 3047 | "version": "1.22.2", 3048 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", 3049 | "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", 3050 | "dev": true, 3051 | "dependencies": { 3052 | "is-core-module": "^2.11.0", 3053 | "path-parse": "^1.0.7", 3054 | "supports-preserve-symlinks-flag": "^1.0.0" 3055 | }, 3056 | "bin": { 3057 | "resolve": "bin/resolve" 3058 | }, 3059 | "funding": { 3060 | "url": "https://github.com/sponsors/ljharb" 3061 | } 3062 | }, 3063 | "node_modules/resolve-cwd": { 3064 | "version": "3.0.0", 3065 | "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", 3066 | "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", 3067 | "dev": true, 3068 | "dependencies": { 3069 | "resolve-from": "^5.0.0" 3070 | }, 3071 | "engines": { 3072 | "node": ">=8" 3073 | } 3074 | }, 3075 | "node_modules/resolve-from": { 3076 | "version": "5.0.0", 3077 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 3078 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 3079 | "dev": true, 3080 | "engines": { 3081 | "node": ">=8" 3082 | } 3083 | }, 3084 | "node_modules/resolve.exports": { 3085 | "version": "2.0.2", 3086 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", 3087 | "integrity": "sha512-X2UW6Nw3n/aMgDVy+0rSqgHlv39WZAlZrXCdnbyEiKm17DSqHX4MmQMaST3FbeWR5FTuRcUwYAziZajji0Y7mg==", 3088 | "dev": true, 3089 | "engines": { 3090 | "node": ">=10" 3091 | } 3092 | }, 3093 | "node_modules/rxjs": { 3094 | "version": "7.8.1", 3095 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.1.tgz", 3096 | "integrity": "sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==", 3097 | "dependencies": { 3098 | "tslib": "^2.1.0" 3099 | } 3100 | }, 3101 | "node_modules/semver": { 3102 | "version": "6.3.1", 3103 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 3104 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 3105 | "dev": true, 3106 | "bin": { 3107 | "semver": "bin/semver.js" 3108 | } 3109 | }, 3110 | "node_modules/shebang-command": { 3111 | "version": "2.0.0", 3112 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3113 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3114 | "dev": true, 3115 | "dependencies": { 3116 | "shebang-regex": "^3.0.0" 3117 | }, 3118 | "engines": { 3119 | "node": ">=8" 3120 | } 3121 | }, 3122 | "node_modules/shebang-regex": { 3123 | "version": "3.0.0", 3124 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3125 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3126 | "dev": true, 3127 | "engines": { 3128 | "node": ">=8" 3129 | } 3130 | }, 3131 | "node_modules/signal-exit": { 3132 | "version": "3.0.7", 3133 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 3134 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 3135 | "dev": true 3136 | }, 3137 | "node_modules/sisteransi": { 3138 | "version": "1.0.5", 3139 | "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", 3140 | "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", 3141 | "dev": true 3142 | }, 3143 | "node_modules/slash": { 3144 | "version": "3.0.0", 3145 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3146 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3147 | "dev": true, 3148 | "engines": { 3149 | "node": ">=8" 3150 | } 3151 | }, 3152 | "node_modules/source-map": { 3153 | "version": "0.6.1", 3154 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3155 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3156 | "dev": true, 3157 | "engines": { 3158 | "node": ">=0.10.0" 3159 | } 3160 | }, 3161 | "node_modules/source-map-support": { 3162 | "version": "0.5.13", 3163 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz", 3164 | "integrity": "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==", 3165 | "dev": true, 3166 | "dependencies": { 3167 | "buffer-from": "^1.0.0", 3168 | "source-map": "^0.6.0" 3169 | } 3170 | }, 3171 | "node_modules/sprintf-js": { 3172 | "version": "1.0.3", 3173 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3174 | "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", 3175 | "dev": true 3176 | }, 3177 | "node_modules/stack-utils": { 3178 | "version": "2.0.6", 3179 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", 3180 | "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", 3181 | "dev": true, 3182 | "dependencies": { 3183 | "escape-string-regexp": "^2.0.0" 3184 | }, 3185 | "engines": { 3186 | "node": ">=10" 3187 | } 3188 | }, 3189 | "node_modules/string-length": { 3190 | "version": "4.0.2", 3191 | "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", 3192 | "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", 3193 | "dev": true, 3194 | "dependencies": { 3195 | "char-regex": "^1.0.2", 3196 | "strip-ansi": "^6.0.0" 3197 | }, 3198 | "engines": { 3199 | "node": ">=10" 3200 | } 3201 | }, 3202 | "node_modules/string-width": { 3203 | "version": "4.2.3", 3204 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3205 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3206 | "dev": true, 3207 | "dependencies": { 3208 | "emoji-regex": "^8.0.0", 3209 | "is-fullwidth-code-point": "^3.0.0", 3210 | "strip-ansi": "^6.0.1" 3211 | }, 3212 | "engines": { 3213 | "node": ">=8" 3214 | } 3215 | }, 3216 | "node_modules/strip-ansi": { 3217 | "version": "6.0.1", 3218 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3219 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3220 | "dev": true, 3221 | "dependencies": { 3222 | "ansi-regex": "^5.0.1" 3223 | }, 3224 | "engines": { 3225 | "node": ">=8" 3226 | } 3227 | }, 3228 | "node_modules/strip-bom": { 3229 | "version": "4.0.0", 3230 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 3231 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 3232 | "dev": true, 3233 | "engines": { 3234 | "node": ">=8" 3235 | } 3236 | }, 3237 | "node_modules/strip-final-newline": { 3238 | "version": "2.0.0", 3239 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 3240 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 3241 | "dev": true, 3242 | "engines": { 3243 | "node": ">=6" 3244 | } 3245 | }, 3246 | "node_modules/strip-json-comments": { 3247 | "version": "3.1.1", 3248 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3249 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3250 | "dev": true, 3251 | "engines": { 3252 | "node": ">=8" 3253 | }, 3254 | "funding": { 3255 | "url": "https://github.com/sponsors/sindresorhus" 3256 | } 3257 | }, 3258 | "node_modules/supports-color": { 3259 | "version": "7.2.0", 3260 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3261 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3262 | "dev": true, 3263 | "dependencies": { 3264 | "has-flag": "^4.0.0" 3265 | }, 3266 | "engines": { 3267 | "node": ">=8" 3268 | } 3269 | }, 3270 | "node_modules/supports-preserve-symlinks-flag": { 3271 | "version": "1.0.0", 3272 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3273 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3274 | "dev": true, 3275 | "engines": { 3276 | "node": ">= 0.4" 3277 | }, 3278 | "funding": { 3279 | "url": "https://github.com/sponsors/ljharb" 3280 | } 3281 | }, 3282 | "node_modules/test-exclude": { 3283 | "version": "6.0.0", 3284 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 3285 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 3286 | "dev": true, 3287 | "dependencies": { 3288 | "@istanbuljs/schema": "^0.1.2", 3289 | "glob": "^7.1.4", 3290 | "minimatch": "^3.0.4" 3291 | }, 3292 | "engines": { 3293 | "node": ">=8" 3294 | } 3295 | }, 3296 | "node_modules/tmpl": { 3297 | "version": "1.0.5", 3298 | "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", 3299 | "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", 3300 | "dev": true 3301 | }, 3302 | "node_modules/to-regex-range": { 3303 | "version": "5.0.1", 3304 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3305 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3306 | "dev": true, 3307 | "dependencies": { 3308 | "is-number": "^7.0.0" 3309 | }, 3310 | "engines": { 3311 | "node": ">=8.0" 3312 | } 3313 | }, 3314 | "node_modules/tslib": { 3315 | "version": "2.6.0", 3316 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.0.tgz", 3317 | "integrity": "sha512-7At1WUettjcSRHXCyYtTselblcHl9PJFFVKiCAy/bY97+BPZXSQ2wbq0P9s8tK2G7dFQfNnlJnPAiArVBVBsfA==" 3318 | }, 3319 | "node_modules/type-detect": { 3320 | "version": "4.0.8", 3321 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3322 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3323 | "dev": true, 3324 | "engines": { 3325 | "node": ">=4" 3326 | } 3327 | }, 3328 | "node_modules/type-fest": { 3329 | "version": "0.21.3", 3330 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 3331 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 3332 | "dev": true, 3333 | "engines": { 3334 | "node": ">=10" 3335 | }, 3336 | "funding": { 3337 | "url": "https://github.com/sponsors/sindresorhus" 3338 | } 3339 | }, 3340 | "node_modules/update-browserslist-db": { 3341 | "version": "1.0.11", 3342 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", 3343 | "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", 3344 | "dev": true, 3345 | "funding": [ 3346 | { 3347 | "type": "opencollective", 3348 | "url": "https://opencollective.com/browserslist" 3349 | }, 3350 | { 3351 | "type": "tidelift", 3352 | "url": "https://tidelift.com/funding/github/npm/browserslist" 3353 | }, 3354 | { 3355 | "type": "github", 3356 | "url": "https://github.com/sponsors/ai" 3357 | } 3358 | ], 3359 | "dependencies": { 3360 | "escalade": "^3.1.1", 3361 | "picocolors": "^1.0.0" 3362 | }, 3363 | "bin": { 3364 | "update-browserslist-db": "cli.js" 3365 | }, 3366 | "peerDependencies": { 3367 | "browserslist": ">= 4.21.0" 3368 | } 3369 | }, 3370 | "node_modules/v8-to-istanbul": { 3371 | "version": "9.1.0", 3372 | "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.1.0.tgz", 3373 | "integrity": "sha512-6z3GW9x8G1gd+JIIgQQQxXuiJtCXeAjp6RaPEPLv62mH3iPHPxV6W3robxtCzNErRo6ZwTmzWhsbNvjyEBKzKA==", 3374 | "dev": true, 3375 | "dependencies": { 3376 | "@jridgewell/trace-mapping": "^0.3.12", 3377 | "@types/istanbul-lib-coverage": "^2.0.1", 3378 | "convert-source-map": "^1.6.0" 3379 | }, 3380 | "engines": { 3381 | "node": ">=10.12.0" 3382 | } 3383 | }, 3384 | "node_modules/v8-to-istanbul/node_modules/convert-source-map": { 3385 | "version": "1.9.0", 3386 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 3387 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", 3388 | "dev": true 3389 | }, 3390 | "node_modules/wait-on": { 3391 | "version": "7.2.0", 3392 | "resolved": "https://registry.npmjs.org/wait-on/-/wait-on-7.2.0.tgz", 3393 | "integrity": "sha512-wCQcHkRazgjG5XoAq9jbTMLpNIjoSlZslrJ2+N9MxDsGEv1HnFoVjOCexL0ESva7Y9cu350j+DWADdk54s4AFQ==", 3394 | "dependencies": { 3395 | "axios": "^1.6.1", 3396 | "joi": "^17.11.0", 3397 | "lodash": "^4.17.21", 3398 | "minimist": "^1.2.8", 3399 | "rxjs": "^7.8.1" 3400 | }, 3401 | "bin": { 3402 | "wait-on": "bin/wait-on" 3403 | }, 3404 | "engines": { 3405 | "node": ">=12.0.0" 3406 | } 3407 | }, 3408 | "node_modules/walker": { 3409 | "version": "1.0.8", 3410 | "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", 3411 | "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", 3412 | "dev": true, 3413 | "dependencies": { 3414 | "makeerror": "1.0.12" 3415 | } 3416 | }, 3417 | "node_modules/which": { 3418 | "version": "2.0.2", 3419 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3420 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3421 | "dev": true, 3422 | "dependencies": { 3423 | "isexe": "^2.0.0" 3424 | }, 3425 | "bin": { 3426 | "node-which": "bin/node-which" 3427 | }, 3428 | "engines": { 3429 | "node": ">= 8" 3430 | } 3431 | }, 3432 | "node_modules/wrap-ansi": { 3433 | "version": "7.0.0", 3434 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3435 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3436 | "dev": true, 3437 | "dependencies": { 3438 | "ansi-styles": "^4.0.0", 3439 | "string-width": "^4.1.0", 3440 | "strip-ansi": "^6.0.0" 3441 | }, 3442 | "engines": { 3443 | "node": ">=10" 3444 | }, 3445 | "funding": { 3446 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3447 | } 3448 | }, 3449 | "node_modules/wrappy": { 3450 | "version": "1.0.2", 3451 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3452 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3453 | "dev": true 3454 | }, 3455 | "node_modules/write-file-atomic": { 3456 | "version": "4.0.2", 3457 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", 3458 | "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", 3459 | "dev": true, 3460 | "dependencies": { 3461 | "imurmurhash": "^0.1.4", 3462 | "signal-exit": "^3.0.7" 3463 | }, 3464 | "engines": { 3465 | "node": "^12.13.0 || ^14.15.0 || >=16.0.0" 3466 | } 3467 | }, 3468 | "node_modules/y18n": { 3469 | "version": "5.0.8", 3470 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3471 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3472 | "dev": true, 3473 | "engines": { 3474 | "node": ">=10" 3475 | } 3476 | }, 3477 | "node_modules/yallist": { 3478 | "version": "3.1.1", 3479 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 3480 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 3481 | "dev": true 3482 | }, 3483 | "node_modules/yargs": { 3484 | "version": "17.7.2", 3485 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 3486 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 3487 | "dev": true, 3488 | "dependencies": { 3489 | "cliui": "^8.0.1", 3490 | "escalade": "^3.1.1", 3491 | "get-caller-file": "^2.0.5", 3492 | "require-directory": "^2.1.1", 3493 | "string-width": "^4.2.3", 3494 | "y18n": "^5.0.5", 3495 | "yargs-parser": "^21.1.1" 3496 | }, 3497 | "engines": { 3498 | "node": ">=12" 3499 | } 3500 | }, 3501 | "node_modules/yargs-parser": { 3502 | "version": "21.1.1", 3503 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 3504 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 3505 | "dev": true, 3506 | "engines": { 3507 | "node": ">=12" 3508 | } 3509 | }, 3510 | "node_modules/yocto-queue": { 3511 | "version": "0.1.0", 3512 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3513 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3514 | "dev": true, 3515 | "engines": { 3516 | "node": ">=10" 3517 | }, 3518 | "funding": { 3519 | "url": "https://github.com/sponsors/sindresorhus" 3520 | } 3521 | } 3522 | } 3523 | } 3524 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "serverlesswp", 3 | "version": "0.3.3", 4 | "description": "Run PHP on Lambda (AWS, Netlify, Vercel)", 5 | "keywords": [ 6 | "serverless", 7 | "wordpress", 8 | "php", 9 | "netlify", 10 | "vercel" 11 | ], 12 | "homepage": "https://github.com/mitchmac/serverlesswp-node#readme", 13 | "main": "src/index.js", 14 | "author": "Mitch MacKenzie", 15 | "license": "MIT", 16 | "repository": { 17 | "type": "git", 18 | "url": "https://github.com/mitchmac/serverlesswp-node.git" 19 | }, 20 | "dependencies": { 21 | "isbinaryfile": "^5.0.0", 22 | "wait-on": "^7.0.1" 23 | }, 24 | "devDependencies": { 25 | "jest": "^29.5.0" 26 | }, 27 | "scripts": { 28 | "test": "jest --testPathIgnorePatterns 'e2e'", 29 | "local-tests": "npm run test && cd tests/e2e && ./local.sh" 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /php-files/exts/opcache.so: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/exts/opcache.so -------------------------------------------------------------------------------- /php-files/lib/libbrotlicommon.so.1: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libbrotlicommon.so.1 -------------------------------------------------------------------------------- /php-files/lib/libbrotlidec.so.1: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libbrotlidec.so.1 -------------------------------------------------------------------------------- /php-files/lib/libcrypt.so.2: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libcrypt.so.2 -------------------------------------------------------------------------------- /php-files/lib/libfreetype.so.6: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libfreetype.so.6 -------------------------------------------------------------------------------- /php-files/lib/libgraphite2.so.3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libgraphite2.so.3 -------------------------------------------------------------------------------- /php-files/lib/libharfbuzz.so.0: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libharfbuzz.so.0 -------------------------------------------------------------------------------- /php-files/lib/libonig.so.5: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libonig.so.5 -------------------------------------------------------------------------------- /php-files/lib/libpng16.so.16: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libpng16.so.16 -------------------------------------------------------------------------------- /php-files/lib/libsqlite3.so.0: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libsqlite3.so.0 -------------------------------------------------------------------------------- /php-files/lib/libzip.so.5: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/lib/libzip.so.5 -------------------------------------------------------------------------------- /php-files/php: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/mitchmac/serverlesswp-node/5831df0e36f49bb18eff92e826d9855b90ff1f73/php-files/php -------------------------------------------------------------------------------- /php-files/php.ini: -------------------------------------------------------------------------------- 1 | extension_dir="exts" 2 | zend_extension="opcache.so" 3 | 4 | opcache.enable=1 5 | opcache.enable_cli=1 6 | post_max_size=6M 7 | upload_max_filesize=6M 8 | 9 | openssl.cafile=/etc/pki/tls/certs/ca-bundle.crt 10 | openssl.capath=/etc/pki/tls/certs -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | # ServerlessWP 2 | Serverless PHP on AWS Lambda, Vercel or Netlify 3 | 4 | Just want to get started with WordPress? 5 | 6 | Try the [WordPress starter project](https://github.com/mitchmac/serverlesswp)! 7 | 8 | | Netlify | Vercel | 9 | | --- | --- | 10 | | [![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/mitchmac/serverlesswp) |[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2Fmitchmac%2Fserverlesswp) | 11 | 12 | 13 | ## Overview 14 | 15 | This is the library that powers ServerlessWP but it can also be used standalone to execute PHP in Lambda functions. 16 | 17 | ServerlessWP includes PHP 8.1 with common extensions and libraries required by WordPress to run in the serverless function Node.js runtimes of Vercel and Netlify. 18 | 19 | ## Usage 20 | ``` 21 | npm i serverlesswp 22 | ``` 23 | 24 | Then in your project's function directory use the ServerlessWP library in a file like api/index.js: 25 | 26 | ```javascript 27 | const path = require('path'); 28 | const serverlesswp = require('serverlesswp'); 29 | 30 | exports.handler = async function (event, context, callback) { 31 | const pathToWP = path.join(process.cwd(), 'wp'); 32 | 33 | return await serverlesswp({docRoot: pathToWP, event: event}); 34 | } 35 | ``` 36 | 37 | Where 38 | 39 | * docRoot is the path to WordPress files 40 | * event is the serverless event data from Vercel or Netlify 41 | 42 | ## License 43 | MIT 44 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | const { spawn } = require('child_process'); 3 | const fs = require('fs').promises; 4 | const { URL } = require('node:url'); 5 | 6 | const waitOn = require('wait-on'); 7 | const isBinaryFile = require("isbinaryfile").isBinaryFile; 8 | 9 | let php; 10 | let serverReady = false; 11 | 12 | const libPath = path.resolve(__dirname, '../php-files/lib'); 13 | const phpPath = path.resolve(__dirname, '../php-files/php'); 14 | const phpIniPath = path.resolve(__dirname, '../php-files/php.ini'); 15 | const cwd = path.resolve(__dirname, '../php-files'); 16 | 17 | const plugins = require('./plugins'); 18 | 19 | async function handler(data) { 20 | await validate(data); 21 | 22 | const { event, docRoot } = data; 23 | 24 | const preRequestResponse = await plugins.executePreRequest(event); 25 | if (preRequestResponse != null) { 26 | return preRequestResponse; 27 | } 28 | 29 | if (!php) { 30 | const env = { 31 | ...process.env, 32 | LD_LIBRARY_PATH: `${libPath}:${process.env['LD_LIBRARY_PATH']}`, 33 | LD_PRELOAD: `${libPath}/libsqlite3.so.0` 34 | }; 35 | 36 | //@TODO: configurable php.ini path 37 | let phpArgs = ['-S', '127.0.0.1:8000', '-t', docRoot, '-c', phpIniPath]; 38 | 39 | if (data.routerScript) { 40 | phpArgs.push(data.routerScript); 41 | } 42 | 43 | php = spawn(phpPath, phpArgs, { 44 | env: env, 45 | cwd: cwd 46 | }); 47 | 48 | php.stdout.on('data', data => { 49 | console.log(data.toString()); 50 | }); 51 | 52 | php.on('error', function (err) { 53 | console.log(err); 54 | }); 55 | 56 | php.stderr.on('data', data => { 57 | console.log(data.toString()); 58 | }); 59 | } 60 | 61 | try { 62 | if (!serverReady) { 63 | const waitOnOpts = { 64 | resources: [ 65 | 'tcp:127.0.0.1:8000' 66 | ], 67 | interval: 5, // poll interval in ms 68 | timeout: 9000, // timeout in ms 69 | }; 70 | await waitOn(waitOnOpts); 71 | serverReady = true; 72 | } 73 | 74 | // Netlify: event.rawQuery 75 | // Vercel: query string is included with event.path 76 | let queryString = ''; 77 | if (event.rawQuery) { 78 | queryString = `?${event.rawQuery}`; 79 | } 80 | 81 | // AWS 82 | if (event.rawQueryString) { 83 | queryString = `?${event.rawQueryString}`; 84 | } 85 | 86 | let body = ''; 87 | if (event.body) { 88 | if (event.isBase64Encoded) { 89 | body = Buffer.from(event.body, 'base64'); 90 | } 91 | else { 92 | body = event.body; 93 | } 94 | } 95 | 96 | let urlPath = ''; 97 | // Vercel & Netlify. 98 | if (event.path) { 99 | urlPath = event.path; 100 | } 101 | 102 | // AWS. 103 | if (event.rawPath && !urlPath) { 104 | urlPath = event.rawPath; 105 | } 106 | 107 | let requestHeaders = {}; 108 | if (event.cookies) { 109 | let cookielist = ''; 110 | for (var i = 0; i < event.cookies.length; i++) { 111 | cookielist += event.cookies[i] + '; '; 112 | } 113 | cookielist = cookielist.slice(0, -2); 114 | requestHeaders = { ...event.headers, Cookie: cookielist }; 115 | } 116 | else { 117 | requestHeaders = event.headers; 118 | } 119 | 120 | // fetch drops host. We have to grab it on the other side. 121 | if (requestHeaders?.host) { 122 | requestHeaders.injectHost = requestHeaders.host; 123 | } 124 | 125 | // Similar workaround here, follow: https://github.com/nodejs/undici/issues/4144 126 | if (requestHeaders && requestHeaders['transfer-encoding']) { 127 | delete requestHeaders['transfer-encoding']; 128 | } 129 | 130 | let requestMethod = 'GET'; 131 | 132 | // Vercel & Netlify. 133 | if (event.httpMethod) { 134 | requestMethod = event.httpMethod 135 | } 136 | 137 | // AWS 138 | if (event.requestContext?.http?.method) { 139 | requestMethod = event.requestContext.http.method; 140 | } 141 | 142 | const url = `http://127.0.0.1:8000${urlPath}${queryString}`; 143 | 144 | let fetchOpts = { 145 | method: requestMethod, 146 | headers: requestHeaders, 147 | redirect: 'manual', 148 | compress: false 149 | }; 150 | 151 | if (body) { 152 | fetchOpts.body = body; 153 | } 154 | 155 | const response = await fetch(url, fetchOpts); 156 | 157 | let headers = {}; 158 | let responseCookies = []; 159 | 160 | response.headers.forEach((value, name) => { 161 | if (name != 'set-cookie') { 162 | headers[name] = value; 163 | } 164 | else { 165 | responseCookies.push(value); 166 | } 167 | }); 168 | 169 | const responseBuffer = await response.arrayBuffer(); 170 | 171 | let base64Encoded = false; 172 | let responseBody; 173 | 174 | const isBin = await isBinaryFile(Buffer.from(responseBuffer)); 175 | 176 | if (isBin || headers['content-type'] === 'font/woff2') { 177 | responseBody = Buffer.from(responseBuffer).toString('base64'); 178 | base64Encoded = true; 179 | headers['x-serverlesswp-binary'] = 'true'; 180 | } 181 | else { 182 | responseBody = Buffer.from(responseBuffer).toString('utf8'); 183 | headers['x-serverlesswp-binary'] = 'false'; 184 | } 185 | 186 | if (headers['location']) { 187 | if (headers['location'].indexOf('http://127.0.0.1:8000') !== -1) { 188 | headers['location'] = headers['location'].replace('http://127.0.0.1:8000', ''); 189 | } 190 | } 191 | 192 | if (!headers['cache-control'] && response.status === 200 && (!data.hasOwnProperty('skipCacheControl') || (data.hasOwnProperty('skipCacheControl') && !data.skipCacheControl))) { 193 | let cacheControl = 'max-age=3600, s-maxage=86400'; 194 | 195 | if (data.defaultCacheControl) { 196 | cacheControl = data.defaultCacheControl; 197 | } 198 | 199 | if (shouldCacheControl(url)) { 200 | headers['cache-control'] = cacheControl; 201 | } 202 | } 203 | 204 | let returnResponse = { 205 | statusCode: response.status || 200, 206 | headers: headers, 207 | body: responseBody, 208 | isBase64Encoded: base64Encoded, 209 | encoding: base64Encoded ? 'base64' : 'utf8' 210 | }; 211 | 212 | if (responseCookies.length) { 213 | // Vercel 214 | if (process.env['VERCEL']) { 215 | returnResponse.headers['set-cookie'] = responseCookies; 216 | } 217 | 218 | // Netlify 219 | if (process.env['SITE_NAME']) { 220 | // @TODO: does this need to be imploded? 221 | returnResponse.multiValueHeaders = {}; 222 | returnResponse.multiValueHeaders['set-cookie'] = responseCookies; 223 | } 224 | 225 | // AWS 226 | if (!process.env['VERCEL'] && !process.env['SITE_NAME']) { 227 | returnResponse.cookies = responseCookies; 228 | } 229 | } 230 | 231 | return await plugins.executePostRequest(event, returnResponse); 232 | } 233 | catch (err) { 234 | console.log(err); 235 | } 236 | 237 | return { 238 | statusCode: 500, 239 | body: 'There was a problem, check your function logs for clues.' 240 | } 241 | } 242 | 243 | //@TODO: tests 244 | function shouldCacheControl(url) { 245 | const parsedUrl = new URL(url); 246 | if (parsedUrl.pathname.match(/\.(js|css|svg|png|gif|txt|jpg|jpeg|webp|woff|woff2|ico|otf)$/gi)) { 247 | return true; 248 | } 249 | return false; 250 | } 251 | 252 | async function validate(data) { 253 | if (!data.hasOwnProperty("event")) { 254 | throw new Error("The event property is required."); 255 | } 256 | else if (!data.event) { 257 | throw new Error("The event property cannot be empty."); 258 | } 259 | 260 | if (!data.hasOwnProperty("docRoot")) { 261 | throw new Error("The docRoot or routerScript property is required."); 262 | } 263 | 264 | const docRootExists = await exists(data.docRoot); 265 | if (!docRootExists) { 266 | throw new Error("The docRoot property is not a valid path."); 267 | } 268 | 269 | if (data.hasOwnProperty("routerScript")) { 270 | const routerExists = await exists(data.routerScript); 271 | if (!routerExists) { 272 | throw new Error("The routerScript property is not a valid path."); 273 | } 274 | } 275 | } 276 | 277 | async function exists(path) { 278 | try { 279 | await fs.access(path); 280 | return true; 281 | } catch (error) { 282 | return false; 283 | } 284 | } 285 | 286 | module.exports = handler; 287 | module.exports.validate = validate; 288 | module.exports.registerPlugin = plugins.register; 289 | module.exports.getPlugins = plugins.getPlugins; -------------------------------------------------------------------------------- /src/plugins.js: -------------------------------------------------------------------------------- 1 | let plugins = []; 2 | let hooks = ["preRequest", "postRequest"]; 3 | let hookTracker = {}; 4 | 5 | function register(plugin) { 6 | // Require a plugin name. 7 | if (!plugin.hasOwnProperty("name") || !plugin.name) { 8 | throw new Error("Plugins are required to have a name"); 9 | } 10 | 11 | // Don't allow double registration. 12 | if (plugins.find((plug) => plug.name === plugin.name)) { 13 | throw new Error("Plugins can only be registered once"); 14 | } 15 | 16 | plugins.push(plugin); 17 | 18 | // Register each hook implementation. 19 | for (const hook of hooks) { 20 | if (typeof plugin[hook] === 'function') { 21 | if (!hookTracker[hook]) { 22 | hookTracker[hook] = []; 23 | } 24 | hookTracker[hook].push(plugin.name); 25 | } 26 | } 27 | } 28 | 29 | function getPlugins() { 30 | return plugins; 31 | } 32 | 33 | function getPluginByName(name) { 34 | return plugins.find(plugin => plugin.name === name); 35 | } 36 | 37 | async function executePreRequest(event) { 38 | let response = null; 39 | if (hookTracker["preRequest"]) { 40 | for (const pluginName of hookTracker["preRequest"]) { 41 | let plugin = getPluginByName(pluginName); 42 | response = await plugin.preRequest(event, response); 43 | } 44 | } 45 | 46 | //@TODO: validate response 47 | return response; 48 | } 49 | 50 | async function executePostRequest(event, response) { 51 | if (hookTracker["postRequest"]) { 52 | for (const pluginName of hookTracker["postRequest"]) { 53 | let plugin = getPluginByName(pluginName); 54 | let pluginResponse; 55 | 56 | pluginResponse = await plugin.postRequest(event, response); 57 | if (pluginResponse) { 58 | response = pluginResponse; 59 | } 60 | } 61 | } 62 | 63 | //@TODO: validate response 64 | return response; 65 | } 66 | 67 | module.exports.register = register; 68 | module.exports.getPlugins = getPlugins; 69 | module.exports.executePreRequest = executePreRequest; 70 | module.exports.executePostRequest = executePostRequest; -------------------------------------------------------------------------------- /tests/e2e/Dockerfile: -------------------------------------------------------------------------------- 1 | FROM public.ecr.aws/lambda/nodejs:22 2 | 3 | COPY temp/package.json temp/package-lock.json ${LAMBDA_TASK_ROOT}/ 4 | RUN npm config set update-notifier false 5 | RUN npm install --omit=optional --omit=dev --verbose 6 | 7 | COPY temp/src ${LAMBDA_TASK_ROOT}/src 8 | COPY temp/php-files ${LAMBDA_TASK_ROOT}/php-files 9 | COPY temp/index.php ${LAMBDA_TASK_ROOT}/wp/ 10 | COPY temp/static.css ${LAMBDA_TASK_ROOT}/wp/ 11 | COPY temp/rss.png ${LAMBDA_TASK_ROOT}/wp/ 12 | COPY router.php ${LAMBDA_TASK_ROOT}/ 13 | COPY test.js ${LAMBDA_TASK_ROOT}/ 14 | 15 | CMD [ "test.handler" ] -------------------------------------------------------------------------------- /tests/e2e/build-test.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | mkdir temp || rm -rf temp/* 4 | 5 | cp -r ../../src/ ../../php-files ../../package.json ../../package-lock.json index.php router.php static.css rss.png temp 6 | 7 | docker build --no-cache --progress=plain -t docker-lambda-serverlesswp . 8 | 9 | rm -rf temp -------------------------------------------------------------------------------- /tests/e2e/index.php: -------------------------------------------------------------------------------- 1 | { 4 | test('Error with missing event property', () => { 5 | const args = {docRoot: '/'} 6 | expect(async () => await serverlesswp.validate(args)).rejects.toThrow(); 7 | }); 8 | 9 | test('Error with empty event property', () => { 10 | const args = {event: '', docRoot: '/'} 11 | expect(async () => await serverlesswp.validate(args)).rejects.toThrow(); 12 | }); 13 | 14 | test('Error with missing docRoot', () => { 15 | const args = {event: 'test'} 16 | expect(async () => await serverlesswp.validate(args)).rejects.toThrow(); 17 | }); 18 | 19 | test('Error with invalid docRoot property', () => { 20 | const args = {event: {}, docRoot: '/invalid'} 21 | expect(async () => await serverlesswp.validate(args)).rejects.toThrow(); 22 | }); 23 | 24 | test('Error with invalid routerScript property', () => { 25 | const args = {event: {}, docRoot: '/', routerScript: '/invalid'} 26 | expect(async () => await serverlesswp.validate(args)).rejects.toThrow(); 27 | }); 28 | 29 | test('Plugin registration', () => { 30 | serverlesswp.registerPlugin({name: 'foo'}); 31 | serverlesswp.registerPlugin({name: 'bar'}); 32 | 33 | const plugins = serverlesswp.getPlugins(); 34 | expect(plugins).toHaveLength(2); 35 | }); 36 | }); 37 | -------------------------------------------------------------------------------- /tests/plugins.test.js: -------------------------------------------------------------------------------- 1 | describe('Plugins tests', () => { 2 | beforeEach(() => { 3 | jest.resetModules(); 4 | }); 5 | 6 | test('Plugin registration', () => { 7 | const plugins = require('../src/plugins'); 8 | 9 | plugins.register({name: 'foo'}); 10 | plugins.register({name: 'bar'}); 11 | 12 | const pluginList = plugins.getPlugins(); 13 | expect(pluginList).toHaveLength(2); 14 | }); 15 | 16 | test('Plugins need a name', () => { 17 | const plugins = require('../src/plugins'); 18 | 19 | expect(() => { plugins.register({}) }).toThrow(); 20 | expect(() => { plugins.register({name: ''}) }).toThrow(); 21 | }); 22 | 23 | test('Plugins can only be registered once', () => { 24 | const plugins = require('../src/plugins'); 25 | 26 | plugins.register({name: 'baz'}); 27 | expect(() => { plugins.register({name: 'baz'}) }).toThrow(); 28 | }); 29 | 30 | test('Do not execute non-existent preRequest', async () => { 31 | const plugins = require('../src/plugins'); 32 | 33 | plugins.register({name: 'Test'}); 34 | 35 | const response = await plugins.executePreRequest({test: 'test'}); 36 | expect(response).toBeNull(); 37 | }); 38 | 39 | test('Execute preRequest', async () => { 40 | const plugins = require('../src/plugins'); 41 | 42 | const statusCode = 200; 43 | const body = 'foo'; 44 | 45 | plugins.register({ 46 | name: 'preRequest', 47 | preRequest: async function(event, response) { 48 | return { 49 | statusCode: 200, 50 | body: event.test, 51 | } 52 | }, 53 | }); 54 | 55 | const response = await plugins.executePreRequest({test: body}); 56 | expect(response.body).toEqual(body); 57 | expect(response.statusCode).toEqual(statusCode); 58 | }); 59 | 60 | test('Execute multiple preRequest', async () => { 61 | const plugins = require('../src/plugins'); 62 | 63 | const body = 'foo'; 64 | 65 | plugins.register({ 66 | name: '1', 67 | preRequest: async function(event, response) { 68 | return { 69 | statusCode: 200, 70 | body: event.test, 71 | } 72 | }, 73 | }); 74 | 75 | plugins.register({ 76 | name: '2', 77 | preRequest: async function(event, response) { 78 | if (response?.statusCode) { 79 | response.statusCode = response.statusCode + 1; 80 | } 81 | return response; 82 | }, 83 | }); 84 | 85 | const response = await plugins.executePreRequest({test: body}); 86 | expect(response.body).toEqual(body); 87 | expect(response.statusCode).toEqual(201); 88 | }); 89 | 90 | test('Execute postRequest', async () => { 91 | const plugins = require('../src/plugins'); 92 | 93 | plugins.register({ 94 | name: 'postRequest', 95 | postRequest: async function(event, response) { 96 | return { 97 | statusCode: response.statusCode + 1, 98 | body: 'Foo' 99 | } 100 | } 101 | }); 102 | 103 | const response = await plugins.executePostRequest({test: 'foo'}, {statusCode: 200, body: 'Test'}); 104 | expect(response.body).toEqual('Foo'); 105 | expect(response.statusCode).toEqual(201); 106 | }); 107 | 108 | test('Execute multiple postRequest', async () => { 109 | const plugins = require('../src/plugins'); 110 | 111 | plugins.register({ 112 | name: '3', 113 | postRequest: async function(event, response) { 114 | return { 115 | statusCode: response.statusCode + 1, 116 | body: 'Foo' 117 | } 118 | } 119 | }); 120 | plugins.register({ 121 | name: '4', 122 | postRequest: async function(event, response) { 123 | return { 124 | statusCode: response.statusCode + 1, 125 | body: 'Bar' 126 | } 127 | } 128 | }); 129 | 130 | const response = await plugins.executePostRequest({test: 'foo'}, {statusCode: 200, body: 'Test'}); 131 | expect(response.body).toEqual('Bar'); 132 | expect(response.statusCode).toEqual(202); 133 | }); 134 | }); 135 | --------------------------------------------------------------------------------