├── auth-back ├── .gitignore ├── auth │ ├── authenticateToken.js │ ├── sign.js │ ├── validateToken.js │ └── verify.js ├── index.js ├── lib │ ├── getUserInfo.js │ ├── jsonResponse.js │ └── trace.js ├── package-lock.json ├── package.json ├── routes │ ├── login.js │ ├── logout.js │ ├── posts.js │ ├── refreshToken.js │ ├── signup.js │ └── user.js └── schema │ ├── todo.js │ ├── token.js │ └── user.js └── auth-front ├── .eslintrc.cjs ├── .gitignore ├── index.html ├── package-lock.json ├── package.json ├── public └── vite.svg ├── src ├── App.css ├── App.tsx ├── assets │ └── react.svg ├── auth │ ├── AuthProvider.tsx │ ├── authConstants.ts │ └── requestNewAccessToken.ts ├── index.css ├── layout │ ├── DefaultLayout.tsx │ └── PortalLayout.tsx ├── main.tsx ├── routes │ ├── Dashboard.tsx │ ├── Login.tsx │ ├── Profile.tsx │ ├── ProtectedRoute.tsx │ └── Signup.tsx ├── types │ └── types.ts └── vite-env.d.ts ├── tsconfig.json ├── tsconfig.node.json └── vite.config.ts /auth-back/.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | 26 | .env 27 | -------------------------------------------------------------------------------- /auth-back/auth/authenticateToken.js: -------------------------------------------------------------------------------- 1 | const log = require("../lib/trace"); 2 | const validateToken = require("./validateToken"); 3 | const { verifyAccessToken } = require("./verify"); 4 | 5 | function authenticateToken(req, res, next) { 6 | let token = null; 7 | log.info("headers", req.headers); 8 | try { 9 | token = validateToken(req.headers); 10 | // log.info("Token", token); 11 | } catch (error) { 12 | //console.log("Error", error.message); 13 | log.error(error.message); 14 | if (error.message === "Token not provided") { 15 | return res.status(401).json({ error: "Token no proporcionado" }); 16 | } 17 | if (error.message === "Token format invalid") { 18 | return res.status(401).json({ error: "Token mal formado" }); 19 | } 20 | } 21 | 22 | try { 23 | const decoded = verifyAccessToken(token); 24 | req.user = { ...decoded.user }; 25 | next(); 26 | } catch (err) { 27 | console.log("6 Token inválido", token, err); 28 | return res.status(403).json({ error: "Token inválido" }); 29 | } 30 | } 31 | 32 | module.exports = authenticateToken; 33 | -------------------------------------------------------------------------------- /auth-back/auth/sign.js: -------------------------------------------------------------------------------- 1 | const jwt = require("jsonwebtoken"); 2 | require("dotenv").config(); 3 | 4 | function sign(payload, isAccessToken) { 5 | console.log("payload", payload); 6 | return jwt.sign( 7 | payload, 8 | isAccessToken 9 | ? process.env.ACCESS_TOKEN_SECRET 10 | : process.env.REFRESH_TOKEN_SECRET, 11 | { 12 | expiresIn: 3600, 13 | algorithm: "HS256", 14 | } 15 | ); 16 | } 17 | 18 | // Función para generar un token de acceso utilizando jsonwebtoken 19 | function generateAccessToken(user) { 20 | return sign({ user }, true); 21 | } 22 | function generateRefreshToken(user) { 23 | return sign({ user }, false); 24 | } 25 | 26 | module.exports = { generateAccessToken, generateRefreshToken }; 27 | -------------------------------------------------------------------------------- /auth-back/auth/validateToken.js: -------------------------------------------------------------------------------- 1 | function validateToken(header) { 2 | if (!header["authorization"]) { 3 | console.log("3. No hay token", header); 4 | throw new Error("Token not provided"); 5 | //return res.status(401).json({ error: "Token no proporcionado" }); 6 | } 7 | 8 | const [bearer, token] = header["authorization"].split(" "); 9 | 10 | if (bearer !== "Bearer") { 11 | console.log("4. No hay token", token); 12 | throw new Error("Token format invalid"); 13 | //return res.status(401).json({ error: "Token mal formado" }); 14 | } 15 | 16 | return token; 17 | } 18 | 19 | module.exports = validateToken; 20 | -------------------------------------------------------------------------------- /auth-back/auth/verify.js: -------------------------------------------------------------------------------- 1 | const jwt = require("jsonwebtoken"); 2 | require("dotenv").config(); 3 | 4 | function verifyAccessToken(token) { 5 | const decoded = jwt.verify(token, process.env.ACCESS_TOKEN_SECRET); 6 | return decoded; 7 | } 8 | 9 | function verifyRefreshToken(token) { 10 | const decoded = jwt.verify(token, process.env.REFRESH_TOKEN_SECRET); 11 | return decoded; 12 | } 13 | module.exports = { verifyAccessToken, verifyRefreshToken }; 14 | -------------------------------------------------------------------------------- /auth-back/index.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const cors = require("cors"); 3 | const app = express(); 4 | const mongoose = require("mongoose"); 5 | const authenticateToken = require("./auth/authenticateToken"); 6 | const log = require("./lib/trace"); 7 | require("dotenv").config(); 8 | 9 | app.use(express.json()); 10 | app.use(cors()); 11 | 12 | const port = process.env.PORT || 3000; 13 | 14 | main().catch((err) => console.log(err)); 15 | 16 | async function main() { 17 | await mongoose.connect(process.env.DB_CONNECTION_STRING); 18 | 19 | console.log("Conectado a la base de datos"); 20 | } 21 | 22 | app.use("/api/signup", require("./routes/signup")); 23 | app.use("/api/login", require("./routes/login")); 24 | app.use("/api/signout", require("./routes/logout")); 25 | 26 | // Ruta para renovar el token de acceso utilizando el token de actualización 27 | app.use("/api/refresh-token", require("./routes/refreshToken")); 28 | 29 | app.use("/api/posts", authenticateToken, require("./routes/posts")); 30 | // Ruta protegida que requiere autenticación 31 | /* app.get("/api/posts", authenticateToken, (req, res) => { 32 | res.json(posts); 33 | }); */ 34 | /* app.post("/api/posts", authenticateToken, (req, res) => { 35 | if (!req.body.title) { 36 | return res.status(400).json({ error: "Title is required" }); 37 | } 38 | 39 | const post = { 40 | id: posts.length + 1, 41 | title: req.body.title, 42 | completed: false, 43 | }; 44 | 45 | posts.push(post); 46 | 47 | res.json(post); 48 | }); */ 49 | 50 | app.use("/api/user", authenticateToken, require("./routes/user")); 51 | 52 | app.listen(port, () => { 53 | console.log(`Server is up on port ${port}`); 54 | }); 55 | 56 | module.exports = app; 57 | -------------------------------------------------------------------------------- /auth-back/lib/getUserInfo.js: -------------------------------------------------------------------------------- 1 | function getUserInfo(user) { 2 | return { 3 | username: user.username, 4 | name: user.name, 5 | id: user.id || user._id, 6 | }; 7 | } 8 | 9 | module.exports = getUserInfo; 10 | -------------------------------------------------------------------------------- /auth-back/lib/jsonResponse.js: -------------------------------------------------------------------------------- 1 | exports.jsonResponse = function (statuscode, body) { 2 | return { 3 | statuscode, 4 | body: body, 5 | }; 6 | }; 7 | -------------------------------------------------------------------------------- /auth-back/lib/trace.js: -------------------------------------------------------------------------------- 1 | const bunyan = require("bunyan"); 2 | 3 | const log = bunyan.createLogger({ 4 | name: "Todoist", 5 | stream: process.stdout, 6 | }); 7 | 8 | module.exports = log; 9 | -------------------------------------------------------------------------------- /auth-back/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "auth-back", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "auth-back", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "bcrypt": "^5.1.0", 13 | "bunyan": "^1.8.15", 14 | "cors": "^2.8.5", 15 | "dotenv": "^16.0.3", 16 | "express": "^4.18.2", 17 | "jsonwebtoken": "^9.0.0", 18 | "mongoose": "^7.1.1", 19 | "nodemon": "^2.0.22" 20 | } 21 | }, 22 | "node_modules/@mapbox/node-pre-gyp": { 23 | "version": "1.0.10", 24 | "resolved": "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.10.tgz", 25 | "integrity": "sha512-4ySo4CjzStuprMwk35H5pPbkymjv1SF3jGLj6rAHp/xT/RF7TL7bd9CTm1xDY49K2qF7jmR/g7k+SkLETP6opA==", 26 | "dependencies": { 27 | "detect-libc": "^2.0.0", 28 | "https-proxy-agent": "^5.0.0", 29 | "make-dir": "^3.1.0", 30 | "node-fetch": "^2.6.7", 31 | "nopt": "^5.0.0", 32 | "npmlog": "^5.0.1", 33 | "rimraf": "^3.0.2", 34 | "semver": "^7.3.5", 35 | "tar": "^6.1.11" 36 | }, 37 | "bin": { 38 | "node-pre-gyp": "bin/node-pre-gyp" 39 | } 40 | }, 41 | "node_modules/@mapbox/node-pre-gyp/node_modules/nopt": { 42 | "version": "5.0.0", 43 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 44 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 45 | "dependencies": { 46 | "abbrev": "1" 47 | }, 48 | "bin": { 49 | "nopt": "bin/nopt.js" 50 | }, 51 | "engines": { 52 | "node": ">=6" 53 | } 54 | }, 55 | "node_modules/@mapbox/node-pre-gyp/node_modules/semver": { 56 | "version": "7.5.0", 57 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.0.tgz", 58 | "integrity": "sha512-+XC0AD/R7Q2mPSRuy2Id0+CGTZ98+8f+KvwirxOKIEyid+XSx6HbC63p+O4IndTHuX5Z+JxQ0TghCkO5Cg/2HA==", 59 | "dependencies": { 60 | "lru-cache": "^6.0.0" 61 | }, 62 | "bin": { 63 | "semver": "bin/semver.js" 64 | }, 65 | "engines": { 66 | "node": ">=10" 67 | } 68 | }, 69 | "node_modules/@types/node": { 70 | "version": "20.1.3", 71 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.1.3.tgz", 72 | "integrity": "sha512-NP2yfZpgmf2eDRPmgGq+fjGjSwFgYbihA8/gK+ey23qT9RkxsgNTZvGOEpXgzIGqesTYkElELLgtKoMQTys5vA==" 73 | }, 74 | "node_modules/@types/webidl-conversions": { 75 | "version": "7.0.0", 76 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 77 | "integrity": "sha512-xTE1E+YF4aWPJJeUzaZI5DRntlkY3+BCVJi0axFptnjGmAoWxkyREIh/XMrfxVLejwQxMCfDXdICo0VLxThrog==" 78 | }, 79 | "node_modules/@types/whatwg-url": { 80 | "version": "8.2.2", 81 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.2.tgz", 82 | "integrity": "sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA==", 83 | "dependencies": { 84 | "@types/node": "*", 85 | "@types/webidl-conversions": "*" 86 | } 87 | }, 88 | "node_modules/abbrev": { 89 | "version": "1.1.1", 90 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 91 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 92 | }, 93 | "node_modules/accepts": { 94 | "version": "1.3.8", 95 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 96 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 97 | "dependencies": { 98 | "mime-types": "~2.1.34", 99 | "negotiator": "0.6.3" 100 | }, 101 | "engines": { 102 | "node": ">= 0.6" 103 | } 104 | }, 105 | "node_modules/agent-base": { 106 | "version": "6.0.2", 107 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 108 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 109 | "dependencies": { 110 | "debug": "4" 111 | }, 112 | "engines": { 113 | "node": ">= 6.0.0" 114 | } 115 | }, 116 | "node_modules/agent-base/node_modules/debug": { 117 | "version": "4.3.4", 118 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 119 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 120 | "dependencies": { 121 | "ms": "2.1.2" 122 | }, 123 | "engines": { 124 | "node": ">=6.0" 125 | }, 126 | "peerDependenciesMeta": { 127 | "supports-color": { 128 | "optional": true 129 | } 130 | } 131 | }, 132 | "node_modules/agent-base/node_modules/ms": { 133 | "version": "2.1.2", 134 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 135 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 136 | }, 137 | "node_modules/ansi-regex": { 138 | "version": "5.0.1", 139 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 140 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 141 | "engines": { 142 | "node": ">=8" 143 | } 144 | }, 145 | "node_modules/anymatch": { 146 | "version": "3.1.3", 147 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 148 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 149 | "dependencies": { 150 | "normalize-path": "^3.0.0", 151 | "picomatch": "^2.0.4" 152 | }, 153 | "engines": { 154 | "node": ">= 8" 155 | } 156 | }, 157 | "node_modules/aproba": { 158 | "version": "2.0.0", 159 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz", 160 | "integrity": "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==" 161 | }, 162 | "node_modules/are-we-there-yet": { 163 | "version": "2.0.0", 164 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz", 165 | "integrity": "sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw==", 166 | "dependencies": { 167 | "delegates": "^1.0.0", 168 | "readable-stream": "^3.6.0" 169 | }, 170 | "engines": { 171 | "node": ">=10" 172 | } 173 | }, 174 | "node_modules/array-flatten": { 175 | "version": "1.1.1", 176 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 177 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 178 | }, 179 | "node_modules/balanced-match": { 180 | "version": "1.0.2", 181 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 182 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 183 | }, 184 | "node_modules/bcrypt": { 185 | "version": "5.1.0", 186 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.1.0.tgz", 187 | "integrity": "sha512-RHBS7HI5N5tEnGTmtR/pppX0mmDSBpQ4aCBsj7CEQfYXDcO74A8sIBYcJMuCsis2E81zDxeENYhv66oZwLiA+Q==", 188 | "hasInstallScript": true, 189 | "dependencies": { 190 | "@mapbox/node-pre-gyp": "^1.0.10", 191 | "node-addon-api": "^5.0.0" 192 | }, 193 | "engines": { 194 | "node": ">= 10.0.0" 195 | } 196 | }, 197 | "node_modules/binary-extensions": { 198 | "version": "2.2.0", 199 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 200 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 201 | "engines": { 202 | "node": ">=8" 203 | } 204 | }, 205 | "node_modules/body-parser": { 206 | "version": "1.20.1", 207 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 208 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 209 | "dependencies": { 210 | "bytes": "3.1.2", 211 | "content-type": "~1.0.4", 212 | "debug": "2.6.9", 213 | "depd": "2.0.0", 214 | "destroy": "1.2.0", 215 | "http-errors": "2.0.0", 216 | "iconv-lite": "0.4.24", 217 | "on-finished": "2.4.1", 218 | "qs": "6.11.0", 219 | "raw-body": "2.5.1", 220 | "type-is": "~1.6.18", 221 | "unpipe": "1.0.0" 222 | }, 223 | "engines": { 224 | "node": ">= 0.8", 225 | "npm": "1.2.8000 || >= 1.4.16" 226 | } 227 | }, 228 | "node_modules/brace-expansion": { 229 | "version": "1.1.11", 230 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 231 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 232 | "dependencies": { 233 | "balanced-match": "^1.0.0", 234 | "concat-map": "0.0.1" 235 | } 236 | }, 237 | "node_modules/braces": { 238 | "version": "3.0.2", 239 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 240 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 241 | "dependencies": { 242 | "fill-range": "^7.0.1" 243 | }, 244 | "engines": { 245 | "node": ">=8" 246 | } 247 | }, 248 | "node_modules/bson": { 249 | "version": "5.3.0", 250 | "resolved": "https://registry.npmjs.org/bson/-/bson-5.3.0.tgz", 251 | "integrity": "sha512-ukmCZMneMlaC5ebPHXIkP8YJzNl5DC41N5MAIvKDqLggdao342t4McltoJBQfQya/nHBWAcSsYRqlXPoQkTJag==", 252 | "engines": { 253 | "node": ">=14.20.1" 254 | } 255 | }, 256 | "node_modules/buffer-equal-constant-time": { 257 | "version": "1.0.1", 258 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 259 | "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" 260 | }, 261 | "node_modules/bunyan": { 262 | "version": "1.8.15", 263 | "resolved": "https://registry.npmjs.org/bunyan/-/bunyan-1.8.15.tgz", 264 | "integrity": "sha512-0tECWShh6wUysgucJcBAoYegf3JJoZWibxdqhTm7OHPeT42qdjkZ29QCMcKwbgU1kiH+auSIasNRXMLWXafXig==", 265 | "engines": [ 266 | "node >=0.10.0" 267 | ], 268 | "bin": { 269 | "bunyan": "bin/bunyan" 270 | }, 271 | "optionalDependencies": { 272 | "dtrace-provider": "~0.8", 273 | "moment": "^2.19.3", 274 | "mv": "~2", 275 | "safe-json-stringify": "~1" 276 | } 277 | }, 278 | "node_modules/bytes": { 279 | "version": "3.1.2", 280 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 281 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 282 | "engines": { 283 | "node": ">= 0.8" 284 | } 285 | }, 286 | "node_modules/call-bind": { 287 | "version": "1.0.2", 288 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 289 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 290 | "dependencies": { 291 | "function-bind": "^1.1.1", 292 | "get-intrinsic": "^1.0.2" 293 | }, 294 | "funding": { 295 | "url": "https://github.com/sponsors/ljharb" 296 | } 297 | }, 298 | "node_modules/chokidar": { 299 | "version": "3.5.3", 300 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 301 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 302 | "funding": [ 303 | { 304 | "type": "individual", 305 | "url": "https://paulmillr.com/funding/" 306 | } 307 | ], 308 | "dependencies": { 309 | "anymatch": "~3.1.2", 310 | "braces": "~3.0.2", 311 | "glob-parent": "~5.1.2", 312 | "is-binary-path": "~2.1.0", 313 | "is-glob": "~4.0.1", 314 | "normalize-path": "~3.0.0", 315 | "readdirp": "~3.6.0" 316 | }, 317 | "engines": { 318 | "node": ">= 8.10.0" 319 | }, 320 | "optionalDependencies": { 321 | "fsevents": "~2.3.2" 322 | } 323 | }, 324 | "node_modules/chownr": { 325 | "version": "2.0.0", 326 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", 327 | "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", 328 | "engines": { 329 | "node": ">=10" 330 | } 331 | }, 332 | "node_modules/color-support": { 333 | "version": "1.1.3", 334 | "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", 335 | "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==", 336 | "bin": { 337 | "color-support": "bin.js" 338 | } 339 | }, 340 | "node_modules/concat-map": { 341 | "version": "0.0.1", 342 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 343 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" 344 | }, 345 | "node_modules/console-control-strings": { 346 | "version": "1.1.0", 347 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 348 | "integrity": "sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==" 349 | }, 350 | "node_modules/content-disposition": { 351 | "version": "0.5.4", 352 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 353 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 354 | "dependencies": { 355 | "safe-buffer": "5.2.1" 356 | }, 357 | "engines": { 358 | "node": ">= 0.6" 359 | } 360 | }, 361 | "node_modules/content-type": { 362 | "version": "1.0.5", 363 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 364 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 365 | "engines": { 366 | "node": ">= 0.6" 367 | } 368 | }, 369 | "node_modules/cookie": { 370 | "version": "0.5.0", 371 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 372 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 373 | "engines": { 374 | "node": ">= 0.6" 375 | } 376 | }, 377 | "node_modules/cookie-signature": { 378 | "version": "1.0.6", 379 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 380 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 381 | }, 382 | "node_modules/cors": { 383 | "version": "2.8.5", 384 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 385 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 386 | "dependencies": { 387 | "object-assign": "^4", 388 | "vary": "^1" 389 | }, 390 | "engines": { 391 | "node": ">= 0.10" 392 | } 393 | }, 394 | "node_modules/debug": { 395 | "version": "2.6.9", 396 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 397 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 398 | "dependencies": { 399 | "ms": "2.0.0" 400 | } 401 | }, 402 | "node_modules/delegates": { 403 | "version": "1.0.0", 404 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 405 | "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==" 406 | }, 407 | "node_modules/depd": { 408 | "version": "2.0.0", 409 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 410 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 411 | "engines": { 412 | "node": ">= 0.8" 413 | } 414 | }, 415 | "node_modules/destroy": { 416 | "version": "1.2.0", 417 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 418 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 419 | "engines": { 420 | "node": ">= 0.8", 421 | "npm": "1.2.8000 || >= 1.4.16" 422 | } 423 | }, 424 | "node_modules/detect-libc": { 425 | "version": "2.0.1", 426 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.1.tgz", 427 | "integrity": "sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w==", 428 | "engines": { 429 | "node": ">=8" 430 | } 431 | }, 432 | "node_modules/dotenv": { 433 | "version": "16.0.3", 434 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 435 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==", 436 | "engines": { 437 | "node": ">=12" 438 | } 439 | }, 440 | "node_modules/dtrace-provider": { 441 | "version": "0.8.8", 442 | "resolved": "https://registry.npmjs.org/dtrace-provider/-/dtrace-provider-0.8.8.tgz", 443 | "integrity": "sha512-b7Z7cNtHPhH9EJhNNbbeqTcXB8LGFFZhq1PGgEvpeHlzd36bhbdTWoE/Ba/YguqpBSlAPKnARWhVlhunCMwfxg==", 444 | "hasInstallScript": true, 445 | "optional": true, 446 | "dependencies": { 447 | "nan": "^2.14.0" 448 | }, 449 | "engines": { 450 | "node": ">=0.10" 451 | } 452 | }, 453 | "node_modules/ecdsa-sig-formatter": { 454 | "version": "1.0.11", 455 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 456 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 457 | "dependencies": { 458 | "safe-buffer": "^5.0.1" 459 | } 460 | }, 461 | "node_modules/ee-first": { 462 | "version": "1.1.1", 463 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 464 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 465 | }, 466 | "node_modules/emoji-regex": { 467 | "version": "8.0.0", 468 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 469 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 470 | }, 471 | "node_modules/encodeurl": { 472 | "version": "1.0.2", 473 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 474 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 475 | "engines": { 476 | "node": ">= 0.8" 477 | } 478 | }, 479 | "node_modules/escape-html": { 480 | "version": "1.0.3", 481 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 482 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 483 | }, 484 | "node_modules/etag": { 485 | "version": "1.8.1", 486 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 487 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 488 | "engines": { 489 | "node": ">= 0.6" 490 | } 491 | }, 492 | "node_modules/express": { 493 | "version": "4.18.2", 494 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 495 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 496 | "dependencies": { 497 | "accepts": "~1.3.8", 498 | "array-flatten": "1.1.1", 499 | "body-parser": "1.20.1", 500 | "content-disposition": "0.5.4", 501 | "content-type": "~1.0.4", 502 | "cookie": "0.5.0", 503 | "cookie-signature": "1.0.6", 504 | "debug": "2.6.9", 505 | "depd": "2.0.0", 506 | "encodeurl": "~1.0.2", 507 | "escape-html": "~1.0.3", 508 | "etag": "~1.8.1", 509 | "finalhandler": "1.2.0", 510 | "fresh": "0.5.2", 511 | "http-errors": "2.0.0", 512 | "merge-descriptors": "1.0.1", 513 | "methods": "~1.1.2", 514 | "on-finished": "2.4.1", 515 | "parseurl": "~1.3.3", 516 | "path-to-regexp": "0.1.7", 517 | "proxy-addr": "~2.0.7", 518 | "qs": "6.11.0", 519 | "range-parser": "~1.2.1", 520 | "safe-buffer": "5.2.1", 521 | "send": "0.18.0", 522 | "serve-static": "1.15.0", 523 | "setprototypeof": "1.2.0", 524 | "statuses": "2.0.1", 525 | "type-is": "~1.6.18", 526 | "utils-merge": "1.0.1", 527 | "vary": "~1.1.2" 528 | }, 529 | "engines": { 530 | "node": ">= 0.10.0" 531 | } 532 | }, 533 | "node_modules/fill-range": { 534 | "version": "7.0.1", 535 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 536 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 537 | "dependencies": { 538 | "to-regex-range": "^5.0.1" 539 | }, 540 | "engines": { 541 | "node": ">=8" 542 | } 543 | }, 544 | "node_modules/finalhandler": { 545 | "version": "1.2.0", 546 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 547 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 548 | "dependencies": { 549 | "debug": "2.6.9", 550 | "encodeurl": "~1.0.2", 551 | "escape-html": "~1.0.3", 552 | "on-finished": "2.4.1", 553 | "parseurl": "~1.3.3", 554 | "statuses": "2.0.1", 555 | "unpipe": "~1.0.0" 556 | }, 557 | "engines": { 558 | "node": ">= 0.8" 559 | } 560 | }, 561 | "node_modules/forwarded": { 562 | "version": "0.2.0", 563 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 564 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 565 | "engines": { 566 | "node": ">= 0.6" 567 | } 568 | }, 569 | "node_modules/fresh": { 570 | "version": "0.5.2", 571 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 572 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 573 | "engines": { 574 | "node": ">= 0.6" 575 | } 576 | }, 577 | "node_modules/fs-minipass": { 578 | "version": "2.1.0", 579 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", 580 | "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", 581 | "dependencies": { 582 | "minipass": "^3.0.0" 583 | }, 584 | "engines": { 585 | "node": ">= 8" 586 | } 587 | }, 588 | "node_modules/fs-minipass/node_modules/minipass": { 589 | "version": "3.3.6", 590 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 591 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 592 | "dependencies": { 593 | "yallist": "^4.0.0" 594 | }, 595 | "engines": { 596 | "node": ">=8" 597 | } 598 | }, 599 | "node_modules/fs.realpath": { 600 | "version": "1.0.0", 601 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 602 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" 603 | }, 604 | "node_modules/fsevents": { 605 | "version": "2.3.2", 606 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 607 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 608 | "hasInstallScript": true, 609 | "optional": true, 610 | "os": [ 611 | "darwin" 612 | ], 613 | "engines": { 614 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 615 | } 616 | }, 617 | "node_modules/function-bind": { 618 | "version": "1.1.1", 619 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 620 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 621 | }, 622 | "node_modules/gauge": { 623 | "version": "3.0.2", 624 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-3.0.2.tgz", 625 | "integrity": "sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q==", 626 | "dependencies": { 627 | "aproba": "^1.0.3 || ^2.0.0", 628 | "color-support": "^1.1.2", 629 | "console-control-strings": "^1.0.0", 630 | "has-unicode": "^2.0.1", 631 | "object-assign": "^4.1.1", 632 | "signal-exit": "^3.0.0", 633 | "string-width": "^4.2.3", 634 | "strip-ansi": "^6.0.1", 635 | "wide-align": "^1.1.2" 636 | }, 637 | "engines": { 638 | "node": ">=10" 639 | } 640 | }, 641 | "node_modules/get-intrinsic": { 642 | "version": "1.2.0", 643 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.0.tgz", 644 | "integrity": "sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==", 645 | "dependencies": { 646 | "function-bind": "^1.1.1", 647 | "has": "^1.0.3", 648 | "has-symbols": "^1.0.3" 649 | }, 650 | "funding": { 651 | "url": "https://github.com/sponsors/ljharb" 652 | } 653 | }, 654 | "node_modules/glob": { 655 | "version": "7.2.3", 656 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 657 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 658 | "dependencies": { 659 | "fs.realpath": "^1.0.0", 660 | "inflight": "^1.0.4", 661 | "inherits": "2", 662 | "minimatch": "^3.1.1", 663 | "once": "^1.3.0", 664 | "path-is-absolute": "^1.0.0" 665 | }, 666 | "engines": { 667 | "node": "*" 668 | }, 669 | "funding": { 670 | "url": "https://github.com/sponsors/isaacs" 671 | } 672 | }, 673 | "node_modules/glob-parent": { 674 | "version": "5.1.2", 675 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 676 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 677 | "dependencies": { 678 | "is-glob": "^4.0.1" 679 | }, 680 | "engines": { 681 | "node": ">= 6" 682 | } 683 | }, 684 | "node_modules/has": { 685 | "version": "1.0.3", 686 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 687 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 688 | "dependencies": { 689 | "function-bind": "^1.1.1" 690 | }, 691 | "engines": { 692 | "node": ">= 0.4.0" 693 | } 694 | }, 695 | "node_modules/has-flag": { 696 | "version": "3.0.0", 697 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 698 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 699 | "engines": { 700 | "node": ">=4" 701 | } 702 | }, 703 | "node_modules/has-symbols": { 704 | "version": "1.0.3", 705 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 706 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 707 | "engines": { 708 | "node": ">= 0.4" 709 | }, 710 | "funding": { 711 | "url": "https://github.com/sponsors/ljharb" 712 | } 713 | }, 714 | "node_modules/has-unicode": { 715 | "version": "2.0.1", 716 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 717 | "integrity": "sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==" 718 | }, 719 | "node_modules/http-errors": { 720 | "version": "2.0.0", 721 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 722 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 723 | "dependencies": { 724 | "depd": "2.0.0", 725 | "inherits": "2.0.4", 726 | "setprototypeof": "1.2.0", 727 | "statuses": "2.0.1", 728 | "toidentifier": "1.0.1" 729 | }, 730 | "engines": { 731 | "node": ">= 0.8" 732 | } 733 | }, 734 | "node_modules/https-proxy-agent": { 735 | "version": "5.0.1", 736 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 737 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 738 | "dependencies": { 739 | "agent-base": "6", 740 | "debug": "4" 741 | }, 742 | "engines": { 743 | "node": ">= 6" 744 | } 745 | }, 746 | "node_modules/https-proxy-agent/node_modules/debug": { 747 | "version": "4.3.4", 748 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 749 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 750 | "dependencies": { 751 | "ms": "2.1.2" 752 | }, 753 | "engines": { 754 | "node": ">=6.0" 755 | }, 756 | "peerDependenciesMeta": { 757 | "supports-color": { 758 | "optional": true 759 | } 760 | } 761 | }, 762 | "node_modules/https-proxy-agent/node_modules/ms": { 763 | "version": "2.1.2", 764 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 765 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 766 | }, 767 | "node_modules/iconv-lite": { 768 | "version": "0.4.24", 769 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 770 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 771 | "dependencies": { 772 | "safer-buffer": ">= 2.1.2 < 3" 773 | }, 774 | "engines": { 775 | "node": ">=0.10.0" 776 | } 777 | }, 778 | "node_modules/ignore-by-default": { 779 | "version": "1.0.1", 780 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 781 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==" 782 | }, 783 | "node_modules/inflight": { 784 | "version": "1.0.6", 785 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 786 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 787 | "dependencies": { 788 | "once": "^1.3.0", 789 | "wrappy": "1" 790 | } 791 | }, 792 | "node_modules/inherits": { 793 | "version": "2.0.4", 794 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 795 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 796 | }, 797 | "node_modules/ip": { 798 | "version": "2.0.0", 799 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 800 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 801 | }, 802 | "node_modules/ipaddr.js": { 803 | "version": "1.9.1", 804 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 805 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 806 | "engines": { 807 | "node": ">= 0.10" 808 | } 809 | }, 810 | "node_modules/is-binary-path": { 811 | "version": "2.1.0", 812 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 813 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 814 | "dependencies": { 815 | "binary-extensions": "^2.0.0" 816 | }, 817 | "engines": { 818 | "node": ">=8" 819 | } 820 | }, 821 | "node_modules/is-extglob": { 822 | "version": "2.1.1", 823 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 824 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 825 | "engines": { 826 | "node": ">=0.10.0" 827 | } 828 | }, 829 | "node_modules/is-fullwidth-code-point": { 830 | "version": "3.0.0", 831 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 832 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 833 | "engines": { 834 | "node": ">=8" 835 | } 836 | }, 837 | "node_modules/is-glob": { 838 | "version": "4.0.3", 839 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 840 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 841 | "dependencies": { 842 | "is-extglob": "^2.1.1" 843 | }, 844 | "engines": { 845 | "node": ">=0.10.0" 846 | } 847 | }, 848 | "node_modules/is-number": { 849 | "version": "7.0.0", 850 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 851 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 852 | "engines": { 853 | "node": ">=0.12.0" 854 | } 855 | }, 856 | "node_modules/jsonwebtoken": { 857 | "version": "9.0.0", 858 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.0.tgz", 859 | "integrity": "sha512-tuGfYXxkQGDPnLJ7SibiQgVgeDgfbPq2k2ICcbgqW8WxWLBAxKQM/ZCu/IT8SOSwmaYl4dpTFCW5xZv7YbbWUw==", 860 | "dependencies": { 861 | "jws": "^3.2.2", 862 | "lodash": "^4.17.21", 863 | "ms": "^2.1.1", 864 | "semver": "^7.3.8" 865 | }, 866 | "engines": { 867 | "node": ">=12", 868 | "npm": ">=6" 869 | } 870 | }, 871 | "node_modules/jsonwebtoken/node_modules/ms": { 872 | "version": "2.1.3", 873 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 874 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 875 | }, 876 | "node_modules/jsonwebtoken/node_modules/semver": { 877 | "version": "7.5.0", 878 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.0.tgz", 879 | "integrity": "sha512-+XC0AD/R7Q2mPSRuy2Id0+CGTZ98+8f+KvwirxOKIEyid+XSx6HbC63p+O4IndTHuX5Z+JxQ0TghCkO5Cg/2HA==", 880 | "dependencies": { 881 | "lru-cache": "^6.0.0" 882 | }, 883 | "bin": { 884 | "semver": "bin/semver.js" 885 | }, 886 | "engines": { 887 | "node": ">=10" 888 | } 889 | }, 890 | "node_modules/jwa": { 891 | "version": "1.4.1", 892 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 893 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 894 | "dependencies": { 895 | "buffer-equal-constant-time": "1.0.1", 896 | "ecdsa-sig-formatter": "1.0.11", 897 | "safe-buffer": "^5.0.1" 898 | } 899 | }, 900 | "node_modules/jws": { 901 | "version": "3.2.2", 902 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 903 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 904 | "dependencies": { 905 | "jwa": "^1.4.1", 906 | "safe-buffer": "^5.0.1" 907 | } 908 | }, 909 | "node_modules/kareem": { 910 | "version": "2.5.1", 911 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.5.1.tgz", 912 | "integrity": "sha512-7jFxRVm+jD+rkq3kY0iZDJfsO2/t4BBPeEb2qKn2lR/9KhuksYk5hxzfRYWMPV8P/x2d0kHD306YyWLzjjH+uA==", 913 | "engines": { 914 | "node": ">=12.0.0" 915 | } 916 | }, 917 | "node_modules/lodash": { 918 | "version": "4.17.21", 919 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 920 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 921 | }, 922 | "node_modules/lru-cache": { 923 | "version": "6.0.0", 924 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 925 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 926 | "dependencies": { 927 | "yallist": "^4.0.0" 928 | }, 929 | "engines": { 930 | "node": ">=10" 931 | } 932 | }, 933 | "node_modules/make-dir": { 934 | "version": "3.1.0", 935 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 936 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 937 | "dependencies": { 938 | "semver": "^6.0.0" 939 | }, 940 | "engines": { 941 | "node": ">=8" 942 | }, 943 | "funding": { 944 | "url": "https://github.com/sponsors/sindresorhus" 945 | } 946 | }, 947 | "node_modules/make-dir/node_modules/semver": { 948 | "version": "6.3.0", 949 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 950 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 951 | "bin": { 952 | "semver": "bin/semver.js" 953 | } 954 | }, 955 | "node_modules/media-typer": { 956 | "version": "0.3.0", 957 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 958 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 959 | "engines": { 960 | "node": ">= 0.6" 961 | } 962 | }, 963 | "node_modules/memory-pager": { 964 | "version": "1.5.0", 965 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 966 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 967 | "optional": true 968 | }, 969 | "node_modules/merge-descriptors": { 970 | "version": "1.0.1", 971 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 972 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 973 | }, 974 | "node_modules/methods": { 975 | "version": "1.1.2", 976 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 977 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 978 | "engines": { 979 | "node": ">= 0.6" 980 | } 981 | }, 982 | "node_modules/mime": { 983 | "version": "1.6.0", 984 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 985 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 986 | "bin": { 987 | "mime": "cli.js" 988 | }, 989 | "engines": { 990 | "node": ">=4" 991 | } 992 | }, 993 | "node_modules/mime-db": { 994 | "version": "1.52.0", 995 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 996 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 997 | "engines": { 998 | "node": ">= 0.6" 999 | } 1000 | }, 1001 | "node_modules/mime-types": { 1002 | "version": "2.1.35", 1003 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1004 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1005 | "dependencies": { 1006 | "mime-db": "1.52.0" 1007 | }, 1008 | "engines": { 1009 | "node": ">= 0.6" 1010 | } 1011 | }, 1012 | "node_modules/minimatch": { 1013 | "version": "3.1.2", 1014 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1015 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1016 | "dependencies": { 1017 | "brace-expansion": "^1.1.7" 1018 | }, 1019 | "engines": { 1020 | "node": "*" 1021 | } 1022 | }, 1023 | "node_modules/minimist": { 1024 | "version": "1.2.8", 1025 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 1026 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 1027 | "optional": true, 1028 | "funding": { 1029 | "url": "https://github.com/sponsors/ljharb" 1030 | } 1031 | }, 1032 | "node_modules/minipass": { 1033 | "version": "5.0.0", 1034 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", 1035 | "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==", 1036 | "engines": { 1037 | "node": ">=8" 1038 | } 1039 | }, 1040 | "node_modules/minizlib": { 1041 | "version": "2.1.2", 1042 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", 1043 | "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", 1044 | "dependencies": { 1045 | "minipass": "^3.0.0", 1046 | "yallist": "^4.0.0" 1047 | }, 1048 | "engines": { 1049 | "node": ">= 8" 1050 | } 1051 | }, 1052 | "node_modules/minizlib/node_modules/minipass": { 1053 | "version": "3.3.6", 1054 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 1055 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 1056 | "dependencies": { 1057 | "yallist": "^4.0.0" 1058 | }, 1059 | "engines": { 1060 | "node": ">=8" 1061 | } 1062 | }, 1063 | "node_modules/mkdirp": { 1064 | "version": "1.0.4", 1065 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1066 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1067 | "bin": { 1068 | "mkdirp": "bin/cmd.js" 1069 | }, 1070 | "engines": { 1071 | "node": ">=10" 1072 | } 1073 | }, 1074 | "node_modules/moment": { 1075 | "version": "2.29.4", 1076 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 1077 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 1078 | "optional": true, 1079 | "engines": { 1080 | "node": "*" 1081 | } 1082 | }, 1083 | "node_modules/mongodb": { 1084 | "version": "5.3.0", 1085 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-5.3.0.tgz", 1086 | "integrity": "sha512-Wy/sbahguL8c3TXQWXmuBabiLD+iVmz+tOgQf+FwkCjhUIorqbAxRbbz00g4ZoN4sXIPwpAlTANMaGRjGGTikQ==", 1087 | "dependencies": { 1088 | "bson": "^5.2.0", 1089 | "mongodb-connection-string-url": "^2.6.0", 1090 | "socks": "^2.7.1" 1091 | }, 1092 | "engines": { 1093 | "node": ">=14.20.1" 1094 | }, 1095 | "optionalDependencies": { 1096 | "saslprep": "^1.0.3" 1097 | }, 1098 | "peerDependencies": { 1099 | "@aws-sdk/credential-providers": "^3.201.0", 1100 | "mongodb-client-encryption": ">=2.3.0 <3", 1101 | "snappy": "^7.2.2" 1102 | }, 1103 | "peerDependenciesMeta": { 1104 | "@aws-sdk/credential-providers": { 1105 | "optional": true 1106 | }, 1107 | "mongodb-client-encryption": { 1108 | "optional": true 1109 | }, 1110 | "snappy": { 1111 | "optional": true 1112 | } 1113 | } 1114 | }, 1115 | "node_modules/mongodb-connection-string-url": { 1116 | "version": "2.6.0", 1117 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz", 1118 | "integrity": "sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ==", 1119 | "dependencies": { 1120 | "@types/whatwg-url": "^8.2.1", 1121 | "whatwg-url": "^11.0.0" 1122 | } 1123 | }, 1124 | "node_modules/mongoose": { 1125 | "version": "7.1.1", 1126 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-7.1.1.tgz", 1127 | "integrity": "sha512-AIxaWwGY+td7QOMk4NgK6fbRuGovFyDzv65nU1uj1DsUh3lpjfP3iFYHSR+sUKrs7nbp19ksLlRXkmInBteSCA==", 1128 | "dependencies": { 1129 | "bson": "^5.2.0", 1130 | "kareem": "2.5.1", 1131 | "mongodb": "5.3.0", 1132 | "mpath": "0.9.0", 1133 | "mquery": "5.0.0", 1134 | "ms": "2.1.3", 1135 | "sift": "16.0.1" 1136 | }, 1137 | "engines": { 1138 | "node": ">=14.0.0" 1139 | }, 1140 | "funding": { 1141 | "type": "opencollective", 1142 | "url": "https://opencollective.com/mongoose" 1143 | } 1144 | }, 1145 | "node_modules/mongoose/node_modules/ms": { 1146 | "version": "2.1.3", 1147 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1148 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1149 | }, 1150 | "node_modules/mpath": { 1151 | "version": "0.9.0", 1152 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 1153 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==", 1154 | "engines": { 1155 | "node": ">=4.0.0" 1156 | } 1157 | }, 1158 | "node_modules/mquery": { 1159 | "version": "5.0.0", 1160 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 1161 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 1162 | "dependencies": { 1163 | "debug": "4.x" 1164 | }, 1165 | "engines": { 1166 | "node": ">=14.0.0" 1167 | } 1168 | }, 1169 | "node_modules/mquery/node_modules/debug": { 1170 | "version": "4.3.4", 1171 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1172 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1173 | "dependencies": { 1174 | "ms": "2.1.2" 1175 | }, 1176 | "engines": { 1177 | "node": ">=6.0" 1178 | }, 1179 | "peerDependenciesMeta": { 1180 | "supports-color": { 1181 | "optional": true 1182 | } 1183 | } 1184 | }, 1185 | "node_modules/mquery/node_modules/ms": { 1186 | "version": "2.1.2", 1187 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1188 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1189 | }, 1190 | "node_modules/ms": { 1191 | "version": "2.0.0", 1192 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1193 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1194 | }, 1195 | "node_modules/mv": { 1196 | "version": "2.1.1", 1197 | "resolved": "https://registry.npmjs.org/mv/-/mv-2.1.1.tgz", 1198 | "integrity": "sha512-at/ZndSy3xEGJ8i0ygALh8ru9qy7gWW1cmkaqBN29JmMlIvM//MEO9y1sk/avxuwnPcfhkejkLsuPxH81BrkSg==", 1199 | "optional": true, 1200 | "dependencies": { 1201 | "mkdirp": "~0.5.1", 1202 | "ncp": "~2.0.0", 1203 | "rimraf": "~2.4.0" 1204 | }, 1205 | "engines": { 1206 | "node": ">=0.8.0" 1207 | } 1208 | }, 1209 | "node_modules/mv/node_modules/glob": { 1210 | "version": "6.0.4", 1211 | "resolved": "https://registry.npmjs.org/glob/-/glob-6.0.4.tgz", 1212 | "integrity": "sha512-MKZeRNyYZAVVVG1oZeLaWie1uweH40m9AZwIwxyPbTSX4hHrVYSzLg0Ro5Z5R7XKkIX+Cc6oD1rqeDJnwsB8/A==", 1213 | "optional": true, 1214 | "dependencies": { 1215 | "inflight": "^1.0.4", 1216 | "inherits": "2", 1217 | "minimatch": "2 || 3", 1218 | "once": "^1.3.0", 1219 | "path-is-absolute": "^1.0.0" 1220 | }, 1221 | "engines": { 1222 | "node": "*" 1223 | } 1224 | }, 1225 | "node_modules/mv/node_modules/mkdirp": { 1226 | "version": "0.5.6", 1227 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 1228 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 1229 | "optional": true, 1230 | "dependencies": { 1231 | "minimist": "^1.2.6" 1232 | }, 1233 | "bin": { 1234 | "mkdirp": "bin/cmd.js" 1235 | } 1236 | }, 1237 | "node_modules/mv/node_modules/rimraf": { 1238 | "version": "2.4.5", 1239 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.4.5.tgz", 1240 | "integrity": "sha512-J5xnxTyqaiw06JjMftq7L9ouA448dw/E7dKghkP9WpKNuwmARNNg+Gk8/u5ryb9N/Yo2+z3MCwuqFK/+qPOPfQ==", 1241 | "optional": true, 1242 | "dependencies": { 1243 | "glob": "^6.0.1" 1244 | }, 1245 | "bin": { 1246 | "rimraf": "bin.js" 1247 | } 1248 | }, 1249 | "node_modules/nan": { 1250 | "version": "2.17.0", 1251 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.17.0.tgz", 1252 | "integrity": "sha512-2ZTgtl0nJsO0KQCjEpxcIr5D+Yv90plTitZt9JBfQvVJDS5seMl3FOvsh3+9CoYWXf/1l5OaZzzF6nDm4cagaQ==", 1253 | "optional": true 1254 | }, 1255 | "node_modules/ncp": { 1256 | "version": "2.0.0", 1257 | "resolved": "https://registry.npmjs.org/ncp/-/ncp-2.0.0.tgz", 1258 | "integrity": "sha512-zIdGUrPRFTUELUvr3Gmc7KZ2Sw/h1PiVM0Af/oHB6zgnV1ikqSfRk+TOufi79aHYCW3NiOXmr1BP5nWbzojLaA==", 1259 | "optional": true, 1260 | "bin": { 1261 | "ncp": "bin/ncp" 1262 | } 1263 | }, 1264 | "node_modules/negotiator": { 1265 | "version": "0.6.3", 1266 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1267 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1268 | "engines": { 1269 | "node": ">= 0.6" 1270 | } 1271 | }, 1272 | "node_modules/node-addon-api": { 1273 | "version": "5.1.0", 1274 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-5.1.0.tgz", 1275 | "integrity": "sha512-eh0GgfEkpnoWDq+VY8OyvYhFEzBk6jIYbRKdIlyTiAXIVJ8PyBaKb0rp7oDtoddbdoHWhq8wwr+XZ81F1rpNdA==" 1276 | }, 1277 | "node_modules/node-fetch": { 1278 | "version": "2.6.11", 1279 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.11.tgz", 1280 | "integrity": "sha512-4I6pdBY1EthSqDmJkiNk3JIT8cswwR9nfeW/cPdUagJYEQG7R95WRH74wpz7ma8Gh/9dI9FP+OU+0E4FvtA55w==", 1281 | "dependencies": { 1282 | "whatwg-url": "^5.0.0" 1283 | }, 1284 | "engines": { 1285 | "node": "4.x || >=6.0.0" 1286 | }, 1287 | "peerDependencies": { 1288 | "encoding": "^0.1.0" 1289 | }, 1290 | "peerDependenciesMeta": { 1291 | "encoding": { 1292 | "optional": true 1293 | } 1294 | } 1295 | }, 1296 | "node_modules/node-fetch/node_modules/tr46": { 1297 | "version": "0.0.3", 1298 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 1299 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 1300 | }, 1301 | "node_modules/node-fetch/node_modules/webidl-conversions": { 1302 | "version": "3.0.1", 1303 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 1304 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 1305 | }, 1306 | "node_modules/node-fetch/node_modules/whatwg-url": { 1307 | "version": "5.0.0", 1308 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 1309 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 1310 | "dependencies": { 1311 | "tr46": "~0.0.3", 1312 | "webidl-conversions": "^3.0.0" 1313 | } 1314 | }, 1315 | "node_modules/nodemon": { 1316 | "version": "2.0.22", 1317 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.22.tgz", 1318 | "integrity": "sha512-B8YqaKMmyuCO7BowF1Z1/mkPqLk6cs/l63Ojtd6otKjMx47Dq1utxfRxcavH1I7VSaL8n5BUaoutadnsX3AAVQ==", 1319 | "dependencies": { 1320 | "chokidar": "^3.5.2", 1321 | "debug": "^3.2.7", 1322 | "ignore-by-default": "^1.0.1", 1323 | "minimatch": "^3.1.2", 1324 | "pstree.remy": "^1.1.8", 1325 | "semver": "^5.7.1", 1326 | "simple-update-notifier": "^1.0.7", 1327 | "supports-color": "^5.5.0", 1328 | "touch": "^3.1.0", 1329 | "undefsafe": "^2.0.5" 1330 | }, 1331 | "bin": { 1332 | "nodemon": "bin/nodemon.js" 1333 | }, 1334 | "engines": { 1335 | "node": ">=8.10.0" 1336 | }, 1337 | "funding": { 1338 | "type": "opencollective", 1339 | "url": "https://opencollective.com/nodemon" 1340 | } 1341 | }, 1342 | "node_modules/nodemon/node_modules/debug": { 1343 | "version": "3.2.7", 1344 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1345 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1346 | "dependencies": { 1347 | "ms": "^2.1.1" 1348 | } 1349 | }, 1350 | "node_modules/nodemon/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/nopt": { 1356 | "version": "1.0.10", 1357 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1358 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 1359 | "dependencies": { 1360 | "abbrev": "1" 1361 | }, 1362 | "bin": { 1363 | "nopt": "bin/nopt.js" 1364 | }, 1365 | "engines": { 1366 | "node": "*" 1367 | } 1368 | }, 1369 | "node_modules/normalize-path": { 1370 | "version": "3.0.0", 1371 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1372 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1373 | "engines": { 1374 | "node": ">=0.10.0" 1375 | } 1376 | }, 1377 | "node_modules/npmlog": { 1378 | "version": "5.0.1", 1379 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-5.0.1.tgz", 1380 | "integrity": "sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw==", 1381 | "dependencies": { 1382 | "are-we-there-yet": "^2.0.0", 1383 | "console-control-strings": "^1.1.0", 1384 | "gauge": "^3.0.0", 1385 | "set-blocking": "^2.0.0" 1386 | } 1387 | }, 1388 | "node_modules/object-assign": { 1389 | "version": "4.1.1", 1390 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1391 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1392 | "engines": { 1393 | "node": ">=0.10.0" 1394 | } 1395 | }, 1396 | "node_modules/object-inspect": { 1397 | "version": "1.12.3", 1398 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 1399 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 1400 | "funding": { 1401 | "url": "https://github.com/sponsors/ljharb" 1402 | } 1403 | }, 1404 | "node_modules/on-finished": { 1405 | "version": "2.4.1", 1406 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1407 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1408 | "dependencies": { 1409 | "ee-first": "1.1.1" 1410 | }, 1411 | "engines": { 1412 | "node": ">= 0.8" 1413 | } 1414 | }, 1415 | "node_modules/once": { 1416 | "version": "1.4.0", 1417 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1418 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1419 | "dependencies": { 1420 | "wrappy": "1" 1421 | } 1422 | }, 1423 | "node_modules/parseurl": { 1424 | "version": "1.3.3", 1425 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1426 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1427 | "engines": { 1428 | "node": ">= 0.8" 1429 | } 1430 | }, 1431 | "node_modules/path-is-absolute": { 1432 | "version": "1.0.1", 1433 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1434 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1435 | "engines": { 1436 | "node": ">=0.10.0" 1437 | } 1438 | }, 1439 | "node_modules/path-to-regexp": { 1440 | "version": "0.1.7", 1441 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1442 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 1443 | }, 1444 | "node_modules/picomatch": { 1445 | "version": "2.3.1", 1446 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1447 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1448 | "engines": { 1449 | "node": ">=8.6" 1450 | }, 1451 | "funding": { 1452 | "url": "https://github.com/sponsors/jonschlinkert" 1453 | } 1454 | }, 1455 | "node_modules/proxy-addr": { 1456 | "version": "2.0.7", 1457 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1458 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1459 | "dependencies": { 1460 | "forwarded": "0.2.0", 1461 | "ipaddr.js": "1.9.1" 1462 | }, 1463 | "engines": { 1464 | "node": ">= 0.10" 1465 | } 1466 | }, 1467 | "node_modules/pstree.remy": { 1468 | "version": "1.1.8", 1469 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1470 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 1471 | }, 1472 | "node_modules/punycode": { 1473 | "version": "2.3.0", 1474 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 1475 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 1476 | "engines": { 1477 | "node": ">=6" 1478 | } 1479 | }, 1480 | "node_modules/qs": { 1481 | "version": "6.11.0", 1482 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1483 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1484 | "dependencies": { 1485 | "side-channel": "^1.0.4" 1486 | }, 1487 | "engines": { 1488 | "node": ">=0.6" 1489 | }, 1490 | "funding": { 1491 | "url": "https://github.com/sponsors/ljharb" 1492 | } 1493 | }, 1494 | "node_modules/range-parser": { 1495 | "version": "1.2.1", 1496 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1497 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1498 | "engines": { 1499 | "node": ">= 0.6" 1500 | } 1501 | }, 1502 | "node_modules/raw-body": { 1503 | "version": "2.5.1", 1504 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 1505 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 1506 | "dependencies": { 1507 | "bytes": "3.1.2", 1508 | "http-errors": "2.0.0", 1509 | "iconv-lite": "0.4.24", 1510 | "unpipe": "1.0.0" 1511 | }, 1512 | "engines": { 1513 | "node": ">= 0.8" 1514 | } 1515 | }, 1516 | "node_modules/readable-stream": { 1517 | "version": "3.6.2", 1518 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 1519 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 1520 | "dependencies": { 1521 | "inherits": "^2.0.3", 1522 | "string_decoder": "^1.1.1", 1523 | "util-deprecate": "^1.0.1" 1524 | }, 1525 | "engines": { 1526 | "node": ">= 6" 1527 | } 1528 | }, 1529 | "node_modules/readdirp": { 1530 | "version": "3.6.0", 1531 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1532 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1533 | "dependencies": { 1534 | "picomatch": "^2.2.1" 1535 | }, 1536 | "engines": { 1537 | "node": ">=8.10.0" 1538 | } 1539 | }, 1540 | "node_modules/rimraf": { 1541 | "version": "3.0.2", 1542 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1543 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1544 | "dependencies": { 1545 | "glob": "^7.1.3" 1546 | }, 1547 | "bin": { 1548 | "rimraf": "bin.js" 1549 | }, 1550 | "funding": { 1551 | "url": "https://github.com/sponsors/isaacs" 1552 | } 1553 | }, 1554 | "node_modules/safe-buffer": { 1555 | "version": "5.2.1", 1556 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1557 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1558 | "funding": [ 1559 | { 1560 | "type": "github", 1561 | "url": "https://github.com/sponsors/feross" 1562 | }, 1563 | { 1564 | "type": "patreon", 1565 | "url": "https://www.patreon.com/feross" 1566 | }, 1567 | { 1568 | "type": "consulting", 1569 | "url": "https://feross.org/support" 1570 | } 1571 | ] 1572 | }, 1573 | "node_modules/safe-json-stringify": { 1574 | "version": "1.2.0", 1575 | "resolved": "https://registry.npmjs.org/safe-json-stringify/-/safe-json-stringify-1.2.0.tgz", 1576 | "integrity": "sha512-gH8eh2nZudPQO6TytOvbxnuhYBOvDBBLW52tz5q6X58lJcd/tkmqFR+5Z9adS8aJtURSXWThWy/xJtJwixErvg==", 1577 | "optional": true 1578 | }, 1579 | "node_modules/safer-buffer": { 1580 | "version": "2.1.2", 1581 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1582 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1583 | }, 1584 | "node_modules/saslprep": { 1585 | "version": "1.0.3", 1586 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 1587 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 1588 | "optional": true, 1589 | "dependencies": { 1590 | "sparse-bitfield": "^3.0.3" 1591 | }, 1592 | "engines": { 1593 | "node": ">=6" 1594 | } 1595 | }, 1596 | "node_modules/semver": { 1597 | "version": "5.7.1", 1598 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1599 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1600 | "bin": { 1601 | "semver": "bin/semver" 1602 | } 1603 | }, 1604 | "node_modules/send": { 1605 | "version": "0.18.0", 1606 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1607 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1608 | "dependencies": { 1609 | "debug": "2.6.9", 1610 | "depd": "2.0.0", 1611 | "destroy": "1.2.0", 1612 | "encodeurl": "~1.0.2", 1613 | "escape-html": "~1.0.3", 1614 | "etag": "~1.8.1", 1615 | "fresh": "0.5.2", 1616 | "http-errors": "2.0.0", 1617 | "mime": "1.6.0", 1618 | "ms": "2.1.3", 1619 | "on-finished": "2.4.1", 1620 | "range-parser": "~1.2.1", 1621 | "statuses": "2.0.1" 1622 | }, 1623 | "engines": { 1624 | "node": ">= 0.8.0" 1625 | } 1626 | }, 1627 | "node_modules/send/node_modules/ms": { 1628 | "version": "2.1.3", 1629 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1630 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1631 | }, 1632 | "node_modules/serve-static": { 1633 | "version": "1.15.0", 1634 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1635 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1636 | "dependencies": { 1637 | "encodeurl": "~1.0.2", 1638 | "escape-html": "~1.0.3", 1639 | "parseurl": "~1.3.3", 1640 | "send": "0.18.0" 1641 | }, 1642 | "engines": { 1643 | "node": ">= 0.8.0" 1644 | } 1645 | }, 1646 | "node_modules/set-blocking": { 1647 | "version": "2.0.0", 1648 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1649 | "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==" 1650 | }, 1651 | "node_modules/setprototypeof": { 1652 | "version": "1.2.0", 1653 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1654 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1655 | }, 1656 | "node_modules/side-channel": { 1657 | "version": "1.0.4", 1658 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1659 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1660 | "dependencies": { 1661 | "call-bind": "^1.0.0", 1662 | "get-intrinsic": "^1.0.2", 1663 | "object-inspect": "^1.9.0" 1664 | }, 1665 | "funding": { 1666 | "url": "https://github.com/sponsors/ljharb" 1667 | } 1668 | }, 1669 | "node_modules/sift": { 1670 | "version": "16.0.1", 1671 | "resolved": "https://registry.npmjs.org/sift/-/sift-16.0.1.tgz", 1672 | "integrity": "sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ==" 1673 | }, 1674 | "node_modules/signal-exit": { 1675 | "version": "3.0.7", 1676 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1677 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" 1678 | }, 1679 | "node_modules/simple-update-notifier": { 1680 | "version": "1.1.0", 1681 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.1.0.tgz", 1682 | "integrity": "sha512-VpsrsJSUcJEseSbMHkrsrAVSdvVS5I96Qo1QAQ4FxQ9wXFcB+pjj7FB7/us9+GcgfW4ziHtYMc1J0PLczb55mg==", 1683 | "dependencies": { 1684 | "semver": "~7.0.0" 1685 | }, 1686 | "engines": { 1687 | "node": ">=8.10.0" 1688 | } 1689 | }, 1690 | "node_modules/simple-update-notifier/node_modules/semver": { 1691 | "version": "7.0.0", 1692 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 1693 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==", 1694 | "bin": { 1695 | "semver": "bin/semver.js" 1696 | } 1697 | }, 1698 | "node_modules/smart-buffer": { 1699 | "version": "4.2.0", 1700 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 1701 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", 1702 | "engines": { 1703 | "node": ">= 6.0.0", 1704 | "npm": ">= 3.0.0" 1705 | } 1706 | }, 1707 | "node_modules/socks": { 1708 | "version": "2.7.1", 1709 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 1710 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 1711 | "dependencies": { 1712 | "ip": "^2.0.0", 1713 | "smart-buffer": "^4.2.0" 1714 | }, 1715 | "engines": { 1716 | "node": ">= 10.13.0", 1717 | "npm": ">= 3.0.0" 1718 | } 1719 | }, 1720 | "node_modules/sparse-bitfield": { 1721 | "version": "3.0.3", 1722 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1723 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 1724 | "optional": true, 1725 | "dependencies": { 1726 | "memory-pager": "^1.0.2" 1727 | } 1728 | }, 1729 | "node_modules/statuses": { 1730 | "version": "2.0.1", 1731 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1732 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1733 | "engines": { 1734 | "node": ">= 0.8" 1735 | } 1736 | }, 1737 | "node_modules/string_decoder": { 1738 | "version": "1.3.0", 1739 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1740 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1741 | "dependencies": { 1742 | "safe-buffer": "~5.2.0" 1743 | } 1744 | }, 1745 | "node_modules/string-width": { 1746 | "version": "4.2.3", 1747 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1748 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1749 | "dependencies": { 1750 | "emoji-regex": "^8.0.0", 1751 | "is-fullwidth-code-point": "^3.0.0", 1752 | "strip-ansi": "^6.0.1" 1753 | }, 1754 | "engines": { 1755 | "node": ">=8" 1756 | } 1757 | }, 1758 | "node_modules/strip-ansi": { 1759 | "version": "6.0.1", 1760 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1761 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1762 | "dependencies": { 1763 | "ansi-regex": "^5.0.1" 1764 | }, 1765 | "engines": { 1766 | "node": ">=8" 1767 | } 1768 | }, 1769 | "node_modules/supports-color": { 1770 | "version": "5.5.0", 1771 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1772 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1773 | "dependencies": { 1774 | "has-flag": "^3.0.0" 1775 | }, 1776 | "engines": { 1777 | "node": ">=4" 1778 | } 1779 | }, 1780 | "node_modules/tar": { 1781 | "version": "6.1.14", 1782 | "resolved": "https://registry.npmjs.org/tar/-/tar-6.1.14.tgz", 1783 | "integrity": "sha512-piERznXu0U7/pW7cdSn7hjqySIVTYT6F76icmFk7ptU7dDYlXTm5r9A6K04R2vU3olYgoKeo1Cg3eeu5nhftAw==", 1784 | "dependencies": { 1785 | "chownr": "^2.0.0", 1786 | "fs-minipass": "^2.0.0", 1787 | "minipass": "^5.0.0", 1788 | "minizlib": "^2.1.1", 1789 | "mkdirp": "^1.0.3", 1790 | "yallist": "^4.0.0" 1791 | }, 1792 | "engines": { 1793 | "node": ">=10" 1794 | } 1795 | }, 1796 | "node_modules/to-regex-range": { 1797 | "version": "5.0.1", 1798 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1799 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1800 | "dependencies": { 1801 | "is-number": "^7.0.0" 1802 | }, 1803 | "engines": { 1804 | "node": ">=8.0" 1805 | } 1806 | }, 1807 | "node_modules/toidentifier": { 1808 | "version": "1.0.1", 1809 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1810 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1811 | "engines": { 1812 | "node": ">=0.6" 1813 | } 1814 | }, 1815 | "node_modules/touch": { 1816 | "version": "3.1.0", 1817 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1818 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1819 | "dependencies": { 1820 | "nopt": "~1.0.10" 1821 | }, 1822 | "bin": { 1823 | "nodetouch": "bin/nodetouch.js" 1824 | } 1825 | }, 1826 | "node_modules/tr46": { 1827 | "version": "3.0.0", 1828 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 1829 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 1830 | "dependencies": { 1831 | "punycode": "^2.1.1" 1832 | }, 1833 | "engines": { 1834 | "node": ">=12" 1835 | } 1836 | }, 1837 | "node_modules/type-is": { 1838 | "version": "1.6.18", 1839 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1840 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1841 | "dependencies": { 1842 | "media-typer": "0.3.0", 1843 | "mime-types": "~2.1.24" 1844 | }, 1845 | "engines": { 1846 | "node": ">= 0.6" 1847 | } 1848 | }, 1849 | "node_modules/undefsafe": { 1850 | "version": "2.0.5", 1851 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1852 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==" 1853 | }, 1854 | "node_modules/unpipe": { 1855 | "version": "1.0.0", 1856 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1857 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1858 | "engines": { 1859 | "node": ">= 0.8" 1860 | } 1861 | }, 1862 | "node_modules/util-deprecate": { 1863 | "version": "1.0.2", 1864 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1865 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 1866 | }, 1867 | "node_modules/utils-merge": { 1868 | "version": "1.0.1", 1869 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1870 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1871 | "engines": { 1872 | "node": ">= 0.4.0" 1873 | } 1874 | }, 1875 | "node_modules/vary": { 1876 | "version": "1.1.2", 1877 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1878 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1879 | "engines": { 1880 | "node": ">= 0.8" 1881 | } 1882 | }, 1883 | "node_modules/webidl-conversions": { 1884 | "version": "7.0.0", 1885 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1886 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 1887 | "engines": { 1888 | "node": ">=12" 1889 | } 1890 | }, 1891 | "node_modules/whatwg-url": { 1892 | "version": "11.0.0", 1893 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 1894 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 1895 | "dependencies": { 1896 | "tr46": "^3.0.0", 1897 | "webidl-conversions": "^7.0.0" 1898 | }, 1899 | "engines": { 1900 | "node": ">=12" 1901 | } 1902 | }, 1903 | "node_modules/wide-align": { 1904 | "version": "1.1.5", 1905 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz", 1906 | "integrity": "sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==", 1907 | "dependencies": { 1908 | "string-width": "^1.0.2 || 2 || 3 || 4" 1909 | } 1910 | }, 1911 | "node_modules/wrappy": { 1912 | "version": "1.0.2", 1913 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1914 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 1915 | }, 1916 | "node_modules/yallist": { 1917 | "version": "4.0.0", 1918 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1919 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1920 | } 1921 | }, 1922 | "dependencies": { 1923 | "@mapbox/node-pre-gyp": { 1924 | "version": "1.0.10", 1925 | "resolved": "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.10.tgz", 1926 | "integrity": "sha512-4ySo4CjzStuprMwk35H5pPbkymjv1SF3jGLj6rAHp/xT/RF7TL7bd9CTm1xDY49K2qF7jmR/g7k+SkLETP6opA==", 1927 | "requires": { 1928 | "detect-libc": "^2.0.0", 1929 | "https-proxy-agent": "^5.0.0", 1930 | "make-dir": "^3.1.0", 1931 | "node-fetch": "^2.6.7", 1932 | "nopt": "^5.0.0", 1933 | "npmlog": "^5.0.1", 1934 | "rimraf": "^3.0.2", 1935 | "semver": "^7.3.5", 1936 | "tar": "^6.1.11" 1937 | }, 1938 | "dependencies": { 1939 | "nopt": { 1940 | "version": "5.0.0", 1941 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 1942 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 1943 | "requires": { 1944 | "abbrev": "1" 1945 | } 1946 | }, 1947 | "semver": { 1948 | "version": "7.5.0", 1949 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.0.tgz", 1950 | "integrity": "sha512-+XC0AD/R7Q2mPSRuy2Id0+CGTZ98+8f+KvwirxOKIEyid+XSx6HbC63p+O4IndTHuX5Z+JxQ0TghCkO5Cg/2HA==", 1951 | "requires": { 1952 | "lru-cache": "^6.0.0" 1953 | } 1954 | } 1955 | } 1956 | }, 1957 | "@types/node": { 1958 | "version": "20.1.3", 1959 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.1.3.tgz", 1960 | "integrity": "sha512-NP2yfZpgmf2eDRPmgGq+fjGjSwFgYbihA8/gK+ey23qT9RkxsgNTZvGOEpXgzIGqesTYkElELLgtKoMQTys5vA==" 1961 | }, 1962 | "@types/webidl-conversions": { 1963 | "version": "7.0.0", 1964 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1965 | "integrity": "sha512-xTE1E+YF4aWPJJeUzaZI5DRntlkY3+BCVJi0axFptnjGmAoWxkyREIh/XMrfxVLejwQxMCfDXdICo0VLxThrog==" 1966 | }, 1967 | "@types/whatwg-url": { 1968 | "version": "8.2.2", 1969 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.2.tgz", 1970 | "integrity": "sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA==", 1971 | "requires": { 1972 | "@types/node": "*", 1973 | "@types/webidl-conversions": "*" 1974 | } 1975 | }, 1976 | "abbrev": { 1977 | "version": "1.1.1", 1978 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 1979 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 1980 | }, 1981 | "accepts": { 1982 | "version": "1.3.8", 1983 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 1984 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 1985 | "requires": { 1986 | "mime-types": "~2.1.34", 1987 | "negotiator": "0.6.3" 1988 | } 1989 | }, 1990 | "agent-base": { 1991 | "version": "6.0.2", 1992 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 1993 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 1994 | "requires": { 1995 | "debug": "4" 1996 | }, 1997 | "dependencies": { 1998 | "debug": { 1999 | "version": "4.3.4", 2000 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2001 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2002 | "requires": { 2003 | "ms": "2.1.2" 2004 | } 2005 | }, 2006 | "ms": { 2007 | "version": "2.1.2", 2008 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2009 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2010 | } 2011 | } 2012 | }, 2013 | "ansi-regex": { 2014 | "version": "5.0.1", 2015 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2016 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" 2017 | }, 2018 | "anymatch": { 2019 | "version": "3.1.3", 2020 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 2021 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 2022 | "requires": { 2023 | "normalize-path": "^3.0.0", 2024 | "picomatch": "^2.0.4" 2025 | } 2026 | }, 2027 | "aproba": { 2028 | "version": "2.0.0", 2029 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz", 2030 | "integrity": "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==" 2031 | }, 2032 | "are-we-there-yet": { 2033 | "version": "2.0.0", 2034 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz", 2035 | "integrity": "sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw==", 2036 | "requires": { 2037 | "delegates": "^1.0.0", 2038 | "readable-stream": "^3.6.0" 2039 | } 2040 | }, 2041 | "array-flatten": { 2042 | "version": "1.1.1", 2043 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 2044 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 2045 | }, 2046 | "balanced-match": { 2047 | "version": "1.0.2", 2048 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2049 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 2050 | }, 2051 | "bcrypt": { 2052 | "version": "5.1.0", 2053 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.1.0.tgz", 2054 | "integrity": "sha512-RHBS7HI5N5tEnGTmtR/pppX0mmDSBpQ4aCBsj7CEQfYXDcO74A8sIBYcJMuCsis2E81zDxeENYhv66oZwLiA+Q==", 2055 | "requires": { 2056 | "@mapbox/node-pre-gyp": "^1.0.10", 2057 | "node-addon-api": "^5.0.0" 2058 | } 2059 | }, 2060 | "binary-extensions": { 2061 | "version": "2.2.0", 2062 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2063 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==" 2064 | }, 2065 | "body-parser": { 2066 | "version": "1.20.1", 2067 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 2068 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 2069 | "requires": { 2070 | "bytes": "3.1.2", 2071 | "content-type": "~1.0.4", 2072 | "debug": "2.6.9", 2073 | "depd": "2.0.0", 2074 | "destroy": "1.2.0", 2075 | "http-errors": "2.0.0", 2076 | "iconv-lite": "0.4.24", 2077 | "on-finished": "2.4.1", 2078 | "qs": "6.11.0", 2079 | "raw-body": "2.5.1", 2080 | "type-is": "~1.6.18", 2081 | "unpipe": "1.0.0" 2082 | } 2083 | }, 2084 | "brace-expansion": { 2085 | "version": "1.1.11", 2086 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2087 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2088 | "requires": { 2089 | "balanced-match": "^1.0.0", 2090 | "concat-map": "0.0.1" 2091 | } 2092 | }, 2093 | "braces": { 2094 | "version": "3.0.2", 2095 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2096 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2097 | "requires": { 2098 | "fill-range": "^7.0.1" 2099 | } 2100 | }, 2101 | "bson": { 2102 | "version": "5.3.0", 2103 | "resolved": "https://registry.npmjs.org/bson/-/bson-5.3.0.tgz", 2104 | "integrity": "sha512-ukmCZMneMlaC5ebPHXIkP8YJzNl5DC41N5MAIvKDqLggdao342t4McltoJBQfQya/nHBWAcSsYRqlXPoQkTJag==" 2105 | }, 2106 | "buffer-equal-constant-time": { 2107 | "version": "1.0.1", 2108 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 2109 | "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" 2110 | }, 2111 | "bunyan": { 2112 | "version": "1.8.15", 2113 | "resolved": "https://registry.npmjs.org/bunyan/-/bunyan-1.8.15.tgz", 2114 | "integrity": "sha512-0tECWShh6wUysgucJcBAoYegf3JJoZWibxdqhTm7OHPeT42qdjkZ29QCMcKwbgU1kiH+auSIasNRXMLWXafXig==", 2115 | "requires": { 2116 | "dtrace-provider": "~0.8", 2117 | "moment": "^2.19.3", 2118 | "mv": "~2", 2119 | "safe-json-stringify": "~1" 2120 | } 2121 | }, 2122 | "bytes": { 2123 | "version": "3.1.2", 2124 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 2125 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" 2126 | }, 2127 | "call-bind": { 2128 | "version": "1.0.2", 2129 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 2130 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 2131 | "requires": { 2132 | "function-bind": "^1.1.1", 2133 | "get-intrinsic": "^1.0.2" 2134 | } 2135 | }, 2136 | "chokidar": { 2137 | "version": "3.5.3", 2138 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 2139 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 2140 | "requires": { 2141 | "anymatch": "~3.1.2", 2142 | "braces": "~3.0.2", 2143 | "fsevents": "~2.3.2", 2144 | "glob-parent": "~5.1.2", 2145 | "is-binary-path": "~2.1.0", 2146 | "is-glob": "~4.0.1", 2147 | "normalize-path": "~3.0.0", 2148 | "readdirp": "~3.6.0" 2149 | } 2150 | }, 2151 | "chownr": { 2152 | "version": "2.0.0", 2153 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", 2154 | "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==" 2155 | }, 2156 | "color-support": { 2157 | "version": "1.1.3", 2158 | "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", 2159 | "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==" 2160 | }, 2161 | "concat-map": { 2162 | "version": "0.0.1", 2163 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2164 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" 2165 | }, 2166 | "console-control-strings": { 2167 | "version": "1.1.0", 2168 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 2169 | "integrity": "sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==" 2170 | }, 2171 | "content-disposition": { 2172 | "version": "0.5.4", 2173 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 2174 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 2175 | "requires": { 2176 | "safe-buffer": "5.2.1" 2177 | } 2178 | }, 2179 | "content-type": { 2180 | "version": "1.0.5", 2181 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 2182 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==" 2183 | }, 2184 | "cookie": { 2185 | "version": "0.5.0", 2186 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 2187 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==" 2188 | }, 2189 | "cookie-signature": { 2190 | "version": "1.0.6", 2191 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 2192 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 2193 | }, 2194 | "cors": { 2195 | "version": "2.8.5", 2196 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 2197 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 2198 | "requires": { 2199 | "object-assign": "^4", 2200 | "vary": "^1" 2201 | } 2202 | }, 2203 | "debug": { 2204 | "version": "2.6.9", 2205 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2206 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2207 | "requires": { 2208 | "ms": "2.0.0" 2209 | } 2210 | }, 2211 | "delegates": { 2212 | "version": "1.0.0", 2213 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 2214 | "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==" 2215 | }, 2216 | "depd": { 2217 | "version": "2.0.0", 2218 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 2219 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 2220 | }, 2221 | "destroy": { 2222 | "version": "1.2.0", 2223 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 2224 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" 2225 | }, 2226 | "detect-libc": { 2227 | "version": "2.0.1", 2228 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.1.tgz", 2229 | "integrity": "sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w==" 2230 | }, 2231 | "dotenv": { 2232 | "version": "16.0.3", 2233 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 2234 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==" 2235 | }, 2236 | "dtrace-provider": { 2237 | "version": "0.8.8", 2238 | "resolved": "https://registry.npmjs.org/dtrace-provider/-/dtrace-provider-0.8.8.tgz", 2239 | "integrity": "sha512-b7Z7cNtHPhH9EJhNNbbeqTcXB8LGFFZhq1PGgEvpeHlzd36bhbdTWoE/Ba/YguqpBSlAPKnARWhVlhunCMwfxg==", 2240 | "optional": true, 2241 | "requires": { 2242 | "nan": "^2.14.0" 2243 | } 2244 | }, 2245 | "ecdsa-sig-formatter": { 2246 | "version": "1.0.11", 2247 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 2248 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 2249 | "requires": { 2250 | "safe-buffer": "^5.0.1" 2251 | } 2252 | }, 2253 | "ee-first": { 2254 | "version": "1.1.1", 2255 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 2256 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 2257 | }, 2258 | "emoji-regex": { 2259 | "version": "8.0.0", 2260 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2261 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2262 | }, 2263 | "encodeurl": { 2264 | "version": "1.0.2", 2265 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2266 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" 2267 | }, 2268 | "escape-html": { 2269 | "version": "1.0.3", 2270 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2271 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 2272 | }, 2273 | "etag": { 2274 | "version": "1.8.1", 2275 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 2276 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==" 2277 | }, 2278 | "express": { 2279 | "version": "4.18.2", 2280 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 2281 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 2282 | "requires": { 2283 | "accepts": "~1.3.8", 2284 | "array-flatten": "1.1.1", 2285 | "body-parser": "1.20.1", 2286 | "content-disposition": "0.5.4", 2287 | "content-type": "~1.0.4", 2288 | "cookie": "0.5.0", 2289 | "cookie-signature": "1.0.6", 2290 | "debug": "2.6.9", 2291 | "depd": "2.0.0", 2292 | "encodeurl": "~1.0.2", 2293 | "escape-html": "~1.0.3", 2294 | "etag": "~1.8.1", 2295 | "finalhandler": "1.2.0", 2296 | "fresh": "0.5.2", 2297 | "http-errors": "2.0.0", 2298 | "merge-descriptors": "1.0.1", 2299 | "methods": "~1.1.2", 2300 | "on-finished": "2.4.1", 2301 | "parseurl": "~1.3.3", 2302 | "path-to-regexp": "0.1.7", 2303 | "proxy-addr": "~2.0.7", 2304 | "qs": "6.11.0", 2305 | "range-parser": "~1.2.1", 2306 | "safe-buffer": "5.2.1", 2307 | "send": "0.18.0", 2308 | "serve-static": "1.15.0", 2309 | "setprototypeof": "1.2.0", 2310 | "statuses": "2.0.1", 2311 | "type-is": "~1.6.18", 2312 | "utils-merge": "1.0.1", 2313 | "vary": "~1.1.2" 2314 | } 2315 | }, 2316 | "fill-range": { 2317 | "version": "7.0.1", 2318 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2319 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2320 | "requires": { 2321 | "to-regex-range": "^5.0.1" 2322 | } 2323 | }, 2324 | "finalhandler": { 2325 | "version": "1.2.0", 2326 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 2327 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 2328 | "requires": { 2329 | "debug": "2.6.9", 2330 | "encodeurl": "~1.0.2", 2331 | "escape-html": "~1.0.3", 2332 | "on-finished": "2.4.1", 2333 | "parseurl": "~1.3.3", 2334 | "statuses": "2.0.1", 2335 | "unpipe": "~1.0.0" 2336 | } 2337 | }, 2338 | "forwarded": { 2339 | "version": "0.2.0", 2340 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 2341 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 2342 | }, 2343 | "fresh": { 2344 | "version": "0.5.2", 2345 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 2346 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" 2347 | }, 2348 | "fs-minipass": { 2349 | "version": "2.1.0", 2350 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", 2351 | "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", 2352 | "requires": { 2353 | "minipass": "^3.0.0" 2354 | }, 2355 | "dependencies": { 2356 | "minipass": { 2357 | "version": "3.3.6", 2358 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 2359 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 2360 | "requires": { 2361 | "yallist": "^4.0.0" 2362 | } 2363 | } 2364 | } 2365 | }, 2366 | "fs.realpath": { 2367 | "version": "1.0.0", 2368 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2369 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" 2370 | }, 2371 | "fsevents": { 2372 | "version": "2.3.2", 2373 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2374 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2375 | "optional": true 2376 | }, 2377 | "function-bind": { 2378 | "version": "1.1.1", 2379 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2380 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2381 | }, 2382 | "gauge": { 2383 | "version": "3.0.2", 2384 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-3.0.2.tgz", 2385 | "integrity": "sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q==", 2386 | "requires": { 2387 | "aproba": "^1.0.3 || ^2.0.0", 2388 | "color-support": "^1.1.2", 2389 | "console-control-strings": "^1.0.0", 2390 | "has-unicode": "^2.0.1", 2391 | "object-assign": "^4.1.1", 2392 | "signal-exit": "^3.0.0", 2393 | "string-width": "^4.2.3", 2394 | "strip-ansi": "^6.0.1", 2395 | "wide-align": "^1.1.2" 2396 | } 2397 | }, 2398 | "get-intrinsic": { 2399 | "version": "1.2.0", 2400 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.0.tgz", 2401 | "integrity": "sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==", 2402 | "requires": { 2403 | "function-bind": "^1.1.1", 2404 | "has": "^1.0.3", 2405 | "has-symbols": "^1.0.3" 2406 | } 2407 | }, 2408 | "glob": { 2409 | "version": "7.2.3", 2410 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2411 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2412 | "requires": { 2413 | "fs.realpath": "^1.0.0", 2414 | "inflight": "^1.0.4", 2415 | "inherits": "2", 2416 | "minimatch": "^3.1.1", 2417 | "once": "^1.3.0", 2418 | "path-is-absolute": "^1.0.0" 2419 | } 2420 | }, 2421 | "glob-parent": { 2422 | "version": "5.1.2", 2423 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2424 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2425 | "requires": { 2426 | "is-glob": "^4.0.1" 2427 | } 2428 | }, 2429 | "has": { 2430 | "version": "1.0.3", 2431 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2432 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2433 | "requires": { 2434 | "function-bind": "^1.1.1" 2435 | } 2436 | }, 2437 | "has-flag": { 2438 | "version": "3.0.0", 2439 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2440 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==" 2441 | }, 2442 | "has-symbols": { 2443 | "version": "1.0.3", 2444 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2445 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 2446 | }, 2447 | "has-unicode": { 2448 | "version": "2.0.1", 2449 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 2450 | "integrity": "sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==" 2451 | }, 2452 | "http-errors": { 2453 | "version": "2.0.0", 2454 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 2455 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 2456 | "requires": { 2457 | "depd": "2.0.0", 2458 | "inherits": "2.0.4", 2459 | "setprototypeof": "1.2.0", 2460 | "statuses": "2.0.1", 2461 | "toidentifier": "1.0.1" 2462 | } 2463 | }, 2464 | "https-proxy-agent": { 2465 | "version": "5.0.1", 2466 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 2467 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 2468 | "requires": { 2469 | "agent-base": "6", 2470 | "debug": "4" 2471 | }, 2472 | "dependencies": { 2473 | "debug": { 2474 | "version": "4.3.4", 2475 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2476 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2477 | "requires": { 2478 | "ms": "2.1.2" 2479 | } 2480 | }, 2481 | "ms": { 2482 | "version": "2.1.2", 2483 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2484 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2485 | } 2486 | } 2487 | }, 2488 | "iconv-lite": { 2489 | "version": "0.4.24", 2490 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2491 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2492 | "requires": { 2493 | "safer-buffer": ">= 2.1.2 < 3" 2494 | } 2495 | }, 2496 | "ignore-by-default": { 2497 | "version": "1.0.1", 2498 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 2499 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==" 2500 | }, 2501 | "inflight": { 2502 | "version": "1.0.6", 2503 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2504 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2505 | "requires": { 2506 | "once": "^1.3.0", 2507 | "wrappy": "1" 2508 | } 2509 | }, 2510 | "inherits": { 2511 | "version": "2.0.4", 2512 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2513 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 2514 | }, 2515 | "ip": { 2516 | "version": "2.0.0", 2517 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 2518 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 2519 | }, 2520 | "ipaddr.js": { 2521 | "version": "1.9.1", 2522 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 2523 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 2524 | }, 2525 | "is-binary-path": { 2526 | "version": "2.1.0", 2527 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2528 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2529 | "requires": { 2530 | "binary-extensions": "^2.0.0" 2531 | } 2532 | }, 2533 | "is-extglob": { 2534 | "version": "2.1.1", 2535 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2536 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==" 2537 | }, 2538 | "is-fullwidth-code-point": { 2539 | "version": "3.0.0", 2540 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2541 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 2542 | }, 2543 | "is-glob": { 2544 | "version": "4.0.3", 2545 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2546 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2547 | "requires": { 2548 | "is-extglob": "^2.1.1" 2549 | } 2550 | }, 2551 | "is-number": { 2552 | "version": "7.0.0", 2553 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2554 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 2555 | }, 2556 | "jsonwebtoken": { 2557 | "version": "9.0.0", 2558 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.0.tgz", 2559 | "integrity": "sha512-tuGfYXxkQGDPnLJ7SibiQgVgeDgfbPq2k2ICcbgqW8WxWLBAxKQM/ZCu/IT8SOSwmaYl4dpTFCW5xZv7YbbWUw==", 2560 | "requires": { 2561 | "jws": "^3.2.2", 2562 | "lodash": "^4.17.21", 2563 | "ms": "^2.1.1", 2564 | "semver": "^7.3.8" 2565 | }, 2566 | "dependencies": { 2567 | "ms": { 2568 | "version": "2.1.3", 2569 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2570 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2571 | }, 2572 | "semver": { 2573 | "version": "7.5.0", 2574 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.0.tgz", 2575 | "integrity": "sha512-+XC0AD/R7Q2mPSRuy2Id0+CGTZ98+8f+KvwirxOKIEyid+XSx6HbC63p+O4IndTHuX5Z+JxQ0TghCkO5Cg/2HA==", 2576 | "requires": { 2577 | "lru-cache": "^6.0.0" 2578 | } 2579 | } 2580 | } 2581 | }, 2582 | "jwa": { 2583 | "version": "1.4.1", 2584 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 2585 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 2586 | "requires": { 2587 | "buffer-equal-constant-time": "1.0.1", 2588 | "ecdsa-sig-formatter": "1.0.11", 2589 | "safe-buffer": "^5.0.1" 2590 | } 2591 | }, 2592 | "jws": { 2593 | "version": "3.2.2", 2594 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 2595 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 2596 | "requires": { 2597 | "jwa": "^1.4.1", 2598 | "safe-buffer": "^5.0.1" 2599 | } 2600 | }, 2601 | "kareem": { 2602 | "version": "2.5.1", 2603 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.5.1.tgz", 2604 | "integrity": "sha512-7jFxRVm+jD+rkq3kY0iZDJfsO2/t4BBPeEb2qKn2lR/9KhuksYk5hxzfRYWMPV8P/x2d0kHD306YyWLzjjH+uA==" 2605 | }, 2606 | "lodash": { 2607 | "version": "4.17.21", 2608 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2609 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" 2610 | }, 2611 | "lru-cache": { 2612 | "version": "6.0.0", 2613 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2614 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2615 | "requires": { 2616 | "yallist": "^4.0.0" 2617 | } 2618 | }, 2619 | "make-dir": { 2620 | "version": "3.1.0", 2621 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2622 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2623 | "requires": { 2624 | "semver": "^6.0.0" 2625 | }, 2626 | "dependencies": { 2627 | "semver": { 2628 | "version": "6.3.0", 2629 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2630 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 2631 | } 2632 | } 2633 | }, 2634 | "media-typer": { 2635 | "version": "0.3.0", 2636 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2637 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" 2638 | }, 2639 | "memory-pager": { 2640 | "version": "1.5.0", 2641 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 2642 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 2643 | "optional": true 2644 | }, 2645 | "merge-descriptors": { 2646 | "version": "1.0.1", 2647 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 2648 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 2649 | }, 2650 | "methods": { 2651 | "version": "1.1.2", 2652 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2653 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==" 2654 | }, 2655 | "mime": { 2656 | "version": "1.6.0", 2657 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2658 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 2659 | }, 2660 | "mime-db": { 2661 | "version": "1.52.0", 2662 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 2663 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 2664 | }, 2665 | "mime-types": { 2666 | "version": "2.1.35", 2667 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 2668 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 2669 | "requires": { 2670 | "mime-db": "1.52.0" 2671 | } 2672 | }, 2673 | "minimatch": { 2674 | "version": "3.1.2", 2675 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2676 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2677 | "requires": { 2678 | "brace-expansion": "^1.1.7" 2679 | } 2680 | }, 2681 | "minimist": { 2682 | "version": "1.2.8", 2683 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2684 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 2685 | "optional": true 2686 | }, 2687 | "minipass": { 2688 | "version": "5.0.0", 2689 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", 2690 | "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==" 2691 | }, 2692 | "minizlib": { 2693 | "version": "2.1.2", 2694 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", 2695 | "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", 2696 | "requires": { 2697 | "minipass": "^3.0.0", 2698 | "yallist": "^4.0.0" 2699 | }, 2700 | "dependencies": { 2701 | "minipass": { 2702 | "version": "3.3.6", 2703 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 2704 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 2705 | "requires": { 2706 | "yallist": "^4.0.0" 2707 | } 2708 | } 2709 | } 2710 | }, 2711 | "mkdirp": { 2712 | "version": "1.0.4", 2713 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 2714 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" 2715 | }, 2716 | "moment": { 2717 | "version": "2.29.4", 2718 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 2719 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 2720 | "optional": true 2721 | }, 2722 | "mongodb": { 2723 | "version": "5.3.0", 2724 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-5.3.0.tgz", 2725 | "integrity": "sha512-Wy/sbahguL8c3TXQWXmuBabiLD+iVmz+tOgQf+FwkCjhUIorqbAxRbbz00g4ZoN4sXIPwpAlTANMaGRjGGTikQ==", 2726 | "requires": { 2727 | "bson": "^5.2.0", 2728 | "mongodb-connection-string-url": "^2.6.0", 2729 | "saslprep": "^1.0.3", 2730 | "socks": "^2.7.1" 2731 | } 2732 | }, 2733 | "mongodb-connection-string-url": { 2734 | "version": "2.6.0", 2735 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz", 2736 | "integrity": "sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ==", 2737 | "requires": { 2738 | "@types/whatwg-url": "^8.2.1", 2739 | "whatwg-url": "^11.0.0" 2740 | } 2741 | }, 2742 | "mongoose": { 2743 | "version": "7.1.1", 2744 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-7.1.1.tgz", 2745 | "integrity": "sha512-AIxaWwGY+td7QOMk4NgK6fbRuGovFyDzv65nU1uj1DsUh3lpjfP3iFYHSR+sUKrs7nbp19ksLlRXkmInBteSCA==", 2746 | "requires": { 2747 | "bson": "^5.2.0", 2748 | "kareem": "2.5.1", 2749 | "mongodb": "5.3.0", 2750 | "mpath": "0.9.0", 2751 | "mquery": "5.0.0", 2752 | "ms": "2.1.3", 2753 | "sift": "16.0.1" 2754 | }, 2755 | "dependencies": { 2756 | "ms": { 2757 | "version": "2.1.3", 2758 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2759 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2760 | } 2761 | } 2762 | }, 2763 | "mpath": { 2764 | "version": "0.9.0", 2765 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 2766 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==" 2767 | }, 2768 | "mquery": { 2769 | "version": "5.0.0", 2770 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 2771 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 2772 | "requires": { 2773 | "debug": "4.x" 2774 | }, 2775 | "dependencies": { 2776 | "debug": { 2777 | "version": "4.3.4", 2778 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2779 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2780 | "requires": { 2781 | "ms": "2.1.2" 2782 | } 2783 | }, 2784 | "ms": { 2785 | "version": "2.1.2", 2786 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2787 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 2788 | } 2789 | } 2790 | }, 2791 | "ms": { 2792 | "version": "2.0.0", 2793 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2794 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 2795 | }, 2796 | "mv": { 2797 | "version": "2.1.1", 2798 | "resolved": "https://registry.npmjs.org/mv/-/mv-2.1.1.tgz", 2799 | "integrity": "sha512-at/ZndSy3xEGJ8i0ygALh8ru9qy7gWW1cmkaqBN29JmMlIvM//MEO9y1sk/avxuwnPcfhkejkLsuPxH81BrkSg==", 2800 | "optional": true, 2801 | "requires": { 2802 | "mkdirp": "~0.5.1", 2803 | "ncp": "~2.0.0", 2804 | "rimraf": "~2.4.0" 2805 | }, 2806 | "dependencies": { 2807 | "glob": { 2808 | "version": "6.0.4", 2809 | "resolved": "https://registry.npmjs.org/glob/-/glob-6.0.4.tgz", 2810 | "integrity": "sha512-MKZeRNyYZAVVVG1oZeLaWie1uweH40m9AZwIwxyPbTSX4hHrVYSzLg0Ro5Z5R7XKkIX+Cc6oD1rqeDJnwsB8/A==", 2811 | "optional": true, 2812 | "requires": { 2813 | "inflight": "^1.0.4", 2814 | "inherits": "2", 2815 | "minimatch": "2 || 3", 2816 | "once": "^1.3.0", 2817 | "path-is-absolute": "^1.0.0" 2818 | } 2819 | }, 2820 | "mkdirp": { 2821 | "version": "0.5.6", 2822 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 2823 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 2824 | "optional": true, 2825 | "requires": { 2826 | "minimist": "^1.2.6" 2827 | } 2828 | }, 2829 | "rimraf": { 2830 | "version": "2.4.5", 2831 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.4.5.tgz", 2832 | "integrity": "sha512-J5xnxTyqaiw06JjMftq7L9ouA448dw/E7dKghkP9WpKNuwmARNNg+Gk8/u5ryb9N/Yo2+z3MCwuqFK/+qPOPfQ==", 2833 | "optional": true, 2834 | "requires": { 2835 | "glob": "^6.0.1" 2836 | } 2837 | } 2838 | } 2839 | }, 2840 | "nan": { 2841 | "version": "2.17.0", 2842 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.17.0.tgz", 2843 | "integrity": "sha512-2ZTgtl0nJsO0KQCjEpxcIr5D+Yv90plTitZt9JBfQvVJDS5seMl3FOvsh3+9CoYWXf/1l5OaZzzF6nDm4cagaQ==", 2844 | "optional": true 2845 | }, 2846 | "ncp": { 2847 | "version": "2.0.0", 2848 | "resolved": "https://registry.npmjs.org/ncp/-/ncp-2.0.0.tgz", 2849 | "integrity": "sha512-zIdGUrPRFTUELUvr3Gmc7KZ2Sw/h1PiVM0Af/oHB6zgnV1ikqSfRk+TOufi79aHYCW3NiOXmr1BP5nWbzojLaA==", 2850 | "optional": true 2851 | }, 2852 | "negotiator": { 2853 | "version": "0.6.3", 2854 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 2855 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 2856 | }, 2857 | "node-addon-api": { 2858 | "version": "5.1.0", 2859 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-5.1.0.tgz", 2860 | "integrity": "sha512-eh0GgfEkpnoWDq+VY8OyvYhFEzBk6jIYbRKdIlyTiAXIVJ8PyBaKb0rp7oDtoddbdoHWhq8wwr+XZ81F1rpNdA==" 2861 | }, 2862 | "node-fetch": { 2863 | "version": "2.6.11", 2864 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.11.tgz", 2865 | "integrity": "sha512-4I6pdBY1EthSqDmJkiNk3JIT8cswwR9nfeW/cPdUagJYEQG7R95WRH74wpz7ma8Gh/9dI9FP+OU+0E4FvtA55w==", 2866 | "requires": { 2867 | "whatwg-url": "^5.0.0" 2868 | }, 2869 | "dependencies": { 2870 | "tr46": { 2871 | "version": "0.0.3", 2872 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 2873 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 2874 | }, 2875 | "webidl-conversions": { 2876 | "version": "3.0.1", 2877 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 2878 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 2879 | }, 2880 | "whatwg-url": { 2881 | "version": "5.0.0", 2882 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 2883 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 2884 | "requires": { 2885 | "tr46": "~0.0.3", 2886 | "webidl-conversions": "^3.0.0" 2887 | } 2888 | } 2889 | } 2890 | }, 2891 | "nodemon": { 2892 | "version": "2.0.22", 2893 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.22.tgz", 2894 | "integrity": "sha512-B8YqaKMmyuCO7BowF1Z1/mkPqLk6cs/l63Ojtd6otKjMx47Dq1utxfRxcavH1I7VSaL8n5BUaoutadnsX3AAVQ==", 2895 | "requires": { 2896 | "chokidar": "^3.5.2", 2897 | "debug": "^3.2.7", 2898 | "ignore-by-default": "^1.0.1", 2899 | "minimatch": "^3.1.2", 2900 | "pstree.remy": "^1.1.8", 2901 | "semver": "^5.7.1", 2902 | "simple-update-notifier": "^1.0.7", 2903 | "supports-color": "^5.5.0", 2904 | "touch": "^3.1.0", 2905 | "undefsafe": "^2.0.5" 2906 | }, 2907 | "dependencies": { 2908 | "debug": { 2909 | "version": "3.2.7", 2910 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 2911 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 2912 | "requires": { 2913 | "ms": "^2.1.1" 2914 | } 2915 | }, 2916 | "ms": { 2917 | "version": "2.1.3", 2918 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2919 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2920 | } 2921 | } 2922 | }, 2923 | "nopt": { 2924 | "version": "1.0.10", 2925 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 2926 | "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", 2927 | "requires": { 2928 | "abbrev": "1" 2929 | } 2930 | }, 2931 | "normalize-path": { 2932 | "version": "3.0.0", 2933 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2934 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" 2935 | }, 2936 | "npmlog": { 2937 | "version": "5.0.1", 2938 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-5.0.1.tgz", 2939 | "integrity": "sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw==", 2940 | "requires": { 2941 | "are-we-there-yet": "^2.0.0", 2942 | "console-control-strings": "^1.1.0", 2943 | "gauge": "^3.0.0", 2944 | "set-blocking": "^2.0.0" 2945 | } 2946 | }, 2947 | "object-assign": { 2948 | "version": "4.1.1", 2949 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2950 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==" 2951 | }, 2952 | "object-inspect": { 2953 | "version": "1.12.3", 2954 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 2955 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==" 2956 | }, 2957 | "on-finished": { 2958 | "version": "2.4.1", 2959 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 2960 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 2961 | "requires": { 2962 | "ee-first": "1.1.1" 2963 | } 2964 | }, 2965 | "once": { 2966 | "version": "1.4.0", 2967 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2968 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2969 | "requires": { 2970 | "wrappy": "1" 2971 | } 2972 | }, 2973 | "parseurl": { 2974 | "version": "1.3.3", 2975 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2976 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2977 | }, 2978 | "path-is-absolute": { 2979 | "version": "1.0.1", 2980 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2981 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" 2982 | }, 2983 | "path-to-regexp": { 2984 | "version": "0.1.7", 2985 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2986 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 2987 | }, 2988 | "picomatch": { 2989 | "version": "2.3.1", 2990 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2991 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==" 2992 | }, 2993 | "proxy-addr": { 2994 | "version": "2.0.7", 2995 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2996 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2997 | "requires": { 2998 | "forwarded": "0.2.0", 2999 | "ipaddr.js": "1.9.1" 3000 | } 3001 | }, 3002 | "pstree.remy": { 3003 | "version": "1.1.8", 3004 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 3005 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 3006 | }, 3007 | "punycode": { 3008 | "version": "2.3.0", 3009 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 3010 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==" 3011 | }, 3012 | "qs": { 3013 | "version": "6.11.0", 3014 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 3015 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 3016 | "requires": { 3017 | "side-channel": "^1.0.4" 3018 | } 3019 | }, 3020 | "range-parser": { 3021 | "version": "1.2.1", 3022 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 3023 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 3024 | }, 3025 | "raw-body": { 3026 | "version": "2.5.1", 3027 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 3028 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 3029 | "requires": { 3030 | "bytes": "3.1.2", 3031 | "http-errors": "2.0.0", 3032 | "iconv-lite": "0.4.24", 3033 | "unpipe": "1.0.0" 3034 | } 3035 | }, 3036 | "readable-stream": { 3037 | "version": "3.6.2", 3038 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 3039 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 3040 | "requires": { 3041 | "inherits": "^2.0.3", 3042 | "string_decoder": "^1.1.1", 3043 | "util-deprecate": "^1.0.1" 3044 | } 3045 | }, 3046 | "readdirp": { 3047 | "version": "3.6.0", 3048 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3049 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3050 | "requires": { 3051 | "picomatch": "^2.2.1" 3052 | } 3053 | }, 3054 | "rimraf": { 3055 | "version": "3.0.2", 3056 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3057 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3058 | "requires": { 3059 | "glob": "^7.1.3" 3060 | } 3061 | }, 3062 | "safe-buffer": { 3063 | "version": "5.2.1", 3064 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3065 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 3066 | }, 3067 | "safe-json-stringify": { 3068 | "version": "1.2.0", 3069 | "resolved": "https://registry.npmjs.org/safe-json-stringify/-/safe-json-stringify-1.2.0.tgz", 3070 | "integrity": "sha512-gH8eh2nZudPQO6TytOvbxnuhYBOvDBBLW52tz5q6X58lJcd/tkmqFR+5Z9adS8aJtURSXWThWy/xJtJwixErvg==", 3071 | "optional": true 3072 | }, 3073 | "safer-buffer": { 3074 | "version": "2.1.2", 3075 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 3076 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 3077 | }, 3078 | "saslprep": { 3079 | "version": "1.0.3", 3080 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 3081 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 3082 | "optional": true, 3083 | "requires": { 3084 | "sparse-bitfield": "^3.0.3" 3085 | } 3086 | }, 3087 | "semver": { 3088 | "version": "5.7.1", 3089 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 3090 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 3091 | }, 3092 | "send": { 3093 | "version": "0.18.0", 3094 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 3095 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 3096 | "requires": { 3097 | "debug": "2.6.9", 3098 | "depd": "2.0.0", 3099 | "destroy": "1.2.0", 3100 | "encodeurl": "~1.0.2", 3101 | "escape-html": "~1.0.3", 3102 | "etag": "~1.8.1", 3103 | "fresh": "0.5.2", 3104 | "http-errors": "2.0.0", 3105 | "mime": "1.6.0", 3106 | "ms": "2.1.3", 3107 | "on-finished": "2.4.1", 3108 | "range-parser": "~1.2.1", 3109 | "statuses": "2.0.1" 3110 | }, 3111 | "dependencies": { 3112 | "ms": { 3113 | "version": "2.1.3", 3114 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 3115 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 3116 | } 3117 | } 3118 | }, 3119 | "serve-static": { 3120 | "version": "1.15.0", 3121 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 3122 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 3123 | "requires": { 3124 | "encodeurl": "~1.0.2", 3125 | "escape-html": "~1.0.3", 3126 | "parseurl": "~1.3.3", 3127 | "send": "0.18.0" 3128 | } 3129 | }, 3130 | "set-blocking": { 3131 | "version": "2.0.0", 3132 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 3133 | "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==" 3134 | }, 3135 | "setprototypeof": { 3136 | "version": "1.2.0", 3137 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 3138 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 3139 | }, 3140 | "side-channel": { 3141 | "version": "1.0.4", 3142 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 3143 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 3144 | "requires": { 3145 | "call-bind": "^1.0.0", 3146 | "get-intrinsic": "^1.0.2", 3147 | "object-inspect": "^1.9.0" 3148 | } 3149 | }, 3150 | "sift": { 3151 | "version": "16.0.1", 3152 | "resolved": "https://registry.npmjs.org/sift/-/sift-16.0.1.tgz", 3153 | "integrity": "sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ==" 3154 | }, 3155 | "signal-exit": { 3156 | "version": "3.0.7", 3157 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 3158 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" 3159 | }, 3160 | "simple-update-notifier": { 3161 | "version": "1.1.0", 3162 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-1.1.0.tgz", 3163 | "integrity": "sha512-VpsrsJSUcJEseSbMHkrsrAVSdvVS5I96Qo1QAQ4FxQ9wXFcB+pjj7FB7/us9+GcgfW4ziHtYMc1J0PLczb55mg==", 3164 | "requires": { 3165 | "semver": "~7.0.0" 3166 | }, 3167 | "dependencies": { 3168 | "semver": { 3169 | "version": "7.0.0", 3170 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", 3171 | "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==" 3172 | } 3173 | } 3174 | }, 3175 | "smart-buffer": { 3176 | "version": "4.2.0", 3177 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 3178 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" 3179 | }, 3180 | "socks": { 3181 | "version": "2.7.1", 3182 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 3183 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 3184 | "requires": { 3185 | "ip": "^2.0.0", 3186 | "smart-buffer": "^4.2.0" 3187 | } 3188 | }, 3189 | "sparse-bitfield": { 3190 | "version": "3.0.3", 3191 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 3192 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 3193 | "optional": true, 3194 | "requires": { 3195 | "memory-pager": "^1.0.2" 3196 | } 3197 | }, 3198 | "statuses": { 3199 | "version": "2.0.1", 3200 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 3201 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" 3202 | }, 3203 | "string_decoder": { 3204 | "version": "1.3.0", 3205 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 3206 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 3207 | "requires": { 3208 | "safe-buffer": "~5.2.0" 3209 | } 3210 | }, 3211 | "string-width": { 3212 | "version": "4.2.3", 3213 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3214 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3215 | "requires": { 3216 | "emoji-regex": "^8.0.0", 3217 | "is-fullwidth-code-point": "^3.0.0", 3218 | "strip-ansi": "^6.0.1" 3219 | } 3220 | }, 3221 | "strip-ansi": { 3222 | "version": "6.0.1", 3223 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3224 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3225 | "requires": { 3226 | "ansi-regex": "^5.0.1" 3227 | } 3228 | }, 3229 | "supports-color": { 3230 | "version": "5.5.0", 3231 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3232 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3233 | "requires": { 3234 | "has-flag": "^3.0.0" 3235 | } 3236 | }, 3237 | "tar": { 3238 | "version": "6.1.14", 3239 | "resolved": "https://registry.npmjs.org/tar/-/tar-6.1.14.tgz", 3240 | "integrity": "sha512-piERznXu0U7/pW7cdSn7hjqySIVTYT6F76icmFk7ptU7dDYlXTm5r9A6K04R2vU3olYgoKeo1Cg3eeu5nhftAw==", 3241 | "requires": { 3242 | "chownr": "^2.0.0", 3243 | "fs-minipass": "^2.0.0", 3244 | "minipass": "^5.0.0", 3245 | "minizlib": "^2.1.1", 3246 | "mkdirp": "^1.0.3", 3247 | "yallist": "^4.0.0" 3248 | } 3249 | }, 3250 | "to-regex-range": { 3251 | "version": "5.0.1", 3252 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3253 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3254 | "requires": { 3255 | "is-number": "^7.0.0" 3256 | } 3257 | }, 3258 | "toidentifier": { 3259 | "version": "1.0.1", 3260 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 3261 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 3262 | }, 3263 | "touch": { 3264 | "version": "3.1.0", 3265 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 3266 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 3267 | "requires": { 3268 | "nopt": "~1.0.10" 3269 | } 3270 | }, 3271 | "tr46": { 3272 | "version": "3.0.0", 3273 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 3274 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 3275 | "requires": { 3276 | "punycode": "^2.1.1" 3277 | } 3278 | }, 3279 | "type-is": { 3280 | "version": "1.6.18", 3281 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 3282 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 3283 | "requires": { 3284 | "media-typer": "0.3.0", 3285 | "mime-types": "~2.1.24" 3286 | } 3287 | }, 3288 | "undefsafe": { 3289 | "version": "2.0.5", 3290 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 3291 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==" 3292 | }, 3293 | "unpipe": { 3294 | "version": "1.0.0", 3295 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3296 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==" 3297 | }, 3298 | "util-deprecate": { 3299 | "version": "1.0.2", 3300 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3301 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 3302 | }, 3303 | "utils-merge": { 3304 | "version": "1.0.1", 3305 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3306 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==" 3307 | }, 3308 | "vary": { 3309 | "version": "1.1.2", 3310 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3311 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==" 3312 | }, 3313 | "webidl-conversions": { 3314 | "version": "7.0.0", 3315 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 3316 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==" 3317 | }, 3318 | "whatwg-url": { 3319 | "version": "11.0.0", 3320 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 3321 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 3322 | "requires": { 3323 | "tr46": "^3.0.0", 3324 | "webidl-conversions": "^7.0.0" 3325 | } 3326 | }, 3327 | "wide-align": { 3328 | "version": "1.1.5", 3329 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz", 3330 | "integrity": "sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==", 3331 | "requires": { 3332 | "string-width": "^1.0.2 || 2 || 3 || 4" 3333 | } 3334 | }, 3335 | "wrappy": { 3336 | "version": "1.0.2", 3337 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3338 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 3339 | }, 3340 | "yallist": { 3341 | "version": "4.0.0", 3342 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3343 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 3344 | } 3345 | } 3346 | } 3347 | -------------------------------------------------------------------------------- /auth-back/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "auth-back", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "dependencies": { 13 | "bcrypt": "^5.1.0", 14 | "bunyan": "^1.8.15", 15 | "cors": "^2.8.5", 16 | "dotenv": "^16.0.3", 17 | "express": "^4.18.2", 18 | "jsonwebtoken": "^9.0.0", 19 | "mongoose": "^7.1.1", 20 | "nodemon": "^2.0.22" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /auth-back/routes/login.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const User = require("../schema/user"); 3 | const { jsonResponse } = require("../lib/jsonResponse"); 4 | const getUserInfo = require("../lib/getUserInfo"); 5 | const router = express.Router(); 6 | 7 | router.post("/", async function (req, res, next) { 8 | const { username, password } = req.body; 9 | 10 | try { 11 | let user = new User(); 12 | const userExists = await user.usernameExists(username); 13 | 14 | if (userExists) { 15 | user = await User.findOne({ username: username }); 16 | 17 | const passwordCorrect = await user.isCorrectPassword( 18 | password, 19 | user.password 20 | ); 21 | 22 | if (passwordCorrect) { 23 | const accessToken = user.createAccessToken(); 24 | const refreshToken = await user.createRefreshToken(); 25 | 26 | console.log({ accessToken, refreshToken }); 27 | 28 | return res.json( 29 | jsonResponse(200, { 30 | accessToken, 31 | refreshToken, 32 | user: getUserInfo(user), 33 | }) 34 | ); 35 | } else { 36 | //res.status(401).json({ error: "username and/or password incorrect" }); 37 | 38 | return res.status(401).json( 39 | jsonResponse(401, { 40 | error: "username and/or password incorrect", 41 | }) 42 | ); 43 | } 44 | } else { 45 | return res.status(401).json( 46 | jsonResponse(401, { 47 | error: "username does not exist", 48 | }) 49 | ); 50 | } 51 | } catch (err) { 52 | console.log(err); 53 | } 54 | }); 55 | 56 | module.exports = router; 57 | -------------------------------------------------------------------------------- /auth-back/routes/logout.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | const Token = require("../schema/token"); 4 | const validateToken = require("../auth/validateToken"); 5 | 6 | router.delete("/", async function (req, res, next) { 7 | try { 8 | const refreshToken = validateToken(req.headers); 9 | 10 | await Token.findOneAndRemove({ token: refreshToken }); 11 | res.json({ 12 | success: "Token removed", 13 | }); 14 | } catch (ex) { 15 | return next(new Error("Error loging out the user " + ex.message)); 16 | } 17 | }); 18 | 19 | module.exports = router; 20 | -------------------------------------------------------------------------------- /auth-back/routes/posts.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | const Todo = require("../schema/todo"); 4 | 5 | router.get("/", async (req, res) => { 6 | try { 7 | const items = await Todo.find({ idUser: req.user.id }); 8 | return res.json(items); 9 | } catch (error) { 10 | console.log(error); 11 | return res.status(500).json({ error: "Error al obtener los todos" }); 12 | } 13 | }); 14 | 15 | router.post("/", async (req, res) => { 16 | if (!req.body.title) { 17 | return res.status(400).json({ error: "Title is required" }); 18 | } 19 | 20 | try { 21 | const todo = new Todo({ 22 | idUser: req.user.id, 23 | title: req.body.title, 24 | completed: false, 25 | }); 26 | const todoInfo = await todo.save(); 27 | console.log({ todoInfo }); 28 | res.json(todoInfo); 29 | } catch (error) { 30 | console.log(error); 31 | res.status(500).json({ error: "Error al crear el todo" }); 32 | } 33 | }); 34 | 35 | module.exports = router; 36 | -------------------------------------------------------------------------------- /auth-back/routes/refreshToken.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const { jsonResponse } = require("../lib/jsonResponse"); 3 | const log = require("../lib/trace"); 4 | const { verifyRefreshToken } = require("../auth/verify"); 5 | const { generateAccessToken } = require("../auth/sign"); 6 | const getUserInfo = require("../lib/getUserInfo"); 7 | const Token = require("../schema/token"); 8 | const router = express.Router(); 9 | 10 | router.post("/", async function (req, res, next) { 11 | log.info("POST /api/refresh-token"); 12 | const refreshToken = req.body.refreshToken; 13 | if (!refreshToken) { 14 | console.log("No se proporcionó token de actualización", refreshToken); 15 | return res 16 | .status(401) 17 | .json({ error: "Token de actualización no proporcionado" }); 18 | } 19 | 20 | try { 21 | const tokenDocument = await Token.findOne({ token: refreshToken }); 22 | 23 | if (!tokenDocument) { 24 | return res.status(403).json({ error: "Token de actualización inválido" }); 25 | } 26 | 27 | const payload = verifyRefreshToken(tokenDocument.token); 28 | const accessToken = generateAccessToken(getUserInfo(payload.user)); 29 | res.json(jsonResponse(200, { accessToken })); 30 | } catch (error) { 31 | return res.status(403).json({ error: "Token de actualización inválido" }); 32 | } 33 | }); 34 | 35 | module.exports = router; 36 | -------------------------------------------------------------------------------- /auth-back/routes/signup.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const User = require("../schema/user"); 3 | const { jsonResponse } = require("../lib/jsonResponse"); 4 | const router = express.Router(); 5 | 6 | router.post("/", async function (req, res, next) { 7 | const { username, password, name } = req.body; 8 | 9 | if (!username || !password || !name) { 10 | //return next(new Error("username and password are required")); 11 | return res.status(409).json( 12 | jsonResponse(409, { 13 | error: "username and password are required", 14 | }) 15 | ); 16 | } 17 | 18 | try { 19 | const user = new User(); 20 | const userExists = await user.usernameExists(username); 21 | 22 | if (userExists) { 23 | return res.status(409).json( 24 | jsonResponse(409, { 25 | error: "username already exists", 26 | }) 27 | ); 28 | //return next(new Error("user already exists")); 29 | } else { 30 | const user = new User({ username, password, name }); 31 | 32 | user.save(); 33 | 34 | res.json( 35 | jsonResponse(200, { 36 | message: "User created successfully", 37 | }) 38 | ); 39 | } 40 | } catch (err) { 41 | return res.status(500).json( 42 | jsonResponse(500, { 43 | error: "Error creating user", 44 | }) 45 | ); 46 | //return next(new Error(err.message)); 47 | } 48 | }); 49 | 50 | module.exports = router; 51 | -------------------------------------------------------------------------------- /auth-back/routes/user.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const { jsonResponse } = require("../lib/jsonResponse"); 3 | const log = require("../lib/trace"); 4 | const router = express.Router(); 5 | 6 | router.get("/", async function (req, res, next) { 7 | log.info("user", req.user); 8 | 9 | res.json(jsonResponse(200, req.user)); 10 | }); 11 | 12 | module.exports = router; 13 | -------------------------------------------------------------------------------- /auth-back/schema/todo.js: -------------------------------------------------------------------------------- 1 | const Mongoose = require("mongoose"); 2 | 3 | const TodoSchema = new Mongoose.Schema({ 4 | id: { type: Object }, 5 | idUser: { type: String, required: true }, 6 | title: { type: String, required: true }, 7 | completed: { type: Boolean, required: true }, 8 | }); 9 | 10 | module.exports = Mongoose.model("Todo", TodoSchema); 11 | -------------------------------------------------------------------------------- /auth-back/schema/token.js: -------------------------------------------------------------------------------- 1 | const Mongoose = require("mongoose"); 2 | 3 | const TokenSchema = new Mongoose.Schema({ 4 | id: { type: Object }, 5 | token: { type: String, required: true }, 6 | }); 7 | 8 | module.exports = Mongoose.model("Token", TokenSchema); 9 | -------------------------------------------------------------------------------- /auth-back/schema/user.js: -------------------------------------------------------------------------------- 1 | const Mongoose = require("mongoose"); 2 | const bcrypt = require("bcrypt"); 3 | const { generateAccessToken, generateRefreshToken } = require("../auth/sign"); 4 | const getUserInfo = require("../lib/getUserInfo"); 5 | const Token = require("../schema/token"); 6 | 7 | const UserSchema = new Mongoose.Schema({ 8 | id: { type: Object }, 9 | username: { type: String, required: true, unique: true }, 10 | password: { type: String, required: true }, 11 | name: { type: String, required: true }, 12 | }); 13 | 14 | UserSchema.pre("save", function (next) { 15 | if (this.isModified("password") || this.isNew) { 16 | const document = this; 17 | 18 | bcrypt.hash(document.password, 10, (err, hash) => { 19 | if (err) { 20 | next(err); 21 | } else { 22 | document.password = hash; 23 | next(); 24 | } 25 | }); 26 | } else { 27 | next(); 28 | } 29 | }); 30 | 31 | UserSchema.methods.usernameExists = async function (username) { 32 | const result = await Mongoose.model("User").find({ username: username }); 33 | return result.length > 0; 34 | }; 35 | 36 | UserSchema.methods.isCorrectPassword = async function (password, hash) { 37 | console.log(password, hash); 38 | const same = await bcrypt.compare(password, hash); 39 | 40 | return same; 41 | }; 42 | 43 | UserSchema.methods.createAccessToken = function () { 44 | return generateAccessToken(getUserInfo(this)); 45 | }; 46 | 47 | UserSchema.methods.createRefreshToken = async function (next) { 48 | const refreshToken = generateRefreshToken(getUserInfo(this)); 49 | 50 | console.error("refreshToken", refreshToken); 51 | 52 | try { 53 | await new Token({ token: refreshToken }).save(); 54 | console.log("Token saved", refreshToken); 55 | return refreshToken; 56 | } catch (error) { 57 | console.error(error); 58 | //next(new Error("Error creating token")); 59 | } 60 | }; 61 | 62 | module.exports = Mongoose.model("User", UserSchema); 63 | -------------------------------------------------------------------------------- /auth-front/.eslintrc.cjs: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { browser: true, es2020: true }, 3 | extends: [ 4 | 'eslint:recommended', 5 | 'plugin:@typescript-eslint/recommended', 6 | 'plugin:react-hooks/recommended', 7 | ], 8 | parser: '@typescript-eslint/parser', 9 | parserOptions: { ecmaVersion: 'latest', sourceType: 'module' }, 10 | plugins: ['react-refresh'], 11 | rules: { 12 | 'react-refresh/only-export-components': 'warn', 13 | }, 14 | } 15 | -------------------------------------------------------------------------------- /auth-front/.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | -------------------------------------------------------------------------------- /auth-front/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Vite + React + TS 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /auth-front/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "auth-front", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "tsc && vite build", 9 | "lint": "eslint src --ext ts,tsx --report-unused-disable-directives --max-warnings 0", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "js-cookie": "^3.0.5", 14 | "react": "^18.2.0", 15 | "react-dom": "^18.2.0", 16 | "react-router-dom": "^6.11.1" 17 | }, 18 | "devDependencies": { 19 | "@types/js-cookie": "^3.0.3", 20 | "@types/react": "^18.0.28", 21 | "@types/react-dom": "^18.0.11", 22 | "@typescript-eslint/eslint-plugin": "^5.57.1", 23 | "@typescript-eslint/parser": "^5.57.1", 24 | "@vitejs/plugin-react": "^4.0.0", 25 | "eslint": "^8.38.0", 26 | "eslint-plugin-react-hooks": "^4.6.0", 27 | "eslint-plugin-react-refresh": "^0.3.4", 28 | "typescript": "^5.0.2", 29 | "vite": "^4.3.2" 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /auth-front/public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /auth-front/src/App.css: -------------------------------------------------------------------------------- 1 | #root { 2 | max-width: 1280px; 3 | margin: 0 auto; 4 | padding: 2rem; 5 | text-align: center; 6 | } 7 | 8 | .logo { 9 | height: 6em; 10 | padding: 1.5em; 11 | will-change: filter; 12 | transition: filter 300ms; 13 | } 14 | .logo:hover { 15 | filter: drop-shadow(0 0 2em #646cffaa); 16 | } 17 | .logo.react:hover { 18 | filter: drop-shadow(0 0 2em #61dafbaa); 19 | } 20 | 21 | @keyframes logo-spin { 22 | from { 23 | transform: rotate(0deg); 24 | } 25 | to { 26 | transform: rotate(360deg); 27 | } 28 | } 29 | 30 | @media (prefers-reduced-motion: no-preference) { 31 | a:nth-of-type(2) .logo { 32 | animation: logo-spin infinite 20s linear; 33 | } 34 | } 35 | 36 | .card { 37 | padding: 2em; 38 | } 39 | 40 | .read-the-docs { 41 | color: #888; 42 | } 43 | -------------------------------------------------------------------------------- /auth-front/src/App.tsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import reactLogo from "./assets/react.svg"; 3 | import viteLogo from "/vite.svg"; 4 | 5 | function App() { 6 | const [count, setCount] = useState(0); 7 | 8 | return ( 9 | <> 10 |
11 | 12 | Vite logo 13 | 14 | 15 | React logo 16 | 17 |
18 |

Vite + React

19 |
20 | 23 |

24 | Edit src/App.tsx and save to test HMR 25 |

26 |
27 |

28 | Click on the Vite and React logos to learn more 29 |

30 | 31 | ); 32 | } 33 | 34 | export default App; 35 | -------------------------------------------------------------------------------- /auth-front/src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /auth-front/src/auth/AuthProvider.tsx: -------------------------------------------------------------------------------- 1 | import { useContext, createContext, useState, useEffect } from "react"; 2 | import type { AuthResponse, User } from "../types/types"; 3 | import requestNewAccessToken from "./requestNewAccessToken"; 4 | import { API_URL } from "./authConstants"; 5 | 6 | const AuthContext = createContext({ 7 | isAuthenticated: false, 8 | getAccessToken: () => {}, 9 | setAccessTokenAndRefreshToken: ( 10 | _accessToken: string, 11 | _refreshToken: string 12 | ) => {}, 13 | getRefreshToken: () => {}, 14 | saveUser: (_userData: AuthResponse) => {}, 15 | getUser: () => ({} as User | undefined), 16 | signout: () => {}, 17 | }); 18 | 19 | interface AuthProviderProps { 20 | children: React.ReactNode; 21 | } 22 | 23 | export function AuthProvider({ children }: AuthProviderProps) { 24 | const [user, setUser] = useState(); 25 | const [accessToken, setAccessToken] = useState(""); 26 | const [refreshToken, setRefreshToken] = useState(""); 27 | const [isAuthenticated, setIsAuthenticated] = useState(false); 28 | const [isloading, setIsLoading] = useState(true); 29 | 30 | function getAccessToken() { 31 | return accessToken; 32 | } 33 | 34 | function saveUser(userData: AuthResponse) { 35 | setAccessTokenAndRefreshToken( 36 | userData.body.accessToken, 37 | userData.body.refreshToken 38 | ); 39 | setUser(userData.body.user); 40 | setIsAuthenticated(true); 41 | } 42 | 43 | function setAccessTokenAndRefreshToken( 44 | accessToken: string, 45 | refreshToken: string 46 | ) { 47 | console.log("setAccessTokenAndRefreshToken", accessToken, refreshToken); 48 | setAccessToken(accessToken); 49 | setRefreshToken(refreshToken); 50 | 51 | localStorage.setItem("token", JSON.stringify({ refreshToken })); 52 | } 53 | 54 | function getRefreshToken() { 55 | if (!!refreshToken) { 56 | return refreshToken; 57 | } 58 | const token = localStorage.getItem("token"); 59 | if (token) { 60 | const { refreshToken } = JSON.parse(token); 61 | setRefreshToken(refreshToken); 62 | return refreshToken; 63 | } 64 | return null; 65 | } 66 | 67 | async function getNewAccessToken(refreshToken: string) { 68 | const token = await requestNewAccessToken(refreshToken); 69 | if (token) { 70 | return token; 71 | } 72 | } 73 | 74 | function getUser(): User | undefined { 75 | return user; 76 | } 77 | 78 | function signout() { 79 | localStorage.removeItem("token"); 80 | setAccessToken(""); 81 | setRefreshToken(""); 82 | setUser(undefined); 83 | setIsAuthenticated(false); 84 | } 85 | 86 | async function checkAuth() { 87 | try { 88 | if (!!accessToken) { 89 | //existe access token 90 | const userInfo = await retrieveUserInfo(accessToken); 91 | setUser(userInfo); 92 | setAccessToken(accessToken); 93 | setIsAuthenticated(true); 94 | setIsLoading(false); 95 | } else { 96 | //no existe access token 97 | const token = localStorage.getItem("token"); 98 | if (token) { 99 | console.log("useEffect: token", token); 100 | const refreshToken = JSON.parse(token).refreshToken; 101 | //pedir nuevo access token 102 | getNewAccessToken(refreshToken) 103 | .then(async (newToken) => { 104 | const userInfo = await retrieveUserInfo(newToken!); 105 | setUser(userInfo); 106 | setAccessToken(newToken!); 107 | setIsAuthenticated(true); 108 | setIsLoading(false); 109 | }) 110 | .catch((error) => { 111 | console.log(error); 112 | setIsLoading(false); 113 | }); 114 | } else { 115 | setIsLoading(false); 116 | } 117 | } 118 | } catch (error) { 119 | setIsLoading(false); 120 | } 121 | } 122 | 123 | useEffect(() => { 124 | checkAuth(); 125 | }, []); 126 | 127 | return ( 128 | 139 | {isloading ?
Loading...
: children} 140 |
141 | ); 142 | } 143 | 144 | async function retrieveUserInfo(accessToken: string) { 145 | try { 146 | const response = await fetch(`${API_URL}/user`, { 147 | method: "GET", 148 | headers: { 149 | "Content-Type": "application/json", 150 | Authorization: `Bearer ${accessToken}`, 151 | }, 152 | }); 153 | 154 | if (response.ok) { 155 | const json = await response.json(); 156 | console.log(json); 157 | return json.body; 158 | } 159 | } catch (error) {} 160 | } 161 | 162 | export const useAuth = () => useContext(AuthContext); 163 | -------------------------------------------------------------------------------- /auth-front/src/auth/authConstants.ts: -------------------------------------------------------------------------------- 1 | export const API_URL = "http://localhost:3000/api"; 2 | -------------------------------------------------------------------------------- /auth-front/src/auth/requestNewAccessToken.ts: -------------------------------------------------------------------------------- 1 | import { AccessTokenResponse } from "../types/types"; 2 | import { API_URL } from "./authConstants"; 3 | 4 | export default async function requestNewAccessToken(refreshToken: string) { 5 | const response = await fetch(`${API_URL}/refresh-token`, { 6 | method: "POST", 7 | headers: { 8 | "Content-Type": "application/json", 9 | }, 10 | body: JSON.stringify({ refreshToken }), 11 | }); 12 | 13 | if (response.ok) { 14 | const json = (await response.json()) as AccessTokenResponse; 15 | 16 | if (json.error) { 17 | throw new Error(json.error); 18 | } 19 | return json.body.accessToken; 20 | } else { 21 | throw new Error("Unable to refresh access token."); 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /auth-front/src/index.css: -------------------------------------------------------------------------------- 1 | :root { 2 | font-family: Arial, Helvetica, sans-serif; 3 | line-height: 1.5; 4 | font-weight: 400; 5 | } 6 | 7 | body { 8 | padding: 0; 9 | margin: 0; 10 | } 11 | 12 | label { 13 | display: block; 14 | } 15 | 16 | .form { 17 | width: 400px; 18 | margin: 0 auto; 19 | } 20 | 21 | input[type="text"], 22 | [type="password"] { 23 | display: block; 24 | padding: 10px; 25 | box-sizing: border-box; 26 | width: 100%; 27 | margin: 5px 0 10px 0; 28 | } 29 | 30 | input[type="button"], 31 | button { 32 | background-color: rgb(39, 131, 212); 33 | padding: 10px; 34 | border: 0; 35 | min-width: 100px; 36 | border-radius: 5px; 37 | color: white; 38 | } 39 | 40 | nav { 41 | background-color: #eee; 42 | } 43 | 44 | nav ul { 45 | margin: 0; 46 | } 47 | 48 | nav ul li { 49 | display: inline-block; 50 | padding: 10px; 51 | } 52 | 53 | a { 54 | color: rgb(97, 28, 161); 55 | text-decoration: none; 56 | } 57 | 58 | .dashboard { 59 | width: 500px; 60 | margin: auto; 61 | } 62 | 63 | .errorMessage { 64 | background-color: #f2dede; 65 | color: #a94442; 66 | padding: 10px; 67 | } 68 | -------------------------------------------------------------------------------- /auth-front/src/layout/DefaultLayout.tsx: -------------------------------------------------------------------------------- 1 | import { Link } from "react-router-dom"; 2 | import React from "react"; 3 | 4 | interface DefaultLayoutProps { 5 | children?: React.ReactNode; 6 | } 7 | export default function DefaultLayout({ children }: DefaultLayoutProps) { 8 | return ( 9 | <> 10 |
11 | 21 |
22 | 23 |
{children}
24 | 25 | ); 26 | } 27 | -------------------------------------------------------------------------------- /auth-front/src/layout/PortalLayout.tsx: -------------------------------------------------------------------------------- 1 | import { Link } from "react-router-dom"; 2 | import React, { MouseEvent } from "react"; 3 | import { useAuth } from "../auth/AuthProvider"; 4 | import { API_URL } from "../auth/authConstants"; 5 | 6 | interface PortalLayoutProps { 7 | children?: React.ReactNode; 8 | } 9 | export default function PortalLayout({ children }: PortalLayoutProps) { 10 | const auth = useAuth(); 11 | 12 | async function handleSignOut(e: MouseEvent) { 13 | e.preventDefault(); 14 | 15 | try { 16 | const response = await fetch(`${API_URL}/signout`, { 17 | method: "DELETE", 18 | headers: { 19 | "Content-Type": "application/json", 20 | Authorization: `Bearer ${auth.getRefreshToken()}`, 21 | }, 22 | }); 23 | if (response.ok) { 24 | auth.signout(); 25 | } 26 | } catch (error) { 27 | console.log(error); 28 | } 29 | } 30 | return ( 31 | <> 32 |
33 | 51 |
52 | 53 |
{children}
54 | 55 | ); 56 | } 57 | -------------------------------------------------------------------------------- /auth-front/src/main.tsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import ReactDOM from "react-dom/client"; 3 | 4 | import { createBrowserRouter, RouterProvider } from "react-router-dom"; 5 | import Login from "./routes/Login.tsx"; 6 | import Signup from "./routes/Signup.tsx"; 7 | import { AuthProvider } from "./auth/AuthProvider.tsx"; 8 | import Dashboard from "./routes/Dashboard.tsx"; 9 | import ProtectedRoute from "./routes/ProtectedRoute.tsx"; 10 | import Profile from "./routes/Profile.tsx"; 11 | 12 | import "./index.css"; 13 | 14 | const router = createBrowserRouter([ 15 | { 16 | path: "/", 17 | element: , 18 | }, 19 | { 20 | path: "/signup", 21 | element: , 22 | }, 23 | { 24 | path: "/", 25 | element: , 26 | children: [ 27 | { 28 | path: "/dashboard", 29 | element: , 30 | }, 31 | { 32 | path: "/me", 33 | element: , 34 | }, 35 | ], 36 | }, 37 | ]); 38 | 39 | ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render( 40 | 41 | 42 | 43 | 44 | 45 | ); 46 | -------------------------------------------------------------------------------- /auth-front/src/routes/Dashboard.tsx: -------------------------------------------------------------------------------- 1 | import { useEffect, useState } from "react"; 2 | import PortalLayout from "../layout/PortalLayout"; 3 | import { useAuth } from "../auth/AuthProvider"; 4 | import { API_URL } from "../auth/authConstants"; 5 | 6 | interface Todo { 7 | id: string; 8 | title: string; 9 | completed: boolean; 10 | } 11 | 12 | export default function Dashboard() { 13 | const auth = useAuth(); 14 | 15 | const [todos, setTodos] = useState([]); 16 | const [value, setValue] = useState(""); 17 | 18 | async function getTodos() { 19 | const accessToken = auth.getAccessToken(); 20 | try { 21 | const response = await fetch(`${API_URL}/posts`, { 22 | method: "GET", 23 | headers: { 24 | "Content-Type": "application/json", 25 | Authorization: `Bearer ${accessToken}`, 26 | }, 27 | }); 28 | 29 | if (response.ok) { 30 | const json = await response.json(); 31 | setTodos(json); 32 | console.log(json); 33 | } 34 | } catch (error) { 35 | console.log(error); 36 | } 37 | } 38 | 39 | async function createTodo() { 40 | if (value.length > 3) { 41 | try { 42 | const response = await fetch(`${API_URL}/posts`, { 43 | method: "POST", 44 | headers: { 45 | "Content-Type": "application/json", 46 | Authorization: `Bearer ${auth.getAccessToken()}`, 47 | }, 48 | body: JSON.stringify({ title: value }), 49 | }); 50 | if (response.ok) { 51 | const todo = (await response.json()) as Todo; 52 | setTodos([...todos, todo]); 53 | } 54 | } catch (error) {} 55 | } 56 | } 57 | 58 | useEffect(() => { 59 | getTodos(); 60 | }, []); 61 | 62 | function handleSubmit(e: React.FormEvent) { 63 | e.preventDefault(); 64 | createTodo(); 65 | } 66 | 67 | return ( 68 | 69 |
70 |

Dashboard de {auth.getUser()?.name ?? ""}

71 |
72 | setValue(e.target.value)} 77 | /> 78 |
79 | {todos.map((post: Todo) => ( 80 |
81 |

{post.title}

82 |

{post.completed}

83 |
84 | ))} 85 |
86 |
87 | ); 88 | } 89 | -------------------------------------------------------------------------------- /auth-front/src/routes/Login.tsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import DefaultLayout from "../layout/DefaultLayout"; 3 | import { useAuth } from "../auth/AuthProvider"; 4 | import { Navigate } from "react-router-dom"; 5 | import { AuthResponse, AuthResponseError } from "../types/types"; 6 | 7 | export default function Login() { 8 | const [username, setUsername] = useState(""); 9 | const [password, setPassword] = useState(""); 10 | const [errorResponse, setErrorResponse] = useState(""); 11 | 12 | const auth = useAuth(); 13 | 14 | function handleChange(e: React.ChangeEvent) { 15 | const { name, value } = e.target as HTMLInputElement; 16 | if (name === "username") { 17 | setUsername(value); 18 | } 19 | if (name === "password") { 20 | setPassword(value); 21 | } 22 | } 23 | 24 | async function handleSubmit(e: React.FormEvent) { 25 | e.preventDefault(); 26 | // auth.setIsAuthenticated(true); 27 | try { 28 | const response = await fetch("http://localhost:3000/api/login", { 29 | method: "POST", 30 | headers: { "Content-Type": "application/json" }, 31 | body: JSON.stringify({ username, password }), 32 | }); 33 | if (response.ok) { 34 | const json = (await response.json()) as AuthResponse; 35 | console.log(json); 36 | 37 | if (json.body.accessToken && json.body.refreshToken) { 38 | auth.saveUser(json); 39 | } 40 | } else { 41 | const json = (await response.json()) as AuthResponseError; 42 | 43 | setErrorResponse(json.body.error); 44 | } 45 | } catch (error) { 46 | console.log(error); 47 | } 48 | } 49 | if (auth.isAuthenticated) { 50 | return ; 51 | } 52 | return ( 53 | 54 |
55 |

Login

56 | {!!errorResponse &&
{errorResponse}
} 57 | 58 | 64 | 65 | 71 | 72 | 73 |
74 |
75 | ); 76 | } 77 | -------------------------------------------------------------------------------- /auth-front/src/routes/Profile.tsx: -------------------------------------------------------------------------------- 1 | import PortalLayout from "../layout/PortalLayout"; 2 | 3 | export default function Profile() { 4 | return ( 5 | 6 |

Profile

7 |
8 | ); 9 | } 10 | -------------------------------------------------------------------------------- /auth-front/src/routes/ProtectedRoute.tsx: -------------------------------------------------------------------------------- 1 | import { Outlet, Navigate } from "react-router-dom"; 2 | import { useAuth } from "../auth/AuthProvider"; 3 | 4 | export default function ProtectedRoute() { 5 | const auth = useAuth(); 6 | 7 | return auth.isAuthenticated ? : ; 8 | } 9 | -------------------------------------------------------------------------------- /auth-front/src/routes/Signup.tsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import DefaultLayout from "../layout/DefaultLayout"; 3 | import { useAuth } from "../auth/AuthProvider"; 4 | import { Navigate, useNavigate } from "react-router-dom"; 5 | import { AuthResponse, AuthResponseError } from "../types/types"; 6 | 7 | export default function Signup() { 8 | const [username, setUsername] = useState(""); 9 | const [password, setPassword] = useState(""); 10 | const [name, setName] = useState(""); 11 | const [errorResponse, setErrorResponse] = useState(""); 12 | 13 | const auth = useAuth(); 14 | const goTo = useNavigate(); 15 | 16 | async function handleSubmit(e: React.ChangeEvent) { 17 | e.preventDefault(); 18 | console.log(username, password, name); 19 | 20 | try { 21 | const response = await fetch("http://localhost:3000/api/signup", { 22 | method: "POST", 23 | headers: { "Content-Type": "application/json" }, 24 | body: JSON.stringify({ username, password, name }), 25 | }); 26 | if (response.ok) { 27 | const json = (await response.json()) as AuthResponse; 28 | console.log(json); 29 | setUsername(""); 30 | setPassword(""); 31 | setName(""); 32 | goTo("/"); 33 | } else { 34 | const json = (await response.json()) as AuthResponseError; 35 | 36 | setErrorResponse(json.body.error); 37 | } 38 | } catch (error) { 39 | console.log(error); 40 | } 41 | } 42 | 43 | if (auth.isAuthenticated) { 44 | return ; 45 | } 46 | 47 | return ( 48 | 49 |
50 |

Signup

51 | {!!errorResponse &&
{errorResponse}
} 52 | 53 | setName(e.target.value)} 57 | value={name} 58 | /> 59 | 60 | setUsername(e.target.value)} 64 | value={username} 65 | /> 66 | 67 | setPassword(e.target.value)} 71 | value={password} 72 | /> 73 | 74 | 75 |
76 |
77 | ); 78 | } 79 | -------------------------------------------------------------------------------- /auth-front/src/types/types.ts: -------------------------------------------------------------------------------- 1 | export interface AuthResponse { 2 | body: { 3 | user: User; 4 | accessToken: string; 5 | refreshToken: string; 6 | }; 7 | } 8 | export interface AuthResponseError { 9 | body: { 10 | error: string; 11 | }; 12 | } 13 | 14 | export interface User { 15 | _id: string; 16 | name: string; 17 | username: string; 18 | } 19 | 20 | export interface AccessTokenResponse { 21 | statusCode: number; 22 | body: { 23 | accessToken: string; 24 | }; 25 | error?: string; 26 | } 27 | -------------------------------------------------------------------------------- /auth-front/src/vite-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /auth-front/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ESNext", 4 | "lib": ["DOM", "DOM.Iterable", "ESNext"], 5 | "module": "ESNext", 6 | "skipLibCheck": true, 7 | 8 | /* Bundler mode */ 9 | "moduleResolution": "bundler", 10 | "allowImportingTsExtensions": true, 11 | "resolveJsonModule": true, 12 | "isolatedModules": true, 13 | "noEmit": true, 14 | "jsx": "react-jsx", 15 | 16 | /* Linting */ 17 | "strict": true, 18 | "noUnusedLocals": true, 19 | "noUnusedParameters": true, 20 | "noFallthroughCasesInSwitch": true 21 | }, 22 | "include": ["src"], 23 | "references": [{ "path": "./tsconfig.node.json" }] 24 | } 25 | -------------------------------------------------------------------------------- /auth-front/tsconfig.node.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "skipLibCheck": true, 5 | "module": "ESNext", 6 | "moduleResolution": "bundler", 7 | "allowSyntheticDefaultImports": true 8 | }, 9 | "include": ["vite.config.ts"] 10 | } 11 | -------------------------------------------------------------------------------- /auth-front/vite.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()], 7 | }) 8 | --------------------------------------------------------------------------------