├── .gitignore ├── .prettierrc ├── README.md ├── config.js ├── index.js ├── package-lock.json ├── package.json └── src ├── app.js ├── connections └── db.js ├── controllers └── users.js ├── joiValidators └── user.js ├── middlewares ├── error.js └── response.js ├── models └── user.js ├── routes ├── index.js └── users.js └── utils ├── httpStatus.js ├── index.js ├── logger.js └── modelNames.js /.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | /node_modules 5 | /.pnp 6 | .pnp.js 7 | 8 | # testing 9 | /coverage 10 | 11 | # production 12 | /build 13 | 14 | # misc 15 | .DS_Store 16 | .env.local 17 | .env.development.local 18 | .env.test.local 19 | .env.production.local 20 | .env 21 | 22 | /uploads 23 | 24 | npm-debug.log* 25 | yarn-debug.log* 26 | yarn-error.log* 27 | 28 | .idea -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "singleQuote": true, 3 | "semi": true, 4 | "printWidth": 80, 5 | "trailingComma": "none" 6 | } -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Task BE 2 | 3 | ## Run on Local Machine 4 | 5 | ### Dependencies: 6 | 1. NodeJS 7 | 2. MongoDB 8 | 9 | 10 | ### Installing Project Dependencies 11 | Run the following command to install the node modules: 12 | ``` 13 | npm install 14 | ``` 15 | 16 | ### Setting the Environment Variables 17 | Set the following environment variables: 18 | ``` 19 | NODE_ENV=development 20 | 21 | PORT= 22 | 23 | # Database 24 | DB_URI= 25 | 26 | # Cloudinary 27 | CLOUDINARY_URL= 28 | ``` 29 | You can get the Cloudinary URL from the Cloudinary Dashboard. 30 | The test values CLOUDINARY_UR and DB_URI can be provided on asking. 31 | ### Running the Server 32 | Run the server by: 33 | ``` 34 | npm run start:dev 35 | ``` 36 | -------------------------------------------------------------------------------- /config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | SERVER_PORT: process.env.PORT, 3 | DB_URI: process.env.DB_URI, 4 | DB_USER: process.env.DB_USER, 5 | DB_NAME: process.env.DB_NAME, 6 | DB_HOST: process.env.DB_HOST, 7 | DB_PORT: process.env.DB_PORT, 8 | DB_PASSWORD: process.env.DB_PASSWORD, 9 | NODE_ENV: process.env.NODE_ENV, 10 | isDevelopEnv: process.env.NODE_ENV === 'development' 11 | }; 12 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | require('dotenv').config(); 2 | const app = require('./src/app'); 3 | const cloudinary = require('cloudinary').v2; 4 | 5 | cloudinary.config({ 6 | secure: true 7 | }); 8 | 9 | const { SERVER_PORT } = require('./config'); 10 | 11 | const port = process.env.PORT || SERVER_PORT; 12 | 13 | app.listen(port, () => console.log(`Listening at http://localhost://${port}`)); 14 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "task-be", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "task-be", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "cloudinary": "^1.41.0", 13 | "colors": "^1.4.0", 14 | "cors": "^2.8.5", 15 | "dotenv": "^16.3.1", 16 | "express": "^4.18.2", 17 | "joi": "^17.11.0", 18 | "mongoose": "^7.6.0", 19 | "morgan": "^1.10.0", 20 | "multer": "^1.4.5-lts.1", 21 | "randomstring": "^1.3.0" 22 | }, 23 | "devDependencies": { 24 | "@types/mongoose": "^5.11.97", 25 | "nodemon": "^3.0.1", 26 | "prettier": "^3.0.3" 27 | } 28 | }, 29 | "node_modules/@hapi/hoek": { 30 | "version": "9.3.0", 31 | "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", 32 | "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==" 33 | }, 34 | "node_modules/@hapi/topo": { 35 | "version": "5.1.0", 36 | "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", 37 | "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", 38 | "dependencies": { 39 | "@hapi/hoek": "^9.0.0" 40 | } 41 | }, 42 | "node_modules/@mongodb-js/saslprep": { 43 | "version": "1.1.0", 44 | "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.0.tgz", 45 | "integrity": "sha512-Xfijy7HvfzzqiOAhAepF4SGN5e9leLkMvg/OPOF97XemjfVCYN/oWa75wnkc6mltMSTwY+XlbhWgUOJmkFspSw==", 46 | "optional": true, 47 | "dependencies": { 48 | "sparse-bitfield": "^3.0.3" 49 | } 50 | }, 51 | "node_modules/@sideway/address": { 52 | "version": "4.1.4", 53 | "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.4.tgz", 54 | "integrity": "sha512-7vwq+rOHVWjyXxVlR76Agnvhy8I9rpzjosTESvmhNeXOXdZZB15Fl+TI9x1SiHZH5Jv2wTGduSxFDIaq0m3DUw==", 55 | "dependencies": { 56 | "@hapi/hoek": "^9.0.0" 57 | } 58 | }, 59 | "node_modules/@sideway/formula": { 60 | "version": "3.0.1", 61 | "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.1.tgz", 62 | "integrity": "sha512-/poHZJJVjx3L+zVD6g9KgHfYnb443oi7wLu/XKojDviHy6HOEOA6z1Trk5aR1dGcmPenJEgb2sK2I80LeS3MIg==" 63 | }, 64 | "node_modules/@sideway/pinpoint": { 65 | "version": "2.0.0", 66 | "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", 67 | "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==" 68 | }, 69 | "node_modules/@types/mongoose": { 70 | "version": "5.11.97", 71 | "resolved": "https://registry.npmjs.org/@types/mongoose/-/mongoose-5.11.97.tgz", 72 | "integrity": "sha512-cqwOVYT3qXyLiGw7ueU2kX9noE8DPGRY6z8eUxudhXY8NZ7DMKYAxyZkLSevGfhCX3dO/AoX5/SO9lAzfjon0Q==", 73 | "deprecated": "Mongoose publishes its own types, so you do not need to install this package.", 74 | "dev": true, 75 | "dependencies": { 76 | "mongoose": "*" 77 | } 78 | }, 79 | "node_modules/@types/node": { 80 | "version": "20.8.2", 81 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.8.2.tgz", 82 | "integrity": "sha512-Vvycsc9FQdwhxE3y3DzeIxuEJbWGDsnrxvMADzTDF/lcdR9/K+AQIeAghTQsHtotg/q0j3WEOYS/jQgSdWue3w==" 83 | }, 84 | "node_modules/@types/webidl-conversions": { 85 | "version": "7.0.1", 86 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.1.tgz", 87 | "integrity": "sha512-8hKOnOan+Uu+NgMaCouhg3cT9x5fFZ92Jwf+uDLXLu/MFRbXxlWwGeQY7KVHkeSft6RvY+tdxklUBuyY9eIEKg==" 88 | }, 89 | "node_modules/@types/whatwg-url": { 90 | "version": "8.2.2", 91 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.2.tgz", 92 | "integrity": "sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA==", 93 | "dependencies": { 94 | "@types/node": "*", 95 | "@types/webidl-conversions": "*" 96 | } 97 | }, 98 | "node_modules/abbrev": { 99 | "version": "1.1.1", 100 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 101 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 102 | "dev": true 103 | }, 104 | "node_modules/accepts": { 105 | "version": "1.3.8", 106 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 107 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 108 | "dependencies": { 109 | "mime-types": "~2.1.34", 110 | "negotiator": "0.6.3" 111 | }, 112 | "engines": { 113 | "node": ">= 0.6" 114 | } 115 | }, 116 | "node_modules/anymatch": { 117 | "version": "3.1.3", 118 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 119 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 120 | "dev": true, 121 | "dependencies": { 122 | "normalize-path": "^3.0.0", 123 | "picomatch": "^2.0.4" 124 | }, 125 | "engines": { 126 | "node": ">= 8" 127 | } 128 | }, 129 | "node_modules/append-field": { 130 | "version": "1.0.0", 131 | "resolved": "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz", 132 | "integrity": "sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw==" 133 | }, 134 | "node_modules/array-flatten": { 135 | "version": "1.1.1", 136 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 137 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 138 | }, 139 | "node_modules/balanced-match": { 140 | "version": "1.0.2", 141 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 142 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 143 | "dev": true 144 | }, 145 | "node_modules/basic-auth": { 146 | "version": "2.0.1", 147 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 148 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 149 | "dependencies": { 150 | "safe-buffer": "5.1.2" 151 | }, 152 | "engines": { 153 | "node": ">= 0.8" 154 | } 155 | }, 156 | "node_modules/basic-auth/node_modules/safe-buffer": { 157 | "version": "5.1.2", 158 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 159 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 160 | }, 161 | "node_modules/binary-extensions": { 162 | "version": "2.2.0", 163 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 164 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 165 | "dev": true, 166 | "engines": { 167 | "node": ">=8" 168 | } 169 | }, 170 | "node_modules/body-parser": { 171 | "version": "1.20.1", 172 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 173 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 174 | "dependencies": { 175 | "bytes": "3.1.2", 176 | "content-type": "~1.0.4", 177 | "debug": "2.6.9", 178 | "depd": "2.0.0", 179 | "destroy": "1.2.0", 180 | "http-errors": "2.0.0", 181 | "iconv-lite": "0.4.24", 182 | "on-finished": "2.4.1", 183 | "qs": "6.11.0", 184 | "raw-body": "2.5.1", 185 | "type-is": "~1.6.18", 186 | "unpipe": "1.0.0" 187 | }, 188 | "engines": { 189 | "node": ">= 0.8", 190 | "npm": "1.2.8000 || >= 1.4.16" 191 | } 192 | }, 193 | "node_modules/brace-expansion": { 194 | "version": "1.1.11", 195 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 196 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 197 | "dev": true, 198 | "dependencies": { 199 | "balanced-match": "^1.0.0", 200 | "concat-map": "0.0.1" 201 | } 202 | }, 203 | "node_modules/braces": { 204 | "version": "3.0.2", 205 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 206 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 207 | "dev": true, 208 | "dependencies": { 209 | "fill-range": "^7.0.1" 210 | }, 211 | "engines": { 212 | "node": ">=8" 213 | } 214 | }, 215 | "node_modules/bson": { 216 | "version": "5.5.0", 217 | "resolved": "https://registry.npmjs.org/bson/-/bson-5.5.0.tgz", 218 | "integrity": "sha512-B+QB4YmDx9RStKv8LLSl/aVIEV3nYJc3cJNNTK2Cd1TL+7P+cNpw9mAPeCgc5K+j01Dv6sxUzcITXDx7ZU3F0w==", 219 | "engines": { 220 | "node": ">=14.20.1" 221 | } 222 | }, 223 | "node_modules/buffer-from": { 224 | "version": "1.1.2", 225 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 226 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" 227 | }, 228 | "node_modules/busboy": { 229 | "version": "1.6.0", 230 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 231 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 232 | "dependencies": { 233 | "streamsearch": "^1.1.0" 234 | }, 235 | "engines": { 236 | "node": ">=10.16.0" 237 | } 238 | }, 239 | "node_modules/bytes": { 240 | "version": "3.1.2", 241 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 242 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 243 | "engines": { 244 | "node": ">= 0.8" 245 | } 246 | }, 247 | "node_modules/call-bind": { 248 | "version": "1.0.2", 249 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 250 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 251 | "dependencies": { 252 | "function-bind": "^1.1.1", 253 | "get-intrinsic": "^1.0.2" 254 | }, 255 | "funding": { 256 | "url": "https://github.com/sponsors/ljharb" 257 | } 258 | }, 259 | "node_modules/chokidar": { 260 | "version": "3.5.3", 261 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 262 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 263 | "dev": true, 264 | "funding": [ 265 | { 266 | "type": "individual", 267 | "url": "https://paulmillr.com/funding/" 268 | } 269 | ], 270 | "dependencies": { 271 | "anymatch": "~3.1.2", 272 | "braces": "~3.0.2", 273 | "glob-parent": "~5.1.2", 274 | "is-binary-path": "~2.1.0", 275 | "is-glob": "~4.0.1", 276 | "normalize-path": "~3.0.0", 277 | "readdirp": "~3.6.0" 278 | }, 279 | "engines": { 280 | "node": ">= 8.10.0" 281 | }, 282 | "optionalDependencies": { 283 | "fsevents": "~2.3.2" 284 | } 285 | }, 286 | "node_modules/cloudinary": { 287 | "version": "1.41.0", 288 | "resolved": "https://registry.npmjs.org/cloudinary/-/cloudinary-1.41.0.tgz", 289 | "integrity": "sha512-qFf2McjvILJITePf4VF1PrY/8c2zy+/q5FVV6V3VWrP/gpIZsusPqXL4QZ6ZKXibPRukzMYqsQEhaSQgJHKKow==", 290 | "dependencies": { 291 | "cloudinary-core": "^2.13.0", 292 | "core-js": "^3.30.1", 293 | "lodash": "^4.17.21", 294 | "q": "^1.5.1" 295 | }, 296 | "engines": { 297 | "node": ">=0.6" 298 | } 299 | }, 300 | "node_modules/cloudinary-core": { 301 | "version": "2.13.0", 302 | "resolved": "https://registry.npmjs.org/cloudinary-core/-/cloudinary-core-2.13.0.tgz", 303 | "integrity": "sha512-Nt0Q5I2FtenmJghtC4YZ3MZZbGg1wLm84SsxcuVwZ83OyJqG9CNIGp86CiI6iDv3QobaqBUpOT7vg+HqY5HxEA==", 304 | "peerDependencies": { 305 | "lodash": ">=4.0" 306 | } 307 | }, 308 | "node_modules/colors": { 309 | "version": "1.4.0", 310 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", 311 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==", 312 | "engines": { 313 | "node": ">=0.1.90" 314 | } 315 | }, 316 | "node_modules/concat-map": { 317 | "version": "0.0.1", 318 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 319 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 320 | "dev": true 321 | }, 322 | "node_modules/concat-stream": { 323 | "version": "1.6.2", 324 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 325 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 326 | "engines": [ 327 | "node >= 0.8" 328 | ], 329 | "dependencies": { 330 | "buffer-from": "^1.0.0", 331 | "inherits": "^2.0.3", 332 | "readable-stream": "^2.2.2", 333 | "typedarray": "^0.0.6" 334 | } 335 | }, 336 | "node_modules/content-disposition": { 337 | "version": "0.5.4", 338 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 339 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 340 | "dependencies": { 341 | "safe-buffer": "5.2.1" 342 | }, 343 | "engines": { 344 | "node": ">= 0.6" 345 | } 346 | }, 347 | "node_modules/content-type": { 348 | "version": "1.0.5", 349 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 350 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 351 | "engines": { 352 | "node": ">= 0.6" 353 | } 354 | }, 355 | "node_modules/cookie": { 356 | "version": "0.5.0", 357 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 358 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 359 | "engines": { 360 | "node": ">= 0.6" 361 | } 362 | }, 363 | "node_modules/cookie-signature": { 364 | "version": "1.0.6", 365 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 366 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 367 | }, 368 | "node_modules/core-js": { 369 | "version": "3.33.0", 370 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.33.0.tgz", 371 | "integrity": "sha512-HoZr92+ZjFEKar5HS6MC776gYslNOKHt75mEBKWKnPeFDpZ6nH5OeF3S6HFT1mUAUZKrzkez05VboaX8myjSuw==", 372 | "hasInstallScript": true, 373 | "funding": { 374 | "type": "opencollective", 375 | "url": "https://opencollective.com/core-js" 376 | } 377 | }, 378 | "node_modules/core-util-is": { 379 | "version": "1.0.3", 380 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 381 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" 382 | }, 383 | "node_modules/cors": { 384 | "version": "2.8.5", 385 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 386 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 387 | "dependencies": { 388 | "object-assign": "^4", 389 | "vary": "^1" 390 | }, 391 | "engines": { 392 | "node": ">= 0.10" 393 | } 394 | }, 395 | "node_modules/debug": { 396 | "version": "2.6.9", 397 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 398 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 399 | "dependencies": { 400 | "ms": "2.0.0" 401 | } 402 | }, 403 | "node_modules/depd": { 404 | "version": "2.0.0", 405 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 406 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 407 | "engines": { 408 | "node": ">= 0.8" 409 | } 410 | }, 411 | "node_modules/destroy": { 412 | "version": "1.2.0", 413 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 414 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 415 | "engines": { 416 | "node": ">= 0.8", 417 | "npm": "1.2.8000 || >= 1.4.16" 418 | } 419 | }, 420 | "node_modules/dotenv": { 421 | "version": "16.3.1", 422 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.3.1.tgz", 423 | "integrity": "sha512-IPzF4w4/Rd94bA9imS68tZBaYyBWSCE47V1RGuMrB94iyTOIEwRmVL2x/4An+6mETpLrKJ5hQkB8W4kFAadeIQ==", 424 | "engines": { 425 | "node": ">=12" 426 | }, 427 | "funding": { 428 | "url": "https://github.com/motdotla/dotenv?sponsor=1" 429 | } 430 | }, 431 | "node_modules/ee-first": { 432 | "version": "1.1.1", 433 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 434 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 435 | }, 436 | "node_modules/encodeurl": { 437 | "version": "1.0.2", 438 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 439 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 440 | "engines": { 441 | "node": ">= 0.8" 442 | } 443 | }, 444 | "node_modules/escape-html": { 445 | "version": "1.0.3", 446 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 447 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 448 | }, 449 | "node_modules/etag": { 450 | "version": "1.8.1", 451 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 452 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 453 | "engines": { 454 | "node": ">= 0.6" 455 | } 456 | }, 457 | "node_modules/express": { 458 | "version": "4.18.2", 459 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 460 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 461 | "dependencies": { 462 | "accepts": "~1.3.8", 463 | "array-flatten": "1.1.1", 464 | "body-parser": "1.20.1", 465 | "content-disposition": "0.5.4", 466 | "content-type": "~1.0.4", 467 | "cookie": "0.5.0", 468 | "cookie-signature": "1.0.6", 469 | "debug": "2.6.9", 470 | "depd": "2.0.0", 471 | "encodeurl": "~1.0.2", 472 | "escape-html": "~1.0.3", 473 | "etag": "~1.8.1", 474 | "finalhandler": "1.2.0", 475 | "fresh": "0.5.2", 476 | "http-errors": "2.0.0", 477 | "merge-descriptors": "1.0.1", 478 | "methods": "~1.1.2", 479 | "on-finished": "2.4.1", 480 | "parseurl": "~1.3.3", 481 | "path-to-regexp": "0.1.7", 482 | "proxy-addr": "~2.0.7", 483 | "qs": "6.11.0", 484 | "range-parser": "~1.2.1", 485 | "safe-buffer": "5.2.1", 486 | "send": "0.18.0", 487 | "serve-static": "1.15.0", 488 | "setprototypeof": "1.2.0", 489 | "statuses": "2.0.1", 490 | "type-is": "~1.6.18", 491 | "utils-merge": "1.0.1", 492 | "vary": "~1.1.2" 493 | }, 494 | "engines": { 495 | "node": ">= 0.10.0" 496 | } 497 | }, 498 | "node_modules/fill-range": { 499 | "version": "7.0.1", 500 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 501 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 502 | "dev": true, 503 | "dependencies": { 504 | "to-regex-range": "^5.0.1" 505 | }, 506 | "engines": { 507 | "node": ">=8" 508 | } 509 | }, 510 | "node_modules/finalhandler": { 511 | "version": "1.2.0", 512 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 513 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 514 | "dependencies": { 515 | "debug": "2.6.9", 516 | "encodeurl": "~1.0.2", 517 | "escape-html": "~1.0.3", 518 | "on-finished": "2.4.1", 519 | "parseurl": "~1.3.3", 520 | "statuses": "2.0.1", 521 | "unpipe": "~1.0.0" 522 | }, 523 | "engines": { 524 | "node": ">= 0.8" 525 | } 526 | }, 527 | "node_modules/forwarded": { 528 | "version": "0.2.0", 529 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 530 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 531 | "engines": { 532 | "node": ">= 0.6" 533 | } 534 | }, 535 | "node_modules/fresh": { 536 | "version": "0.5.2", 537 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 538 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 539 | "engines": { 540 | "node": ">= 0.6" 541 | } 542 | }, 543 | "node_modules/fsevents": { 544 | "version": "2.3.3", 545 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 546 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 547 | "dev": true, 548 | "hasInstallScript": true, 549 | "optional": true, 550 | "os": [ 551 | "darwin" 552 | ], 553 | "engines": { 554 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 555 | } 556 | }, 557 | "node_modules/function-bind": { 558 | "version": "1.1.1", 559 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 560 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 561 | }, 562 | "node_modules/get-intrinsic": { 563 | "version": "1.2.1", 564 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 565 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 566 | "dependencies": { 567 | "function-bind": "^1.1.1", 568 | "has": "^1.0.3", 569 | "has-proto": "^1.0.1", 570 | "has-symbols": "^1.0.3" 571 | }, 572 | "funding": { 573 | "url": "https://github.com/sponsors/ljharb" 574 | } 575 | }, 576 | "node_modules/glob-parent": { 577 | "version": "5.1.2", 578 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 579 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 580 | "dev": true, 581 | "dependencies": { 582 | "is-glob": "^4.0.1" 583 | }, 584 | "engines": { 585 | "node": ">= 6" 586 | } 587 | }, 588 | "node_modules/has": { 589 | "version": "1.0.4", 590 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.4.tgz", 591 | "integrity": "sha512-qdSAmqLF6209RFj4VVItywPMbm3vWylknmB3nvNiUIs72xAimcM8nVYxYr7ncvZq5qzk9MKIZR8ijqD/1QuYjQ==", 592 | "engines": { 593 | "node": ">= 0.4.0" 594 | } 595 | }, 596 | "node_modules/has-flag": { 597 | "version": "3.0.0", 598 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 599 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 600 | "dev": true, 601 | "engines": { 602 | "node": ">=4" 603 | } 604 | }, 605 | "node_modules/has-proto": { 606 | "version": "1.0.1", 607 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 608 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", 609 | "engines": { 610 | "node": ">= 0.4" 611 | }, 612 | "funding": { 613 | "url": "https://github.com/sponsors/ljharb" 614 | } 615 | }, 616 | "node_modules/has-symbols": { 617 | "version": "1.0.3", 618 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 619 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 620 | "engines": { 621 | "node": ">= 0.4" 622 | }, 623 | "funding": { 624 | "url": "https://github.com/sponsors/ljharb" 625 | } 626 | }, 627 | "node_modules/http-errors": { 628 | "version": "2.0.0", 629 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 630 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 631 | "dependencies": { 632 | "depd": "2.0.0", 633 | "inherits": "2.0.4", 634 | "setprototypeof": "1.2.0", 635 | "statuses": "2.0.1", 636 | "toidentifier": "1.0.1" 637 | }, 638 | "engines": { 639 | "node": ">= 0.8" 640 | } 641 | }, 642 | "node_modules/iconv-lite": { 643 | "version": "0.4.24", 644 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 645 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 646 | "dependencies": { 647 | "safer-buffer": ">= 2.1.2 < 3" 648 | }, 649 | "engines": { 650 | "node": ">=0.10.0" 651 | } 652 | }, 653 | "node_modules/ignore-by-default": { 654 | "version": "1.0.1", 655 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 656 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", 657 | "dev": true 658 | }, 659 | "node_modules/inherits": { 660 | "version": "2.0.4", 661 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 662 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 663 | }, 664 | "node_modules/ip": { 665 | "version": "2.0.0", 666 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 667 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 668 | }, 669 | "node_modules/ipaddr.js": { 670 | "version": "1.9.1", 671 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 672 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 673 | "engines": { 674 | "node": ">= 0.10" 675 | } 676 | }, 677 | "node_modules/is-binary-path": { 678 | "version": "2.1.0", 679 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 680 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 681 | "dev": true, 682 | "dependencies": { 683 | "binary-extensions": "^2.0.0" 684 | }, 685 | "engines": { 686 | "node": ">=8" 687 | } 688 | }, 689 | "node_modules/is-extglob": { 690 | "version": "2.1.1", 691 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 692 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 693 | "dev": true, 694 | "engines": { 695 | "node": ">=0.10.0" 696 | } 697 | }, 698 | "node_modules/is-glob": { 699 | "version": "4.0.3", 700 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 701 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 702 | "dev": true, 703 | "dependencies": { 704 | "is-extglob": "^2.1.1" 705 | }, 706 | "engines": { 707 | "node": ">=0.10.0" 708 | } 709 | }, 710 | "node_modules/is-number": { 711 | "version": "7.0.0", 712 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 713 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 714 | "dev": true, 715 | "engines": { 716 | "node": ">=0.12.0" 717 | } 718 | }, 719 | "node_modules/isarray": { 720 | "version": "1.0.0", 721 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 722 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" 723 | }, 724 | "node_modules/joi": { 725 | "version": "17.11.0", 726 | "resolved": "https://registry.npmjs.org/joi/-/joi-17.11.0.tgz", 727 | "integrity": "sha512-NgB+lZLNoqISVy1rZocE9PZI36bL/77ie924Ri43yEvi9GUUMPeyVIr8KdFTMUlby1p0PBYMk9spIxEUQYqrJQ==", 728 | "dependencies": { 729 | "@hapi/hoek": "^9.0.0", 730 | "@hapi/topo": "^5.0.0", 731 | "@sideway/address": "^4.1.3", 732 | "@sideway/formula": "^3.0.1", 733 | "@sideway/pinpoint": "^2.0.0" 734 | } 735 | }, 736 | "node_modules/kareem": { 737 | "version": "2.5.1", 738 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.5.1.tgz", 739 | "integrity": "sha512-7jFxRVm+jD+rkq3kY0iZDJfsO2/t4BBPeEb2qKn2lR/9KhuksYk5hxzfRYWMPV8P/x2d0kHD306YyWLzjjH+uA==", 740 | "engines": { 741 | "node": ">=12.0.0" 742 | } 743 | }, 744 | "node_modules/lodash": { 745 | "version": "4.17.21", 746 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 747 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 748 | }, 749 | "node_modules/lru-cache": { 750 | "version": "6.0.0", 751 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 752 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 753 | "dev": true, 754 | "dependencies": { 755 | "yallist": "^4.0.0" 756 | }, 757 | "engines": { 758 | "node": ">=10" 759 | } 760 | }, 761 | "node_modules/media-typer": { 762 | "version": "0.3.0", 763 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 764 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 765 | "engines": { 766 | "node": ">= 0.6" 767 | } 768 | }, 769 | "node_modules/memory-pager": { 770 | "version": "1.5.0", 771 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 772 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 773 | "optional": true 774 | }, 775 | "node_modules/merge-descriptors": { 776 | "version": "1.0.1", 777 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 778 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 779 | }, 780 | "node_modules/methods": { 781 | "version": "1.1.2", 782 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 783 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 784 | "engines": { 785 | "node": ">= 0.6" 786 | } 787 | }, 788 | "node_modules/mime": { 789 | "version": "1.6.0", 790 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 791 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 792 | "bin": { 793 | "mime": "cli.js" 794 | }, 795 | "engines": { 796 | "node": ">=4" 797 | } 798 | }, 799 | "node_modules/mime-db": { 800 | "version": "1.52.0", 801 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 802 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 803 | "engines": { 804 | "node": ">= 0.6" 805 | } 806 | }, 807 | "node_modules/mime-types": { 808 | "version": "2.1.35", 809 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 810 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 811 | "dependencies": { 812 | "mime-db": "1.52.0" 813 | }, 814 | "engines": { 815 | "node": ">= 0.6" 816 | } 817 | }, 818 | "node_modules/minimatch": { 819 | "version": "3.1.2", 820 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 821 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 822 | "dev": true, 823 | "dependencies": { 824 | "brace-expansion": "^1.1.7" 825 | }, 826 | "engines": { 827 | "node": "*" 828 | } 829 | }, 830 | "node_modules/minimist": { 831 | "version": "1.2.8", 832 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 833 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 834 | "funding": { 835 | "url": "https://github.com/sponsors/ljharb" 836 | } 837 | }, 838 | "node_modules/mkdirp": { 839 | "version": "0.5.6", 840 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 841 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 842 | "dependencies": { 843 | "minimist": "^1.2.6" 844 | }, 845 | "bin": { 846 | "mkdirp": "bin/cmd.js" 847 | } 848 | }, 849 | "node_modules/mongodb": { 850 | "version": "5.9.0", 851 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-5.9.0.tgz", 852 | "integrity": "sha512-g+GCMHN1CoRUA+wb1Agv0TI4YTSiWr42B5ulkiAfLLHitGK1R+PkSAf3Lr5rPZwi/3F04LiaZEW0Kxro9Fi2TA==", 853 | "dependencies": { 854 | "bson": "^5.5.0", 855 | "mongodb-connection-string-url": "^2.6.0", 856 | "socks": "^2.7.1" 857 | }, 858 | "engines": { 859 | "node": ">=14.20.1" 860 | }, 861 | "optionalDependencies": { 862 | "@mongodb-js/saslprep": "^1.1.0" 863 | }, 864 | "peerDependencies": { 865 | "@aws-sdk/credential-providers": "^3.188.0", 866 | "@mongodb-js/zstd": "^1.0.0", 867 | "kerberos": "^1.0.0 || ^2.0.0", 868 | "mongodb-client-encryption": ">=2.3.0 <3", 869 | "snappy": "^7.2.2" 870 | }, 871 | "peerDependenciesMeta": { 872 | "@aws-sdk/credential-providers": { 873 | "optional": true 874 | }, 875 | "@mongodb-js/zstd": { 876 | "optional": true 877 | }, 878 | "kerberos": { 879 | "optional": true 880 | }, 881 | "mongodb-client-encryption": { 882 | "optional": true 883 | }, 884 | "snappy": { 885 | "optional": true 886 | } 887 | } 888 | }, 889 | "node_modules/mongodb-connection-string-url": { 890 | "version": "2.6.0", 891 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz", 892 | "integrity": "sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ==", 893 | "dependencies": { 894 | "@types/whatwg-url": "^8.2.1", 895 | "whatwg-url": "^11.0.0" 896 | } 897 | }, 898 | "node_modules/mongoose": { 899 | "version": "7.6.0", 900 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-7.6.0.tgz", 901 | "integrity": "sha512-ztQ12rm0BQN5i7LB6xhWX4l9a9w2aa3jEwa/mM2vAutYJRyAwOzcusvKJBULMzFHyUDBOVW15grisexypgMIWA==", 902 | "dependencies": { 903 | "bson": "^5.4.0", 904 | "kareem": "2.5.1", 905 | "mongodb": "5.9.0", 906 | "mpath": "0.9.0", 907 | "mquery": "5.0.0", 908 | "ms": "2.1.3", 909 | "sift": "16.0.1" 910 | }, 911 | "engines": { 912 | "node": ">=14.20.1" 913 | }, 914 | "funding": { 915 | "type": "opencollective", 916 | "url": "https://opencollective.com/mongoose" 917 | } 918 | }, 919 | "node_modules/mongoose/node_modules/ms": { 920 | "version": "2.1.3", 921 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 922 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 923 | }, 924 | "node_modules/morgan": { 925 | "version": "1.10.0", 926 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz", 927 | "integrity": "sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==", 928 | "dependencies": { 929 | "basic-auth": "~2.0.1", 930 | "debug": "2.6.9", 931 | "depd": "~2.0.0", 932 | "on-finished": "~2.3.0", 933 | "on-headers": "~1.0.2" 934 | }, 935 | "engines": { 936 | "node": ">= 0.8.0" 937 | } 938 | }, 939 | "node_modules/morgan/node_modules/on-finished": { 940 | "version": "2.3.0", 941 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 942 | "integrity": "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==", 943 | "dependencies": { 944 | "ee-first": "1.1.1" 945 | }, 946 | "engines": { 947 | "node": ">= 0.8" 948 | } 949 | }, 950 | "node_modules/mpath": { 951 | "version": "0.9.0", 952 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 953 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==", 954 | "engines": { 955 | "node": ">=4.0.0" 956 | } 957 | }, 958 | "node_modules/mquery": { 959 | "version": "5.0.0", 960 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 961 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 962 | "dependencies": { 963 | "debug": "4.x" 964 | }, 965 | "engines": { 966 | "node": ">=14.0.0" 967 | } 968 | }, 969 | "node_modules/mquery/node_modules/debug": { 970 | "version": "4.3.4", 971 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 972 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 973 | "dependencies": { 974 | "ms": "2.1.2" 975 | }, 976 | "engines": { 977 | "node": ">=6.0" 978 | }, 979 | "peerDependenciesMeta": { 980 | "supports-color": { 981 | "optional": true 982 | } 983 | } 984 | }, 985 | "node_modules/mquery/node_modules/ms": { 986 | "version": "2.1.2", 987 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 988 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 989 | }, 990 | "node_modules/ms": { 991 | "version": "2.0.0", 992 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 993 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 994 | }, 995 | "node_modules/multer": { 996 | "version": "1.4.5-lts.1", 997 | "resolved": "https://registry.npmjs.org/multer/-/multer-1.4.5-lts.1.tgz", 998 | "integrity": "sha512-ywPWvcDMeH+z9gQq5qYHCCy+ethsk4goepZ45GLD63fOu0YcNecQxi64nDs3qluZB+murG3/D4dJ7+dGctcCQQ==", 999 | "dependencies": { 1000 | "append-field": "^1.0.0", 1001 | "busboy": "^1.0.0", 1002 | "concat-stream": "^1.5.2", 1003 | "mkdirp": "^0.5.4", 1004 | "object-assign": "^4.1.1", 1005 | "type-is": "^1.6.4", 1006 | "xtend": "^4.0.0" 1007 | }, 1008 | "engines": { 1009 | "node": ">= 6.0.0" 1010 | } 1011 | }, 1012 | "node_modules/negotiator": { 1013 | "version": "0.6.3", 1014 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1015 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1016 | "engines": { 1017 | "node": ">= 0.6" 1018 | } 1019 | }, 1020 | "node_modules/nodemon": { 1021 | "version": "3.0.1", 1022 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.0.1.tgz", 1023 | "integrity": "sha512-g9AZ7HmkhQkqXkRc20w+ZfQ73cHLbE8hnPbtaFbFtCumZsjyMhKk9LajQ07U5Ux28lvFjZ5X7HvWR1xzU8jHVw==", 1024 | "dev": true, 1025 | "dependencies": { 1026 | "chokidar": "^3.5.2", 1027 | "debug": "^3.2.7", 1028 | "ignore-by-default": "^1.0.1", 1029 | "minimatch": "^3.1.2", 1030 | "pstree.remy": "^1.1.8", 1031 | "semver": "^7.5.3", 1032 | "simple-update-notifier": "^2.0.0", 1033 | "supports-color": "^5.5.0", 1034 | "touch": "^3.1.0", 1035 | "undefsafe": "^2.0.5" 1036 | }, 1037 | "bin": { 1038 | "nodemon": "bin/nodemon.js" 1039 | }, 1040 | "engines": { 1041 | "node": ">=10" 1042 | }, 1043 | "funding": { 1044 | "type": "opencollective", 1045 | "url": "https://opencollective.com/nodemon" 1046 | } 1047 | }, 1048 | "node_modules/nodemon/node_modules/debug": { 1049 | "version": "3.2.7", 1050 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1051 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1052 | "dev": true, 1053 | "dependencies": { 1054 | "ms": "^2.1.1" 1055 | } 1056 | }, 1057 | "node_modules/nodemon/node_modules/ms": { 1058 | "version": "2.1.3", 1059 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1060 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1061 | "dev": true 1062 | }, 1063 | "node_modules/nopt": { 1064 | "version": "1.0.10", 1065 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1066 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 1067 | "dev": true, 1068 | "dependencies": { 1069 | "abbrev": "1" 1070 | }, 1071 | "bin": { 1072 | "nopt": "bin/nopt.js" 1073 | }, 1074 | "engines": { 1075 | "node": "*" 1076 | } 1077 | }, 1078 | "node_modules/normalize-path": { 1079 | "version": "3.0.0", 1080 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1081 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1082 | "dev": true, 1083 | "engines": { 1084 | "node": ">=0.10.0" 1085 | } 1086 | }, 1087 | "node_modules/object-assign": { 1088 | "version": "4.1.1", 1089 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1090 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1091 | "engines": { 1092 | "node": ">=0.10.0" 1093 | } 1094 | }, 1095 | "node_modules/object-inspect": { 1096 | "version": "1.12.3", 1097 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 1098 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 1099 | "funding": { 1100 | "url": "https://github.com/sponsors/ljharb" 1101 | } 1102 | }, 1103 | "node_modules/on-finished": { 1104 | "version": "2.4.1", 1105 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1106 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1107 | "dependencies": { 1108 | "ee-first": "1.1.1" 1109 | }, 1110 | "engines": { 1111 | "node": ">= 0.8" 1112 | } 1113 | }, 1114 | "node_modules/on-headers": { 1115 | "version": "1.0.2", 1116 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 1117 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", 1118 | "engines": { 1119 | "node": ">= 0.8" 1120 | } 1121 | }, 1122 | "node_modules/parseurl": { 1123 | "version": "1.3.3", 1124 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1125 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1126 | "engines": { 1127 | "node": ">= 0.8" 1128 | } 1129 | }, 1130 | "node_modules/path-to-regexp": { 1131 | "version": "0.1.7", 1132 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1133 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 1134 | }, 1135 | "node_modules/picomatch": { 1136 | "version": "2.3.1", 1137 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1138 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1139 | "dev": true, 1140 | "engines": { 1141 | "node": ">=8.6" 1142 | }, 1143 | "funding": { 1144 | "url": "https://github.com/sponsors/jonschlinkert" 1145 | } 1146 | }, 1147 | "node_modules/prettier": { 1148 | "version": "3.0.3", 1149 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.0.3.tgz", 1150 | "integrity": "sha512-L/4pUDMxcNa8R/EthV08Zt42WBO4h1rarVtK0K+QJG0X187OLo7l699jWw0GKuwzkPQ//jMFA/8Xm6Fh3J/DAg==", 1151 | "dev": true, 1152 | "bin": { 1153 | "prettier": "bin/prettier.cjs" 1154 | }, 1155 | "engines": { 1156 | "node": ">=14" 1157 | }, 1158 | "funding": { 1159 | "url": "https://github.com/prettier/prettier?sponsor=1" 1160 | } 1161 | }, 1162 | "node_modules/process-nextick-args": { 1163 | "version": "2.0.1", 1164 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1165 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 1166 | }, 1167 | "node_modules/proxy-addr": { 1168 | "version": "2.0.7", 1169 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1170 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1171 | "dependencies": { 1172 | "forwarded": "0.2.0", 1173 | "ipaddr.js": "1.9.1" 1174 | }, 1175 | "engines": { 1176 | "node": ">= 0.10" 1177 | } 1178 | }, 1179 | "node_modules/pstree.remy": { 1180 | "version": "1.1.8", 1181 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1182 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1183 | "dev": true 1184 | }, 1185 | "node_modules/punycode": { 1186 | "version": "2.3.0", 1187 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 1188 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 1189 | "engines": { 1190 | "node": ">=6" 1191 | } 1192 | }, 1193 | "node_modules/q": { 1194 | "version": "1.5.1", 1195 | "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", 1196 | "integrity": "sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw==", 1197 | "engines": { 1198 | "node": ">=0.6.0", 1199 | "teleport": ">=0.2.0" 1200 | } 1201 | }, 1202 | "node_modules/qs": { 1203 | "version": "6.11.0", 1204 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1205 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1206 | "dependencies": { 1207 | "side-channel": "^1.0.4" 1208 | }, 1209 | "engines": { 1210 | "node": ">=0.6" 1211 | }, 1212 | "funding": { 1213 | "url": "https://github.com/sponsors/ljharb" 1214 | } 1215 | }, 1216 | "node_modules/randombytes": { 1217 | "version": "2.0.3", 1218 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.0.3.tgz", 1219 | "integrity": "sha512-lDVjxQQFoCG1jcrP06LNo2lbWp4QTShEXnhActFBwYuHprllQV6VUpwreApsYqCgD+N1mHoqJ/BI/4eV4R2GYg==" 1220 | }, 1221 | "node_modules/randomstring": { 1222 | "version": "1.3.0", 1223 | "resolved": "https://registry.npmjs.org/randomstring/-/randomstring-1.3.0.tgz", 1224 | "integrity": "sha512-gY7aQ4i1BgwZ8I1Op4YseITAyiDiajeZOPQUbIq9TPGPhUm5FX59izIaOpmKbME1nmnEiABf28d9K2VSii6BBg==", 1225 | "dependencies": { 1226 | "randombytes": "2.0.3" 1227 | }, 1228 | "bin": { 1229 | "randomstring": "bin/randomstring" 1230 | }, 1231 | "engines": { 1232 | "node": "*" 1233 | } 1234 | }, 1235 | "node_modules/range-parser": { 1236 | "version": "1.2.1", 1237 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1238 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1239 | "engines": { 1240 | "node": ">= 0.6" 1241 | } 1242 | }, 1243 | "node_modules/raw-body": { 1244 | "version": "2.5.1", 1245 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 1246 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 1247 | "dependencies": { 1248 | "bytes": "3.1.2", 1249 | "http-errors": "2.0.0", 1250 | "iconv-lite": "0.4.24", 1251 | "unpipe": "1.0.0" 1252 | }, 1253 | "engines": { 1254 | "node": ">= 0.8" 1255 | } 1256 | }, 1257 | "node_modules/readable-stream": { 1258 | "version": "2.3.8", 1259 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 1260 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 1261 | "dependencies": { 1262 | "core-util-is": "~1.0.0", 1263 | "inherits": "~2.0.3", 1264 | "isarray": "~1.0.0", 1265 | "process-nextick-args": "~2.0.0", 1266 | "safe-buffer": "~5.1.1", 1267 | "string_decoder": "~1.1.1", 1268 | "util-deprecate": "~1.0.1" 1269 | } 1270 | }, 1271 | "node_modules/readable-stream/node_modules/safe-buffer": { 1272 | "version": "5.1.2", 1273 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1274 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1275 | }, 1276 | "node_modules/readdirp": { 1277 | "version": "3.6.0", 1278 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1279 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1280 | "dev": true, 1281 | "dependencies": { 1282 | "picomatch": "^2.2.1" 1283 | }, 1284 | "engines": { 1285 | "node": ">=8.10.0" 1286 | } 1287 | }, 1288 | "node_modules/safe-buffer": { 1289 | "version": "5.2.1", 1290 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1291 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1292 | "funding": [ 1293 | { 1294 | "type": "github", 1295 | "url": "https://github.com/sponsors/feross" 1296 | }, 1297 | { 1298 | "type": "patreon", 1299 | "url": "https://www.patreon.com/feross" 1300 | }, 1301 | { 1302 | "type": "consulting", 1303 | "url": "https://feross.org/support" 1304 | } 1305 | ] 1306 | }, 1307 | "node_modules/safer-buffer": { 1308 | "version": "2.1.2", 1309 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1310 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1311 | }, 1312 | "node_modules/semver": { 1313 | "version": "7.5.4", 1314 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 1315 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 1316 | "dev": true, 1317 | "dependencies": { 1318 | "lru-cache": "^6.0.0" 1319 | }, 1320 | "bin": { 1321 | "semver": "bin/semver.js" 1322 | }, 1323 | "engines": { 1324 | "node": ">=10" 1325 | } 1326 | }, 1327 | "node_modules/send": { 1328 | "version": "0.18.0", 1329 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1330 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1331 | "dependencies": { 1332 | "debug": "2.6.9", 1333 | "depd": "2.0.0", 1334 | "destroy": "1.2.0", 1335 | "encodeurl": "~1.0.2", 1336 | "escape-html": "~1.0.3", 1337 | "etag": "~1.8.1", 1338 | "fresh": "0.5.2", 1339 | "http-errors": "2.0.0", 1340 | "mime": "1.6.0", 1341 | "ms": "2.1.3", 1342 | "on-finished": "2.4.1", 1343 | "range-parser": "~1.2.1", 1344 | "statuses": "2.0.1" 1345 | }, 1346 | "engines": { 1347 | "node": ">= 0.8.0" 1348 | } 1349 | }, 1350 | "node_modules/send/node_modules/ms": { 1351 | "version": "2.1.3", 1352 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1353 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1354 | }, 1355 | "node_modules/serve-static": { 1356 | "version": "1.15.0", 1357 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1358 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1359 | "dependencies": { 1360 | "encodeurl": "~1.0.2", 1361 | "escape-html": "~1.0.3", 1362 | "parseurl": "~1.3.3", 1363 | "send": "0.18.0" 1364 | }, 1365 | "engines": { 1366 | "node": ">= 0.8.0" 1367 | } 1368 | }, 1369 | "node_modules/setprototypeof": { 1370 | "version": "1.2.0", 1371 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1372 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1373 | }, 1374 | "node_modules/side-channel": { 1375 | "version": "1.0.4", 1376 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1377 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1378 | "dependencies": { 1379 | "call-bind": "^1.0.0", 1380 | "get-intrinsic": "^1.0.2", 1381 | "object-inspect": "^1.9.0" 1382 | }, 1383 | "funding": { 1384 | "url": "https://github.com/sponsors/ljharb" 1385 | } 1386 | }, 1387 | "node_modules/sift": { 1388 | "version": "16.0.1", 1389 | "resolved": "https://registry.npmjs.org/sift/-/sift-16.0.1.tgz", 1390 | "integrity": "sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ==" 1391 | }, 1392 | "node_modules/simple-update-notifier": { 1393 | "version": "2.0.0", 1394 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", 1395 | "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", 1396 | "dev": true, 1397 | "dependencies": { 1398 | "semver": "^7.5.3" 1399 | }, 1400 | "engines": { 1401 | "node": ">=10" 1402 | } 1403 | }, 1404 | "node_modules/smart-buffer": { 1405 | "version": "4.2.0", 1406 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 1407 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", 1408 | "engines": { 1409 | "node": ">= 6.0.0", 1410 | "npm": ">= 3.0.0" 1411 | } 1412 | }, 1413 | "node_modules/socks": { 1414 | "version": "2.7.1", 1415 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 1416 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 1417 | "dependencies": { 1418 | "ip": "^2.0.0", 1419 | "smart-buffer": "^4.2.0" 1420 | }, 1421 | "engines": { 1422 | "node": ">= 10.13.0", 1423 | "npm": ">= 3.0.0" 1424 | } 1425 | }, 1426 | "node_modules/sparse-bitfield": { 1427 | "version": "3.0.3", 1428 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1429 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 1430 | "optional": true, 1431 | "dependencies": { 1432 | "memory-pager": "^1.0.2" 1433 | } 1434 | }, 1435 | "node_modules/statuses": { 1436 | "version": "2.0.1", 1437 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1438 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1439 | "engines": { 1440 | "node": ">= 0.8" 1441 | } 1442 | }, 1443 | "node_modules/streamsearch": { 1444 | "version": "1.1.0", 1445 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 1446 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 1447 | "engines": { 1448 | "node": ">=10.0.0" 1449 | } 1450 | }, 1451 | "node_modules/string_decoder": { 1452 | "version": "1.1.1", 1453 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1454 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1455 | "dependencies": { 1456 | "safe-buffer": "~5.1.0" 1457 | } 1458 | }, 1459 | "node_modules/string_decoder/node_modules/safe-buffer": { 1460 | "version": "5.1.2", 1461 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1462 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1463 | }, 1464 | "node_modules/supports-color": { 1465 | "version": "5.5.0", 1466 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1467 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1468 | "dev": true, 1469 | "dependencies": { 1470 | "has-flag": "^3.0.0" 1471 | }, 1472 | "engines": { 1473 | "node": ">=4" 1474 | } 1475 | }, 1476 | "node_modules/to-regex-range": { 1477 | "version": "5.0.1", 1478 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1479 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1480 | "dev": true, 1481 | "dependencies": { 1482 | "is-number": "^7.0.0" 1483 | }, 1484 | "engines": { 1485 | "node": ">=8.0" 1486 | } 1487 | }, 1488 | "node_modules/toidentifier": { 1489 | "version": "1.0.1", 1490 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1491 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1492 | "engines": { 1493 | "node": ">=0.6" 1494 | } 1495 | }, 1496 | "node_modules/touch": { 1497 | "version": "3.1.0", 1498 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1499 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1500 | "dev": true, 1501 | "dependencies": { 1502 | "nopt": "~1.0.10" 1503 | }, 1504 | "bin": { 1505 | "nodetouch": "bin/nodetouch.js" 1506 | } 1507 | }, 1508 | "node_modules/tr46": { 1509 | "version": "3.0.0", 1510 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 1511 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 1512 | "dependencies": { 1513 | "punycode": "^2.1.1" 1514 | }, 1515 | "engines": { 1516 | "node": ">=12" 1517 | } 1518 | }, 1519 | "node_modules/type-is": { 1520 | "version": "1.6.18", 1521 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1522 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1523 | "dependencies": { 1524 | "media-typer": "0.3.0", 1525 | "mime-types": "~2.1.24" 1526 | }, 1527 | "engines": { 1528 | "node": ">= 0.6" 1529 | } 1530 | }, 1531 | "node_modules/typedarray": { 1532 | "version": "0.0.6", 1533 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 1534 | "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==" 1535 | }, 1536 | "node_modules/undefsafe": { 1537 | "version": "2.0.5", 1538 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1539 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 1540 | "dev": true 1541 | }, 1542 | "node_modules/unpipe": { 1543 | "version": "1.0.0", 1544 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1545 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1546 | "engines": { 1547 | "node": ">= 0.8" 1548 | } 1549 | }, 1550 | "node_modules/util-deprecate": { 1551 | "version": "1.0.2", 1552 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1553 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 1554 | }, 1555 | "node_modules/utils-merge": { 1556 | "version": "1.0.1", 1557 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1558 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1559 | "engines": { 1560 | "node": ">= 0.4.0" 1561 | } 1562 | }, 1563 | "node_modules/vary": { 1564 | "version": "1.1.2", 1565 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1566 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1567 | "engines": { 1568 | "node": ">= 0.8" 1569 | } 1570 | }, 1571 | "node_modules/webidl-conversions": { 1572 | "version": "7.0.0", 1573 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1574 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 1575 | "engines": { 1576 | "node": ">=12" 1577 | } 1578 | }, 1579 | "node_modules/whatwg-url": { 1580 | "version": "11.0.0", 1581 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 1582 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 1583 | "dependencies": { 1584 | "tr46": "^3.0.0", 1585 | "webidl-conversions": "^7.0.0" 1586 | }, 1587 | "engines": { 1588 | "node": ">=12" 1589 | } 1590 | }, 1591 | "node_modules/xtend": { 1592 | "version": "4.0.2", 1593 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 1594 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 1595 | "engines": { 1596 | "node": ">=0.4" 1597 | } 1598 | }, 1599 | "node_modules/yallist": { 1600 | "version": "4.0.0", 1601 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1602 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1603 | "dev": true 1604 | } 1605 | }, 1606 | "dependencies": { 1607 | "@hapi/hoek": { 1608 | "version": "9.3.0", 1609 | "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", 1610 | "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==" 1611 | }, 1612 | "@hapi/topo": { 1613 | "version": "5.1.0", 1614 | "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", 1615 | "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", 1616 | "requires": { 1617 | "@hapi/hoek": "^9.0.0" 1618 | } 1619 | }, 1620 | "@mongodb-js/saslprep": { 1621 | "version": "1.1.0", 1622 | "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.0.tgz", 1623 | "integrity": "sha512-Xfijy7HvfzzqiOAhAepF4SGN5e9leLkMvg/OPOF97XemjfVCYN/oWa75wnkc6mltMSTwY+XlbhWgUOJmkFspSw==", 1624 | "optional": true, 1625 | "requires": { 1626 | "sparse-bitfield": "^3.0.3" 1627 | } 1628 | }, 1629 | "@sideway/address": { 1630 | "version": "4.1.4", 1631 | "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.4.tgz", 1632 | "integrity": "sha512-7vwq+rOHVWjyXxVlR76Agnvhy8I9rpzjosTESvmhNeXOXdZZB15Fl+TI9x1SiHZH5Jv2wTGduSxFDIaq0m3DUw==", 1633 | "requires": { 1634 | "@hapi/hoek": "^9.0.0" 1635 | } 1636 | }, 1637 | "@sideway/formula": { 1638 | "version": "3.0.1", 1639 | "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.1.tgz", 1640 | "integrity": "sha512-/poHZJJVjx3L+zVD6g9KgHfYnb443oi7wLu/XKojDviHy6HOEOA6z1Trk5aR1dGcmPenJEgb2sK2I80LeS3MIg==" 1641 | }, 1642 | "@sideway/pinpoint": { 1643 | "version": "2.0.0", 1644 | "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", 1645 | "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==" 1646 | }, 1647 | "@types/mongoose": { 1648 | "version": "5.11.97", 1649 | "resolved": "https://registry.npmjs.org/@types/mongoose/-/mongoose-5.11.97.tgz", 1650 | "integrity": "sha512-cqwOVYT3qXyLiGw7ueU2kX9noE8DPGRY6z8eUxudhXY8NZ7DMKYAxyZkLSevGfhCX3dO/AoX5/SO9lAzfjon0Q==", 1651 | "dev": true, 1652 | "requires": { 1653 | "mongoose": "*" 1654 | } 1655 | }, 1656 | "@types/node": { 1657 | "version": "20.8.2", 1658 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.8.2.tgz", 1659 | "integrity": "sha512-Vvycsc9FQdwhxE3y3DzeIxuEJbWGDsnrxvMADzTDF/lcdR9/K+AQIeAghTQsHtotg/q0j3WEOYS/jQgSdWue3w==" 1660 | }, 1661 | "@types/webidl-conversions": { 1662 | "version": "7.0.1", 1663 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.1.tgz", 1664 | "integrity": "sha512-8hKOnOan+Uu+NgMaCouhg3cT9x5fFZ92Jwf+uDLXLu/MFRbXxlWwGeQY7KVHkeSft6RvY+tdxklUBuyY9eIEKg==" 1665 | }, 1666 | "@types/whatwg-url": { 1667 | "version": "8.2.2", 1668 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.2.tgz", 1669 | "integrity": "sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA==", 1670 | "requires": { 1671 | "@types/node": "*", 1672 | "@types/webidl-conversions": "*" 1673 | } 1674 | }, 1675 | "abbrev": { 1676 | "version": "1.1.1", 1677 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 1678 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 1679 | "dev": true 1680 | }, 1681 | "accepts": { 1682 | "version": "1.3.8", 1683 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 1684 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 1685 | "requires": { 1686 | "mime-types": "~2.1.34", 1687 | "negotiator": "0.6.3" 1688 | } 1689 | }, 1690 | "anymatch": { 1691 | "version": "3.1.3", 1692 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1693 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1694 | "dev": true, 1695 | "requires": { 1696 | "normalize-path": "^3.0.0", 1697 | "picomatch": "^2.0.4" 1698 | } 1699 | }, 1700 | "append-field": { 1701 | "version": "1.0.0", 1702 | "resolved": "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz", 1703 | "integrity": "sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw==" 1704 | }, 1705 | "array-flatten": { 1706 | "version": "1.1.1", 1707 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 1708 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 1709 | }, 1710 | "balanced-match": { 1711 | "version": "1.0.2", 1712 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1713 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1714 | "dev": true 1715 | }, 1716 | "basic-auth": { 1717 | "version": "2.0.1", 1718 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 1719 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 1720 | "requires": { 1721 | "safe-buffer": "5.1.2" 1722 | }, 1723 | "dependencies": { 1724 | "safe-buffer": { 1725 | "version": "5.1.2", 1726 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1727 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1728 | } 1729 | } 1730 | }, 1731 | "binary-extensions": { 1732 | "version": "2.2.0", 1733 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1734 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 1735 | "dev": true 1736 | }, 1737 | "body-parser": { 1738 | "version": "1.20.1", 1739 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 1740 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 1741 | "requires": { 1742 | "bytes": "3.1.2", 1743 | "content-type": "~1.0.4", 1744 | "debug": "2.6.9", 1745 | "depd": "2.0.0", 1746 | "destroy": "1.2.0", 1747 | "http-errors": "2.0.0", 1748 | "iconv-lite": "0.4.24", 1749 | "on-finished": "2.4.1", 1750 | "qs": "6.11.0", 1751 | "raw-body": "2.5.1", 1752 | "type-is": "~1.6.18", 1753 | "unpipe": "1.0.0" 1754 | } 1755 | }, 1756 | "brace-expansion": { 1757 | "version": "1.1.11", 1758 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1759 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1760 | "dev": true, 1761 | "requires": { 1762 | "balanced-match": "^1.0.0", 1763 | "concat-map": "0.0.1" 1764 | } 1765 | }, 1766 | "braces": { 1767 | "version": "3.0.2", 1768 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1769 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1770 | "dev": true, 1771 | "requires": { 1772 | "fill-range": "^7.0.1" 1773 | } 1774 | }, 1775 | "bson": { 1776 | "version": "5.5.0", 1777 | "resolved": "https://registry.npmjs.org/bson/-/bson-5.5.0.tgz", 1778 | "integrity": "sha512-B+QB4YmDx9RStKv8LLSl/aVIEV3nYJc3cJNNTK2Cd1TL+7P+cNpw9mAPeCgc5K+j01Dv6sxUzcITXDx7ZU3F0w==" 1779 | }, 1780 | "buffer-from": { 1781 | "version": "1.1.2", 1782 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1783 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" 1784 | }, 1785 | "busboy": { 1786 | "version": "1.6.0", 1787 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 1788 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 1789 | "requires": { 1790 | "streamsearch": "^1.1.0" 1791 | } 1792 | }, 1793 | "bytes": { 1794 | "version": "3.1.2", 1795 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 1796 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" 1797 | }, 1798 | "call-bind": { 1799 | "version": "1.0.2", 1800 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 1801 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 1802 | "requires": { 1803 | "function-bind": "^1.1.1", 1804 | "get-intrinsic": "^1.0.2" 1805 | } 1806 | }, 1807 | "chokidar": { 1808 | "version": "3.5.3", 1809 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 1810 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 1811 | "dev": true, 1812 | "requires": { 1813 | "anymatch": "~3.1.2", 1814 | "braces": "~3.0.2", 1815 | "fsevents": "~2.3.2", 1816 | "glob-parent": "~5.1.2", 1817 | "is-binary-path": "~2.1.0", 1818 | "is-glob": "~4.0.1", 1819 | "normalize-path": "~3.0.0", 1820 | "readdirp": "~3.6.0" 1821 | } 1822 | }, 1823 | "cloudinary": { 1824 | "version": "1.41.0", 1825 | "resolved": "https://registry.npmjs.org/cloudinary/-/cloudinary-1.41.0.tgz", 1826 | "integrity": "sha512-qFf2McjvILJITePf4VF1PrY/8c2zy+/q5FVV6V3VWrP/gpIZsusPqXL4QZ6ZKXibPRukzMYqsQEhaSQgJHKKow==", 1827 | "requires": { 1828 | "cloudinary-core": "^2.13.0", 1829 | "core-js": "^3.30.1", 1830 | "lodash": "^4.17.21", 1831 | "q": "^1.5.1" 1832 | } 1833 | }, 1834 | "cloudinary-core": { 1835 | "version": "2.13.0", 1836 | "resolved": "https://registry.npmjs.org/cloudinary-core/-/cloudinary-core-2.13.0.tgz", 1837 | "integrity": "sha512-Nt0Q5I2FtenmJghtC4YZ3MZZbGg1wLm84SsxcuVwZ83OyJqG9CNIGp86CiI6iDv3QobaqBUpOT7vg+HqY5HxEA==", 1838 | "requires": {} 1839 | }, 1840 | "colors": { 1841 | "version": "1.4.0", 1842 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", 1843 | "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==" 1844 | }, 1845 | "concat-map": { 1846 | "version": "0.0.1", 1847 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1848 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1849 | "dev": true 1850 | }, 1851 | "concat-stream": { 1852 | "version": "1.6.2", 1853 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 1854 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 1855 | "requires": { 1856 | "buffer-from": "^1.0.0", 1857 | "inherits": "^2.0.3", 1858 | "readable-stream": "^2.2.2", 1859 | "typedarray": "^0.0.6" 1860 | } 1861 | }, 1862 | "content-disposition": { 1863 | "version": "0.5.4", 1864 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 1865 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 1866 | "requires": { 1867 | "safe-buffer": "5.2.1" 1868 | } 1869 | }, 1870 | "content-type": { 1871 | "version": "1.0.5", 1872 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 1873 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==" 1874 | }, 1875 | "cookie": { 1876 | "version": "0.5.0", 1877 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 1878 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==" 1879 | }, 1880 | "cookie-signature": { 1881 | "version": "1.0.6", 1882 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 1883 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 1884 | }, 1885 | "core-js": { 1886 | "version": "3.33.0", 1887 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.33.0.tgz", 1888 | "integrity": "sha512-HoZr92+ZjFEKar5HS6MC776gYslNOKHt75mEBKWKnPeFDpZ6nH5OeF3S6HFT1mUAUZKrzkez05VboaX8myjSuw==" 1889 | }, 1890 | "core-util-is": { 1891 | "version": "1.0.3", 1892 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 1893 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" 1894 | }, 1895 | "cors": { 1896 | "version": "2.8.5", 1897 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 1898 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 1899 | "requires": { 1900 | "object-assign": "^4", 1901 | "vary": "^1" 1902 | } 1903 | }, 1904 | "debug": { 1905 | "version": "2.6.9", 1906 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1907 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1908 | "requires": { 1909 | "ms": "2.0.0" 1910 | } 1911 | }, 1912 | "depd": { 1913 | "version": "2.0.0", 1914 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 1915 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 1916 | }, 1917 | "destroy": { 1918 | "version": "1.2.0", 1919 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 1920 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" 1921 | }, 1922 | "dotenv": { 1923 | "version": "16.3.1", 1924 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.3.1.tgz", 1925 | "integrity": "sha512-IPzF4w4/Rd94bA9imS68tZBaYyBWSCE47V1RGuMrB94iyTOIEwRmVL2x/4An+6mETpLrKJ5hQkB8W4kFAadeIQ==" 1926 | }, 1927 | "ee-first": { 1928 | "version": "1.1.1", 1929 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 1930 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 1931 | }, 1932 | "encodeurl": { 1933 | "version": "1.0.2", 1934 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 1935 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" 1936 | }, 1937 | "escape-html": { 1938 | "version": "1.0.3", 1939 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 1940 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 1941 | }, 1942 | "etag": { 1943 | "version": "1.8.1", 1944 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1945 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==" 1946 | }, 1947 | "express": { 1948 | "version": "4.18.2", 1949 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 1950 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 1951 | "requires": { 1952 | "accepts": "~1.3.8", 1953 | "array-flatten": "1.1.1", 1954 | "body-parser": "1.20.1", 1955 | "content-disposition": "0.5.4", 1956 | "content-type": "~1.0.4", 1957 | "cookie": "0.5.0", 1958 | "cookie-signature": "1.0.6", 1959 | "debug": "2.6.9", 1960 | "depd": "2.0.0", 1961 | "encodeurl": "~1.0.2", 1962 | "escape-html": "~1.0.3", 1963 | "etag": "~1.8.1", 1964 | "finalhandler": "1.2.0", 1965 | "fresh": "0.5.2", 1966 | "http-errors": "2.0.0", 1967 | "merge-descriptors": "1.0.1", 1968 | "methods": "~1.1.2", 1969 | "on-finished": "2.4.1", 1970 | "parseurl": "~1.3.3", 1971 | "path-to-regexp": "0.1.7", 1972 | "proxy-addr": "~2.0.7", 1973 | "qs": "6.11.0", 1974 | "range-parser": "~1.2.1", 1975 | "safe-buffer": "5.2.1", 1976 | "send": "0.18.0", 1977 | "serve-static": "1.15.0", 1978 | "setprototypeof": "1.2.0", 1979 | "statuses": "2.0.1", 1980 | "type-is": "~1.6.18", 1981 | "utils-merge": "1.0.1", 1982 | "vary": "~1.1.2" 1983 | } 1984 | }, 1985 | "fill-range": { 1986 | "version": "7.0.1", 1987 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1988 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1989 | "dev": true, 1990 | "requires": { 1991 | "to-regex-range": "^5.0.1" 1992 | } 1993 | }, 1994 | "finalhandler": { 1995 | "version": "1.2.0", 1996 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 1997 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 1998 | "requires": { 1999 | "debug": "2.6.9", 2000 | "encodeurl": "~1.0.2", 2001 | "escape-html": "~1.0.3", 2002 | "on-finished": "2.4.1", 2003 | "parseurl": "~1.3.3", 2004 | "statuses": "2.0.1", 2005 | "unpipe": "~1.0.0" 2006 | } 2007 | }, 2008 | "forwarded": { 2009 | "version": "0.2.0", 2010 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 2011 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 2012 | }, 2013 | "fresh": { 2014 | "version": "0.5.2", 2015 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 2016 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" 2017 | }, 2018 | "fsevents": { 2019 | "version": "2.3.3", 2020 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2021 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2022 | "dev": true, 2023 | "optional": true 2024 | }, 2025 | "function-bind": { 2026 | "version": "1.1.1", 2027 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2028 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2029 | }, 2030 | "get-intrinsic": { 2031 | "version": "1.2.1", 2032 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 2033 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 2034 | "requires": { 2035 | "function-bind": "^1.1.1", 2036 | "has": "^1.0.3", 2037 | "has-proto": "^1.0.1", 2038 | "has-symbols": "^1.0.3" 2039 | } 2040 | }, 2041 | "glob-parent": { 2042 | "version": "5.1.2", 2043 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2044 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2045 | "dev": true, 2046 | "requires": { 2047 | "is-glob": "^4.0.1" 2048 | } 2049 | }, 2050 | "has": { 2051 | "version": "1.0.4", 2052 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.4.tgz", 2053 | "integrity": "sha512-qdSAmqLF6209RFj4VVItywPMbm3vWylknmB3nvNiUIs72xAimcM8nVYxYr7ncvZq5qzk9MKIZR8ijqD/1QuYjQ==" 2054 | }, 2055 | "has-flag": { 2056 | "version": "3.0.0", 2057 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2058 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2059 | "dev": true 2060 | }, 2061 | "has-proto": { 2062 | "version": "1.0.1", 2063 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 2064 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==" 2065 | }, 2066 | "has-symbols": { 2067 | "version": "1.0.3", 2068 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2069 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 2070 | }, 2071 | "http-errors": { 2072 | "version": "2.0.0", 2073 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 2074 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 2075 | "requires": { 2076 | "depd": "2.0.0", 2077 | "inherits": "2.0.4", 2078 | "setprototypeof": "1.2.0", 2079 | "statuses": "2.0.1", 2080 | "toidentifier": "1.0.1" 2081 | } 2082 | }, 2083 | "iconv-lite": { 2084 | "version": "0.4.24", 2085 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2086 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2087 | "requires": { 2088 | "safer-buffer": ">= 2.1.2 < 3" 2089 | } 2090 | }, 2091 | "ignore-by-default": { 2092 | "version": "1.0.1", 2093 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 2094 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", 2095 | "dev": true 2096 | }, 2097 | "inherits": { 2098 | "version": "2.0.4", 2099 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2100 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2101 | }, 2102 | "ip": { 2103 | "version": "2.0.0", 2104 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 2105 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 2106 | }, 2107 | "ipaddr.js": { 2108 | "version": "1.9.1", 2109 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 2110 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 2111 | }, 2112 | "is-binary-path": { 2113 | "version": "2.1.0", 2114 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2115 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2116 | "dev": true, 2117 | "requires": { 2118 | "binary-extensions": "^2.0.0" 2119 | } 2120 | }, 2121 | "is-extglob": { 2122 | "version": "2.1.1", 2123 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2124 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2125 | "dev": true 2126 | }, 2127 | "is-glob": { 2128 | "version": "4.0.3", 2129 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2130 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2131 | "dev": true, 2132 | "requires": { 2133 | "is-extglob": "^2.1.1" 2134 | } 2135 | }, 2136 | "is-number": { 2137 | "version": "7.0.0", 2138 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2139 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2140 | "dev": true 2141 | }, 2142 | "isarray": { 2143 | "version": "1.0.0", 2144 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2145 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" 2146 | }, 2147 | "joi": { 2148 | "version": "17.11.0", 2149 | "resolved": "https://registry.npmjs.org/joi/-/joi-17.11.0.tgz", 2150 | "integrity": "sha512-NgB+lZLNoqISVy1rZocE9PZI36bL/77ie924Ri43yEvi9GUUMPeyVIr8KdFTMUlby1p0PBYMk9spIxEUQYqrJQ==", 2151 | "requires": { 2152 | "@hapi/hoek": "^9.0.0", 2153 | "@hapi/topo": "^5.0.0", 2154 | "@sideway/address": "^4.1.3", 2155 | "@sideway/formula": "^3.0.1", 2156 | "@sideway/pinpoint": "^2.0.0" 2157 | } 2158 | }, 2159 | "kareem": { 2160 | "version": "2.5.1", 2161 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.5.1.tgz", 2162 | "integrity": "sha512-7jFxRVm+jD+rkq3kY0iZDJfsO2/t4BBPeEb2qKn2lR/9KhuksYk5hxzfRYWMPV8P/x2d0kHD306YyWLzjjH+uA==" 2163 | }, 2164 | "lodash": { 2165 | "version": "4.17.21", 2166 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2167 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 2168 | }, 2169 | "lru-cache": { 2170 | "version": "6.0.0", 2171 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2172 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2173 | "dev": true, 2174 | "requires": { 2175 | "yallist": "^4.0.0" 2176 | } 2177 | }, 2178 | "media-typer": { 2179 | "version": "0.3.0", 2180 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2181 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" 2182 | }, 2183 | "memory-pager": { 2184 | "version": "1.5.0", 2185 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 2186 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 2187 | "optional": true 2188 | }, 2189 | "merge-descriptors": { 2190 | "version": "1.0.1", 2191 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 2192 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 2193 | }, 2194 | "methods": { 2195 | "version": "1.1.2", 2196 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2197 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==" 2198 | }, 2199 | "mime": { 2200 | "version": "1.6.0", 2201 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2202 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 2203 | }, 2204 | "mime-db": { 2205 | "version": "1.52.0", 2206 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2207 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 2208 | }, 2209 | "mime-types": { 2210 | "version": "2.1.35", 2211 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2212 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2213 | "requires": { 2214 | "mime-db": "1.52.0" 2215 | } 2216 | }, 2217 | "minimatch": { 2218 | "version": "3.1.2", 2219 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2220 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2221 | "dev": true, 2222 | "requires": { 2223 | "brace-expansion": "^1.1.7" 2224 | } 2225 | }, 2226 | "minimist": { 2227 | "version": "1.2.8", 2228 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2229 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==" 2230 | }, 2231 | "mkdirp": { 2232 | "version": "0.5.6", 2233 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 2234 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 2235 | "requires": { 2236 | "minimist": "^1.2.6" 2237 | } 2238 | }, 2239 | "mongodb": { 2240 | "version": "5.9.0", 2241 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-5.9.0.tgz", 2242 | "integrity": "sha512-g+GCMHN1CoRUA+wb1Agv0TI4YTSiWr42B5ulkiAfLLHitGK1R+PkSAf3Lr5rPZwi/3F04LiaZEW0Kxro9Fi2TA==", 2243 | "requires": { 2244 | "@mongodb-js/saslprep": "^1.1.0", 2245 | "bson": "^5.5.0", 2246 | "mongodb-connection-string-url": "^2.6.0", 2247 | "socks": "^2.7.1" 2248 | } 2249 | }, 2250 | "mongodb-connection-string-url": { 2251 | "version": "2.6.0", 2252 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz", 2253 | "integrity": "sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ==", 2254 | "requires": { 2255 | "@types/whatwg-url": "^8.2.1", 2256 | "whatwg-url": "^11.0.0" 2257 | } 2258 | }, 2259 | "mongoose": { 2260 | "version": "7.6.0", 2261 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-7.6.0.tgz", 2262 | "integrity": "sha512-ztQ12rm0BQN5i7LB6xhWX4l9a9w2aa3jEwa/mM2vAutYJRyAwOzcusvKJBULMzFHyUDBOVW15grisexypgMIWA==", 2263 | "requires": { 2264 | "bson": "^5.4.0", 2265 | "kareem": "2.5.1", 2266 | "mongodb": "5.9.0", 2267 | "mpath": "0.9.0", 2268 | "mquery": "5.0.0", 2269 | "ms": "2.1.3", 2270 | "sift": "16.0.1" 2271 | }, 2272 | "dependencies": { 2273 | "ms": { 2274 | "version": "2.1.3", 2275 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2276 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2277 | } 2278 | } 2279 | }, 2280 | "morgan": { 2281 | "version": "1.10.0", 2282 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz", 2283 | "integrity": "sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==", 2284 | "requires": { 2285 | "basic-auth": "~2.0.1", 2286 | "debug": "2.6.9", 2287 | "depd": "~2.0.0", 2288 | "on-finished": "~2.3.0", 2289 | "on-headers": "~1.0.2" 2290 | }, 2291 | "dependencies": { 2292 | "on-finished": { 2293 | "version": "2.3.0", 2294 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2295 | "integrity": "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==", 2296 | "requires": { 2297 | "ee-first": "1.1.1" 2298 | } 2299 | } 2300 | } 2301 | }, 2302 | "mpath": { 2303 | "version": "0.9.0", 2304 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 2305 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==" 2306 | }, 2307 | "mquery": { 2308 | "version": "5.0.0", 2309 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 2310 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 2311 | "requires": { 2312 | "debug": "4.x" 2313 | }, 2314 | "dependencies": { 2315 | "debug": { 2316 | "version": "4.3.4", 2317 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2318 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2319 | "requires": { 2320 | "ms": "2.1.2" 2321 | } 2322 | }, 2323 | "ms": { 2324 | "version": "2.1.2", 2325 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2326 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2327 | } 2328 | } 2329 | }, 2330 | "ms": { 2331 | "version": "2.0.0", 2332 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2333 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 2334 | }, 2335 | "multer": { 2336 | "version": "1.4.5-lts.1", 2337 | "resolved": "https://registry.npmjs.org/multer/-/multer-1.4.5-lts.1.tgz", 2338 | "integrity": "sha512-ywPWvcDMeH+z9gQq5qYHCCy+ethsk4goepZ45GLD63fOu0YcNecQxi64nDs3qluZB+murG3/D4dJ7+dGctcCQQ==", 2339 | "requires": { 2340 | "append-field": "^1.0.0", 2341 | "busboy": "^1.0.0", 2342 | "concat-stream": "^1.5.2", 2343 | "mkdirp": "^0.5.4", 2344 | "object-assign": "^4.1.1", 2345 | "type-is": "^1.6.4", 2346 | "xtend": "^4.0.0" 2347 | } 2348 | }, 2349 | "negotiator": { 2350 | "version": "0.6.3", 2351 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 2352 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 2353 | }, 2354 | "nodemon": { 2355 | "version": "3.0.1", 2356 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.0.1.tgz", 2357 | "integrity": "sha512-g9AZ7HmkhQkqXkRc20w+ZfQ73cHLbE8hnPbtaFbFtCumZsjyMhKk9LajQ07U5Ux28lvFjZ5X7HvWR1xzU8jHVw==", 2358 | "dev": true, 2359 | "requires": { 2360 | "chokidar": "^3.5.2", 2361 | "debug": "^3.2.7", 2362 | "ignore-by-default": "^1.0.1", 2363 | "minimatch": "^3.1.2", 2364 | "pstree.remy": "^1.1.8", 2365 | "semver": "^7.5.3", 2366 | "simple-update-notifier": "^2.0.0", 2367 | "supports-color": "^5.5.0", 2368 | "touch": "^3.1.0", 2369 | "undefsafe": "^2.0.5" 2370 | }, 2371 | "dependencies": { 2372 | "debug": { 2373 | "version": "3.2.7", 2374 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 2375 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 2376 | "dev": true, 2377 | "requires": { 2378 | "ms": "^2.1.1" 2379 | } 2380 | }, 2381 | "ms": { 2382 | "version": "2.1.3", 2383 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2384 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2385 | "dev": true 2386 | } 2387 | } 2388 | }, 2389 | "nopt": { 2390 | "version": "1.0.10", 2391 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 2392 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 2393 | "dev": true, 2394 | "requires": { 2395 | "abbrev": "1" 2396 | } 2397 | }, 2398 | "normalize-path": { 2399 | "version": "3.0.0", 2400 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2401 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2402 | "dev": true 2403 | }, 2404 | "object-assign": { 2405 | "version": "4.1.1", 2406 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2407 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==" 2408 | }, 2409 | "object-inspect": { 2410 | "version": "1.12.3", 2411 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 2412 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==" 2413 | }, 2414 | "on-finished": { 2415 | "version": "2.4.1", 2416 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 2417 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 2418 | "requires": { 2419 | "ee-first": "1.1.1" 2420 | } 2421 | }, 2422 | "on-headers": { 2423 | "version": "1.0.2", 2424 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 2425 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" 2426 | }, 2427 | "parseurl": { 2428 | "version": "1.3.3", 2429 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2430 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2431 | }, 2432 | "path-to-regexp": { 2433 | "version": "0.1.7", 2434 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2435 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 2436 | }, 2437 | "picomatch": { 2438 | "version": "2.3.1", 2439 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2440 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2441 | "dev": true 2442 | }, 2443 | "prettier": { 2444 | "version": "3.0.3", 2445 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.0.3.tgz", 2446 | "integrity": "sha512-L/4pUDMxcNa8R/EthV08Zt42WBO4h1rarVtK0K+QJG0X187OLo7l699jWw0GKuwzkPQ//jMFA/8Xm6Fh3J/DAg==", 2447 | "dev": true 2448 | }, 2449 | "process-nextick-args": { 2450 | "version": "2.0.1", 2451 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2452 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 2453 | }, 2454 | "proxy-addr": { 2455 | "version": "2.0.7", 2456 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2457 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2458 | "requires": { 2459 | "forwarded": "0.2.0", 2460 | "ipaddr.js": "1.9.1" 2461 | } 2462 | }, 2463 | "pstree.remy": { 2464 | "version": "1.1.8", 2465 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 2466 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 2467 | "dev": true 2468 | }, 2469 | "punycode": { 2470 | "version": "2.3.0", 2471 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 2472 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==" 2473 | }, 2474 | "q": { 2475 | "version": "1.5.1", 2476 | "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", 2477 | "integrity": "sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw==" 2478 | }, 2479 | "qs": { 2480 | "version": "6.11.0", 2481 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 2482 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 2483 | "requires": { 2484 | "side-channel": "^1.0.4" 2485 | } 2486 | }, 2487 | "randombytes": { 2488 | "version": "2.0.3", 2489 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.0.3.tgz", 2490 | "integrity": "sha512-lDVjxQQFoCG1jcrP06LNo2lbWp4QTShEXnhActFBwYuHprllQV6VUpwreApsYqCgD+N1mHoqJ/BI/4eV4R2GYg==" 2491 | }, 2492 | "randomstring": { 2493 | "version": "1.3.0", 2494 | "resolved": "https://registry.npmjs.org/randomstring/-/randomstring-1.3.0.tgz", 2495 | "integrity": "sha512-gY7aQ4i1BgwZ8I1Op4YseITAyiDiajeZOPQUbIq9TPGPhUm5FX59izIaOpmKbME1nmnEiABf28d9K2VSii6BBg==", 2496 | "requires": { 2497 | "randombytes": "2.0.3" 2498 | } 2499 | }, 2500 | "range-parser": { 2501 | "version": "1.2.1", 2502 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2503 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 2504 | }, 2505 | "raw-body": { 2506 | "version": "2.5.1", 2507 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 2508 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 2509 | "requires": { 2510 | "bytes": "3.1.2", 2511 | "http-errors": "2.0.0", 2512 | "iconv-lite": "0.4.24", 2513 | "unpipe": "1.0.0" 2514 | } 2515 | }, 2516 | "readable-stream": { 2517 | "version": "2.3.8", 2518 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 2519 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 2520 | "requires": { 2521 | "core-util-is": "~1.0.0", 2522 | "inherits": "~2.0.3", 2523 | "isarray": "~1.0.0", 2524 | "process-nextick-args": "~2.0.0", 2525 | "safe-buffer": "~5.1.1", 2526 | "string_decoder": "~1.1.1", 2527 | "util-deprecate": "~1.0.1" 2528 | }, 2529 | "dependencies": { 2530 | "safe-buffer": { 2531 | "version": "5.1.2", 2532 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2533 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2534 | } 2535 | } 2536 | }, 2537 | "readdirp": { 2538 | "version": "3.6.0", 2539 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2540 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2541 | "dev": true, 2542 | "requires": { 2543 | "picomatch": "^2.2.1" 2544 | } 2545 | }, 2546 | "safe-buffer": { 2547 | "version": "5.2.1", 2548 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2549 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2550 | }, 2551 | "safer-buffer": { 2552 | "version": "2.1.2", 2553 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2554 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2555 | }, 2556 | "semver": { 2557 | "version": "7.5.4", 2558 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 2559 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 2560 | "dev": true, 2561 | "requires": { 2562 | "lru-cache": "^6.0.0" 2563 | } 2564 | }, 2565 | "send": { 2566 | "version": "0.18.0", 2567 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 2568 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 2569 | "requires": { 2570 | "debug": "2.6.9", 2571 | "depd": "2.0.0", 2572 | "destroy": "1.2.0", 2573 | "encodeurl": "~1.0.2", 2574 | "escape-html": "~1.0.3", 2575 | "etag": "~1.8.1", 2576 | "fresh": "0.5.2", 2577 | "http-errors": "2.0.0", 2578 | "mime": "1.6.0", 2579 | "ms": "2.1.3", 2580 | "on-finished": "2.4.1", 2581 | "range-parser": "~1.2.1", 2582 | "statuses": "2.0.1" 2583 | }, 2584 | "dependencies": { 2585 | "ms": { 2586 | "version": "2.1.3", 2587 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2588 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2589 | } 2590 | } 2591 | }, 2592 | "serve-static": { 2593 | "version": "1.15.0", 2594 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 2595 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 2596 | "requires": { 2597 | "encodeurl": "~1.0.2", 2598 | "escape-html": "~1.0.3", 2599 | "parseurl": "~1.3.3", 2600 | "send": "0.18.0" 2601 | } 2602 | }, 2603 | "setprototypeof": { 2604 | "version": "1.2.0", 2605 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 2606 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 2607 | }, 2608 | "side-channel": { 2609 | "version": "1.0.4", 2610 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 2611 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 2612 | "requires": { 2613 | "call-bind": "^1.0.0", 2614 | "get-intrinsic": "^1.0.2", 2615 | "object-inspect": "^1.9.0" 2616 | } 2617 | }, 2618 | "sift": { 2619 | "version": "16.0.1", 2620 | "resolved": "https://registry.npmjs.org/sift/-/sift-16.0.1.tgz", 2621 | "integrity": "sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ==" 2622 | }, 2623 | "simple-update-notifier": { 2624 | "version": "2.0.0", 2625 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", 2626 | "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", 2627 | "dev": true, 2628 | "requires": { 2629 | "semver": "^7.5.3" 2630 | } 2631 | }, 2632 | "smart-buffer": { 2633 | "version": "4.2.0", 2634 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 2635 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" 2636 | }, 2637 | "socks": { 2638 | "version": "2.7.1", 2639 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 2640 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 2641 | "requires": { 2642 | "ip": "^2.0.0", 2643 | "smart-buffer": "^4.2.0" 2644 | } 2645 | }, 2646 | "sparse-bitfield": { 2647 | "version": "3.0.3", 2648 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 2649 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 2650 | "optional": true, 2651 | "requires": { 2652 | "memory-pager": "^1.0.2" 2653 | } 2654 | }, 2655 | "statuses": { 2656 | "version": "2.0.1", 2657 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 2658 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" 2659 | }, 2660 | "streamsearch": { 2661 | "version": "1.1.0", 2662 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 2663 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==" 2664 | }, 2665 | "string_decoder": { 2666 | "version": "1.1.1", 2667 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2668 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2669 | "requires": { 2670 | "safe-buffer": "~5.1.0" 2671 | }, 2672 | "dependencies": { 2673 | "safe-buffer": { 2674 | "version": "5.1.2", 2675 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2676 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2677 | } 2678 | } 2679 | }, 2680 | "supports-color": { 2681 | "version": "5.5.0", 2682 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2683 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2684 | "dev": true, 2685 | "requires": { 2686 | "has-flag": "^3.0.0" 2687 | } 2688 | }, 2689 | "to-regex-range": { 2690 | "version": "5.0.1", 2691 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2692 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2693 | "dev": true, 2694 | "requires": { 2695 | "is-number": "^7.0.0" 2696 | } 2697 | }, 2698 | "toidentifier": { 2699 | "version": "1.0.1", 2700 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 2701 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 2702 | }, 2703 | "touch": { 2704 | "version": "3.1.0", 2705 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2706 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2707 | "dev": true, 2708 | "requires": { 2709 | "nopt": "~1.0.10" 2710 | } 2711 | }, 2712 | "tr46": { 2713 | "version": "3.0.0", 2714 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 2715 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 2716 | "requires": { 2717 | "punycode": "^2.1.1" 2718 | } 2719 | }, 2720 | "type-is": { 2721 | "version": "1.6.18", 2722 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2723 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2724 | "requires": { 2725 | "media-typer": "0.3.0", 2726 | "mime-types": "~2.1.24" 2727 | } 2728 | }, 2729 | "typedarray": { 2730 | "version": "0.0.6", 2731 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 2732 | "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==" 2733 | }, 2734 | "undefsafe": { 2735 | "version": "2.0.5", 2736 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 2737 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 2738 | "dev": true 2739 | }, 2740 | "unpipe": { 2741 | "version": "1.0.0", 2742 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2743 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==" 2744 | }, 2745 | "util-deprecate": { 2746 | "version": "1.0.2", 2747 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2748 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 2749 | }, 2750 | "utils-merge": { 2751 | "version": "1.0.1", 2752 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2753 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==" 2754 | }, 2755 | "vary": { 2756 | "version": "1.1.2", 2757 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2758 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==" 2759 | }, 2760 | "webidl-conversions": { 2761 | "version": "7.0.0", 2762 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 2763 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==" 2764 | }, 2765 | "whatwg-url": { 2766 | "version": "11.0.0", 2767 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 2768 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 2769 | "requires": { 2770 | "tr46": "^3.0.0", 2771 | "webidl-conversions": "^7.0.0" 2772 | } 2773 | }, 2774 | "xtend": { 2775 | "version": "4.0.2", 2776 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2777 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" 2778 | }, 2779 | "yallist": { 2780 | "version": "4.0.0", 2781 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2782 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2783 | "dev": true 2784 | } 2785 | } 2786 | } 2787 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "task-be", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "node index.js", 8 | "start:dev": "nodemon index.js", 9 | "migrate": "npx sequelize db:migrate", 10 | "test": "echo \"Error: no test specified\" && exit 1" 11 | }, 12 | "author": "", 13 | "license": "ISC", 14 | "dependencies": { 15 | "cloudinary": "^1.41.0", 16 | "colors": "^1.4.0", 17 | "cors": "^2.8.5", 18 | "dotenv": "^16.3.1", 19 | "express": "^4.18.2", 20 | "joi": "^17.11.0", 21 | "mongoose": "^7.6.0", 22 | "morgan": "^1.10.0", 23 | "multer": "^1.4.5-lts.1", 24 | "randomstring": "^1.3.0" 25 | }, 26 | "devDependencies": { 27 | "@types/mongoose": "^5.11.97", 28 | "nodemon": "^3.0.1", 29 | "prettier": "^3.0.3" 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /src/app.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const morgan = require('morgan'); 3 | const cors = require('cors'); 4 | 5 | require('./connections/db'); 6 | 7 | const app = express(); 8 | 9 | app.use( 10 | morgan( 11 | ':date[iso] :method :url :status :res[content-length] - :response-time ms' 12 | ) 13 | ); 14 | 15 | app.use(cors()); 16 | app.use(express.json()); 17 | app.use(express.urlencoded({ extended: true })); 18 | 19 | const appRoutes = require('./routes'); 20 | app.use(appRoutes); 21 | 22 | module.exports = app; 23 | -------------------------------------------------------------------------------- /src/connections/db.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const { DB_URI } = require('../../config'); 3 | const logger = require('../utils/logger'); 4 | 5 | const connectToDB = async () => { 6 | try { 7 | await mongoose.connect(DB_URI); 8 | logger.success('Connected successfully to DB!'); 9 | } catch (err) { 10 | logger.error('Cannot connect to DB!'); 11 | } 12 | }; 13 | 14 | connectToDB().then(() => {}); 15 | -------------------------------------------------------------------------------- /src/controllers/users.js: -------------------------------------------------------------------------------- 1 | const randomstring = require('randomstring'); 2 | const cloudinary = require('cloudinary').v2; 3 | const path = require('path'); 4 | 5 | const { 6 | SERVER_ERROR_500, 7 | BAD_REQUEST_400, 8 | NOT_FOUND_404 9 | } = require('../utils/httpStatus'); 10 | const User = require('../models/user'); 11 | const { addProfileInfoValidator } = require('../joiValidators/user'); 12 | 13 | const addProfileInfo = async (req, res, next) => { 14 | try { 15 | const { error, value } = addProfileInfoValidator(req.body); 16 | if (error) { 17 | return next({ 18 | error: `${error.details[0].message}.`, 19 | code: BAD_REQUEST_400 20 | }); 21 | } 22 | const { userId, firstName, lastName, email, profileImgURL } = value; 23 | let newUser; 24 | if (userId) { 25 | newUser = await User.findOneAndUpdate( 26 | { _id: userId }, 27 | { 28 | firstName, 29 | lastName, 30 | email, 31 | profileImgURL 32 | }, 33 | { 34 | new: true 35 | } 36 | ); 37 | if (!newUser) { 38 | return next({ 39 | error: `User Not Found.`, 40 | code: NOT_FOUND_404 41 | }); 42 | } 43 | } else { 44 | newUser = await User.create({ 45 | firstName, 46 | lastName, 47 | email, 48 | profileImgURL 49 | }); 50 | } 51 | res.response({ 52 | id: newUser.id, 53 | firstName: newUser.firstName, 54 | lastName: newUser.lastName, 55 | email: newUser.email 56 | }); 57 | next(); 58 | } catch (err) { 59 | console.log(err); 60 | next({ 61 | code: SERVER_ERROR_500, 62 | error: 'Internal Server Error!' 63 | }); 64 | } 65 | }; 66 | 67 | const addLinks = async (req, res, next) => { 68 | try { 69 | const { userId, links } = req.body; 70 | let newUser = null; 71 | if (!userId && !links) { 72 | return next({ 73 | error: 'No Data Provided!', 74 | code: BAD_REQUEST_400 75 | }); 76 | } 77 | if (userId) { 78 | newUser = await User.findById(userId); 79 | if (!newUser) { 80 | return next({ 81 | error: 'User Not Found!', 82 | code: NOT_FOUND_404 83 | }); 84 | } 85 | if (links) { 86 | const currLinks = newUser.links || {}; 87 | newUser.links = { ...currLinks, ...links }; 88 | await newUser.save(); 89 | } 90 | res.response({ 91 | id: userId, 92 | links: newUser.links || {} 93 | }); 94 | next(); 95 | return; 96 | } 97 | newUser = await User.create({ links }); 98 | res.response({ 99 | id: newUser.id, 100 | links: newUser.links 101 | }); 102 | next(); 103 | } catch (err) { 104 | console.log(err); 105 | next({ 106 | code: SERVER_ERROR_500, 107 | error: 'Internal Server Error!' 108 | }); 109 | } 110 | }; 111 | 112 | const getShareableToken = async (req, res, next) => { 113 | try { 114 | const { userId } = req.query; 115 | if (!userId) { 116 | return next({ 117 | error: 'User Id Not Provided!', 118 | code: BAD_REQUEST_400 119 | }); 120 | } 121 | let user = await User.findById(userId); 122 | if (!user) { 123 | return next({ 124 | error: 'User Not Found!', 125 | code: NOT_FOUND_404 126 | }); 127 | } 128 | let shareableToken = user.shareableToken; 129 | if (!shareableToken) { 130 | shareableToken = randomstring.generate(); 131 | await User.updateOne( 132 | { 133 | _id: userId 134 | }, 135 | { shareableToken: shareableToken } 136 | ); 137 | } 138 | res.response({ 139 | token: shareableToken 140 | }); 141 | next(); 142 | } catch (err) { 143 | console.log(err); 144 | next({ 145 | code: SERVER_ERROR_500, 146 | error: 'Internal Server Error!' 147 | }); 148 | } 149 | }; 150 | 151 | const getUserData = async (req, res, next) => { 152 | try { 153 | const { token } = req.query; 154 | if (!token) { 155 | return next({ 156 | error: 'Token Not Provided!', 157 | code: BAD_REQUEST_400 158 | }); 159 | } 160 | const user = await User.findOne({ shareableToken: token }); 161 | res.response({ 162 | user: user && { 163 | firstName: user.firstName, 164 | lastName: user.lastName, 165 | email: user.email, 166 | links: user.links, 167 | profileImgURL: user.profileImgURL 168 | } 169 | }); 170 | next(); 171 | } catch (err) { 172 | console.log(err); 173 | next({ 174 | code: SERVER_ERROR_500, 175 | error: 'Internal Server Error!' 176 | }); 177 | } 178 | }; 179 | 180 | const uploadProfileImage = async (req, res, next) => { 181 | try { 182 | if (!req.file) 183 | return next({ 184 | error: 'Image Not Provided!', 185 | code: BAD_REQUEST_400 186 | }); 187 | const result = await cloudinary.uploader.upload( 188 | path.join(__dirname, '..', '..', req.file.path) 189 | ); 190 | res.response({ 191 | imgURL: result.secure_url 192 | }); 193 | next(); 194 | } catch (err) { 195 | console.log(err); 196 | next({ 197 | code: SERVER_ERROR_500, 198 | error: 'Internal Server Error!' 199 | }); 200 | } 201 | }; 202 | 203 | module.exports = { 204 | addProfileInfo, 205 | addLinks, 206 | getShareableToken, 207 | getUserData, 208 | uploadProfileImage 209 | }; 210 | -------------------------------------------------------------------------------- /src/joiValidators/user.js: -------------------------------------------------------------------------------- 1 | const Joi = require('joi'); 2 | const { emailRegex } = require('../utils'); 3 | 4 | const addProfileInfoValidator = (data) => { 5 | const schema = Joi.object({ 6 | firstName: Joi.string().required().not().empty(), 7 | lastName: Joi.string().required().not().empty(), 8 | profileImgURL: Joi.string().required().not().empty(), 9 | email: Joi.string().required().pattern(emailRegex).not().empty().messages({ 10 | 'string.pattern.base': '"email" is not valid' 11 | }), 12 | userId: Joi.string().optional() 13 | }); 14 | return schema.validate(data); 15 | }; 16 | 17 | module.exports = { addProfileInfoValidator }; 18 | -------------------------------------------------------------------------------- /src/middlewares/error.js: -------------------------------------------------------------------------------- 1 | // eslint-disable-next-line no-unused-vars 2 | const errorHandler = (err, req, res, next) => { 3 | return res 4 | .status(err.code) 5 | .send({ error: err.error, statusCode: err.code, data: null }); 6 | }; 7 | 8 | module.exports = { 9 | errorHandler 10 | }; 11 | -------------------------------------------------------------------------------- /src/middlewares/response.js: -------------------------------------------------------------------------------- 1 | const { OK_200 } = require('../utils/httpStatus'); 2 | 3 | const afterMiddlewareLoader = (req, res, next) => { 4 | res.response = function (responseData) { 5 | req.responseData = responseData; 6 | }; 7 | next(); 8 | }; 9 | 10 | const responseSender = (req, res) => { 11 | res 12 | .status(OK_200) 13 | .send({ error: null, statusCode: OK_200, data: req.responseData }); 14 | }; 15 | 16 | module.exports = { 17 | afterMiddlewareLoader, 18 | responseSender 19 | }; 20 | -------------------------------------------------------------------------------- /src/models/user.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const { Schema } = require('mongoose'); 3 | const { USER } = require('../utils/modelNames'); 4 | 5 | const userSchema = new Schema({ 6 | firstName: { 7 | type: String 8 | }, 9 | lastName: { 10 | type: String 11 | }, 12 | email: { 13 | type: String 14 | }, 15 | links: { 16 | type: Object 17 | }, 18 | shareableToken: { 19 | type: String 20 | }, 21 | profileImgURL: { 22 | type: String 23 | } 24 | }); 25 | 26 | module.exports = mongoose.model(USER, userSchema); 27 | -------------------------------------------------------------------------------- /src/routes/index.js: -------------------------------------------------------------------------------- 1 | const { OK_200 } = require('../utils/httpStatus'); 2 | const router = require('express').Router(); 3 | 4 | const userRouter = require('./users'); 5 | 6 | router.get('/check-health', (req, res) => { 7 | res.status(OK_200).json({ healthStatus: 'OK' }); 8 | }); 9 | 10 | router.use('/users', userRouter); 11 | 12 | module.exports = router; 13 | -------------------------------------------------------------------------------- /src/routes/users.js: -------------------------------------------------------------------------------- 1 | const router = require('express').Router(); 2 | const multer = require('multer'); 3 | const upload = multer({ dest: 'uploads' }); 4 | const { 5 | afterMiddlewareLoader, 6 | responseSender 7 | } = require('../middlewares/response'); 8 | const { errorHandler } = require('../middlewares/error'); 9 | const { 10 | addProfileInfo, 11 | addLinks, 12 | getShareableToken, 13 | getUserData, 14 | uploadProfileImage 15 | } = require('../controllers/users'); 16 | 17 | router.post( 18 | '/add-profile-info', 19 | afterMiddlewareLoader, 20 | addProfileInfo, 21 | errorHandler, 22 | responseSender 23 | ); 24 | 25 | router.post( 26 | '/add-links', 27 | afterMiddlewareLoader, 28 | addLinks, 29 | errorHandler, 30 | responseSender 31 | ); 32 | 33 | router.get( 34 | '/get-shareable-token', 35 | afterMiddlewareLoader, 36 | getShareableToken, 37 | errorHandler, 38 | responseSender 39 | ); 40 | 41 | router.get( 42 | '/get-user-data', 43 | afterMiddlewareLoader, 44 | getUserData, 45 | errorHandler, 46 | responseSender 47 | ); 48 | 49 | router.post( 50 | '/upload-profile-img', 51 | upload.single('image'), 52 | afterMiddlewareLoader, 53 | uploadProfileImage, 54 | errorHandler, 55 | responseSender 56 | ); 57 | 58 | module.exports = router; 59 | -------------------------------------------------------------------------------- /src/utils/httpStatus.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | OK_200: 200, 3 | CREATED_201: 201, 4 | SERVER_ERROR_500: 500, 5 | NO_CONTENT_204: 204, 6 | NOT_FOUND_404: 404, 7 | BAD_REQUEST_400: 400, 8 | UN_AUTHORIZED_401: 401, 9 | FORBIDDEN_403: 403, 10 | UNPROCESSABLE_ENTITY_422: 422 11 | }; 12 | -------------------------------------------------------------------------------- /src/utils/index.js: -------------------------------------------------------------------------------- 1 | const emailRegex = 2 | /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; 3 | 4 | module.exports = { 5 | emailRegex 6 | }; 7 | -------------------------------------------------------------------------------- /src/utils/logger.js: -------------------------------------------------------------------------------- 1 | const colors = require('colors/safe').bold; 2 | 3 | const log = console.log; 4 | 5 | module.exports = { 6 | warning: (message) => log(colors.yellow(`Warning: ${message}`)), 7 | error: (message) => log(colors.red(`Error: ${message}`)), 8 | info: (message) => log(colors.blue(`Info: ${message}`)), 9 | success: (message) => log(colors.green(`Success: ${message}`)), 10 | log: (message) => log(message) 11 | }; 12 | -------------------------------------------------------------------------------- /src/utils/modelNames.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | USER: 'user', 3 | LINK: 'link' 4 | }; 5 | --------------------------------------------------------------------------------