├── server ├── .gitignore ├── package.json ├── Document.js ├── server.js └── package-lock.json ├── client ├── vercel.json ├── vite.config.js ├── .gitignore ├── index.html ├── src │ ├── main.jsx │ ├── App.jsx │ ├── App.css │ ├── index.css │ ├── TextEditor.jsx │ └── assets │ │ └── react.svg ├── package.json └── eslint.config.js ├── Screenshot 2024-09-15 205900.png ├── Screenshot 2024-09-15 213221.png ├── LICENSE └── README.md /server/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | -------------------------------------------------------------------------------- /client/vercel.json: -------------------------------------------------------------------------------- 1 | { 2 | "rewrites": [ 3 | { "source": "/(.*)", "destination": "/index.html" } 4 | ] 5 | } 6 | -------------------------------------------------------------------------------- /Screenshot 2024-09-15 205900.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/hackice20/Sync-Script/HEAD/Screenshot 2024-09-15 205900.png -------------------------------------------------------------------------------- /Screenshot 2024-09-15 213221.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/hackice20/Sync-Script/HEAD/Screenshot 2024-09-15 213221.png -------------------------------------------------------------------------------- /client/vite.config.js: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()], 7 | }) 8 | -------------------------------------------------------------------------------- /client/.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | -------------------------------------------------------------------------------- /client/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Vite + React 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /client/src/main.jsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import ReactDOM from "react-dom/client"; 3 | import App from "./App"; 4 | import "./App.css"; // Assuming you are using app.css now instead of styles.css 5 | 6 | // Create the root element for the React app 7 | const root = ReactDOM.createRoot(document.getElementById("root")); 8 | 9 | // Render the application 10 | root.render( 11 | 12 | 13 | 14 | ); 15 | 16 | -------------------------------------------------------------------------------- /server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "main": "server.js", 5 | "scripts": { 6 | "test": "echo \"Error: no test specified\" && exit 1", 7 | "start": "nodemon server.js" 8 | }, 9 | "author": "yashs", 10 | "license": "ISC", 11 | "description": "", 12 | "dependencies": { 13 | "express": "^4.21.0", 14 | "mongoose": "^8.6.2", 15 | "nodemon": "^3.1.4", 16 | "socket.io": "^4.7.5", 17 | "cors": "^2.8.5", 18 | "dotenv": "16.4.7" 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /client/src/App.jsx: -------------------------------------------------------------------------------- 1 | import TextEditor from "./TextEditor"; 2 | import { BrowserRouter as Router, Routes, Route, Navigate } from "react-router-dom"; 3 | import { v4 as uuidV4 } from "uuid"; 4 | 5 | function App() { 6 | return ( 7 | 8 | 9 | } 12 | /> 13 | } /> 14 | 15 | 16 | ); 17 | } 18 | 19 | export default App; 20 | 21 | -------------------------------------------------------------------------------- /server/Document.js: -------------------------------------------------------------------------------- 1 | const { Schema, model } = require("mongoose") 2 | 3 | // Define the Document schema 4 | const documentSchema = new Schema( 5 | { 6 | _id: { 7 | type: String, 8 | required: true, 9 | }, 10 | data: { 11 | type: Object, 12 | required: true, 13 | default: {}, // Ensure there's a default empty object if no data is provided 14 | }, 15 | }, 16 | { 17 | timestamps: true, // Adds createdAt and updatedAt timestamps automatically 18 | versionKey: false, // Removes the __v field, which tracks schema versioning 19 | } 20 | ) 21 | 22 | // Export the Document model 23 | module.exports = model("Document", documentSchema) 24 | -------------------------------------------------------------------------------- /client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "client", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "vite build", 9 | "lint": "eslint .", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "quill": "^2.0.2", 14 | "react": "^18.3.1", 15 | "react-dom": "^18.3.1", 16 | "react-router-dom": "^6.26.2", 17 | "socket.io-client": "^4.7.5", 18 | "uuid": "^10.0.0" 19 | }, 20 | "devDependencies": { 21 | "@eslint/js": "^9.9.0", 22 | "@types/react": "^18.3.3", 23 | "@types/react-dom": "^18.3.0", 24 | "@vitejs/plugin-react": "^4.3.1", 25 | "eslint": "^9.9.0", 26 | "eslint-plugin-react": "^7.35.0", 27 | "eslint-plugin-react-hooks": "^5.1.0-rc.0", 28 | "eslint-plugin-react-refresh": "^0.4.9", 29 | "globals": "^15.9.0", 30 | "vite": "^5.4.1" 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2024 Yash Kamble 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /client/eslint.config.js: -------------------------------------------------------------------------------- 1 | import js from '@eslint/js' 2 | import globals from 'globals' 3 | import react from 'eslint-plugin-react' 4 | import reactHooks from 'eslint-plugin-react-hooks' 5 | import reactRefresh from 'eslint-plugin-react-refresh' 6 | 7 | export default [ 8 | { ignores: ['dist'] }, 9 | { 10 | files: ['**/*.{js,jsx}'], 11 | languageOptions: { 12 | ecmaVersion: 2020, 13 | globals: globals.browser, 14 | parserOptions: { 15 | ecmaVersion: 'latest', 16 | ecmaFeatures: { jsx: true }, 17 | sourceType: 'module', 18 | }, 19 | }, 20 | settings: { react: { version: '18.3' } }, 21 | plugins: { 22 | react, 23 | 'react-hooks': reactHooks, 24 | 'react-refresh': reactRefresh, 25 | }, 26 | rules: { 27 | ...js.configs.recommended.rules, 28 | ...react.configs.recommended.rules, 29 | ...react.configs['jsx-runtime'].rules, 30 | ...reactHooks.configs.recommended.rules, 31 | 'react/jsx-no-target-blank': 'off', 32 | 'react-refresh/only-export-components': [ 33 | 'warn', 34 | { allowConstantExport: true }, 35 | ], 36 | }, 37 | }, 38 | ] 39 | -------------------------------------------------------------------------------- /client/src/App.css: -------------------------------------------------------------------------------- 1 | /* Universal box-sizing */ 2 | *, *::before, *::after { 3 | box-sizing: border-box; 4 | } 5 | 6 | /* Background and margin reset for the body */ 7 | body { 8 | background-color: #F3F3F3; 9 | margin: 0; 10 | } 11 | 12 | /* Styling the Quill editor */ 13 | .container .ql-editor { 14 | width: 8.5in; 15 | min-height: 11in; 16 | padding: 1in; 17 | margin: 1rem; 18 | box-shadow: 0 0 5px 0 rgba(0, 0, 0, .5); 19 | background-color: white; 20 | } 21 | 22 | /* Centering the Quill editor container */ 23 | .container .ql-container.ql-snow { 24 | border: none; 25 | display: flex; 26 | justify-content: center; 27 | } 28 | 29 | /* Sticky toolbar for Quill editor */ 30 | .container .ql-toolbar.ql-snow { 31 | display: flex; 32 | justify-content: center; 33 | position: sticky; 34 | top: 0; 35 | z-index: 1; 36 | background-color: #F3F3F3; 37 | border: none; 38 | box-shadow: 0 0 5px 0 rgba(0, 0, 0, .5); 39 | } 40 | 41 | /* Print-specific styles */ 42 | @page { 43 | margin: 1in; 44 | } 45 | 46 | @media print { 47 | body { 48 | background: none; 49 | } 50 | 51 | .container .ql-editor { 52 | width: 6.5in; 53 | height: 9in; 54 | padding: 0; 55 | margin: 0; 56 | box-shadow: none; 57 | align-self: flex-start; 58 | } 59 | 60 | .container .ql-toolbar.ql-snow { 61 | display: none; 62 | } 63 | } 64 | -------------------------------------------------------------------------------- /client/src/index.css: -------------------------------------------------------------------------------- 1 | :root { 2 | font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif; 3 | line-height: 1.5; 4 | font-weight: 400; 5 | 6 | color-scheme: light dark; 7 | color: rgba(255, 255, 255, 0.87); 8 | background-color: #242424; 9 | 10 | font-synthesis: none; 11 | text-rendering: optimizeLegibility; 12 | -webkit-font-smoothing: antialiased; 13 | -moz-osx-font-smoothing: grayscale; 14 | } 15 | 16 | a { 17 | font-weight: 500; 18 | color: #646cff; 19 | text-decoration: inherit; 20 | } 21 | a:hover { 22 | color: #535bf2; 23 | } 24 | 25 | body { 26 | margin: 0; 27 | display: flex; 28 | place-items: center; 29 | min-width: 320px; 30 | min-height: 100vh; 31 | } 32 | 33 | h1 { 34 | font-size: 3.2em; 35 | line-height: 1.1; 36 | } 37 | 38 | button { 39 | border-radius: 8px; 40 | border: 1px solid transparent; 41 | padding: 0.6em 1.2em; 42 | font-size: 1em; 43 | font-weight: 500; 44 | font-family: inherit; 45 | background-color: #1a1a1a; 46 | cursor: pointer; 47 | transition: border-color 0.25s; 48 | } 49 | button:hover { 50 | border-color: #646cff; 51 | } 52 | button:focus, 53 | button:focus-visible { 54 | outline: 4px auto -webkit-focus-ring-color; 55 | } 56 | 57 | @media (prefers-color-scheme: light) { 58 | :root { 59 | color: #213547; 60 | background-color: #ffffff; 61 | } 62 | a:hover { 63 | color: #747bff; 64 | } 65 | button { 66 | background-color: #f9f9f9; 67 | } 68 | } 69 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | 2 | # Sync-Script 3 | 4 | Sync-Script is a collaborative text editor designed for real-time document editing. 5 | It provides seamless synchronization of document changes across multiple users. 6 | 7 | **Screenshot of UI** 8 | ![Screenshot of UI](https://github.com/hackice20/Sync-Script/blob/master/Screenshot%202024-09-15%20205900.png) 9 | 10 | **DataBase OutPut** 11 | ![DataBase OutPut](https://github.com/hackice20/Sync-Script/blob/master/Screenshot%202024-09-15%20213221.png) 12 | 13 | **Video Demo** 14 | [Video Demo](https://youtu.be/zYzlZV121C0) 15 | 16 | ## Features 17 | 18 | - **Real-Time Collaboration**: Allows multiple users to edit the same document simultaneously. Changes are broadcasted to all connected clients instantly. 19 | - **Automatic Saving**: Periodically saves document changes to prevent data loss. The save interval is configurable. 20 | - **Live Updates**: Updates from other users are reflected in real-time, ensuring everyone sees the latest version of the document. 21 | - **User-Friendly Interface**: Provides a clean and intuitive editor interface with customizable toolbar options for a rich text editing experience. 22 | - **Document Management**: Users can create new documents or open existing ones using unique identifiers. 23 | 24 | ## Technologies Used 25 | 26 | - **Node.js**: JavaScript runtime environment used for server-side development. 27 | - **Express.js**: Web framework for Node.js used to build the backend server. 28 | - **MongoDB**: NoSQL database for storing and retrieving documents. 29 | - **WebSocket (Socket.io)**: Enables real-time, bidirectional communication between the server and clients. 30 | - **Quill**: Rich text editor used for document editing in the frontend. 31 | - **Vite**: Modern build tool that provides fast development and optimized builds for React applications. 32 | - **React**: JavaScript library for building user interfaces, used for creating the frontend components. 33 | 34 | ``` 35 | -------------------------------------------------------------------------------- /server/server.js: -------------------------------------------------------------------------------- 1 | const express = require("express") 2 | const cors = require('cors'); 3 | const mongoose = require("mongoose") 4 | require('dotenv').config(); 5 | const Document = require("./Document") 6 | 7 | // Initialize Express app 8 | const app = express() 9 | app.use(cors({ 10 | origin: 'https://sync-script-mu.vercel.app/', // Vercel frontend URL 11 | })); 12 | app.use(express.json()); 13 | 14 | 15 | const uri = process.env.MONGO_URI; 16 | 17 | mongoose.connect(uri, {}) 18 | .then(() => console.log("Connected to MongoDB")) 19 | .catch(err => console.error("Connection error", err)); 20 | 21 | // Create an HTTP server and pass the Express app to it 22 | const server = require("http").createServer(app) 23 | 24 | // Initialize Socket.IO with the HTTP server 25 | const io = require("socket.io")(server, { 26 | cors: { 27 | origin: "*", // Allow all origins (for dev), adjust this in production 28 | methods: ["GET", "POST"], 29 | }, 30 | }) 31 | 32 | const defaultValue = "" 33 | 34 | // Add a basic route to display "Hi" when accessed via the browser 35 | app.get("/", (req, res) => { 36 | res.send("Hi") 37 | }) 38 | 39 | // Socket.IO logic 40 | io.on("connection", socket => { 41 | console.log("Client connected") 42 | 43 | socket.on("get-document", async documentId => { 44 | const document = await findOrCreateDocument(documentId) 45 | socket.join(documentId) 46 | socket.emit("load-document", document.data) 47 | 48 | socket.on("send-changes", delta => { 49 | socket.broadcast.to(documentId).emit("receive-changes", delta) 50 | }) 51 | 52 | socket.on("save-document", async data => { 53 | await Document.findByIdAndUpdate(documentId, { data }) 54 | }) 55 | }) 56 | 57 | socket.on("disconnect", () => { 58 | console.log("Client disconnected") 59 | }) 60 | }) 61 | 62 | // Function to find or create a document 63 | async function findOrCreateDocument(id) { 64 | if (id == null) return 65 | 66 | let document = await Document.findById(id) 67 | if (document) return document 68 | 69 | return await Document.create({ _id: id, data: defaultValue }) 70 | } 71 | const PORT = process.env.PORT || 3001 72 | // Start the server on port 3001 and log a message 73 | server.listen(PORT, () => { 74 | console.log('Server started on port 3001') 75 | }) 76 | -------------------------------------------------------------------------------- /client/src/TextEditor.jsx: -------------------------------------------------------------------------------- 1 | import { useCallback, useEffect, useState } from "react"; 2 | import Quill from "quill"; // Import Quill from the latest version (ESM support) 3 | import "quill/dist/quill.snow.css"; 4 | import { io } from "socket.io-client"; 5 | import { useParams } from "react-router-dom"; 6 | 7 | const SAVE_INTERVAL_MS = 2000; 8 | const TOOLBAR_OPTIONS = [ 9 | [{ header: [1, 2, 3, 4, 5, 6, false] }], 10 | [{ font: [] }], 11 | [{ list: "ordered" }, { list: "bullet" }], 12 | ["bold", "italic", "underline"], 13 | [{ color: [] }, { background: [] }], 14 | [{ script: "sub" }, { script: "super" }], 15 | [{ align: [] }], 16 | ["image", "blockquote", "code-block"], 17 | ["clean"], 18 | ]; 19 | 20 | export default function TextEditor() { 21 | const { id: documentId } = useParams(); 22 | const [socket, setSocket] = useState(null); 23 | const [quill, setQuill] = useState(null); 24 | 25 | useEffect(() => { 26 | const s = io("https://sync-script-chay.onrender.com/"); 27 | setSocket(s); 28 | 29 | return () => { 30 | s.disconnect(); 31 | }; 32 | }, []); 33 | 34 | useEffect(() => { 35 | if (socket == null || quill == null) return; 36 | 37 | socket.once("load-document", (document) => { 38 | quill.setContents(document); 39 | quill.enable(); 40 | }); 41 | 42 | socket.emit("get-document", documentId); 43 | }, [socket, quill, documentId]); 44 | 45 | useEffect(() => { 46 | if (socket == null || quill == null) return; 47 | 48 | const interval = setInterval(() => { 49 | socket.emit("save-document", quill.getContents()); 50 | }, SAVE_INTERVAL_MS); 51 | 52 | return () => { 53 | clearInterval(interval); 54 | }; 55 | }, [socket, quill]); 56 | 57 | useEffect(() => { 58 | if (socket == null || quill == null) return; 59 | 60 | const handler = (delta) => { 61 | quill.updateContents(delta); 62 | }; 63 | socket.on("receive-changes", handler); 64 | 65 | return () => { 66 | socket.off("receive-changes", handler); 67 | }; 68 | }, [socket, quill]); 69 | 70 | useEffect(() => { 71 | if (socket == null || quill == null) return; 72 | 73 | const handler = (delta, oldDelta, source) => { 74 | if (source !== "user") return; 75 | socket.emit("send-changes", delta); 76 | }; 77 | quill.on("text-change", handler); 78 | 79 | return () => { 80 | quill.off("text-change", handler); 81 | }; 82 | }, [socket, quill]); 83 | 84 | const wrapperRef = useCallback((wrapper) => { 85 | if (wrapper == null) return; 86 | 87 | wrapper.innerHTML = ""; 88 | const editor = document.createElement("div"); 89 | wrapper.append(editor); 90 | const q = new Quill(editor, { 91 | theme: "snow", 92 | modules: { toolbar: TOOLBAR_OPTIONS }, 93 | }); 94 | q.disable(); 95 | q.setText("Loading..."); 96 | setQuill(q); 97 | }, []); 98 | 99 | return
; 100 | } 101 | -------------------------------------------------------------------------------- /client/src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /server/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "server", 9 | "version": "1.0.0", 10 | "license": "ISC", 11 | "dependencies": { 12 | "express": "^4.21.0", 13 | "mongoose": "^8.6.2", 14 | "nodemon": "^3.1.4", 15 | "socket.io": "^4.7.5" 16 | } 17 | }, 18 | "node_modules/@mongodb-js/saslprep": { 19 | "version": "1.1.9", 20 | "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.9.tgz", 21 | "integrity": "sha512-tVkljjeEaAhCqTzajSdgbQ6gE6f3oneVwa3iXR6csiEwXXOFsiC6Uh9iAjAhXPtqa/XMDHWjjeNH/77m/Yq2dw==", 22 | "license": "MIT", 23 | "dependencies": { 24 | "sparse-bitfield": "^3.0.3" 25 | } 26 | }, 27 | "node_modules/@socket.io/component-emitter": { 28 | "version": "3.1.2", 29 | "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.1.2.tgz", 30 | "integrity": "sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==", 31 | "license": "MIT" 32 | }, 33 | "node_modules/@types/cookie": { 34 | "version": "0.4.1", 35 | "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.4.1.tgz", 36 | "integrity": "sha512-XW/Aa8APYr6jSVVA1y/DEIZX0/GMKLEVekNG727R8cs56ahETkRAy/3DR7+fJyh7oUgGwNQaRfXCun0+KbWY7Q==", 37 | "license": "MIT" 38 | }, 39 | "node_modules/@types/cors": { 40 | "version": "2.8.17", 41 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.17.tgz", 42 | "integrity": "sha512-8CGDvrBj1zgo2qE+oS3pOCyYNqCPryMWY2bGfwA0dcfopWGgxs+78df0Rs3rc9THP4JkOhLsAa+15VdpAqkcUA==", 43 | "license": "MIT", 44 | "dependencies": { 45 | "@types/node": "*" 46 | } 47 | }, 48 | "node_modules/@types/node": { 49 | "version": "22.5.5", 50 | "resolved": "https://registry.npmjs.org/@types/node/-/node-22.5.5.tgz", 51 | "integrity": "sha512-Xjs4y5UPO/CLdzpgR6GirZJx36yScjh73+2NlLlkFRSoQN8B0DpfXPdZGnvVmLRLOsqDpOfTNv7D9trgGhmOIA==", 52 | "license": "MIT", 53 | "dependencies": { 54 | "undici-types": "~6.19.2" 55 | } 56 | }, 57 | "node_modules/@types/webidl-conversions": { 58 | "version": "7.0.3", 59 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.3.tgz", 60 | "integrity": "sha512-CiJJvcRtIgzadHCYXw7dqEnMNRjhGZlYK05Mj9OyktqV8uVT8fD2BFOB7S1uwBE3Kj2Z+4UyPmFw/Ixgw/LAlA==", 61 | "license": "MIT" 62 | }, 63 | "node_modules/@types/whatwg-url": { 64 | "version": "11.0.5", 65 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-11.0.5.tgz", 66 | "integrity": "sha512-coYR071JRaHa+xoEvvYqvnIHaVqaYrLPbsufM9BF63HkwI5Lgmy2QR8Q5K/lYDYo5AK82wOvSOS0UsLTpTG7uQ==", 67 | "license": "MIT", 68 | "dependencies": { 69 | "@types/webidl-conversions": "*" 70 | } 71 | }, 72 | "node_modules/accepts": { 73 | "version": "1.3.8", 74 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 75 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 76 | "license": "MIT", 77 | "dependencies": { 78 | "mime-types": "~2.1.34", 79 | "negotiator": "0.6.3" 80 | }, 81 | "engines": { 82 | "node": ">= 0.6" 83 | } 84 | }, 85 | "node_modules/anymatch": { 86 | "version": "3.1.3", 87 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 88 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 89 | "license": "ISC", 90 | "dependencies": { 91 | "normalize-path": "^3.0.0", 92 | "picomatch": "^2.0.4" 93 | }, 94 | "engines": { 95 | "node": ">= 8" 96 | } 97 | }, 98 | "node_modules/array-flatten": { 99 | "version": "1.1.1", 100 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 101 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==", 102 | "license": "MIT" 103 | }, 104 | "node_modules/balanced-match": { 105 | "version": "1.0.2", 106 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 107 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 108 | "license": "MIT" 109 | }, 110 | "node_modules/base64id": { 111 | "version": "2.0.0", 112 | "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", 113 | "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==", 114 | "license": "MIT", 115 | "engines": { 116 | "node": "^4.5.0 || >= 5.9" 117 | } 118 | }, 119 | "node_modules/binary-extensions": { 120 | "version": "2.3.0", 121 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 122 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 123 | "license": "MIT", 124 | "engines": { 125 | "node": ">=8" 126 | }, 127 | "funding": { 128 | "url": "https://github.com/sponsors/sindresorhus" 129 | } 130 | }, 131 | "node_modules/body-parser": { 132 | "version": "1.20.3", 133 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", 134 | "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", 135 | "license": "MIT", 136 | "dependencies": { 137 | "bytes": "3.1.2", 138 | "content-type": "~1.0.5", 139 | "debug": "2.6.9", 140 | "depd": "2.0.0", 141 | "destroy": "1.2.0", 142 | "http-errors": "2.0.0", 143 | "iconv-lite": "0.4.24", 144 | "on-finished": "2.4.1", 145 | "qs": "6.13.0", 146 | "raw-body": "2.5.2", 147 | "type-is": "~1.6.18", 148 | "unpipe": "1.0.0" 149 | }, 150 | "engines": { 151 | "node": ">= 0.8", 152 | "npm": "1.2.8000 || >= 1.4.16" 153 | } 154 | }, 155 | "node_modules/body-parser/node_modules/debug": { 156 | "version": "2.6.9", 157 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 158 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 159 | "license": "MIT", 160 | "dependencies": { 161 | "ms": "2.0.0" 162 | } 163 | }, 164 | "node_modules/body-parser/node_modules/ms": { 165 | "version": "2.0.0", 166 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 167 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", 168 | "license": "MIT" 169 | }, 170 | "node_modules/brace-expansion": { 171 | "version": "1.1.11", 172 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 173 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 174 | "license": "MIT", 175 | "dependencies": { 176 | "balanced-match": "^1.0.0", 177 | "concat-map": "0.0.1" 178 | } 179 | }, 180 | "node_modules/braces": { 181 | "version": "3.0.3", 182 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 183 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 184 | "license": "MIT", 185 | "dependencies": { 186 | "fill-range": "^7.1.1" 187 | }, 188 | "engines": { 189 | "node": ">=8" 190 | } 191 | }, 192 | "node_modules/bson": { 193 | "version": "6.8.0", 194 | "resolved": "https://registry.npmjs.org/bson/-/bson-6.8.0.tgz", 195 | "integrity": "sha512-iOJg8pr7wq2tg/zSlCCHMi3hMm5JTOxLTagf3zxhcenHsFp+c6uOs6K7W5UE7A4QIJGtqh/ZovFNMP4mOPJynQ==", 196 | "license": "Apache-2.0", 197 | "engines": { 198 | "node": ">=16.20.1" 199 | } 200 | }, 201 | "node_modules/bytes": { 202 | "version": "3.1.2", 203 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", 204 | "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", 205 | "license": "MIT", 206 | "engines": { 207 | "node": ">= 0.8" 208 | } 209 | }, 210 | "node_modules/call-bind": { 211 | "version": "1.0.7", 212 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", 213 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", 214 | "license": "MIT", 215 | "dependencies": { 216 | "es-define-property": "^1.0.0", 217 | "es-errors": "^1.3.0", 218 | "function-bind": "^1.1.2", 219 | "get-intrinsic": "^1.2.4", 220 | "set-function-length": "^1.2.1" 221 | }, 222 | "engines": { 223 | "node": ">= 0.4" 224 | }, 225 | "funding": { 226 | "url": "https://github.com/sponsors/ljharb" 227 | } 228 | }, 229 | "node_modules/chokidar": { 230 | "version": "3.6.0", 231 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 232 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 233 | "license": "MIT", 234 | "dependencies": { 235 | "anymatch": "~3.1.2", 236 | "braces": "~3.0.2", 237 | "glob-parent": "~5.1.2", 238 | "is-binary-path": "~2.1.0", 239 | "is-glob": "~4.0.1", 240 | "normalize-path": "~3.0.0", 241 | "readdirp": "~3.6.0" 242 | }, 243 | "engines": { 244 | "node": ">= 8.10.0" 245 | }, 246 | "funding": { 247 | "url": "https://paulmillr.com/funding/" 248 | }, 249 | "optionalDependencies": { 250 | "fsevents": "~2.3.2" 251 | } 252 | }, 253 | "node_modules/concat-map": { 254 | "version": "0.0.1", 255 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 256 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 257 | "license": "MIT" 258 | }, 259 | "node_modules/content-disposition": { 260 | "version": "0.5.4", 261 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", 262 | "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", 263 | "license": "MIT", 264 | "dependencies": { 265 | "safe-buffer": "5.2.1" 266 | }, 267 | "engines": { 268 | "node": ">= 0.6" 269 | } 270 | }, 271 | "node_modules/content-type": { 272 | "version": "1.0.5", 273 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 274 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 275 | "license": "MIT", 276 | "engines": { 277 | "node": ">= 0.6" 278 | } 279 | }, 280 | "node_modules/cookie": { 281 | "version": "0.4.2", 282 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 283 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 284 | "license": "MIT", 285 | "engines": { 286 | "node": ">= 0.6" 287 | } 288 | }, 289 | "node_modules/cookie-signature": { 290 | "version": "1.0.6", 291 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 292 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==", 293 | "license": "MIT" 294 | }, 295 | "node_modules/cors": { 296 | "version": "2.8.5", 297 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 298 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 299 | "license": "MIT", 300 | "dependencies": { 301 | "object-assign": "^4", 302 | "vary": "^1" 303 | }, 304 | "engines": { 305 | "node": ">= 0.10" 306 | } 307 | }, 308 | "node_modules/debug": { 309 | "version": "4.3.7", 310 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", 311 | "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", 312 | "license": "MIT", 313 | "dependencies": { 314 | "ms": "^2.1.3" 315 | }, 316 | "engines": { 317 | "node": ">=6.0" 318 | }, 319 | "peerDependenciesMeta": { 320 | "supports-color": { 321 | "optional": true 322 | } 323 | } 324 | }, 325 | "node_modules/define-data-property": { 326 | "version": "1.1.4", 327 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", 328 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", 329 | "license": "MIT", 330 | "dependencies": { 331 | "es-define-property": "^1.0.0", 332 | "es-errors": "^1.3.0", 333 | "gopd": "^1.0.1" 334 | }, 335 | "engines": { 336 | "node": ">= 0.4" 337 | }, 338 | "funding": { 339 | "url": "https://github.com/sponsors/ljharb" 340 | } 341 | }, 342 | "node_modules/depd": { 343 | "version": "2.0.0", 344 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 345 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 346 | "license": "MIT", 347 | "engines": { 348 | "node": ">= 0.8" 349 | } 350 | }, 351 | "node_modules/destroy": { 352 | "version": "1.2.0", 353 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", 354 | "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", 355 | "license": "MIT", 356 | "engines": { 357 | "node": ">= 0.8", 358 | "npm": "1.2.8000 || >= 1.4.16" 359 | } 360 | }, 361 | "node_modules/ee-first": { 362 | "version": "1.1.1", 363 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 364 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", 365 | "license": "MIT" 366 | }, 367 | "node_modules/encodeurl": { 368 | "version": "2.0.0", 369 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz", 370 | "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", 371 | "license": "MIT", 372 | "engines": { 373 | "node": ">= 0.8" 374 | } 375 | }, 376 | "node_modules/engine.io": { 377 | "version": "6.5.5", 378 | "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-6.5.5.tgz", 379 | "integrity": "sha512-C5Pn8Wk+1vKBoHghJODM63yk8MvrO9EWZUfkAt5HAqIgPE4/8FF0PEGHXtEd40l223+cE5ABWuPzm38PHFXfMA==", 380 | "license": "MIT", 381 | "dependencies": { 382 | "@types/cookie": "^0.4.1", 383 | "@types/cors": "^2.8.12", 384 | "@types/node": ">=10.0.0", 385 | "accepts": "~1.3.4", 386 | "base64id": "2.0.0", 387 | "cookie": "~0.4.1", 388 | "cors": "~2.8.5", 389 | "debug": "~4.3.1", 390 | "engine.io-parser": "~5.2.1", 391 | "ws": "~8.17.1" 392 | }, 393 | "engines": { 394 | "node": ">=10.2.0" 395 | } 396 | }, 397 | "node_modules/engine.io-parser": { 398 | "version": "5.2.3", 399 | "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.2.3.tgz", 400 | "integrity": "sha512-HqD3yTBfnBxIrbnM1DoD6Pcq8NECnh8d4As1Qgh0z5Gg3jRRIqijury0CL3ghu/edArpUYiYqQiDUQBIs4np3Q==", 401 | "license": "MIT", 402 | "engines": { 403 | "node": ">=10.0.0" 404 | } 405 | }, 406 | "node_modules/es-define-property": { 407 | "version": "1.0.0", 408 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", 409 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", 410 | "license": "MIT", 411 | "dependencies": { 412 | "get-intrinsic": "^1.2.4" 413 | }, 414 | "engines": { 415 | "node": ">= 0.4" 416 | } 417 | }, 418 | "node_modules/es-errors": { 419 | "version": "1.3.0", 420 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 421 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 422 | "license": "MIT", 423 | "engines": { 424 | "node": ">= 0.4" 425 | } 426 | }, 427 | "node_modules/escape-html": { 428 | "version": "1.0.3", 429 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 430 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==", 431 | "license": "MIT" 432 | }, 433 | "node_modules/etag": { 434 | "version": "1.8.1", 435 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 436 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 437 | "license": "MIT", 438 | "engines": { 439 | "node": ">= 0.6" 440 | } 441 | }, 442 | "node_modules/express": { 443 | "version": "4.21.0", 444 | "resolved": "https://registry.npmjs.org/express/-/express-4.21.0.tgz", 445 | "integrity": "sha512-VqcNGcj/Id5ZT1LZ/cfihi3ttTn+NJmkli2eZADigjq29qTlWi/hAQ43t/VLPq8+UX06FCEx3ByOYet6ZFblng==", 446 | "license": "MIT", 447 | "dependencies": { 448 | "accepts": "~1.3.8", 449 | "array-flatten": "1.1.1", 450 | "body-parser": "1.20.3", 451 | "content-disposition": "0.5.4", 452 | "content-type": "~1.0.4", 453 | "cookie": "0.6.0", 454 | "cookie-signature": "1.0.6", 455 | "debug": "2.6.9", 456 | "depd": "2.0.0", 457 | "encodeurl": "~2.0.0", 458 | "escape-html": "~1.0.3", 459 | "etag": "~1.8.1", 460 | "finalhandler": "1.3.1", 461 | "fresh": "0.5.2", 462 | "http-errors": "2.0.0", 463 | "merge-descriptors": "1.0.3", 464 | "methods": "~1.1.2", 465 | "on-finished": "2.4.1", 466 | "parseurl": "~1.3.3", 467 | "path-to-regexp": "0.1.10", 468 | "proxy-addr": "~2.0.7", 469 | "qs": "6.13.0", 470 | "range-parser": "~1.2.1", 471 | "safe-buffer": "5.2.1", 472 | "send": "0.19.0", 473 | "serve-static": "1.16.2", 474 | "setprototypeof": "1.2.0", 475 | "statuses": "2.0.1", 476 | "type-is": "~1.6.18", 477 | "utils-merge": "1.0.1", 478 | "vary": "~1.1.2" 479 | }, 480 | "engines": { 481 | "node": ">= 0.10.0" 482 | } 483 | }, 484 | "node_modules/express/node_modules/cookie": { 485 | "version": "0.6.0", 486 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", 487 | "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", 488 | "license": "MIT", 489 | "engines": { 490 | "node": ">= 0.6" 491 | } 492 | }, 493 | "node_modules/express/node_modules/debug": { 494 | "version": "2.6.9", 495 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 496 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 497 | "license": "MIT", 498 | "dependencies": { 499 | "ms": "2.0.0" 500 | } 501 | }, 502 | "node_modules/express/node_modules/ms": { 503 | "version": "2.0.0", 504 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 505 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", 506 | "license": "MIT" 507 | }, 508 | "node_modules/fill-range": { 509 | "version": "7.1.1", 510 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 511 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 512 | "license": "MIT", 513 | "dependencies": { 514 | "to-regex-range": "^5.0.1" 515 | }, 516 | "engines": { 517 | "node": ">=8" 518 | } 519 | }, 520 | "node_modules/finalhandler": { 521 | "version": "1.3.1", 522 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.3.1.tgz", 523 | "integrity": "sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==", 524 | "license": "MIT", 525 | "dependencies": { 526 | "debug": "2.6.9", 527 | "encodeurl": "~2.0.0", 528 | "escape-html": "~1.0.3", 529 | "on-finished": "2.4.1", 530 | "parseurl": "~1.3.3", 531 | "statuses": "2.0.1", 532 | "unpipe": "~1.0.0" 533 | }, 534 | "engines": { 535 | "node": ">= 0.8" 536 | } 537 | }, 538 | "node_modules/finalhandler/node_modules/debug": { 539 | "version": "2.6.9", 540 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 541 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 542 | "license": "MIT", 543 | "dependencies": { 544 | "ms": "2.0.0" 545 | } 546 | }, 547 | "node_modules/finalhandler/node_modules/ms": { 548 | "version": "2.0.0", 549 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 550 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", 551 | "license": "MIT" 552 | }, 553 | "node_modules/forwarded": { 554 | "version": "0.2.0", 555 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 556 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 557 | "license": "MIT", 558 | "engines": { 559 | "node": ">= 0.6" 560 | } 561 | }, 562 | "node_modules/fresh": { 563 | "version": "0.5.2", 564 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 565 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 566 | "license": "MIT", 567 | "engines": { 568 | "node": ">= 0.6" 569 | } 570 | }, 571 | "node_modules/fsevents": { 572 | "version": "2.3.3", 573 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 574 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 575 | "hasInstallScript": true, 576 | "license": "MIT", 577 | "optional": true, 578 | "os": [ 579 | "darwin" 580 | ], 581 | "engines": { 582 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 583 | } 584 | }, 585 | "node_modules/function-bind": { 586 | "version": "1.1.2", 587 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 588 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 589 | "license": "MIT", 590 | "funding": { 591 | "url": "https://github.com/sponsors/ljharb" 592 | } 593 | }, 594 | "node_modules/get-intrinsic": { 595 | "version": "1.2.4", 596 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", 597 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", 598 | "license": "MIT", 599 | "dependencies": { 600 | "es-errors": "^1.3.0", 601 | "function-bind": "^1.1.2", 602 | "has-proto": "^1.0.1", 603 | "has-symbols": "^1.0.3", 604 | "hasown": "^2.0.0" 605 | }, 606 | "engines": { 607 | "node": ">= 0.4" 608 | }, 609 | "funding": { 610 | "url": "https://github.com/sponsors/ljharb" 611 | } 612 | }, 613 | "node_modules/glob-parent": { 614 | "version": "5.1.2", 615 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 616 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 617 | "license": "ISC", 618 | "dependencies": { 619 | "is-glob": "^4.0.1" 620 | }, 621 | "engines": { 622 | "node": ">= 6" 623 | } 624 | }, 625 | "node_modules/gopd": { 626 | "version": "1.0.1", 627 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 628 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 629 | "license": "MIT", 630 | "dependencies": { 631 | "get-intrinsic": "^1.1.3" 632 | }, 633 | "funding": { 634 | "url": "https://github.com/sponsors/ljharb" 635 | } 636 | }, 637 | "node_modules/has-flag": { 638 | "version": "3.0.0", 639 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 640 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 641 | "license": "MIT", 642 | "engines": { 643 | "node": ">=4" 644 | } 645 | }, 646 | "node_modules/has-property-descriptors": { 647 | "version": "1.0.2", 648 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", 649 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", 650 | "license": "MIT", 651 | "dependencies": { 652 | "es-define-property": "^1.0.0" 653 | }, 654 | "funding": { 655 | "url": "https://github.com/sponsors/ljharb" 656 | } 657 | }, 658 | "node_modules/has-proto": { 659 | "version": "1.0.3", 660 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", 661 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", 662 | "license": "MIT", 663 | "engines": { 664 | "node": ">= 0.4" 665 | }, 666 | "funding": { 667 | "url": "https://github.com/sponsors/ljharb" 668 | } 669 | }, 670 | "node_modules/has-symbols": { 671 | "version": "1.0.3", 672 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 673 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 674 | "license": "MIT", 675 | "engines": { 676 | "node": ">= 0.4" 677 | }, 678 | "funding": { 679 | "url": "https://github.com/sponsors/ljharb" 680 | } 681 | }, 682 | "node_modules/hasown": { 683 | "version": "2.0.2", 684 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 685 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 686 | "license": "MIT", 687 | "dependencies": { 688 | "function-bind": "^1.1.2" 689 | }, 690 | "engines": { 691 | "node": ">= 0.4" 692 | } 693 | }, 694 | "node_modules/http-errors": { 695 | "version": "2.0.0", 696 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", 697 | "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", 698 | "license": "MIT", 699 | "dependencies": { 700 | "depd": "2.0.0", 701 | "inherits": "2.0.4", 702 | "setprototypeof": "1.2.0", 703 | "statuses": "2.0.1", 704 | "toidentifier": "1.0.1" 705 | }, 706 | "engines": { 707 | "node": ">= 0.8" 708 | } 709 | }, 710 | "node_modules/iconv-lite": { 711 | "version": "0.4.24", 712 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 713 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 714 | "license": "MIT", 715 | "dependencies": { 716 | "safer-buffer": ">= 2.1.2 < 3" 717 | }, 718 | "engines": { 719 | "node": ">=0.10.0" 720 | } 721 | }, 722 | "node_modules/ignore-by-default": { 723 | "version": "1.0.1", 724 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 725 | "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==", 726 | "license": "ISC" 727 | }, 728 | "node_modules/inherits": { 729 | "version": "2.0.4", 730 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 731 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 732 | "license": "ISC" 733 | }, 734 | "node_modules/ipaddr.js": { 735 | "version": "1.9.1", 736 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 737 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 738 | "license": "MIT", 739 | "engines": { 740 | "node": ">= 0.10" 741 | } 742 | }, 743 | "node_modules/is-binary-path": { 744 | "version": "2.1.0", 745 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 746 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 747 | "license": "MIT", 748 | "dependencies": { 749 | "binary-extensions": "^2.0.0" 750 | }, 751 | "engines": { 752 | "node": ">=8" 753 | } 754 | }, 755 | "node_modules/is-extglob": { 756 | "version": "2.1.1", 757 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 758 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 759 | "license": "MIT", 760 | "engines": { 761 | "node": ">=0.10.0" 762 | } 763 | }, 764 | "node_modules/is-glob": { 765 | "version": "4.0.3", 766 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 767 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 768 | "license": "MIT", 769 | "dependencies": { 770 | "is-extglob": "^2.1.1" 771 | }, 772 | "engines": { 773 | "node": ">=0.10.0" 774 | } 775 | }, 776 | "node_modules/is-number": { 777 | "version": "7.0.0", 778 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 779 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 780 | "license": "MIT", 781 | "engines": { 782 | "node": ">=0.12.0" 783 | } 784 | }, 785 | "node_modules/kareem": { 786 | "version": "2.6.3", 787 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.6.3.tgz", 788 | "integrity": "sha512-C3iHfuGUXK2u8/ipq9LfjFfXFxAZMQJJq7vLS45r3D9Y2xQ/m4S8zaR4zMLFWh9AsNPXmcFfUDhTEO8UIC/V6Q==", 789 | "license": "Apache-2.0", 790 | "engines": { 791 | "node": ">=12.0.0" 792 | } 793 | }, 794 | "node_modules/media-typer": { 795 | "version": "0.3.0", 796 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 797 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 798 | "license": "MIT", 799 | "engines": { 800 | "node": ">= 0.6" 801 | } 802 | }, 803 | "node_modules/memory-pager": { 804 | "version": "1.5.0", 805 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 806 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 807 | "license": "MIT" 808 | }, 809 | "node_modules/merge-descriptors": { 810 | "version": "1.0.3", 811 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.3.tgz", 812 | "integrity": "sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==", 813 | "license": "MIT", 814 | "funding": { 815 | "url": "https://github.com/sponsors/sindresorhus" 816 | } 817 | }, 818 | "node_modules/methods": { 819 | "version": "1.1.2", 820 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 821 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 822 | "license": "MIT", 823 | "engines": { 824 | "node": ">= 0.6" 825 | } 826 | }, 827 | "node_modules/mime": { 828 | "version": "1.6.0", 829 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 830 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 831 | "license": "MIT", 832 | "bin": { 833 | "mime": "cli.js" 834 | }, 835 | "engines": { 836 | "node": ">=4" 837 | } 838 | }, 839 | "node_modules/mime-db": { 840 | "version": "1.52.0", 841 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 842 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 843 | "license": "MIT", 844 | "engines": { 845 | "node": ">= 0.6" 846 | } 847 | }, 848 | "node_modules/mime-types": { 849 | "version": "2.1.35", 850 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 851 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 852 | "license": "MIT", 853 | "dependencies": { 854 | "mime-db": "1.52.0" 855 | }, 856 | "engines": { 857 | "node": ">= 0.6" 858 | } 859 | }, 860 | "node_modules/minimatch": { 861 | "version": "3.1.2", 862 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 863 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 864 | "license": "ISC", 865 | "dependencies": { 866 | "brace-expansion": "^1.1.7" 867 | }, 868 | "engines": { 869 | "node": "*" 870 | } 871 | }, 872 | "node_modules/mongodb": { 873 | "version": "6.8.0", 874 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-6.8.0.tgz", 875 | "integrity": "sha512-HGQ9NWDle5WvwMnrvUxsFYPd3JEbqD3RgABHBQRuoCEND0qzhsd0iH5ypHsf1eJ+sXmvmyKpP+FLOKY8Il7jMw==", 876 | "license": "Apache-2.0", 877 | "dependencies": { 878 | "@mongodb-js/saslprep": "^1.1.5", 879 | "bson": "^6.7.0", 880 | "mongodb-connection-string-url": "^3.0.0" 881 | }, 882 | "engines": { 883 | "node": ">=16.20.1" 884 | }, 885 | "peerDependencies": { 886 | "@aws-sdk/credential-providers": "^3.188.0", 887 | "@mongodb-js/zstd": "^1.1.0", 888 | "gcp-metadata": "^5.2.0", 889 | "kerberos": "^2.0.1", 890 | "mongodb-client-encryption": ">=6.0.0 <7", 891 | "snappy": "^7.2.2", 892 | "socks": "^2.7.1" 893 | }, 894 | "peerDependenciesMeta": { 895 | "@aws-sdk/credential-providers": { 896 | "optional": true 897 | }, 898 | "@mongodb-js/zstd": { 899 | "optional": true 900 | }, 901 | "gcp-metadata": { 902 | "optional": true 903 | }, 904 | "kerberos": { 905 | "optional": true 906 | }, 907 | "mongodb-client-encryption": { 908 | "optional": true 909 | }, 910 | "snappy": { 911 | "optional": true 912 | }, 913 | "socks": { 914 | "optional": true 915 | } 916 | } 917 | }, 918 | "node_modules/mongodb-connection-string-url": { 919 | "version": "3.0.1", 920 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-3.0.1.tgz", 921 | "integrity": "sha512-XqMGwRX0Lgn05TDB4PyG2h2kKO/FfWJyCzYQbIhXUxz7ETt0I/FqHjUeqj37irJ+Dl1ZtU82uYyj14u2XsZKfg==", 922 | "license": "Apache-2.0", 923 | "dependencies": { 924 | "@types/whatwg-url": "^11.0.2", 925 | "whatwg-url": "^13.0.0" 926 | } 927 | }, 928 | "node_modules/mongoose": { 929 | "version": "8.6.2", 930 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-8.6.2.tgz", 931 | "integrity": "sha512-ErbDVvuUzUfyQpXvJ6sXznmZDICD8r6wIsa0VKjJtB6/LZncqwUn5Um040G1BaNo6L3Jz+xItLSwT0wZmSmUaQ==", 932 | "license": "MIT", 933 | "dependencies": { 934 | "bson": "^6.7.0", 935 | "kareem": "2.6.3", 936 | "mongodb": "6.8.0", 937 | "mpath": "0.9.0", 938 | "mquery": "5.0.0", 939 | "ms": "2.1.3", 940 | "sift": "17.1.3" 941 | }, 942 | "engines": { 943 | "node": ">=16.20.1" 944 | }, 945 | "funding": { 946 | "type": "opencollective", 947 | "url": "https://opencollective.com/mongoose" 948 | } 949 | }, 950 | "node_modules/mpath": { 951 | "version": "0.9.0", 952 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 953 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==", 954 | "license": "MIT", 955 | "engines": { 956 | "node": ">=4.0.0" 957 | } 958 | }, 959 | "node_modules/mquery": { 960 | "version": "5.0.0", 961 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 962 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 963 | "license": "MIT", 964 | "dependencies": { 965 | "debug": "4.x" 966 | }, 967 | "engines": { 968 | "node": ">=14.0.0" 969 | } 970 | }, 971 | "node_modules/ms": { 972 | "version": "2.1.3", 973 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 974 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 975 | "license": "MIT" 976 | }, 977 | "node_modules/negotiator": { 978 | "version": "0.6.3", 979 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 980 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 981 | "license": "MIT", 982 | "engines": { 983 | "node": ">= 0.6" 984 | } 985 | }, 986 | "node_modules/nodemon": { 987 | "version": "3.1.4", 988 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.1.4.tgz", 989 | "integrity": "sha512-wjPBbFhtpJwmIeY2yP7QF+UKzPfltVGtfce1g/bB15/8vCGZj8uxD62b/b9M9/WVgme0NZudpownKN+c0plXlQ==", 990 | "license": "MIT", 991 | "dependencies": { 992 | "chokidar": "^3.5.2", 993 | "debug": "^4", 994 | "ignore-by-default": "^1.0.1", 995 | "minimatch": "^3.1.2", 996 | "pstree.remy": "^1.1.8", 997 | "semver": "^7.5.3", 998 | "simple-update-notifier": "^2.0.0", 999 | "supports-color": "^5.5.0", 1000 | "touch": "^3.1.0", 1001 | "undefsafe": "^2.0.5" 1002 | }, 1003 | "bin": { 1004 | "nodemon": "bin/nodemon.js" 1005 | }, 1006 | "engines": { 1007 | "node": ">=10" 1008 | }, 1009 | "funding": { 1010 | "type": "opencollective", 1011 | "url": "https://opencollective.com/nodemon" 1012 | } 1013 | }, 1014 | "node_modules/normalize-path": { 1015 | "version": "3.0.0", 1016 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1017 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1018 | "license": "MIT", 1019 | "engines": { 1020 | "node": ">=0.10.0" 1021 | } 1022 | }, 1023 | "node_modules/object-assign": { 1024 | "version": "4.1.1", 1025 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1026 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1027 | "license": "MIT", 1028 | "engines": { 1029 | "node": ">=0.10.0" 1030 | } 1031 | }, 1032 | "node_modules/object-inspect": { 1033 | "version": "1.13.2", 1034 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", 1035 | "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", 1036 | "license": "MIT", 1037 | "engines": { 1038 | "node": ">= 0.4" 1039 | }, 1040 | "funding": { 1041 | "url": "https://github.com/sponsors/ljharb" 1042 | } 1043 | }, 1044 | "node_modules/on-finished": { 1045 | "version": "2.4.1", 1046 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", 1047 | "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", 1048 | "license": "MIT", 1049 | "dependencies": { 1050 | "ee-first": "1.1.1" 1051 | }, 1052 | "engines": { 1053 | "node": ">= 0.8" 1054 | } 1055 | }, 1056 | "node_modules/parseurl": { 1057 | "version": "1.3.3", 1058 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1059 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1060 | "license": "MIT", 1061 | "engines": { 1062 | "node": ">= 0.8" 1063 | } 1064 | }, 1065 | "node_modules/path-to-regexp": { 1066 | "version": "0.1.10", 1067 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.10.tgz", 1068 | "integrity": "sha512-7lf7qcQidTku0Gu3YDPc8DJ1q7OOucfa/BSsIwjuh56VU7katFvuM8hULfkwB3Fns/rsVF7PwPKVw1sl5KQS9w==", 1069 | "license": "MIT" 1070 | }, 1071 | "node_modules/picomatch": { 1072 | "version": "2.3.1", 1073 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1074 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1075 | "license": "MIT", 1076 | "engines": { 1077 | "node": ">=8.6" 1078 | }, 1079 | "funding": { 1080 | "url": "https://github.com/sponsors/jonschlinkert" 1081 | } 1082 | }, 1083 | "node_modules/proxy-addr": { 1084 | "version": "2.0.7", 1085 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1086 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1087 | "license": "MIT", 1088 | "dependencies": { 1089 | "forwarded": "0.2.0", 1090 | "ipaddr.js": "1.9.1" 1091 | }, 1092 | "engines": { 1093 | "node": ">= 0.10" 1094 | } 1095 | }, 1096 | "node_modules/pstree.remy": { 1097 | "version": "1.1.8", 1098 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1099 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1100 | "license": "MIT" 1101 | }, 1102 | "node_modules/punycode": { 1103 | "version": "2.3.1", 1104 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 1105 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 1106 | "license": "MIT", 1107 | "engines": { 1108 | "node": ">=6" 1109 | } 1110 | }, 1111 | "node_modules/qs": { 1112 | "version": "6.13.0", 1113 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.13.0.tgz", 1114 | "integrity": "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==", 1115 | "license": "BSD-3-Clause", 1116 | "dependencies": { 1117 | "side-channel": "^1.0.6" 1118 | }, 1119 | "engines": { 1120 | "node": ">=0.6" 1121 | }, 1122 | "funding": { 1123 | "url": "https://github.com/sponsors/ljharb" 1124 | } 1125 | }, 1126 | "node_modules/range-parser": { 1127 | "version": "1.2.1", 1128 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1129 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1130 | "license": "MIT", 1131 | "engines": { 1132 | "node": ">= 0.6" 1133 | } 1134 | }, 1135 | "node_modules/raw-body": { 1136 | "version": "2.5.2", 1137 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", 1138 | "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", 1139 | "license": "MIT", 1140 | "dependencies": { 1141 | "bytes": "3.1.2", 1142 | "http-errors": "2.0.0", 1143 | "iconv-lite": "0.4.24", 1144 | "unpipe": "1.0.0" 1145 | }, 1146 | "engines": { 1147 | "node": ">= 0.8" 1148 | } 1149 | }, 1150 | "node_modules/readdirp": { 1151 | "version": "3.6.0", 1152 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1153 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1154 | "license": "MIT", 1155 | "dependencies": { 1156 | "picomatch": "^2.2.1" 1157 | }, 1158 | "engines": { 1159 | "node": ">=8.10.0" 1160 | } 1161 | }, 1162 | "node_modules/safe-buffer": { 1163 | "version": "5.2.1", 1164 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1165 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1166 | "funding": [ 1167 | { 1168 | "type": "github", 1169 | "url": "https://github.com/sponsors/feross" 1170 | }, 1171 | { 1172 | "type": "patreon", 1173 | "url": "https://www.patreon.com/feross" 1174 | }, 1175 | { 1176 | "type": "consulting", 1177 | "url": "https://feross.org/support" 1178 | } 1179 | ], 1180 | "license": "MIT" 1181 | }, 1182 | "node_modules/safer-buffer": { 1183 | "version": "2.1.2", 1184 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1185 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1186 | "license": "MIT" 1187 | }, 1188 | "node_modules/semver": { 1189 | "version": "7.6.3", 1190 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 1191 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 1192 | "license": "ISC", 1193 | "bin": { 1194 | "semver": "bin/semver.js" 1195 | }, 1196 | "engines": { 1197 | "node": ">=10" 1198 | } 1199 | }, 1200 | "node_modules/send": { 1201 | "version": "0.19.0", 1202 | "resolved": "https://registry.npmjs.org/send/-/send-0.19.0.tgz", 1203 | "integrity": "sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==", 1204 | "license": "MIT", 1205 | "dependencies": { 1206 | "debug": "2.6.9", 1207 | "depd": "2.0.0", 1208 | "destroy": "1.2.0", 1209 | "encodeurl": "~1.0.2", 1210 | "escape-html": "~1.0.3", 1211 | "etag": "~1.8.1", 1212 | "fresh": "0.5.2", 1213 | "http-errors": "2.0.0", 1214 | "mime": "1.6.0", 1215 | "ms": "2.1.3", 1216 | "on-finished": "2.4.1", 1217 | "range-parser": "~1.2.1", 1218 | "statuses": "2.0.1" 1219 | }, 1220 | "engines": { 1221 | "node": ">= 0.8.0" 1222 | } 1223 | }, 1224 | "node_modules/send/node_modules/debug": { 1225 | "version": "2.6.9", 1226 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1227 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1228 | "license": "MIT", 1229 | "dependencies": { 1230 | "ms": "2.0.0" 1231 | } 1232 | }, 1233 | "node_modules/send/node_modules/debug/node_modules/ms": { 1234 | "version": "2.0.0", 1235 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1236 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", 1237 | "license": "MIT" 1238 | }, 1239 | "node_modules/send/node_modules/encodeurl": { 1240 | "version": "1.0.2", 1241 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 1242 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 1243 | "license": "MIT", 1244 | "engines": { 1245 | "node": ">= 0.8" 1246 | } 1247 | }, 1248 | "node_modules/serve-static": { 1249 | "version": "1.16.2", 1250 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.16.2.tgz", 1251 | "integrity": "sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw==", 1252 | "license": "MIT", 1253 | "dependencies": { 1254 | "encodeurl": "~2.0.0", 1255 | "escape-html": "~1.0.3", 1256 | "parseurl": "~1.3.3", 1257 | "send": "0.19.0" 1258 | }, 1259 | "engines": { 1260 | "node": ">= 0.8.0" 1261 | } 1262 | }, 1263 | "node_modules/set-function-length": { 1264 | "version": "1.2.2", 1265 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", 1266 | "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", 1267 | "license": "MIT", 1268 | "dependencies": { 1269 | "define-data-property": "^1.1.4", 1270 | "es-errors": "^1.3.0", 1271 | "function-bind": "^1.1.2", 1272 | "get-intrinsic": "^1.2.4", 1273 | "gopd": "^1.0.1", 1274 | "has-property-descriptors": "^1.0.2" 1275 | }, 1276 | "engines": { 1277 | "node": ">= 0.4" 1278 | } 1279 | }, 1280 | "node_modules/setprototypeof": { 1281 | "version": "1.2.0", 1282 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 1283 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", 1284 | "license": "ISC" 1285 | }, 1286 | "node_modules/side-channel": { 1287 | "version": "1.0.6", 1288 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", 1289 | "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", 1290 | "license": "MIT", 1291 | "dependencies": { 1292 | "call-bind": "^1.0.7", 1293 | "es-errors": "^1.3.0", 1294 | "get-intrinsic": "^1.2.4", 1295 | "object-inspect": "^1.13.1" 1296 | }, 1297 | "engines": { 1298 | "node": ">= 0.4" 1299 | }, 1300 | "funding": { 1301 | "url": "https://github.com/sponsors/ljharb" 1302 | } 1303 | }, 1304 | "node_modules/sift": { 1305 | "version": "17.1.3", 1306 | "resolved": "https://registry.npmjs.org/sift/-/sift-17.1.3.tgz", 1307 | "integrity": "sha512-Rtlj66/b0ICeFzYTuNvX/EF1igRbbnGSvEyT79McoZa/DeGhMyC5pWKOEsZKnpkqtSeovd5FL/bjHWC3CIIvCQ==", 1308 | "license": "MIT" 1309 | }, 1310 | "node_modules/simple-update-notifier": { 1311 | "version": "2.0.0", 1312 | "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", 1313 | "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", 1314 | "license": "MIT", 1315 | "dependencies": { 1316 | "semver": "^7.5.3" 1317 | }, 1318 | "engines": { 1319 | "node": ">=10" 1320 | } 1321 | }, 1322 | "node_modules/socket.io": { 1323 | "version": "4.7.5", 1324 | "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-4.7.5.tgz", 1325 | "integrity": "sha512-DmeAkF6cwM9jSfmp6Dr/5/mfMwb5Z5qRrSXLpo3Fq5SqyU8CMF15jIN4ZhfSwu35ksM1qmHZDQ/DK5XTccSTvA==", 1326 | "license": "MIT", 1327 | "dependencies": { 1328 | "accepts": "~1.3.4", 1329 | "base64id": "~2.0.0", 1330 | "cors": "~2.8.5", 1331 | "debug": "~4.3.2", 1332 | "engine.io": "~6.5.2", 1333 | "socket.io-adapter": "~2.5.2", 1334 | "socket.io-parser": "~4.2.4" 1335 | }, 1336 | "engines": { 1337 | "node": ">=10.2.0" 1338 | } 1339 | }, 1340 | "node_modules/socket.io-adapter": { 1341 | "version": "2.5.5", 1342 | "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-2.5.5.tgz", 1343 | "integrity": "sha512-eLDQas5dzPgOWCk9GuuJC2lBqItuhKI4uxGgo9aIV7MYbk2h9Q6uULEh8WBzThoI7l+qU9Ast9fVUmkqPP9wYg==", 1344 | "license": "MIT", 1345 | "dependencies": { 1346 | "debug": "~4.3.4", 1347 | "ws": "~8.17.1" 1348 | } 1349 | }, 1350 | "node_modules/socket.io-parser": { 1351 | "version": "4.2.4", 1352 | "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.2.4.tgz", 1353 | "integrity": "sha512-/GbIKmo8ioc+NIWIhwdecY0ge+qVBSMdgxGygevmdHj24bsfgtCmcUUcQ5ZzcylGFHsN3k4HB4Cgkl96KVnuew==", 1354 | "license": "MIT", 1355 | "dependencies": { 1356 | "@socket.io/component-emitter": "~3.1.0", 1357 | "debug": "~4.3.1" 1358 | }, 1359 | "engines": { 1360 | "node": ">=10.0.0" 1361 | } 1362 | }, 1363 | "node_modules/sparse-bitfield": { 1364 | "version": "3.0.3", 1365 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1366 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 1367 | "license": "MIT", 1368 | "dependencies": { 1369 | "memory-pager": "^1.0.2" 1370 | } 1371 | }, 1372 | "node_modules/statuses": { 1373 | "version": "2.0.1", 1374 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", 1375 | "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", 1376 | "license": "MIT", 1377 | "engines": { 1378 | "node": ">= 0.8" 1379 | } 1380 | }, 1381 | "node_modules/supports-color": { 1382 | "version": "5.5.0", 1383 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1384 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1385 | "license": "MIT", 1386 | "dependencies": { 1387 | "has-flag": "^3.0.0" 1388 | }, 1389 | "engines": { 1390 | "node": ">=4" 1391 | } 1392 | }, 1393 | "node_modules/to-regex-range": { 1394 | "version": "5.0.1", 1395 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1396 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1397 | "license": "MIT", 1398 | "dependencies": { 1399 | "is-number": "^7.0.0" 1400 | }, 1401 | "engines": { 1402 | "node": ">=8.0" 1403 | } 1404 | }, 1405 | "node_modules/toidentifier": { 1406 | "version": "1.0.1", 1407 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", 1408 | "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", 1409 | "license": "MIT", 1410 | "engines": { 1411 | "node": ">=0.6" 1412 | } 1413 | }, 1414 | "node_modules/touch": { 1415 | "version": "3.1.1", 1416 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.1.tgz", 1417 | "integrity": "sha512-r0eojU4bI8MnHr8c5bNo7lJDdI2qXlWWJk6a9EAFG7vbhTjElYhBVS3/miuE0uOuoLdb8Mc/rVfsmm6eo5o9GA==", 1418 | "license": "ISC", 1419 | "bin": { 1420 | "nodetouch": "bin/nodetouch.js" 1421 | } 1422 | }, 1423 | "node_modules/tr46": { 1424 | "version": "4.1.1", 1425 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz", 1426 | "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==", 1427 | "license": "MIT", 1428 | "dependencies": { 1429 | "punycode": "^2.3.0" 1430 | }, 1431 | "engines": { 1432 | "node": ">=14" 1433 | } 1434 | }, 1435 | "node_modules/type-is": { 1436 | "version": "1.6.18", 1437 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1438 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1439 | "license": "MIT", 1440 | "dependencies": { 1441 | "media-typer": "0.3.0", 1442 | "mime-types": "~2.1.24" 1443 | }, 1444 | "engines": { 1445 | "node": ">= 0.6" 1446 | } 1447 | }, 1448 | "node_modules/undefsafe": { 1449 | "version": "2.0.5", 1450 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1451 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==", 1452 | "license": "MIT" 1453 | }, 1454 | "node_modules/undici-types": { 1455 | "version": "6.19.8", 1456 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", 1457 | "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", 1458 | "license": "MIT" 1459 | }, 1460 | "node_modules/unpipe": { 1461 | "version": "1.0.0", 1462 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1463 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 1464 | "license": "MIT", 1465 | "engines": { 1466 | "node": ">= 0.8" 1467 | } 1468 | }, 1469 | "node_modules/utils-merge": { 1470 | "version": "1.0.1", 1471 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1472 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1473 | "license": "MIT", 1474 | "engines": { 1475 | "node": ">= 0.4.0" 1476 | } 1477 | }, 1478 | "node_modules/vary": { 1479 | "version": "1.1.2", 1480 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1481 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1482 | "license": "MIT", 1483 | "engines": { 1484 | "node": ">= 0.8" 1485 | } 1486 | }, 1487 | "node_modules/webidl-conversions": { 1488 | "version": "7.0.0", 1489 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1490 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 1491 | "license": "BSD-2-Clause", 1492 | "engines": { 1493 | "node": ">=12" 1494 | } 1495 | }, 1496 | "node_modules/whatwg-url": { 1497 | "version": "13.0.0", 1498 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-13.0.0.tgz", 1499 | "integrity": "sha512-9WWbymnqj57+XEuqADHrCJ2eSXzn8WXIW/YSGaZtb2WKAInQ6CHfaUUcTyyver0p8BDg5StLQq8h1vtZuwmOig==", 1500 | "license": "MIT", 1501 | "dependencies": { 1502 | "tr46": "^4.1.1", 1503 | "webidl-conversions": "^7.0.0" 1504 | }, 1505 | "engines": { 1506 | "node": ">=16" 1507 | } 1508 | }, 1509 | "node_modules/ws": { 1510 | "version": "8.17.1", 1511 | "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.1.tgz", 1512 | "integrity": "sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==", 1513 | "license": "MIT", 1514 | "engines": { 1515 | "node": ">=10.0.0" 1516 | }, 1517 | "peerDependencies": { 1518 | "bufferutil": "^4.0.1", 1519 | "utf-8-validate": ">=5.0.2" 1520 | }, 1521 | "peerDependenciesMeta": { 1522 | "bufferutil": { 1523 | "optional": true 1524 | }, 1525 | "utf-8-validate": { 1526 | "optional": true 1527 | } 1528 | } 1529 | } 1530 | } 1531 | } 1532 | --------------------------------------------------------------------------------