├── .gitignore ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── src └── index.ts ├── superargs.png └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist 3 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2025 Supercorp 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 | ![Superargs: Update MCP server args from the chat](https://raw.githubusercontent.com/supercorp-ai/superargs/main/superargs.png) 2 | 3 | **Superargs** allows setting up MCP server args during runtime. 4 | Provide arguments to any **MCP server** during interaction with assistant instead of during initial setup. 5 | Whether it’s authentication tokens, environment variables, or other CLI arguments, Superargs makes it easy to provide it during runtime. 6 | 7 | Supported by [superinterface.ai](https://superinterface.ai), [supermachine.ai](https://supermachine.ai) and [supercorp.ai](https://supercorp.ai). 8 | 9 | ## Installation & Usage 10 | 11 | Run Superargs via `npx`: 12 | 13 | ```bash 14 | npx -y superargs --stdio "npx -y @modelcontextprotocol/server-postgres {{databaseUrl}}" 15 | ``` 16 | 17 | - **`--stdio`**: Shell command that runs a stdio MCP server with args to be replaced during runtime in the form `{{argName}}`. 18 | - **`--update-args-tool-name`**: (Optional) Custom name for the tool used to update/restart args. Defaults to `update_args`. 19 | 20 | ### Args 21 | 22 | Args in the `--stdio` command are denoted by `{{argName}}`. For example: 23 | 24 | ```bash 25 | npx -y superargs --stdio "GITHUB_PERSONAL_ACCESS_TOKEN={{githubToken}} npx -y @modelcontextprotocol/server-github" 26 | ``` 27 | 28 | In this command: 29 | - `{{githubToken}}` is an arg that can be set at runtime using the `update_args` tool (or a custom tool name if specified). 30 | 31 | ## Once Started 32 | 33 | - **Initial state**: At the start, the MCP server will not have any args set. 34 | 35 | - If underlying MCP stdio server can start without args, it will try to start without them to provide tools lists and other MCP server functions. 36 | If it can work without args, the only difference will be that it will have an additional **update_args** tool to update args. 37 | 38 | - If the server requires args to start, it will not start until the args are set and it will only have the **update_args** tool. 39 | All other MCP server functions will either return an empty list or an error message. 40 | 41 | - **When update_args is used**: The server will restart with the new args and all MCP server functions will be available. 42 | 43 | - **Tool to Update Args**: By default, named `update_args`, allows updating args and restarting the child MCP server. 44 | 45 | ## Examples 46 | 47 | Another example with GitHub MCP server: 48 | 49 | ```bash 50 | npx -y superargs --stdio "GITHUB_PERSONAL_ACCESS_TOKEN={{githubToken}} npx -y @modelcontextprotocol/server-github" 51 | ``` 52 | 53 | And with SQLite MCP server: 54 | 55 | ```bash 56 | npx -y superargs --stdio "uv mcp-server-sqlite --db-path={{dbPath}}" 57 | ``` 58 | 59 | ### Example with MCP Inspector 60 | 61 | 1. **Run MCP Inspector with Superargs**: 62 | 63 | ```bash 64 | npx @modelcontextprotocol/inspector npx -y superargs --stdio "npx -y @modelcontextprotocol/server-postgres {{databaseUrl}}" 65 | ``` 66 | 67 | This command starts Superargs and connects it to MCP Inspector, enabling you to manage your PostgreSQL MCP server through the inspector interface. 68 | 69 | 2. **Manage MCP Server**: 70 | 71 | With MCP Inspector, you can list tools, run prompts, access resources, or perform other MCP actions through Superargs. 72 | 73 | ## How It Works 74 | 75 | **Superargs** acts as a middleware wrapper around your MCP server, enabling dynamic injection of args at runtime. It forwards all MCP requests (tools, prompts, resources, messages, roots, etc.) to the underlying child server and introduces an additional tool to manage these args. 76 | 77 | ### Key Features 78 | 79 | - **Dynamic Arg Injection**: Replace placeholders in your MCP server command with actual values during runtime. 80 | - **Customizable Tool Name**: Rename the arg update tool via `--update-args-tool-name` to suit your workflow. 81 | - **Comprehensive MCP Support**: Forwards all MCP requests to the child server, including tools, prompts, resources, messages, and roots. 82 | - **Change Notifications**: Sends notifications like `sendToolListChanged`, `sendPromptListChanged`, and `sendResourceUpdated` when args are updated, ensuring connected clients are aware of changes. 83 | 84 | ### Main Use Case 85 | 86 | **Superargs** empowers users to set up and configure MCP servers dynamically during their interactions with AI assistants. 87 | Instead of requiring administrators to pre-configure servers with necessary args and credentials, users can provide these details on-the-fly through conversation, enhancing flexibility and reducing setup overhead. 88 | 89 | ### Providing sensitive args securely 90 | 91 | Args are passed to the child MCP server in the command specified. Nothing is stored. 92 | 93 | If you don’t want the LLM to ever see these args, do a direct call to the MCP server through server client (so it’s not the assistant who is calling it, but your code directly). 94 | 95 | ## Why MCP? 96 | 97 | [Model Context Protocol](https://modelcontextprotocol.io/) standardizes how AI tools exchange data. If your MCP server requires dynamic args such as authentication tokens or configuration paths, **Superargs** allows you to provide them at runtime without altering the server's code. This enables flexible deployments, remote access, and easier debugging. 98 | 99 | ## Contributing 100 | 101 | Contributions are welcome! Whether you have ideas for new features, improvements, or encounter any issues, please open an [issue](https://github.com/supercorp-ai/superargs/issues) or submit a [pull request](https://github.com/supercorp-ai/superarg/pulls). 102 | 103 | ## License 104 | 105 | [MIT License](./LICENSE) 106 | 107 | --- 108 | 109 | **Superargs** is supported by [Superinterface](https://superinterface.ai), [Supermachine](https://supermachine.ai) and [Supercorp](https://supercorp.ai). 110 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "superarg", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "superarg", 9 | "version": "1.0.0", 10 | "dependencies": { 11 | "@modelcontextprotocol/sdk": "latest", 12 | "body-parser": "^1.20.2", 13 | "express": "^4.18.2", 14 | "yargs": "^17.7.2" 15 | }, 16 | "bin": { 17 | "superarg": "dist/index.js" 18 | }, 19 | "devDependencies": { 20 | "@types/body-parser": "^1.19.2", 21 | "@types/express": "^4.17.16", 22 | "@types/node": "^20.5.9", 23 | "@types/yargs": "^17.0.33", 24 | "ts-node": "^10.9.1", 25 | "tsx": "^3.12.7", 26 | "typescript": "^5.2.2" 27 | } 28 | }, 29 | "node_modules/@cspotcode/source-map-support": { 30 | "version": "0.8.1", 31 | "resolved": "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz", 32 | "integrity": "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==", 33 | "dev": true, 34 | "dependencies": { 35 | "@jridgewell/trace-mapping": "0.3.9" 36 | }, 37 | "engines": { 38 | "node": ">=12" 39 | } 40 | }, 41 | "node_modules/@esbuild/android-arm": { 42 | "version": "0.18.20", 43 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.18.20.tgz", 44 | "integrity": "sha512-fyi7TDI/ijKKNZTUJAQqiG5T7YjJXgnzkURqmGj13C6dCqckZBLdl4h7bkhHt/t0WP+zO9/zwroDvANaOqO5Sw==", 45 | "cpu": [ 46 | "arm" 47 | ], 48 | "dev": true, 49 | "optional": true, 50 | "os": [ 51 | "android" 52 | ], 53 | "engines": { 54 | "node": ">=12" 55 | } 56 | }, 57 | "node_modules/@esbuild/android-arm64": { 58 | "version": "0.18.20", 59 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.18.20.tgz", 60 | "integrity": "sha512-Nz4rJcchGDtENV0eMKUNa6L12zz2zBDXuhj/Vjh18zGqB44Bi7MBMSXjgunJgjRhCmKOjnPuZp4Mb6OKqtMHLQ==", 61 | "cpu": [ 62 | "arm64" 63 | ], 64 | "dev": true, 65 | "optional": true, 66 | "os": [ 67 | "android" 68 | ], 69 | "engines": { 70 | "node": ">=12" 71 | } 72 | }, 73 | "node_modules/@esbuild/android-x64": { 74 | "version": "0.18.20", 75 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.18.20.tgz", 76 | "integrity": "sha512-8GDdlePJA8D6zlZYJV/jnrRAi6rOiNaCC/JclcXpB+KIuvfBN4owLtgzY2bsxnx666XjJx2kDPUmnTtR8qKQUg==", 77 | "cpu": [ 78 | "x64" 79 | ], 80 | "dev": true, 81 | "optional": true, 82 | "os": [ 83 | "android" 84 | ], 85 | "engines": { 86 | "node": ">=12" 87 | } 88 | }, 89 | "node_modules/@esbuild/darwin-arm64": { 90 | "version": "0.18.20", 91 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.18.20.tgz", 92 | "integrity": "sha512-bxRHW5kHU38zS2lPTPOyuyTm+S+eobPUnTNkdJEfAddYgEcll4xkT8DB9d2008DtTbl7uJag2HuE5NZAZgnNEA==", 93 | "cpu": [ 94 | "arm64" 95 | ], 96 | "dev": true, 97 | "optional": true, 98 | "os": [ 99 | "darwin" 100 | ], 101 | "engines": { 102 | "node": ">=12" 103 | } 104 | }, 105 | "node_modules/@esbuild/darwin-x64": { 106 | "version": "0.18.20", 107 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.18.20.tgz", 108 | "integrity": "sha512-pc5gxlMDxzm513qPGbCbDukOdsGtKhfxD1zJKXjCCcU7ju50O7MeAZ8c4krSJcOIJGFR+qx21yMMVYwiQvyTyQ==", 109 | "cpu": [ 110 | "x64" 111 | ], 112 | "dev": true, 113 | "optional": true, 114 | "os": [ 115 | "darwin" 116 | ], 117 | "engines": { 118 | "node": ">=12" 119 | } 120 | }, 121 | "node_modules/@esbuild/freebsd-arm64": { 122 | "version": "0.18.20", 123 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.20.tgz", 124 | "integrity": "sha512-yqDQHy4QHevpMAaxhhIwYPMv1NECwOvIpGCZkECn8w2WFHXjEwrBn3CeNIYsibZ/iZEUemj++M26W3cNR5h+Tw==", 125 | "cpu": [ 126 | "arm64" 127 | ], 128 | "dev": true, 129 | "optional": true, 130 | "os": [ 131 | "freebsd" 132 | ], 133 | "engines": { 134 | "node": ">=12" 135 | } 136 | }, 137 | "node_modules/@esbuild/freebsd-x64": { 138 | "version": "0.18.20", 139 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.18.20.tgz", 140 | "integrity": "sha512-tgWRPPuQsd3RmBZwarGVHZQvtzfEBOreNuxEMKFcd5DaDn2PbBxfwLcj4+aenoh7ctXcbXmOQIn8HI6mCSw5MQ==", 141 | "cpu": [ 142 | "x64" 143 | ], 144 | "dev": true, 145 | "optional": true, 146 | "os": [ 147 | "freebsd" 148 | ], 149 | "engines": { 150 | "node": ">=12" 151 | } 152 | }, 153 | "node_modules/@esbuild/linux-arm": { 154 | "version": "0.18.20", 155 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.18.20.tgz", 156 | "integrity": "sha512-/5bHkMWnq1EgKr1V+Ybz3s1hWXok7mDFUMQ4cG10AfW3wL02PSZi5kFpYKrptDsgb2WAJIvRcDm+qIvXf/apvg==", 157 | "cpu": [ 158 | "arm" 159 | ], 160 | "dev": true, 161 | "optional": true, 162 | "os": [ 163 | "linux" 164 | ], 165 | "engines": { 166 | "node": ">=12" 167 | } 168 | }, 169 | "node_modules/@esbuild/linux-arm64": { 170 | "version": "0.18.20", 171 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.18.20.tgz", 172 | "integrity": "sha512-2YbscF+UL7SQAVIpnWvYwM+3LskyDmPhe31pE7/aoTMFKKzIc9lLbyGUpmmb8a8AixOL61sQ/mFh3jEjHYFvdA==", 173 | "cpu": [ 174 | "arm64" 175 | ], 176 | "dev": true, 177 | "optional": true, 178 | "os": [ 179 | "linux" 180 | ], 181 | "engines": { 182 | "node": ">=12" 183 | } 184 | }, 185 | "node_modules/@esbuild/linux-ia32": { 186 | "version": "0.18.20", 187 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.18.20.tgz", 188 | "integrity": "sha512-P4etWwq6IsReT0E1KHU40bOnzMHoH73aXp96Fs8TIT6z9Hu8G6+0SHSw9i2isWrD2nbx2qo5yUqACgdfVGx7TA==", 189 | "cpu": [ 190 | "ia32" 191 | ], 192 | "dev": true, 193 | "optional": true, 194 | "os": [ 195 | "linux" 196 | ], 197 | "engines": { 198 | "node": ">=12" 199 | } 200 | }, 201 | "node_modules/@esbuild/linux-loong64": { 202 | "version": "0.18.20", 203 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.18.20.tgz", 204 | "integrity": "sha512-nXW8nqBTrOpDLPgPY9uV+/1DjxoQ7DoB2N8eocyq8I9XuqJ7BiAMDMf9n1xZM9TgW0J8zrquIb/A7s3BJv7rjg==", 205 | "cpu": [ 206 | "loong64" 207 | ], 208 | "dev": true, 209 | "optional": true, 210 | "os": [ 211 | "linux" 212 | ], 213 | "engines": { 214 | "node": ">=12" 215 | } 216 | }, 217 | "node_modules/@esbuild/linux-mips64el": { 218 | "version": "0.18.20", 219 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.18.20.tgz", 220 | "integrity": "sha512-d5NeaXZcHp8PzYy5VnXV3VSd2D328Zb+9dEq5HE6bw6+N86JVPExrA6O68OPwobntbNJ0pzCpUFZTo3w0GyetQ==", 221 | "cpu": [ 222 | "mips64el" 223 | ], 224 | "dev": true, 225 | "optional": true, 226 | "os": [ 227 | "linux" 228 | ], 229 | "engines": { 230 | "node": ">=12" 231 | } 232 | }, 233 | "node_modules/@esbuild/linux-ppc64": { 234 | "version": "0.18.20", 235 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.18.20.tgz", 236 | "integrity": "sha512-WHPyeScRNcmANnLQkq6AfyXRFr5D6N2sKgkFo2FqguP44Nw2eyDlbTdZwd9GYk98DZG9QItIiTlFLHJHjxP3FA==", 237 | "cpu": [ 238 | "ppc64" 239 | ], 240 | "dev": true, 241 | "optional": true, 242 | "os": [ 243 | "linux" 244 | ], 245 | "engines": { 246 | "node": ">=12" 247 | } 248 | }, 249 | "node_modules/@esbuild/linux-riscv64": { 250 | "version": "0.18.20", 251 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.18.20.tgz", 252 | "integrity": "sha512-WSxo6h5ecI5XH34KC7w5veNnKkju3zBRLEQNY7mv5mtBmrP/MjNBCAlsM2u5hDBlS3NGcTQpoBvRzqBcRtpq1A==", 253 | "cpu": [ 254 | "riscv64" 255 | ], 256 | "dev": true, 257 | "optional": true, 258 | "os": [ 259 | "linux" 260 | ], 261 | "engines": { 262 | "node": ">=12" 263 | } 264 | }, 265 | "node_modules/@esbuild/linux-s390x": { 266 | "version": "0.18.20", 267 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.18.20.tgz", 268 | "integrity": "sha512-+8231GMs3mAEth6Ja1iK0a1sQ3ohfcpzpRLH8uuc5/KVDFneH6jtAJLFGafpzpMRO6DzJ6AvXKze9LfFMrIHVQ==", 269 | "cpu": [ 270 | "s390x" 271 | ], 272 | "dev": true, 273 | "optional": true, 274 | "os": [ 275 | "linux" 276 | ], 277 | "engines": { 278 | "node": ">=12" 279 | } 280 | }, 281 | "node_modules/@esbuild/linux-x64": { 282 | "version": "0.18.20", 283 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.18.20.tgz", 284 | "integrity": "sha512-UYqiqemphJcNsFEskc73jQ7B9jgwjWrSayxawS6UVFZGWrAAtkzjxSqnoclCXxWtfwLdzU+vTpcNYhpn43uP1w==", 285 | "cpu": [ 286 | "x64" 287 | ], 288 | "dev": true, 289 | "optional": true, 290 | "os": [ 291 | "linux" 292 | ], 293 | "engines": { 294 | "node": ">=12" 295 | } 296 | }, 297 | "node_modules/@esbuild/netbsd-x64": { 298 | "version": "0.18.20", 299 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.18.20.tgz", 300 | "integrity": "sha512-iO1c++VP6xUBUmltHZoMtCUdPlnPGdBom6IrO4gyKPFFVBKioIImVooR5I83nTew5UOYrk3gIJhbZh8X44y06A==", 301 | "cpu": [ 302 | "x64" 303 | ], 304 | "dev": true, 305 | "optional": true, 306 | "os": [ 307 | "netbsd" 308 | ], 309 | "engines": { 310 | "node": ">=12" 311 | } 312 | }, 313 | "node_modules/@esbuild/openbsd-x64": { 314 | "version": "0.18.20", 315 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.18.20.tgz", 316 | "integrity": "sha512-e5e4YSsuQfX4cxcygw/UCPIEP6wbIL+se3sxPdCiMbFLBWu0eiZOJ7WoD+ptCLrmjZBK1Wk7I6D/I3NglUGOxg==", 317 | "cpu": [ 318 | "x64" 319 | ], 320 | "dev": true, 321 | "optional": true, 322 | "os": [ 323 | "openbsd" 324 | ], 325 | "engines": { 326 | "node": ">=12" 327 | } 328 | }, 329 | "node_modules/@esbuild/sunos-x64": { 330 | "version": "0.18.20", 331 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.18.20.tgz", 332 | "integrity": "sha512-kDbFRFp0YpTQVVrqUd5FTYmWo45zGaXe0X8E1G/LKFC0v8x0vWrhOWSLITcCn63lmZIxfOMXtCfti/RxN/0wnQ==", 333 | "cpu": [ 334 | "x64" 335 | ], 336 | "dev": true, 337 | "optional": true, 338 | "os": [ 339 | "sunos" 340 | ], 341 | "engines": { 342 | "node": ">=12" 343 | } 344 | }, 345 | "node_modules/@esbuild/win32-arm64": { 346 | "version": "0.18.20", 347 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.18.20.tgz", 348 | "integrity": "sha512-ddYFR6ItYgoaq4v4JmQQaAI5s7npztfV4Ag6NrhiaW0RrnOXqBkgwZLofVTlq1daVTQNhtI5oieTvkRPfZrePg==", 349 | "cpu": [ 350 | "arm64" 351 | ], 352 | "dev": true, 353 | "optional": true, 354 | "os": [ 355 | "win32" 356 | ], 357 | "engines": { 358 | "node": ">=12" 359 | } 360 | }, 361 | "node_modules/@esbuild/win32-ia32": { 362 | "version": "0.18.20", 363 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.18.20.tgz", 364 | "integrity": "sha512-Wv7QBi3ID/rROT08SABTS7eV4hX26sVduqDOTe1MvGMjNd3EjOz4b7zeexIR62GTIEKrfJXKL9LFxTYgkyeu7g==", 365 | "cpu": [ 366 | "ia32" 367 | ], 368 | "dev": true, 369 | "optional": true, 370 | "os": [ 371 | "win32" 372 | ], 373 | "engines": { 374 | "node": ">=12" 375 | } 376 | }, 377 | "node_modules/@esbuild/win32-x64": { 378 | "version": "0.18.20", 379 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.18.20.tgz", 380 | "integrity": "sha512-kTdfRcSiDfQca/y9QIkng02avJ+NCaQvrMejlsB3RRv5sE9rRoeBPISaZpKxHELzRxZyLvNts1P27W3wV+8geQ==", 381 | "cpu": [ 382 | "x64" 383 | ], 384 | "dev": true, 385 | "optional": true, 386 | "os": [ 387 | "win32" 388 | ], 389 | "engines": { 390 | "node": ">=12" 391 | } 392 | }, 393 | "node_modules/@jridgewell/resolve-uri": { 394 | "version": "3.1.2", 395 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 396 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 397 | "dev": true, 398 | "engines": { 399 | "node": ">=6.0.0" 400 | } 401 | }, 402 | "node_modules/@jridgewell/sourcemap-codec": { 403 | "version": "1.5.0", 404 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", 405 | "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", 406 | "dev": true 407 | }, 408 | "node_modules/@jridgewell/trace-mapping": { 409 | "version": "0.3.9", 410 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz", 411 | "integrity": "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==", 412 | "dev": true, 413 | "dependencies": { 414 | "@jridgewell/resolve-uri": "^3.0.3", 415 | "@jridgewell/sourcemap-codec": "^1.4.10" 416 | } 417 | }, 418 | "node_modules/@modelcontextprotocol/sdk": { 419 | "version": "1.0.4", 420 | "resolved": "https://registry.npmjs.org/@modelcontextprotocol/sdk/-/sdk-1.0.4.tgz", 421 | "integrity": "sha512-C+jw1lF6HSGzs7EZpzHbXfzz9rj9him4BaoumlTciW/IDDgIpweF/qiCWKlP02QKg5PPcgY6xY2WCt5y2tpYow==", 422 | "dependencies": { 423 | "content-type": "^1.0.5", 424 | "raw-body": "^3.0.0", 425 | "zod": "^3.23.8" 426 | } 427 | }, 428 | "node_modules/@tsconfig/node10": { 429 | "version": "1.0.11", 430 | "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.11.tgz", 431 | "integrity": "sha512-DcRjDCujK/kCk/cUe8Xz8ZSpm8mS3mNNpta+jGCA6USEDfktlNvm1+IuZ9eTcDbNk41BHwpHHeW+N1lKCz4zOw==", 432 | "dev": true 433 | }, 434 | "node_modules/@tsconfig/node12": { 435 | "version": "1.0.11", 436 | "resolved": "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz", 437 | "integrity": "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==", 438 | "dev": true 439 | }, 440 | "node_modules/@tsconfig/node14": { 441 | "version": "1.0.3", 442 | "resolved": "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz", 443 | "integrity": "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==", 444 | "dev": true 445 | }, 446 | "node_modules/@tsconfig/node16": { 447 | "version": "1.0.4", 448 | "resolved": "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.4.tgz", 449 | "integrity": "sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA==", 450 | "dev": true 451 | }, 452 | "node_modules/@types/body-parser": { 453 | "version": "1.19.5", 454 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.5.tgz", 455 | "integrity": "sha512-fB3Zu92ucau0iQ0JMCFQE7b/dv8Ot07NI3KaZIkIUNXq82k4eBAqUaneXfleGY9JWskeS9y+u0nXMyspcuQrCg==", 456 | "dev": true, 457 | "dependencies": { 458 | "@types/connect": "*", 459 | "@types/node": "*" 460 | } 461 | }, 462 | "node_modules/@types/connect": { 463 | "version": "3.4.38", 464 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.38.tgz", 465 | "integrity": "sha512-K6uROf1LD88uDQqJCktA4yzL1YYAK6NgfsI0v/mTgyPKWsX1CnJ0XPSDhViejru1GcRkLWb8RlzFYJRqGUbaug==", 466 | "dev": true, 467 | "dependencies": { 468 | "@types/node": "*" 469 | } 470 | }, 471 | "node_modules/@types/express": { 472 | "version": "4.17.21", 473 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.21.tgz", 474 | "integrity": "sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ==", 475 | "dev": true, 476 | "dependencies": { 477 | "@types/body-parser": "*", 478 | "@types/express-serve-static-core": "^4.17.33", 479 | "@types/qs": "*", 480 | "@types/serve-static": "*" 481 | } 482 | }, 483 | "node_modules/@types/express-serve-static-core": { 484 | "version": "4.19.6", 485 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.19.6.tgz", 486 | "integrity": "sha512-N4LZ2xG7DatVqhCZzOGb1Yi5lMbXSZcmdLDe9EzSndPV2HpWYWzRbaerl2n27irrm94EPpprqa8KpskPT085+A==", 487 | "dev": true, 488 | "dependencies": { 489 | "@types/node": "*", 490 | "@types/qs": "*", 491 | "@types/range-parser": "*", 492 | "@types/send": "*" 493 | } 494 | }, 495 | "node_modules/@types/http-errors": { 496 | "version": "2.0.4", 497 | "resolved": "https://registry.npmjs.org/@types/http-errors/-/http-errors-2.0.4.tgz", 498 | "integrity": "sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA==", 499 | "dev": true 500 | }, 501 | "node_modules/@types/mime": { 502 | "version": "1.3.5", 503 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.5.tgz", 504 | "integrity": "sha512-/pyBZWSLD2n0dcHE3hq8s8ZvcETHtEuF+3E7XVt0Ig2nvsVQXdghHVcEkIWjy9A0wKfTn97a/PSDYohKIlnP/w==", 505 | "dev": true 506 | }, 507 | "node_modules/@types/node": { 508 | "version": "20.17.10", 509 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.10.tgz", 510 | "integrity": "sha512-/jrvh5h6NXhEauFFexRin69nA0uHJ5gwk4iDivp/DeoEua3uwCUto6PC86IpRITBOs4+6i2I56K5x5b6WYGXHA==", 511 | "dev": true, 512 | "dependencies": { 513 | "undici-types": "~6.19.2" 514 | } 515 | }, 516 | "node_modules/@types/qs": { 517 | "version": "6.9.17", 518 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.17.tgz", 519 | "integrity": "sha512-rX4/bPcfmvxHDv0XjfJELTTr+iB+tn032nPILqHm5wbthUUUuVtNGGqzhya9XUxjTP8Fpr0qYgSZZKxGY++svQ==", 520 | "dev": true 521 | }, 522 | "node_modules/@types/range-parser": { 523 | "version": "1.2.7", 524 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.7.tgz", 525 | "integrity": "sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==", 526 | "dev": true 527 | }, 528 | "node_modules/@types/send": { 529 | "version": "0.17.4", 530 | "resolved": "https://registry.npmjs.org/@types/send/-/send-0.17.4.tgz", 531 | "integrity": "sha512-x2EM6TJOybec7c52BX0ZspPodMsQUd5L6PRwOunVyVUhXiBSKf3AezDL8Dgvgt5o0UfKNfuA0eMLr2wLT4AiBA==", 532 | "dev": true, 533 | "dependencies": { 534 | "@types/mime": "^1", 535 | "@types/node": "*" 536 | } 537 | }, 538 | "node_modules/@types/serve-static": { 539 | "version": "1.15.7", 540 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.7.tgz", 541 | "integrity": "sha512-W8Ym+h8nhuRwaKPaDw34QUkwsGi6Rc4yYqvKFo5rm2FUEhCFbzVWrxXUxuKK8TASjWsysJY0nsmNCGhCOIsrOw==", 542 | "dev": true, 543 | "dependencies": { 544 | "@types/http-errors": "*", 545 | "@types/node": "*", 546 | "@types/send": "*" 547 | } 548 | }, 549 | "node_modules/@types/yargs": { 550 | "version": "17.0.33", 551 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.33.tgz", 552 | "integrity": "sha512-WpxBCKWPLr4xSsHgz511rFJAM+wS28w2zEO1QDNY5zM/S8ok70NNfztH0xwhqKyaK0OHCbN98LDAZuy1ctxDkA==", 553 | "dev": true, 554 | "dependencies": { 555 | "@types/yargs-parser": "*" 556 | } 557 | }, 558 | "node_modules/@types/yargs-parser": { 559 | "version": "21.0.3", 560 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz", 561 | "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==", 562 | "dev": true 563 | }, 564 | "node_modules/accepts": { 565 | "version": "1.3.8", 566 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 567 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 568 | "dependencies": { 569 | "mime-types": "~2.1.34", 570 | "negotiator": "0.6.3" 571 | }, 572 | "engines": { 573 | "node": ">= 0.6" 574 | } 575 | }, 576 | "node_modules/acorn": { 577 | "version": "8.14.0", 578 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz", 579 | "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==", 580 | "dev": true, 581 | "bin": { 582 | "acorn": "bin/acorn" 583 | }, 584 | "engines": { 585 | "node": ">=0.4.0" 586 | } 587 | }, 588 | "node_modules/acorn-walk": { 589 | "version": "8.3.4", 590 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.4.tgz", 591 | "integrity": "sha512-ueEepnujpqee2o5aIYnvHU6C0A42MNdsIDeqy5BydrkuC5R1ZuUFnm27EeFJGoEHJQgn3uleRvmTXaJgfXbt4g==", 592 | "dev": true, 593 | "dependencies": { 594 | "acorn": "^8.11.0" 595 | }, 596 | "engines": { 597 | "node": ">=0.4.0" 598 | } 599 | }, 600 | "node_modules/ansi-regex": { 601 | "version": "5.0.1", 602 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 603 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 604 | "engines": { 605 | "node": ">=8" 606 | } 607 | }, 608 | "node_modules/ansi-styles": { 609 | "version": "4.3.0", 610 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 611 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 612 | "dependencies": { 613 | "color-convert": "^2.0.1" 614 | }, 615 | "engines": { 616 | "node": ">=8" 617 | }, 618 | "funding": { 619 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 620 | } 621 | }, 622 | "node_modules/arg": { 623 | "version": "4.1.3", 624 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz", 625 | "integrity": "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==", 626 | "dev": true 627 | }, 628 | "node_modules/array-flatten": { 629 | "version": "1.1.1", 630 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 631 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 632 | }, 633 | "node_modules/body-parser": { 634 | "version": "1.20.3", 635 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", 636 | "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", 637 | "dependencies": { 638 | "bytes": "3.1.2", 639 | "content-type": "~1.0.5", 640 | "debug": "2.6.9", 641 | "depd": "2.0.0", 642 | "destroy": "1.2.0", 643 | "http-errors": "2.0.0", 644 | "iconv-lite": "0.4.24", 645 | "on-finished": "2.4.1", 646 | "qs": "6.13.0", 647 | "raw-body": "2.5.2", 648 | "type-is": "~1.6.18", 649 | "unpipe": "1.0.0" 650 | }, 651 | "engines": { 652 | "node": ">= 0.8", 653 | "npm": "1.2.8000 || >= 1.4.16" 654 | } 655 | }, 656 | "node_modules/body-parser/node_modules/raw-body": { 657 | "version": "2.5.2", 658 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", 659 | "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", 660 | "dependencies": { 661 | "bytes": "3.1.2", 662 | "http-errors": "2.0.0", 663 | "iconv-lite": "0.4.24", 664 | "unpipe": "1.0.0" 665 | }, 666 | "engines": { 667 | "node": ">= 0.8" 668 | } 669 | }, 670 | "node_modules/buffer-from": { 671 | "version": "1.1.2", 672 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 673 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 674 | "dev": true 675 | }, 676 | "node_modules/bytes": { 677 | "version": "3.1.2", 678 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 679 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 680 | "engines": { 681 | "node": ">= 0.8" 682 | } 683 | }, 684 | "node_modules/call-bind-apply-helpers": { 685 | "version": "1.0.1", 686 | "resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.1.tgz", 687 | "integrity": "sha512-BhYE+WDaywFg2TBWYNXAE+8B1ATnThNBqXHP5nQu0jWJdVvY2hvkpyB3qOmtmDePiS5/BDQ8wASEWGMWRG148g==", 688 | "dependencies": { 689 | "es-errors": "^1.3.0", 690 | "function-bind": "^1.1.2" 691 | }, 692 | "engines": { 693 | "node": ">= 0.4" 694 | } 695 | }, 696 | "node_modules/call-bound": { 697 | "version": "1.0.3", 698 | "resolved": "https://registry.npmjs.org/call-bound/-/call-bound-1.0.3.tgz", 699 | "integrity": "sha512-YTd+6wGlNlPxSuri7Y6X8tY2dmm12UMH66RpKMhiX6rsk5wXXnYgbUcOt8kiS31/AjfoTOvCsE+w8nZQLQnzHA==", 700 | "dependencies": { 701 | "call-bind-apply-helpers": "^1.0.1", 702 | "get-intrinsic": "^1.2.6" 703 | }, 704 | "engines": { 705 | "node": ">= 0.4" 706 | }, 707 | "funding": { 708 | "url": "https://github.com/sponsors/ljharb" 709 | } 710 | }, 711 | "node_modules/cliui": { 712 | "version": "8.0.1", 713 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 714 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 715 | "dependencies": { 716 | "string-width": "^4.2.0", 717 | "strip-ansi": "^6.0.1", 718 | "wrap-ansi": "^7.0.0" 719 | }, 720 | "engines": { 721 | "node": ">=12" 722 | } 723 | }, 724 | "node_modules/color-convert": { 725 | "version": "2.0.1", 726 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 727 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 728 | "dependencies": { 729 | "color-name": "~1.1.4" 730 | }, 731 | "engines": { 732 | "node": ">=7.0.0" 733 | } 734 | }, 735 | "node_modules/color-name": { 736 | "version": "1.1.4", 737 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 738 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 739 | }, 740 | "node_modules/content-disposition": { 741 | "version": "0.5.4", 742 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 743 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 744 | "dependencies": { 745 | "safe-buffer": "5.2.1" 746 | }, 747 | "engines": { 748 | "node": ">= 0.6" 749 | } 750 | }, 751 | "node_modules/content-type": { 752 | "version": "1.0.5", 753 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 754 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 755 | "engines": { 756 | "node": ">= 0.6" 757 | } 758 | }, 759 | "node_modules/cookie": { 760 | "version": "0.7.1", 761 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.7.1.tgz", 762 | "integrity": "sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==", 763 | "engines": { 764 | "node": ">= 0.6" 765 | } 766 | }, 767 | "node_modules/cookie-signature": { 768 | "version": "1.0.6", 769 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 770 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 771 | }, 772 | "node_modules/create-require": { 773 | "version": "1.1.1", 774 | "resolved": "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz", 775 | "integrity": "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==", 776 | "dev": true 777 | }, 778 | "node_modules/debug": { 779 | "version": "2.6.9", 780 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 781 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 782 | "dependencies": { 783 | "ms": "2.0.0" 784 | } 785 | }, 786 | "node_modules/depd": { 787 | "version": "2.0.0", 788 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 789 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 790 | "engines": { 791 | "node": ">= 0.8" 792 | } 793 | }, 794 | "node_modules/destroy": { 795 | "version": "1.2.0", 796 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 797 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 798 | "engines": { 799 | "node": ">= 0.8", 800 | "npm": "1.2.8000 || >= 1.4.16" 801 | } 802 | }, 803 | "node_modules/diff": { 804 | "version": "4.0.2", 805 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 806 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 807 | "dev": true, 808 | "engines": { 809 | "node": ">=0.3.1" 810 | } 811 | }, 812 | "node_modules/dunder-proto": { 813 | "version": "1.0.1", 814 | "resolved": "https://registry.npmjs.org/dunder-proto/-/dunder-proto-1.0.1.tgz", 815 | "integrity": "sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==", 816 | "dependencies": { 817 | "call-bind-apply-helpers": "^1.0.1", 818 | "es-errors": "^1.3.0", 819 | "gopd": "^1.2.0" 820 | }, 821 | "engines": { 822 | "node": ">= 0.4" 823 | } 824 | }, 825 | "node_modules/ee-first": { 826 | "version": "1.1.1", 827 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 828 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 829 | }, 830 | "node_modules/emoji-regex": { 831 | "version": "8.0.0", 832 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 833 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 834 | }, 835 | "node_modules/encodeurl": { 836 | "version": "2.0.0", 837 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz", 838 | "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", 839 | "engines": { 840 | "node": ">= 0.8" 841 | } 842 | }, 843 | "node_modules/es-define-property": { 844 | "version": "1.0.1", 845 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.1.tgz", 846 | "integrity": "sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g==", 847 | "engines": { 848 | "node": ">= 0.4" 849 | } 850 | }, 851 | "node_modules/es-errors": { 852 | "version": "1.3.0", 853 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 854 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 855 | "engines": { 856 | "node": ">= 0.4" 857 | } 858 | }, 859 | "node_modules/es-object-atoms": { 860 | "version": "1.0.0", 861 | "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", 862 | "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", 863 | "dependencies": { 864 | "es-errors": "^1.3.0" 865 | }, 866 | "engines": { 867 | "node": ">= 0.4" 868 | } 869 | }, 870 | "node_modules/esbuild": { 871 | "version": "0.18.20", 872 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.18.20.tgz", 873 | "integrity": "sha512-ceqxoedUrcayh7Y7ZX6NdbbDzGROiyVBgC4PriJThBKSVPWnnFHZAkfI1lJT8QFkOwH4qOS2SJkS4wvpGl8BpA==", 874 | "dev": true, 875 | "hasInstallScript": true, 876 | "bin": { 877 | "esbuild": "bin/esbuild" 878 | }, 879 | "engines": { 880 | "node": ">=12" 881 | }, 882 | "optionalDependencies": { 883 | "@esbuild/android-arm": "0.18.20", 884 | "@esbuild/android-arm64": "0.18.20", 885 | "@esbuild/android-x64": "0.18.20", 886 | "@esbuild/darwin-arm64": "0.18.20", 887 | "@esbuild/darwin-x64": "0.18.20", 888 | "@esbuild/freebsd-arm64": "0.18.20", 889 | "@esbuild/freebsd-x64": "0.18.20", 890 | "@esbuild/linux-arm": "0.18.20", 891 | "@esbuild/linux-arm64": "0.18.20", 892 | "@esbuild/linux-ia32": "0.18.20", 893 | "@esbuild/linux-loong64": "0.18.20", 894 | "@esbuild/linux-mips64el": "0.18.20", 895 | "@esbuild/linux-ppc64": "0.18.20", 896 | "@esbuild/linux-riscv64": "0.18.20", 897 | "@esbuild/linux-s390x": "0.18.20", 898 | "@esbuild/linux-x64": "0.18.20", 899 | "@esbuild/netbsd-x64": "0.18.20", 900 | "@esbuild/openbsd-x64": "0.18.20", 901 | "@esbuild/sunos-x64": "0.18.20", 902 | "@esbuild/win32-arm64": "0.18.20", 903 | "@esbuild/win32-ia32": "0.18.20", 904 | "@esbuild/win32-x64": "0.18.20" 905 | } 906 | }, 907 | "node_modules/escalade": { 908 | "version": "3.2.0", 909 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", 910 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", 911 | "engines": { 912 | "node": ">=6" 913 | } 914 | }, 915 | "node_modules/escape-html": { 916 | "version": "1.0.3", 917 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 918 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 919 | }, 920 | "node_modules/etag": { 921 | "version": "1.8.1", 922 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 923 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 924 | "engines": { 925 | "node": ">= 0.6" 926 | } 927 | }, 928 | "node_modules/express": { 929 | "version": "4.21.2", 930 | "resolved": "https://registry.npmjs.org/express/-/express-4.21.2.tgz", 931 | "integrity": "sha512-28HqgMZAmih1Czt9ny7qr6ek2qddF4FclbMzwhCREB6OFfH+rXAnuNCwo1/wFvrtbgsQDb4kSbX9de9lFbrXnA==", 932 | "dependencies": { 933 | "accepts": "~1.3.8", 934 | "array-flatten": "1.1.1", 935 | "body-parser": "1.20.3", 936 | "content-disposition": "0.5.4", 937 | "content-type": "~1.0.4", 938 | "cookie": "0.7.1", 939 | "cookie-signature": "1.0.6", 940 | "debug": "2.6.9", 941 | "depd": "2.0.0", 942 | "encodeurl": "~2.0.0", 943 | "escape-html": "~1.0.3", 944 | "etag": "~1.8.1", 945 | "finalhandler": "1.3.1", 946 | "fresh": "0.5.2", 947 | "http-errors": "2.0.0", 948 | "merge-descriptors": "1.0.3", 949 | "methods": "~1.1.2", 950 | "on-finished": "2.4.1", 951 | "parseurl": "~1.3.3", 952 | "path-to-regexp": "0.1.12", 953 | "proxy-addr": "~2.0.7", 954 | "qs": "6.13.0", 955 | "range-parser": "~1.2.1", 956 | "safe-buffer": "5.2.1", 957 | "send": "0.19.0", 958 | "serve-static": "1.16.2", 959 | "setprototypeof": "1.2.0", 960 | "statuses": "2.0.1", 961 | "type-is": "~1.6.18", 962 | "utils-merge": "1.0.1", 963 | "vary": "~1.1.2" 964 | }, 965 | "engines": { 966 | "node": ">= 0.10.0" 967 | }, 968 | "funding": { 969 | "type": "opencollective", 970 | "url": "https://opencollective.com/express" 971 | } 972 | }, 973 | "node_modules/finalhandler": { 974 | "version": "1.3.1", 975 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.3.1.tgz", 976 | "integrity": "sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==", 977 | "dependencies": { 978 | "debug": "2.6.9", 979 | "encodeurl": "~2.0.0", 980 | "escape-html": "~1.0.3", 981 | "on-finished": "2.4.1", 982 | "parseurl": "~1.3.3", 983 | "statuses": "2.0.1", 984 | "unpipe": "~1.0.0" 985 | }, 986 | "engines": { 987 | "node": ">= 0.8" 988 | } 989 | }, 990 | "node_modules/forwarded": { 991 | "version": "0.2.0", 992 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 993 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 994 | "engines": { 995 | "node": ">= 0.6" 996 | } 997 | }, 998 | "node_modules/fresh": { 999 | "version": "0.5.2", 1000 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1001 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 1002 | "engines": { 1003 | "node": ">= 0.6" 1004 | } 1005 | }, 1006 | "node_modules/fsevents": { 1007 | "version": "2.3.3", 1008 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 1009 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 1010 | "dev": true, 1011 | "hasInstallScript": true, 1012 | "optional": true, 1013 | "os": [ 1014 | "darwin" 1015 | ], 1016 | "engines": { 1017 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1018 | } 1019 | }, 1020 | "node_modules/function-bind": { 1021 | "version": "1.1.2", 1022 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 1023 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 1024 | "funding": { 1025 | "url": "https://github.com/sponsors/ljharb" 1026 | } 1027 | }, 1028 | "node_modules/get-caller-file": { 1029 | "version": "2.0.5", 1030 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1031 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1032 | "engines": { 1033 | "node": "6.* || 8.* || >= 10.*" 1034 | } 1035 | }, 1036 | "node_modules/get-intrinsic": { 1037 | "version": "1.2.6", 1038 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.6.tgz", 1039 | "integrity": "sha512-qxsEs+9A+u85HhllWJJFicJfPDhRmjzoYdl64aMWW9yRIJmSyxdn8IEkuIM530/7T+lv0TIHd8L6Q/ra0tEoeA==", 1040 | "dependencies": { 1041 | "call-bind-apply-helpers": "^1.0.1", 1042 | "dunder-proto": "^1.0.0", 1043 | "es-define-property": "^1.0.1", 1044 | "es-errors": "^1.3.0", 1045 | "es-object-atoms": "^1.0.0", 1046 | "function-bind": "^1.1.2", 1047 | "gopd": "^1.2.0", 1048 | "has-symbols": "^1.1.0", 1049 | "hasown": "^2.0.2", 1050 | "math-intrinsics": "^1.0.0" 1051 | }, 1052 | "engines": { 1053 | "node": ">= 0.4" 1054 | }, 1055 | "funding": { 1056 | "url": "https://github.com/sponsors/ljharb" 1057 | } 1058 | }, 1059 | "node_modules/get-tsconfig": { 1060 | "version": "4.8.1", 1061 | "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.8.1.tgz", 1062 | "integrity": "sha512-k9PN+cFBmaLWtVz29SkUoqU5O0slLuHJXt/2P+tMVFT+phsSGXGkp9t3rQIqdz0e+06EHNGs3oM6ZX1s2zHxRg==", 1063 | "dev": true, 1064 | "dependencies": { 1065 | "resolve-pkg-maps": "^1.0.0" 1066 | }, 1067 | "funding": { 1068 | "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1" 1069 | } 1070 | }, 1071 | "node_modules/gopd": { 1072 | "version": "1.2.0", 1073 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.2.0.tgz", 1074 | "integrity": "sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==", 1075 | "engines": { 1076 | "node": ">= 0.4" 1077 | }, 1078 | "funding": { 1079 | "url": "https://github.com/sponsors/ljharb" 1080 | } 1081 | }, 1082 | "node_modules/has-symbols": { 1083 | "version": "1.1.0", 1084 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.1.0.tgz", 1085 | "integrity": "sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ==", 1086 | "engines": { 1087 | "node": ">= 0.4" 1088 | }, 1089 | "funding": { 1090 | "url": "https://github.com/sponsors/ljharb" 1091 | } 1092 | }, 1093 | "node_modules/hasown": { 1094 | "version": "2.0.2", 1095 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 1096 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 1097 | "dependencies": { 1098 | "function-bind": "^1.1.2" 1099 | }, 1100 | "engines": { 1101 | "node": ">= 0.4" 1102 | } 1103 | }, 1104 | "node_modules/http-errors": { 1105 | "version": "2.0.0", 1106 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 1107 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 1108 | "dependencies": { 1109 | "depd": "2.0.0", 1110 | "inherits": "2.0.4", 1111 | "setprototypeof": "1.2.0", 1112 | "statuses": "2.0.1", 1113 | "toidentifier": "1.0.1" 1114 | }, 1115 | "engines": { 1116 | "node": ">= 0.8" 1117 | } 1118 | }, 1119 | "node_modules/iconv-lite": { 1120 | "version": "0.4.24", 1121 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1122 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1123 | "dependencies": { 1124 | "safer-buffer": ">= 2.1.2 < 3" 1125 | }, 1126 | "engines": { 1127 | "node": ">=0.10.0" 1128 | } 1129 | }, 1130 | "node_modules/inherits": { 1131 | "version": "2.0.4", 1132 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1133 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1134 | }, 1135 | "node_modules/ipaddr.js": { 1136 | "version": "1.9.1", 1137 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1138 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 1139 | "engines": { 1140 | "node": ">= 0.10" 1141 | } 1142 | }, 1143 | "node_modules/is-fullwidth-code-point": { 1144 | "version": "3.0.0", 1145 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1146 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1147 | "engines": { 1148 | "node": ">=8" 1149 | } 1150 | }, 1151 | "node_modules/make-error": { 1152 | "version": "1.3.6", 1153 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 1154 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 1155 | "dev": true 1156 | }, 1157 | "node_modules/math-intrinsics": { 1158 | "version": "1.1.0", 1159 | "resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz", 1160 | "integrity": "sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==", 1161 | "engines": { 1162 | "node": ">= 0.4" 1163 | } 1164 | }, 1165 | "node_modules/media-typer": { 1166 | "version": "0.3.0", 1167 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1168 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1169 | "engines": { 1170 | "node": ">= 0.6" 1171 | } 1172 | }, 1173 | "node_modules/merge-descriptors": { 1174 | "version": "1.0.3", 1175 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.3.tgz", 1176 | "integrity": "sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==", 1177 | "funding": { 1178 | "url": "https://github.com/sponsors/sindresorhus" 1179 | } 1180 | }, 1181 | "node_modules/methods": { 1182 | "version": "1.1.2", 1183 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1184 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 1185 | "engines": { 1186 | "node": ">= 0.6" 1187 | } 1188 | }, 1189 | "node_modules/mime": { 1190 | "version": "1.6.0", 1191 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1192 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1193 | "bin": { 1194 | "mime": "cli.js" 1195 | }, 1196 | "engines": { 1197 | "node": ">=4" 1198 | } 1199 | }, 1200 | "node_modules/mime-db": { 1201 | "version": "1.52.0", 1202 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1203 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1204 | "engines": { 1205 | "node": ">= 0.6" 1206 | } 1207 | }, 1208 | "node_modules/mime-types": { 1209 | "version": "2.1.35", 1210 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1211 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1212 | "dependencies": { 1213 | "mime-db": "1.52.0" 1214 | }, 1215 | "engines": { 1216 | "node": ">= 0.6" 1217 | } 1218 | }, 1219 | "node_modules/ms": { 1220 | "version": "2.0.0", 1221 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1222 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1223 | }, 1224 | "node_modules/negotiator": { 1225 | "version": "0.6.3", 1226 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1227 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1228 | "engines": { 1229 | "node": ">= 0.6" 1230 | } 1231 | }, 1232 | "node_modules/object-inspect": { 1233 | "version": "1.13.3", 1234 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.3.tgz", 1235 | "integrity": "sha512-kDCGIbxkDSXE3euJZZXzc6to7fCrKHNI/hSRQnRuQ+BWjFNzZwiFF8fj/6o2t2G9/jTj8PSIYTfCLelLZEeRpA==", 1236 | "engines": { 1237 | "node": ">= 0.4" 1238 | }, 1239 | "funding": { 1240 | "url": "https://github.com/sponsors/ljharb" 1241 | } 1242 | }, 1243 | "node_modules/on-finished": { 1244 | "version": "2.4.1", 1245 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1246 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1247 | "dependencies": { 1248 | "ee-first": "1.1.1" 1249 | }, 1250 | "engines": { 1251 | "node": ">= 0.8" 1252 | } 1253 | }, 1254 | "node_modules/parseurl": { 1255 | "version": "1.3.3", 1256 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1257 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1258 | "engines": { 1259 | "node": ">= 0.8" 1260 | } 1261 | }, 1262 | "node_modules/path-to-regexp": { 1263 | "version": "0.1.12", 1264 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.12.tgz", 1265 | "integrity": "sha512-RA1GjUVMnvYFxuqovrEqZoxxW5NUZqbwKtYz/Tt7nXerk0LbLblQmrsgdeOxV5SFHf0UDggjS/bSeOZwt1pmEQ==" 1266 | }, 1267 | "node_modules/proxy-addr": { 1268 | "version": "2.0.7", 1269 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1270 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1271 | "dependencies": { 1272 | "forwarded": "0.2.0", 1273 | "ipaddr.js": "1.9.1" 1274 | }, 1275 | "engines": { 1276 | "node": ">= 0.10" 1277 | } 1278 | }, 1279 | "node_modules/qs": { 1280 | "version": "6.13.0", 1281 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.13.0.tgz", 1282 | "integrity": "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==", 1283 | "dependencies": { 1284 | "side-channel": "^1.0.6" 1285 | }, 1286 | "engines": { 1287 | "node": ">=0.6" 1288 | }, 1289 | "funding": { 1290 | "url": "https://github.com/sponsors/ljharb" 1291 | } 1292 | }, 1293 | "node_modules/range-parser": { 1294 | "version": "1.2.1", 1295 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1296 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1297 | "engines": { 1298 | "node": ">= 0.6" 1299 | } 1300 | }, 1301 | "node_modules/raw-body": { 1302 | "version": "3.0.0", 1303 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-3.0.0.tgz", 1304 | "integrity": "sha512-RmkhL8CAyCRPXCE28MMH0z2PNWQBNk2Q09ZdxM9IOOXwxwZbN+qbWaatPkdkWIKL2ZVDImrN/pK5HTRz2PcS4g==", 1305 | "dependencies": { 1306 | "bytes": "3.1.2", 1307 | "http-errors": "2.0.0", 1308 | "iconv-lite": "0.6.3", 1309 | "unpipe": "1.0.0" 1310 | }, 1311 | "engines": { 1312 | "node": ">= 0.8" 1313 | } 1314 | }, 1315 | "node_modules/raw-body/node_modules/iconv-lite": { 1316 | "version": "0.6.3", 1317 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", 1318 | "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", 1319 | "dependencies": { 1320 | "safer-buffer": ">= 2.1.2 < 3.0.0" 1321 | }, 1322 | "engines": { 1323 | "node": ">=0.10.0" 1324 | } 1325 | }, 1326 | "node_modules/require-directory": { 1327 | "version": "2.1.1", 1328 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1329 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1330 | "engines": { 1331 | "node": ">=0.10.0" 1332 | } 1333 | }, 1334 | "node_modules/resolve-pkg-maps": { 1335 | "version": "1.0.0", 1336 | "resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz", 1337 | "integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==", 1338 | "dev": true, 1339 | "funding": { 1340 | "url": "https://github.com/privatenumber/resolve-pkg-maps?sponsor=1" 1341 | } 1342 | }, 1343 | "node_modules/safe-buffer": { 1344 | "version": "5.2.1", 1345 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1346 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1347 | "funding": [ 1348 | { 1349 | "type": "github", 1350 | "url": "https://github.com/sponsors/feross" 1351 | }, 1352 | { 1353 | "type": "patreon", 1354 | "url": "https://www.patreon.com/feross" 1355 | }, 1356 | { 1357 | "type": "consulting", 1358 | "url": "https://feross.org/support" 1359 | } 1360 | ] 1361 | }, 1362 | "node_modules/safer-buffer": { 1363 | "version": "2.1.2", 1364 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1365 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1366 | }, 1367 | "node_modules/send": { 1368 | "version": "0.19.0", 1369 | "resolved": "https://registry.npmjs.org/send/-/send-0.19.0.tgz", 1370 | "integrity": "sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==", 1371 | "dependencies": { 1372 | "debug": "2.6.9", 1373 | "depd": "2.0.0", 1374 | "destroy": "1.2.0", 1375 | "encodeurl": "~1.0.2", 1376 | "escape-html": "~1.0.3", 1377 | "etag": "~1.8.1", 1378 | "fresh": "0.5.2", 1379 | "http-errors": "2.0.0", 1380 | "mime": "1.6.0", 1381 | "ms": "2.1.3", 1382 | "on-finished": "2.4.1", 1383 | "range-parser": "~1.2.1", 1384 | "statuses": "2.0.1" 1385 | }, 1386 | "engines": { 1387 | "node": ">= 0.8.0" 1388 | } 1389 | }, 1390 | "node_modules/send/node_modules/encodeurl": { 1391 | "version": "1.0.2", 1392 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 1393 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 1394 | "engines": { 1395 | "node": ">= 0.8" 1396 | } 1397 | }, 1398 | "node_modules/send/node_modules/ms": { 1399 | "version": "2.1.3", 1400 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1401 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1402 | }, 1403 | "node_modules/serve-static": { 1404 | "version": "1.16.2", 1405 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.16.2.tgz", 1406 | "integrity": "sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw==", 1407 | "dependencies": { 1408 | "encodeurl": "~2.0.0", 1409 | "escape-html": "~1.0.3", 1410 | "parseurl": "~1.3.3", 1411 | "send": "0.19.0" 1412 | }, 1413 | "engines": { 1414 | "node": ">= 0.8.0" 1415 | } 1416 | }, 1417 | "node_modules/setprototypeof": { 1418 | "version": "1.2.0", 1419 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1420 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1421 | }, 1422 | "node_modules/side-channel": { 1423 | "version": "1.1.0", 1424 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.1.0.tgz", 1425 | "integrity": "sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw==", 1426 | "dependencies": { 1427 | "es-errors": "^1.3.0", 1428 | "object-inspect": "^1.13.3", 1429 | "side-channel-list": "^1.0.0", 1430 | "side-channel-map": "^1.0.1", 1431 | "side-channel-weakmap": "^1.0.2" 1432 | }, 1433 | "engines": { 1434 | "node": ">= 0.4" 1435 | }, 1436 | "funding": { 1437 | "url": "https://github.com/sponsors/ljharb" 1438 | } 1439 | }, 1440 | "node_modules/side-channel-list": { 1441 | "version": "1.0.0", 1442 | "resolved": "https://registry.npmjs.org/side-channel-list/-/side-channel-list-1.0.0.tgz", 1443 | "integrity": "sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA==", 1444 | "dependencies": { 1445 | "es-errors": "^1.3.0", 1446 | "object-inspect": "^1.13.3" 1447 | }, 1448 | "engines": { 1449 | "node": ">= 0.4" 1450 | }, 1451 | "funding": { 1452 | "url": "https://github.com/sponsors/ljharb" 1453 | } 1454 | }, 1455 | "node_modules/side-channel-map": { 1456 | "version": "1.0.1", 1457 | "resolved": "https://registry.npmjs.org/side-channel-map/-/side-channel-map-1.0.1.tgz", 1458 | "integrity": "sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA==", 1459 | "dependencies": { 1460 | "call-bound": "^1.0.2", 1461 | "es-errors": "^1.3.0", 1462 | "get-intrinsic": "^1.2.5", 1463 | "object-inspect": "^1.13.3" 1464 | }, 1465 | "engines": { 1466 | "node": ">= 0.4" 1467 | }, 1468 | "funding": { 1469 | "url": "https://github.com/sponsors/ljharb" 1470 | } 1471 | }, 1472 | "node_modules/side-channel-weakmap": { 1473 | "version": "1.0.2", 1474 | "resolved": "https://registry.npmjs.org/side-channel-weakmap/-/side-channel-weakmap-1.0.2.tgz", 1475 | "integrity": "sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A==", 1476 | "dependencies": { 1477 | "call-bound": "^1.0.2", 1478 | "es-errors": "^1.3.0", 1479 | "get-intrinsic": "^1.2.5", 1480 | "object-inspect": "^1.13.3", 1481 | "side-channel-map": "^1.0.1" 1482 | }, 1483 | "engines": { 1484 | "node": ">= 0.4" 1485 | }, 1486 | "funding": { 1487 | "url": "https://github.com/sponsors/ljharb" 1488 | } 1489 | }, 1490 | "node_modules/source-map": { 1491 | "version": "0.6.1", 1492 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1493 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 1494 | "dev": true, 1495 | "engines": { 1496 | "node": ">=0.10.0" 1497 | } 1498 | }, 1499 | "node_modules/source-map-support": { 1500 | "version": "0.5.21", 1501 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 1502 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 1503 | "dev": true, 1504 | "dependencies": { 1505 | "buffer-from": "^1.0.0", 1506 | "source-map": "^0.6.0" 1507 | } 1508 | }, 1509 | "node_modules/statuses": { 1510 | "version": "2.0.1", 1511 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1512 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1513 | "engines": { 1514 | "node": ">= 0.8" 1515 | } 1516 | }, 1517 | "node_modules/string-width": { 1518 | "version": "4.2.3", 1519 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1520 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1521 | "dependencies": { 1522 | "emoji-regex": "^8.0.0", 1523 | "is-fullwidth-code-point": "^3.0.0", 1524 | "strip-ansi": "^6.0.1" 1525 | }, 1526 | "engines": { 1527 | "node": ">=8" 1528 | } 1529 | }, 1530 | "node_modules/strip-ansi": { 1531 | "version": "6.0.1", 1532 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1533 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1534 | "dependencies": { 1535 | "ansi-regex": "^5.0.1" 1536 | }, 1537 | "engines": { 1538 | "node": ">=8" 1539 | } 1540 | }, 1541 | "node_modules/toidentifier": { 1542 | "version": "1.0.1", 1543 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1544 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1545 | "engines": { 1546 | "node": ">=0.6" 1547 | } 1548 | }, 1549 | "node_modules/ts-node": { 1550 | "version": "10.9.2", 1551 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-10.9.2.tgz", 1552 | "integrity": "sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ==", 1553 | "dev": true, 1554 | "dependencies": { 1555 | "@cspotcode/source-map-support": "^0.8.0", 1556 | "@tsconfig/node10": "^1.0.7", 1557 | "@tsconfig/node12": "^1.0.7", 1558 | "@tsconfig/node14": "^1.0.0", 1559 | "@tsconfig/node16": "^1.0.2", 1560 | "acorn": "^8.4.1", 1561 | "acorn-walk": "^8.1.1", 1562 | "arg": "^4.1.0", 1563 | "create-require": "^1.1.0", 1564 | "diff": "^4.0.1", 1565 | "make-error": "^1.1.1", 1566 | "v8-compile-cache-lib": "^3.0.1", 1567 | "yn": "3.1.1" 1568 | }, 1569 | "bin": { 1570 | "ts-node": "dist/bin.js", 1571 | "ts-node-cwd": "dist/bin-cwd.js", 1572 | "ts-node-esm": "dist/bin-esm.js", 1573 | "ts-node-script": "dist/bin-script.js", 1574 | "ts-node-transpile-only": "dist/bin-transpile.js", 1575 | "ts-script": "dist/bin-script-deprecated.js" 1576 | }, 1577 | "peerDependencies": { 1578 | "@swc/core": ">=1.2.50", 1579 | "@swc/wasm": ">=1.2.50", 1580 | "@types/node": "*", 1581 | "typescript": ">=2.7" 1582 | }, 1583 | "peerDependenciesMeta": { 1584 | "@swc/core": { 1585 | "optional": true 1586 | }, 1587 | "@swc/wasm": { 1588 | "optional": true 1589 | } 1590 | } 1591 | }, 1592 | "node_modules/tsx": { 1593 | "version": "3.14.0", 1594 | "resolved": "https://registry.npmjs.org/tsx/-/tsx-3.14.0.tgz", 1595 | "integrity": "sha512-xHtFaKtHxM9LOklMmJdI3BEnQq/D5F73Of2E1GDrITi9sgoVkvIsrQUTY1G8FlmGtA+awCI4EBlTRRYxkL2sRg==", 1596 | "dev": true, 1597 | "dependencies": { 1598 | "esbuild": "~0.18.20", 1599 | "get-tsconfig": "^4.7.2", 1600 | "source-map-support": "^0.5.21" 1601 | }, 1602 | "bin": { 1603 | "tsx": "dist/cli.mjs" 1604 | }, 1605 | "optionalDependencies": { 1606 | "fsevents": "~2.3.3" 1607 | } 1608 | }, 1609 | "node_modules/type-is": { 1610 | "version": "1.6.18", 1611 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1612 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1613 | "dependencies": { 1614 | "media-typer": "0.3.0", 1615 | "mime-types": "~2.1.24" 1616 | }, 1617 | "engines": { 1618 | "node": ">= 0.6" 1619 | } 1620 | }, 1621 | "node_modules/typescript": { 1622 | "version": "5.7.2", 1623 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.2.tgz", 1624 | "integrity": "sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg==", 1625 | "dev": true, 1626 | "bin": { 1627 | "tsc": "bin/tsc", 1628 | "tsserver": "bin/tsserver" 1629 | }, 1630 | "engines": { 1631 | "node": ">=14.17" 1632 | } 1633 | }, 1634 | "node_modules/undici-types": { 1635 | "version": "6.19.8", 1636 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", 1637 | "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", 1638 | "dev": true 1639 | }, 1640 | "node_modules/unpipe": { 1641 | "version": "1.0.0", 1642 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1643 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1644 | "engines": { 1645 | "node": ">= 0.8" 1646 | } 1647 | }, 1648 | "node_modules/utils-merge": { 1649 | "version": "1.0.1", 1650 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1651 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1652 | "engines": { 1653 | "node": ">= 0.4.0" 1654 | } 1655 | }, 1656 | "node_modules/v8-compile-cache-lib": { 1657 | "version": "3.0.1", 1658 | "resolved": "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz", 1659 | "integrity": "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==", 1660 | "dev": true 1661 | }, 1662 | "node_modules/vary": { 1663 | "version": "1.1.2", 1664 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1665 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1666 | "engines": { 1667 | "node": ">= 0.8" 1668 | } 1669 | }, 1670 | "node_modules/wrap-ansi": { 1671 | "version": "7.0.0", 1672 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1673 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1674 | "dependencies": { 1675 | "ansi-styles": "^4.0.0", 1676 | "string-width": "^4.1.0", 1677 | "strip-ansi": "^6.0.0" 1678 | }, 1679 | "engines": { 1680 | "node": ">=10" 1681 | }, 1682 | "funding": { 1683 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1684 | } 1685 | }, 1686 | "node_modules/y18n": { 1687 | "version": "5.0.8", 1688 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1689 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1690 | "engines": { 1691 | "node": ">=10" 1692 | } 1693 | }, 1694 | "node_modules/yargs": { 1695 | "version": "17.7.2", 1696 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 1697 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 1698 | "dependencies": { 1699 | "cliui": "^8.0.1", 1700 | "escalade": "^3.1.1", 1701 | "get-caller-file": "^2.0.5", 1702 | "require-directory": "^2.1.1", 1703 | "string-width": "^4.2.3", 1704 | "y18n": "^5.0.5", 1705 | "yargs-parser": "^21.1.1" 1706 | }, 1707 | "engines": { 1708 | "node": ">=12" 1709 | } 1710 | }, 1711 | "node_modules/yargs-parser": { 1712 | "version": "21.1.1", 1713 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 1714 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 1715 | "engines": { 1716 | "node": ">=12" 1717 | } 1718 | }, 1719 | "node_modules/yn": { 1720 | "version": "3.1.1", 1721 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 1722 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", 1723 | "dev": true, 1724 | "engines": { 1725 | "node": ">=6" 1726 | } 1727 | }, 1728 | "node_modules/zod": { 1729 | "version": "3.24.1", 1730 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.24.1.tgz", 1731 | "integrity": "sha512-muH7gBL9sI1nciMZV67X5fTKKBLtwpZ5VBp1vsOQzj1MhrBZ4wlVCm3gedKZWLp0Oyel8sIGfeiz54Su+OVT+A==", 1732 | "funding": { 1733 | "url": "https://github.com/sponsors/colinhacks" 1734 | } 1735 | } 1736 | } 1737 | } 1738 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "superargs", 3 | "version": "1.0.3", 4 | "description": "Update MCP server args during MCP server runtime.", 5 | "repository": { 6 | "type": "git", 7 | "url": "git+https://github.com/supercorp-ai/superargs.git" 8 | }, 9 | "keywords": [ 10 | "mcp", 11 | "server", 12 | "stdio", 13 | "sse", 14 | "env", 15 | "arguments", 16 | "arg", 17 | "args", 18 | "runtime" 19 | ], 20 | "type": "module", 21 | "bin": { 22 | "superargs": "dist/index.js" 23 | }, 24 | "scripts": { 25 | "build": "tsc", 26 | "start": "node dist/index.js" 27 | }, 28 | "dependencies": { 29 | "@modelcontextprotocol/sdk": "latest", 30 | "body-parser": "^1.20.2", 31 | "express": "^4.18.2", 32 | "yargs": "^17.7.2" 33 | }, 34 | "devDependencies": { 35 | "@types/body-parser": "^1.19.2", 36 | "@types/express": "^4.17.16", 37 | "@types/node": "^20.5.9", 38 | "@types/yargs": "^17.0.33", 39 | "ts-node": "^10.9.1", 40 | "tsx": "^3.12.7", 41 | "typescript": "^5.2.2" 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | import yargs from 'yargs' 4 | import { hideBin } from 'yargs/helpers' 5 | import { spawn, ChildProcessWithoutNullStreams } from 'child_process' 6 | import { 7 | ListToolsRequestSchema, 8 | ListToolsRequest, 9 | ListToolsResult, 10 | CallToolRequestSchema, 11 | CallToolRequest, 12 | CallToolResult, 13 | ListPromptsRequestSchema, 14 | ListPromptsRequest, 15 | GetPromptRequestSchema, 16 | GetPromptRequest, 17 | ListResourcesRequestSchema, 18 | ListResourcesRequest, 19 | ReadResourceRequestSchema, 20 | ReadResourceRequest, 21 | ListResourceTemplatesRequestSchema, 22 | ListResourceTemplatesRequest, 23 | CreateMessageRequestSchema, 24 | CreateMessageRequest, 25 | ListRootsRequestSchema, 26 | ListRootsRequest, 27 | PingRequestSchema, 28 | PingRequest, 29 | CompleteRequestSchema, 30 | CompleteRequest, 31 | SetLevelRequestSchema, 32 | SetLevelRequest, 33 | SubscribeRequestSchema, 34 | SubscribeRequest, 35 | UnsubscribeRequestSchema, 36 | UnsubscribeRequest, 37 | Tool, 38 | } from '@modelcontextprotocol/sdk/types.js' 39 | import { Server } from '@modelcontextprotocol/sdk/server/index.js' 40 | import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js' 41 | 42 | type Method = ListToolsRequest['method'] | 43 | CallToolRequest['method'] | 44 | ListPromptsRequest['method'] | 45 | GetPromptRequest['method'] | 46 | ListResourcesRequest['method'] | 47 | ReadResourceRequest['method'] | 48 | CreateMessageRequest['method'] | 49 | ListRootsRequest['method'] | 50 | ListResourceTemplatesRequest['method'] | 51 | PingRequest['method'] | 52 | CompleteRequest['method'] | 53 | SetLevelRequest['method'] | 54 | SubscribeRequest['method'] | 55 | UnsubscribeRequest['method'] 56 | 57 | type ForwardedRequest = { 58 | method: Method 59 | schema: any 60 | fallbackRequesHandler?: (request: any) => any 61 | } 62 | 63 | const ARGS_REGEX = /{{(.*?)}}/g 64 | 65 | const findArgs = (command: string): string[] => { 66 | const matches = new Set() 67 | let match 68 | while ((match = ARGS_REGEX.exec(command)) !== null) { 69 | matches.add(match[1].trim()) 70 | } 71 | return Array.from(matches) 72 | } 73 | 74 | const replaceArgs = (command: string, values: Record): string => { 75 | return command.replace(ARGS_REGEX, (_, name: string) => { 76 | const key = name.trim() 77 | return key in values ? values[key] : `{{${key}}}` 78 | }) 79 | } 80 | 81 | async function main() { 82 | const argv = yargs(hideBin(process.argv)) 83 | .option('stdio', { 84 | type: 'string', 85 | demandOption: true, 86 | description: 'Shell command that runs an MCP server over stdio, e.g. "ENV=foo npx -y server-github {{myToken}}"' 87 | }) 88 | .option('update-args-tool-name', { 89 | type: 'string', 90 | default: 'update_args', 91 | description: 'Name of the tool used to update args and restart stdio (default: "update_args")' 92 | }) 93 | .help() 94 | .parseSync() 95 | 96 | console.error('[superargs] Starting...') 97 | console.error('[superargs] Superargs is supported by Superinterface - https://superinterface.ai') 98 | console.error(`[superargs] - stdio: ${argv.stdio}`) 99 | console.error(`[superargs] - updateArgsToolName: ${argv.updateArgsToolName}`) 100 | 101 | const originalCommand = argv.stdio.trim() 102 | const updateArgsToolName = argv.updateArgsToolName.trim() 103 | 104 | const args = findArgs(originalCommand) 105 | console.error(`[superargs] Found args: ${JSON.stringify(args)}`) 106 | 107 | const parentServer = new Server( 108 | { 109 | name: 'superargs', 110 | version: '1.0.0', 111 | }, 112 | { 113 | capabilities: { 114 | tools: {}, 115 | resources: {}, 116 | prompts: {}, 117 | sampling: {}, 118 | roots: {}, 119 | logging: {}, 120 | }, 121 | } 122 | ) 123 | 124 | let child: ChildProcessWithoutNullStreams | null = null 125 | let requestIdCounter = 0 126 | const pendingRequests = new Mapvoid, reject: (err:Error)=>void}>() 127 | 128 | let currentValues: Record = {} 129 | let argsUpdated = false 130 | 131 | const spawnChild = () => { 132 | killChild() 133 | 134 | const finalCmd = replaceArgs(originalCommand, currentValues) 135 | console.error(`[superargs] Spawning child process:\n ${finalCmd}`) 136 | 137 | child = spawn(finalCmd, { shell: true }) 138 | 139 | const req = { 140 | jsonrpc: '2.0', 141 | method: 'notifications/initialized', 142 | } 143 | 144 | child.stdin.write(JSON.stringify(req) + '\n') 145 | 146 | child.on('exit', (code, signal) => { 147 | console.error(`[superargs] Child process exited with code=${code}, signal=${signal}`) 148 | child = null 149 | 150 | for (const { reject } of pendingRequests.values()) { 151 | reject(new Error('Child process exited')) 152 | } 153 | pendingRequests.clear() 154 | }) 155 | 156 | let buffer = '' 157 | child.stdout.on('data', (chunk: Buffer) => { 158 | buffer += chunk.toString('utf8') 159 | const lines = buffer.split(/\r?\n/) 160 | buffer = lines.pop() ?? '' 161 | for (const line of lines) { 162 | if (!line.trim()) continue 163 | let msg 164 | try { 165 | msg = JSON.parse(line) 166 | } catch (err) { 167 | console.error('[superargs] Child produced non-JSON line:', line) 168 | continue 169 | } 170 | handleChildMessage(msg) 171 | } 172 | }) 173 | 174 | child.stderr.on('data', (chunk: Buffer) => { 175 | console.error('[superargs] [child stderr]', chunk.toString('utf8')) 176 | }) 177 | } 178 | 179 | const killChild = () => { 180 | if (!child) return 181 | 182 | console.error('[superargs] Killing existing child...') 183 | child.kill('SIGTERM') 184 | child = null 185 | 186 | for (const { reject } of pendingRequests.values()) { 187 | reject(new Error('Child killed')) 188 | } 189 | pendingRequests.clear() 190 | } 191 | 192 | const handleChildMessage = (msg: any) => { 193 | if (!msg || msg.jsonrpc !== '2.0') { 194 | console.error('[superargs] Invalid JSON-RPC from child:', msg) 195 | return 196 | } 197 | const id = msg.id 198 | if (!id || !pendingRequests.has(id)) { 199 | console.error('[superargs] Child responded with unknown id=', id) 200 | return 201 | } 202 | const { resolve, reject } = pendingRequests.get(id)! 203 | pendingRequests.delete(id) 204 | 205 | if ('error' in msg) { 206 | reject(msg.error) 207 | } else { 208 | resolve(msg.result) 209 | } 210 | } 211 | 212 | const ensureChildRunning = () => { 213 | if (!child) { 214 | spawnChild() 215 | } 216 | } 217 | 218 | const callChild = (method: Method, params: any): Promise => { 219 | if (!child) { 220 | throw new Error('Child is not running.') 221 | } 222 | const id = ++requestIdCounter 223 | const req = { 224 | jsonrpc: '2.0', 225 | id, 226 | method, 227 | params, 228 | } 229 | return new Promise((resolve, reject) => { 230 | pendingRequests.set(id, { resolve, reject }) 231 | child!.stdin.write(JSON.stringify(req) + '\n') 232 | }) 233 | } 234 | 235 | const broadcastChildUpdates = async () => { 236 | argsUpdated = true 237 | parentServer.sendToolListChanged() 238 | parentServer.sendResourceListChanged() 239 | parentServer.sendPromptListChanged() 240 | } 241 | 242 | const updateArgsTool: Tool = { 243 | name: updateArgsToolName, 244 | description: 'Updates args (tokens, etc.).', 245 | inputSchema: { 246 | type: 'object', 247 | properties: args.reduce((acc, v) => { 248 | acc[v] = { 249 | type: 'string', 250 | description: `Value for arg "{{${v}}}"`, 251 | } 252 | return acc 253 | }, {} as Record), 254 | required: [], 255 | } 256 | } 257 | 258 | parentServer.setRequestHandler(ListToolsRequestSchema, async () => { 259 | try { 260 | ensureChildRunning() 261 | const resp = await callChild('tools/list', {}) 262 | const childTools = resp.tools ?? [] 263 | return { 264 | tools: [...childTools, updateArgsTool], 265 | } as ListToolsResult 266 | } catch (err) { 267 | console.error('[superargs] Could not list child tools, fallback to [updateArgsTool]:', err) 268 | return { 269 | tools: [updateArgsTool], 270 | } as ListToolsResult 271 | } 272 | }) 273 | 274 | parentServer.setRequestHandler(CallToolRequestSchema, async (request) => { 275 | const { name, arguments: args } = request.params 276 | 277 | if (name === updateArgsToolName) { 278 | if (args && typeof args === 'object') { 279 | for (const [k, v] of Object.entries(args)) { 280 | if (typeof v === 'string') { 281 | currentValues[k] = v 282 | } 283 | } 284 | } 285 | spawnChild() 286 | await broadcastChildUpdates() 287 | 288 | return { 289 | content: [ 290 | { 291 | type: 'text', 292 | text: 'Updated successfully.', 293 | }, 294 | ], 295 | isError: false, 296 | } as CallToolResult 297 | } 298 | 299 | ensureChildRunning() 300 | return callChild('tools/call', { 301 | name, 302 | arguments: args, 303 | }) 304 | }) 305 | 306 | const forwardedRequests: ForwardedRequest[] = [ 307 | { 308 | method: 'ping', 309 | schema: PingRequestSchema, 310 | fallbackRequesHandler: () => ({}), 311 | }, 312 | { 313 | method: 'completion/complete', 314 | schema: CompleteRequestSchema, 315 | }, 316 | { 317 | method: 'logging/setLevel', 318 | schema: SetLevelRequestSchema, 319 | }, 320 | { 321 | method: 'resources/subscribe', 322 | schema: SubscribeRequestSchema, 323 | }, 324 | { 325 | method: 'resources/unsubscribe', 326 | schema: UnsubscribeRequestSchema, 327 | }, 328 | { 329 | method: 'prompts/list', 330 | schema: ListPromptsRequestSchema, 331 | fallbackRequesHandler: () => ({ prompts: [] }), 332 | }, 333 | { 334 | method: 'prompts/get', 335 | schema: GetPromptRequestSchema, 336 | }, 337 | { 338 | method: 'resources/list', 339 | schema: ListResourcesRequestSchema, 340 | fallbackRequesHandler: () => ({ resources: [] }), 341 | }, 342 | { 343 | method: 'resources/read', 344 | schema: ReadResourceRequestSchema, 345 | }, 346 | { 347 | method: 'resources/templates/list', 348 | schema: ListResourceTemplatesRequestSchema, 349 | fallbackRequesHandler: () => ({ resourceTemplates: [] }), 350 | }, 351 | { 352 | method: 'sampling/createMessage', 353 | schema: CreateMessageRequestSchema, 354 | }, 355 | { 356 | method: 'roots/list', 357 | schema: ListRootsRequestSchema, 358 | fallbackRequesHandler: () => ({ roots: [] }), 359 | }, 360 | ] 361 | 362 | for (const { method, schema, fallbackRequesHandler } of forwardedRequests) { 363 | parentServer.setRequestHandler(schema, async (request) => { 364 | ensureChildRunning() 365 | 366 | let result 367 | 368 | try { 369 | result = await callChild(method, request.params) 370 | } catch (err) { 371 | console.error(`[superargs] Could not forward request [${method}]:`, err) 372 | 373 | if (!argsUpdated && fallbackRequesHandler) { 374 | return fallbackRequesHandler(request) 375 | } else { 376 | throw err 377 | } 378 | } 379 | 380 | return result 381 | }) 382 | } 383 | 384 | const parentTransport = new StdioServerTransport() 385 | await parentServer.connect(parentTransport) 386 | 387 | console.error('[superargs] Ready. Waiting on stdio for requests.') 388 | } 389 | 390 | main().catch((err) => { 391 | console.error('[superargs] Fatal error:', err) 392 | process.exit(1) 393 | }) 394 | -------------------------------------------------------------------------------- /superargs.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/supercorp-ai/superargs/1a0ace6f350d17c2055db2f7552808df0b05f6d5/superargs.png -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "NodeNext", 4 | "moduleResolution": "NodeNext", 5 | "target": "ES2022", 6 | "strict": true, 7 | "esModuleInterop": true, 8 | "forceConsistentCasingInFileNames": true, 9 | "outDir": "dist" 10 | }, 11 | "include": ["src/**/*"] 12 | } 13 | --------------------------------------------------------------------------------