├── .dockerignore ├── .env.default ├── .eslintrc.js ├── .gitignore ├── .node-version ├── CHANGELOG.md ├── Dockerfile ├── LICENSE ├── README.md ├── docker_release.sh ├── package-lock.json ├── package.json ├── screenshot.png ├── src ├── app.js ├── client.js ├── routes.js └── utils.js └── tests ├── fixtures.js └── routes.tests.js /.dockerignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | npm-debug.log 3 | .env 4 | .idea 5 | .git 6 | tests 7 | -------------------------------------------------------------------------------- /.env.default: -------------------------------------------------------------------------------- 1 | APP_PORT=3000 2 | APP_ALERTMANAGER_SECRET= 3 | MATRIX_HOMESERVER_URL=https://homeserver.tld 4 | # The rooms to send alerts to, separated by a | 5 | # Each entry contains the receiver name (from alertmanager) and the 6 | # internal id (not the public alias) of the Matrix channel to forward to, 7 | # seperated by a '/'. The last '/' is used to separate the receiver name from 8 | # the matrix room. Every matrix room starts with an '!' by convention. 9 | MATRIX_ROOMS=monitoring/default-receiver/matrix/!abcdefgh:homeserver.tld|receiver2/!qwerty:homeserver.tld 10 | MATRIX_TOKEN= 11 | MATRIX_USER=@alertmanager:homeserver.tld 12 | # Set this to 1 to make firing alerts do a `@room` mention. 13 | # NOTE! Bot should also have enough power in the room for this to be useful. 14 | MENTION_ROOM=0 15 | -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | "env": { 3 | "es6": true, 4 | "node": true 5 | }, 6 | "extends": "eslint:recommended", 7 | "parserOptions": { 8 | "ecmaVersion": 2018, 9 | "sourceType": "module" 10 | }, 11 | "rules": { 12 | "indent": [ 13 | "error", 14 | 4 15 | ], 16 | "linebreak-style": [ 17 | "error", 18 | "unix" 19 | ], 20 | "quotes": [ 21 | "error", 22 | "single" 23 | ], 24 | "semi": [ 25 | "error", 26 | "never" 27 | ] 28 | } 29 | }; 30 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Created by .ignore support plugin (hsz.mobi) 2 | ### Linux template 3 | *~ 4 | 5 | # temporary files which can be created if a process still has a handle open of a deleted file 6 | .fuse_hidden* 7 | 8 | # KDE directory preferences 9 | .directory 10 | 11 | # Linux trash folder which might appear on any partition or disk 12 | .Trash-* 13 | 14 | # .nfs files are created when an open file is removed but is still being accessed 15 | .nfs* 16 | ### macOS template 17 | # General 18 | .DS_Store 19 | .AppleDouble 20 | .LSOverride 21 | 22 | # Icon must end with two \r 23 | Icon 24 | 25 | # Thumbnails 26 | ._* 27 | 28 | # Files that might appear in the root of a volume 29 | .DocumentRevisions-V100 30 | .fseventsd 31 | .Spotlight-V100 32 | .TemporaryItems 33 | .Trashes 34 | .VolumeIcon.icns 35 | .com.apple.timemachine.donotpresent 36 | 37 | # Directories potentially created on remote AFP share 38 | .AppleDB 39 | .AppleDesktop 40 | Network Trash Folder 41 | Temporary Items 42 | .apdisk 43 | ### Node template 44 | # Logs 45 | logs 46 | *.log 47 | npm-debug.log* 48 | yarn-debug.log* 49 | yarn-error.log* 50 | 51 | # Runtime data 52 | pids 53 | *.pid 54 | *.seed 55 | *.pid.lock 56 | 57 | # Directory for instrumented libs generated by jscoverage/JSCover 58 | lib-cov 59 | 60 | # Coverage directory used by tools like istanbul 61 | coverage 62 | 63 | # nyc test coverage 64 | .nyc_output 65 | 66 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 67 | .grunt 68 | 69 | # Bower dependency directory (https://bower.io/) 70 | bower_components 71 | 72 | # node-waf configuration 73 | .lock-wscript 74 | 75 | # Compiled binary addons (https://nodejs.org/api/addons.html) 76 | build/Release 77 | 78 | # Dependency directories 79 | node_modules/ 80 | jspm_packages/ 81 | 82 | # TypeScript v1 declaration files 83 | typings/ 84 | 85 | # Optional npm cache directory 86 | .npm 87 | 88 | # Optional eslint cache 89 | .eslintcache 90 | 91 | # Optional REPL history 92 | .node_repl_history 93 | 94 | # Output of 'npm pack' 95 | *.tgz 96 | 97 | # Yarn Integrity file 98 | .yarn-integrity 99 | 100 | # dotenv environment variables file 101 | .env 102 | 103 | # next.js build output 104 | .next 105 | ### JetBrains template 106 | # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm 107 | # Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 108 | 109 | .idea/ 110 | 111 | # CMake 112 | cmake-build-debug/ 113 | cmake-build-release/ 114 | 115 | # File-based project format 116 | *.iws 117 | 118 | # IntelliJ 119 | out/ 120 | 121 | # mpeltonen/sbt-idea plugin 122 | .idea_modules/ 123 | 124 | # JIRA plugin 125 | atlassian-ide-plugin.xml 126 | 127 | # Crashlytics plugin (for Android Studio and IntelliJ) 128 | com_crashlytics_export_strings.xml 129 | crashlytics.properties 130 | crashlytics-build.properties 131 | fabric.properties 132 | -------------------------------------------------------------------------------- /.node-version: -------------------------------------------------------------------------------- 1 | 20 2 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Changelog 2 | 3 | ## 0.8.0 - 2024-09-15 4 | 5 | ### Fixed 6 | 7 | * Receivers can now contain `/` to better support Prometheus-Operator (@siretart) 8 | * Room joins use exponential backoff on failures to avoid spamming the homeserver (@jelmer) 9 | 10 | ### Changed 11 | 12 | * Required NodeJS version is now 20 13 | * Various dependency updates 14 | 15 | ## 0.7.2 - 2023-04-15 16 | 17 | ### Changed 18 | 19 | * Various dependency updates 20 | 21 | ## 0.7.1 - 2023-04-01 22 | 23 | ### Changed 24 | 25 | * Various dependency updates 26 | 27 | ## 0.7.0 - 2023-01-13 28 | 29 | ### Added 30 | 31 | * Basic auth support by @tnyeanderson 32 | 33 | ### Changed 34 | 35 | * Dependency updates 36 | 37 | ## 0.6.0 - 2022-12-06 38 | 39 | ### Breaking 40 | 41 | * Required NodeJS version is now 18 42 | 43 | ### Changed 44 | 45 | * Docker image changed to base on Alpine to reduce size. 46 | 47 | * Various dependency updates. 48 | 49 | ## 0.5.0 - 2021-09-23 50 | 51 | ### Changed 52 | 53 | - Webhook endpoint now supports payloads up to 1M (up from 100k) by Sebastian Hasler. 54 | 55 | ## 0.4.0 - 2020-12-04 56 | 57 | ### Changed 58 | 59 | - Improve formatting of alerts by using more attributes by @ssams 60 | - Update Node version to 14 and bump various dependencies. 61 | 62 | ## 0.3.0 - 2020-07-17 63 | 64 | ### Added 65 | 66 | - Add option to mention room when alert is firing by @sbruder 67 | 68 | ## 0.3.0-rc1 - 2020-07-06 69 | 70 | ### Changed 71 | 72 | - Application will wait for initialization to complete before serving requests 73 | (ensures bot can connect to the homeserver and join the rooms) by @abelxluck 74 | - Wait for message to send (or fail to send) before returning a success/error 75 | message to the caller by @abelxluck 76 | 77 | ## 0.2.0 - 2020-04-11 78 | 79 | ### Added 80 | 81 | - Bot will now try to join rooms it is not in always before sending a message. 82 | 83 | ### Changed 84 | 85 | - Default port 3000 is now set in the docker image by @ptman 86 | 87 | ## 0.1.0 - 2019-11-12 88 | 89 | ### Changed 90 | 91 | - Added message styling by @daniego 92 | 93 | ## 0.0.2 - 2019-10-30 94 | 95 | ### Changed 96 | 97 | - Matrix-JS-SDK version updated to latest by @Lyr 98 | 99 | ## 0.0.1 100 | 101 | First released version 102 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:20-alpine 2 | 3 | ENV APP_PORT="3000" 4 | 5 | WORKDIR /app 6 | 7 | COPY package*.json ./ 8 | 9 | RUN npm install --only=production 10 | 11 | COPY . . 12 | 13 | EXPOSE 3000 14 | 15 | CMD ["npm", "start"] 16 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 Jason Robinson 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | [![](https://img.shields.io/docker/pulls/jaywink/matrix-alertmanager.svg)](https://cloud.docker.com/u/jaywink/repository/docker/jaywink/matrix-alertmanager) [![](https://img.shields.io/matrix/matrix-alertmanager:federator.dev.svg?server_fqdn=federator.dev)](https://matrix.to/#/#matrix-alertmanager:federator.dev) 2 | 3 | # Matrix-Alertmanager 4 | 5 | ![](./screenshot.png) 6 | 7 | A bot to receive Prometheus Alertmanager webhook events and forward them to chosen rooms. 8 | 9 | Main features: 10 | 11 | * Uses pre-created Matrix user to send alerts using token auth. 12 | * Configurable room per alert receiver. 13 | * Automatic joining of configured rooms. Private rooms require an invite. 14 | * Secret key authentication with Alertmanager. 15 | * HTML formatted messages. 16 | * Optionally mentions `@room` on firing alerts 17 | 18 | ## How to use 19 | 20 | ### Configuration 21 | 22 | Whether running manually or via the Docker image, the configuration is set 23 | via environment variables. When running manually, copy `.env.default` 24 | into `.env`, set the values and they will be loaded automatically. 25 | When using the Docker image, set the environment variables when running 26 | the container. 27 | 28 | ### Docker 29 | 30 | The [Docker image](https://cloud.docker.com/repository/docker/jaywink/matrix-alertmanager) `jaywink/matrix-alertmanager:latest` is the easiest way to get the service running. Ensure you set the required environment variables listed in `.env.default` in this repository. 31 | 32 | ### Alertmanager 33 | 34 | You will need to configure a webhook receiver in Alertmanager. It should looks something like this: 35 | 36 | ```yaml 37 | receivers: 38 | - name: 'myreceiver' 39 | webhook_configs: 40 | - url: 'https://my-matrix-alertmanager.tld/alerts?secret=veryverysecretkeyhere' 41 | ``` 42 | 43 | The secret key obviously should match the one in the alertmanager configuration. 44 | 45 | Alternatively, put the secret in a separate file and use basic auth with username `alertmanager`: 46 | 47 | ```yaml 48 | receivers: 49 | - name: 'myreceiver' 50 | webhook_configs: 51 | - url: 'https://my-matrix-alertmanager.tld/alerts' 52 | http_config: 53 | basic_auth: 54 | username: alertmanager 55 | password_file: /path/to/password.secret 56 | ``` 57 | 58 | ### Prometheus rules 59 | 60 | Add some styling to your prometheus rules 61 | 62 | ```yaml 63 | rules: 64 | - alert: High Memory Usage of Container 65 | annotations: 66 | description: Container named {{\$labels.container_name}} in {{\$labels.pod_name}} in {{\$labels.namespace}} is using more than 75% of Memory Limit 67 | expr: | 68 | ((( sum(container_memory_usage_bytes{image!=\"\",container_name!=\"POD\", namespace!=\"kube-system\"}) by (namespace,container_name,pod_name, instance) / sum(container_spec_memory_limit_bytes{image!=\"\",container_name!=\"POD\",namespace!=\"kube-system\"}) by (namespace,container_name,pod_name, instance) ) * 100 ) < +Inf ) > 75 69 | for: 5m 70 | labels: 71 | team: dev 72 | ``` 73 | 74 | NOTE! Currently, the bot cannot talk HTTPS, so you need to have a reverse proxy in place to terminate SSL, or use unsecure unencrypted connections. 75 | 76 | ## TODO 77 | 78 | * Registering an account instead of having to use an existing account 79 | 80 | ## Tech 81 | 82 | Node 20, Express, Matrix JS SDK 83 | 84 | ## Help 85 | 86 | Come chat in the https://matrix.to/#/#matrix-alertmanager:federator.dev room! 87 | 88 | ## Author 89 | 90 | Jason Robinson / https://jasonrobinson.me / @jaywink:federator.dev 91 | 92 | ## License 93 | 94 | MIT 95 | -------------------------------------------------------------------------------- /docker_release.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env bash 2 | 3 | set -e 4 | 5 | if [[ -z "$1" ]]; then 6 | tag=latest 7 | else 8 | tag=$1 9 | fi 10 | 11 | docker login 12 | docker build -t jaywink/matrix-alertmanager:${tag} . 13 | docker push jaywink/matrix-alertmanager:${tag} 14 | 15 | if [[ "$tag" == "latest" ]]; then 16 | exit 17 | fi 18 | 19 | docker tag jaywink/matrix-alertmanager:${tag} jaywink/matrix-alertmanager:latest 20 | docker push jaywink/matrix-alertmanager:latest 21 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "matrix-alertmanager", 3 | "version": "0.8.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "matrix-alertmanager", 9 | "version": "0.8.0", 10 | "license": "MIT", 11 | "dependencies": { 12 | "dotenv": "^16.4.5", 13 | "express": "^4.21.0", 14 | "matrix-js-sdk": "^34.5.0", 15 | "striptags": "^3.2.0" 16 | }, 17 | "devDependencies": { 18 | "chai": "<5", 19 | "eslint": "^9.10.0", 20 | "mocha": "^10.7.3", 21 | "nodemon": "^3.1.4", 22 | "npm-check-updates": "^17.1.1", 23 | "sinon": "^19.0.2" 24 | }, 25 | "engines": { 26 | "node": ">= 20" 27 | } 28 | }, 29 | "node_modules/@babel/runtime": { 30 | "version": "7.20.6", 31 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.20.6.tgz", 32 | "integrity": "sha512-Q+8MqP7TiHMWzSfwiJwXCjyf4GYA4Dgw3emg/7xmwsdLJOZUp+nMqcOwOzzYheuM1rhDu8FSj2l0aoMygEuXuA==", 33 | "dependencies": { 34 | "regenerator-runtime": "^0.13.11" 35 | }, 36 | "engines": { 37 | "node": ">=6.9.0" 38 | } 39 | }, 40 | "node_modules/@eslint-community/eslint-utils": { 41 | "version": "4.4.0", 42 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 43 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 44 | "dev": true, 45 | "dependencies": { 46 | "eslint-visitor-keys": "^3.3.0" 47 | }, 48 | "engines": { 49 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 50 | }, 51 | "peerDependencies": { 52 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 53 | } 54 | }, 55 | "node_modules/@eslint-community/regexpp": { 56 | "version": "4.11.0", 57 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.11.0.tgz", 58 | "integrity": "sha512-G/M/tIiMrTAxEWRfLfQJMmGNX28IxBg4PBz8XqQhqUHLFI6TL2htpIB1iQCj144V5ee/JaKyT9/WZ0MGZWfA7A==", 59 | "dev": true, 60 | "engines": { 61 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 62 | } 63 | }, 64 | "node_modules/@eslint/config-array": { 65 | "version": "0.18.0", 66 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.18.0.tgz", 67 | "integrity": "sha512-fTxvnS1sRMu3+JjXwJG0j/i4RT9u4qJ+lqS/yCGap4lH4zZGzQ7tu+xZqQmcMZq5OBZDL4QRxQzRjkWcGt8IVw==", 68 | "dev": true, 69 | "dependencies": { 70 | "@eslint/object-schema": "^2.1.4", 71 | "debug": "^4.3.1", 72 | "minimatch": "^3.1.2" 73 | }, 74 | "engines": { 75 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 76 | } 77 | }, 78 | "node_modules/@eslint/eslintrc": { 79 | "version": "3.1.0", 80 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.1.0.tgz", 81 | "integrity": "sha512-4Bfj15dVJdoy3RfZmmo86RK1Fwzn6SstsvK9JS+BaVKqC6QQQQyXekNaC+g+LKNgkQ+2VhGAzm6hO40AhMR3zQ==", 82 | "dev": true, 83 | "dependencies": { 84 | "ajv": "^6.12.4", 85 | "debug": "^4.3.2", 86 | "espree": "^10.0.1", 87 | "globals": "^14.0.0", 88 | "ignore": "^5.2.0", 89 | "import-fresh": "^3.2.1", 90 | "js-yaml": "^4.1.0", 91 | "minimatch": "^3.1.2", 92 | "strip-json-comments": "^3.1.1" 93 | }, 94 | "engines": { 95 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 96 | }, 97 | "funding": { 98 | "url": "https://opencollective.com/eslint" 99 | } 100 | }, 101 | "node_modules/@eslint/js": { 102 | "version": "9.10.0", 103 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.10.0.tgz", 104 | "integrity": "sha512-fuXtbiP5GWIn8Fz+LWoOMVf/Jxm+aajZYkhi6CuEm4SxymFM+eUWzbO9qXT+L0iCkL5+KGYMCSGxo686H19S1g==", 105 | "dev": true, 106 | "engines": { 107 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 108 | } 109 | }, 110 | "node_modules/@eslint/object-schema": { 111 | "version": "2.1.4", 112 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.4.tgz", 113 | "integrity": "sha512-BsWiH1yFGjXXS2yvrf5LyuoSIIbPrGUWob917o+BTKuZ7qJdxX8aJLRxs1fS9n6r7vESrq1OUqb68dANcFXuQQ==", 114 | "dev": true, 115 | "engines": { 116 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 117 | } 118 | }, 119 | "node_modules/@eslint/plugin-kit": { 120 | "version": "0.1.0", 121 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.1.0.tgz", 122 | "integrity": "sha512-autAXT203ixhqei9xt+qkYOvY8l6LAFIdT2UXc/RPNeUVfqRF1BV94GTJyVPFKT8nFM6MyVJhjLj9E8JWvf5zQ==", 123 | "dev": true, 124 | "dependencies": { 125 | "levn": "^0.4.1" 126 | }, 127 | "engines": { 128 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 129 | } 130 | }, 131 | "node_modules/@humanwhocodes/module-importer": { 132 | "version": "1.0.1", 133 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 134 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 135 | "dev": true, 136 | "engines": { 137 | "node": ">=12.22" 138 | }, 139 | "funding": { 140 | "type": "github", 141 | "url": "https://github.com/sponsors/nzakas" 142 | } 143 | }, 144 | "node_modules/@humanwhocodes/retry": { 145 | "version": "0.3.0", 146 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.0.tgz", 147 | "integrity": "sha512-d2CGZR2o7fS6sWB7DG/3a95bGKQyHMACZ5aW8qGkkqQpUoZV6C0X7Pc7l4ZNMZkfNBf4VWNe9E1jRsf0G146Ew==", 148 | "dev": true, 149 | "engines": { 150 | "node": ">=18.18" 151 | }, 152 | "funding": { 153 | "type": "github", 154 | "url": "https://github.com/sponsors/nzakas" 155 | } 156 | }, 157 | "node_modules/@matrix-org/matrix-sdk-crypto-wasm": { 158 | "version": "7.0.0", 159 | "resolved": "https://registry.npmjs.org/@matrix-org/matrix-sdk-crypto-wasm/-/matrix-sdk-crypto-wasm-7.0.0.tgz", 160 | "integrity": "sha512-MOencXiW/gI5MuTtCNsuojjwT5DXCrjMqv9xOslJC9h2tPdLFFFMGr58dY5Lis4DRd9MRWcgrGowUIHOqieWTA==", 161 | "engines": { 162 | "node": ">= 10" 163 | } 164 | }, 165 | "node_modules/@matrix-org/olm": { 166 | "version": "3.2.15", 167 | "resolved": "https://registry.npmjs.org/@matrix-org/olm/-/olm-3.2.15.tgz", 168 | "integrity": "sha512-S7lOrndAK9/8qOtaTq/WhttJC/o4GAzdfK0MUPpo8ApzsJEC0QjtwrkC3KBXdFP1cD1MXi/mlKR7aaoVMKgs6Q==" 169 | }, 170 | "node_modules/@nodelib/fs.scandir": { 171 | "version": "2.1.5", 172 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 173 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 174 | "dev": true, 175 | "dependencies": { 176 | "@nodelib/fs.stat": "2.0.5", 177 | "run-parallel": "^1.1.9" 178 | }, 179 | "engines": { 180 | "node": ">= 8" 181 | } 182 | }, 183 | "node_modules/@nodelib/fs.stat": { 184 | "version": "2.0.5", 185 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 186 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 187 | "dev": true, 188 | "engines": { 189 | "node": ">= 8" 190 | } 191 | }, 192 | "node_modules/@nodelib/fs.walk": { 193 | "version": "1.2.8", 194 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 195 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 196 | "dev": true, 197 | "dependencies": { 198 | "@nodelib/fs.scandir": "2.1.5", 199 | "fastq": "^1.6.0" 200 | }, 201 | "engines": { 202 | "node": ">= 8" 203 | } 204 | }, 205 | "node_modules/@sinonjs/commons": { 206 | "version": "3.0.1", 207 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz", 208 | "integrity": "sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==", 209 | "dev": true, 210 | "dependencies": { 211 | "type-detect": "4.0.8" 212 | } 213 | }, 214 | "node_modules/@sinonjs/fake-timers": { 215 | "version": "13.0.2", 216 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-13.0.2.tgz", 217 | "integrity": "sha512-4Bb+oqXZTSTZ1q27Izly9lv8B9dlV61CROxPiVtywwzv5SnytJqhvYe6FclHYuXml4cd1VHPo1zd5PmTeJozvA==", 218 | "dev": true, 219 | "dependencies": { 220 | "@sinonjs/commons": "^3.0.1" 221 | } 222 | }, 223 | "node_modules/@sinonjs/samsam": { 224 | "version": "8.0.2", 225 | "resolved": "https://registry.npmjs.org/@sinonjs/samsam/-/samsam-8.0.2.tgz", 226 | "integrity": "sha512-v46t/fwnhejRSFTGqbpn9u+LQ9xJDse10gNnPgAcxgdoCDMXj/G2asWAC/8Qs+BAZDicX+MNZouXT1A7c83kVw==", 227 | "dev": true, 228 | "dependencies": { 229 | "@sinonjs/commons": "^3.0.1", 230 | "lodash.get": "^4.4.2", 231 | "type-detect": "^4.1.0" 232 | } 233 | }, 234 | "node_modules/@sinonjs/samsam/node_modules/type-detect": { 235 | "version": "4.1.0", 236 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.1.0.tgz", 237 | "integrity": "sha512-Acylog8/luQ8L7il+geoSxhEkazvkslg7PSNKOX59mbB9cOveP5aq9h74Y7YU8yDpJwetzQQrfIwtf4Wp4LKcw==", 238 | "dev": true, 239 | "engines": { 240 | "node": ">=4" 241 | } 242 | }, 243 | "node_modules/@sinonjs/text-encoding": { 244 | "version": "0.7.3", 245 | "resolved": "https://registry.npmjs.org/@sinonjs/text-encoding/-/text-encoding-0.7.3.tgz", 246 | "integrity": "sha512-DE427ROAphMQzU4ENbliGYrBSYPXF+TtLg9S8vzeA+OF4ZKzoDdzfL8sxuMUGS/lgRhM6j1URSk9ghf7Xo1tyA==", 247 | "dev": true 248 | }, 249 | "node_modules/@types/events": { 250 | "version": "3.0.3", 251 | "resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.3.tgz", 252 | "integrity": "sha512-trOc4AAUThEz9hapPtSd7wf5tiQKvTtu5b371UxXdTuqzIh0ArcRspRP0i0Viu+LXstIQ1z96t1nsPxT9ol01g==" 253 | }, 254 | "node_modules/@types/retry": { 255 | "version": "0.12.0", 256 | "resolved": "https://registry.npmjs.org/@types/retry/-/retry-0.12.0.tgz", 257 | "integrity": "sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==" 258 | }, 259 | "node_modules/abbrev": { 260 | "version": "1.1.1", 261 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 262 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 263 | "dev": true 264 | }, 265 | "node_modules/accepts": { 266 | "version": "1.3.8", 267 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 268 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 269 | "dependencies": { 270 | "mime-types": "~2.1.34", 271 | "negotiator": "0.6.3" 272 | }, 273 | "engines": { 274 | "node": ">= 0.6" 275 | } 276 | }, 277 | "node_modules/acorn": { 278 | "version": "8.12.1", 279 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", 280 | "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", 281 | "dev": true, 282 | "bin": { 283 | "acorn": "bin/acorn" 284 | }, 285 | "engines": { 286 | "node": ">=0.4.0" 287 | } 288 | }, 289 | "node_modules/acorn-jsx": { 290 | "version": "5.3.2", 291 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 292 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 293 | "dev": true, 294 | "peerDependencies": { 295 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 296 | } 297 | }, 298 | "node_modules/ajv": { 299 | "version": "6.12.6", 300 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 301 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 302 | "dev": true, 303 | "dependencies": { 304 | "fast-deep-equal": "^3.1.1", 305 | "fast-json-stable-stringify": "^2.0.0", 306 | "json-schema-traverse": "^0.4.1", 307 | "uri-js": "^4.2.2" 308 | }, 309 | "funding": { 310 | "type": "github", 311 | "url": "https://github.com/sponsors/epoberezkin" 312 | } 313 | }, 314 | "node_modules/another-json": { 315 | "version": "0.2.0", 316 | "resolved": "https://registry.npmjs.org/another-json/-/another-json-0.2.0.tgz", 317 | "integrity": "sha1-tfQBnJc7bdXGUGotk0acttMq7tw=" 318 | }, 319 | "node_modules/ansi-colors": { 320 | "version": "4.1.3", 321 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", 322 | "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", 323 | "dev": true, 324 | "engines": { 325 | "node": ">=6" 326 | } 327 | }, 328 | "node_modules/ansi-regex": { 329 | "version": "5.0.1", 330 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 331 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 332 | "dev": true, 333 | "engines": { 334 | "node": ">=8" 335 | } 336 | }, 337 | "node_modules/anymatch": { 338 | "version": "3.1.2", 339 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 340 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 341 | "dev": true, 342 | "dependencies": { 343 | "normalize-path": "^3.0.0", 344 | "picomatch": "^2.0.4" 345 | }, 346 | "engines": { 347 | "node": ">= 8" 348 | } 349 | }, 350 | "node_modules/argparse": { 351 | "version": "2.0.1", 352 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 353 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 354 | "dev": true 355 | }, 356 | "node_modules/array-flatten": { 357 | "version": "1.1.1", 358 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 359 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 360 | }, 361 | "node_modules/assertion-error": { 362 | "version": "1.1.0", 363 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 364 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 365 | "dev": true, 366 | "license": "MIT", 367 | "engines": { 368 | "node": "*" 369 | } 370 | }, 371 | "node_modules/balanced-match": { 372 | "version": "1.0.2", 373 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 374 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 375 | "dev": true 376 | }, 377 | "node_modules/base-x": { 378 | "version": "5.0.0", 379 | "resolved": "https://registry.npmjs.org/base-x/-/base-x-5.0.0.tgz", 380 | "integrity": "sha512-sMW3VGSX1QWVFA6l8U62MLKz29rRfpTlYdCqLdpLo1/Yd4zZwSbnUaDfciIAowAqvq7YFnWq9hrhdg1KYgc1lQ==" 381 | }, 382 | "node_modules/binary-extensions": { 383 | "version": "2.2.0", 384 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 385 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 386 | "dev": true, 387 | "engines": { 388 | "node": ">=8" 389 | } 390 | }, 391 | "node_modules/body-parser": { 392 | "version": "1.20.3", 393 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", 394 | "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", 395 | "dependencies": { 396 | "bytes": "3.1.2", 397 | "content-type": "~1.0.5", 398 | "debug": "2.6.9", 399 | "depd": "2.0.0", 400 | "destroy": "1.2.0", 401 | "http-errors": "2.0.0", 402 | "iconv-lite": "0.4.24", 403 | "on-finished": "2.4.1", 404 | "qs": "6.13.0", 405 | "raw-body": "2.5.2", 406 | "type-is": "~1.6.18", 407 | "unpipe": "1.0.0" 408 | }, 409 | "engines": { 410 | "node": ">= 0.8", 411 | "npm": "1.2.8000 || >= 1.4.16" 412 | } 413 | }, 414 | "node_modules/body-parser/node_modules/debug": { 415 | "version": "2.6.9", 416 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 417 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 418 | "dependencies": { 419 | "ms": "2.0.0" 420 | } 421 | }, 422 | "node_modules/body-parser/node_modules/ms": { 423 | "version": "2.0.0", 424 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 425 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 426 | }, 427 | "node_modules/brace-expansion": { 428 | "version": "1.1.11", 429 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 430 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 431 | "dev": true, 432 | "dependencies": { 433 | "balanced-match": "^1.0.0", 434 | "concat-map": "0.0.1" 435 | } 436 | }, 437 | "node_modules/braces": { 438 | "version": "3.0.3", 439 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 440 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 441 | "dev": true, 442 | "license": "MIT", 443 | "dependencies": { 444 | "fill-range": "^7.1.1" 445 | }, 446 | "engines": { 447 | "node": ">=8" 448 | } 449 | }, 450 | "node_modules/browser-stdout": { 451 | "version": "1.3.1", 452 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 453 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 454 | "dev": true 455 | }, 456 | "node_modules/bs58": { 457 | "version": "6.0.0", 458 | "resolved": "https://registry.npmjs.org/bs58/-/bs58-6.0.0.tgz", 459 | "integrity": "sha512-PD0wEnEYg6ijszw/u8s+iI3H17cTymlrwkKhDhPZq+Sokl3AU4htyBFTjAeNAlCCmg0f53g6ih3jATyCKftTfw==", 460 | "dependencies": { 461 | "base-x": "^5.0.0" 462 | } 463 | }, 464 | "node_modules/bytes": { 465 | "version": "3.1.2", 466 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 467 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 468 | "engines": { 469 | "node": ">= 0.8" 470 | } 471 | }, 472 | "node_modules/call-bind": { 473 | "version": "1.0.7", 474 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", 475 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", 476 | "dependencies": { 477 | "es-define-property": "^1.0.0", 478 | "es-errors": "^1.3.0", 479 | "function-bind": "^1.1.2", 480 | "get-intrinsic": "^1.2.4", 481 | "set-function-length": "^1.2.1" 482 | }, 483 | "engines": { 484 | "node": ">= 0.4" 485 | }, 486 | "funding": { 487 | "url": "https://github.com/sponsors/ljharb" 488 | } 489 | }, 490 | "node_modules/callsites": { 491 | "version": "3.1.0", 492 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 493 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 494 | "dev": true, 495 | "engines": { 496 | "node": ">=6" 497 | } 498 | }, 499 | "node_modules/camelcase": { 500 | "version": "6.2.0", 501 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 502 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 503 | "dev": true, 504 | "engines": { 505 | "node": ">=10" 506 | }, 507 | "funding": { 508 | "url": "https://github.com/sponsors/sindresorhus" 509 | } 510 | }, 511 | "node_modules/chai": { 512 | "version": "4.5.0", 513 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.5.0.tgz", 514 | "integrity": "sha512-RITGBfijLkBddZvnn8jdqoTypxvqbOLYQkGGxXzeFjVHvudaPw0HNFD9x928/eUwYWd2dPCugVqspGALTZZQKw==", 515 | "dev": true, 516 | "license": "MIT", 517 | "dependencies": { 518 | "assertion-error": "^1.1.0", 519 | "check-error": "^1.0.3", 520 | "deep-eql": "^4.1.3", 521 | "get-func-name": "^2.0.2", 522 | "loupe": "^2.3.6", 523 | "pathval": "^1.1.1", 524 | "type-detect": "^4.1.0" 525 | }, 526 | "engines": { 527 | "node": ">=4" 528 | } 529 | }, 530 | "node_modules/chai/node_modules/type-detect": { 531 | "version": "4.1.0", 532 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.1.0.tgz", 533 | "integrity": "sha512-Acylog8/luQ8L7il+geoSxhEkazvkslg7PSNKOX59mbB9cOveP5aq9h74Y7YU8yDpJwetzQQrfIwtf4Wp4LKcw==", 534 | "dev": true, 535 | "license": "MIT", 536 | "engines": { 537 | "node": ">=4" 538 | } 539 | }, 540 | "node_modules/chalk": { 541 | "version": "4.1.2", 542 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 543 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 544 | "dev": true, 545 | "dependencies": { 546 | "ansi-styles": "^4.1.0", 547 | "supports-color": "^7.1.0" 548 | }, 549 | "engines": { 550 | "node": ">=10" 551 | }, 552 | "funding": { 553 | "url": "https://github.com/chalk/chalk?sponsor=1" 554 | } 555 | }, 556 | "node_modules/chalk/node_modules/ansi-styles": { 557 | "version": "4.3.0", 558 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 559 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 560 | "dev": true, 561 | "dependencies": { 562 | "color-convert": "^2.0.1" 563 | }, 564 | "engines": { 565 | "node": ">=8" 566 | }, 567 | "funding": { 568 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 569 | } 570 | }, 571 | "node_modules/chalk/node_modules/color-convert": { 572 | "version": "2.0.1", 573 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 574 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 575 | "dev": true, 576 | "dependencies": { 577 | "color-name": "~1.1.4" 578 | }, 579 | "engines": { 580 | "node": ">=7.0.0" 581 | } 582 | }, 583 | "node_modules/chalk/node_modules/color-name": { 584 | "version": "1.1.4", 585 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 586 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 587 | "dev": true 588 | }, 589 | "node_modules/chalk/node_modules/has-flag": { 590 | "version": "4.0.0", 591 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 592 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 593 | "dev": true, 594 | "engines": { 595 | "node": ">=8" 596 | } 597 | }, 598 | "node_modules/chalk/node_modules/supports-color": { 599 | "version": "7.2.0", 600 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 601 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 602 | "dev": true, 603 | "dependencies": { 604 | "has-flag": "^4.0.0" 605 | }, 606 | "engines": { 607 | "node": ">=8" 608 | } 609 | }, 610 | "node_modules/check-error": { 611 | "version": "1.0.3", 612 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.3.tgz", 613 | "integrity": "sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg==", 614 | "dev": true, 615 | "license": "MIT", 616 | "dependencies": { 617 | "get-func-name": "^2.0.2" 618 | }, 619 | "engines": { 620 | "node": "*" 621 | } 622 | }, 623 | "node_modules/chokidar": { 624 | "version": "3.5.3", 625 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 626 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 627 | "dev": true, 628 | "funding": [ 629 | { 630 | "type": "individual", 631 | "url": "https://paulmillr.com/funding/" 632 | } 633 | ], 634 | "dependencies": { 635 | "anymatch": "~3.1.2", 636 | "braces": "~3.0.2", 637 | "glob-parent": "~5.1.2", 638 | "is-binary-path": "~2.1.0", 639 | "is-glob": "~4.0.1", 640 | "normalize-path": "~3.0.0", 641 | "readdirp": "~3.6.0" 642 | }, 643 | "engines": { 644 | "node": ">= 8.10.0" 645 | }, 646 | "optionalDependencies": { 647 | "fsevents": "~2.3.2" 648 | } 649 | }, 650 | "node_modules/cliui": { 651 | "version": "7.0.4", 652 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 653 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 654 | "dev": true, 655 | "dependencies": { 656 | "string-width": "^4.2.0", 657 | "strip-ansi": "^6.0.0", 658 | "wrap-ansi": "^7.0.0" 659 | } 660 | }, 661 | "node_modules/concat-map": { 662 | "version": "0.0.1", 663 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 664 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 665 | "dev": true 666 | }, 667 | "node_modules/content-disposition": { 668 | "version": "0.5.4", 669 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 670 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 671 | "dependencies": { 672 | "safe-buffer": "5.2.1" 673 | }, 674 | "engines": { 675 | "node": ">= 0.6" 676 | } 677 | }, 678 | "node_modules/content-type": { 679 | "version": "1.0.5", 680 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 681 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 682 | "engines": { 683 | "node": ">= 0.6" 684 | } 685 | }, 686 | "node_modules/cookie": { 687 | "version": "0.6.0", 688 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", 689 | "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", 690 | "engines": { 691 | "node": ">= 0.6" 692 | } 693 | }, 694 | "node_modules/cookie-signature": { 695 | "version": "1.0.6", 696 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 697 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 698 | }, 699 | "node_modules/cross-spawn": { 700 | "version": "7.0.3", 701 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 702 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 703 | "dev": true, 704 | "dependencies": { 705 | "path-key": "^3.1.0", 706 | "shebang-command": "^2.0.0", 707 | "which": "^2.0.1" 708 | }, 709 | "engines": { 710 | "node": ">= 8" 711 | } 712 | }, 713 | "node_modules/debug": { 714 | "version": "4.3.4", 715 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 716 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 717 | "dev": true, 718 | "dependencies": { 719 | "ms": "2.1.2" 720 | }, 721 | "engines": { 722 | "node": ">=6.0" 723 | }, 724 | "peerDependenciesMeta": { 725 | "supports-color": { 726 | "optional": true 727 | } 728 | } 729 | }, 730 | "node_modules/decamelize": { 731 | "version": "4.0.0", 732 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 733 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 734 | "dev": true, 735 | "engines": { 736 | "node": ">=10" 737 | }, 738 | "funding": { 739 | "url": "https://github.com/sponsors/sindresorhus" 740 | } 741 | }, 742 | "node_modules/deep-eql": { 743 | "version": "4.1.4", 744 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.4.tgz", 745 | "integrity": "sha512-SUwdGfqdKOwxCPeVYjwSyRpJ7Z+fhpwIAtmCUdZIWZ/YP5R9WAsyuSgpLVDi9bjWoN2LXHNss/dk3urXtdQxGg==", 746 | "dev": true, 747 | "license": "MIT", 748 | "dependencies": { 749 | "type-detect": "^4.0.0" 750 | }, 751 | "engines": { 752 | "node": ">=6" 753 | } 754 | }, 755 | "node_modules/deep-is": { 756 | "version": "0.1.4", 757 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 758 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 759 | "dev": true 760 | }, 761 | "node_modules/define-data-property": { 762 | "version": "1.1.4", 763 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", 764 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", 765 | "dependencies": { 766 | "es-define-property": "^1.0.0", 767 | "es-errors": "^1.3.0", 768 | "gopd": "^1.0.1" 769 | }, 770 | "engines": { 771 | "node": ">= 0.4" 772 | }, 773 | "funding": { 774 | "url": "https://github.com/sponsors/ljharb" 775 | } 776 | }, 777 | "node_modules/depd": { 778 | "version": "2.0.0", 779 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 780 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 781 | "engines": { 782 | "node": ">= 0.8" 783 | } 784 | }, 785 | "node_modules/destroy": { 786 | "version": "1.2.0", 787 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 788 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 789 | "engines": { 790 | "node": ">= 0.8", 791 | "npm": "1.2.8000 || >= 1.4.16" 792 | } 793 | }, 794 | "node_modules/diff": { 795 | "version": "5.2.0", 796 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.2.0.tgz", 797 | "integrity": "sha512-uIFDxqpRZGZ6ThOk84hEfqWoHx2devRFvpTZcTHur85vImfaxUbTW9Ryh4CpCuDnToOP1CEtXKIgytHBPVff5A==", 798 | "dev": true, 799 | "engines": { 800 | "node": ">=0.3.1" 801 | } 802 | }, 803 | "node_modules/dotenv": { 804 | "version": "16.4.5", 805 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.4.5.tgz", 806 | "integrity": "sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==", 807 | "engines": { 808 | "node": ">=12" 809 | }, 810 | "funding": { 811 | "url": "https://dotenvx.com" 812 | } 813 | }, 814 | "node_modules/ee-first": { 815 | "version": "1.1.1", 816 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 817 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 818 | }, 819 | "node_modules/emoji-regex": { 820 | "version": "8.0.0", 821 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 822 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 823 | "dev": true 824 | }, 825 | "node_modules/encodeurl": { 826 | "version": "2.0.0", 827 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz", 828 | "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", 829 | "engines": { 830 | "node": ">= 0.8" 831 | } 832 | }, 833 | "node_modules/es-define-property": { 834 | "version": "1.0.0", 835 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", 836 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", 837 | "dependencies": { 838 | "get-intrinsic": "^1.2.4" 839 | }, 840 | "engines": { 841 | "node": ">= 0.4" 842 | } 843 | }, 844 | "node_modules/es-errors": { 845 | "version": "1.3.0", 846 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 847 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 848 | "engines": { 849 | "node": ">= 0.4" 850 | } 851 | }, 852 | "node_modules/escalade": { 853 | "version": "3.1.1", 854 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 855 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 856 | "dev": true, 857 | "engines": { 858 | "node": ">=6" 859 | } 860 | }, 861 | "node_modules/escape-html": { 862 | "version": "1.0.3", 863 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 864 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 865 | }, 866 | "node_modules/escape-string-regexp": { 867 | "version": "4.0.0", 868 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 869 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 870 | "dev": true, 871 | "engines": { 872 | "node": ">=10" 873 | }, 874 | "funding": { 875 | "url": "https://github.com/sponsors/sindresorhus" 876 | } 877 | }, 878 | "node_modules/eslint": { 879 | "version": "9.10.0", 880 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.10.0.tgz", 881 | "integrity": "sha512-Y4D0IgtBZfOcOUAIQTSXBKoNGfY0REGqHJG6+Q81vNippW5YlKjHFj4soMxamKK1NXHUWuBZTLdU3Km+L/pcHw==", 882 | "dev": true, 883 | "dependencies": { 884 | "@eslint-community/eslint-utils": "^4.2.0", 885 | "@eslint-community/regexpp": "^4.11.0", 886 | "@eslint/config-array": "^0.18.0", 887 | "@eslint/eslintrc": "^3.1.0", 888 | "@eslint/js": "9.10.0", 889 | "@eslint/plugin-kit": "^0.1.0", 890 | "@humanwhocodes/module-importer": "^1.0.1", 891 | "@humanwhocodes/retry": "^0.3.0", 892 | "@nodelib/fs.walk": "^1.2.8", 893 | "ajv": "^6.12.4", 894 | "chalk": "^4.0.0", 895 | "cross-spawn": "^7.0.2", 896 | "debug": "^4.3.2", 897 | "escape-string-regexp": "^4.0.0", 898 | "eslint-scope": "^8.0.2", 899 | "eslint-visitor-keys": "^4.0.0", 900 | "espree": "^10.1.0", 901 | "esquery": "^1.5.0", 902 | "esutils": "^2.0.2", 903 | "fast-deep-equal": "^3.1.3", 904 | "file-entry-cache": "^8.0.0", 905 | "find-up": "^5.0.0", 906 | "glob-parent": "^6.0.2", 907 | "ignore": "^5.2.0", 908 | "imurmurhash": "^0.1.4", 909 | "is-glob": "^4.0.0", 910 | "is-path-inside": "^3.0.3", 911 | "json-stable-stringify-without-jsonify": "^1.0.1", 912 | "lodash.merge": "^4.6.2", 913 | "minimatch": "^3.1.2", 914 | "natural-compare": "^1.4.0", 915 | "optionator": "^0.9.3", 916 | "strip-ansi": "^6.0.1", 917 | "text-table": "^0.2.0" 918 | }, 919 | "bin": { 920 | "eslint": "bin/eslint.js" 921 | }, 922 | "engines": { 923 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 924 | }, 925 | "funding": { 926 | "url": "https://eslint.org/donate" 927 | }, 928 | "peerDependencies": { 929 | "jiti": "*" 930 | }, 931 | "peerDependenciesMeta": { 932 | "jiti": { 933 | "optional": true 934 | } 935 | } 936 | }, 937 | "node_modules/eslint-scope": { 938 | "version": "8.0.2", 939 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.0.2.tgz", 940 | "integrity": "sha512-6E4xmrTw5wtxnLA5wYL3WDfhZ/1bUBGOXV0zQvVRDOtrR8D0p6W7fs3JweNYhwRYeGvd/1CKX2se0/2s7Q/nJA==", 941 | "dev": true, 942 | "dependencies": { 943 | "esrecurse": "^4.3.0", 944 | "estraverse": "^5.2.0" 945 | }, 946 | "engines": { 947 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 948 | }, 949 | "funding": { 950 | "url": "https://opencollective.com/eslint" 951 | } 952 | }, 953 | "node_modules/eslint-visitor-keys": { 954 | "version": "3.4.0", 955 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.0.tgz", 956 | "integrity": "sha512-HPpKPUBQcAsZOsHAFwTtIKcYlCje62XB7SEAcxjtmW6TD1WVpkS6i6/hOVtTZIl4zGj/mBqpFVGvaDneik+VoQ==", 957 | "dev": true, 958 | "engines": { 959 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 960 | }, 961 | "funding": { 962 | "url": "https://opencollective.com/eslint" 963 | } 964 | }, 965 | "node_modules/eslint/node_modules/eslint-visitor-keys": { 966 | "version": "4.0.0", 967 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.0.0.tgz", 968 | "integrity": "sha512-OtIRv/2GyiF6o/d8K7MYKKbXrOUBIK6SfkIRM4Z0dY3w+LiQ0vy3F57m0Z71bjbyeiWFiHJ8brqnmE6H6/jEuw==", 969 | "dev": true, 970 | "engines": { 971 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 972 | }, 973 | "funding": { 974 | "url": "https://opencollective.com/eslint" 975 | } 976 | }, 977 | "node_modules/eslint/node_modules/glob-parent": { 978 | "version": "6.0.2", 979 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 980 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 981 | "dev": true, 982 | "dependencies": { 983 | "is-glob": "^4.0.3" 984 | }, 985 | "engines": { 986 | "node": ">=10.13.0" 987 | } 988 | }, 989 | "node_modules/espree": { 990 | "version": "10.1.0", 991 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.1.0.tgz", 992 | "integrity": "sha512-M1M6CpiE6ffoigIOWYO9UDP8TMUw9kqb21tf+08IgDYjCsOvCuDt4jQcZmoYxx+w7zlKw9/N0KXfto+I8/FrXA==", 993 | "dev": true, 994 | "dependencies": { 995 | "acorn": "^8.12.0", 996 | "acorn-jsx": "^5.3.2", 997 | "eslint-visitor-keys": "^4.0.0" 998 | }, 999 | "engines": { 1000 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 1001 | }, 1002 | "funding": { 1003 | "url": "https://opencollective.com/eslint" 1004 | } 1005 | }, 1006 | "node_modules/espree/node_modules/eslint-visitor-keys": { 1007 | "version": "4.0.0", 1008 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.0.0.tgz", 1009 | "integrity": "sha512-OtIRv/2GyiF6o/d8K7MYKKbXrOUBIK6SfkIRM4Z0dY3w+LiQ0vy3F57m0Z71bjbyeiWFiHJ8brqnmE6H6/jEuw==", 1010 | "dev": true, 1011 | "engines": { 1012 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 1013 | }, 1014 | "funding": { 1015 | "url": "https://opencollective.com/eslint" 1016 | } 1017 | }, 1018 | "node_modules/esquery": { 1019 | "version": "1.5.0", 1020 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 1021 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 1022 | "dev": true, 1023 | "dependencies": { 1024 | "estraverse": "^5.1.0" 1025 | }, 1026 | "engines": { 1027 | "node": ">=0.10" 1028 | } 1029 | }, 1030 | "node_modules/esrecurse": { 1031 | "version": "4.3.0", 1032 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1033 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1034 | "dev": true, 1035 | "dependencies": { 1036 | "estraverse": "^5.2.0" 1037 | }, 1038 | "engines": { 1039 | "node": ">=4.0" 1040 | } 1041 | }, 1042 | "node_modules/estraverse": { 1043 | "version": "5.3.0", 1044 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1045 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1046 | "dev": true, 1047 | "engines": { 1048 | "node": ">=4.0" 1049 | } 1050 | }, 1051 | "node_modules/esutils": { 1052 | "version": "2.0.3", 1053 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1054 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1055 | "dev": true, 1056 | "engines": { 1057 | "node": ">=0.10.0" 1058 | } 1059 | }, 1060 | "node_modules/etag": { 1061 | "version": "1.8.1", 1062 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1063 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 1064 | "engines": { 1065 | "node": ">= 0.6" 1066 | } 1067 | }, 1068 | "node_modules/events": { 1069 | "version": "3.3.0", 1070 | "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", 1071 | "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", 1072 | "engines": { 1073 | "node": ">=0.8.x" 1074 | } 1075 | }, 1076 | "node_modules/express": { 1077 | "version": "4.21.0", 1078 | "resolved": "https://registry.npmjs.org/express/-/express-4.21.0.tgz", 1079 | "integrity": "sha512-VqcNGcj/Id5ZT1LZ/cfihi3ttTn+NJmkli2eZADigjq29qTlWi/hAQ43t/VLPq8+UX06FCEx3ByOYet6ZFblng==", 1080 | "dependencies": { 1081 | "accepts": "~1.3.8", 1082 | "array-flatten": "1.1.1", 1083 | "body-parser": "1.20.3", 1084 | "content-disposition": "0.5.4", 1085 | "content-type": "~1.0.4", 1086 | "cookie": "0.6.0", 1087 | "cookie-signature": "1.0.6", 1088 | "debug": "2.6.9", 1089 | "depd": "2.0.0", 1090 | "encodeurl": "~2.0.0", 1091 | "escape-html": "~1.0.3", 1092 | "etag": "~1.8.1", 1093 | "finalhandler": "1.3.1", 1094 | "fresh": "0.5.2", 1095 | "http-errors": "2.0.0", 1096 | "merge-descriptors": "1.0.3", 1097 | "methods": "~1.1.2", 1098 | "on-finished": "2.4.1", 1099 | "parseurl": "~1.3.3", 1100 | "path-to-regexp": "0.1.10", 1101 | "proxy-addr": "~2.0.7", 1102 | "qs": "6.13.0", 1103 | "range-parser": "~1.2.1", 1104 | "safe-buffer": "5.2.1", 1105 | "send": "0.19.0", 1106 | "serve-static": "1.16.2", 1107 | "setprototypeof": "1.2.0", 1108 | "statuses": "2.0.1", 1109 | "type-is": "~1.6.18", 1110 | "utils-merge": "1.0.1", 1111 | "vary": "~1.1.2" 1112 | }, 1113 | "engines": { 1114 | "node": ">= 0.10.0" 1115 | } 1116 | }, 1117 | "node_modules/express/node_modules/debug": { 1118 | "version": "2.6.9", 1119 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1120 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1121 | "dependencies": { 1122 | "ms": "2.0.0" 1123 | } 1124 | }, 1125 | "node_modules/express/node_modules/ms": { 1126 | "version": "2.0.0", 1127 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1128 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1129 | }, 1130 | "node_modules/fast-deep-equal": { 1131 | "version": "3.1.3", 1132 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1133 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1134 | "dev": true 1135 | }, 1136 | "node_modules/fast-json-stable-stringify": { 1137 | "version": "2.1.0", 1138 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1139 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1140 | "dev": true 1141 | }, 1142 | "node_modules/fast-levenshtein": { 1143 | "version": "2.0.6", 1144 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1145 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1146 | "dev": true 1147 | }, 1148 | "node_modules/fastq": { 1149 | "version": "1.14.0", 1150 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.14.0.tgz", 1151 | "integrity": "sha512-eR2D+V9/ExcbF9ls441yIuN6TI2ED1Y2ZcA5BmMtJsOkWOFRJQ0Jt0g1UwqXJJVAb+V+umH5Dfr8oh4EVP7VVg==", 1152 | "dev": true, 1153 | "dependencies": { 1154 | "reusify": "^1.0.4" 1155 | } 1156 | }, 1157 | "node_modules/file-entry-cache": { 1158 | "version": "8.0.0", 1159 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz", 1160 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==", 1161 | "dev": true, 1162 | "dependencies": { 1163 | "flat-cache": "^4.0.0" 1164 | }, 1165 | "engines": { 1166 | "node": ">=16.0.0" 1167 | } 1168 | }, 1169 | "node_modules/fill-range": { 1170 | "version": "7.1.1", 1171 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 1172 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 1173 | "dev": true, 1174 | "license": "MIT", 1175 | "dependencies": { 1176 | "to-regex-range": "^5.0.1" 1177 | }, 1178 | "engines": { 1179 | "node": ">=8" 1180 | } 1181 | }, 1182 | "node_modules/finalhandler": { 1183 | "version": "1.3.1", 1184 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.3.1.tgz", 1185 | "integrity": "sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==", 1186 | "dependencies": { 1187 | "debug": "2.6.9", 1188 | "encodeurl": "~2.0.0", 1189 | "escape-html": "~1.0.3", 1190 | "on-finished": "2.4.1", 1191 | "parseurl": "~1.3.3", 1192 | "statuses": "2.0.1", 1193 | "unpipe": "~1.0.0" 1194 | }, 1195 | "engines": { 1196 | "node": ">= 0.8" 1197 | } 1198 | }, 1199 | "node_modules/finalhandler/node_modules/debug": { 1200 | "version": "2.6.9", 1201 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1202 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1203 | "dependencies": { 1204 | "ms": "2.0.0" 1205 | } 1206 | }, 1207 | "node_modules/finalhandler/node_modules/ms": { 1208 | "version": "2.0.0", 1209 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1210 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1211 | }, 1212 | "node_modules/find-up": { 1213 | "version": "5.0.0", 1214 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1215 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1216 | "dev": true, 1217 | "dependencies": { 1218 | "locate-path": "^6.0.0", 1219 | "path-exists": "^4.0.0" 1220 | }, 1221 | "engines": { 1222 | "node": ">=10" 1223 | }, 1224 | "funding": { 1225 | "url": "https://github.com/sponsors/sindresorhus" 1226 | } 1227 | }, 1228 | "node_modules/flat": { 1229 | "version": "5.0.2", 1230 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1231 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1232 | "dev": true, 1233 | "bin": { 1234 | "flat": "cli.js" 1235 | } 1236 | }, 1237 | "node_modules/flat-cache": { 1238 | "version": "4.0.1", 1239 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz", 1240 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==", 1241 | "dev": true, 1242 | "dependencies": { 1243 | "flatted": "^3.2.9", 1244 | "keyv": "^4.5.4" 1245 | }, 1246 | "engines": { 1247 | "node": ">=16" 1248 | } 1249 | }, 1250 | "node_modules/flatted": { 1251 | "version": "3.3.1", 1252 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 1253 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 1254 | "dev": true 1255 | }, 1256 | "node_modules/forwarded": { 1257 | "version": "0.2.0", 1258 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 1259 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 1260 | "engines": { 1261 | "node": ">= 0.6" 1262 | } 1263 | }, 1264 | "node_modules/fresh": { 1265 | "version": "0.5.2", 1266 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1267 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 1268 | "engines": { 1269 | "node": ">= 0.6" 1270 | } 1271 | }, 1272 | "node_modules/fs.realpath": { 1273 | "version": "1.0.0", 1274 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1275 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1276 | "dev": true 1277 | }, 1278 | "node_modules/fsevents": { 1279 | "version": "2.3.2", 1280 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1281 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1282 | "dev": true, 1283 | "hasInstallScript": true, 1284 | "optional": true, 1285 | "os": [ 1286 | "darwin" 1287 | ], 1288 | "engines": { 1289 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1290 | } 1291 | }, 1292 | "node_modules/function-bind": { 1293 | "version": "1.1.2", 1294 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 1295 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 1296 | "funding": { 1297 | "url": "https://github.com/sponsors/ljharb" 1298 | } 1299 | }, 1300 | "node_modules/get-caller-file": { 1301 | "version": "2.0.5", 1302 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1303 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1304 | "dev": true, 1305 | "engines": { 1306 | "node": "6.* || 8.* || >= 10.*" 1307 | } 1308 | }, 1309 | "node_modules/get-func-name": { 1310 | "version": "2.0.2", 1311 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.2.tgz", 1312 | "integrity": "sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==", 1313 | "dev": true, 1314 | "license": "MIT", 1315 | "engines": { 1316 | "node": "*" 1317 | } 1318 | }, 1319 | "node_modules/get-intrinsic": { 1320 | "version": "1.2.4", 1321 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", 1322 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", 1323 | "dependencies": { 1324 | "es-errors": "^1.3.0", 1325 | "function-bind": "^1.1.2", 1326 | "has-proto": "^1.0.1", 1327 | "has-symbols": "^1.0.3", 1328 | "hasown": "^2.0.0" 1329 | }, 1330 | "engines": { 1331 | "node": ">= 0.4" 1332 | }, 1333 | "funding": { 1334 | "url": "https://github.com/sponsors/ljharb" 1335 | } 1336 | }, 1337 | "node_modules/glob": { 1338 | "version": "8.1.0", 1339 | "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", 1340 | "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==", 1341 | "deprecated": "Glob versions prior to v9 are no longer supported", 1342 | "dev": true, 1343 | "dependencies": { 1344 | "fs.realpath": "^1.0.0", 1345 | "inflight": "^1.0.4", 1346 | "inherits": "2", 1347 | "minimatch": "^5.0.1", 1348 | "once": "^1.3.0" 1349 | }, 1350 | "engines": { 1351 | "node": ">=12" 1352 | }, 1353 | "funding": { 1354 | "url": "https://github.com/sponsors/isaacs" 1355 | } 1356 | }, 1357 | "node_modules/glob-parent": { 1358 | "version": "5.1.2", 1359 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1360 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1361 | "dev": true, 1362 | "dependencies": { 1363 | "is-glob": "^4.0.1" 1364 | }, 1365 | "engines": { 1366 | "node": ">= 6" 1367 | } 1368 | }, 1369 | "node_modules/glob/node_modules/brace-expansion": { 1370 | "version": "2.0.1", 1371 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1372 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1373 | "dev": true, 1374 | "dependencies": { 1375 | "balanced-match": "^1.0.0" 1376 | } 1377 | }, 1378 | "node_modules/glob/node_modules/minimatch": { 1379 | "version": "5.1.6", 1380 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 1381 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 1382 | "dev": true, 1383 | "dependencies": { 1384 | "brace-expansion": "^2.0.1" 1385 | }, 1386 | "engines": { 1387 | "node": ">=10" 1388 | } 1389 | }, 1390 | "node_modules/globals": { 1391 | "version": "14.0.0", 1392 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", 1393 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", 1394 | "dev": true, 1395 | "engines": { 1396 | "node": ">=18" 1397 | }, 1398 | "funding": { 1399 | "url": "https://github.com/sponsors/sindresorhus" 1400 | } 1401 | }, 1402 | "node_modules/gopd": { 1403 | "version": "1.0.1", 1404 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 1405 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 1406 | "dependencies": { 1407 | "get-intrinsic": "^1.1.3" 1408 | }, 1409 | "funding": { 1410 | "url": "https://github.com/sponsors/ljharb" 1411 | } 1412 | }, 1413 | "node_modules/has-flag": { 1414 | "version": "3.0.0", 1415 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1416 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1417 | "dev": true, 1418 | "engines": { 1419 | "node": ">=4" 1420 | } 1421 | }, 1422 | "node_modules/has-property-descriptors": { 1423 | "version": "1.0.2", 1424 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", 1425 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", 1426 | "dependencies": { 1427 | "es-define-property": "^1.0.0" 1428 | }, 1429 | "funding": { 1430 | "url": "https://github.com/sponsors/ljharb" 1431 | } 1432 | }, 1433 | "node_modules/has-proto": { 1434 | "version": "1.0.3", 1435 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", 1436 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", 1437 | "engines": { 1438 | "node": ">= 0.4" 1439 | }, 1440 | "funding": { 1441 | "url": "https://github.com/sponsors/ljharb" 1442 | } 1443 | }, 1444 | "node_modules/has-symbols": { 1445 | "version": "1.0.3", 1446 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 1447 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 1448 | "engines": { 1449 | "node": ">= 0.4" 1450 | }, 1451 | "funding": { 1452 | "url": "https://github.com/sponsors/ljharb" 1453 | } 1454 | }, 1455 | "node_modules/hasown": { 1456 | "version": "2.0.2", 1457 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 1458 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 1459 | "dependencies": { 1460 | "function-bind": "^1.1.2" 1461 | }, 1462 | "engines": { 1463 | "node": ">= 0.4" 1464 | } 1465 | }, 1466 | "node_modules/he": { 1467 | "version": "1.2.0", 1468 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1469 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1470 | "dev": true, 1471 | "bin": { 1472 | "he": "bin/he" 1473 | } 1474 | }, 1475 | "node_modules/http-errors": { 1476 | "version": "2.0.0", 1477 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 1478 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 1479 | "dependencies": { 1480 | "depd": "2.0.0", 1481 | "inherits": "2.0.4", 1482 | "setprototypeof": "1.2.0", 1483 | "statuses": "2.0.1", 1484 | "toidentifier": "1.0.1" 1485 | }, 1486 | "engines": { 1487 | "node": ">= 0.8" 1488 | } 1489 | }, 1490 | "node_modules/iconv-lite": { 1491 | "version": "0.4.24", 1492 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1493 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1494 | "dependencies": { 1495 | "safer-buffer": ">= 2.1.2 < 3" 1496 | }, 1497 | "engines": { 1498 | "node": ">=0.10.0" 1499 | } 1500 | }, 1501 | "node_modules/ignore": { 1502 | "version": "5.2.4", 1503 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 1504 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 1505 | "dev": true, 1506 | "engines": { 1507 | "node": ">= 4" 1508 | } 1509 | }, 1510 | "node_modules/ignore-by-default": { 1511 | "version": "1.0.1", 1512 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1513 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1514 | "dev": true 1515 | }, 1516 | "node_modules/import-fresh": { 1517 | "version": "3.3.0", 1518 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1519 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1520 | "dev": true, 1521 | "dependencies": { 1522 | "parent-module": "^1.0.0", 1523 | "resolve-from": "^4.0.0" 1524 | }, 1525 | "engines": { 1526 | "node": ">=6" 1527 | }, 1528 | "funding": { 1529 | "url": "https://github.com/sponsors/sindresorhus" 1530 | } 1531 | }, 1532 | "node_modules/imurmurhash": { 1533 | "version": "0.1.4", 1534 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1535 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1536 | "dev": true, 1537 | "engines": { 1538 | "node": ">=0.8.19" 1539 | } 1540 | }, 1541 | "node_modules/inflight": { 1542 | "version": "1.0.6", 1543 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1544 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1545 | "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", 1546 | "dev": true, 1547 | "dependencies": { 1548 | "once": "^1.3.0", 1549 | "wrappy": "1" 1550 | } 1551 | }, 1552 | "node_modules/inherits": { 1553 | "version": "2.0.4", 1554 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1555 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1556 | }, 1557 | "node_modules/ipaddr.js": { 1558 | "version": "1.9.1", 1559 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1560 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 1561 | "engines": { 1562 | "node": ">= 0.10" 1563 | } 1564 | }, 1565 | "node_modules/is-binary-path": { 1566 | "version": "2.1.0", 1567 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1568 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1569 | "dev": true, 1570 | "dependencies": { 1571 | "binary-extensions": "^2.0.0" 1572 | }, 1573 | "engines": { 1574 | "node": ">=8" 1575 | } 1576 | }, 1577 | "node_modules/is-extglob": { 1578 | "version": "2.1.1", 1579 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1580 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1581 | "dev": true, 1582 | "engines": { 1583 | "node": ">=0.10.0" 1584 | } 1585 | }, 1586 | "node_modules/is-fullwidth-code-point": { 1587 | "version": "3.0.0", 1588 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1589 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1590 | "dev": true, 1591 | "engines": { 1592 | "node": ">=8" 1593 | } 1594 | }, 1595 | "node_modules/is-glob": { 1596 | "version": "4.0.3", 1597 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1598 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1599 | "dev": true, 1600 | "dependencies": { 1601 | "is-extglob": "^2.1.1" 1602 | }, 1603 | "engines": { 1604 | "node": ">=0.10.0" 1605 | } 1606 | }, 1607 | "node_modules/is-number": { 1608 | "version": "7.0.0", 1609 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1610 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1611 | "dev": true, 1612 | "license": "MIT", 1613 | "engines": { 1614 | "node": ">=0.12.0" 1615 | } 1616 | }, 1617 | "node_modules/is-path-inside": { 1618 | "version": "3.0.3", 1619 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1620 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1621 | "dev": true, 1622 | "engines": { 1623 | "node": ">=8" 1624 | } 1625 | }, 1626 | "node_modules/is-plain-obj": { 1627 | "version": "2.1.0", 1628 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1629 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1630 | "dev": true, 1631 | "engines": { 1632 | "node": ">=8" 1633 | } 1634 | }, 1635 | "node_modules/is-unicode-supported": { 1636 | "version": "0.1.0", 1637 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1638 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1639 | "dev": true, 1640 | "engines": { 1641 | "node": ">=10" 1642 | }, 1643 | "funding": { 1644 | "url": "https://github.com/sponsors/sindresorhus" 1645 | } 1646 | }, 1647 | "node_modules/isexe": { 1648 | "version": "2.0.0", 1649 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1650 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1651 | "dev": true 1652 | }, 1653 | "node_modules/js-yaml": { 1654 | "version": "4.1.0", 1655 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1656 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1657 | "dev": true, 1658 | "dependencies": { 1659 | "argparse": "^2.0.1" 1660 | }, 1661 | "bin": { 1662 | "js-yaml": "bin/js-yaml.js" 1663 | } 1664 | }, 1665 | "node_modules/json-buffer": { 1666 | "version": "3.0.1", 1667 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 1668 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 1669 | "dev": true 1670 | }, 1671 | "node_modules/json-schema-traverse": { 1672 | "version": "0.4.1", 1673 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1674 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1675 | "dev": true 1676 | }, 1677 | "node_modules/json-stable-stringify-without-jsonify": { 1678 | "version": "1.0.1", 1679 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1680 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1681 | "dev": true 1682 | }, 1683 | "node_modules/just-extend": { 1684 | "version": "6.2.0", 1685 | "resolved": "https://registry.npmjs.org/just-extend/-/just-extend-6.2.0.tgz", 1686 | "integrity": "sha512-cYofQu2Xpom82S6qD778jBDpwvvy39s1l/hrYij2u9AMdQcGRpaBu6kY4mVhuno5kJVi1DAz4aiphA2WI1/OAw==", 1687 | "dev": true 1688 | }, 1689 | "node_modules/jwt-decode": { 1690 | "version": "4.0.0", 1691 | "resolved": "https://registry.npmjs.org/jwt-decode/-/jwt-decode-4.0.0.tgz", 1692 | "integrity": "sha512-+KJGIyHgkGuIq3IEBNftfhW/LfWhXUIY6OmyVWjliu5KH1y0fw7VQ8YndE2O4qZdMSd9SqbnC8GOcZEy0Om7sA==", 1693 | "engines": { 1694 | "node": ">=18" 1695 | } 1696 | }, 1697 | "node_modules/keyv": { 1698 | "version": "4.5.4", 1699 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 1700 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 1701 | "dev": true, 1702 | "dependencies": { 1703 | "json-buffer": "3.0.1" 1704 | } 1705 | }, 1706 | "node_modules/levn": { 1707 | "version": "0.4.1", 1708 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1709 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1710 | "dev": true, 1711 | "dependencies": { 1712 | "prelude-ls": "^1.2.1", 1713 | "type-check": "~0.4.0" 1714 | }, 1715 | "engines": { 1716 | "node": ">= 0.8.0" 1717 | } 1718 | }, 1719 | "node_modules/locate-path": { 1720 | "version": "6.0.0", 1721 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1722 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1723 | "dev": true, 1724 | "dependencies": { 1725 | "p-locate": "^5.0.0" 1726 | }, 1727 | "engines": { 1728 | "node": ">=10" 1729 | }, 1730 | "funding": { 1731 | "url": "https://github.com/sponsors/sindresorhus" 1732 | } 1733 | }, 1734 | "node_modules/lodash.get": { 1735 | "version": "4.4.2", 1736 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 1737 | "integrity": "sha512-z+Uw/vLuy6gQe8cfaFWD7p0wVv8fJl3mbzXh33RS+0oW2wvUqiRXiQ69gLWSLpgB5/6sU+r6BlQR0MBILadqTQ==", 1738 | "dev": true 1739 | }, 1740 | "node_modules/lodash.merge": { 1741 | "version": "4.6.2", 1742 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1743 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1744 | "dev": true 1745 | }, 1746 | "node_modules/log-symbols": { 1747 | "version": "4.1.0", 1748 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1749 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1750 | "dev": true, 1751 | "dependencies": { 1752 | "chalk": "^4.1.0", 1753 | "is-unicode-supported": "^0.1.0" 1754 | }, 1755 | "engines": { 1756 | "node": ">=10" 1757 | }, 1758 | "funding": { 1759 | "url": "https://github.com/sponsors/sindresorhus" 1760 | } 1761 | }, 1762 | "node_modules/loglevel": { 1763 | "version": "1.8.1", 1764 | "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.8.1.tgz", 1765 | "integrity": "sha512-tCRIJM51SHjAayKwC+QAg8hT8vg6z7GSgLJKGvzuPb1Wc+hLzqtuVLxp6/HzSPOozuK+8ErAhy7U/sVzw8Dgfg==", 1766 | "engines": { 1767 | "node": ">= 0.6.0" 1768 | }, 1769 | "funding": { 1770 | "type": "tidelift", 1771 | "url": "https://tidelift.com/funding/github/npm/loglevel" 1772 | } 1773 | }, 1774 | "node_modules/loupe": { 1775 | "version": "2.3.7", 1776 | "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.7.tgz", 1777 | "integrity": "sha512-zSMINGVYkdpYSOBmLi0D1Uo7JU9nVdQKrHxC8eYlV+9YKK9WePqAlL7lSlorG/U2Fw1w0hTBmaa/jrQ3UbPHtA==", 1778 | "dev": true, 1779 | "license": "MIT", 1780 | "dependencies": { 1781 | "get-func-name": "^2.0.1" 1782 | } 1783 | }, 1784 | "node_modules/matrix-events-sdk": { 1785 | "version": "0.0.1", 1786 | "resolved": "https://registry.npmjs.org/matrix-events-sdk/-/matrix-events-sdk-0.0.1.tgz", 1787 | "integrity": "sha512-1QEOsXO+bhyCroIe2/A5OwaxHvBm7EsSQ46DEDn8RBIfQwN5HWBpFvyWWR4QY0KHPPnnJdI99wgRiAl7Ad5qaA==" 1788 | }, 1789 | "node_modules/matrix-js-sdk": { 1790 | "version": "34.5.0", 1791 | "resolved": "https://registry.npmjs.org/matrix-js-sdk/-/matrix-js-sdk-34.5.0.tgz", 1792 | "integrity": "sha512-pbp+IxAkSwGmefrlUGCrtrs3UWyqN2iWh4lKnJW+jFIlsksXq7A8vL4cS1z8LXmpcHQAg3mKNuj8n8uhm51t1A==", 1793 | "dependencies": { 1794 | "@babel/runtime": "^7.12.5", 1795 | "@matrix-org/matrix-sdk-crypto-wasm": "^7.0.0", 1796 | "@matrix-org/olm": "3.2.15", 1797 | "another-json": "^0.2.0", 1798 | "bs58": "^6.0.0", 1799 | "content-type": "^1.0.4", 1800 | "jwt-decode": "^4.0.0", 1801 | "loglevel": "^1.7.1", 1802 | "matrix-events-sdk": "0.0.1", 1803 | "matrix-widget-api": "^1.8.2", 1804 | "oidc-client-ts": "^3.0.1", 1805 | "p-retry": "4", 1806 | "sdp-transform": "^2.14.1", 1807 | "unhomoglyph": "^1.0.6", 1808 | "uuid": "10" 1809 | }, 1810 | "engines": { 1811 | "node": ">=20.0.0" 1812 | } 1813 | }, 1814 | "node_modules/matrix-widget-api": { 1815 | "version": "1.9.0", 1816 | "resolved": "https://registry.npmjs.org/matrix-widget-api/-/matrix-widget-api-1.9.0.tgz", 1817 | "integrity": "sha512-au8mqralNDqrEvaVAkU37bXOb8I9SCe+ACdPk11QWw58FKstVq31q2wRz+qWA6J+42KJ6s1DggWbG/S3fEs3jw==", 1818 | "dependencies": { 1819 | "@types/events": "^3.0.0", 1820 | "events": "^3.2.0" 1821 | } 1822 | }, 1823 | "node_modules/media-typer": { 1824 | "version": "0.3.0", 1825 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1826 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1827 | "engines": { 1828 | "node": ">= 0.6" 1829 | } 1830 | }, 1831 | "node_modules/merge-descriptors": { 1832 | "version": "1.0.3", 1833 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.3.tgz", 1834 | "integrity": "sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==", 1835 | "funding": { 1836 | "url": "https://github.com/sponsors/sindresorhus" 1837 | } 1838 | }, 1839 | "node_modules/methods": { 1840 | "version": "1.1.2", 1841 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1842 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1843 | "engines": { 1844 | "node": ">= 0.6" 1845 | } 1846 | }, 1847 | "node_modules/mime": { 1848 | "version": "1.6.0", 1849 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1850 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1851 | "bin": { 1852 | "mime": "cli.js" 1853 | }, 1854 | "engines": { 1855 | "node": ">=4" 1856 | } 1857 | }, 1858 | "node_modules/mime-db": { 1859 | "version": "1.52.0", 1860 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1861 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1862 | "engines": { 1863 | "node": ">= 0.6" 1864 | } 1865 | }, 1866 | "node_modules/mime-types": { 1867 | "version": "2.1.35", 1868 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1869 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1870 | "dependencies": { 1871 | "mime-db": "1.52.0" 1872 | }, 1873 | "engines": { 1874 | "node": ">= 0.6" 1875 | } 1876 | }, 1877 | "node_modules/minimatch": { 1878 | "version": "3.1.2", 1879 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1880 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1881 | "dev": true, 1882 | "dependencies": { 1883 | "brace-expansion": "^1.1.7" 1884 | }, 1885 | "engines": { 1886 | "node": "*" 1887 | } 1888 | }, 1889 | "node_modules/mocha": { 1890 | "version": "10.7.3", 1891 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.7.3.tgz", 1892 | "integrity": "sha512-uQWxAu44wwiACGqjbPYmjo7Lg8sFrS3dQe7PP2FQI+woptP4vZXSMcfMyFL/e1yFEeEpV4RtyTpZROOKmxis+A==", 1893 | "dev": true, 1894 | "dependencies": { 1895 | "ansi-colors": "^4.1.3", 1896 | "browser-stdout": "^1.3.1", 1897 | "chokidar": "^3.5.3", 1898 | "debug": "^4.3.5", 1899 | "diff": "^5.2.0", 1900 | "escape-string-regexp": "^4.0.0", 1901 | "find-up": "^5.0.0", 1902 | "glob": "^8.1.0", 1903 | "he": "^1.2.0", 1904 | "js-yaml": "^4.1.0", 1905 | "log-symbols": "^4.1.0", 1906 | "minimatch": "^5.1.6", 1907 | "ms": "^2.1.3", 1908 | "serialize-javascript": "^6.0.2", 1909 | "strip-json-comments": "^3.1.1", 1910 | "supports-color": "^8.1.1", 1911 | "workerpool": "^6.5.1", 1912 | "yargs": "^16.2.0", 1913 | "yargs-parser": "^20.2.9", 1914 | "yargs-unparser": "^2.0.0" 1915 | }, 1916 | "bin": { 1917 | "_mocha": "bin/_mocha", 1918 | "mocha": "bin/mocha.js" 1919 | }, 1920 | "engines": { 1921 | "node": ">= 14.0.0" 1922 | } 1923 | }, 1924 | "node_modules/mocha/node_modules/brace-expansion": { 1925 | "version": "2.0.1", 1926 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1927 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1928 | "dev": true, 1929 | "dependencies": { 1930 | "balanced-match": "^1.0.0" 1931 | } 1932 | }, 1933 | "node_modules/mocha/node_modules/debug": { 1934 | "version": "4.3.7", 1935 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", 1936 | "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", 1937 | "dev": true, 1938 | "dependencies": { 1939 | "ms": "^2.1.3" 1940 | }, 1941 | "engines": { 1942 | "node": ">=6.0" 1943 | }, 1944 | "peerDependenciesMeta": { 1945 | "supports-color": { 1946 | "optional": true 1947 | } 1948 | } 1949 | }, 1950 | "node_modules/mocha/node_modules/has-flag": { 1951 | "version": "4.0.0", 1952 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1953 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1954 | "dev": true, 1955 | "engines": { 1956 | "node": ">=8" 1957 | } 1958 | }, 1959 | "node_modules/mocha/node_modules/minimatch": { 1960 | "version": "5.1.6", 1961 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 1962 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 1963 | "dev": true, 1964 | "dependencies": { 1965 | "brace-expansion": "^2.0.1" 1966 | }, 1967 | "engines": { 1968 | "node": ">=10" 1969 | } 1970 | }, 1971 | "node_modules/mocha/node_modules/ms": { 1972 | "version": "2.1.3", 1973 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1974 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1975 | "dev": true 1976 | }, 1977 | "node_modules/mocha/node_modules/supports-color": { 1978 | "version": "8.1.1", 1979 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1980 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1981 | "dev": true, 1982 | "dependencies": { 1983 | "has-flag": "^4.0.0" 1984 | }, 1985 | "engines": { 1986 | "node": ">=10" 1987 | }, 1988 | "funding": { 1989 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1990 | } 1991 | }, 1992 | "node_modules/ms": { 1993 | "version": "2.1.2", 1994 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1995 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1996 | "dev": true 1997 | }, 1998 | "node_modules/natural-compare": { 1999 | "version": "1.4.0", 2000 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2001 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2002 | "dev": true 2003 | }, 2004 | "node_modules/negotiator": { 2005 | "version": "0.6.3", 2006 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 2007 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 2008 | "engines": { 2009 | "node": ">= 0.6" 2010 | } 2011 | }, 2012 | "node_modules/nise": { 2013 | "version": "6.1.1", 2014 | "resolved": "https://registry.npmjs.org/nise/-/nise-6.1.1.tgz", 2015 | "integrity": "sha512-aMSAzLVY7LyeM60gvBS423nBmIPP+Wy7St7hsb+8/fc1HmeoHJfLO8CKse4u3BtOZvQLJghYPI2i/1WZrEj5/g==", 2016 | "dev": true, 2017 | "dependencies": { 2018 | "@sinonjs/commons": "^3.0.1", 2019 | "@sinonjs/fake-timers": "^13.0.1", 2020 | "@sinonjs/text-encoding": "^0.7.3", 2021 | "just-extend": "^6.2.0", 2022 | "path-to-regexp": "^8.1.0" 2023 | } 2024 | }, 2025 | "node_modules/nise/node_modules/path-to-regexp": { 2026 | "version": "8.1.0", 2027 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-8.1.0.tgz", 2028 | "integrity": "sha512-Bqn3vc8CMHty6zuD+tG23s6v2kwxslHEhTj4eYaVKGIEB+YX/2wd0/rgXLFD9G9id9KCtbVy/3ZgmvZjpa0UdQ==", 2029 | "dev": true, 2030 | "engines": { 2031 | "node": ">=16" 2032 | } 2033 | }, 2034 | "node_modules/nodemon": { 2035 | "version": "3.1.4", 2036 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.1.4.tgz", 2037 | "integrity": "sha512-wjPBbFhtpJwmIeY2yP7QF+UKzPfltVGtfce1g/bB15/8vCGZj8uxD62b/b9M9/WVgme0NZudpownKN+c0plXlQ==", 2038 | "dev": true, 2039 | "dependencies": { 2040 | "chokidar": "^3.5.2", 2041 | "debug": "^4", 2042 | "ignore-by-default": "^1.0.1", 2043 | "minimatch": "^3.1.2", 2044 | "pstree.remy": "^1.1.8", 2045 | "semver": "^7.5.3", 2046 | "simple-update-notifier": "^2.0.0", 2047 | "supports-color": "^5.5.0", 2048 | "touch": "^3.1.0", 2049 | "undefsafe": "^2.0.5" 2050 | }, 2051 | "bin": { 2052 | "nodemon": "bin/nodemon.js" 2053 | }, 2054 | "engines": { 2055 | "node": ">=10" 2056 | }, 2057 | "funding": { 2058 | "type": "opencollective", 2059 | "url": "https://opencollective.com/nodemon" 2060 | } 2061 | }, 2062 | "node_modules/nopt": { 2063 | "version": "1.0.10", 2064 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 2065 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 2066 | "dev": true, 2067 | "dependencies": { 2068 | "abbrev": "1" 2069 | }, 2070 | "bin": { 2071 | "nopt": "bin/nopt.js" 2072 | }, 2073 | "engines": { 2074 | "node": "*" 2075 | } 2076 | }, 2077 | "node_modules/normalize-path": { 2078 | "version": "3.0.0", 2079 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2080 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2081 | "dev": true, 2082 | "engines": { 2083 | "node": ">=0.10.0" 2084 | } 2085 | }, 2086 | "node_modules/npm-check-updates": { 2087 | "version": "17.1.1", 2088 | "resolved": "https://registry.npmjs.org/npm-check-updates/-/npm-check-updates-17.1.1.tgz", 2089 | "integrity": "sha512-2aqIzGAEWB7xPf0hKHTkNmUM5jHbn2S5r2/z/7dA5Ij2h/sVYAg9R/uVkaUC3VORPAfBm7pKkCWo6E9clEVQ9A==", 2090 | "dev": true, 2091 | "bin": { 2092 | "ncu": "build/cli.js", 2093 | "npm-check-updates": "build/cli.js" 2094 | }, 2095 | "engines": { 2096 | "node": "^18.18.0 || >=20.0.0", 2097 | "npm": ">=8.12.1" 2098 | } 2099 | }, 2100 | "node_modules/object-inspect": { 2101 | "version": "1.13.2", 2102 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", 2103 | "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", 2104 | "engines": { 2105 | "node": ">= 0.4" 2106 | }, 2107 | "funding": { 2108 | "url": "https://github.com/sponsors/ljharb" 2109 | } 2110 | }, 2111 | "node_modules/oidc-client-ts": { 2112 | "version": "3.0.1", 2113 | "resolved": "https://registry.npmjs.org/oidc-client-ts/-/oidc-client-ts-3.0.1.tgz", 2114 | "integrity": "sha512-xX8unZNtmtw3sOz4FPSqDhkLFnxCDsdo2qhFEH2opgWnF/iXMFoYdBQzkwCxAZVgt3FT3DnuBY3k80EZHT0RYg==", 2115 | "dependencies": { 2116 | "jwt-decode": "^4.0.0" 2117 | }, 2118 | "engines": { 2119 | "node": ">=18" 2120 | } 2121 | }, 2122 | "node_modules/on-finished": { 2123 | "version": "2.4.1", 2124 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 2125 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 2126 | "dependencies": { 2127 | "ee-first": "1.1.1" 2128 | }, 2129 | "engines": { 2130 | "node": ">= 0.8" 2131 | } 2132 | }, 2133 | "node_modules/once": { 2134 | "version": "1.4.0", 2135 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2136 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2137 | "dev": true, 2138 | "dependencies": { 2139 | "wrappy": "1" 2140 | } 2141 | }, 2142 | "node_modules/optionator": { 2143 | "version": "0.9.4", 2144 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", 2145 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", 2146 | "dev": true, 2147 | "dependencies": { 2148 | "deep-is": "^0.1.3", 2149 | "fast-levenshtein": "^2.0.6", 2150 | "levn": "^0.4.1", 2151 | "prelude-ls": "^1.2.1", 2152 | "type-check": "^0.4.0", 2153 | "word-wrap": "^1.2.5" 2154 | }, 2155 | "engines": { 2156 | "node": ">= 0.8.0" 2157 | } 2158 | }, 2159 | "node_modules/p-limit": { 2160 | "version": "3.1.0", 2161 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2162 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2163 | "dev": true, 2164 | "dependencies": { 2165 | "yocto-queue": "^0.1.0" 2166 | }, 2167 | "engines": { 2168 | "node": ">=10" 2169 | }, 2170 | "funding": { 2171 | "url": "https://github.com/sponsors/sindresorhus" 2172 | } 2173 | }, 2174 | "node_modules/p-locate": { 2175 | "version": "5.0.0", 2176 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2177 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2178 | "dev": true, 2179 | "dependencies": { 2180 | "p-limit": "^3.0.2" 2181 | }, 2182 | "engines": { 2183 | "node": ">=10" 2184 | }, 2185 | "funding": { 2186 | "url": "https://github.com/sponsors/sindresorhus" 2187 | } 2188 | }, 2189 | "node_modules/p-retry": { 2190 | "version": "4.6.2", 2191 | "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-4.6.2.tgz", 2192 | "integrity": "sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==", 2193 | "dependencies": { 2194 | "@types/retry": "0.12.0", 2195 | "retry": "^0.13.1" 2196 | }, 2197 | "engines": { 2198 | "node": ">=8" 2199 | } 2200 | }, 2201 | "node_modules/p-retry/node_modules/retry": { 2202 | "version": "0.13.1", 2203 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz", 2204 | "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==", 2205 | "engines": { 2206 | "node": ">= 4" 2207 | } 2208 | }, 2209 | "node_modules/parent-module": { 2210 | "version": "1.0.1", 2211 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2212 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2213 | "dev": true, 2214 | "dependencies": { 2215 | "callsites": "^3.0.0" 2216 | }, 2217 | "engines": { 2218 | "node": ">=6" 2219 | } 2220 | }, 2221 | "node_modules/parseurl": { 2222 | "version": "1.3.3", 2223 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2224 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 2225 | "engines": { 2226 | "node": ">= 0.8" 2227 | } 2228 | }, 2229 | "node_modules/path-exists": { 2230 | "version": "4.0.0", 2231 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2232 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2233 | "dev": true, 2234 | "engines": { 2235 | "node": ">=8" 2236 | } 2237 | }, 2238 | "node_modules/path-key": { 2239 | "version": "3.1.1", 2240 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2241 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2242 | "dev": true, 2243 | "engines": { 2244 | "node": ">=8" 2245 | } 2246 | }, 2247 | "node_modules/path-to-regexp": { 2248 | "version": "0.1.10", 2249 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.10.tgz", 2250 | "integrity": "sha512-7lf7qcQidTku0Gu3YDPc8DJ1q7OOucfa/BSsIwjuh56VU7katFvuM8hULfkwB3Fns/rsVF7PwPKVw1sl5KQS9w==" 2251 | }, 2252 | "node_modules/pathval": { 2253 | "version": "1.1.1", 2254 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 2255 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 2256 | "dev": true, 2257 | "license": "MIT", 2258 | "engines": { 2259 | "node": "*" 2260 | } 2261 | }, 2262 | "node_modules/picomatch": { 2263 | "version": "2.3.0", 2264 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 2265 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 2266 | "dev": true, 2267 | "engines": { 2268 | "node": ">=8.6" 2269 | }, 2270 | "funding": { 2271 | "url": "https://github.com/sponsors/jonschlinkert" 2272 | } 2273 | }, 2274 | "node_modules/prelude-ls": { 2275 | "version": "1.2.1", 2276 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2277 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2278 | "dev": true, 2279 | "engines": { 2280 | "node": ">= 0.8.0" 2281 | } 2282 | }, 2283 | "node_modules/proxy-addr": { 2284 | "version": "2.0.7", 2285 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2286 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2287 | "dependencies": { 2288 | "forwarded": "0.2.0", 2289 | "ipaddr.js": "1.9.1" 2290 | }, 2291 | "engines": { 2292 | "node": ">= 0.10" 2293 | } 2294 | }, 2295 | "node_modules/pstree.remy": { 2296 | "version": "1.1.8", 2297 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 2298 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 2299 | "dev": true 2300 | }, 2301 | "node_modules/punycode": { 2302 | "version": "2.3.1", 2303 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2304 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2305 | "dev": true, 2306 | "engines": { 2307 | "node": ">=6" 2308 | } 2309 | }, 2310 | "node_modules/qs": { 2311 | "version": "6.13.0", 2312 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.13.0.tgz", 2313 | "integrity": "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==", 2314 | "dependencies": { 2315 | "side-channel": "^1.0.6" 2316 | }, 2317 | "engines": { 2318 | "node": ">=0.6" 2319 | }, 2320 | "funding": { 2321 | "url": "https://github.com/sponsors/ljharb" 2322 | } 2323 | }, 2324 | "node_modules/queue-microtask": { 2325 | "version": "1.2.3", 2326 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2327 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2328 | "dev": true, 2329 | "funding": [ 2330 | { 2331 | "type": "github", 2332 | "url": "https://github.com/sponsors/feross" 2333 | }, 2334 | { 2335 | "type": "patreon", 2336 | "url": "https://www.patreon.com/feross" 2337 | }, 2338 | { 2339 | "type": "consulting", 2340 | "url": "https://feross.org/support" 2341 | } 2342 | ] 2343 | }, 2344 | "node_modules/randombytes": { 2345 | "version": "2.1.0", 2346 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2347 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2348 | "dev": true, 2349 | "dependencies": { 2350 | "safe-buffer": "^5.1.0" 2351 | } 2352 | }, 2353 | "node_modules/range-parser": { 2354 | "version": "1.2.1", 2355 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2356 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 2357 | "engines": { 2358 | "node": ">= 0.6" 2359 | } 2360 | }, 2361 | "node_modules/raw-body": { 2362 | "version": "2.5.2", 2363 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", 2364 | "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", 2365 | "dependencies": { 2366 | "bytes": "3.1.2", 2367 | "http-errors": "2.0.0", 2368 | "iconv-lite": "0.4.24", 2369 | "unpipe": "1.0.0" 2370 | }, 2371 | "engines": { 2372 | "node": ">= 0.8" 2373 | } 2374 | }, 2375 | "node_modules/readdirp": { 2376 | "version": "3.6.0", 2377 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2378 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2379 | "dev": true, 2380 | "dependencies": { 2381 | "picomatch": "^2.2.1" 2382 | }, 2383 | "engines": { 2384 | "node": ">=8.10.0" 2385 | } 2386 | }, 2387 | "node_modules/regenerator-runtime": { 2388 | "version": "0.13.11", 2389 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", 2390 | "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==" 2391 | }, 2392 | "node_modules/require-directory": { 2393 | "version": "2.1.1", 2394 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2395 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2396 | "dev": true, 2397 | "engines": { 2398 | "node": ">=0.10.0" 2399 | } 2400 | }, 2401 | "node_modules/resolve-from": { 2402 | "version": "4.0.0", 2403 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2404 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2405 | "dev": true, 2406 | "engines": { 2407 | "node": ">=4" 2408 | } 2409 | }, 2410 | "node_modules/reusify": { 2411 | "version": "1.0.4", 2412 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2413 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2414 | "dev": true, 2415 | "engines": { 2416 | "iojs": ">=1.0.0", 2417 | "node": ">=0.10.0" 2418 | } 2419 | }, 2420 | "node_modules/run-parallel": { 2421 | "version": "1.2.0", 2422 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2423 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2424 | "dev": true, 2425 | "funding": [ 2426 | { 2427 | "type": "github", 2428 | "url": "https://github.com/sponsors/feross" 2429 | }, 2430 | { 2431 | "type": "patreon", 2432 | "url": "https://www.patreon.com/feross" 2433 | }, 2434 | { 2435 | "type": "consulting", 2436 | "url": "https://feross.org/support" 2437 | } 2438 | ], 2439 | "dependencies": { 2440 | "queue-microtask": "^1.2.2" 2441 | } 2442 | }, 2443 | "node_modules/safe-buffer": { 2444 | "version": "5.2.1", 2445 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2446 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 2447 | "funding": [ 2448 | { 2449 | "type": "github", 2450 | "url": "https://github.com/sponsors/feross" 2451 | }, 2452 | { 2453 | "type": "patreon", 2454 | "url": "https://www.patreon.com/feross" 2455 | }, 2456 | { 2457 | "type": "consulting", 2458 | "url": "https://feross.org/support" 2459 | } 2460 | ] 2461 | }, 2462 | "node_modules/safer-buffer": { 2463 | "version": "2.1.2", 2464 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2465 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2466 | }, 2467 | "node_modules/sdp-transform": { 2468 | "version": "2.14.1", 2469 | "resolved": "https://registry.npmjs.org/sdp-transform/-/sdp-transform-2.14.1.tgz", 2470 | "integrity": "sha512-RjZyX3nVwJyCuTo5tGPx+PZWkDMCg7oOLpSlhjDdZfwUoNqG1mM8nyj31IGHyaPWXhjbP7cdK3qZ2bmkJ1GzRw==", 2471 | "bin": { 2472 | "sdp-verify": "checker.js" 2473 | } 2474 | }, 2475 | "node_modules/semver": { 2476 | "version": "7.6.3", 2477 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2478 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2479 | "dev": true, 2480 | "bin": { 2481 | "semver": "bin/semver.js" 2482 | }, 2483 | "engines": { 2484 | "node": ">=10" 2485 | } 2486 | }, 2487 | "node_modules/send": { 2488 | "version": "0.19.0", 2489 | "resolved": "https://registry.npmjs.org/send/-/send-0.19.0.tgz", 2490 | "integrity": "sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==", 2491 | "dependencies": { 2492 | "debug": "2.6.9", 2493 | "depd": "2.0.0", 2494 | "destroy": "1.2.0", 2495 | "encodeurl": "~1.0.2", 2496 | "escape-html": "~1.0.3", 2497 | "etag": "~1.8.1", 2498 | "fresh": "0.5.2", 2499 | "http-errors": "2.0.0", 2500 | "mime": "1.6.0", 2501 | "ms": "2.1.3", 2502 | "on-finished": "2.4.1", 2503 | "range-parser": "~1.2.1", 2504 | "statuses": "2.0.1" 2505 | }, 2506 | "engines": { 2507 | "node": ">= 0.8.0" 2508 | } 2509 | }, 2510 | "node_modules/send/node_modules/debug": { 2511 | "version": "2.6.9", 2512 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2513 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2514 | "dependencies": { 2515 | "ms": "2.0.0" 2516 | } 2517 | }, 2518 | "node_modules/send/node_modules/debug/node_modules/ms": { 2519 | "version": "2.0.0", 2520 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2521 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 2522 | }, 2523 | "node_modules/send/node_modules/encodeurl": { 2524 | "version": "1.0.2", 2525 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2526 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 2527 | "engines": { 2528 | "node": ">= 0.8" 2529 | } 2530 | }, 2531 | "node_modules/send/node_modules/ms": { 2532 | "version": "2.1.3", 2533 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2534 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2535 | }, 2536 | "node_modules/serialize-javascript": { 2537 | "version": "6.0.2", 2538 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.2.tgz", 2539 | "integrity": "sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==", 2540 | "dev": true, 2541 | "dependencies": { 2542 | "randombytes": "^2.1.0" 2543 | } 2544 | }, 2545 | "node_modules/serve-static": { 2546 | "version": "1.16.2", 2547 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.16.2.tgz", 2548 | "integrity": "sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw==", 2549 | "dependencies": { 2550 | "encodeurl": "~2.0.0", 2551 | "escape-html": "~1.0.3", 2552 | "parseurl": "~1.3.3", 2553 | "send": "0.19.0" 2554 | }, 2555 | "engines": { 2556 | "node": ">= 0.8.0" 2557 | } 2558 | }, 2559 | "node_modules/set-function-length": { 2560 | "version": "1.2.2", 2561 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", 2562 | "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", 2563 | "dependencies": { 2564 | "define-data-property": "^1.1.4", 2565 | "es-errors": "^1.3.0", 2566 | "function-bind": "^1.1.2", 2567 | "get-intrinsic": "^1.2.4", 2568 | "gopd": "^1.0.1", 2569 | "has-property-descriptors": "^1.0.2" 2570 | }, 2571 | "engines": { 2572 | "node": ">= 0.4" 2573 | } 2574 | }, 2575 | "node_modules/setprototypeof": { 2576 | "version": "1.2.0", 2577 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 2578 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 2579 | }, 2580 | "node_modules/shebang-command": { 2581 | "version": "2.0.0", 2582 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2583 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2584 | "dev": true, 2585 | "dependencies": { 2586 | "shebang-regex": "^3.0.0" 2587 | }, 2588 | "engines": { 2589 | "node": ">=8" 2590 | } 2591 | }, 2592 | "node_modules/shebang-regex": { 2593 | "version": "3.0.0", 2594 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2595 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2596 | "dev": true, 2597 | "engines": { 2598 | "node": ">=8" 2599 | } 2600 | }, 2601 | "node_modules/side-channel": { 2602 | "version": "1.0.6", 2603 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", 2604 | "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", 2605 | "dependencies": { 2606 | "call-bind": "^1.0.7", 2607 | "es-errors": "^1.3.0", 2608 | "get-intrinsic": "^1.2.4", 2609 | "object-inspect": "^1.13.1" 2610 | }, 2611 | "engines": { 2612 | "node": ">= 0.4" 2613 | }, 2614 | "funding": { 2615 | "url": "https://github.com/sponsors/ljharb" 2616 | } 2617 | }, 2618 | "node_modules/simple-update-notifier": { 2619 | "version": "2.0.0", 2620 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", 2621 | "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", 2622 | "dev": true, 2623 | "dependencies": { 2624 | "semver": "^7.5.3" 2625 | }, 2626 | "engines": { 2627 | "node": ">=10" 2628 | } 2629 | }, 2630 | "node_modules/sinon": { 2631 | "version": "19.0.2", 2632 | "resolved": "https://registry.npmjs.org/sinon/-/sinon-19.0.2.tgz", 2633 | "integrity": "sha512-euuToqM+PjO4UgXeLETsfQiuoyPXlqFezr6YZDFwHR3t4qaX0fZUe1MfPMznTL5f8BWrVS89KduLdMUsxFCO6g==", 2634 | "dev": true, 2635 | "dependencies": { 2636 | "@sinonjs/commons": "^3.0.1", 2637 | "@sinonjs/fake-timers": "^13.0.2", 2638 | "@sinonjs/samsam": "^8.0.1", 2639 | "diff": "^7.0.0", 2640 | "nise": "^6.1.1", 2641 | "supports-color": "^7.2.0" 2642 | }, 2643 | "funding": { 2644 | "type": "opencollective", 2645 | "url": "https://opencollective.com/sinon" 2646 | } 2647 | }, 2648 | "node_modules/sinon/node_modules/diff": { 2649 | "version": "7.0.0", 2650 | "resolved": "https://registry.npmjs.org/diff/-/diff-7.0.0.tgz", 2651 | "integrity": "sha512-PJWHUb1RFevKCwaFA9RlG5tCd+FO5iRh9A8HEtkmBH2Li03iJriB6m6JIN4rGz3K3JLawI7/veA1xzRKP6ISBw==", 2652 | "dev": true, 2653 | "engines": { 2654 | "node": ">=0.3.1" 2655 | } 2656 | }, 2657 | "node_modules/sinon/node_modules/has-flag": { 2658 | "version": "4.0.0", 2659 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2660 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2661 | "dev": true, 2662 | "engines": { 2663 | "node": ">=8" 2664 | } 2665 | }, 2666 | "node_modules/sinon/node_modules/supports-color": { 2667 | "version": "7.2.0", 2668 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2669 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2670 | "dev": true, 2671 | "dependencies": { 2672 | "has-flag": "^4.0.0" 2673 | }, 2674 | "engines": { 2675 | "node": ">=8" 2676 | } 2677 | }, 2678 | "node_modules/statuses": { 2679 | "version": "2.0.1", 2680 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 2681 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 2682 | "engines": { 2683 | "node": ">= 0.8" 2684 | } 2685 | }, 2686 | "node_modules/string-width": { 2687 | "version": "4.2.3", 2688 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2689 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2690 | "dev": true, 2691 | "dependencies": { 2692 | "emoji-regex": "^8.0.0", 2693 | "is-fullwidth-code-point": "^3.0.0", 2694 | "strip-ansi": "^6.0.1" 2695 | }, 2696 | "engines": { 2697 | "node": ">=8" 2698 | } 2699 | }, 2700 | "node_modules/strip-ansi": { 2701 | "version": "6.0.1", 2702 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2703 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2704 | "dev": true, 2705 | "dependencies": { 2706 | "ansi-regex": "^5.0.1" 2707 | }, 2708 | "engines": { 2709 | "node": ">=8" 2710 | } 2711 | }, 2712 | "node_modules/strip-json-comments": { 2713 | "version": "3.1.1", 2714 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2715 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2716 | "dev": true, 2717 | "engines": { 2718 | "node": ">=8" 2719 | }, 2720 | "funding": { 2721 | "url": "https://github.com/sponsors/sindresorhus" 2722 | } 2723 | }, 2724 | "node_modules/striptags": { 2725 | "version": "3.2.0", 2726 | "resolved": "https://registry.npmjs.org/striptags/-/striptags-3.2.0.tgz", 2727 | "integrity": "sha512-g45ZOGzHDMe2bdYMdIvdAfCQkCTDMGBazSw1ypMowwGIee7ZQ5dU0rBJ8Jqgl+jAKIv4dbeE1jscZq9wid1Tkw==" 2728 | }, 2729 | "node_modules/supports-color": { 2730 | "version": "5.5.0", 2731 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2732 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2733 | "dev": true, 2734 | "dependencies": { 2735 | "has-flag": "^3.0.0" 2736 | }, 2737 | "engines": { 2738 | "node": ">=4" 2739 | } 2740 | }, 2741 | "node_modules/text-table": { 2742 | "version": "0.2.0", 2743 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2744 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2745 | "dev": true 2746 | }, 2747 | "node_modules/to-regex-range": { 2748 | "version": "5.0.1", 2749 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2750 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2751 | "dev": true, 2752 | "license": "MIT", 2753 | "dependencies": { 2754 | "is-number": "^7.0.0" 2755 | }, 2756 | "engines": { 2757 | "node": ">=8.0" 2758 | } 2759 | }, 2760 | "node_modules/toidentifier": { 2761 | "version": "1.0.1", 2762 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 2763 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 2764 | "engines": { 2765 | "node": ">=0.6" 2766 | } 2767 | }, 2768 | "node_modules/touch": { 2769 | "version": "3.1.0", 2770 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2771 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2772 | "dev": true, 2773 | "dependencies": { 2774 | "nopt": "~1.0.10" 2775 | }, 2776 | "bin": { 2777 | "nodetouch": "bin/nodetouch.js" 2778 | } 2779 | }, 2780 | "node_modules/type-check": { 2781 | "version": "0.4.0", 2782 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2783 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2784 | "dev": true, 2785 | "dependencies": { 2786 | "prelude-ls": "^1.2.1" 2787 | }, 2788 | "engines": { 2789 | "node": ">= 0.8.0" 2790 | } 2791 | }, 2792 | "node_modules/type-detect": { 2793 | "version": "4.0.8", 2794 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 2795 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 2796 | "dev": true, 2797 | "engines": { 2798 | "node": ">=4" 2799 | } 2800 | }, 2801 | "node_modules/type-is": { 2802 | "version": "1.6.18", 2803 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2804 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2805 | "dependencies": { 2806 | "media-typer": "0.3.0", 2807 | "mime-types": "~2.1.24" 2808 | }, 2809 | "engines": { 2810 | "node": ">= 0.6" 2811 | } 2812 | }, 2813 | "node_modules/undefsafe": { 2814 | "version": "2.0.5", 2815 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 2816 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 2817 | "dev": true 2818 | }, 2819 | "node_modules/unhomoglyph": { 2820 | "version": "1.0.6", 2821 | "resolved": "https://registry.npmjs.org/unhomoglyph/-/unhomoglyph-1.0.6.tgz", 2822 | "integrity": "sha512-7uvcWI3hWshSADBu4JpnyYbTVc7YlhF5GDW/oPD5AxIxl34k4wXR3WDkPnzLxkN32LiTCTKMQLtKVZiwki3zGg==" 2823 | }, 2824 | "node_modules/unpipe": { 2825 | "version": "1.0.0", 2826 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2827 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 2828 | "engines": { 2829 | "node": ">= 0.8" 2830 | } 2831 | }, 2832 | "node_modules/uri-js": { 2833 | "version": "4.4.1", 2834 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2835 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2836 | "dev": true, 2837 | "dependencies": { 2838 | "punycode": "^2.1.0" 2839 | } 2840 | }, 2841 | "node_modules/utils-merge": { 2842 | "version": "1.0.1", 2843 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2844 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 2845 | "engines": { 2846 | "node": ">= 0.4.0" 2847 | } 2848 | }, 2849 | "node_modules/uuid": { 2850 | "version": "10.0.0", 2851 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-10.0.0.tgz", 2852 | "integrity": "sha512-8XkAphELsDnEGrDxUOHB3RGvXz6TeuYSGEZBOjtTtPm2lwhGBjLgOzLHB63IUWfBpNucQjND6d3AOudO+H3RWQ==", 2853 | "funding": [ 2854 | "https://github.com/sponsors/broofa", 2855 | "https://github.com/sponsors/ctavan" 2856 | ], 2857 | "bin": { 2858 | "uuid": "dist/bin/uuid" 2859 | } 2860 | }, 2861 | "node_modules/vary": { 2862 | "version": "1.1.2", 2863 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2864 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 2865 | "engines": { 2866 | "node": ">= 0.8" 2867 | } 2868 | }, 2869 | "node_modules/which": { 2870 | "version": "2.0.2", 2871 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2872 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2873 | "dev": true, 2874 | "dependencies": { 2875 | "isexe": "^2.0.0" 2876 | }, 2877 | "bin": { 2878 | "node-which": "bin/node-which" 2879 | }, 2880 | "engines": { 2881 | "node": ">= 8" 2882 | } 2883 | }, 2884 | "node_modules/word-wrap": { 2885 | "version": "1.2.5", 2886 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", 2887 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", 2888 | "dev": true, 2889 | "engines": { 2890 | "node": ">=0.10.0" 2891 | } 2892 | }, 2893 | "node_modules/workerpool": { 2894 | "version": "6.5.1", 2895 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.5.1.tgz", 2896 | "integrity": "sha512-Fs4dNYcsdpYSAfVxhnl1L5zTksjvOJxtC5hzMNl+1t9B8hTJTdKDyZ5ju7ztgPy+ft9tBFXoOlDNiOT9WUXZlA==", 2897 | "dev": true 2898 | }, 2899 | "node_modules/wrap-ansi": { 2900 | "version": "7.0.0", 2901 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2902 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2903 | "dev": true, 2904 | "dependencies": { 2905 | "ansi-styles": "^4.0.0", 2906 | "string-width": "^4.1.0", 2907 | "strip-ansi": "^6.0.0" 2908 | }, 2909 | "engines": { 2910 | "node": ">=10" 2911 | }, 2912 | "funding": { 2913 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2914 | } 2915 | }, 2916 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 2917 | "version": "4.3.0", 2918 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2919 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2920 | "dev": true, 2921 | "dependencies": { 2922 | "color-convert": "^2.0.1" 2923 | }, 2924 | "engines": { 2925 | "node": ">=8" 2926 | }, 2927 | "funding": { 2928 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2929 | } 2930 | }, 2931 | "node_modules/wrap-ansi/node_modules/color-convert": { 2932 | "version": "2.0.1", 2933 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2934 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2935 | "dev": true, 2936 | "dependencies": { 2937 | "color-name": "~1.1.4" 2938 | }, 2939 | "engines": { 2940 | "node": ">=7.0.0" 2941 | } 2942 | }, 2943 | "node_modules/wrap-ansi/node_modules/color-name": { 2944 | "version": "1.1.4", 2945 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2946 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2947 | "dev": true 2948 | }, 2949 | "node_modules/wrappy": { 2950 | "version": "1.0.2", 2951 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2952 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 2953 | "dev": true 2954 | }, 2955 | "node_modules/y18n": { 2956 | "version": "5.0.8", 2957 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2958 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2959 | "dev": true, 2960 | "engines": { 2961 | "node": ">=10" 2962 | } 2963 | }, 2964 | "node_modules/yargs": { 2965 | "version": "16.2.0", 2966 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2967 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2968 | "dev": true, 2969 | "dependencies": { 2970 | "cliui": "^7.0.2", 2971 | "escalade": "^3.1.1", 2972 | "get-caller-file": "^2.0.5", 2973 | "require-directory": "^2.1.1", 2974 | "string-width": "^4.2.0", 2975 | "y18n": "^5.0.5", 2976 | "yargs-parser": "^20.2.2" 2977 | }, 2978 | "engines": { 2979 | "node": ">=10" 2980 | } 2981 | }, 2982 | "node_modules/yargs-parser": { 2983 | "version": "20.2.9", 2984 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 2985 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 2986 | "dev": true, 2987 | "engines": { 2988 | "node": ">=10" 2989 | } 2990 | }, 2991 | "node_modules/yargs-unparser": { 2992 | "version": "2.0.0", 2993 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 2994 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 2995 | "dev": true, 2996 | "dependencies": { 2997 | "camelcase": "^6.0.0", 2998 | "decamelize": "^4.0.0", 2999 | "flat": "^5.0.2", 3000 | "is-plain-obj": "^2.1.0" 3001 | }, 3002 | "engines": { 3003 | "node": ">=10" 3004 | } 3005 | }, 3006 | "node_modules/yocto-queue": { 3007 | "version": "0.1.0", 3008 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3009 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3010 | "dev": true, 3011 | "engines": { 3012 | "node": ">=10" 3013 | }, 3014 | "funding": { 3015 | "url": "https://github.com/sponsors/sindresorhus" 3016 | } 3017 | } 3018 | } 3019 | } 3020 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "matrix-alertmanager", 3 | "version": "0.8.0", 4 | "description": "Prometheus Alertmanager bot for Matrix", 5 | "main": "src/app.js", 6 | "scripts": { 7 | "dev": "node_modules/.bin/nodemon src/app.js localhost 3000", 8 | "test": "node_modules/.bin/mocha tests/", 9 | "start": "node src/app.js" 10 | }, 11 | "repository": { 12 | "type": "git", 13 | "url": "https://github.com/jaywink/matrix-alertmanager" 14 | }, 15 | "keywords": [ 16 | "matrix", 17 | "alertmanager", 18 | "prometheus", 19 | "bot" 20 | ], 21 | "engines": { 22 | "node": ">= 20" 23 | }, 24 | "author": "Jason Robinson", 25 | "license": "MIT", 26 | "devDependencies": { 27 | "chai": "<5", 28 | "eslint": "^9.10.0", 29 | "mocha": "^10.7.3", 30 | "nodemon": "^3.1.4", 31 | "npm-check-updates": "^17.1.1", 32 | "sinon": "^19.0.2" 33 | }, 34 | "dependencies": { 35 | "dotenv": "^16.4.5", 36 | "express": "^4.21.0", 37 | "matrix-js-sdk": "^34.5.0", 38 | "striptags": "^3.2.0" 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /screenshot.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/jaywink/matrix-alertmanager/6102aed54ccb6363a5d99c3299f40201b2652e99/screenshot.png -------------------------------------------------------------------------------- /src/app.js: -------------------------------------------------------------------------------- 1 | const express = require('express') 2 | const client = require('./client') 3 | const routes = require('./routes') 4 | 5 | // Config 6 | require('dotenv').config() 7 | 8 | // App 9 | const app = express() 10 | app.use(express.json({ limit: 1048576 })) // 1MiB 11 | // Routes 12 | app.get('/', routes.getRoot) 13 | app.post('/alerts', routes.postAlerts) 14 | // Initialize Matrix client 15 | client.init().then(() => { 16 | // eslint-disable-next-line no-console 17 | console.log('matrix-alertmanager initialized and ready') 18 | app.listen(process.env.APP_PORT, () => {}) 19 | }).catch(e => { 20 | // eslint-disable-next-line no-console 21 | console.error('initialization failed') 22 | // eslint-disable-next-line no-console 23 | console.error(e) 24 | }) 25 | 26 | module.exports = app 27 | -------------------------------------------------------------------------------- /src/client.js: -------------------------------------------------------------------------------- 1 | const striptags = require('striptags') 2 | 3 | let joinedRoomsCache = [] 4 | 5 | let roomRetryInfo = {} 6 | 7 | const client = { 8 | ensureInRoom: async function(roomId) { 9 | const currentTime = Date.now(); 10 | 11 | if (!roomRetryInfo[roomId]) { 12 | roomRetryInfo[roomId] = { lastAttempt: 0, retryCount: 0 }; 13 | } 14 | 15 | const timeSinceLastAttempt = currentTime - roomRetryInfo[roomId].lastAttempt; 16 | 17 | // Calculate the delay using exponential back-off, starting from 1 second (1000 ms). 18 | // 2 ** retryCount will double the wait time with each failure. 19 | const delay = Math.min((2 ** roomRetryInfo[roomId].retryCount) * 1000, 60000); // Cap delay at 60 seconds. 20 | 21 | if (timeSinceLastAttempt < delay) { 22 | return; 23 | } 24 | 25 | roomRetryInfo[roomId].lastAttempt = currentTime; 26 | 27 | if (joinedRoomsCache.indexOf(roomId === -1)) { 28 | try { 29 | const room = await client.connection.joinRoom(roomId) 30 | if (room) { 31 | joinedRoomsCache.push(room.roomId) 32 | roomRetryInfo[roomId].retryCount = 0; 33 | } 34 | } catch (ex) { 35 | console.warn(`Could not join room ${roomId} - ${ex}`) 36 | roomRetryInfo[roomId].retryCount++; 37 | } 38 | } 39 | }, 40 | init: async function() { 41 | const matrix = await import('matrix-js-sdk') 42 | // Init Matrix client 43 | this.connection = matrix.createClient({ 44 | baseUrl: process.env.MATRIX_HOMESERVER_URL, 45 | accessToken: process.env.MATRIX_TOKEN, 46 | userId: process.env.MATRIX_USER, 47 | localTimeoutMs: 30000, 48 | }) 49 | 50 | // Ensure in right rooms 51 | const rooms = await this.connection.getJoinedRooms() 52 | const joinedRooms = rooms.joined_rooms 53 | const roomConfigs = process.env.MATRIX_ROOMS.split('|') 54 | roomConfigs.forEach(async roomConfig => { 55 | const i = roomConfig.lastIndexOf('/') 56 | const room = roomConfig.slice(i+1) 57 | if (joinedRooms.indexOf(room) === -1) { 58 | await this.ensureInRoom(room) 59 | } 60 | }) 61 | }, 62 | sendAlert: async function(roomId, alert) { 63 | await this.ensureInRoom(roomId) 64 | return this.connection.sendEvent( 65 | roomId, 66 | 'm.room.message', 67 | { 68 | 'body': striptags(alert), 69 | 'formatted_body': alert, 70 | 'msgtype': 'm.text', 71 | 'format': 'org.matrix.custom.html' 72 | }, 73 | '', 74 | ) 75 | }, 76 | } 77 | 78 | module.exports = client 79 | -------------------------------------------------------------------------------- /src/routes.js: -------------------------------------------------------------------------------- 1 | const client = require('./client') 2 | const utils = require('./utils') 3 | 4 | const routes = { 5 | getRoot: (req, res) => { 6 | res.send('Hey 👋') 7 | }, 8 | postAlerts: async (req, res) => { 9 | const secret = req.query.secret || utils.getBasicAuthPassword(req) 10 | if (secret !== process.env.APP_ALERTMANAGER_SECRET) { 11 | res.status(403).end() 12 | return 13 | } 14 | const alerts = utils.parseAlerts(req.body) 15 | 16 | if (!alerts) { 17 | res.json({'result': 'no alerts found in payload'}) 18 | return 19 | } 20 | 21 | const roomId = utils.getRoomForReceiver(req.body.receiver) 22 | if (!roomId) { 23 | res.json({'result': 'no rooms configured for this receiver'}) 24 | return 25 | } 26 | 27 | try { 28 | const promises = alerts.map(alert => client.sendAlert(roomId, alert)) 29 | await Promise.all(promises) 30 | res.json({'result': 'ok'}) 31 | } catch (e) { 32 | // eslint-disable-next-line no-console 33 | console.error(e) 34 | res.status(500) 35 | res.json({'result': 'error'}) 36 | } 37 | }, 38 | } 39 | 40 | module.exports = routes 41 | -------------------------------------------------------------------------------- /src/utils.js: -------------------------------------------------------------------------------- 1 | const utils = { 2 | 3 | getBasicAuthPassword: req => { 4 | const content = req.get("Authorization").replace(/^Basic /, '') 5 | return atob(content).replace(/^alertmanager:/, '') 6 | }, 7 | 8 | getRoomForReceiver: receiver => { 9 | /* 10 | Get the right roomId for the given receiver from MATRIX_ROOMS configuration item. 11 | 12 | For is separated by pipe for multiple receiver/rooms. 13 | */ 14 | const roomConfigs = process.env.MATRIX_ROOMS.split('|') 15 | let roomId = false 16 | for (let config of roomConfigs) { 17 | const i = config.lastIndexOf('/') 18 | if (config.slice(0, i) === receiver) { 19 | roomId = config.slice(i+1) 20 | break 21 | } 22 | } 23 | return roomId 24 | }, 25 | 26 | formatAlert: data => { 27 | /* 28 | Format a single alert into a message string. 29 | */ 30 | let parts = [] 31 | //console.log(data) 32 | 33 | if (data.status === 'firing') { 34 | if (process.env.MENTION_ROOM === "1") { 35 | parts.push('@room', '
') 36 | } 37 | let color = (function(severity) { 38 | switch(severity) { 39 | case 'warning': 40 | return '#ffc107'; // orange 41 | case 'none': 42 | return '#17a2b8'; // blue 43 | default: 44 | return '#dc3545'; // red 45 | } 46 | })(data.labels.severity); 47 | parts.push('FIRING:') 48 | } else if (data.status === 'resolved') { 49 | parts.push('RESOLVED:') 50 | } else { 51 | parts.push(data.status.toUpperCase() + ':') 52 | } 53 | 54 | // name and location of occurrence 55 | if (data.labels.alertname !== undefined) { 56 | parts.push('', data.labels.alertname, '') 57 | if (data.labels.host !== undefined || data.labels.instance !== undefined) { 58 | parts.push(' at ') 59 | } 60 | } 61 | if (data.labels.host !== undefined) { 62 | parts.push(data.labels.host) 63 | } else if (data.labels.instance !== undefined) { 64 | parts.push(data.labels.instance) 65 | } 66 | 67 | // additional descriptive content 68 | if (data.annotations.message !== undefined) { 69 | parts.push('
', data.annotations.message.replace("\n", "
")) 70 | } 71 | if (data.annotations.description !== undefined) { 72 | parts.push('
', data.annotations.description) 73 | } 74 | parts.push('
Alert link') 75 | 76 | return parts.join(' ') 77 | }, 78 | 79 | parseAlerts: data => { 80 | /* 81 | Parse AlertManager data object into an Array of message strings. 82 | */ 83 | if (!data.alerts) { 84 | return [] 85 | } 86 | 87 | let alerts = [] 88 | 89 | data.alerts.forEach(alert => { 90 | alerts.push(utils.formatAlert(alert)) 91 | }) 92 | return alerts 93 | }, 94 | } 95 | 96 | module.exports = utils 97 | -------------------------------------------------------------------------------- /tests/fixtures.js: -------------------------------------------------------------------------------- 1 | const fixtures = { 2 | alerts: { 3 | 'receiver': 'monitoring/default-receiver/matrix', 4 | 'status': 'firing', 5 | 'alerts': [{ 6 | 'status': 'firing', 7 | 'labels': { 8 | 'alertname': 'DiskSpace', 9 | 'device': '/dev/sda1', 10 | 'fstype': 'ext4', 11 | 'host': 'foo', 12 | 'instance': '1.2.3.4', 13 | 'job': 'node', 14 | 'mountpoint': '/' 15 | }, 16 | 'annotations': { 17 | 'description': 'Filesystem low', 18 | 'summary': 'Instance 1.2.3.4 filesystem usage is dangerously high' 19 | }, 20 | 'startsAt': '2018-12-05T23:38:43.700314857Z', 21 | 'endsAt': '0001-01-01T00:00:00Z', 22 | 'generatorURL': 'http://1.2.3.4/graph?1' 23 | }, { 24 | 'status': 'firing', 25 | 'labels': { 26 | 'alertname': 'DiskSpace', 27 | 'device': '/dev/sda1', 28 | 'fstype': 'ext4', 29 | 'host': 'foo', 30 | 'instance': '1.2.3.4', 31 | 'job': 'node', 32 | 'mountpoint': '/' 33 | }, 34 | 'annotations': { 35 | 'description': 'Filesystem low', 36 | 'summary': 'Instance 1.2.3.4 filesystem usage is dangerously high' 37 | }, 38 | 'startsAt': '2018-12-05T23:38:43.700314857Z', 39 | 'endsAt': '0001-01-01T00:00:00Z', 40 | 'generatorURL': 'http://1.2.3.4/graph?1' 41 | }], 42 | 'groupLabels': {}, 43 | 'commonLabels': { 44 | 'job': 'node' 45 | }, 46 | 'commonAnnotations': {}, 47 | 'externalURL': 'http://1.2.3.4', 48 | 'version': '4', 49 | 'groupKey': '{}:{}' 50 | } 51 | } 52 | 53 | module.exports = fixtures 54 | -------------------------------------------------------------------------------- /tests/routes.tests.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable no-undef */ 2 | const chai = require('chai') 3 | const sinon = require('sinon') 4 | const client = require('../src//client') 5 | const fixtures = require('./fixtures') 6 | const routes = require('../src/routes') 7 | const utils = require('../src/utils') 8 | 9 | const expect = chai.expect 10 | require('dotenv').config({path: '.env.default'}) 11 | 12 | describe('routes', function() { 13 | describe('getRoot', function() { 14 | it('waves', function() { 15 | let req = {} 16 | let res = { 17 | send: sinon.spy() 18 | } 19 | routes.getRoot(req, res) 20 | 21 | expect(res.send.calledOnce).to.be.true 22 | expect(res.send.firstCall.args[0]).to.equal('Hey 👋') 23 | }) 24 | }) 25 | 26 | describe('postAlerts', function() { 27 | before(async() => { 28 | this.clientStub = sinon.stub(client, 'sendAlert').returns(true) 29 | this.req = { 30 | body: fixtures.alerts, 31 | query: { 32 | secret: process.env.APP_ALERTMANAGER_SECRET, 33 | }, 34 | } 35 | this.res = { 36 | json: sinon.spy() 37 | } 38 | }) 39 | 40 | it('calls client sendAlert for each alert', () => { 41 | routes.postAlerts(this.req, this.res) 42 | 43 | expect(this.clientStub.calledTwice).to.be.true 44 | }) 45 | 46 | it('calls parseAlerts', () => { 47 | const parseStub = sinon.stub(utils, 'parseAlerts').returns([]) 48 | 49 | routes.postAlerts(this.req, this.res) 50 | 51 | expect(parseStub.calledOnce).to.be.true 52 | expect(parseStub.firstCall.args[0]).to.eql(fixtures.alerts) 53 | 54 | parseStub.restore() 55 | }) 56 | 57 | it('returns ok', async() => { 58 | await routes.postAlerts(this.req, this.res) 59 | 60 | expect(this.res.json.calledOnce).to.be.true 61 | expect(this.res.json.firstCall.args[0]).to.eql({'result': 'ok'}) 62 | }) 63 | 64 | afterEach(() => { 65 | this.clientStub.reset() 66 | sinon.reset(this.res.json) 67 | }) 68 | }) 69 | }) 70 | --------------------------------------------------------------------------------