├── .DS_Store ├── .env.example ├── .gitignore ├── app.js ├── config ├── development.json └── mongoose-connection.js ├── controllers └── authController.js ├── designs ├── Desktop - 70.png ├── Desktop - 71.png ├── Desktop - 72.png ├── Desktop - 73.png └── Desktop - 74.png ├── middlewares └── isLoggedIn.js ├── models ├── owner-model.js ├── product-model.js └── user-model.js ├── package-lock.json ├── package.json ├── public ├── images │ └── .gitkeep ├── javascripts │ └── .gitkeep └── stylesheets │ └── .gitkeep ├── routes ├── index.js ├── ownersRouter.js ├── productsRouter.js └── usersRouter.js ├── utils └── generateToken.js └── views ├── .gitkeep ├── admin.ejs ├── cart.ejs ├── createproducts.ejs ├── index.ejs ├── owner-login.ejs ├── partials ├── footer.ejs └── header.ejs └── shop.ejs /.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/.DS_Store -------------------------------------------------------------------------------- /.env.example: -------------------------------------------------------------------------------- 1 | JWT_KEY=YOUR_JWT_KEY 2 | NODE_ENV=development 3 | EXPRESS_SESSION_SECRET=YOUR_EXPRESS_SESSION_SECRET -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | .env -------------------------------------------------------------------------------- /app.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const app = express(); 3 | const cookieParser = require("cookie-parser"); 4 | const path = require("path"); 5 | const expressSession = require("express-session"); 6 | const flash = require("connect-flash"); 7 | 8 | require("dotenv").config(); 9 | 10 | const ownersRouter = require("./routes/ownersRouter"); 11 | const productsRouter = require("./routes/productsRouter"); 12 | const usersRouter = require("./routes/usersRouter"); 13 | const indexRouter = require("./routes/index"); 14 | 15 | const db = require("./config/mongoose-connection"); 16 | 17 | app.use(express.json()); 18 | app.use(express.urlencoded({ extended: true })); 19 | app.use(cookieParser()); 20 | app.use( 21 | expressSession({ 22 | resave: false, 23 | saveUninitialized: false, 24 | secret: process.env.EXPRESS_SESSION_SECRET, 25 | }) 26 | ); 27 | app.use(flash()); 28 | app.use(express.static(path.join(__dirname, "public"))); 29 | app.set("view engine", "ejs"); 30 | 31 | app.use("/", indexRouter); 32 | app.use("/owners", ownersRouter); 33 | app.use("/users", usersRouter); 34 | app.use("/products", productsRouter); 35 | 36 | app.listen(3000); 37 | -------------------------------------------------------------------------------- /config/development.json: -------------------------------------------------------------------------------- 1 | { 2 | "MONGODB_URI": "mongodb://127.0.0.1:27017" 3 | } 4 | -------------------------------------------------------------------------------- /config/mongoose-connection.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | const config = require("config"); 3 | 4 | const dbgr = require("debug")("development:mongoose"); 5 | 6 | mongoose 7 | .connect(`${config.get("MONGODB_URI")}/scatch`) 8 | .then(function () { 9 | dbgr("connected"); 10 | }) 11 | .catch(function (err) { 12 | dbgr(err); 13 | }); 14 | 15 | module.exports = mongoose.connection; 16 | -------------------------------------------------------------------------------- /controllers/authController.js: -------------------------------------------------------------------------------- 1 | const userModel = require("../models/user-model"); 2 | const bcrypt = require("bcrypt"); 3 | const { generateToken } = require("../utils/generateToken"); 4 | 5 | module.exports.registerUser = async function (req, res) { 6 | try { 7 | let { email, password, fullname } = req.body; 8 | 9 | let user = await userModel.findOne({ email: email }); 10 | if (user) { 11 | req.flash("error", "You already have an account, please login."); 12 | return res.redirect("/"); 13 | } 14 | 15 | bcrypt.genSalt(10, function (err, salt) { 16 | bcrypt.hash(password, salt, async function (err, hash) { 17 | if (err) return res.send(err.message); 18 | else { 19 | let user = await userModel.create({ 20 | email, 21 | password: hash, 22 | fullname, 23 | }); 24 | 25 | let token = generateToken(user); 26 | res.cookie("token", token); 27 | 28 | res.redirect("/shop"); 29 | } 30 | }); 31 | }); 32 | } catch (err) { 33 | res.send(err.message); 34 | } 35 | }; 36 | 37 | module.exports.loginUser = async function (req, res) { 38 | let { email, password } = req.body; 39 | 40 | let user = await userModel.findOne({ email: email }); 41 | if (!user) { 42 | req.flash("error", "Email or Password incorrect"); 43 | return res.redirect("/"); 44 | } 45 | 46 | bcrypt.compare(password, user.password, function (err, result) { 47 | if (result) { 48 | let token = generateToken(user); 49 | res.cookie("token", token); 50 | res.redirect("/shop"); 51 | } else { 52 | req.flash("error", "Email or Password incorrect"); 53 | return res.redirect("/"); 54 | } 55 | }); 56 | }; 57 | 58 | module.exports.logout = function (req, res) { 59 | res.cookie("token", ""); 60 | res.redirect("/"); 61 | }; 62 | -------------------------------------------------------------------------------- /designs/Desktop - 70.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/designs/Desktop - 70.png -------------------------------------------------------------------------------- /designs/Desktop - 71.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/designs/Desktop - 71.png -------------------------------------------------------------------------------- /designs/Desktop - 72.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/designs/Desktop - 72.png -------------------------------------------------------------------------------- /designs/Desktop - 73.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/designs/Desktop - 73.png -------------------------------------------------------------------------------- /designs/Desktop - 74.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/designs/Desktop - 74.png -------------------------------------------------------------------------------- /middlewares/isLoggedIn.js: -------------------------------------------------------------------------------- 1 | const jwt = require("jsonwebtoken"); 2 | const userModel = require("../models/user-model"); 3 | 4 | module.exports = async function (req, res, next) { 5 | if (!req.cookies.token) { 6 | req.flash("error", "you need to login first"); 7 | return res.redirect("/"); 8 | } 9 | 10 | try { 11 | let decoded = jwt.verify(req.cookies.token, process.env.JWT_KEY); 12 | let user = await userModel 13 | .findOne({ email: decoded.email }) 14 | .select("-password"); 15 | req.user = user; 16 | next(); 17 | } catch (err) { 18 | req.flash("error", "you need to login first"); 19 | res.redirect("/"); 20 | } 21 | }; 22 | -------------------------------------------------------------------------------- /models/owner-model.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | 3 | const ownerSchema = mongoose.Schema({ 4 | fullname: { 5 | type: String, 6 | minLength: 3, 7 | trim: true, 8 | }, 9 | email: String, 10 | password: String, 11 | products: { 12 | type: Array, 13 | default: [], 14 | }, 15 | picture: String, 16 | gstin: String, 17 | }); 18 | 19 | module.exports = mongoose.model("owner", ownerSchema); 20 | -------------------------------------------------------------------------------- /models/product-model.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | 3 | const productSchema = mongoose.Schema({ 4 | image: String, 5 | name: String, 6 | price: Number, 7 | discount: { 8 | type: Number, 9 | default: 0, 10 | }, 11 | bgcolor: String, 12 | panelcolor: String, 13 | textcolor: String, 14 | }); 15 | 16 | module.exports = mongoose.model("product", productSchema); 17 | -------------------------------------------------------------------------------- /models/user-model.js: -------------------------------------------------------------------------------- 1 | const mongoose = require("mongoose"); 2 | 3 | const userSchema = mongoose.Schema({ 4 | fullname: { 5 | type: String, 6 | minLength: 3, 7 | trim: true, 8 | }, 9 | email: String, 10 | password: String, 11 | cart: { 12 | type: Array, 13 | default: [], 14 | }, 15 | orders: { 16 | type: Array, 17 | default: [], 18 | }, 19 | contact: Number, 20 | picture: String, 21 | }); 22 | 23 | module.exports = mongoose.model("user", userSchema); 24 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "scatch", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "scatch", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "bcrypt": "^5.1.1", 13 | "config": "^3.3.11", 14 | "connect-flash": "^0.1.1", 15 | "cookie-parser": "^1.4.6", 16 | "debug": "^4.3.4", 17 | "dotenv": "^16.4.5", 18 | "ejs": "^3.1.10", 19 | "express": "^4.19.2", 20 | "express-session": "^1.18.0", 21 | "jsonwebtoken": "^9.0.2", 22 | "mongoose": "^8.3.5" 23 | } 24 | }, 25 | "node_modules/@mapbox/node-pre-gyp": { 26 | "version": "1.0.11", 27 | "resolved": "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.11.tgz", 28 | "integrity": "sha512-Yhlar6v9WQgUp/He7BdgzOz8lqMQ8sU+jkCq7Wx8Myc5YFJLbEe7lgui/V7G1qB1DJykHSGwreceSaD60Y0PUQ==", 29 | "dependencies": { 30 | "detect-libc": "^2.0.0", 31 | "https-proxy-agent": "^5.0.0", 32 | "make-dir": "^3.1.0", 33 | "node-fetch": "^2.6.7", 34 | "nopt": "^5.0.0", 35 | "npmlog": "^5.0.1", 36 | "rimraf": "^3.0.2", 37 | "semver": "^7.3.5", 38 | "tar": "^6.1.11" 39 | }, 40 | "bin": { 41 | "node-pre-gyp": "bin/node-pre-gyp" 42 | } 43 | }, 44 | "node_modules/@mongodb-js/saslprep": { 45 | "version": "1.1.7", 46 | "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.7.tgz", 47 | "integrity": "sha512-dCHW/oEX0KJ4NjDULBo3JiOaK5+6axtpBbS+ao2ZInoAL9/YRQLhXzSNAFz7hP4nzLkIqsfYAK/PDE3+XHny0Q==", 48 | "dependencies": { 49 | "sparse-bitfield": "^3.0.3" 50 | } 51 | }, 52 | "node_modules/@types/webidl-conversions": { 53 | "version": "7.0.3", 54 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.3.tgz", 55 | "integrity": "sha512-CiJJvcRtIgzadHCYXw7dqEnMNRjhGZlYK05Mj9OyktqV8uVT8fD2BFOB7S1uwBE3Kj2Z+4UyPmFw/Ixgw/LAlA==" 56 | }, 57 | "node_modules/@types/whatwg-url": { 58 | "version": "11.0.4", 59 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-11.0.4.tgz", 60 | "integrity": "sha512-lXCmTWSHJvf0TRSO58nm978b8HJ/EdsSsEKLd3ODHFjo+3VGAyyTp4v50nWvwtzBxSMQrVOK7tcuN0zGPLICMw==", 61 | "dependencies": { 62 | "@types/webidl-conversions": "*" 63 | } 64 | }, 65 | "node_modules/abbrev": { 66 | "version": "1.1.1", 67 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 68 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 69 | }, 70 | "node_modules/accepts": { 71 | "version": "1.3.8", 72 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 73 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 74 | "dependencies": { 75 | "mime-types": "~2.1.34", 76 | "negotiator": "0.6.3" 77 | }, 78 | "engines": { 79 | "node": ">= 0.6" 80 | } 81 | }, 82 | "node_modules/agent-base": { 83 | "version": "6.0.2", 84 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 85 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 86 | "dependencies": { 87 | "debug": "4" 88 | }, 89 | "engines": { 90 | "node": ">= 6.0.0" 91 | } 92 | }, 93 | "node_modules/ansi-regex": { 94 | "version": "5.0.1", 95 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 96 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 97 | "engines": { 98 | "node": ">=8" 99 | } 100 | }, 101 | "node_modules/ansi-styles": { 102 | "version": "4.3.0", 103 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 104 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 105 | "dependencies": { 106 | "color-convert": "^2.0.1" 107 | }, 108 | "engines": { 109 | "node": ">=8" 110 | }, 111 | "funding": { 112 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 113 | } 114 | }, 115 | "node_modules/aproba": { 116 | "version": "2.0.0", 117 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz", 118 | "integrity": "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==" 119 | }, 120 | "node_modules/are-we-there-yet": { 121 | "version": "2.0.0", 122 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz", 123 | "integrity": "sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw==", 124 | "dependencies": { 125 | "delegates": "^1.0.0", 126 | "readable-stream": "^3.6.0" 127 | }, 128 | "engines": { 129 | "node": ">=10" 130 | } 131 | }, 132 | "node_modules/array-flatten": { 133 | "version": "1.1.1", 134 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 135 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 136 | }, 137 | "node_modules/async": { 138 | "version": "3.2.5", 139 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.5.tgz", 140 | "integrity": "sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg==" 141 | }, 142 | "node_modules/balanced-match": { 143 | "version": "1.0.2", 144 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 145 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 146 | }, 147 | "node_modules/bcrypt": { 148 | "version": "5.1.1", 149 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.1.1.tgz", 150 | "integrity": "sha512-AGBHOG5hPYZ5Xl9KXzU5iKq9516yEmvCKDg3ecP5kX2aB6UqTeXZxk2ELnDgDm6BQSMlLt9rDB4LoSMx0rYwww==", 151 | "hasInstallScript": true, 152 | "dependencies": { 153 | "@mapbox/node-pre-gyp": "^1.0.11", 154 | "node-addon-api": "^5.0.0" 155 | }, 156 | "engines": { 157 | "node": ">= 10.0.0" 158 | } 159 | }, 160 | "node_modules/body-parser": { 161 | "version": "1.20.2", 162 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz", 163 | "integrity": "sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==", 164 | "dependencies": { 165 | "bytes": "3.1.2", 166 | "content-type": "~1.0.5", 167 | "debug": "2.6.9", 168 | "depd": "2.0.0", 169 | "destroy": "1.2.0", 170 | "http-errors": "2.0.0", 171 | "iconv-lite": "0.4.24", 172 | "on-finished": "2.4.1", 173 | "qs": "6.11.0", 174 | "raw-body": "2.5.2", 175 | "type-is": "~1.6.18", 176 | "unpipe": "1.0.0" 177 | }, 178 | "engines": { 179 | "node": ">= 0.8", 180 | "npm": "1.2.8000 || >= 1.4.16" 181 | } 182 | }, 183 | "node_modules/body-parser/node_modules/debug": { 184 | "version": "2.6.9", 185 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 186 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 187 | "dependencies": { 188 | "ms": "2.0.0" 189 | } 190 | }, 191 | "node_modules/body-parser/node_modules/ms": { 192 | "version": "2.0.0", 193 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 194 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 195 | }, 196 | "node_modules/brace-expansion": { 197 | "version": "1.1.11", 198 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 199 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 200 | "dependencies": { 201 | "balanced-match": "^1.0.0", 202 | "concat-map": "0.0.1" 203 | } 204 | }, 205 | "node_modules/bson": { 206 | "version": "6.7.0", 207 | "resolved": "https://registry.npmjs.org/bson/-/bson-6.7.0.tgz", 208 | "integrity": "sha512-w2IquM5mYzYZv6rs3uN2DZTOBe2a0zXLj53TGDqwF4l6Sz/XsISrisXOJihArF9+BZ6Cq/GjVht7Sjfmri7ytQ==", 209 | "engines": { 210 | "node": ">=16.20.1" 211 | } 212 | }, 213 | "node_modules/buffer-equal-constant-time": { 214 | "version": "1.0.1", 215 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 216 | "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" 217 | }, 218 | "node_modules/bytes": { 219 | "version": "3.1.2", 220 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 221 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 222 | "engines": { 223 | "node": ">= 0.8" 224 | } 225 | }, 226 | "node_modules/call-bind": { 227 | "version": "1.0.7", 228 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", 229 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", 230 | "dependencies": { 231 | "es-define-property": "^1.0.0", 232 | "es-errors": "^1.3.0", 233 | "function-bind": "^1.1.2", 234 | "get-intrinsic": "^1.2.4", 235 | "set-function-length": "^1.2.1" 236 | }, 237 | "engines": { 238 | "node": ">= 0.4" 239 | }, 240 | "funding": { 241 | "url": "https://github.com/sponsors/ljharb" 242 | } 243 | }, 244 | "node_modules/chalk": { 245 | "version": "4.1.2", 246 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 247 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 248 | "dependencies": { 249 | "ansi-styles": "^4.1.0", 250 | "supports-color": "^7.1.0" 251 | }, 252 | "engines": { 253 | "node": ">=10" 254 | }, 255 | "funding": { 256 | "url": "https://github.com/chalk/chalk?sponsor=1" 257 | } 258 | }, 259 | "node_modules/chownr": { 260 | "version": "2.0.0", 261 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", 262 | "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==", 263 | "engines": { 264 | "node": ">=10" 265 | } 266 | }, 267 | "node_modules/color-convert": { 268 | "version": "2.0.1", 269 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 270 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 271 | "dependencies": { 272 | "color-name": "~1.1.4" 273 | }, 274 | "engines": { 275 | "node": ">=7.0.0" 276 | } 277 | }, 278 | "node_modules/color-name": { 279 | "version": "1.1.4", 280 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 281 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 282 | }, 283 | "node_modules/color-support": { 284 | "version": "1.1.3", 285 | "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", 286 | "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==", 287 | "bin": { 288 | "color-support": "bin.js" 289 | } 290 | }, 291 | "node_modules/concat-map": { 292 | "version": "0.0.1", 293 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 294 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" 295 | }, 296 | "node_modules/config": { 297 | "version": "3.3.11", 298 | "resolved": "https://registry.npmjs.org/config/-/config-3.3.11.tgz", 299 | "integrity": "sha512-Dhn63ZoWCW5EMg4P0Sl/XNsj/7RLiUIA1x1npCy+m2cRwRHzLnt3UtYtxRDMZW/6oOMdWhCzaGYkOcajGgrAOA==", 300 | "dependencies": { 301 | "json5": "^2.2.3" 302 | }, 303 | "engines": { 304 | "node": ">= 10.0.0" 305 | } 306 | }, 307 | "node_modules/connect-flash": { 308 | "version": "0.1.1", 309 | "resolved": "https://registry.npmjs.org/connect-flash/-/connect-flash-0.1.1.tgz", 310 | "integrity": "sha512-2rcfELQt/ZMP+SM/pG8PyhJRaLKp+6Hk2IUBNkEit09X+vwn3QsAL3ZbYtxUn7NVPzbMTSLRDhqe0B/eh30RYA==", 311 | "engines": { 312 | "node": ">= 0.4.0" 313 | } 314 | }, 315 | "node_modules/console-control-strings": { 316 | "version": "1.1.0", 317 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 318 | "integrity": "sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==" 319 | }, 320 | "node_modules/content-disposition": { 321 | "version": "0.5.4", 322 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 323 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 324 | "dependencies": { 325 | "safe-buffer": "5.2.1" 326 | }, 327 | "engines": { 328 | "node": ">= 0.6" 329 | } 330 | }, 331 | "node_modules/content-type": { 332 | "version": "1.0.5", 333 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 334 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 335 | "engines": { 336 | "node": ">= 0.6" 337 | } 338 | }, 339 | "node_modules/cookie": { 340 | "version": "0.4.1", 341 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 342 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==", 343 | "engines": { 344 | "node": ">= 0.6" 345 | } 346 | }, 347 | "node_modules/cookie-parser": { 348 | "version": "1.4.6", 349 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.6.tgz", 350 | "integrity": "sha512-z3IzaNjdwUC2olLIB5/ITd0/setiaFMLYiZJle7xg5Fe9KWAceil7xszYfHHBtDFYLSgJduS2Ty0P1uJdPDJeA==", 351 | "dependencies": { 352 | "cookie": "0.4.1", 353 | "cookie-signature": "1.0.6" 354 | }, 355 | "engines": { 356 | "node": ">= 0.8.0" 357 | } 358 | }, 359 | "node_modules/cookie-signature": { 360 | "version": "1.0.6", 361 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 362 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 363 | }, 364 | "node_modules/debug": { 365 | "version": "4.3.4", 366 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 367 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 368 | "dependencies": { 369 | "ms": "2.1.2" 370 | }, 371 | "engines": { 372 | "node": ">=6.0" 373 | }, 374 | "peerDependenciesMeta": { 375 | "supports-color": { 376 | "optional": true 377 | } 378 | } 379 | }, 380 | "node_modules/define-data-property": { 381 | "version": "1.1.4", 382 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", 383 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", 384 | "dependencies": { 385 | "es-define-property": "^1.0.0", 386 | "es-errors": "^1.3.0", 387 | "gopd": "^1.0.1" 388 | }, 389 | "engines": { 390 | "node": ">= 0.4" 391 | }, 392 | "funding": { 393 | "url": "https://github.com/sponsors/ljharb" 394 | } 395 | }, 396 | "node_modules/delegates": { 397 | "version": "1.0.0", 398 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 399 | "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==" 400 | }, 401 | "node_modules/depd": { 402 | "version": "2.0.0", 403 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 404 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 405 | "engines": { 406 | "node": ">= 0.8" 407 | } 408 | }, 409 | "node_modules/destroy": { 410 | "version": "1.2.0", 411 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 412 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 413 | "engines": { 414 | "node": ">= 0.8", 415 | "npm": "1.2.8000 || >= 1.4.16" 416 | } 417 | }, 418 | "node_modules/detect-libc": { 419 | "version": "2.0.3", 420 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.3.tgz", 421 | "integrity": "sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==", 422 | "engines": { 423 | "node": ">=8" 424 | } 425 | }, 426 | "node_modules/dotenv": { 427 | "version": "16.4.5", 428 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.4.5.tgz", 429 | "integrity": "sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==", 430 | "engines": { 431 | "node": ">=12" 432 | }, 433 | "funding": { 434 | "url": "https://dotenvx.com" 435 | } 436 | }, 437 | "node_modules/ecdsa-sig-formatter": { 438 | "version": "1.0.11", 439 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 440 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 441 | "dependencies": { 442 | "safe-buffer": "^5.0.1" 443 | } 444 | }, 445 | "node_modules/ee-first": { 446 | "version": "1.1.1", 447 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 448 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 449 | }, 450 | "node_modules/ejs": { 451 | "version": "3.1.10", 452 | "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.10.tgz", 453 | "integrity": "sha512-UeJmFfOrAQS8OJWPZ4qtgHyWExa088/MtK5UEyoJGFH67cDEXkZSviOiKRCZ4Xij0zxI3JECgYs3oKx+AizQBA==", 454 | "dependencies": { 455 | "jake": "^10.8.5" 456 | }, 457 | "bin": { 458 | "ejs": "bin/cli.js" 459 | }, 460 | "engines": { 461 | "node": ">=0.10.0" 462 | } 463 | }, 464 | "node_modules/emoji-regex": { 465 | "version": "8.0.0", 466 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 467 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 468 | }, 469 | "node_modules/encodeurl": { 470 | "version": "1.0.2", 471 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 472 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 473 | "engines": { 474 | "node": ">= 0.8" 475 | } 476 | }, 477 | "node_modules/es-define-property": { 478 | "version": "1.0.0", 479 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", 480 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", 481 | "dependencies": { 482 | "get-intrinsic": "^1.2.4" 483 | }, 484 | "engines": { 485 | "node": ">= 0.4" 486 | } 487 | }, 488 | "node_modules/es-errors": { 489 | "version": "1.3.0", 490 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 491 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 492 | "engines": { 493 | "node": ">= 0.4" 494 | } 495 | }, 496 | "node_modules/escape-html": { 497 | "version": "1.0.3", 498 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 499 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 500 | }, 501 | "node_modules/etag": { 502 | "version": "1.8.1", 503 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 504 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 505 | "engines": { 506 | "node": ">= 0.6" 507 | } 508 | }, 509 | "node_modules/express": { 510 | "version": "4.19.2", 511 | "resolved": "https://registry.npmjs.org/express/-/express-4.19.2.tgz", 512 | "integrity": "sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==", 513 | "dependencies": { 514 | "accepts": "~1.3.8", 515 | "array-flatten": "1.1.1", 516 | "body-parser": "1.20.2", 517 | "content-disposition": "0.5.4", 518 | "content-type": "~1.0.4", 519 | "cookie": "0.6.0", 520 | "cookie-signature": "1.0.6", 521 | "debug": "2.6.9", 522 | "depd": "2.0.0", 523 | "encodeurl": "~1.0.2", 524 | "escape-html": "~1.0.3", 525 | "etag": "~1.8.1", 526 | "finalhandler": "1.2.0", 527 | "fresh": "0.5.2", 528 | "http-errors": "2.0.0", 529 | "merge-descriptors": "1.0.1", 530 | "methods": "~1.1.2", 531 | "on-finished": "2.4.1", 532 | "parseurl": "~1.3.3", 533 | "path-to-regexp": "0.1.7", 534 | "proxy-addr": "~2.0.7", 535 | "qs": "6.11.0", 536 | "range-parser": "~1.2.1", 537 | "safe-buffer": "5.2.1", 538 | "send": "0.18.0", 539 | "serve-static": "1.15.0", 540 | "setprototypeof": "1.2.0", 541 | "statuses": "2.0.1", 542 | "type-is": "~1.6.18", 543 | "utils-merge": "1.0.1", 544 | "vary": "~1.1.2" 545 | }, 546 | "engines": { 547 | "node": ">= 0.10.0" 548 | } 549 | }, 550 | "node_modules/express-session": { 551 | "version": "1.18.0", 552 | "resolved": "https://registry.npmjs.org/express-session/-/express-session-1.18.0.tgz", 553 | "integrity": "sha512-m93QLWr0ju+rOwApSsyso838LQwgfs44QtOP/WBiwtAgPIo/SAh1a5c6nn2BR6mFNZehTpqKDESzP+fRHVbxwQ==", 554 | "dependencies": { 555 | "cookie": "0.6.0", 556 | "cookie-signature": "1.0.7", 557 | "debug": "2.6.9", 558 | "depd": "~2.0.0", 559 | "on-headers": "~1.0.2", 560 | "parseurl": "~1.3.3", 561 | "safe-buffer": "5.2.1", 562 | "uid-safe": "~2.1.5" 563 | }, 564 | "engines": { 565 | "node": ">= 0.8.0" 566 | } 567 | }, 568 | "node_modules/express-session/node_modules/cookie": { 569 | "version": "0.6.0", 570 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", 571 | "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", 572 | "engines": { 573 | "node": ">= 0.6" 574 | } 575 | }, 576 | "node_modules/express-session/node_modules/cookie-signature": { 577 | "version": "1.0.7", 578 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.7.tgz", 579 | "integrity": "sha512-NXdYc3dLr47pBkpUCHtKSwIOQXLVn8dZEuywboCOJY/osA0wFSLlSawr3KN8qXJEyX66FcONTH8EIlVuK0yyFA==" 580 | }, 581 | "node_modules/express-session/node_modules/debug": { 582 | "version": "2.6.9", 583 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 584 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 585 | "dependencies": { 586 | "ms": "2.0.0" 587 | } 588 | }, 589 | "node_modules/express-session/node_modules/ms": { 590 | "version": "2.0.0", 591 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 592 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 593 | }, 594 | "node_modules/express/node_modules/cookie": { 595 | "version": "0.6.0", 596 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", 597 | "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", 598 | "engines": { 599 | "node": ">= 0.6" 600 | } 601 | }, 602 | "node_modules/express/node_modules/debug": { 603 | "version": "2.6.9", 604 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 605 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 606 | "dependencies": { 607 | "ms": "2.0.0" 608 | } 609 | }, 610 | "node_modules/express/node_modules/ms": { 611 | "version": "2.0.0", 612 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 613 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 614 | }, 615 | "node_modules/filelist": { 616 | "version": "1.0.4", 617 | "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz", 618 | "integrity": "sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q==", 619 | "dependencies": { 620 | "minimatch": "^5.0.1" 621 | } 622 | }, 623 | "node_modules/filelist/node_modules/brace-expansion": { 624 | "version": "2.0.1", 625 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 626 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 627 | "dependencies": { 628 | "balanced-match": "^1.0.0" 629 | } 630 | }, 631 | "node_modules/filelist/node_modules/minimatch": { 632 | "version": "5.1.6", 633 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 634 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 635 | "dependencies": { 636 | "brace-expansion": "^2.0.1" 637 | }, 638 | "engines": { 639 | "node": ">=10" 640 | } 641 | }, 642 | "node_modules/finalhandler": { 643 | "version": "1.2.0", 644 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 645 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 646 | "dependencies": { 647 | "debug": "2.6.9", 648 | "encodeurl": "~1.0.2", 649 | "escape-html": "~1.0.3", 650 | "on-finished": "2.4.1", 651 | "parseurl": "~1.3.3", 652 | "statuses": "2.0.1", 653 | "unpipe": "~1.0.0" 654 | }, 655 | "engines": { 656 | "node": ">= 0.8" 657 | } 658 | }, 659 | "node_modules/finalhandler/node_modules/debug": { 660 | "version": "2.6.9", 661 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 662 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 663 | "dependencies": { 664 | "ms": "2.0.0" 665 | } 666 | }, 667 | "node_modules/finalhandler/node_modules/ms": { 668 | "version": "2.0.0", 669 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 670 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 671 | }, 672 | "node_modules/forwarded": { 673 | "version": "0.2.0", 674 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 675 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 676 | "engines": { 677 | "node": ">= 0.6" 678 | } 679 | }, 680 | "node_modules/fresh": { 681 | "version": "0.5.2", 682 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 683 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 684 | "engines": { 685 | "node": ">= 0.6" 686 | } 687 | }, 688 | "node_modules/fs-minipass": { 689 | "version": "2.1.0", 690 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", 691 | "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", 692 | "dependencies": { 693 | "minipass": "^3.0.0" 694 | }, 695 | "engines": { 696 | "node": ">= 8" 697 | } 698 | }, 699 | "node_modules/fs-minipass/node_modules/minipass": { 700 | "version": "3.3.6", 701 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 702 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 703 | "dependencies": { 704 | "yallist": "^4.0.0" 705 | }, 706 | "engines": { 707 | "node": ">=8" 708 | } 709 | }, 710 | "node_modules/fs.realpath": { 711 | "version": "1.0.0", 712 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 713 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" 714 | }, 715 | "node_modules/function-bind": { 716 | "version": "1.1.2", 717 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 718 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 719 | "funding": { 720 | "url": "https://github.com/sponsors/ljharb" 721 | } 722 | }, 723 | "node_modules/gauge": { 724 | "version": "3.0.2", 725 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-3.0.2.tgz", 726 | "integrity": "sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q==", 727 | "dependencies": { 728 | "aproba": "^1.0.3 || ^2.0.0", 729 | "color-support": "^1.1.2", 730 | "console-control-strings": "^1.0.0", 731 | "has-unicode": "^2.0.1", 732 | "object-assign": "^4.1.1", 733 | "signal-exit": "^3.0.0", 734 | "string-width": "^4.2.3", 735 | "strip-ansi": "^6.0.1", 736 | "wide-align": "^1.1.2" 737 | }, 738 | "engines": { 739 | "node": ">=10" 740 | } 741 | }, 742 | "node_modules/get-intrinsic": { 743 | "version": "1.2.4", 744 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", 745 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", 746 | "dependencies": { 747 | "es-errors": "^1.3.0", 748 | "function-bind": "^1.1.2", 749 | "has-proto": "^1.0.1", 750 | "has-symbols": "^1.0.3", 751 | "hasown": "^2.0.0" 752 | }, 753 | "engines": { 754 | "node": ">= 0.4" 755 | }, 756 | "funding": { 757 | "url": "https://github.com/sponsors/ljharb" 758 | } 759 | }, 760 | "node_modules/glob": { 761 | "version": "7.2.3", 762 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 763 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 764 | "dependencies": { 765 | "fs.realpath": "^1.0.0", 766 | "inflight": "^1.0.4", 767 | "inherits": "2", 768 | "minimatch": "^3.1.1", 769 | "once": "^1.3.0", 770 | "path-is-absolute": "^1.0.0" 771 | }, 772 | "engines": { 773 | "node": "*" 774 | }, 775 | "funding": { 776 | "url": "https://github.com/sponsors/isaacs" 777 | } 778 | }, 779 | "node_modules/gopd": { 780 | "version": "1.0.1", 781 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 782 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 783 | "dependencies": { 784 | "get-intrinsic": "^1.1.3" 785 | }, 786 | "funding": { 787 | "url": "https://github.com/sponsors/ljharb" 788 | } 789 | }, 790 | "node_modules/has-flag": { 791 | "version": "4.0.0", 792 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 793 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 794 | "engines": { 795 | "node": ">=8" 796 | } 797 | }, 798 | "node_modules/has-property-descriptors": { 799 | "version": "1.0.2", 800 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", 801 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", 802 | "dependencies": { 803 | "es-define-property": "^1.0.0" 804 | }, 805 | "funding": { 806 | "url": "https://github.com/sponsors/ljharb" 807 | } 808 | }, 809 | "node_modules/has-proto": { 810 | "version": "1.0.3", 811 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", 812 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", 813 | "engines": { 814 | "node": ">= 0.4" 815 | }, 816 | "funding": { 817 | "url": "https://github.com/sponsors/ljharb" 818 | } 819 | }, 820 | "node_modules/has-symbols": { 821 | "version": "1.0.3", 822 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 823 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 824 | "engines": { 825 | "node": ">= 0.4" 826 | }, 827 | "funding": { 828 | "url": "https://github.com/sponsors/ljharb" 829 | } 830 | }, 831 | "node_modules/has-unicode": { 832 | "version": "2.0.1", 833 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 834 | "integrity": "sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==" 835 | }, 836 | "node_modules/hasown": { 837 | "version": "2.0.2", 838 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 839 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 840 | "dependencies": { 841 | "function-bind": "^1.1.2" 842 | }, 843 | "engines": { 844 | "node": ">= 0.4" 845 | } 846 | }, 847 | "node_modules/http-errors": { 848 | "version": "2.0.0", 849 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 850 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 851 | "dependencies": { 852 | "depd": "2.0.0", 853 | "inherits": "2.0.4", 854 | "setprototypeof": "1.2.0", 855 | "statuses": "2.0.1", 856 | "toidentifier": "1.0.1" 857 | }, 858 | "engines": { 859 | "node": ">= 0.8" 860 | } 861 | }, 862 | "node_modules/https-proxy-agent": { 863 | "version": "5.0.1", 864 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 865 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 866 | "dependencies": { 867 | "agent-base": "6", 868 | "debug": "4" 869 | }, 870 | "engines": { 871 | "node": ">= 6" 872 | } 873 | }, 874 | "node_modules/iconv-lite": { 875 | "version": "0.4.24", 876 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 877 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 878 | "dependencies": { 879 | "safer-buffer": ">= 2.1.2 < 3" 880 | }, 881 | "engines": { 882 | "node": ">=0.10.0" 883 | } 884 | }, 885 | "node_modules/inflight": { 886 | "version": "1.0.6", 887 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 888 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 889 | "dependencies": { 890 | "once": "^1.3.0", 891 | "wrappy": "1" 892 | } 893 | }, 894 | "node_modules/inherits": { 895 | "version": "2.0.4", 896 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 897 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 898 | }, 899 | "node_modules/ipaddr.js": { 900 | "version": "1.9.1", 901 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 902 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 903 | "engines": { 904 | "node": ">= 0.10" 905 | } 906 | }, 907 | "node_modules/is-fullwidth-code-point": { 908 | "version": "3.0.0", 909 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 910 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 911 | "engines": { 912 | "node": ">=8" 913 | } 914 | }, 915 | "node_modules/jake": { 916 | "version": "10.9.1", 917 | "resolved": "https://registry.npmjs.org/jake/-/jake-10.9.1.tgz", 918 | "integrity": "sha512-61btcOHNnLnsOdtLgA5efqQWjnSi/vow5HbI7HMdKKWqvrKR1bLK3BPlJn9gcSaP2ewuamUSMB5XEy76KUIS2w==", 919 | "dependencies": { 920 | "async": "^3.2.3", 921 | "chalk": "^4.0.2", 922 | "filelist": "^1.0.4", 923 | "minimatch": "^3.1.2" 924 | }, 925 | "bin": { 926 | "jake": "bin/cli.js" 927 | }, 928 | "engines": { 929 | "node": ">=10" 930 | } 931 | }, 932 | "node_modules/json5": { 933 | "version": "2.2.3", 934 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 935 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 936 | "bin": { 937 | "json5": "lib/cli.js" 938 | }, 939 | "engines": { 940 | "node": ">=6" 941 | } 942 | }, 943 | "node_modules/jsonwebtoken": { 944 | "version": "9.0.2", 945 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", 946 | "integrity": "sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ==", 947 | "dependencies": { 948 | "jws": "^3.2.2", 949 | "lodash.includes": "^4.3.0", 950 | "lodash.isboolean": "^3.0.3", 951 | "lodash.isinteger": "^4.0.4", 952 | "lodash.isnumber": "^3.0.3", 953 | "lodash.isplainobject": "^4.0.6", 954 | "lodash.isstring": "^4.0.1", 955 | "lodash.once": "^4.0.0", 956 | "ms": "^2.1.1", 957 | "semver": "^7.5.4" 958 | }, 959 | "engines": { 960 | "node": ">=12", 961 | "npm": ">=6" 962 | } 963 | }, 964 | "node_modules/jsonwebtoken/node_modules/ms": { 965 | "version": "2.1.3", 966 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 967 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 968 | }, 969 | "node_modules/jwa": { 970 | "version": "1.4.1", 971 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 972 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 973 | "dependencies": { 974 | "buffer-equal-constant-time": "1.0.1", 975 | "ecdsa-sig-formatter": "1.0.11", 976 | "safe-buffer": "^5.0.1" 977 | } 978 | }, 979 | "node_modules/jws": { 980 | "version": "3.2.2", 981 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 982 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 983 | "dependencies": { 984 | "jwa": "^1.4.1", 985 | "safe-buffer": "^5.0.1" 986 | } 987 | }, 988 | "node_modules/kareem": { 989 | "version": "2.6.3", 990 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.6.3.tgz", 991 | "integrity": "sha512-C3iHfuGUXK2u8/ipq9LfjFfXFxAZMQJJq7vLS45r3D9Y2xQ/m4S8zaR4zMLFWh9AsNPXmcFfUDhTEO8UIC/V6Q==", 992 | "engines": { 993 | "node": ">=12.0.0" 994 | } 995 | }, 996 | "node_modules/lodash.includes": { 997 | "version": "4.3.0", 998 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 999 | "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" 1000 | }, 1001 | "node_modules/lodash.isboolean": { 1002 | "version": "3.0.3", 1003 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1004 | "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" 1005 | }, 1006 | "node_modules/lodash.isinteger": { 1007 | "version": "4.0.4", 1008 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1009 | "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" 1010 | }, 1011 | "node_modules/lodash.isnumber": { 1012 | "version": "3.0.3", 1013 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1014 | "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" 1015 | }, 1016 | "node_modules/lodash.isplainobject": { 1017 | "version": "4.0.6", 1018 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1019 | "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" 1020 | }, 1021 | "node_modules/lodash.isstring": { 1022 | "version": "4.0.1", 1023 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1024 | "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" 1025 | }, 1026 | "node_modules/lodash.once": { 1027 | "version": "4.1.1", 1028 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1029 | "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" 1030 | }, 1031 | "node_modules/make-dir": { 1032 | "version": "3.1.0", 1033 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1034 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1035 | "dependencies": { 1036 | "semver": "^6.0.0" 1037 | }, 1038 | "engines": { 1039 | "node": ">=8" 1040 | }, 1041 | "funding": { 1042 | "url": "https://github.com/sponsors/sindresorhus" 1043 | } 1044 | }, 1045 | "node_modules/make-dir/node_modules/semver": { 1046 | "version": "6.3.1", 1047 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 1048 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 1049 | "bin": { 1050 | "semver": "bin/semver.js" 1051 | } 1052 | }, 1053 | "node_modules/media-typer": { 1054 | "version": "0.3.0", 1055 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1056 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 1057 | "engines": { 1058 | "node": ">= 0.6" 1059 | } 1060 | }, 1061 | "node_modules/memory-pager": { 1062 | "version": "1.5.0", 1063 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1064 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==" 1065 | }, 1066 | "node_modules/merge-descriptors": { 1067 | "version": "1.0.1", 1068 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1069 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 1070 | }, 1071 | "node_modules/methods": { 1072 | "version": "1.1.2", 1073 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1074 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 1075 | "engines": { 1076 | "node": ">= 0.6" 1077 | } 1078 | }, 1079 | "node_modules/mime": { 1080 | "version": "1.6.0", 1081 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1082 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1083 | "bin": { 1084 | "mime": "cli.js" 1085 | }, 1086 | "engines": { 1087 | "node": ">=4" 1088 | } 1089 | }, 1090 | "node_modules/mime-db": { 1091 | "version": "1.52.0", 1092 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1093 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1094 | "engines": { 1095 | "node": ">= 0.6" 1096 | } 1097 | }, 1098 | "node_modules/mime-types": { 1099 | "version": "2.1.35", 1100 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1101 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1102 | "dependencies": { 1103 | "mime-db": "1.52.0" 1104 | }, 1105 | "engines": { 1106 | "node": ">= 0.6" 1107 | } 1108 | }, 1109 | "node_modules/minimatch": { 1110 | "version": "3.1.2", 1111 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1112 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1113 | "dependencies": { 1114 | "brace-expansion": "^1.1.7" 1115 | }, 1116 | "engines": { 1117 | "node": "*" 1118 | } 1119 | }, 1120 | "node_modules/minipass": { 1121 | "version": "5.0.0", 1122 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz", 1123 | "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==", 1124 | "engines": { 1125 | "node": ">=8" 1126 | } 1127 | }, 1128 | "node_modules/minizlib": { 1129 | "version": "2.1.2", 1130 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", 1131 | "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", 1132 | "dependencies": { 1133 | "minipass": "^3.0.0", 1134 | "yallist": "^4.0.0" 1135 | }, 1136 | "engines": { 1137 | "node": ">= 8" 1138 | } 1139 | }, 1140 | "node_modules/minizlib/node_modules/minipass": { 1141 | "version": "3.3.6", 1142 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz", 1143 | "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==", 1144 | "dependencies": { 1145 | "yallist": "^4.0.0" 1146 | }, 1147 | "engines": { 1148 | "node": ">=8" 1149 | } 1150 | }, 1151 | "node_modules/mkdirp": { 1152 | "version": "1.0.4", 1153 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1154 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 1155 | "bin": { 1156 | "mkdirp": "bin/cmd.js" 1157 | }, 1158 | "engines": { 1159 | "node": ">=10" 1160 | } 1161 | }, 1162 | "node_modules/mongodb": { 1163 | "version": "6.5.0", 1164 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-6.5.0.tgz", 1165 | "integrity": "sha512-Fozq68InT+JKABGLqctgtb8P56pRrJFkbhW0ux+x1mdHeyinor8oNzJqwLjV/t5X5nJGfTlluxfyMnOXNggIUA==", 1166 | "dependencies": { 1167 | "@mongodb-js/saslprep": "^1.1.5", 1168 | "bson": "^6.4.0", 1169 | "mongodb-connection-string-url": "^3.0.0" 1170 | }, 1171 | "engines": { 1172 | "node": ">=16.20.1" 1173 | }, 1174 | "peerDependencies": { 1175 | "@aws-sdk/credential-providers": "^3.188.0", 1176 | "@mongodb-js/zstd": "^1.1.0", 1177 | "gcp-metadata": "^5.2.0", 1178 | "kerberos": "^2.0.1", 1179 | "mongodb-client-encryption": ">=6.0.0 <7", 1180 | "snappy": "^7.2.2", 1181 | "socks": "^2.7.1" 1182 | }, 1183 | "peerDependenciesMeta": { 1184 | "@aws-sdk/credential-providers": { 1185 | "optional": true 1186 | }, 1187 | "@mongodb-js/zstd": { 1188 | "optional": true 1189 | }, 1190 | "gcp-metadata": { 1191 | "optional": true 1192 | }, 1193 | "kerberos": { 1194 | "optional": true 1195 | }, 1196 | "mongodb-client-encryption": { 1197 | "optional": true 1198 | }, 1199 | "snappy": { 1200 | "optional": true 1201 | }, 1202 | "socks": { 1203 | "optional": true 1204 | } 1205 | } 1206 | }, 1207 | "node_modules/mongodb-connection-string-url": { 1208 | "version": "3.0.1", 1209 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-3.0.1.tgz", 1210 | "integrity": "sha512-XqMGwRX0Lgn05TDB4PyG2h2kKO/FfWJyCzYQbIhXUxz7ETt0I/FqHjUeqj37irJ+Dl1ZtU82uYyj14u2XsZKfg==", 1211 | "dependencies": { 1212 | "@types/whatwg-url": "^11.0.2", 1213 | "whatwg-url": "^13.0.0" 1214 | } 1215 | }, 1216 | "node_modules/mongoose": { 1217 | "version": "8.3.5", 1218 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-8.3.5.tgz", 1219 | "integrity": "sha512-2zqeAjHjCqT1o5HeUCvkE9tUHsXwemnwEZ2SKnUxsaP8p1a+UcSQSNbnSuOzUVePMwLETrsvLIRdFLjsNfCgWA==", 1220 | "dependencies": { 1221 | "bson": "^6.5.0", 1222 | "kareem": "2.6.3", 1223 | "mongodb": "6.5.0", 1224 | "mpath": "0.9.0", 1225 | "mquery": "5.0.0", 1226 | "ms": "2.1.3", 1227 | "sift": "17.1.3" 1228 | }, 1229 | "engines": { 1230 | "node": ">=16.20.1" 1231 | }, 1232 | "funding": { 1233 | "type": "opencollective", 1234 | "url": "https://opencollective.com/mongoose" 1235 | } 1236 | }, 1237 | "node_modules/mongoose/node_modules/ms": { 1238 | "version": "2.1.3", 1239 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1240 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1241 | }, 1242 | "node_modules/mpath": { 1243 | "version": "0.9.0", 1244 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 1245 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==", 1246 | "engines": { 1247 | "node": ">=4.0.0" 1248 | } 1249 | }, 1250 | "node_modules/mquery": { 1251 | "version": "5.0.0", 1252 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 1253 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 1254 | "dependencies": { 1255 | "debug": "4.x" 1256 | }, 1257 | "engines": { 1258 | "node": ">=14.0.0" 1259 | } 1260 | }, 1261 | "node_modules/ms": { 1262 | "version": "2.1.2", 1263 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1264 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1265 | }, 1266 | "node_modules/negotiator": { 1267 | "version": "0.6.3", 1268 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1269 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 1270 | "engines": { 1271 | "node": ">= 0.6" 1272 | } 1273 | }, 1274 | "node_modules/node-addon-api": { 1275 | "version": "5.1.0", 1276 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-5.1.0.tgz", 1277 | "integrity": "sha512-eh0GgfEkpnoWDq+VY8OyvYhFEzBk6jIYbRKdIlyTiAXIVJ8PyBaKb0rp7oDtoddbdoHWhq8wwr+XZ81F1rpNdA==" 1278 | }, 1279 | "node_modules/node-fetch": { 1280 | "version": "2.7.0", 1281 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", 1282 | "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", 1283 | "dependencies": { 1284 | "whatwg-url": "^5.0.0" 1285 | }, 1286 | "engines": { 1287 | "node": "4.x || >=6.0.0" 1288 | }, 1289 | "peerDependencies": { 1290 | "encoding": "^0.1.0" 1291 | }, 1292 | "peerDependenciesMeta": { 1293 | "encoding": { 1294 | "optional": true 1295 | } 1296 | } 1297 | }, 1298 | "node_modules/node-fetch/node_modules/tr46": { 1299 | "version": "0.0.3", 1300 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 1301 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 1302 | }, 1303 | "node_modules/node-fetch/node_modules/webidl-conversions": { 1304 | "version": "3.0.1", 1305 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 1306 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 1307 | }, 1308 | "node_modules/node-fetch/node_modules/whatwg-url": { 1309 | "version": "5.0.0", 1310 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 1311 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 1312 | "dependencies": { 1313 | "tr46": "~0.0.3", 1314 | "webidl-conversions": "^3.0.0" 1315 | } 1316 | }, 1317 | "node_modules/nopt": { 1318 | "version": "5.0.0", 1319 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz", 1320 | "integrity": "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==", 1321 | "dependencies": { 1322 | "abbrev": "1" 1323 | }, 1324 | "bin": { 1325 | "nopt": "bin/nopt.js" 1326 | }, 1327 | "engines": { 1328 | "node": ">=6" 1329 | } 1330 | }, 1331 | "node_modules/npmlog": { 1332 | "version": "5.0.1", 1333 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-5.0.1.tgz", 1334 | "integrity": "sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw==", 1335 | "dependencies": { 1336 | "are-we-there-yet": "^2.0.0", 1337 | "console-control-strings": "^1.1.0", 1338 | "gauge": "^3.0.0", 1339 | "set-blocking": "^2.0.0" 1340 | } 1341 | }, 1342 | "node_modules/object-assign": { 1343 | "version": "4.1.1", 1344 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1345 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1346 | "engines": { 1347 | "node": ">=0.10.0" 1348 | } 1349 | }, 1350 | "node_modules/object-inspect": { 1351 | "version": "1.13.1", 1352 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", 1353 | "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", 1354 | "funding": { 1355 | "url": "https://github.com/sponsors/ljharb" 1356 | } 1357 | }, 1358 | "node_modules/on-finished": { 1359 | "version": "2.4.1", 1360 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1361 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1362 | "dependencies": { 1363 | "ee-first": "1.1.1" 1364 | }, 1365 | "engines": { 1366 | "node": ">= 0.8" 1367 | } 1368 | }, 1369 | "node_modules/on-headers": { 1370 | "version": "1.0.2", 1371 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 1372 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", 1373 | "engines": { 1374 | "node": ">= 0.8" 1375 | } 1376 | }, 1377 | "node_modules/once": { 1378 | "version": "1.4.0", 1379 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1380 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1381 | "dependencies": { 1382 | "wrappy": "1" 1383 | } 1384 | }, 1385 | "node_modules/parseurl": { 1386 | "version": "1.3.3", 1387 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1388 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1389 | "engines": { 1390 | "node": ">= 0.8" 1391 | } 1392 | }, 1393 | "node_modules/path-is-absolute": { 1394 | "version": "1.0.1", 1395 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1396 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1397 | "engines": { 1398 | "node": ">=0.10.0" 1399 | } 1400 | }, 1401 | "node_modules/path-to-regexp": { 1402 | "version": "0.1.7", 1403 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1404 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 1405 | }, 1406 | "node_modules/proxy-addr": { 1407 | "version": "2.0.7", 1408 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1409 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1410 | "dependencies": { 1411 | "forwarded": "0.2.0", 1412 | "ipaddr.js": "1.9.1" 1413 | }, 1414 | "engines": { 1415 | "node": ">= 0.10" 1416 | } 1417 | }, 1418 | "node_modules/punycode": { 1419 | "version": "2.3.1", 1420 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 1421 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 1422 | "engines": { 1423 | "node": ">=6" 1424 | } 1425 | }, 1426 | "node_modules/qs": { 1427 | "version": "6.11.0", 1428 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1429 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1430 | "dependencies": { 1431 | "side-channel": "^1.0.4" 1432 | }, 1433 | "engines": { 1434 | "node": ">=0.6" 1435 | }, 1436 | "funding": { 1437 | "url": "https://github.com/sponsors/ljharb" 1438 | } 1439 | }, 1440 | "node_modules/random-bytes": { 1441 | "version": "1.0.0", 1442 | "resolved": "https://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz", 1443 | "integrity": "sha512-iv7LhNVO047HzYR3InF6pUcUsPQiHTM1Qal51DcGSuZFBil1aBBWG5eHPNek7bvILMaYJ/8RU1e8w1AMdHmLQQ==", 1444 | "engines": { 1445 | "node": ">= 0.8" 1446 | } 1447 | }, 1448 | "node_modules/range-parser": { 1449 | "version": "1.2.1", 1450 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1451 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1452 | "engines": { 1453 | "node": ">= 0.6" 1454 | } 1455 | }, 1456 | "node_modules/raw-body": { 1457 | "version": "2.5.2", 1458 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", 1459 | "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", 1460 | "dependencies": { 1461 | "bytes": "3.1.2", 1462 | "http-errors": "2.0.0", 1463 | "iconv-lite": "0.4.24", 1464 | "unpipe": "1.0.0" 1465 | }, 1466 | "engines": { 1467 | "node": ">= 0.8" 1468 | } 1469 | }, 1470 | "node_modules/readable-stream": { 1471 | "version": "3.6.2", 1472 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 1473 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 1474 | "dependencies": { 1475 | "inherits": "^2.0.3", 1476 | "string_decoder": "^1.1.1", 1477 | "util-deprecate": "^1.0.1" 1478 | }, 1479 | "engines": { 1480 | "node": ">= 6" 1481 | } 1482 | }, 1483 | "node_modules/rimraf": { 1484 | "version": "3.0.2", 1485 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1486 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1487 | "dependencies": { 1488 | "glob": "^7.1.3" 1489 | }, 1490 | "bin": { 1491 | "rimraf": "bin.js" 1492 | }, 1493 | "funding": { 1494 | "url": "https://github.com/sponsors/isaacs" 1495 | } 1496 | }, 1497 | "node_modules/safe-buffer": { 1498 | "version": "5.2.1", 1499 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1500 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1501 | "funding": [ 1502 | { 1503 | "type": "github", 1504 | "url": "https://github.com/sponsors/feross" 1505 | }, 1506 | { 1507 | "type": "patreon", 1508 | "url": "https://www.patreon.com/feross" 1509 | }, 1510 | { 1511 | "type": "consulting", 1512 | "url": "https://feross.org/support" 1513 | } 1514 | ] 1515 | }, 1516 | "node_modules/safer-buffer": { 1517 | "version": "2.1.2", 1518 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1519 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1520 | }, 1521 | "node_modules/semver": { 1522 | "version": "7.6.2", 1523 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", 1524 | "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", 1525 | "bin": { 1526 | "semver": "bin/semver.js" 1527 | }, 1528 | "engines": { 1529 | "node": ">=10" 1530 | } 1531 | }, 1532 | "node_modules/send": { 1533 | "version": "0.18.0", 1534 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1535 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1536 | "dependencies": { 1537 | "debug": "2.6.9", 1538 | "depd": "2.0.0", 1539 | "destroy": "1.2.0", 1540 | "encodeurl": "~1.0.2", 1541 | "escape-html": "~1.0.3", 1542 | "etag": "~1.8.1", 1543 | "fresh": "0.5.2", 1544 | "http-errors": "2.0.0", 1545 | "mime": "1.6.0", 1546 | "ms": "2.1.3", 1547 | "on-finished": "2.4.1", 1548 | "range-parser": "~1.2.1", 1549 | "statuses": "2.0.1" 1550 | }, 1551 | "engines": { 1552 | "node": ">= 0.8.0" 1553 | } 1554 | }, 1555 | "node_modules/send/node_modules/debug": { 1556 | "version": "2.6.9", 1557 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1558 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1559 | "dependencies": { 1560 | "ms": "2.0.0" 1561 | } 1562 | }, 1563 | "node_modules/send/node_modules/debug/node_modules/ms": { 1564 | "version": "2.0.0", 1565 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1566 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1567 | }, 1568 | "node_modules/send/node_modules/ms": { 1569 | "version": "2.1.3", 1570 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1571 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1572 | }, 1573 | "node_modules/serve-static": { 1574 | "version": "1.15.0", 1575 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1576 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1577 | "dependencies": { 1578 | "encodeurl": "~1.0.2", 1579 | "escape-html": "~1.0.3", 1580 | "parseurl": "~1.3.3", 1581 | "send": "0.18.0" 1582 | }, 1583 | "engines": { 1584 | "node": ">= 0.8.0" 1585 | } 1586 | }, 1587 | "node_modules/set-blocking": { 1588 | "version": "2.0.0", 1589 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1590 | "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==" 1591 | }, 1592 | "node_modules/set-function-length": { 1593 | "version": "1.2.2", 1594 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", 1595 | "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", 1596 | "dependencies": { 1597 | "define-data-property": "^1.1.4", 1598 | "es-errors": "^1.3.0", 1599 | "function-bind": "^1.1.2", 1600 | "get-intrinsic": "^1.2.4", 1601 | "gopd": "^1.0.1", 1602 | "has-property-descriptors": "^1.0.2" 1603 | }, 1604 | "engines": { 1605 | "node": ">= 0.4" 1606 | } 1607 | }, 1608 | "node_modules/setprototypeof": { 1609 | "version": "1.2.0", 1610 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1611 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1612 | }, 1613 | "node_modules/side-channel": { 1614 | "version": "1.0.6", 1615 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", 1616 | "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", 1617 | "dependencies": { 1618 | "call-bind": "^1.0.7", 1619 | "es-errors": "^1.3.0", 1620 | "get-intrinsic": "^1.2.4", 1621 | "object-inspect": "^1.13.1" 1622 | }, 1623 | "engines": { 1624 | "node": ">= 0.4" 1625 | }, 1626 | "funding": { 1627 | "url": "https://github.com/sponsors/ljharb" 1628 | } 1629 | }, 1630 | "node_modules/sift": { 1631 | "version": "17.1.3", 1632 | "resolved": "https://registry.npmjs.org/sift/-/sift-17.1.3.tgz", 1633 | "integrity": "sha512-Rtlj66/b0ICeFzYTuNvX/EF1igRbbnGSvEyT79McoZa/DeGhMyC5pWKOEsZKnpkqtSeovd5FL/bjHWC3CIIvCQ==" 1634 | }, 1635 | "node_modules/signal-exit": { 1636 | "version": "3.0.7", 1637 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1638 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" 1639 | }, 1640 | "node_modules/sparse-bitfield": { 1641 | "version": "3.0.3", 1642 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1643 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 1644 | "dependencies": { 1645 | "memory-pager": "^1.0.2" 1646 | } 1647 | }, 1648 | "node_modules/statuses": { 1649 | "version": "2.0.1", 1650 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1651 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1652 | "engines": { 1653 | "node": ">= 0.8" 1654 | } 1655 | }, 1656 | "node_modules/string_decoder": { 1657 | "version": "1.3.0", 1658 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 1659 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 1660 | "dependencies": { 1661 | "safe-buffer": "~5.2.0" 1662 | } 1663 | }, 1664 | "node_modules/string-width": { 1665 | "version": "4.2.3", 1666 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1667 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1668 | "dependencies": { 1669 | "emoji-regex": "^8.0.0", 1670 | "is-fullwidth-code-point": "^3.0.0", 1671 | "strip-ansi": "^6.0.1" 1672 | }, 1673 | "engines": { 1674 | "node": ">=8" 1675 | } 1676 | }, 1677 | "node_modules/strip-ansi": { 1678 | "version": "6.0.1", 1679 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1680 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1681 | "dependencies": { 1682 | "ansi-regex": "^5.0.1" 1683 | }, 1684 | "engines": { 1685 | "node": ">=8" 1686 | } 1687 | }, 1688 | "node_modules/supports-color": { 1689 | "version": "7.2.0", 1690 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1691 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1692 | "dependencies": { 1693 | "has-flag": "^4.0.0" 1694 | }, 1695 | "engines": { 1696 | "node": ">=8" 1697 | } 1698 | }, 1699 | "node_modules/tar": { 1700 | "version": "6.2.1", 1701 | "resolved": "https://registry.npmjs.org/tar/-/tar-6.2.1.tgz", 1702 | "integrity": "sha512-DZ4yORTwrbTj/7MZYq2w+/ZFdI6OZ/f9SFHR+71gIVUZhOQPHzVCLpvRnPgyaMpfWxxk/4ONva3GQSyNIKRv6A==", 1703 | "dependencies": { 1704 | "chownr": "^2.0.0", 1705 | "fs-minipass": "^2.0.0", 1706 | "minipass": "^5.0.0", 1707 | "minizlib": "^2.1.1", 1708 | "mkdirp": "^1.0.3", 1709 | "yallist": "^4.0.0" 1710 | }, 1711 | "engines": { 1712 | "node": ">=10" 1713 | } 1714 | }, 1715 | "node_modules/toidentifier": { 1716 | "version": "1.0.1", 1717 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1718 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1719 | "engines": { 1720 | "node": ">=0.6" 1721 | } 1722 | }, 1723 | "node_modules/tr46": { 1724 | "version": "4.1.1", 1725 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz", 1726 | "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==", 1727 | "dependencies": { 1728 | "punycode": "^2.3.0" 1729 | }, 1730 | "engines": { 1731 | "node": ">=14" 1732 | } 1733 | }, 1734 | "node_modules/type-is": { 1735 | "version": "1.6.18", 1736 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1737 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1738 | "dependencies": { 1739 | "media-typer": "0.3.0", 1740 | "mime-types": "~2.1.24" 1741 | }, 1742 | "engines": { 1743 | "node": ">= 0.6" 1744 | } 1745 | }, 1746 | "node_modules/uid-safe": { 1747 | "version": "2.1.5", 1748 | "resolved": "https://registry.npmjs.org/uid-safe/-/uid-safe-2.1.5.tgz", 1749 | "integrity": "sha512-KPHm4VL5dDXKz01UuEd88Df+KzynaohSL9fBh096KWAxSKZQDI2uBrVqtvRM4rwrIrRRKsdLNML/lnaaVSRioA==", 1750 | "dependencies": { 1751 | "random-bytes": "~1.0.0" 1752 | }, 1753 | "engines": { 1754 | "node": ">= 0.8" 1755 | } 1756 | }, 1757 | "node_modules/unpipe": { 1758 | "version": "1.0.0", 1759 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1760 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1761 | "engines": { 1762 | "node": ">= 0.8" 1763 | } 1764 | }, 1765 | "node_modules/util-deprecate": { 1766 | "version": "1.0.2", 1767 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1768 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 1769 | }, 1770 | "node_modules/utils-merge": { 1771 | "version": "1.0.1", 1772 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1773 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1774 | "engines": { 1775 | "node": ">= 0.4.0" 1776 | } 1777 | }, 1778 | "node_modules/vary": { 1779 | "version": "1.1.2", 1780 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1781 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1782 | "engines": { 1783 | "node": ">= 0.8" 1784 | } 1785 | }, 1786 | "node_modules/webidl-conversions": { 1787 | "version": "7.0.0", 1788 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1789 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 1790 | "engines": { 1791 | "node": ">=12" 1792 | } 1793 | }, 1794 | "node_modules/whatwg-url": { 1795 | "version": "13.0.0", 1796 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-13.0.0.tgz", 1797 | "integrity": "sha512-9WWbymnqj57+XEuqADHrCJ2eSXzn8WXIW/YSGaZtb2WKAInQ6CHfaUUcTyyver0p8BDg5StLQq8h1vtZuwmOig==", 1798 | "dependencies": { 1799 | "tr46": "^4.1.1", 1800 | "webidl-conversions": "^7.0.0" 1801 | }, 1802 | "engines": { 1803 | "node": ">=16" 1804 | } 1805 | }, 1806 | "node_modules/wide-align": { 1807 | "version": "1.1.5", 1808 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz", 1809 | "integrity": "sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==", 1810 | "dependencies": { 1811 | "string-width": "^1.0.2 || 2 || 3 || 4" 1812 | } 1813 | }, 1814 | "node_modules/wrappy": { 1815 | "version": "1.0.2", 1816 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1817 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" 1818 | }, 1819 | "node_modules/yallist": { 1820 | "version": "4.0.0", 1821 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1822 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1823 | } 1824 | } 1825 | } 1826 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "scatch", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "app.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.1", 14 | "config": "^3.3.11", 15 | "connect-flash": "^0.1.1", 16 | "cookie-parser": "^1.4.6", 17 | "debug": "^4.3.4", 18 | "dotenv": "^16.4.5", 19 | "ejs": "^3.1.10", 20 | "express": "^4.19.2", 21 | "express-session": "^1.18.0", 22 | "jsonwebtoken": "^9.0.2", 23 | "mongoose": "^8.3.5" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /public/images/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/public/images/.gitkeep -------------------------------------------------------------------------------- /public/javascripts/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/public/javascripts/.gitkeep -------------------------------------------------------------------------------- /public/stylesheets/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/public/stylesheets/.gitkeep -------------------------------------------------------------------------------- /routes/index.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | const isloggedin = require("../middlewares/isLoggedIn"); 4 | 5 | router.get("/", function (req, res) { 6 | let error = req.flash("error"); 7 | res.render("index", { error }); 8 | }); 9 | 10 | router.get("/shop", isloggedin, function (req, res) { 11 | res.render("shop"); 12 | }); 13 | 14 | module.exports = router; 15 | -------------------------------------------------------------------------------- /routes/ownersRouter.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | const ownerModel = require("../models/owner-model"); 4 | 5 | if (process.env.NODE_ENV === "development") { 6 | router.post("/create", async function (req, res) { 7 | let owners = await ownerModel.find(); 8 | if (owners.length > 0) { 9 | return res 10 | .status(500) 11 | .send("You don't have permission to create a new owner."); 12 | } 13 | 14 | let { fullname, email, password } = req.body; 15 | 16 | let createdOwner = await ownerModel.create({ 17 | fullname, 18 | email, 19 | password, 20 | }); 21 | 22 | res.status(201).send(createdOwner); 23 | }); 24 | } 25 | 26 | router.get("/", function (req, res) { 27 | res.send("hey it's working"); 28 | }); 29 | 30 | module.exports = router; 31 | -------------------------------------------------------------------------------- /routes/productsRouter.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | 4 | router.get("/", function (req, res) { 5 | res.send("hey it's working"); 6 | }); 7 | 8 | module.exports = router; 9 | -------------------------------------------------------------------------------- /routes/usersRouter.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const router = express.Router(); 3 | const isloggedin = require("../middlewares/isLoggedIn"); 4 | const { 5 | registerUser, 6 | loginUser, 7 | logout, 8 | } = require("../controllers/authController"); 9 | 10 | router.get("/", function (req, res) { 11 | res.send("hey it's working"); 12 | }); 13 | 14 | router.post("/register", registerUser); 15 | 16 | router.post("/login", loginUser); 17 | 18 | router.get("/logout", logout); 19 | 20 | module.exports = router; 21 | -------------------------------------------------------------------------------- /utils/generateToken.js: -------------------------------------------------------------------------------- 1 | const jwt = require("jsonwebtoken"); 2 | 3 | const generateToken = (user) => { 4 | return jwt.sign({ email: user.email, id: user._id }, process.env.JWT_KEY); 5 | }; 6 | module.exports.generateToken = generateToken; 7 | -------------------------------------------------------------------------------- /views/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/scatch/f6b765caac09dd93c260ea24fb71e9cf342ef241/views/.gitkeep -------------------------------------------------------------------------------- /views/admin.ejs: -------------------------------------------------------------------------------- 1 | <%- include('./partials/header') %> 2 |