├── .gitignore ├── LICENSE ├── README.md ├── docs └── images │ └── threejs-webrtc.gif ├── package-lock.json ├── package.json ├── public ├── index.html └── js │ ├── communications.js │ ├── index.js │ └── libs │ ├── firstPersonControls.js │ └── simplepeer.min.js └── server.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | mydatabase.json -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2024 Aidan Nelson 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 | This [three.js](threejs.org) template allows multiplayer three.js scenes with integrated audio/video capabilities. It uses a node server running socket.io to provide multiplayer functionality as well as WebRTC signaling. 2 | 3 |  4 | 5 | ## Quickstart: 6 | 7 | 1. Download the repository to your computer: 8 | ```bash 9 | $ git clone https://github.com/AidanNelson/threejs-webrtc.git 10 | ``` 11 | 2. Navigate into the local folder and install Node dependencies: 12 | ```bash 13 | $ cd threejs-webrtc 14 | $ npm install 15 | ``` 16 | 3. Start the server: 17 | ```bash 18 | $ npm start 19 | ``` 20 | 4. Navigate to `http://localhost:8080` on your browser. 21 | 22 | ## Technology: 23 | 24 | This space is built using a number of technologies, including: 25 | 26 | * [three.js](https://threejs.org/) provides rendering / 3D environment interaction 27 | * [socket.io](https://socket.io/) provides the three.js multiplayer functionality, and acts as a WebRTC signaling server 28 | * [WebRTC](https://developer.mozilla.org/en-US/docs/Web/API/WebRTC_API) provides video / audio chat functionality 29 | * [Simple Peer](https://github.com/feross/simple-peer) provides a friendlier API for WebRTC 30 | 31 | ## Credits: 32 | 33 | This template uses code from a number of sources, including: 34 | 35 | * Or Fleisher - [THREE.Multiplayer](https://github.com/juniorxsound/THREE.Multiplayer) server and client setup using socket.io with three.js 36 | * Mikołaj Wargowski - [Simple Chat App](https://github.com/Miczeq22/simple-chat-app) using [WebRTC](https://developer.mozilla.org/en-US/docs/Web/API/WebRTC_API) with three.js 37 | * Zachary Stenger - [Three.js Video Chat](https://github.com/zacharystenger/three-js-video-chat) using [WebRTC](https://developer.mozilla.org/en-US/docs/Web/API/WebRTC_API) 38 | -------------------------------------------------------------------------------- /docs/images/threejs-webrtc.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/AidanNelson/threejs-webrtc/004bf34acefc2170e61b32d206e5a23677b3faaf/docs/images/threejs-webrtc.gif -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "three.js-webrtc", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "three.js-webrtc", 9 | "version": "1.0.0", 10 | "license": "MIT", 11 | "dependencies": { 12 | "express": "^4.19.2", 13 | "nedb": "^1.8.0", 14 | "socket.io": "^4.7.5" 15 | }, 16 | "devDependencies": { 17 | "nodemon": "^3.1.0" 18 | } 19 | }, 20 | "node_modules/@socket.io/component-emitter": { 21 | "version": "3.1.0", 22 | "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.1.0.tgz", 23 | "integrity": "sha512-+9jVqKhRSpsc591z5vX+X5Yyw+he/HCB4iQ/RYxw35CEPaY1gnsNE43nf9n9AaYjAQrTiI/mOwKUKdUs9vf7Xg==" 24 | }, 25 | "node_modules/@types/cookie": { 26 | "version": "0.4.1", 27 | "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.4.1.tgz", 28 | "integrity": "sha512-XW/Aa8APYr6jSVVA1y/DEIZX0/GMKLEVekNG727R8cs56ahETkRAy/3DR7+fJyh7oUgGwNQaRfXCun0+KbWY7Q==" 29 | }, 30 | "node_modules/@types/cors": { 31 | "version": "2.8.17", 32 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.17.tgz", 33 | "integrity": "sha512-8CGDvrBj1zgo2qE+oS3pOCyYNqCPryMWY2bGfwA0dcfopWGgxs+78df0Rs3rc9THP4JkOhLsAa+15VdpAqkcUA==", 34 | "dependencies": { 35 | "@types/node": "*" 36 | } 37 | }, 38 | "node_modules/@types/node": { 39 | "version": "20.12.6", 40 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.12.6.tgz", 41 | "integrity": "sha512-3KurE8taB8GCvZBPngVbp0lk5CKi8M9f9k1rsADh0Evdz5SzJ+Q+Hx9uHoFGsLnLnd1xmkDQr2hVhlA0Mn0lKQ==", 42 | "dependencies": { 43 | "undici-types": "~5.26.4" 44 | } 45 | }, 46 | "node_modules/abbrev": { 47 | "version": "1.1.1", 48 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 49 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 50 | "dev": true 51 | }, 52 | "node_modules/accepts": { 53 | "version": "1.3.8", 54 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 55 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 56 | "dependencies": { 57 | "mime-types": "~2.1.34", 58 | "negotiator": "0.6.3" 59 | }, 60 | "engines": { 61 | "node": ">= 0.6" 62 | } 63 | }, 64 | "node_modules/anymatch": { 65 | "version": "3.1.3", 66 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 67 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 68 | "dev": true, 69 | "dependencies": { 70 | "normalize-path": "^3.0.0", 71 | "picomatch": "^2.0.4" 72 | }, 73 | "engines": { 74 | "node": ">= 8" 75 | } 76 | }, 77 | "node_modules/array-flatten": { 78 | "version": "1.1.1", 79 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 80 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 81 | }, 82 | "node_modules/async": { 83 | "version": "0.2.10", 84 | "resolved": "https://registry.npmjs.org/async/-/async-0.2.10.tgz", 85 | "integrity": "sha512-eAkdoKxU6/LkKDBzLpT+t6Ff5EtfSF4wx1WfJiPEEV7WNLnDaRXk0oVysiEPm262roaachGexwUv94WhSgN5TQ==" 86 | }, 87 | "node_modules/balanced-match": { 88 | "version": "1.0.2", 89 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 90 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 91 | "dev": true 92 | }, 93 | "node_modules/base64id": { 94 | "version": "2.0.0", 95 | "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", 96 | "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==", 97 | "engines": { 98 | "node": "^4.5.0 || >= 5.9" 99 | } 100 | }, 101 | "node_modules/binary-extensions": { 102 | "version": "2.3.0", 103 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 104 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 105 | "dev": true, 106 | "engines": { 107 | "node": ">=8" 108 | }, 109 | "funding": { 110 | "url": "https://github.com/sponsors/sindresorhus" 111 | } 112 | }, 113 | "node_modules/binary-search-tree": { 114 | "version": "0.2.5", 115 | "resolved": "https://registry.npmjs.org/binary-search-tree/-/binary-search-tree-0.2.5.tgz", 116 | "integrity": "sha512-CvNVKS6iXagL1uGwLagSXz1hzSMezxOuGnFi5FHGKqaTO3nPPWrAbyALUzK640j+xOTVm7lzD9YP8W1f/gvUdw==", 117 | "dependencies": { 118 | "underscore": "~1.4.4" 119 | } 120 | }, 121 | "node_modules/body-parser": { 122 | "version": "1.20.2", 123 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz", 124 | "integrity": "sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==", 125 | "dependencies": { 126 | "bytes": "3.1.2", 127 | "content-type": "~1.0.5", 128 | "debug": "2.6.9", 129 | "depd": "2.0.0", 130 | "destroy": "1.2.0", 131 | "http-errors": "2.0.0", 132 | "iconv-lite": "0.4.24", 133 | "on-finished": "2.4.1", 134 | "qs": "6.11.0", 135 | "raw-body": "2.5.2", 136 | "type-is": "~1.6.18", 137 | "unpipe": "1.0.0" 138 | }, 139 | "engines": { 140 | "node": ">= 0.8", 141 | "npm": "1.2.8000 || >= 1.4.16" 142 | } 143 | }, 144 | "node_modules/brace-expansion": { 145 | "version": "1.1.11", 146 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 147 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 148 | "dev": true, 149 | "dependencies": { 150 | "balanced-match": "^1.0.0", 151 | "concat-map": "0.0.1" 152 | } 153 | }, 154 | "node_modules/braces": { 155 | "version": "3.0.2", 156 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 157 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 158 | "dev": true, 159 | "dependencies": { 160 | "fill-range": "^7.0.1" 161 | }, 162 | "engines": { 163 | "node": ">=8" 164 | } 165 | }, 166 | "node_modules/bytes": { 167 | "version": "3.1.2", 168 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 169 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 170 | "engines": { 171 | "node": ">= 0.8" 172 | } 173 | }, 174 | "node_modules/call-bind": { 175 | "version": "1.0.7", 176 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", 177 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", 178 | "dependencies": { 179 | "es-define-property": "^1.0.0", 180 | "es-errors": "^1.3.0", 181 | "function-bind": "^1.1.2", 182 | "get-intrinsic": "^1.2.4", 183 | "set-function-length": "^1.2.1" 184 | }, 185 | "engines": { 186 | "node": ">= 0.4" 187 | }, 188 | "funding": { 189 | "url": "https://github.com/sponsors/ljharb" 190 | } 191 | }, 192 | "node_modules/chokidar": { 193 | "version": "3.6.0", 194 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 195 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 196 | "dev": true, 197 | "dependencies": { 198 | "anymatch": "~3.1.2", 199 | "braces": "~3.0.2", 200 | "glob-parent": "~5.1.2", 201 | "is-binary-path": "~2.1.0", 202 | "is-glob": "~4.0.1", 203 | "normalize-path": "~3.0.0", 204 | "readdirp": "~3.6.0" 205 | }, 206 | "engines": { 207 | "node": ">= 8.10.0" 208 | }, 209 | "funding": { 210 | "url": "https://paulmillr.com/funding/" 211 | }, 212 | "optionalDependencies": { 213 | "fsevents": "~2.3.2" 214 | } 215 | }, 216 | "node_modules/concat-map": { 217 | "version": "0.0.1", 218 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 219 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 220 | "dev": true 221 | }, 222 | "node_modules/content-disposition": { 223 | "version": "0.5.4", 224 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 225 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 226 | "dependencies": { 227 | "safe-buffer": "5.2.1" 228 | }, 229 | "engines": { 230 | "node": ">= 0.6" 231 | } 232 | }, 233 | "node_modules/content-type": { 234 | "version": "1.0.5", 235 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 236 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 237 | "engines": { 238 | "node": ">= 0.6" 239 | } 240 | }, 241 | "node_modules/cookie": { 242 | "version": "0.6.0", 243 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", 244 | "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", 245 | "engines": { 246 | "node": ">= 0.6" 247 | } 248 | }, 249 | "node_modules/cookie-signature": { 250 | "version": "1.0.6", 251 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 252 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 253 | }, 254 | "node_modules/cors": { 255 | "version": "2.8.5", 256 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 257 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 258 | "dependencies": { 259 | "object-assign": "^4", 260 | "vary": "^1" 261 | }, 262 | "engines": { 263 | "node": ">= 0.10" 264 | } 265 | }, 266 | "node_modules/debug": { 267 | "version": "2.6.9", 268 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 269 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 270 | "dependencies": { 271 | "ms": "2.0.0" 272 | } 273 | }, 274 | "node_modules/define-data-property": { 275 | "version": "1.1.4", 276 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", 277 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", 278 | "dependencies": { 279 | "es-define-property": "^1.0.0", 280 | "es-errors": "^1.3.0", 281 | "gopd": "^1.0.1" 282 | }, 283 | "engines": { 284 | "node": ">= 0.4" 285 | }, 286 | "funding": { 287 | "url": "https://github.com/sponsors/ljharb" 288 | } 289 | }, 290 | "node_modules/depd": { 291 | "version": "2.0.0", 292 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 293 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 294 | "engines": { 295 | "node": ">= 0.8" 296 | } 297 | }, 298 | "node_modules/destroy": { 299 | "version": "1.2.0", 300 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 301 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 302 | "engines": { 303 | "node": ">= 0.8", 304 | "npm": "1.2.8000 || >= 1.4.16" 305 | } 306 | }, 307 | "node_modules/ee-first": { 308 | "version": "1.1.1", 309 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 310 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 311 | }, 312 | "node_modules/encodeurl": { 313 | "version": "1.0.2", 314 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 315 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 316 | "engines": { 317 | "node": ">= 0.8" 318 | } 319 | }, 320 | "node_modules/engine.io": { 321 | "version": "6.5.4", 322 | "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-6.5.4.tgz", 323 | "integrity": "sha512-KdVSDKhVKyOi+r5uEabrDLZw2qXStVvCsEB/LN3mw4WFi6Gx50jTyuxYVCwAAC0U46FdnzP/ScKRBTXb/NiEOg==", 324 | "dependencies": { 325 | "@types/cookie": "^0.4.1", 326 | "@types/cors": "^2.8.12", 327 | "@types/node": ">=10.0.0", 328 | "accepts": "~1.3.4", 329 | "base64id": "2.0.0", 330 | "cookie": "~0.4.1", 331 | "cors": "~2.8.5", 332 | "debug": "~4.3.1", 333 | "engine.io-parser": "~5.2.1", 334 | "ws": "~8.11.0" 335 | }, 336 | "engines": { 337 | "node": ">=10.2.0" 338 | } 339 | }, 340 | "node_modules/engine.io-parser": { 341 | "version": "5.2.2", 342 | "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.2.2.tgz", 343 | "integrity": "sha512-RcyUFKA93/CXH20l4SoVvzZfrSDMOTUS3bWVpTt2FuFP+XYrL8i8oonHP7WInRyVHXh0n/ORtoeiE1os+8qkSw==", 344 | "engines": { 345 | "node": ">=10.0.0" 346 | } 347 | }, 348 | "node_modules/engine.io/node_modules/cookie": { 349 | "version": "0.4.2", 350 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 351 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 352 | "engines": { 353 | "node": ">= 0.6" 354 | } 355 | }, 356 | "node_modules/engine.io/node_modules/debug": { 357 | "version": "4.3.4", 358 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 359 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 360 | "dependencies": { 361 | "ms": "2.1.2" 362 | }, 363 | "engines": { 364 | "node": ">=6.0" 365 | }, 366 | "peerDependenciesMeta": { 367 | "supports-color": { 368 | "optional": true 369 | } 370 | } 371 | }, 372 | "node_modules/engine.io/node_modules/ms": { 373 | "version": "2.1.2", 374 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 375 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 376 | }, 377 | "node_modules/es-define-property": { 378 | "version": "1.0.0", 379 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", 380 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", 381 | "dependencies": { 382 | "get-intrinsic": "^1.2.4" 383 | }, 384 | "engines": { 385 | "node": ">= 0.4" 386 | } 387 | }, 388 | "node_modules/es-errors": { 389 | "version": "1.3.0", 390 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 391 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 392 | "engines": { 393 | "node": ">= 0.4" 394 | } 395 | }, 396 | "node_modules/escape-html": { 397 | "version": "1.0.3", 398 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 399 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 400 | }, 401 | "node_modules/etag": { 402 | "version": "1.8.1", 403 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 404 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 405 | "engines": { 406 | "node": ">= 0.6" 407 | } 408 | }, 409 | "node_modules/express": { 410 | "version": "4.19.2", 411 | "resolved": "https://registry.npmjs.org/express/-/express-4.19.2.tgz", 412 | "integrity": "sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==", 413 | "dependencies": { 414 | "accepts": "~1.3.8", 415 | "array-flatten": "1.1.1", 416 | "body-parser": "1.20.2", 417 | "content-disposition": "0.5.4", 418 | "content-type": "~1.0.4", 419 | "cookie": "0.6.0", 420 | "cookie-signature": "1.0.6", 421 | "debug": "2.6.9", 422 | "depd": "2.0.0", 423 | "encodeurl": "~1.0.2", 424 | "escape-html": "~1.0.3", 425 | "etag": "~1.8.1", 426 | "finalhandler": "1.2.0", 427 | "fresh": "0.5.2", 428 | "http-errors": "2.0.0", 429 | "merge-descriptors": "1.0.1", 430 | "methods": "~1.1.2", 431 | "on-finished": "2.4.1", 432 | "parseurl": "~1.3.3", 433 | "path-to-regexp": "0.1.7", 434 | "proxy-addr": "~2.0.7", 435 | "qs": "6.11.0", 436 | "range-parser": "~1.2.1", 437 | "safe-buffer": "5.2.1", 438 | "send": "0.18.0", 439 | "serve-static": "1.15.0", 440 | "setprototypeof": "1.2.0", 441 | "statuses": "2.0.1", 442 | "type-is": "~1.6.18", 443 | "utils-merge": "1.0.1", 444 | "vary": "~1.1.2" 445 | }, 446 | "engines": { 447 | "node": ">= 0.10.0" 448 | } 449 | }, 450 | "node_modules/fill-range": { 451 | "version": "7.0.1", 452 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 453 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 454 | "dev": true, 455 | "dependencies": { 456 | "to-regex-range": "^5.0.1" 457 | }, 458 | "engines": { 459 | "node": ">=8" 460 | } 461 | }, 462 | "node_modules/finalhandler": { 463 | "version": "1.2.0", 464 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 465 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 466 | "dependencies": { 467 | "debug": "2.6.9", 468 | "encodeurl": "~1.0.2", 469 | "escape-html": "~1.0.3", 470 | "on-finished": "2.4.1", 471 | "parseurl": "~1.3.3", 472 | "statuses": "2.0.1", 473 | "unpipe": "~1.0.0" 474 | }, 475 | "engines": { 476 | "node": ">= 0.8" 477 | } 478 | }, 479 | "node_modules/forwarded": { 480 | "version": "0.2.0", 481 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 482 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 483 | "engines": { 484 | "node": ">= 0.6" 485 | } 486 | }, 487 | "node_modules/fresh": { 488 | "version": "0.5.2", 489 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 490 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 491 | "engines": { 492 | "node": ">= 0.6" 493 | } 494 | }, 495 | "node_modules/fsevents": { 496 | "version": "2.3.3", 497 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 498 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 499 | "dev": true, 500 | "hasInstallScript": true, 501 | "optional": true, 502 | "os": [ 503 | "darwin" 504 | ], 505 | "engines": { 506 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 507 | } 508 | }, 509 | "node_modules/function-bind": { 510 | "version": "1.1.2", 511 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 512 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 513 | "funding": { 514 | "url": "https://github.com/sponsors/ljharb" 515 | } 516 | }, 517 | "node_modules/get-intrinsic": { 518 | "version": "1.2.4", 519 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", 520 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", 521 | "dependencies": { 522 | "es-errors": "^1.3.0", 523 | "function-bind": "^1.1.2", 524 | "has-proto": "^1.0.1", 525 | "has-symbols": "^1.0.3", 526 | "hasown": "^2.0.0" 527 | }, 528 | "engines": { 529 | "node": ">= 0.4" 530 | }, 531 | "funding": { 532 | "url": "https://github.com/sponsors/ljharb" 533 | } 534 | }, 535 | "node_modules/glob-parent": { 536 | "version": "5.1.2", 537 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 538 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 539 | "dev": true, 540 | "dependencies": { 541 | "is-glob": "^4.0.1" 542 | }, 543 | "engines": { 544 | "node": ">= 6" 545 | } 546 | }, 547 | "node_modules/gopd": { 548 | "version": "1.0.1", 549 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 550 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 551 | "dependencies": { 552 | "get-intrinsic": "^1.1.3" 553 | }, 554 | "funding": { 555 | "url": "https://github.com/sponsors/ljharb" 556 | } 557 | }, 558 | "node_modules/has-flag": { 559 | "version": "3.0.0", 560 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 561 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 562 | "dev": true, 563 | "engines": { 564 | "node": ">=4" 565 | } 566 | }, 567 | "node_modules/has-property-descriptors": { 568 | "version": "1.0.2", 569 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", 570 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", 571 | "dependencies": { 572 | "es-define-property": "^1.0.0" 573 | }, 574 | "funding": { 575 | "url": "https://github.com/sponsors/ljharb" 576 | } 577 | }, 578 | "node_modules/has-proto": { 579 | "version": "1.0.3", 580 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", 581 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", 582 | "engines": { 583 | "node": ">= 0.4" 584 | }, 585 | "funding": { 586 | "url": "https://github.com/sponsors/ljharb" 587 | } 588 | }, 589 | "node_modules/has-symbols": { 590 | "version": "1.0.3", 591 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 592 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 593 | "engines": { 594 | "node": ">= 0.4" 595 | }, 596 | "funding": { 597 | "url": "https://github.com/sponsors/ljharb" 598 | } 599 | }, 600 | "node_modules/hasown": { 601 | "version": "2.0.2", 602 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 603 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 604 | "dependencies": { 605 | "function-bind": "^1.1.2" 606 | }, 607 | "engines": { 608 | "node": ">= 0.4" 609 | } 610 | }, 611 | "node_modules/http-errors": { 612 | "version": "2.0.0", 613 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 614 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 615 | "dependencies": { 616 | "depd": "2.0.0", 617 | "inherits": "2.0.4", 618 | "setprototypeof": "1.2.0", 619 | "statuses": "2.0.1", 620 | "toidentifier": "1.0.1" 621 | }, 622 | "engines": { 623 | "node": ">= 0.8" 624 | } 625 | }, 626 | "node_modules/iconv-lite": { 627 | "version": "0.4.24", 628 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 629 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 630 | "dependencies": { 631 | "safer-buffer": ">= 2.1.2 < 3" 632 | }, 633 | "engines": { 634 | "node": ">=0.10.0" 635 | } 636 | }, 637 | "node_modules/ignore-by-default": { 638 | "version": "1.0.1", 639 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 640 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", 641 | "dev": true 642 | }, 643 | "node_modules/immediate": { 644 | "version": "3.0.6", 645 | "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.0.6.tgz", 646 | "integrity": "sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ==" 647 | }, 648 | "node_modules/inherits": { 649 | "version": "2.0.4", 650 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 651 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 652 | }, 653 | "node_modules/ipaddr.js": { 654 | "version": "1.9.1", 655 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 656 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 657 | "engines": { 658 | "node": ">= 0.10" 659 | } 660 | }, 661 | "node_modules/is-binary-path": { 662 | "version": "2.1.0", 663 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 664 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 665 | "dev": true, 666 | "dependencies": { 667 | "binary-extensions": "^2.0.0" 668 | }, 669 | "engines": { 670 | "node": ">=8" 671 | } 672 | }, 673 | "node_modules/is-extglob": { 674 | "version": "2.1.1", 675 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 676 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 677 | "dev": true, 678 | "engines": { 679 | "node": ">=0.10.0" 680 | } 681 | }, 682 | "node_modules/is-glob": { 683 | "version": "4.0.3", 684 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 685 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 686 | "dev": true, 687 | "dependencies": { 688 | "is-extglob": "^2.1.1" 689 | }, 690 | "engines": { 691 | "node": ">=0.10.0" 692 | } 693 | }, 694 | "node_modules/is-number": { 695 | "version": "7.0.0", 696 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 697 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 698 | "dev": true, 699 | "engines": { 700 | "node": ">=0.12.0" 701 | } 702 | }, 703 | "node_modules/lie": { 704 | "version": "3.1.1", 705 | "resolved": "https://registry.npmjs.org/lie/-/lie-3.1.1.tgz", 706 | "integrity": "sha512-RiNhHysUjhrDQntfYSfY4MU24coXXdEOgw9WGcKHNeEwffDYbF//u87M1EWaMGzuFoSbqW0C9C6lEEhDOAswfw==", 707 | "dependencies": { 708 | "immediate": "~3.0.5" 709 | } 710 | }, 711 | "node_modules/localforage": { 712 | "version": "1.10.0", 713 | "resolved": "https://registry.npmjs.org/localforage/-/localforage-1.10.0.tgz", 714 | "integrity": "sha512-14/H1aX7hzBBmmh7sGPd+AOMkkIrHM3Z1PAyGgZigA1H1p5O5ANnMyWzvpAETtG68/dC4pC0ncy3+PPGzXZHPg==", 715 | "dependencies": { 716 | "lie": "3.1.1" 717 | } 718 | }, 719 | "node_modules/lru-cache": { 720 | "version": "6.0.0", 721 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 722 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 723 | "dev": true, 724 | "dependencies": { 725 | "yallist": "^4.0.0" 726 | }, 727 | "engines": { 728 | "node": ">=10" 729 | } 730 | }, 731 | "node_modules/media-typer": { 732 | "version": "0.3.0", 733 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 734 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 735 | "engines": { 736 | "node": ">= 0.6" 737 | } 738 | }, 739 | "node_modules/merge-descriptors": { 740 | "version": "1.0.1", 741 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 742 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 743 | }, 744 | "node_modules/methods": { 745 | "version": "1.1.2", 746 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 747 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 748 | "engines": { 749 | "node": ">= 0.6" 750 | } 751 | }, 752 | "node_modules/mime": { 753 | "version": "1.6.0", 754 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 755 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 756 | "bin": { 757 | "mime": "cli.js" 758 | }, 759 | "engines": { 760 | "node": ">=4" 761 | } 762 | }, 763 | "node_modules/mime-db": { 764 | "version": "1.52.0", 765 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 766 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 767 | "engines": { 768 | "node": ">= 0.6" 769 | } 770 | }, 771 | "node_modules/mime-types": { 772 | "version": "2.1.35", 773 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 774 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 775 | "dependencies": { 776 | "mime-db": "1.52.0" 777 | }, 778 | "engines": { 779 | "node": ">= 0.6" 780 | } 781 | }, 782 | "node_modules/minimatch": { 783 | "version": "3.1.2", 784 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 785 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 786 | "dev": true, 787 | "dependencies": { 788 | "brace-expansion": "^1.1.7" 789 | }, 790 | "engines": { 791 | "node": "*" 792 | } 793 | }, 794 | "node_modules/minimist": { 795 | "version": "1.2.8", 796 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 797 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 798 | "funding": { 799 | "url": "https://github.com/sponsors/ljharb" 800 | } 801 | }, 802 | "node_modules/mkdirp": { 803 | "version": "0.5.6", 804 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 805 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 806 | "dependencies": { 807 | "minimist": "^1.2.6" 808 | }, 809 | "bin": { 810 | "mkdirp": "bin/cmd.js" 811 | } 812 | }, 813 | "node_modules/ms": { 814 | "version": "2.0.0", 815 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 816 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 817 | }, 818 | "node_modules/nedb": { 819 | "version": "1.8.0", 820 | "resolved": "https://registry.npmjs.org/nedb/-/nedb-1.8.0.tgz", 821 | "integrity": "sha512-ip7BJdyb5m+86ZbSb4y10FCCW9g35+U8bDRrZlAfCI6m4dKwEsQ5M52grcDcVK4Vm/vnPlDLywkyo3GliEkb5A==", 822 | "dependencies": { 823 | "async": "0.2.10", 824 | "binary-search-tree": "0.2.5", 825 | "localforage": "^1.3.0", 826 | "mkdirp": "~0.5.1", 827 | "underscore": "~1.4.4" 828 | } 829 | }, 830 | "node_modules/negotiator": { 831 | "version": "0.6.3", 832 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 833 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 834 | "engines": { 835 | "node": ">= 0.6" 836 | } 837 | }, 838 | "node_modules/nodemon": { 839 | "version": "3.1.0", 840 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.1.0.tgz", 841 | "integrity": "sha512-xqlktYlDMCepBJd43ZQhjWwMw2obW/JRvkrLxq5RCNcuDDX1DbcPT+qT1IlIIdf+DhnWs90JpTMe+Y5KxOchvA==", 842 | "dev": true, 843 | "dependencies": { 844 | "chokidar": "^3.5.2", 845 | "debug": "^4", 846 | "ignore-by-default": "^1.0.1", 847 | "minimatch": "^3.1.2", 848 | "pstree.remy": "^1.1.8", 849 | "semver": "^7.5.3", 850 | "simple-update-notifier": "^2.0.0", 851 | "supports-color": "^5.5.0", 852 | "touch": "^3.1.0", 853 | "undefsafe": "^2.0.5" 854 | }, 855 | "bin": { 856 | "nodemon": "bin/nodemon.js" 857 | }, 858 | "engines": { 859 | "node": ">=10" 860 | }, 861 | "funding": { 862 | "type": "opencollective", 863 | "url": "https://opencollective.com/nodemon" 864 | } 865 | }, 866 | "node_modules/nodemon/node_modules/debug": { 867 | "version": "4.3.4", 868 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 869 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 870 | "dev": true, 871 | "dependencies": { 872 | "ms": "2.1.2" 873 | }, 874 | "engines": { 875 | "node": ">=6.0" 876 | }, 877 | "peerDependenciesMeta": { 878 | "supports-color": { 879 | "optional": true 880 | } 881 | } 882 | }, 883 | "node_modules/nodemon/node_modules/ms": { 884 | "version": "2.1.2", 885 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 886 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 887 | "dev": true 888 | }, 889 | "node_modules/nopt": { 890 | "version": "1.0.10", 891 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 892 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 893 | "dev": true, 894 | "dependencies": { 895 | "abbrev": "1" 896 | }, 897 | "bin": { 898 | "nopt": "bin/nopt.js" 899 | }, 900 | "engines": { 901 | "node": "*" 902 | } 903 | }, 904 | "node_modules/normalize-path": { 905 | "version": "3.0.0", 906 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 907 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 908 | "dev": true, 909 | "engines": { 910 | "node": ">=0.10.0" 911 | } 912 | }, 913 | "node_modules/object-assign": { 914 | "version": "4.1.1", 915 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 916 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 917 | "engines": { 918 | "node": ">=0.10.0" 919 | } 920 | }, 921 | "node_modules/object-inspect": { 922 | "version": "1.13.1", 923 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", 924 | "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", 925 | "funding": { 926 | "url": "https://github.com/sponsors/ljharb" 927 | } 928 | }, 929 | "node_modules/on-finished": { 930 | "version": "2.4.1", 931 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 932 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 933 | "dependencies": { 934 | "ee-first": "1.1.1" 935 | }, 936 | "engines": { 937 | "node": ">= 0.8" 938 | } 939 | }, 940 | "node_modules/parseurl": { 941 | "version": "1.3.3", 942 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 943 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 944 | "engines": { 945 | "node": ">= 0.8" 946 | } 947 | }, 948 | "node_modules/path-to-regexp": { 949 | "version": "0.1.7", 950 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 951 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 952 | }, 953 | "node_modules/picomatch": { 954 | "version": "2.3.1", 955 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 956 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 957 | "dev": true, 958 | "engines": { 959 | "node": ">=8.6" 960 | }, 961 | "funding": { 962 | "url": "https://github.com/sponsors/jonschlinkert" 963 | } 964 | }, 965 | "node_modules/proxy-addr": { 966 | "version": "2.0.7", 967 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 968 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 969 | "dependencies": { 970 | "forwarded": "0.2.0", 971 | "ipaddr.js": "1.9.1" 972 | }, 973 | "engines": { 974 | "node": ">= 0.10" 975 | } 976 | }, 977 | "node_modules/pstree.remy": { 978 | "version": "1.1.8", 979 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 980 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 981 | "dev": true 982 | }, 983 | "node_modules/qs": { 984 | "version": "6.11.0", 985 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 986 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 987 | "dependencies": { 988 | "side-channel": "^1.0.4" 989 | }, 990 | "engines": { 991 | "node": ">=0.6" 992 | }, 993 | "funding": { 994 | "url": "https://github.com/sponsors/ljharb" 995 | } 996 | }, 997 | "node_modules/range-parser": { 998 | "version": "1.2.1", 999 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1000 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1001 | "engines": { 1002 | "node": ">= 0.6" 1003 | } 1004 | }, 1005 | "node_modules/raw-body": { 1006 | "version": "2.5.2", 1007 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", 1008 | "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", 1009 | "dependencies": { 1010 | "bytes": "3.1.2", 1011 | "http-errors": "2.0.0", 1012 | "iconv-lite": "0.4.24", 1013 | "unpipe": "1.0.0" 1014 | }, 1015 | "engines": { 1016 | "node": ">= 0.8" 1017 | } 1018 | }, 1019 | "node_modules/readdirp": { 1020 | "version": "3.6.0", 1021 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1022 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1023 | "dev": true, 1024 | "dependencies": { 1025 | "picomatch": "^2.2.1" 1026 | }, 1027 | "engines": { 1028 | "node": ">=8.10.0" 1029 | } 1030 | }, 1031 | "node_modules/safe-buffer": { 1032 | "version": "5.2.1", 1033 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1034 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1035 | "funding": [ 1036 | { 1037 | "type": "github", 1038 | "url": "https://github.com/sponsors/feross" 1039 | }, 1040 | { 1041 | "type": "patreon", 1042 | "url": "https://www.patreon.com/feross" 1043 | }, 1044 | { 1045 | "type": "consulting", 1046 | "url": "https://feross.org/support" 1047 | } 1048 | ] 1049 | }, 1050 | "node_modules/safer-buffer": { 1051 | "version": "2.1.2", 1052 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1053 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1054 | }, 1055 | "node_modules/semver": { 1056 | "version": "7.6.0", 1057 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", 1058 | "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", 1059 | "dev": true, 1060 | "dependencies": { 1061 | "lru-cache": "^6.0.0" 1062 | }, 1063 | "bin": { 1064 | "semver": "bin/semver.js" 1065 | }, 1066 | "engines": { 1067 | "node": ">=10" 1068 | } 1069 | }, 1070 | "node_modules/send": { 1071 | "version": "0.18.0", 1072 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1073 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1074 | "dependencies": { 1075 | "debug": "2.6.9", 1076 | "depd": "2.0.0", 1077 | "destroy": "1.2.0", 1078 | "encodeurl": "~1.0.2", 1079 | "escape-html": "~1.0.3", 1080 | "etag": "~1.8.1", 1081 | "fresh": "0.5.2", 1082 | "http-errors": "2.0.0", 1083 | "mime": "1.6.0", 1084 | "ms": "2.1.3", 1085 | "on-finished": "2.4.1", 1086 | "range-parser": "~1.2.1", 1087 | "statuses": "2.0.1" 1088 | }, 1089 | "engines": { 1090 | "node": ">= 0.8.0" 1091 | } 1092 | }, 1093 | "node_modules/send/node_modules/ms": { 1094 | "version": "2.1.3", 1095 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1096 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1097 | }, 1098 | "node_modules/serve-static": { 1099 | "version": "1.15.0", 1100 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1101 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1102 | "dependencies": { 1103 | "encodeurl": "~1.0.2", 1104 | "escape-html": "~1.0.3", 1105 | "parseurl": "~1.3.3", 1106 | "send": "0.18.0" 1107 | }, 1108 | "engines": { 1109 | "node": ">= 0.8.0" 1110 | } 1111 | }, 1112 | "node_modules/set-function-length": { 1113 | "version": "1.2.2", 1114 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", 1115 | "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", 1116 | "dependencies": { 1117 | "define-data-property": "^1.1.4", 1118 | "es-errors": "^1.3.0", 1119 | "function-bind": "^1.1.2", 1120 | "get-intrinsic": "^1.2.4", 1121 | "gopd": "^1.0.1", 1122 | "has-property-descriptors": "^1.0.2" 1123 | }, 1124 | "engines": { 1125 | "node": ">= 0.4" 1126 | } 1127 | }, 1128 | "node_modules/setprototypeof": { 1129 | "version": "1.2.0", 1130 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1131 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1132 | }, 1133 | "node_modules/side-channel": { 1134 | "version": "1.0.6", 1135 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", 1136 | "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", 1137 | "dependencies": { 1138 | "call-bind": "^1.0.7", 1139 | "es-errors": "^1.3.0", 1140 | "get-intrinsic": "^1.2.4", 1141 | "object-inspect": "^1.13.1" 1142 | }, 1143 | "engines": { 1144 | "node": ">= 0.4" 1145 | }, 1146 | "funding": { 1147 | "url": "https://github.com/sponsors/ljharb" 1148 | } 1149 | }, 1150 | "node_modules/simple-update-notifier": { 1151 | "version": "2.0.0", 1152 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", 1153 | "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", 1154 | "dev": true, 1155 | "dependencies": { 1156 | "semver": "^7.5.3" 1157 | }, 1158 | "engines": { 1159 | "node": ">=10" 1160 | } 1161 | }, 1162 | "node_modules/socket.io": { 1163 | "version": "4.7.5", 1164 | "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-4.7.5.tgz", 1165 | "integrity": "sha512-DmeAkF6cwM9jSfmp6Dr/5/mfMwb5Z5qRrSXLpo3Fq5SqyU8CMF15jIN4ZhfSwu35ksM1qmHZDQ/DK5XTccSTvA==", 1166 | "dependencies": { 1167 | "accepts": "~1.3.4", 1168 | "base64id": "~2.0.0", 1169 | "cors": "~2.8.5", 1170 | "debug": "~4.3.2", 1171 | "engine.io": "~6.5.2", 1172 | "socket.io-adapter": "~2.5.2", 1173 | "socket.io-parser": "~4.2.4" 1174 | }, 1175 | "engines": { 1176 | "node": ">=10.2.0" 1177 | } 1178 | }, 1179 | "node_modules/socket.io-adapter": { 1180 | "version": "2.5.4", 1181 | "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-2.5.4.tgz", 1182 | "integrity": "sha512-wDNHGXGewWAjQPt3pyeYBtpWSq9cLE5UW1ZUPL/2eGK9jtse/FpXib7epSTsz0Q0m+6sg6Y4KtcFTlah1bdOVg==", 1183 | "dependencies": { 1184 | "debug": "~4.3.4", 1185 | "ws": "~8.11.0" 1186 | } 1187 | }, 1188 | "node_modules/socket.io-adapter/node_modules/debug": { 1189 | "version": "4.3.4", 1190 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1191 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1192 | "dependencies": { 1193 | "ms": "2.1.2" 1194 | }, 1195 | "engines": { 1196 | "node": ">=6.0" 1197 | }, 1198 | "peerDependenciesMeta": { 1199 | "supports-color": { 1200 | "optional": true 1201 | } 1202 | } 1203 | }, 1204 | "node_modules/socket.io-adapter/node_modules/ms": { 1205 | "version": "2.1.2", 1206 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1207 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1208 | }, 1209 | "node_modules/socket.io-parser": { 1210 | "version": "4.2.4", 1211 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.2.4.tgz", 1212 | "integrity": "sha512-/GbIKmo8ioc+NIWIhwdecY0ge+qVBSMdgxGygevmdHj24bsfgtCmcUUcQ5ZzcylGFHsN3k4HB4Cgkl96KVnuew==", 1213 | "dependencies": { 1214 | "@socket.io/component-emitter": "~3.1.0", 1215 | "debug": "~4.3.1" 1216 | }, 1217 | "engines": { 1218 | "node": ">=10.0.0" 1219 | } 1220 | }, 1221 | "node_modules/socket.io-parser/node_modules/debug": { 1222 | "version": "4.3.4", 1223 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1224 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1225 | "dependencies": { 1226 | "ms": "2.1.2" 1227 | }, 1228 | "engines": { 1229 | "node": ">=6.0" 1230 | }, 1231 | "peerDependenciesMeta": { 1232 | "supports-color": { 1233 | "optional": true 1234 | } 1235 | } 1236 | }, 1237 | "node_modules/socket.io-parser/node_modules/ms": { 1238 | "version": "2.1.2", 1239 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1240 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1241 | }, 1242 | "node_modules/socket.io/node_modules/debug": { 1243 | "version": "4.3.3", 1244 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 1245 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 1246 | "dependencies": { 1247 | "ms": "2.1.2" 1248 | }, 1249 | "engines": { 1250 | "node": ">=6.0" 1251 | }, 1252 | "peerDependenciesMeta": { 1253 | "supports-color": { 1254 | "optional": true 1255 | } 1256 | } 1257 | }, 1258 | "node_modules/socket.io/node_modules/ms": { 1259 | "version": "2.1.2", 1260 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1261 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1262 | }, 1263 | "node_modules/statuses": { 1264 | "version": "2.0.1", 1265 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1266 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1267 | "engines": { 1268 | "node": ">= 0.8" 1269 | } 1270 | }, 1271 | "node_modules/supports-color": { 1272 | "version": "5.5.0", 1273 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1274 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1275 | "dev": true, 1276 | "dependencies": { 1277 | "has-flag": "^3.0.0" 1278 | }, 1279 | "engines": { 1280 | "node": ">=4" 1281 | } 1282 | }, 1283 | "node_modules/to-regex-range": { 1284 | "version": "5.0.1", 1285 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1286 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1287 | "dev": true, 1288 | "dependencies": { 1289 | "is-number": "^7.0.0" 1290 | }, 1291 | "engines": { 1292 | "node": ">=8.0" 1293 | } 1294 | }, 1295 | "node_modules/toidentifier": { 1296 | "version": "1.0.1", 1297 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1298 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1299 | "engines": { 1300 | "node": ">=0.6" 1301 | } 1302 | }, 1303 | "node_modules/touch": { 1304 | "version": "3.1.0", 1305 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1306 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1307 | "dev": true, 1308 | "dependencies": { 1309 | "nopt": "~1.0.10" 1310 | }, 1311 | "bin": { 1312 | "nodetouch": "bin/nodetouch.js" 1313 | } 1314 | }, 1315 | "node_modules/type-is": { 1316 | "version": "1.6.18", 1317 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1318 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1319 | "dependencies": { 1320 | "media-typer": "0.3.0", 1321 | "mime-types": "~2.1.24" 1322 | }, 1323 | "engines": { 1324 | "node": ">= 0.6" 1325 | } 1326 | }, 1327 | "node_modules/undefsafe": { 1328 | "version": "2.0.5", 1329 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1330 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 1331 | "dev": true 1332 | }, 1333 | "node_modules/underscore": { 1334 | "version": "1.4.4", 1335 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.4.4.tgz", 1336 | "integrity": "sha512-ZqGrAgaqqZM7LGRzNjLnw5elevWb5M8LEoDMadxIW3OWbcv72wMMgKdwOKpd5Fqxe8choLD8HN3iSj3TUh/giQ==" 1337 | }, 1338 | "node_modules/undici-types": { 1339 | "version": "5.26.5", 1340 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 1341 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==" 1342 | }, 1343 | "node_modules/unpipe": { 1344 | "version": "1.0.0", 1345 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1346 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1347 | "engines": { 1348 | "node": ">= 0.8" 1349 | } 1350 | }, 1351 | "node_modules/utils-merge": { 1352 | "version": "1.0.1", 1353 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1354 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 1355 | "engines": { 1356 | "node": ">= 0.4.0" 1357 | } 1358 | }, 1359 | "node_modules/vary": { 1360 | "version": "1.1.2", 1361 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1362 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 1363 | "engines": { 1364 | "node": ">= 0.8" 1365 | } 1366 | }, 1367 | "node_modules/ws": { 1368 | "version": "8.11.0", 1369 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.11.0.tgz", 1370 | "integrity": "sha512-HPG3wQd9sNQoT9xHyNCXoDUa+Xw/VevmY9FoHyQ+g+rrMn4j6FB4np7Z0OhdTgjx6MgQLK7jwSy1YecU1+4Asg==", 1371 | "engines": { 1372 | "node": ">=10.0.0" 1373 | }, 1374 | "peerDependencies": { 1375 | "bufferutil": "^4.0.1", 1376 | "utf-8-validate": "^5.0.2" 1377 | }, 1378 | "peerDependenciesMeta": { 1379 | "bufferutil": { 1380 | "optional": true 1381 | }, 1382 | "utf-8-validate": { 1383 | "optional": true 1384 | } 1385 | } 1386 | }, 1387 | "node_modules/yallist": { 1388 | "version": "4.0.0", 1389 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1390 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1391 | "dev": true 1392 | } 1393 | } 1394 | } 1395 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "three.js-webrtc", 3 | "version": "1.0.0", 4 | "description": "Template for using three.js with socket.io and WebRTC", 5 | "main": "server.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "nodemon --ignore ./public/ server.js --ignore ./mydatabase.json" 9 | }, 10 | "author": "", 11 | "license": "MIT", 12 | "dependencies": { 13 | "express": "^4.19.2", 14 | "nedb": "^1.8.0", 15 | "socket.io": "^4.7.5" 16 | }, 17 | "devDependencies": { 18 | "nodemon": "^3.1.0" 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 |
4 |>1,_=-7,h=a?l-1:0,b=a?-1:1,d=t[n+h];for(h+=b,c=d&(1<<-_)-1,d>>=-_,_+=p;0<_;c=256*c+t[n+h],h+=b,_-=8);for(u=c&(1<<-_)-1,c>>=-_,_+=o;0<_;u=256*u+t[n+h],h+=b,_-=8);if(0===c)c=1-g;else{if(c===f)return u?NaN:(d?-1:1)*(1/0);u+=r(2,o),c-=g}return(d?-1:1)*u*r(2,c-o)},o.write=function(a,o,l,u,p,f){var h,b,y,g=Math.LN2,_=Math.log,C=8*f-p-1,R=(1< =1.5*a?"s":"")}var l=24*(60*60000);t.exports=function(e,t){t=t||{};var n=typeof e;if("string"==n&&0