├── .gitignore ├── README.md ├── index.js ├── package-lock.json ├── package.json └── vercel.json /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | .env 3 | .vercel 4 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## What We Did Today. 2 | 3 | - **Different Dashboard Home Page for User and Admin**: Implemented distinct home pages for users and administrators to provide customized experiences based on roles. 4 | - **Fix Login Issue and API Race Condition**: Resolved issues related to user login and addressed race conditions in API requests to ensure smooth and reliable operations. 5 | - **Create Admin Dashboard Stats API**: Developed an API to fetch and display statistical data for the admin dashboard, providing insights into various metrics. 6 | - **Load Data and Display Stats on the Admin Home**: Loaded statistical data and displayed it on the admin home page to give administrators a quick overview of important metrics. 7 | - **High-Level Overview of Aggregate Pipeline**: Provided a high-level overview of the MongoDB aggregate pipeline for data aggregation and analysis. 8 | - **Get Order Quantity and Revenue by Category**: Used aggregate functions to calculate order quantities and revenue by category, enabling detailed financial insights. 9 | - **Display Custom Bar Chart and Custom Pie Chart**: Created custom bar and pie charts to visually represent data, making it easier to understand and analyze. 10 | - **Deploy Bistro Boss to Vercel and Firebase**: Deployed the Bistro Boss application to Vercel and Firebase for hosting, ensuring scalability and high availability. 11 | 12 | # MongoDB Aggregation Documentation 13 | 14 | ## Overview 15 | MongoDB's aggregation framework is a powerful tool for data processing and analysis, allowing you to transform and summarize data in a variety of ways. Aggregations are operations that process data records and return computed results. They are often used to group values from multiple documents together, perform operations on the grouped data, and return a single result. 16 | 17 | ## Aggregation Pipeline 18 | The aggregation pipeline is a framework for data aggregation, modeled on the concept of data processing pipelines. Documents enter a multi-stage pipeline that transforms the documents into an aggregated result. Each stage in the pipeline performs an operation on the input documents and passes the results to the next stage. 19 | 20 | ### Basic Syntax 21 | ```javascript 22 | db.collection.aggregate([ 23 | { $stage1: { /* stage1 options */ }}, 24 | { $stage2: { /* stage2 options */ }}, 25 | // More stages as needed 26 | ]) 27 | ``` 28 | # MongoDB Aggregation Pipeline Guide 29 | 30 | ## Common Aggregation Stages 31 | 32 | ### $match 33 | Filters documents based on specified conditions. 34 | 35 | ```javascript 36 | { $match: { status: "A" } } 37 | ``` 38 | 39 | ## $group 40 | Groups documents by a specified identifier and applies accumulator expressions to each group. 41 | 42 | ```javascript 43 | { 44 | $group: { 45 | _id: "$field", 46 | total: { $sum: "$amount" } 47 | } 48 | } 49 | ``` 50 | ## $project 51 | The `$project` stage reshapes documents by adding or removing fields. It allows you to specify which fields to include or exclude in the output documents, along with computed fields using expressions. 52 | 53 | ### Example: 54 | ```javascript 55 | { 56 | $project: { 57 | name: 1, 58 | total: { $sum: "$items.price" } 59 | } 60 | } 61 | ``` 62 | ## $sort 63 | The `$sort` stage sorts input documents based on the specified criteria. It's useful for ordering documents based on one or more fields, either ascending or descending. 64 | 65 | ## Example: 66 | ```javascript 67 | { $sort: { total: -1 } } 68 | ``` 69 | ## $limit 70 | Limits the number of documents passed to the next stage. 71 | 72 | ```javascript 73 | { $limit: 5 } 74 | ``` 75 | ## $lookup 76 | Performs a left outer join with another collection. 77 | 78 | ```javascript 79 | { 80 | $lookup: { 81 | from: "otherCollection", 82 | localField: "localField", 83 | foreignField: "foreignField", 84 | as: "fromItems" 85 | } 86 | } 87 | ``` 88 | # Example Aggregation Pipeline: Calculate Total Sales by Category 89 | 90 | ```javascript 91 | db.sales.aggregate([ 92 | { 93 | $match: { 94 | date: { $gte: ISODate("2024-01-01"), $lt: ISODate("2025-01-01") } 95 | } 96 | }, 97 | { 98 | $group: { 99 | _id: "$category", 100 | totalSales: { $sum: "$amount" } 101 | } 102 | }, 103 | { 104 | $sort: { totalSales: -1 } 105 | } 106 | ]) 107 | ``` 108 | # $unwind 109 | 110 | Deconstructs an array field into separate documents. 111 | 112 | ```javascript 113 | { $unwind: "$items" } 114 | ``` 115 | # $addFields 116 | 117 | Adds new fields to documents. 118 | 119 | ```javascript 120 | { 121 | $addFields: { 122 | totalAfterDiscount: { $subtract: ["$total", "$discount"] } 123 | } 124 | } 125 | ``` 126 | This example calculates a new field totalAfterDiscount by subtracting the value of the field discount from the value of the field total. 127 | # $redact 128 | 129 | Controls document field visibility. 130 | 131 | ```javascript 132 | { 133 | $redact: { 134 | $cond: { 135 | if: { $eq: ["$status", "A"] }, 136 | then: "$$KEEP", 137 | else: "$$PRUNE" 138 | } 139 | } 140 | } 141 | ``` 142 | This example controls the visibility of document fields based on the value of the status field. If the status field is equal to "A", the document is kept ($$KEEP), otherwise it's pruned ($$PRUNE). 143 | # $out 144 | 145 | Writes aggregation results to a specified collection. 146 | 147 | ```javascript 148 | { $out: "resultCollection" } 149 | ``` 150 | This stage saves the results of the aggregation pipeline to a new collection named "resultCollection". 151 | # Best Practices 152 | 153 | - **Indexing:** Ensure indexing on fields used in $match, $group, and $lookup stages for better performance. 154 | - **Pipeline Optimization:** Place $match and $sort stages early in the pipeline to reduce document processing. 155 | - **Stage Limits:** Be aware of memory limitations; consider breaking complex pipelines into multiple stages or using $merge. 156 | 157 | # Conclusion 158 | 159 | MongoDB's aggregation framework is versatile and powerful, allowing for complex data transformations and analyses. Mastering the various stages and techniques enables efficient data processing and valuable insights extraction. 160 | 161 | For detailed information, refer to the official [MongoDB documentation](https://www.mongodb.com/docs/manual/aggregation/). 162 | 163 | 164 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const app = express(); 3 | const cors = require('cors'); 4 | const jwt = require('jsonwebtoken'); 5 | require('dotenv').config(); 6 | const stripe = require('stripe')(process.env.STRIPE_SECRET_KEY); 7 | 8 | const port = process.env.PORT || 5000; 9 | 10 | // middleware 11 | app.use(cors()); 12 | app.use(express.json()); 13 | 14 | 15 | const { MongoClient, ServerApiVersion, ObjectId } = require('mongodb'); 16 | const uri = `mongodb+srv://${process.env.DB_USER}:${process.env.DB_PASS}@cluster0.swu9d.mongodb.net/?retryWrites=true&w=majority`; 17 | 18 | // Create a MongoClient with a MongoClientOptions object to set the Stable API version 19 | const client = new MongoClient(uri, { 20 | serverApi: { 21 | version: ServerApiVersion.v1, 22 | strict: true, 23 | deprecationErrors: true, 24 | } 25 | }); 26 | 27 | async function run() { 28 | try { 29 | // Connect the client to the server (optional starting in v4.7) 30 | // await client.connect(); 31 | 32 | const userCollection = client.db("bistroDb").collection("users"); 33 | const menuCollection = client.db("bistroDb").collection("menu"); 34 | const reviewCollection = client.db("bistroDb").collection("reviews"); 35 | const cartCollection = client.db("bistroDb").collection("carts"); 36 | const paymentCollection = client.db("bistroDb").collection("payments"); 37 | 38 | // jwt related api 39 | app.post('/jwt', async (req, res) => { 40 | const user = req.body; 41 | const token = jwt.sign(user, process.env.ACCESS_TOKEN_SECRET, { expiresIn: '1h' }); 42 | res.send({ token }); 43 | }) 44 | 45 | // middlewares 46 | const verifyToken = (req, res, next) => { 47 | // console.log('inside verify token', req.headers.authorization); 48 | if (!req.headers.authorization) { 49 | return res.status(401).send({ message: 'unauthorized access' }); 50 | } 51 | const token = req.headers.authorization.split(' ')[1]; 52 | jwt.verify(token, process.env.ACCESS_TOKEN_SECRET, (err, decoded) => { 53 | if (err) { 54 | return res.status(401).send({ message: 'unauthorized access' }) 55 | } 56 | req.decoded = decoded; 57 | next(); 58 | }) 59 | } 60 | 61 | // use verify admin after verifyToken 62 | const verifyAdmin = async (req, res, next) => { 63 | const email = req.decoded.email; 64 | const query = { email: email }; 65 | const user = await userCollection.findOne(query); 66 | const isAdmin = user?.role === 'admin'; 67 | if (!isAdmin) { 68 | return res.status(403).send({ message: 'forbidden access' }); 69 | } 70 | next(); 71 | } 72 | 73 | // users related api 74 | app.get('/users', verifyToken, verifyAdmin, async (req, res) => { 75 | const result = await userCollection.find().toArray(); 76 | res.send(result); 77 | }); 78 | 79 | app.get('/users/admin/:email', verifyToken, async (req, res) => { 80 | const email = req.params.email; 81 | 82 | if (email !== req.decoded.email) { 83 | return res.status(403).send({ message: 'forbidden access' }) 84 | } 85 | 86 | const query = { email: email }; 87 | const user = await userCollection.findOne(query); 88 | let admin = false; 89 | if (user) { 90 | admin = user?.role === 'admin'; 91 | } 92 | res.send({ admin }); 93 | }) 94 | 95 | app.post('/users', async (req, res) => { 96 | const user = req.body; 97 | // insert email if user doesnt exists: 98 | // you can do this many ways (1. email unique, 2. upsert 3. simple checking) 99 | const query = { email: user.email } 100 | const existingUser = await userCollection.findOne(query); 101 | if (existingUser) { 102 | return res.send({ message: 'user already exists', insertedId: null }) 103 | } 104 | const result = await userCollection.insertOne(user); 105 | res.send(result); 106 | }); 107 | 108 | app.patch('/users/admin/:id', verifyToken, verifyAdmin, async (req, res) => { 109 | const id = req.params.id; 110 | const filter = { _id: new ObjectId(id) }; 111 | const updatedDoc = { 112 | $set: { 113 | role: 'admin' 114 | } 115 | } 116 | const result = await userCollection.updateOne(filter, updatedDoc); 117 | res.send(result); 118 | }) 119 | 120 | app.delete('/users/:id', verifyToken, verifyAdmin, async (req, res) => { 121 | const id = req.params.id; 122 | const query = { _id: new ObjectId(id) } 123 | const result = await userCollection.deleteOne(query); 124 | res.send(result); 125 | }) 126 | 127 | // menu related apis 128 | app.get('/menu', async (req, res) => { 129 | const result = await menuCollection.find().toArray(); 130 | res.send(result); 131 | }); 132 | 133 | app.get('/menu/:id', async (req, res) => { 134 | const id = req.params.id; 135 | const query = { _id: new ObjectId(id) } 136 | const result = await menuCollection.findOne(query); 137 | res.send(result); 138 | }) 139 | 140 | app.post('/menu', verifyToken, verifyAdmin, async (req, res) => { 141 | const item = req.body; 142 | const result = await menuCollection.insertOne(item); 143 | res.send(result); 144 | }); 145 | 146 | app.patch('/menu/:id', async (req, res) => { 147 | const item = req.body; 148 | const id = req.params.id; 149 | const filter = { _id: new ObjectId(id) } 150 | const updatedDoc = { 151 | $set: { 152 | name: item.name, 153 | category: item.category, 154 | price: item.price, 155 | recipe: item.recipe, 156 | image: item.image 157 | } 158 | } 159 | 160 | const result = await menuCollection.updateOne(filter, updatedDoc) 161 | res.send(result); 162 | }) 163 | 164 | app.delete('/menu/:id', verifyToken, verifyAdmin, async (req, res) => { 165 | const id = req.params.id; 166 | const query = { _id: new ObjectId(id) } 167 | const result = await menuCollection.deleteOne(query); 168 | res.send(result); 169 | }) 170 | 171 | app.get('/reviews', async (req, res) => { 172 | const result = await reviewCollection.find().toArray(); 173 | res.send(result); 174 | }) 175 | 176 | // carts collection 177 | app.get('/carts', async (req, res) => { 178 | const email = req.query.email; 179 | const query = { email: email }; 180 | const result = await cartCollection.find(query).toArray(); 181 | res.send(result); 182 | }); 183 | 184 | app.post('/carts', async (req, res) => { 185 | const cartItem = req.body; 186 | const result = await cartCollection.insertOne(cartItem); 187 | res.send(result); 188 | }); 189 | 190 | app.delete('/carts/:id', async (req, res) => { 191 | const id = req.params.id; 192 | const query = { _id: new ObjectId(id) } 193 | const result = await cartCollection.deleteOne(query); 194 | res.send(result); 195 | }); 196 | 197 | // payment intent 198 | app.post('/create-payment-intent', async (req, res) => { 199 | const { price } = req.body; 200 | const amount = parseInt(price * 100); 201 | console.log(amount, 'amount inside the intent') 202 | 203 | const paymentIntent = await stripe.paymentIntents.create({ 204 | amount: amount, 205 | currency: 'usd', 206 | payment_method_types: ['card'] 207 | }); 208 | 209 | res.send({ 210 | clientSecret: paymentIntent.client_secret 211 | }) 212 | }); 213 | 214 | 215 | app.get('/payments/:email', verifyToken, async (req, res) => { 216 | const query = { email: req.params.email } 217 | if (req.params.email !== req.decoded.email) { 218 | return res.status(403).send({ message: 'forbidden access' }); 219 | } 220 | const result = await paymentCollection.find(query).toArray(); 221 | res.send(result); 222 | }) 223 | 224 | app.post('/payments', async (req, res) => { 225 | const payment = req.body; 226 | const paymentResult = await paymentCollection.insertOne(payment); 227 | 228 | // carefully delete each item from the cart 229 | console.log('payment info', payment); 230 | const query = { 231 | _id: { 232 | $in: payment.cartIds.map(id => new ObjectId(id)) 233 | } 234 | }; 235 | 236 | const deleteResult = await cartCollection.deleteMany(query); 237 | 238 | res.send({ paymentResult, deleteResult }); 239 | }) 240 | 241 | // stats or analytics 242 | app.get('/admin-stats', verifyToken, verifyAdmin, async (req, res) => { 243 | const users = await userCollection.estimatedDocumentCount(); 244 | const menuItems = await menuCollection.estimatedDocumentCount(); 245 | const orders = await paymentCollection.estimatedDocumentCount(); 246 | 247 | // this is not the best way 248 | // const payments = await paymentCollection.find().toArray(); 249 | // const revenue = payments.reduce((total, payment) => total + payment.price, 0); 250 | 251 | const result = await paymentCollection.aggregate([ 252 | { 253 | $group: { 254 | _id: null, 255 | totalRevenue: { 256 | $sum: '$price' 257 | } 258 | } 259 | } 260 | ]).toArray(); 261 | 262 | const revenue = result.length > 0 ? result[0].totalRevenue : 0; 263 | 264 | res.send({ 265 | users, 266 | menuItems, 267 | orders, 268 | revenue 269 | }) 270 | }) 271 | 272 | 273 | // order status 274 | /** 275 | * ---------------------------- 276 | * NON-Efficient Way 277 | * ------------------------------ 278 | * 1. load all the payments 279 | * 2. for every menuItemIds (which is an array), go find the item from menu collection 280 | * 3. for every item in the menu collection that you found from a payment entry (document) 281 | */ 282 | 283 | // using aggregate pipeline 284 | app.get('/order-stats', verifyToken, verifyAdmin, async(req, res) =>{ 285 | const result = await paymentCollection.aggregate([ 286 | { 287 | $unwind: '$menuItemIds' 288 | }, 289 | { 290 | $lookup: { 291 | from: 'menu', 292 | localField: 'menuItemIds', 293 | foreignField: '_id', 294 | as: 'menuItems' 295 | } 296 | }, 297 | { 298 | $unwind: '$menuItems' 299 | }, 300 | { 301 | $group: { 302 | _id: '$menuItems.category', 303 | quantity:{ $sum: 1 }, 304 | revenue: { $sum: '$menuItems.price'} 305 | } 306 | }, 307 | { 308 | $project: { 309 | _id: 0, 310 | category: '$_id', 311 | quantity: '$quantity', 312 | revenue: '$revenue' 313 | } 314 | } 315 | ]).toArray(); 316 | 317 | res.send(result); 318 | 319 | }) 320 | 321 | // Send a ping to confirm a successful connection 322 | // await client.db("admin").command({ ping: 1 }); 323 | // console.log("Pinged your deployment. You successfully connected to MongoDB!"); 324 | } finally { 325 | // Ensures that the client will close when you finish/error 326 | // await client.close(); 327 | } 328 | } 329 | run().catch(console.dir); 330 | 331 | 332 | app.get('/', (req, res) => { 333 | res.send('boss is sitting') 334 | }) 335 | 336 | app.listen(port, () => { 337 | console.log(`Bistro boss is sitting on port ${port}`); 338 | }) 339 | 340 | /** 341 | * -------------------------------- 342 | * NAMING CONVENTION 343 | * -------------------------------- 344 | * app.get('/users') 345 | * app.get('/users/:id') 346 | * app.post('/users') 347 | * app.put('/users/:id') 348 | * app.patch('/users/:id') 349 | * app.delete('/users/:id') 350 | * 351 | */ -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "bistro-boss-server", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "bistro-boss-server", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "cors": "^2.8.5", 13 | "dotenv": "^16.0.3", 14 | "express": "^4.18.2", 15 | "jsonwebtoken": "^9.0.2", 16 | "mongodb": "^5.5.0", 17 | "stripe": "^14.5.0" 18 | } 19 | }, 20 | "node_modules/@types/node": { 21 | "version": "20.2.3", 22 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.2.3.tgz", 23 | "integrity": "sha512-pg9d0yC4rVNWQzX8U7xb4olIOFuuVL9za3bzMT2pu2SU0SNEi66i2qrvhE2qt0HvkhuCaWJu7pLNOt/Pj8BIrw==" 24 | }, 25 | "node_modules/@types/webidl-conversions": { 26 | "version": "7.0.0", 27 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 28 | "integrity": "sha512-xTE1E+YF4aWPJJeUzaZI5DRntlkY3+BCVJi0axFptnjGmAoWxkyREIh/XMrfxVLejwQxMCfDXdICo0VLxThrog==" 29 | }, 30 | "node_modules/@types/whatwg-url": { 31 | "version": "8.2.2", 32 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.2.tgz", 33 | "integrity": "sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA==", 34 | "dependencies": { 35 | "@types/node": "*", 36 | "@types/webidl-conversions": "*" 37 | } 38 | }, 39 | "node_modules/accepts": { 40 | "version": "1.3.8", 41 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 42 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 43 | "dependencies": { 44 | "mime-types": "~2.1.34", 45 | "negotiator": "0.6.3" 46 | }, 47 | "engines": { 48 | "node": ">= 0.6" 49 | } 50 | }, 51 | "node_modules/array-flatten": { 52 | "version": "1.1.1", 53 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 54 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 55 | }, 56 | "node_modules/body-parser": { 57 | "version": "1.20.1", 58 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 59 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 60 | "dependencies": { 61 | "bytes": "3.1.2", 62 | "content-type": "~1.0.4", 63 | "debug": "2.6.9", 64 | "depd": "2.0.0", 65 | "destroy": "1.2.0", 66 | "http-errors": "2.0.0", 67 | "iconv-lite": "0.4.24", 68 | "on-finished": "2.4.1", 69 | "qs": "6.11.0", 70 | "raw-body": "2.5.1", 71 | "type-is": "~1.6.18", 72 | "unpipe": "1.0.0" 73 | }, 74 | "engines": { 75 | "node": ">= 0.8", 76 | "npm": "1.2.8000 || >= 1.4.16" 77 | } 78 | }, 79 | "node_modules/bson": { 80 | "version": "5.3.0", 81 | "resolved": "https://registry.npmjs.org/bson/-/bson-5.3.0.tgz", 82 | "integrity": "sha512-ukmCZMneMlaC5ebPHXIkP8YJzNl5DC41N5MAIvKDqLggdao342t4McltoJBQfQya/nHBWAcSsYRqlXPoQkTJag==", 83 | "engines": { 84 | "node": ">=14.20.1" 85 | } 86 | }, 87 | "node_modules/buffer-equal-constant-time": { 88 | "version": "1.0.1", 89 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 90 | "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" 91 | }, 92 | "node_modules/bytes": { 93 | "version": "3.1.2", 94 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 95 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 96 | "engines": { 97 | "node": ">= 0.8" 98 | } 99 | }, 100 | "node_modules/call-bind": { 101 | "version": "1.0.2", 102 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 103 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 104 | "dependencies": { 105 | "function-bind": "^1.1.1", 106 | "get-intrinsic": "^1.0.2" 107 | }, 108 | "funding": { 109 | "url": "https://github.com/sponsors/ljharb" 110 | } 111 | }, 112 | "node_modules/content-disposition": { 113 | "version": "0.5.4", 114 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 115 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 116 | "dependencies": { 117 | "safe-buffer": "5.2.1" 118 | }, 119 | "engines": { 120 | "node": ">= 0.6" 121 | } 122 | }, 123 | "node_modules/content-type": { 124 | "version": "1.0.5", 125 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 126 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 127 | "engines": { 128 | "node": ">= 0.6" 129 | } 130 | }, 131 | "node_modules/cookie": { 132 | "version": "0.5.0", 133 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 134 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", 135 | "engines": { 136 | "node": ">= 0.6" 137 | } 138 | }, 139 | "node_modules/cookie-signature": { 140 | "version": "1.0.6", 141 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 142 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 143 | }, 144 | "node_modules/cors": { 145 | "version": "2.8.5", 146 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 147 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 148 | "dependencies": { 149 | "object-assign": "^4", 150 | "vary": "^1" 151 | }, 152 | "engines": { 153 | "node": ">= 0.10" 154 | } 155 | }, 156 | "node_modules/debug": { 157 | "version": "2.6.9", 158 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 159 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 160 | "dependencies": { 161 | "ms": "2.0.0" 162 | } 163 | }, 164 | "node_modules/depd": { 165 | "version": "2.0.0", 166 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 167 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 168 | "engines": { 169 | "node": ">= 0.8" 170 | } 171 | }, 172 | "node_modules/destroy": { 173 | "version": "1.2.0", 174 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 175 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 176 | "engines": { 177 | "node": ">= 0.8", 178 | "npm": "1.2.8000 || >= 1.4.16" 179 | } 180 | }, 181 | "node_modules/dotenv": { 182 | "version": "16.0.3", 183 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 184 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==", 185 | "engines": { 186 | "node": ">=12" 187 | } 188 | }, 189 | "node_modules/ecdsa-sig-formatter": { 190 | "version": "1.0.11", 191 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 192 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 193 | "dependencies": { 194 | "safe-buffer": "^5.0.1" 195 | } 196 | }, 197 | "node_modules/ee-first": { 198 | "version": "1.1.1", 199 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 200 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 201 | }, 202 | "node_modules/encodeurl": { 203 | "version": "1.0.2", 204 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 205 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 206 | "engines": { 207 | "node": ">= 0.8" 208 | } 209 | }, 210 | "node_modules/escape-html": { 211 | "version": "1.0.3", 212 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 213 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 214 | }, 215 | "node_modules/etag": { 216 | "version": "1.8.1", 217 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 218 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 219 | "engines": { 220 | "node": ">= 0.6" 221 | } 222 | }, 223 | "node_modules/express": { 224 | "version": "4.18.2", 225 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 226 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 227 | "dependencies": { 228 | "accepts": "~1.3.8", 229 | "array-flatten": "1.1.1", 230 | "body-parser": "1.20.1", 231 | "content-disposition": "0.5.4", 232 | "content-type": "~1.0.4", 233 | "cookie": "0.5.0", 234 | "cookie-signature": "1.0.6", 235 | "debug": "2.6.9", 236 | "depd": "2.0.0", 237 | "encodeurl": "~1.0.2", 238 | "escape-html": "~1.0.3", 239 | "etag": "~1.8.1", 240 | "finalhandler": "1.2.0", 241 | "fresh": "0.5.2", 242 | "http-errors": "2.0.0", 243 | "merge-descriptors": "1.0.1", 244 | "methods": "~1.1.2", 245 | "on-finished": "2.4.1", 246 | "parseurl": "~1.3.3", 247 | "path-to-regexp": "0.1.7", 248 | "proxy-addr": "~2.0.7", 249 | "qs": "6.11.0", 250 | "range-parser": "~1.2.1", 251 | "safe-buffer": "5.2.1", 252 | "send": "0.18.0", 253 | "serve-static": "1.15.0", 254 | "setprototypeof": "1.2.0", 255 | "statuses": "2.0.1", 256 | "type-is": "~1.6.18", 257 | "utils-merge": "1.0.1", 258 | "vary": "~1.1.2" 259 | }, 260 | "engines": { 261 | "node": ">= 0.10.0" 262 | } 263 | }, 264 | "node_modules/finalhandler": { 265 | "version": "1.2.0", 266 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 267 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 268 | "dependencies": { 269 | "debug": "2.6.9", 270 | "encodeurl": "~1.0.2", 271 | "escape-html": "~1.0.3", 272 | "on-finished": "2.4.1", 273 | "parseurl": "~1.3.3", 274 | "statuses": "2.0.1", 275 | "unpipe": "~1.0.0" 276 | }, 277 | "engines": { 278 | "node": ">= 0.8" 279 | } 280 | }, 281 | "node_modules/forwarded": { 282 | "version": "0.2.0", 283 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 284 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 285 | "engines": { 286 | "node": ">= 0.6" 287 | } 288 | }, 289 | "node_modules/fresh": { 290 | "version": "0.5.2", 291 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 292 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 293 | "engines": { 294 | "node": ">= 0.6" 295 | } 296 | }, 297 | "node_modules/function-bind": { 298 | "version": "1.1.1", 299 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 300 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 301 | }, 302 | "node_modules/get-intrinsic": { 303 | "version": "1.2.1", 304 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 305 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 306 | "dependencies": { 307 | "function-bind": "^1.1.1", 308 | "has": "^1.0.3", 309 | "has-proto": "^1.0.1", 310 | "has-symbols": "^1.0.3" 311 | }, 312 | "funding": { 313 | "url": "https://github.com/sponsors/ljharb" 314 | } 315 | }, 316 | "node_modules/has": { 317 | "version": "1.0.3", 318 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 319 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 320 | "dependencies": { 321 | "function-bind": "^1.1.1" 322 | }, 323 | "engines": { 324 | "node": ">= 0.4.0" 325 | } 326 | }, 327 | "node_modules/has-proto": { 328 | "version": "1.0.1", 329 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 330 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", 331 | "engines": { 332 | "node": ">= 0.4" 333 | }, 334 | "funding": { 335 | "url": "https://github.com/sponsors/ljharb" 336 | } 337 | }, 338 | "node_modules/has-symbols": { 339 | "version": "1.0.3", 340 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 341 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 342 | "engines": { 343 | "node": ">= 0.4" 344 | }, 345 | "funding": { 346 | "url": "https://github.com/sponsors/ljharb" 347 | } 348 | }, 349 | "node_modules/http-errors": { 350 | "version": "2.0.0", 351 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 352 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 353 | "dependencies": { 354 | "depd": "2.0.0", 355 | "inherits": "2.0.4", 356 | "setprototypeof": "1.2.0", 357 | "statuses": "2.0.1", 358 | "toidentifier": "1.0.1" 359 | }, 360 | "engines": { 361 | "node": ">= 0.8" 362 | } 363 | }, 364 | "node_modules/iconv-lite": { 365 | "version": "0.4.24", 366 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 367 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 368 | "dependencies": { 369 | "safer-buffer": ">= 2.1.2 < 3" 370 | }, 371 | "engines": { 372 | "node": ">=0.10.0" 373 | } 374 | }, 375 | "node_modules/inherits": { 376 | "version": "2.0.4", 377 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 378 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 379 | }, 380 | "node_modules/ip": { 381 | "version": "2.0.0", 382 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 383 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 384 | }, 385 | "node_modules/ipaddr.js": { 386 | "version": "1.9.1", 387 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 388 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 389 | "engines": { 390 | "node": ">= 0.10" 391 | } 392 | }, 393 | "node_modules/jsonwebtoken": { 394 | "version": "9.0.2", 395 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", 396 | "integrity": "sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ==", 397 | "dependencies": { 398 | "jws": "^3.2.2", 399 | "lodash.includes": "^4.3.0", 400 | "lodash.isboolean": "^3.0.3", 401 | "lodash.isinteger": "^4.0.4", 402 | "lodash.isnumber": "^3.0.3", 403 | "lodash.isplainobject": "^4.0.6", 404 | "lodash.isstring": "^4.0.1", 405 | "lodash.once": "^4.0.0", 406 | "ms": "^2.1.1", 407 | "semver": "^7.5.4" 408 | }, 409 | "engines": { 410 | "node": ">=12", 411 | "npm": ">=6" 412 | } 413 | }, 414 | "node_modules/jsonwebtoken/node_modules/ms": { 415 | "version": "2.1.3", 416 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 417 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 418 | }, 419 | "node_modules/jwa": { 420 | "version": "1.4.1", 421 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 422 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 423 | "dependencies": { 424 | "buffer-equal-constant-time": "1.0.1", 425 | "ecdsa-sig-formatter": "1.0.11", 426 | "safe-buffer": "^5.0.1" 427 | } 428 | }, 429 | "node_modules/jws": { 430 | "version": "3.2.2", 431 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 432 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 433 | "dependencies": { 434 | "jwa": "^1.4.1", 435 | "safe-buffer": "^5.0.1" 436 | } 437 | }, 438 | "node_modules/lodash.includes": { 439 | "version": "4.3.0", 440 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 441 | "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" 442 | }, 443 | "node_modules/lodash.isboolean": { 444 | "version": "3.0.3", 445 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 446 | "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" 447 | }, 448 | "node_modules/lodash.isinteger": { 449 | "version": "4.0.4", 450 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 451 | "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" 452 | }, 453 | "node_modules/lodash.isnumber": { 454 | "version": "3.0.3", 455 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 456 | "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" 457 | }, 458 | "node_modules/lodash.isplainobject": { 459 | "version": "4.0.6", 460 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 461 | "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" 462 | }, 463 | "node_modules/lodash.isstring": { 464 | "version": "4.0.1", 465 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 466 | "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" 467 | }, 468 | "node_modules/lodash.once": { 469 | "version": "4.1.1", 470 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 471 | "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" 472 | }, 473 | "node_modules/lru-cache": { 474 | "version": "6.0.0", 475 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 476 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 477 | "dependencies": { 478 | "yallist": "^4.0.0" 479 | }, 480 | "engines": { 481 | "node": ">=10" 482 | } 483 | }, 484 | "node_modules/media-typer": { 485 | "version": "0.3.0", 486 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 487 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 488 | "engines": { 489 | "node": ">= 0.6" 490 | } 491 | }, 492 | "node_modules/memory-pager": { 493 | "version": "1.5.0", 494 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 495 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 496 | "optional": true 497 | }, 498 | "node_modules/merge-descriptors": { 499 | "version": "1.0.1", 500 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 501 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 502 | }, 503 | "node_modules/methods": { 504 | "version": "1.1.2", 505 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 506 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 507 | "engines": { 508 | "node": ">= 0.6" 509 | } 510 | }, 511 | "node_modules/mime": { 512 | "version": "1.6.0", 513 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 514 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 515 | "bin": { 516 | "mime": "cli.js" 517 | }, 518 | "engines": { 519 | "node": ">=4" 520 | } 521 | }, 522 | "node_modules/mime-db": { 523 | "version": "1.52.0", 524 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 525 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 526 | "engines": { 527 | "node": ">= 0.6" 528 | } 529 | }, 530 | "node_modules/mime-types": { 531 | "version": "2.1.35", 532 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 533 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 534 | "dependencies": { 535 | "mime-db": "1.52.0" 536 | }, 537 | "engines": { 538 | "node": ">= 0.6" 539 | } 540 | }, 541 | "node_modules/mongodb": { 542 | "version": "5.5.0", 543 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-5.5.0.tgz", 544 | "integrity": "sha512-XgrkUgAAdfnZKQfk5AsYL8j7O99WHd4YXPxYxnh8dZxD+ekYWFRA3JktUsBnfg+455Smf75/+asoU/YLwNGoQQ==", 545 | "dependencies": { 546 | "bson": "^5.3.0", 547 | "mongodb-connection-string-url": "^2.6.0", 548 | "socks": "^2.7.1" 549 | }, 550 | "engines": { 551 | "node": ">=14.20.1" 552 | }, 553 | "optionalDependencies": { 554 | "saslprep": "^1.0.3" 555 | }, 556 | "peerDependencies": { 557 | "@aws-sdk/credential-providers": "^3.201.0", 558 | "mongodb-client-encryption": ">=2.3.0 <3", 559 | "snappy": "^7.2.2" 560 | }, 561 | "peerDependenciesMeta": { 562 | "@aws-sdk/credential-providers": { 563 | "optional": true 564 | }, 565 | "mongodb-client-encryption": { 566 | "optional": true 567 | }, 568 | "snappy": { 569 | "optional": true 570 | } 571 | } 572 | }, 573 | "node_modules/mongodb-connection-string-url": { 574 | "version": "2.6.0", 575 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz", 576 | "integrity": "sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ==", 577 | "dependencies": { 578 | "@types/whatwg-url": "^8.2.1", 579 | "whatwg-url": "^11.0.0" 580 | } 581 | }, 582 | "node_modules/ms": { 583 | "version": "2.0.0", 584 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 585 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 586 | }, 587 | "node_modules/negotiator": { 588 | "version": "0.6.3", 589 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 590 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 591 | "engines": { 592 | "node": ">= 0.6" 593 | } 594 | }, 595 | "node_modules/object-assign": { 596 | "version": "4.1.1", 597 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 598 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 599 | "engines": { 600 | "node": ">=0.10.0" 601 | } 602 | }, 603 | "node_modules/object-inspect": { 604 | "version": "1.12.3", 605 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 606 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 607 | "funding": { 608 | "url": "https://github.com/sponsors/ljharb" 609 | } 610 | }, 611 | "node_modules/on-finished": { 612 | "version": "2.4.1", 613 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 614 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 615 | "dependencies": { 616 | "ee-first": "1.1.1" 617 | }, 618 | "engines": { 619 | "node": ">= 0.8" 620 | } 621 | }, 622 | "node_modules/parseurl": { 623 | "version": "1.3.3", 624 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 625 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 626 | "engines": { 627 | "node": ">= 0.8" 628 | } 629 | }, 630 | "node_modules/path-to-regexp": { 631 | "version": "0.1.7", 632 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 633 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 634 | }, 635 | "node_modules/proxy-addr": { 636 | "version": "2.0.7", 637 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 638 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 639 | "dependencies": { 640 | "forwarded": "0.2.0", 641 | "ipaddr.js": "1.9.1" 642 | }, 643 | "engines": { 644 | "node": ">= 0.10" 645 | } 646 | }, 647 | "node_modules/punycode": { 648 | "version": "2.3.0", 649 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 650 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 651 | "engines": { 652 | "node": ">=6" 653 | } 654 | }, 655 | "node_modules/qs": { 656 | "version": "6.11.0", 657 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 658 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 659 | "dependencies": { 660 | "side-channel": "^1.0.4" 661 | }, 662 | "engines": { 663 | "node": ">=0.6" 664 | }, 665 | "funding": { 666 | "url": "https://github.com/sponsors/ljharb" 667 | } 668 | }, 669 | "node_modules/range-parser": { 670 | "version": "1.2.1", 671 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 672 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 673 | "engines": { 674 | "node": ">= 0.6" 675 | } 676 | }, 677 | "node_modules/raw-body": { 678 | "version": "2.5.1", 679 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 680 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 681 | "dependencies": { 682 | "bytes": "3.1.2", 683 | "http-errors": "2.0.0", 684 | "iconv-lite": "0.4.24", 685 | "unpipe": "1.0.0" 686 | }, 687 | "engines": { 688 | "node": ">= 0.8" 689 | } 690 | }, 691 | "node_modules/safe-buffer": { 692 | "version": "5.2.1", 693 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 694 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 695 | "funding": [ 696 | { 697 | "type": "github", 698 | "url": "https://github.com/sponsors/feross" 699 | }, 700 | { 701 | "type": "patreon", 702 | "url": "https://www.patreon.com/feross" 703 | }, 704 | { 705 | "type": "consulting", 706 | "url": "https://feross.org/support" 707 | } 708 | ] 709 | }, 710 | "node_modules/safer-buffer": { 711 | "version": "2.1.2", 712 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 713 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 714 | }, 715 | "node_modules/saslprep": { 716 | "version": "1.0.3", 717 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 718 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 719 | "optional": true, 720 | "dependencies": { 721 | "sparse-bitfield": "^3.0.3" 722 | }, 723 | "engines": { 724 | "node": ">=6" 725 | } 726 | }, 727 | "node_modules/semver": { 728 | "version": "7.5.4", 729 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 730 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 731 | "dependencies": { 732 | "lru-cache": "^6.0.0" 733 | }, 734 | "bin": { 735 | "semver": "bin/semver.js" 736 | }, 737 | "engines": { 738 | "node": ">=10" 739 | } 740 | }, 741 | "node_modules/send": { 742 | "version": "0.18.0", 743 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 744 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 745 | "dependencies": { 746 | "debug": "2.6.9", 747 | "depd": "2.0.0", 748 | "destroy": "1.2.0", 749 | "encodeurl": "~1.0.2", 750 | "escape-html": "~1.0.3", 751 | "etag": "~1.8.1", 752 | "fresh": "0.5.2", 753 | "http-errors": "2.0.0", 754 | "mime": "1.6.0", 755 | "ms": "2.1.3", 756 | "on-finished": "2.4.1", 757 | "range-parser": "~1.2.1", 758 | "statuses": "2.0.1" 759 | }, 760 | "engines": { 761 | "node": ">= 0.8.0" 762 | } 763 | }, 764 | "node_modules/send/node_modules/ms": { 765 | "version": "2.1.3", 766 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 767 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 768 | }, 769 | "node_modules/serve-static": { 770 | "version": "1.15.0", 771 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 772 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 773 | "dependencies": { 774 | "encodeurl": "~1.0.2", 775 | "escape-html": "~1.0.3", 776 | "parseurl": "~1.3.3", 777 | "send": "0.18.0" 778 | }, 779 | "engines": { 780 | "node": ">= 0.8.0" 781 | } 782 | }, 783 | "node_modules/setprototypeof": { 784 | "version": "1.2.0", 785 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 786 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 787 | }, 788 | "node_modules/side-channel": { 789 | "version": "1.0.4", 790 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 791 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 792 | "dependencies": { 793 | "call-bind": "^1.0.0", 794 | "get-intrinsic": "^1.0.2", 795 | "object-inspect": "^1.9.0" 796 | }, 797 | "funding": { 798 | "url": "https://github.com/sponsors/ljharb" 799 | } 800 | }, 801 | "node_modules/smart-buffer": { 802 | "version": "4.2.0", 803 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 804 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", 805 | "engines": { 806 | "node": ">= 6.0.0", 807 | "npm": ">= 3.0.0" 808 | } 809 | }, 810 | "node_modules/socks": { 811 | "version": "2.7.1", 812 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 813 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 814 | "dependencies": { 815 | "ip": "^2.0.0", 816 | "smart-buffer": "^4.2.0" 817 | }, 818 | "engines": { 819 | "node": ">= 10.13.0", 820 | "npm": ">= 3.0.0" 821 | } 822 | }, 823 | "node_modules/sparse-bitfield": { 824 | "version": "3.0.3", 825 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 826 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 827 | "optional": true, 828 | "dependencies": { 829 | "memory-pager": "^1.0.2" 830 | } 831 | }, 832 | "node_modules/statuses": { 833 | "version": "2.0.1", 834 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 835 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 836 | "engines": { 837 | "node": ">= 0.8" 838 | } 839 | }, 840 | "node_modules/stripe": { 841 | "version": "14.5.0", 842 | "resolved": "https://registry.npmjs.org/stripe/-/stripe-14.5.0.tgz", 843 | "integrity": "sha512-MTt0P0VYDAj2VZyZMW41AxcXVs9s06EDFIHYat4UUkluJgnBHo4T4E2byPhnxoJCPvdzWBwBLnhWbSOg//VTpA==", 844 | "dependencies": { 845 | "@types/node": ">=8.1.0", 846 | "qs": "^6.11.0" 847 | }, 848 | "engines": { 849 | "node": ">=12.*" 850 | } 851 | }, 852 | "node_modules/toidentifier": { 853 | "version": "1.0.1", 854 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 855 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 856 | "engines": { 857 | "node": ">=0.6" 858 | } 859 | }, 860 | "node_modules/tr46": { 861 | "version": "3.0.0", 862 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 863 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 864 | "dependencies": { 865 | "punycode": "^2.1.1" 866 | }, 867 | "engines": { 868 | "node": ">=12" 869 | } 870 | }, 871 | "node_modules/type-is": { 872 | "version": "1.6.18", 873 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 874 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 875 | "dependencies": { 876 | "media-typer": "0.3.0", 877 | "mime-types": "~2.1.24" 878 | }, 879 | "engines": { 880 | "node": ">= 0.6" 881 | } 882 | }, 883 | "node_modules/unpipe": { 884 | "version": "1.0.0", 885 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 886 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 887 | "engines": { 888 | "node": ">= 0.8" 889 | } 890 | }, 891 | "node_modules/utils-merge": { 892 | "version": "1.0.1", 893 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 894 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 895 | "engines": { 896 | "node": ">= 0.4.0" 897 | } 898 | }, 899 | "node_modules/vary": { 900 | "version": "1.1.2", 901 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 902 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 903 | "engines": { 904 | "node": ">= 0.8" 905 | } 906 | }, 907 | "node_modules/webidl-conversions": { 908 | "version": "7.0.0", 909 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 910 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 911 | "engines": { 912 | "node": ">=12" 913 | } 914 | }, 915 | "node_modules/whatwg-url": { 916 | "version": "11.0.0", 917 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 918 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 919 | "dependencies": { 920 | "tr46": "^3.0.0", 921 | "webidl-conversions": "^7.0.0" 922 | }, 923 | "engines": { 924 | "node": ">=12" 925 | } 926 | }, 927 | "node_modules/yallist": { 928 | "version": "4.0.0", 929 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 930 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 931 | } 932 | }, 933 | "dependencies": { 934 | "@types/node": { 935 | "version": "20.2.3", 936 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.2.3.tgz", 937 | "integrity": "sha512-pg9d0yC4rVNWQzX8U7xb4olIOFuuVL9za3bzMT2pu2SU0SNEi66i2qrvhE2qt0HvkhuCaWJu7pLNOt/Pj8BIrw==" 938 | }, 939 | "@types/webidl-conversions": { 940 | "version": "7.0.0", 941 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 942 | "integrity": "sha512-xTE1E+YF4aWPJJeUzaZI5DRntlkY3+BCVJi0axFptnjGmAoWxkyREIh/XMrfxVLejwQxMCfDXdICo0VLxThrog==" 943 | }, 944 | "@types/whatwg-url": { 945 | "version": "8.2.2", 946 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.2.tgz", 947 | "integrity": "sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA==", 948 | "requires": { 949 | "@types/node": "*", 950 | "@types/webidl-conversions": "*" 951 | } 952 | }, 953 | "accepts": { 954 | "version": "1.3.8", 955 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 956 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 957 | "requires": { 958 | "mime-types": "~2.1.34", 959 | "negotiator": "0.6.3" 960 | } 961 | }, 962 | "array-flatten": { 963 | "version": "1.1.1", 964 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 965 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 966 | }, 967 | "body-parser": { 968 | "version": "1.20.1", 969 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", 970 | "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", 971 | "requires": { 972 | "bytes": "3.1.2", 973 | "content-type": "~1.0.4", 974 | "debug": "2.6.9", 975 | "depd": "2.0.0", 976 | "destroy": "1.2.0", 977 | "http-errors": "2.0.0", 978 | "iconv-lite": "0.4.24", 979 | "on-finished": "2.4.1", 980 | "qs": "6.11.0", 981 | "raw-body": "2.5.1", 982 | "type-is": "~1.6.18", 983 | "unpipe": "1.0.0" 984 | } 985 | }, 986 | "bson": { 987 | "version": "5.3.0", 988 | "resolved": "https://registry.npmjs.org/bson/-/bson-5.3.0.tgz", 989 | "integrity": "sha512-ukmCZMneMlaC5ebPHXIkP8YJzNl5DC41N5MAIvKDqLggdao342t4McltoJBQfQya/nHBWAcSsYRqlXPoQkTJag==" 990 | }, 991 | "buffer-equal-constant-time": { 992 | "version": "1.0.1", 993 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 994 | "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" 995 | }, 996 | "bytes": { 997 | "version": "3.1.2", 998 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 999 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" 1000 | }, 1001 | "call-bind": { 1002 | "version": "1.0.2", 1003 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 1004 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 1005 | "requires": { 1006 | "function-bind": "^1.1.1", 1007 | "get-intrinsic": "^1.0.2" 1008 | } 1009 | }, 1010 | "content-disposition": { 1011 | "version": "0.5.4", 1012 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 1013 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 1014 | "requires": { 1015 | "safe-buffer": "5.2.1" 1016 | } 1017 | }, 1018 | "content-type": { 1019 | "version": "1.0.5", 1020 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 1021 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==" 1022 | }, 1023 | "cookie": { 1024 | "version": "0.5.0", 1025 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", 1026 | "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==" 1027 | }, 1028 | "cookie-signature": { 1029 | "version": "1.0.6", 1030 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 1031 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 1032 | }, 1033 | "cors": { 1034 | "version": "2.8.5", 1035 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 1036 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 1037 | "requires": { 1038 | "object-assign": "^4", 1039 | "vary": "^1" 1040 | } 1041 | }, 1042 | "debug": { 1043 | "version": "2.6.9", 1044 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1045 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1046 | "requires": { 1047 | "ms": "2.0.0" 1048 | } 1049 | }, 1050 | "depd": { 1051 | "version": "2.0.0", 1052 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 1053 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 1054 | }, 1055 | "destroy": { 1056 | "version": "1.2.0", 1057 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 1058 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" 1059 | }, 1060 | "dotenv": { 1061 | "version": "16.0.3", 1062 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.0.3.tgz", 1063 | "integrity": "sha512-7GO6HghkA5fYG9TYnNxi14/7K9f5occMlp3zXAuSxn7CKCxt9xbNWG7yF8hTCSUchlfWSe3uLmlPfigevRItzQ==" 1064 | }, 1065 | "ecdsa-sig-formatter": { 1066 | "version": "1.0.11", 1067 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 1068 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 1069 | "requires": { 1070 | "safe-buffer": "^5.0.1" 1071 | } 1072 | }, 1073 | "ee-first": { 1074 | "version": "1.1.1", 1075 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 1076 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 1077 | }, 1078 | "encodeurl": { 1079 | "version": "1.0.2", 1080 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 1081 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" 1082 | }, 1083 | "escape-html": { 1084 | "version": "1.0.3", 1085 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 1086 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 1087 | }, 1088 | "etag": { 1089 | "version": "1.8.1", 1090 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1091 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==" 1092 | }, 1093 | "express": { 1094 | "version": "4.18.2", 1095 | "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", 1096 | "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", 1097 | "requires": { 1098 | "accepts": "~1.3.8", 1099 | "array-flatten": "1.1.1", 1100 | "body-parser": "1.20.1", 1101 | "content-disposition": "0.5.4", 1102 | "content-type": "~1.0.4", 1103 | "cookie": "0.5.0", 1104 | "cookie-signature": "1.0.6", 1105 | "debug": "2.6.9", 1106 | "depd": "2.0.0", 1107 | "encodeurl": "~1.0.2", 1108 | "escape-html": "~1.0.3", 1109 | "etag": "~1.8.1", 1110 | "finalhandler": "1.2.0", 1111 | "fresh": "0.5.2", 1112 | "http-errors": "2.0.0", 1113 | "merge-descriptors": "1.0.1", 1114 | "methods": "~1.1.2", 1115 | "on-finished": "2.4.1", 1116 | "parseurl": "~1.3.3", 1117 | "path-to-regexp": "0.1.7", 1118 | "proxy-addr": "~2.0.7", 1119 | "qs": "6.11.0", 1120 | "range-parser": "~1.2.1", 1121 | "safe-buffer": "5.2.1", 1122 | "send": "0.18.0", 1123 | "serve-static": "1.15.0", 1124 | "setprototypeof": "1.2.0", 1125 | "statuses": "2.0.1", 1126 | "type-is": "~1.6.18", 1127 | "utils-merge": "1.0.1", 1128 | "vary": "~1.1.2" 1129 | } 1130 | }, 1131 | "finalhandler": { 1132 | "version": "1.2.0", 1133 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", 1134 | "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", 1135 | "requires": { 1136 | "debug": "2.6.9", 1137 | "encodeurl": "~1.0.2", 1138 | "escape-html": "~1.0.3", 1139 | "on-finished": "2.4.1", 1140 | "parseurl": "~1.3.3", 1141 | "statuses": "2.0.1", 1142 | "unpipe": "~1.0.0" 1143 | } 1144 | }, 1145 | "forwarded": { 1146 | "version": "0.2.0", 1147 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 1148 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 1149 | }, 1150 | "fresh": { 1151 | "version": "0.5.2", 1152 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1153 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" 1154 | }, 1155 | "function-bind": { 1156 | "version": "1.1.1", 1157 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1158 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 1159 | }, 1160 | "get-intrinsic": { 1161 | "version": "1.2.1", 1162 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.1.tgz", 1163 | "integrity": "sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==", 1164 | "requires": { 1165 | "function-bind": "^1.1.1", 1166 | "has": "^1.0.3", 1167 | "has-proto": "^1.0.1", 1168 | "has-symbols": "^1.0.3" 1169 | } 1170 | }, 1171 | "has": { 1172 | "version": "1.0.3", 1173 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1174 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1175 | "requires": { 1176 | "function-bind": "^1.1.1" 1177 | } 1178 | }, 1179 | "has-proto": { 1180 | "version": "1.0.1", 1181 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 1182 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==" 1183 | }, 1184 | "has-symbols": { 1185 | "version": "1.0.3", 1186 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 1187 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" 1188 | }, 1189 | "http-errors": { 1190 | "version": "2.0.0", 1191 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 1192 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 1193 | "requires": { 1194 | "depd": "2.0.0", 1195 | "inherits": "2.0.4", 1196 | "setprototypeof": "1.2.0", 1197 | "statuses": "2.0.1", 1198 | "toidentifier": "1.0.1" 1199 | } 1200 | }, 1201 | "iconv-lite": { 1202 | "version": "0.4.24", 1203 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1204 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1205 | "requires": { 1206 | "safer-buffer": ">= 2.1.2 < 3" 1207 | } 1208 | }, 1209 | "inherits": { 1210 | "version": "2.0.4", 1211 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1212 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1213 | }, 1214 | "ip": { 1215 | "version": "2.0.0", 1216 | "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz", 1217 | "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==" 1218 | }, 1219 | "ipaddr.js": { 1220 | "version": "1.9.1", 1221 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1222 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 1223 | }, 1224 | "jsonwebtoken": { 1225 | "version": "9.0.2", 1226 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", 1227 | "integrity": "sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ==", 1228 | "requires": { 1229 | "jws": "^3.2.2", 1230 | "lodash.includes": "^4.3.0", 1231 | "lodash.isboolean": "^3.0.3", 1232 | "lodash.isinteger": "^4.0.4", 1233 | "lodash.isnumber": "^3.0.3", 1234 | "lodash.isplainobject": "^4.0.6", 1235 | "lodash.isstring": "^4.0.1", 1236 | "lodash.once": "^4.0.0", 1237 | "ms": "^2.1.1", 1238 | "semver": "^7.5.4" 1239 | }, 1240 | "dependencies": { 1241 | "ms": { 1242 | "version": "2.1.3", 1243 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1244 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1245 | } 1246 | } 1247 | }, 1248 | "jwa": { 1249 | "version": "1.4.1", 1250 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 1251 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 1252 | "requires": { 1253 | "buffer-equal-constant-time": "1.0.1", 1254 | "ecdsa-sig-formatter": "1.0.11", 1255 | "safe-buffer": "^5.0.1" 1256 | } 1257 | }, 1258 | "jws": { 1259 | "version": "3.2.2", 1260 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 1261 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 1262 | "requires": { 1263 | "jwa": "^1.4.1", 1264 | "safe-buffer": "^5.0.1" 1265 | } 1266 | }, 1267 | "lodash.includes": { 1268 | "version": "4.3.0", 1269 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1270 | "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" 1271 | }, 1272 | "lodash.isboolean": { 1273 | "version": "3.0.3", 1274 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1275 | "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" 1276 | }, 1277 | "lodash.isinteger": { 1278 | "version": "4.0.4", 1279 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1280 | "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" 1281 | }, 1282 | "lodash.isnumber": { 1283 | "version": "3.0.3", 1284 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1285 | "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" 1286 | }, 1287 | "lodash.isplainobject": { 1288 | "version": "4.0.6", 1289 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1290 | "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" 1291 | }, 1292 | "lodash.isstring": { 1293 | "version": "4.0.1", 1294 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1295 | "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" 1296 | }, 1297 | "lodash.once": { 1298 | "version": "4.1.1", 1299 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1300 | "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" 1301 | }, 1302 | "lru-cache": { 1303 | "version": "6.0.0", 1304 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1305 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1306 | "requires": { 1307 | "yallist": "^4.0.0" 1308 | } 1309 | }, 1310 | "media-typer": { 1311 | "version": "0.3.0", 1312 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1313 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" 1314 | }, 1315 | "memory-pager": { 1316 | "version": "1.5.0", 1317 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1318 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1319 | "optional": true 1320 | }, 1321 | "merge-descriptors": { 1322 | "version": "1.0.1", 1323 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1324 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 1325 | }, 1326 | "methods": { 1327 | "version": "1.1.2", 1328 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1329 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==" 1330 | }, 1331 | "mime": { 1332 | "version": "1.6.0", 1333 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1334 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1335 | }, 1336 | "mime-db": { 1337 | "version": "1.52.0", 1338 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1339 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" 1340 | }, 1341 | "mime-types": { 1342 | "version": "2.1.35", 1343 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1344 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1345 | "requires": { 1346 | "mime-db": "1.52.0" 1347 | } 1348 | }, 1349 | "mongodb": { 1350 | "version": "5.5.0", 1351 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-5.5.0.tgz", 1352 | "integrity": "sha512-XgrkUgAAdfnZKQfk5AsYL8j7O99WHd4YXPxYxnh8dZxD+ekYWFRA3JktUsBnfg+455Smf75/+asoU/YLwNGoQQ==", 1353 | "requires": { 1354 | "bson": "^5.3.0", 1355 | "mongodb-connection-string-url": "^2.6.0", 1356 | "saslprep": "^1.0.3", 1357 | "socks": "^2.7.1" 1358 | } 1359 | }, 1360 | "mongodb-connection-string-url": { 1361 | "version": "2.6.0", 1362 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz", 1363 | "integrity": "sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ==", 1364 | "requires": { 1365 | "@types/whatwg-url": "^8.2.1", 1366 | "whatwg-url": "^11.0.0" 1367 | } 1368 | }, 1369 | "ms": { 1370 | "version": "2.0.0", 1371 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1372 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 1373 | }, 1374 | "negotiator": { 1375 | "version": "0.6.3", 1376 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 1377 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" 1378 | }, 1379 | "object-assign": { 1380 | "version": "4.1.1", 1381 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1382 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==" 1383 | }, 1384 | "object-inspect": { 1385 | "version": "1.12.3", 1386 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 1387 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==" 1388 | }, 1389 | "on-finished": { 1390 | "version": "2.4.1", 1391 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1392 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1393 | "requires": { 1394 | "ee-first": "1.1.1" 1395 | } 1396 | }, 1397 | "parseurl": { 1398 | "version": "1.3.3", 1399 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1400 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1401 | }, 1402 | "path-to-regexp": { 1403 | "version": "0.1.7", 1404 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1405 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 1406 | }, 1407 | "proxy-addr": { 1408 | "version": "2.0.7", 1409 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1410 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1411 | "requires": { 1412 | "forwarded": "0.2.0", 1413 | "ipaddr.js": "1.9.1" 1414 | } 1415 | }, 1416 | "punycode": { 1417 | "version": "2.3.0", 1418 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 1419 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==" 1420 | }, 1421 | "qs": { 1422 | "version": "6.11.0", 1423 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", 1424 | "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", 1425 | "requires": { 1426 | "side-channel": "^1.0.4" 1427 | } 1428 | }, 1429 | "range-parser": { 1430 | "version": "1.2.1", 1431 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1432 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1433 | }, 1434 | "raw-body": { 1435 | "version": "2.5.1", 1436 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", 1437 | "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", 1438 | "requires": { 1439 | "bytes": "3.1.2", 1440 | "http-errors": "2.0.0", 1441 | "iconv-lite": "0.4.24", 1442 | "unpipe": "1.0.0" 1443 | } 1444 | }, 1445 | "safe-buffer": { 1446 | "version": "5.2.1", 1447 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1448 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 1449 | }, 1450 | "safer-buffer": { 1451 | "version": "2.1.2", 1452 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1453 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1454 | }, 1455 | "saslprep": { 1456 | "version": "1.0.3", 1457 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 1458 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 1459 | "optional": true, 1460 | "requires": { 1461 | "sparse-bitfield": "^3.0.3" 1462 | } 1463 | }, 1464 | "semver": { 1465 | "version": "7.5.4", 1466 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 1467 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 1468 | "requires": { 1469 | "lru-cache": "^6.0.0" 1470 | } 1471 | }, 1472 | "send": { 1473 | "version": "0.18.0", 1474 | "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", 1475 | "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", 1476 | "requires": { 1477 | "debug": "2.6.9", 1478 | "depd": "2.0.0", 1479 | "destroy": "1.2.0", 1480 | "encodeurl": "~1.0.2", 1481 | "escape-html": "~1.0.3", 1482 | "etag": "~1.8.1", 1483 | "fresh": "0.5.2", 1484 | "http-errors": "2.0.0", 1485 | "mime": "1.6.0", 1486 | "ms": "2.1.3", 1487 | "on-finished": "2.4.1", 1488 | "range-parser": "~1.2.1", 1489 | "statuses": "2.0.1" 1490 | }, 1491 | "dependencies": { 1492 | "ms": { 1493 | "version": "2.1.3", 1494 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1495 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1496 | } 1497 | } 1498 | }, 1499 | "serve-static": { 1500 | "version": "1.15.0", 1501 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", 1502 | "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", 1503 | "requires": { 1504 | "encodeurl": "~1.0.2", 1505 | "escape-html": "~1.0.3", 1506 | "parseurl": "~1.3.3", 1507 | "send": "0.18.0" 1508 | } 1509 | }, 1510 | "setprototypeof": { 1511 | "version": "1.2.0", 1512 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1513 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 1514 | }, 1515 | "side-channel": { 1516 | "version": "1.0.4", 1517 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1518 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1519 | "requires": { 1520 | "call-bind": "^1.0.0", 1521 | "get-intrinsic": "^1.0.2", 1522 | "object-inspect": "^1.9.0" 1523 | } 1524 | }, 1525 | "smart-buffer": { 1526 | "version": "4.2.0", 1527 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", 1528 | "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" 1529 | }, 1530 | "socks": { 1531 | "version": "2.7.1", 1532 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz", 1533 | "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==", 1534 | "requires": { 1535 | "ip": "^2.0.0", 1536 | "smart-buffer": "^4.2.0" 1537 | } 1538 | }, 1539 | "sparse-bitfield": { 1540 | "version": "3.0.3", 1541 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1542 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 1543 | "optional": true, 1544 | "requires": { 1545 | "memory-pager": "^1.0.2" 1546 | } 1547 | }, 1548 | "statuses": { 1549 | "version": "2.0.1", 1550 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1551 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" 1552 | }, 1553 | "stripe": { 1554 | "version": "14.5.0", 1555 | "resolved": "https://registry.npmjs.org/stripe/-/stripe-14.5.0.tgz", 1556 | "integrity": "sha512-MTt0P0VYDAj2VZyZMW41AxcXVs9s06EDFIHYat4UUkluJgnBHo4T4E2byPhnxoJCPvdzWBwBLnhWbSOg//VTpA==", 1557 | "requires": { 1558 | "@types/node": ">=8.1.0", 1559 | "qs": "^6.11.0" 1560 | } 1561 | }, 1562 | "toidentifier": { 1563 | "version": "1.0.1", 1564 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1565 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" 1566 | }, 1567 | "tr46": { 1568 | "version": "3.0.0", 1569 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 1570 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 1571 | "requires": { 1572 | "punycode": "^2.1.1" 1573 | } 1574 | }, 1575 | "type-is": { 1576 | "version": "1.6.18", 1577 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1578 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1579 | "requires": { 1580 | "media-typer": "0.3.0", 1581 | "mime-types": "~2.1.24" 1582 | } 1583 | }, 1584 | "unpipe": { 1585 | "version": "1.0.0", 1586 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1587 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==" 1588 | }, 1589 | "utils-merge": { 1590 | "version": "1.0.1", 1591 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1592 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==" 1593 | }, 1594 | "vary": { 1595 | "version": "1.1.2", 1596 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1597 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==" 1598 | }, 1599 | "webidl-conversions": { 1600 | "version": "7.0.0", 1601 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1602 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==" 1603 | }, 1604 | "whatwg-url": { 1605 | "version": "11.0.0", 1606 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 1607 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 1608 | "requires": { 1609 | "tr46": "^3.0.0", 1610 | "webidl-conversions": "^7.0.0" 1611 | } 1612 | }, 1613 | "yallist": { 1614 | "version": "4.0.0", 1615 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1616 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1617 | } 1618 | } 1619 | } 1620 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "bistro-boss-server", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "node index.js", 8 | "test": "echo \"Error: no test specified\" && exit 1" 9 | }, 10 | "keywords": [], 11 | "author": "", 12 | "license": "ISC", 13 | "dependencies": { 14 | "cors": "^2.8.5", 15 | "dotenv": "^16.0.3", 16 | "express": "^4.18.2", 17 | "jsonwebtoken": "^9.0.2", 18 | "mongodb": "^5.5.0", 19 | "stripe": "^14.5.0" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /vercel.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": 2, 3 | "builds": [ 4 | { 5 | "src": "./index.js", 6 | "use": "@vercel/node" 7 | } 8 | ], 9 | "routes": [ 10 | { 11 | "src": "/(.*)", 12 | "dest": "/", 13 | "methods": ["GET", "POST", "PUT", "PATCH", "DELETE", "OPTIONS"] 14 | } 15 | ] 16 | } --------------------------------------------------------------------------------