├── .env ├── .gitignore ├── Controllers └── user-controller.js ├── DbConnection └── DB.js ├── ResponseHandler └── response-handle.js ├── Routes └── user-routes.js ├── abc.txt ├── package-lock.json ├── package.json ├── server.js └── tsconfig.json /.env: -------------------------------------------------------------------------------- 1 | PORT = 3000 2 | NODE_ENV = practise purpose -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | # node_modules/ 5 | /node_modules 6 | /resources 7 | /.pnp 8 | .pnp.js 9 | 10 | # testing 11 | /coverage 12 | 13 | # production 14 | /build 15 | 16 | # misc 17 | .DS_Store 18 | .env.local 19 | .env.development.local 20 | .env.test.local 21 | .env.production.local 22 | 23 | npm-debug.log* 24 | yarn-debug.log* 25 | yarn-error.log* 26 | -------------------------------------------------------------------------------- /Controllers/user-controller.js: -------------------------------------------------------------------------------- 1 | 2 | import connection, { ConnectDB } from "../DBConnection/DB.js"; 3 | import { ErrorHandler, SuccessHandler } from "../ResponseHandler/response-handle.js"; 4 | import { v4 as uuid } from "uuid"; 5 | 6 | // DATABASE ACCESS 7 | // const db = await ConnectDB(); 8 | const db = connection; 9 | 10 | 11 | // @Desc : Database Creation 12 | // @Route : GET/api/createDb 13 | const createDatabase = () => { 14 | let sql = `CREATE DATABASE practiseDatabase`; 15 | db.query(sql, (err, result) => { 16 | console.log("Result = ", result); 17 | res.status(200).json(SuccessHandler(ResponseData, 'Database Created :)')); 18 | if (err) throw err; 19 | }); 20 | }; 21 | 22 | 23 | // @Desc : Create User Table 24 | // @Route : GET/api/createUserTable 25 | const createUserTable = (req, res) => { 26 | let sqlQuery = `CREATE TABLE users ( SERIAL_NO int AUTO_INCREMENT, UNIQUE_ID VARCHAR(255) NOT NULL , NAME VARCHAR(255), AGE VARCHAR(255), ROLL_NO VARCHAR(255), STANDARD VARCHAR(255) , GENDER VARCHAR(255) , ADDRESS VARCHAR(255) , PRIMARY KEY(SERIAL_NO) )`; // primary_key = SERIAL_NOy 27 | // var response = await db.execute(sqlQuery); 28 | db.query(sqlQuery, (err, result) => { 29 | if (err) throw err; 30 | console.log("Result = ", result); 31 | res.status(200).json(SuccessHandler(ResponseData, 'User Table Created Success :)')); 32 | }); 33 | }; 34 | 35 | 36 | // @Desc : Add New User 37 | // @Route : GET/api/user/new 38 | const addNewUser = async (req, res) => { 39 | try { 40 | // Unique ID generator 41 | // var uniq = 'id' + (new Date()).getTime(); 42 | let val = Math.floor((1 + Math.random()) * 0x1000000).toString(16).substring(1); // .toString(16) --> means convert into hexadecimal 43 | let uniqueId = `UID-` + val; 44 | let ID = uuid(); 45 | 46 | // Inserting Manually 47 | // let query = `INSERT INTO users SET UNIQUE_ID = ? , NAME = ? , AGE = ? , ROLL_NO = ? , STANDARD = ? , GENDER = ? , ADDRESS = ?`; 48 | // var result = await db.execute(query, [uniqueId, 'LALALAaaaa', '4', '00', 'Dev', 'Female', 'Kolkata']); 49 | 50 | // Inserting from the UI/Postman 51 | let data = req.body || {}; 52 | 53 | // Throws Error 54 | if (data.name.length > 0 && data.age.length > 0 && data.roll.length > 0 && data.gender.length > 0 && data.address.length > 0) 55 | throw new Error("Missing fields"); 56 | 57 | 58 | let query = `INSERT INTO users SET UNIQUE_ID = ? , NAME = ? , AGE = ? , ROLL_NO = ? , STANDARD = ? , GENDER = ? , ADDRESS = ?`; 59 | var result = await db.execute(query, [ 60 | ID, 61 | data.name, 62 | data.age || " ", 63 | data.roll, 64 | data.standard, 65 | data.gender, 66 | data.address, 67 | // JSON.stringify(data.tags), 68 | // data.image?.trim() || defaultBannerImage, 69 | ]); 70 | 71 | const ResponseData = { 72 | ID: ID, 73 | Name: data.name, 74 | Age: data.age || " ", 75 | "Roll No.": data.roll, 76 | Standard: data.standard, 77 | Gender: data.gender, 78 | Address: data.address, 79 | }; 80 | 81 | if (result) 82 | res.status(200).json(SuccessHandler(ResponseData, 'User Inserted Successfully!')); 83 | } 84 | catch (err) { 85 | console.log(err); 86 | res.status(500).send(ErrorHandler(500, req, res, 'User Not Inserted!')); 87 | } 88 | }; 89 | 90 | 91 | // @Desc : Fetch All User 92 | // @Route : GET/api/user/all 93 | const getAllUsers = async (req, res) => { 94 | try { 95 | let query = `SELECT * FROM users`; 96 | var [rows, fields] = await db.execute(query); 97 | /* var result = db.execute(query, (err, result) => { 98 | if (err) throw err; 99 | res.send('Fetch All Users... '); 100 | }) */ 101 | console.log(rows); 102 | if (rows) 103 | res.status(200).json(SuccessHandler(rows, 'All User Fetched!')); 104 | 105 | } catch (err) { 106 | console.log(err); 107 | throw new ErrorHandler(500, req, res, 'User Not Inserted!') 108 | } 109 | }; 110 | 111 | 112 | // @Desc : Get User by ID ( parameters) 113 | // @Route : GET/api/user/:id 114 | const getUserById = async (req, res) => { 115 | try { 116 | // let query = `SELECT * FROM users WHERE NAME = ?`; 117 | // const [rows, fields] = await db.execute(query, ['Larry']); 118 | 119 | let query = `SELECT * FROM users WHERE SERIAL_NO = ${req.params.id}`; 120 | const [rows, fields] = await db.execute(query); 121 | 122 | console.log(rows); 123 | if (rows && rows.length > 0) console.log(rows[0]); 124 | } catch (err) { 125 | console.log(err); 126 | // throw new ErrorHandler(500, req, res, 'Error ', err); 127 | } 128 | }; 129 | 130 | 131 | // @Desc : Update User 132 | // @Route : GET/api/user/update/:id 133 | const updateUser = async (req, res) => { 134 | try { 135 | console.log("req.params.id = ", req.params.id); 136 | const { name, age, roll, standard, gender, address } = req.body; // Destructure 137 | 138 | // METHOD - 1 139 | // let modify = "Niharika Dutta"; 140 | // let query = `UPDATE users SET NAME = ? WHERE SERIAL_NO = ?`; 141 | // const [rows, fields] = await db.execute(query, [modify, req.params.id]); 142 | 143 | 144 | // METHOD - 2 145 | // let query = `UPDATE users SET NAME = '${modify}' WHERE UNIQUE_ID = ${req.params.id}`; 146 | if (name.length > 0 && age.length > 0 && roll.length > 0 && gender.length > 0 && address.length > 0) 147 | throw new Error("Missing fields"); 148 | 149 | let query = `UPDATE users SET NAME = ? , AGE = ? , ROLL_NO = ? , STANDARD = ? , GENDER = ? , ADDRESS = ? WHERE UNIQUE_ID = ?`; 150 | const [result, fields] = await db.execute(query, [ 151 | req.params.id, 152 | name, 153 | age || "", 154 | roll, 155 | standard, 156 | gender, 157 | address, 158 | ]); 159 | 160 | const ResponseData = { 161 | ID: req.params.id, 162 | Name: name, 163 | Age: age || " ", 164 | "Roll No.": roll, 165 | Standard: standard, 166 | Gender: gender, 167 | Address: address, 168 | }; 169 | if (result) 170 | res.status(200).json(SuccessHandler(ResponseData, 'User Updated Successfully!')); 171 | } 172 | catch (err) { 173 | console.log(err); 174 | res.status(500).send(ErrorHandler(500, req, res, 'User Not Updated!')); 175 | } 176 | }; 177 | 178 | 179 | // @Desc : Delete User 180 | // @Route : GET/api/user/delete/:id 181 | const deleteUser = async (req, res) => { 182 | try { 183 | let query = `DELETE FROM users WHERE UNIQUE_ID = "${req.params.id}"`; 184 | await db.execute(query); 185 | 186 | if (!req.params.id) 187 | throw new Error("Missing ID"); 188 | 189 | res.status(200).json(SuccessHandler(null, 'User Deleted Successfully!')); 190 | } 191 | catch (err) { 192 | console.log(err); 193 | res.status(500).send(ErrorHandler(500, req, res, 'User Not Deleted!')); 194 | } 195 | }; 196 | 197 | 198 | export { createDatabase, createUserTable, addNewUser, getAllUsers, getUserById, updateUser, deleteUser, }; 199 | -------------------------------------------------------------------------------- /DbConnection/DB.js: -------------------------------------------------------------------------------- 1 | 2 | import mysql from 'mysql2/promise'; 3 | 4 | 5 | // CREATE CONNECTION TO THE DATABASE 6 | const ConnectDB = async () => { 7 | try { 8 | const db = await mysql.createConnection({ 9 | host: 'localhost', 10 | user: 'root', 11 | password: 'niharika#28', 12 | database: 'practiseDatabase', 13 | // port: 6900, 14 | // multipleStatements: true, // Prevent nested sql statements 15 | // connectTimeout: 60 * 60 * 1000, 16 | // debug: true, 17 | }); 18 | return db; 19 | } 20 | catch (error) { 21 | console.error(`Error : ${error.message}`); 22 | process.exit(1) 23 | } 24 | } 25 | 26 | const connection = await mysql.createConnection({ 27 | host: 'localhost', 28 | user: 'root', 29 | password: 'niharika#28', 30 | database: 'practiseDatabase', 31 | }); 32 | 33 | 34 | export default connection; 35 | export { ConnectDB }; 36 | -------------------------------------------------------------------------------- /ResponseHandler/response-handle.js: -------------------------------------------------------------------------------- 1 | 2 | 3 | export const ErrorHandler = (statusCode, req, res, msg, err) => { 4 | console.log(err, statusCode); 5 | const Obj = { 6 | success: false, 7 | path: req.path, 8 | Error: err, 9 | ErrorCode: res.statusCode, 10 | ErrorMessage: res.statusMessage, 11 | method: req.method, 12 | message: msg, 13 | }; 14 | return Obj; 15 | } 16 | 17 | 18 | export const SuccessHandler = (data, message) => ({ 19 | success: true, 20 | status: 'Success', 21 | message: message || 'Success', 22 | data, 23 | }); 24 | 25 | 26 | -------------------------------------------------------------------------------- /Routes/user-routes.js: -------------------------------------------------------------------------------- 1 | 2 | import express from 'express'; 3 | const router = express.Router(); 4 | import { createDatabase, createUserTable, addNewUser, getAllUsers, getUserById, updateUser, deleteUser } from '../Controllers/user-controller.js'; 5 | 6 | 7 | router.get('/createDb', createDatabase); 8 | router.get('/createUserTable', createUserTable); 9 | router.post('/new', addNewUser); 10 | router.get('/all', getAllUsers); 11 | router.put('/update/:id', updateUser); 12 | router.delete('/delete/:id', deleteUser); 13 | router.get('/:id', getUserById); // applicable for id as well as other params 14 | 15 | 16 | export default router; 17 | -------------------------------------------------------------------------------- /abc.txt: -------------------------------------------------------------------------------- 1 | 2 | res.send("Created Success"); 3 | res.status(200); 4 | res.status(statusCode).json(); 5 | res.status(200).send('New User Added Success... '); 6 | 7 | 8 | if (condition) 9 | throw new Error("Missing Field"); 10 | 11 | Both req and res are made available to us by the Express framework 12 | 13 | 14 | const text = '["Ford", "BMW", "Audi", "Fiat"]'; ---> JSON.parse() to convert text/string into a JavaScript Array / Object 15 | const myArr = JSON.parse(text); 16 | 17 | var params = JSON.parse(JSON.stringify(defaultParams)); 18 | 19 | JSON.stringify(arr / obj) --> When data is sent to a server it must be sent as a STRING. 20 | JSON.stringify() method converts JavaScript data to a JSON-formatted string. 21 | 22 | data.image?.trim() || defaultBannerImage 23 | 24 | 25 | 26 | 27 | -------------------- || Async - Await Function || -------------------- 28 | let hello = async function() { return "Hello" }; 29 | hello(); 30 | 31 | let hello = async () => "Hello"; 32 | 33 | ASYNC - AWAIT ==> await keyword tells the function to "WAIT" until its Promise resolves before executing the next line 34 | 35 | 36 | 37 | 38 | -------------------- || MULTER || -------------------- 39 | Multer : Adds a body object and a file or files object to the request object. The body object contains the values of the text fields of the form, 40 | the file or files object contains the files uploaded via the form. 41 | 42 | enctype="multipart/form-data" in your form. 43 | 44 | 45 | # router.post('/upload', multerUpload.array('image'), imageUploadController); 46 | 47 | # app.post('/upload', upload.single('avatar'), () => {} ) 48 | 49 | # app.post('/upload', upload.array('photos', 12), () => {} ) // Can only upload up to 12 files - LIMIT 50 | 51 | # const Multiple = upload.fields([{ name: 'avatar', maxCount: 1 }, { name: 'gallery', maxCount: 8 }]) 52 | app.post('/upload', Multiple, () => {} ) 53 | 54 | 55 | 56 | 57 | sqlQuery = `CREATE TABLE Hotel_Images ( imageId VARCHAR(255) NOT NULL, 58 | abc VARCHAR(255) NOT NULL, 59 | imageUrl VARCHAR(255) NOT NULL, 60 | CONSTRAINT roomImage_Pk PRIMARY KEY(imageId) , 61 | CONSTRAINT roomImage_Fk FOREIGN KEY(abc) REFERENCES Room(roomId) )`; // means abc in this TableB == roomId in TableA -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "crud_using_node_sql", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@sindresorhus/is": { 8 | "version": "0.14.0", 9 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 10 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==" 11 | }, 12 | "@szmarczak/http-timer": { 13 | "version": "1.1.2", 14 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 15 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 16 | "requires": { 17 | "defer-to-connect": "^1.0.1" 18 | } 19 | }, 20 | "abbrev": { 21 | "version": "1.1.1", 22 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 23 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 24 | }, 25 | "accepts": { 26 | "version": "1.3.7", 27 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 28 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 29 | "requires": { 30 | "mime-types": "~2.1.24", 31 | "negotiator": "0.6.2" 32 | } 33 | }, 34 | "ansi-align": { 35 | "version": "3.0.1", 36 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz", 37 | "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==", 38 | "requires": { 39 | "string-width": "^4.1.0" 40 | } 41 | }, 42 | "ansi-regex": { 43 | "version": "5.0.1", 44 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 45 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" 46 | }, 47 | "ansi-styles": { 48 | "version": "4.3.0", 49 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 50 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 51 | "requires": { 52 | "color-convert": "^2.0.1" 53 | } 54 | }, 55 | "anymatch": { 56 | "version": "3.1.2", 57 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 58 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 59 | "requires": { 60 | "normalize-path": "^3.0.0", 61 | "picomatch": "^2.0.4" 62 | } 63 | }, 64 | "array-flatten": { 65 | "version": "1.1.1", 66 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 67 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 68 | }, 69 | "balanced-match": { 70 | "version": "1.0.2", 71 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 72 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 73 | }, 74 | "binary-extensions": { 75 | "version": "2.2.0", 76 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 77 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==" 78 | }, 79 | "body-parser": { 80 | "version": "1.19.0", 81 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 82 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 83 | "requires": { 84 | "bytes": "3.1.0", 85 | "content-type": "~1.0.4", 86 | "debug": "2.6.9", 87 | "depd": "~1.1.2", 88 | "http-errors": "1.7.2", 89 | "iconv-lite": "0.4.24", 90 | "on-finished": "~2.3.0", 91 | "qs": "6.7.0", 92 | "raw-body": "2.4.0", 93 | "type-is": "~1.6.17" 94 | } 95 | }, 96 | "boxen": { 97 | "version": "5.1.2", 98 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-5.1.2.tgz", 99 | "integrity": "sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ==", 100 | "requires": { 101 | "ansi-align": "^3.0.0", 102 | "camelcase": "^6.2.0", 103 | "chalk": "^4.1.0", 104 | "cli-boxes": "^2.2.1", 105 | "string-width": "^4.2.2", 106 | "type-fest": "^0.20.2", 107 | "widest-line": "^3.1.0", 108 | "wrap-ansi": "^7.0.0" 109 | } 110 | }, 111 | "brace-expansion": { 112 | "version": "1.1.11", 113 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 114 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 115 | "requires": { 116 | "balanced-match": "^1.0.0", 117 | "concat-map": "0.0.1" 118 | } 119 | }, 120 | "braces": { 121 | "version": "3.0.2", 122 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 123 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 124 | "requires": { 125 | "fill-range": "^7.0.1" 126 | } 127 | }, 128 | "bytes": { 129 | "version": "3.1.0", 130 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 131 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 132 | }, 133 | "cacheable-request": { 134 | "version": "6.1.0", 135 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 136 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 137 | "requires": { 138 | "clone-response": "^1.0.2", 139 | "get-stream": "^5.1.0", 140 | "http-cache-semantics": "^4.0.0", 141 | "keyv": "^3.0.0", 142 | "lowercase-keys": "^2.0.0", 143 | "normalize-url": "^4.1.0", 144 | "responselike": "^1.0.2" 145 | }, 146 | "dependencies": { 147 | "get-stream": { 148 | "version": "5.2.0", 149 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 150 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 151 | "requires": { 152 | "pump": "^3.0.0" 153 | } 154 | }, 155 | "lowercase-keys": { 156 | "version": "2.0.0", 157 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 158 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==" 159 | } 160 | } 161 | }, 162 | "camelcase": { 163 | "version": "6.2.1", 164 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.1.tgz", 165 | "integrity": "sha512-tVI4q5jjFV5CavAU8DXfza/TJcZutVKo/5Foskmsqcm0MsL91moHvwiGNnqaa2o6PF/7yT5ikDRcVcl8Rj6LCA==" 166 | }, 167 | "chalk": { 168 | "version": "4.1.2", 169 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 170 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 171 | "requires": { 172 | "ansi-styles": "^4.1.0", 173 | "supports-color": "^7.1.0" 174 | }, 175 | "dependencies": { 176 | "has-flag": { 177 | "version": "4.0.0", 178 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 179 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 180 | }, 181 | "supports-color": { 182 | "version": "7.2.0", 183 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 184 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 185 | "requires": { 186 | "has-flag": "^4.0.0" 187 | } 188 | } 189 | } 190 | }, 191 | "chokidar": { 192 | "version": "3.5.2", 193 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 194 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 195 | "requires": { 196 | "anymatch": "~3.1.2", 197 | "braces": "~3.0.2", 198 | "fsevents": "~2.3.2", 199 | "glob-parent": "~5.1.2", 200 | "is-binary-path": "~2.1.0", 201 | "is-glob": "~4.0.1", 202 | "normalize-path": "~3.0.0", 203 | "readdirp": "~3.6.0" 204 | } 205 | }, 206 | "ci-info": { 207 | "version": "2.0.0", 208 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 209 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" 210 | }, 211 | "cli-boxes": { 212 | "version": "2.2.1", 213 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", 214 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==" 215 | }, 216 | "clone-response": { 217 | "version": "1.0.2", 218 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 219 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 220 | "requires": { 221 | "mimic-response": "^1.0.0" 222 | } 223 | }, 224 | "color-convert": { 225 | "version": "2.0.1", 226 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 227 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 228 | "requires": { 229 | "color-name": "~1.1.4" 230 | } 231 | }, 232 | "color-name": { 233 | "version": "1.1.4", 234 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 235 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 236 | }, 237 | "concat-map": { 238 | "version": "0.0.1", 239 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 240 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 241 | }, 242 | "configstore": { 243 | "version": "5.0.1", 244 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 245 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 246 | "requires": { 247 | "dot-prop": "^5.2.0", 248 | "graceful-fs": "^4.1.2", 249 | "make-dir": "^3.0.0", 250 | "unique-string": "^2.0.0", 251 | "write-file-atomic": "^3.0.0", 252 | "xdg-basedir": "^4.0.0" 253 | } 254 | }, 255 | "content-disposition": { 256 | "version": "0.5.3", 257 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 258 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 259 | "requires": { 260 | "safe-buffer": "5.1.2" 261 | } 262 | }, 263 | "content-type": { 264 | "version": "1.0.4", 265 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 266 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 267 | }, 268 | "cookie": { 269 | "version": "0.4.0", 270 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 271 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 272 | }, 273 | "cookie-signature": { 274 | "version": "1.0.6", 275 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 276 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 277 | }, 278 | "crypto-random-string": { 279 | "version": "2.0.0", 280 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 281 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==" 282 | }, 283 | "debug": { 284 | "version": "2.6.9", 285 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 286 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 287 | "requires": { 288 | "ms": "2.0.0" 289 | } 290 | }, 291 | "decompress-response": { 292 | "version": "3.3.0", 293 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 294 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 295 | "requires": { 296 | "mimic-response": "^1.0.0" 297 | } 298 | }, 299 | "deep-extend": { 300 | "version": "0.6.0", 301 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 302 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 303 | }, 304 | "defer-to-connect": { 305 | "version": "1.1.3", 306 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 307 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==" 308 | }, 309 | "denque": { 310 | "version": "2.0.1", 311 | "resolved": "https://registry.npmjs.org/denque/-/denque-2.0.1.tgz", 312 | "integrity": "sha512-tfiWc6BQLXNLpNiR5iGd0Ocu3P3VpxfzFiqubLgMfhfOw9WyvgJBd46CClNn9k3qfbjvT//0cf7AlYRX/OslMQ==" 313 | }, 314 | "depd": { 315 | "version": "1.1.2", 316 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 317 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 318 | }, 319 | "destroy": { 320 | "version": "1.0.4", 321 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 322 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 323 | }, 324 | "dot-prop": { 325 | "version": "5.3.0", 326 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 327 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 328 | "requires": { 329 | "is-obj": "^2.0.0" 330 | } 331 | }, 332 | "dotenv": { 333 | "version": "10.0.0", 334 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-10.0.0.tgz", 335 | "integrity": "sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q==" 336 | }, 337 | "duplexer3": { 338 | "version": "0.1.4", 339 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 340 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=" 341 | }, 342 | "ee-first": { 343 | "version": "1.1.1", 344 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 345 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 346 | }, 347 | "emoji-regex": { 348 | "version": "8.0.0", 349 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 350 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 351 | }, 352 | "encodeurl": { 353 | "version": "1.0.2", 354 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 355 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 356 | }, 357 | "end-of-stream": { 358 | "version": "1.4.4", 359 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 360 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 361 | "requires": { 362 | "once": "^1.4.0" 363 | } 364 | }, 365 | "escape-goat": { 366 | "version": "2.1.1", 367 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 368 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==" 369 | }, 370 | "escape-html": { 371 | "version": "1.0.3", 372 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 373 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 374 | }, 375 | "etag": { 376 | "version": "1.8.1", 377 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 378 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 379 | }, 380 | "express": { 381 | "version": "4.17.1", 382 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 383 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 384 | "requires": { 385 | "accepts": "~1.3.7", 386 | "array-flatten": "1.1.1", 387 | "body-parser": "1.19.0", 388 | "content-disposition": "0.5.3", 389 | "content-type": "~1.0.4", 390 | "cookie": "0.4.0", 391 | "cookie-signature": "1.0.6", 392 | "debug": "2.6.9", 393 | "depd": "~1.1.2", 394 | "encodeurl": "~1.0.2", 395 | "escape-html": "~1.0.3", 396 | "etag": "~1.8.1", 397 | "finalhandler": "~1.1.2", 398 | "fresh": "0.5.2", 399 | "merge-descriptors": "1.0.1", 400 | "methods": "~1.1.2", 401 | "on-finished": "~2.3.0", 402 | "parseurl": "~1.3.3", 403 | "path-to-regexp": "0.1.7", 404 | "proxy-addr": "~2.0.5", 405 | "qs": "6.7.0", 406 | "range-parser": "~1.2.1", 407 | "safe-buffer": "5.1.2", 408 | "send": "0.17.1", 409 | "serve-static": "1.14.1", 410 | "setprototypeof": "1.1.1", 411 | "statuses": "~1.5.0", 412 | "type-is": "~1.6.18", 413 | "utils-merge": "1.0.1", 414 | "vary": "~1.1.2" 415 | } 416 | }, 417 | "fill-range": { 418 | "version": "7.0.1", 419 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 420 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 421 | "requires": { 422 | "to-regex-range": "^5.0.1" 423 | } 424 | }, 425 | "finalhandler": { 426 | "version": "1.1.2", 427 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 428 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 429 | "requires": { 430 | "debug": "2.6.9", 431 | "encodeurl": "~1.0.2", 432 | "escape-html": "~1.0.3", 433 | "on-finished": "~2.3.0", 434 | "parseurl": "~1.3.3", 435 | "statuses": "~1.5.0", 436 | "unpipe": "~1.0.0" 437 | } 438 | }, 439 | "forwarded": { 440 | "version": "0.2.0", 441 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 442 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 443 | }, 444 | "fresh": { 445 | "version": "0.5.2", 446 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 447 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 448 | }, 449 | "fsevents": { 450 | "version": "2.3.2", 451 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 452 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 453 | "optional": true 454 | }, 455 | "generate-function": { 456 | "version": "2.3.1", 457 | "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.3.1.tgz", 458 | "integrity": "sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ==", 459 | "requires": { 460 | "is-property": "^1.0.2" 461 | } 462 | }, 463 | "get-stream": { 464 | "version": "4.1.0", 465 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 466 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 467 | "requires": { 468 | "pump": "^3.0.0" 469 | } 470 | }, 471 | "glob-parent": { 472 | "version": "5.1.2", 473 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 474 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 475 | "requires": { 476 | "is-glob": "^4.0.1" 477 | } 478 | }, 479 | "global-dirs": { 480 | "version": "3.0.0", 481 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-3.0.0.tgz", 482 | "integrity": "sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA==", 483 | "requires": { 484 | "ini": "2.0.0" 485 | } 486 | }, 487 | "got": { 488 | "version": "9.6.0", 489 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 490 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 491 | "requires": { 492 | "@sindresorhus/is": "^0.14.0", 493 | "@szmarczak/http-timer": "^1.1.2", 494 | "cacheable-request": "^6.0.0", 495 | "decompress-response": "^3.3.0", 496 | "duplexer3": "^0.1.4", 497 | "get-stream": "^4.1.0", 498 | "lowercase-keys": "^1.0.1", 499 | "mimic-response": "^1.0.1", 500 | "p-cancelable": "^1.0.0", 501 | "to-readable-stream": "^1.0.0", 502 | "url-parse-lax": "^3.0.0" 503 | } 504 | }, 505 | "graceful-fs": { 506 | "version": "4.2.8", 507 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 508 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==" 509 | }, 510 | "has-flag": { 511 | "version": "3.0.0", 512 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 513 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 514 | }, 515 | "has-yarn": { 516 | "version": "2.1.0", 517 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 518 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==" 519 | }, 520 | "http-cache-semantics": { 521 | "version": "4.1.0", 522 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 523 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==" 524 | }, 525 | "http-errors": { 526 | "version": "1.7.2", 527 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 528 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 529 | "requires": { 530 | "depd": "~1.1.2", 531 | "inherits": "2.0.3", 532 | "setprototypeof": "1.1.1", 533 | "statuses": ">= 1.5.0 < 2", 534 | "toidentifier": "1.0.0" 535 | } 536 | }, 537 | "iconv-lite": { 538 | "version": "0.4.24", 539 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 540 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 541 | "requires": { 542 | "safer-buffer": ">= 2.1.2 < 3" 543 | } 544 | }, 545 | "ignore-by-default": { 546 | "version": "1.0.1", 547 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 548 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=" 549 | }, 550 | "import-lazy": { 551 | "version": "2.1.0", 552 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 553 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=" 554 | }, 555 | "imurmurhash": { 556 | "version": "0.1.4", 557 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 558 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 559 | }, 560 | "inherits": { 561 | "version": "2.0.3", 562 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 563 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 564 | }, 565 | "ini": { 566 | "version": "2.0.0", 567 | "resolved": "https://registry.npmjs.org/ini/-/ini-2.0.0.tgz", 568 | "integrity": "sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==" 569 | }, 570 | "ipaddr.js": { 571 | "version": "1.9.1", 572 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 573 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 574 | }, 575 | "is-binary-path": { 576 | "version": "2.1.0", 577 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 578 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 579 | "requires": { 580 | "binary-extensions": "^2.0.0" 581 | } 582 | }, 583 | "is-ci": { 584 | "version": "2.0.0", 585 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 586 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 587 | "requires": { 588 | "ci-info": "^2.0.0" 589 | } 590 | }, 591 | "is-extglob": { 592 | "version": "2.1.1", 593 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 594 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 595 | }, 596 | "is-fullwidth-code-point": { 597 | "version": "3.0.0", 598 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 599 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 600 | }, 601 | "is-glob": { 602 | "version": "4.0.3", 603 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 604 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 605 | "requires": { 606 | "is-extglob": "^2.1.1" 607 | } 608 | }, 609 | "is-installed-globally": { 610 | "version": "0.4.0", 611 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.4.0.tgz", 612 | "integrity": "sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==", 613 | "requires": { 614 | "global-dirs": "^3.0.0", 615 | "is-path-inside": "^3.0.2" 616 | } 617 | }, 618 | "is-npm": { 619 | "version": "5.0.0", 620 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-5.0.0.tgz", 621 | "integrity": "sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA==" 622 | }, 623 | "is-number": { 624 | "version": "7.0.0", 625 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 626 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 627 | }, 628 | "is-obj": { 629 | "version": "2.0.0", 630 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 631 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==" 632 | }, 633 | "is-path-inside": { 634 | "version": "3.0.3", 635 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 636 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==" 637 | }, 638 | "is-property": { 639 | "version": "1.0.2", 640 | "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz", 641 | "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=" 642 | }, 643 | "is-typedarray": { 644 | "version": "1.0.0", 645 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 646 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 647 | }, 648 | "is-yarn-global": { 649 | "version": "0.3.0", 650 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 651 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==" 652 | }, 653 | "json-buffer": { 654 | "version": "3.0.0", 655 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 656 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=" 657 | }, 658 | "keyv": { 659 | "version": "3.1.0", 660 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 661 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 662 | "requires": { 663 | "json-buffer": "3.0.0" 664 | } 665 | }, 666 | "latest-version": { 667 | "version": "5.1.0", 668 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 669 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 670 | "requires": { 671 | "package-json": "^6.3.0" 672 | } 673 | }, 674 | "long": { 675 | "version": "4.0.0", 676 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 677 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 678 | }, 679 | "lowercase-keys": { 680 | "version": "1.0.1", 681 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 682 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==" 683 | }, 684 | "lru-cache": { 685 | "version": "6.0.0", 686 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 687 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 688 | "requires": { 689 | "yallist": "^4.0.0" 690 | } 691 | }, 692 | "make-dir": { 693 | "version": "3.1.0", 694 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 695 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 696 | "requires": { 697 | "semver": "^6.0.0" 698 | }, 699 | "dependencies": { 700 | "semver": { 701 | "version": "6.3.0", 702 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 703 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 704 | } 705 | } 706 | }, 707 | "media-typer": { 708 | "version": "0.3.0", 709 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 710 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 711 | }, 712 | "merge-descriptors": { 713 | "version": "1.0.1", 714 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 715 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 716 | }, 717 | "methods": { 718 | "version": "1.1.2", 719 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 720 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 721 | }, 722 | "mime": { 723 | "version": "1.6.0", 724 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 725 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 726 | }, 727 | "mime-db": { 728 | "version": "1.51.0", 729 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz", 730 | "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g==" 731 | }, 732 | "mime-types": { 733 | "version": "2.1.34", 734 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz", 735 | "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==", 736 | "requires": { 737 | "mime-db": "1.51.0" 738 | } 739 | }, 740 | "mimic-response": { 741 | "version": "1.0.1", 742 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 743 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==" 744 | }, 745 | "minimatch": { 746 | "version": "3.0.4", 747 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 748 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 749 | "requires": { 750 | "brace-expansion": "^1.1.7" 751 | } 752 | }, 753 | "minimist": { 754 | "version": "1.2.5", 755 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 756 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 757 | }, 758 | "ms": { 759 | "version": "2.0.0", 760 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 761 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 762 | }, 763 | "mysql2": { 764 | "version": "2.3.3", 765 | "resolved": "https://registry.npmjs.org/mysql2/-/mysql2-2.3.3.tgz", 766 | "integrity": "sha512-wxJUev6LgMSgACDkb/InIFxDprRa6T95+VEoR+xPvtngtccNH2dGjEB/fVZ8yg1gWv1510c9CvXuJHi5zUm0ZA==", 767 | "requires": { 768 | "denque": "^2.0.1", 769 | "generate-function": "^2.3.1", 770 | "iconv-lite": "^0.6.3", 771 | "long": "^4.0.0", 772 | "lru-cache": "^6.0.0", 773 | "named-placeholders": "^1.1.2", 774 | "seq-queue": "^0.0.5", 775 | "sqlstring": "^2.3.2" 776 | }, 777 | "dependencies": { 778 | "iconv-lite": { 779 | "version": "0.6.3", 780 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", 781 | "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", 782 | "requires": { 783 | "safer-buffer": ">= 2.1.2 < 3.0.0" 784 | } 785 | } 786 | } 787 | }, 788 | "named-placeholders": { 789 | "version": "1.1.2", 790 | "resolved": "https://registry.npmjs.org/named-placeholders/-/named-placeholders-1.1.2.tgz", 791 | "integrity": "sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA==", 792 | "requires": { 793 | "lru-cache": "^4.1.3" 794 | }, 795 | "dependencies": { 796 | "lru-cache": { 797 | "version": "4.1.5", 798 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 799 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 800 | "requires": { 801 | "pseudomap": "^1.0.2", 802 | "yallist": "^2.1.2" 803 | } 804 | }, 805 | "yallist": { 806 | "version": "2.1.2", 807 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 808 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 809 | } 810 | } 811 | }, 812 | "negotiator": { 813 | "version": "0.6.2", 814 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 815 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 816 | }, 817 | "nodemon": { 818 | "version": "2.0.15", 819 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.15.tgz", 820 | "integrity": "sha512-gdHMNx47Gw7b3kWxJV64NI+Q5nfl0y5DgDbiVtShiwa7Z0IZ07Ll4RLFo6AjrhzMtoEZn5PDE3/c2AbVsiCkpA==", 821 | "requires": { 822 | "chokidar": "^3.5.2", 823 | "debug": "^3.2.7", 824 | "ignore-by-default": "^1.0.1", 825 | "minimatch": "^3.0.4", 826 | "pstree.remy": "^1.1.8", 827 | "semver": "^5.7.1", 828 | "supports-color": "^5.5.0", 829 | "touch": "^3.1.0", 830 | "undefsafe": "^2.0.5", 831 | "update-notifier": "^5.1.0" 832 | }, 833 | "dependencies": { 834 | "debug": { 835 | "version": "3.2.7", 836 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 837 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 838 | "requires": { 839 | "ms": "^2.1.1" 840 | } 841 | }, 842 | "ms": { 843 | "version": "2.1.3", 844 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 845 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 846 | } 847 | } 848 | }, 849 | "nopt": { 850 | "version": "1.0.10", 851 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 852 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 853 | "requires": { 854 | "abbrev": "1" 855 | } 856 | }, 857 | "normalize-path": { 858 | "version": "3.0.0", 859 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 860 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" 861 | }, 862 | "normalize-url": { 863 | "version": "4.5.1", 864 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz", 865 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==" 866 | }, 867 | "on-finished": { 868 | "version": "2.3.0", 869 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 870 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 871 | "requires": { 872 | "ee-first": "1.1.1" 873 | } 874 | }, 875 | "once": { 876 | "version": "1.4.0", 877 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 878 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 879 | "requires": { 880 | "wrappy": "1" 881 | } 882 | }, 883 | "p-cancelable": { 884 | "version": "1.1.0", 885 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 886 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==" 887 | }, 888 | "package-json": { 889 | "version": "6.5.0", 890 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 891 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 892 | "requires": { 893 | "got": "^9.6.0", 894 | "registry-auth-token": "^4.0.0", 895 | "registry-url": "^5.0.0", 896 | "semver": "^6.2.0" 897 | }, 898 | "dependencies": { 899 | "semver": { 900 | "version": "6.3.0", 901 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 902 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 903 | } 904 | } 905 | }, 906 | "parseurl": { 907 | "version": "1.3.3", 908 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 909 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 910 | }, 911 | "path-to-regexp": { 912 | "version": "0.1.7", 913 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 914 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 915 | }, 916 | "picomatch": { 917 | "version": "2.3.0", 918 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 919 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==" 920 | }, 921 | "prepend-http": { 922 | "version": "2.0.0", 923 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 924 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=" 925 | }, 926 | "proxy-addr": { 927 | "version": "2.0.7", 928 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 929 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 930 | "requires": { 931 | "forwarded": "0.2.0", 932 | "ipaddr.js": "1.9.1" 933 | } 934 | }, 935 | "pseudomap": { 936 | "version": "1.0.2", 937 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 938 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 939 | }, 940 | "pstree.remy": { 941 | "version": "1.1.8", 942 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 943 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 944 | }, 945 | "pump": { 946 | "version": "3.0.0", 947 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 948 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 949 | "requires": { 950 | "end-of-stream": "^1.1.0", 951 | "once": "^1.3.1" 952 | } 953 | }, 954 | "pupa": { 955 | "version": "2.1.1", 956 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", 957 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", 958 | "requires": { 959 | "escape-goat": "^2.0.0" 960 | } 961 | }, 962 | "qs": { 963 | "version": "6.7.0", 964 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 965 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 966 | }, 967 | "range-parser": { 968 | "version": "1.2.1", 969 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 970 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 971 | }, 972 | "raw-body": { 973 | "version": "2.4.0", 974 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 975 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 976 | "requires": { 977 | "bytes": "3.1.0", 978 | "http-errors": "1.7.2", 979 | "iconv-lite": "0.4.24", 980 | "unpipe": "1.0.0" 981 | } 982 | }, 983 | "rc": { 984 | "version": "1.2.8", 985 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 986 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 987 | "requires": { 988 | "deep-extend": "^0.6.0", 989 | "ini": "~1.3.0", 990 | "minimist": "^1.2.0", 991 | "strip-json-comments": "~2.0.1" 992 | }, 993 | "dependencies": { 994 | "ini": { 995 | "version": "1.3.8", 996 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 997 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" 998 | } 999 | } 1000 | }, 1001 | "readdirp": { 1002 | "version": "3.6.0", 1003 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1004 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1005 | "requires": { 1006 | "picomatch": "^2.2.1" 1007 | } 1008 | }, 1009 | "registry-auth-token": { 1010 | "version": "4.2.1", 1011 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz", 1012 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==", 1013 | "requires": { 1014 | "rc": "^1.2.8" 1015 | } 1016 | }, 1017 | "registry-url": { 1018 | "version": "5.1.0", 1019 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1020 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1021 | "requires": { 1022 | "rc": "^1.2.8" 1023 | } 1024 | }, 1025 | "responselike": { 1026 | "version": "1.0.2", 1027 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1028 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1029 | "requires": { 1030 | "lowercase-keys": "^1.0.0" 1031 | } 1032 | }, 1033 | "safe-buffer": { 1034 | "version": "5.1.2", 1035 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1036 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1037 | }, 1038 | "safer-buffer": { 1039 | "version": "2.1.2", 1040 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1041 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1042 | }, 1043 | "semver": { 1044 | "version": "5.7.1", 1045 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1046 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1047 | }, 1048 | "semver-diff": { 1049 | "version": "3.1.1", 1050 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1051 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1052 | "requires": { 1053 | "semver": "^6.3.0" 1054 | }, 1055 | "dependencies": { 1056 | "semver": { 1057 | "version": "6.3.0", 1058 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1059 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 1060 | } 1061 | } 1062 | }, 1063 | "send": { 1064 | "version": "0.17.1", 1065 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1066 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1067 | "requires": { 1068 | "debug": "2.6.9", 1069 | "depd": "~1.1.2", 1070 | "destroy": "~1.0.4", 1071 | "encodeurl": "~1.0.2", 1072 | "escape-html": "~1.0.3", 1073 | "etag": "~1.8.1", 1074 | "fresh": "0.5.2", 1075 | "http-errors": "~1.7.2", 1076 | "mime": "1.6.0", 1077 | "ms": "2.1.1", 1078 | "on-finished": "~2.3.0", 1079 | "range-parser": "~1.2.1", 1080 | "statuses": "~1.5.0" 1081 | }, 1082 | "dependencies": { 1083 | "ms": { 1084 | "version": "2.1.1", 1085 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1086 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1087 | } 1088 | } 1089 | }, 1090 | "seq-queue": { 1091 | "version": "0.0.5", 1092 | "resolved": "https://registry.npmjs.org/seq-queue/-/seq-queue-0.0.5.tgz", 1093 | "integrity": "sha1-1WgS4cAXpuTnw+Ojeh2m143TyT4=" 1094 | }, 1095 | "serve-static": { 1096 | "version": "1.14.1", 1097 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1098 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1099 | "requires": { 1100 | "encodeurl": "~1.0.2", 1101 | "escape-html": "~1.0.3", 1102 | "parseurl": "~1.3.3", 1103 | "send": "0.17.1" 1104 | } 1105 | }, 1106 | "setprototypeof": { 1107 | "version": "1.1.1", 1108 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1109 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1110 | }, 1111 | "signal-exit": { 1112 | "version": "3.0.6", 1113 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.6.tgz", 1114 | "integrity": "sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ==" 1115 | }, 1116 | "sqlstring": { 1117 | "version": "2.3.2", 1118 | "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.2.tgz", 1119 | "integrity": "sha512-vF4ZbYdKS8OnoJAWBmMxCQDkiEBkGQYU7UZPtL8flbDRSNkhaXvRJ279ZtI6M+zDaQovVU4tuRgzK5fVhvFAhg==" 1120 | }, 1121 | "statuses": { 1122 | "version": "1.5.0", 1123 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1124 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1125 | }, 1126 | "string-width": { 1127 | "version": "4.2.3", 1128 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1129 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1130 | "requires": { 1131 | "emoji-regex": "^8.0.0", 1132 | "is-fullwidth-code-point": "^3.0.0", 1133 | "strip-ansi": "^6.0.1" 1134 | } 1135 | }, 1136 | "strip-ansi": { 1137 | "version": "6.0.1", 1138 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1139 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1140 | "requires": { 1141 | "ansi-regex": "^5.0.1" 1142 | } 1143 | }, 1144 | "strip-json-comments": { 1145 | "version": "2.0.1", 1146 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1147 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 1148 | }, 1149 | "supports-color": { 1150 | "version": "5.5.0", 1151 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1152 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1153 | "requires": { 1154 | "has-flag": "^3.0.0" 1155 | } 1156 | }, 1157 | "to-readable-stream": { 1158 | "version": "1.0.0", 1159 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1160 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==" 1161 | }, 1162 | "to-regex-range": { 1163 | "version": "5.0.1", 1164 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1165 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1166 | "requires": { 1167 | "is-number": "^7.0.0" 1168 | } 1169 | }, 1170 | "toidentifier": { 1171 | "version": "1.0.0", 1172 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1173 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 1174 | }, 1175 | "touch": { 1176 | "version": "3.1.0", 1177 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1178 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1179 | "requires": { 1180 | "nopt": "~1.0.10" 1181 | } 1182 | }, 1183 | "type-fest": { 1184 | "version": "0.20.2", 1185 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1186 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==" 1187 | }, 1188 | "type-is": { 1189 | "version": "1.6.18", 1190 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1191 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1192 | "requires": { 1193 | "media-typer": "0.3.0", 1194 | "mime-types": "~2.1.24" 1195 | } 1196 | }, 1197 | "typedarray-to-buffer": { 1198 | "version": "3.1.5", 1199 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1200 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1201 | "requires": { 1202 | "is-typedarray": "^1.0.0" 1203 | } 1204 | }, 1205 | "undefsafe": { 1206 | "version": "2.0.5", 1207 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", 1208 | "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==" 1209 | }, 1210 | "unique-string": { 1211 | "version": "2.0.0", 1212 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 1213 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 1214 | "requires": { 1215 | "crypto-random-string": "^2.0.0" 1216 | } 1217 | }, 1218 | "unpipe": { 1219 | "version": "1.0.0", 1220 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1221 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1222 | }, 1223 | "update-notifier": { 1224 | "version": "5.1.0", 1225 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-5.1.0.tgz", 1226 | "integrity": "sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw==", 1227 | "requires": { 1228 | "boxen": "^5.0.0", 1229 | "chalk": "^4.1.0", 1230 | "configstore": "^5.0.1", 1231 | "has-yarn": "^2.1.0", 1232 | "import-lazy": "^2.1.0", 1233 | "is-ci": "^2.0.0", 1234 | "is-installed-globally": "^0.4.0", 1235 | "is-npm": "^5.0.0", 1236 | "is-yarn-global": "^0.3.0", 1237 | "latest-version": "^5.1.0", 1238 | "pupa": "^2.1.1", 1239 | "semver": "^7.3.4", 1240 | "semver-diff": "^3.1.1", 1241 | "xdg-basedir": "^4.0.0" 1242 | }, 1243 | "dependencies": { 1244 | "semver": { 1245 | "version": "7.3.5", 1246 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1247 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1248 | "requires": { 1249 | "lru-cache": "^6.0.0" 1250 | } 1251 | } 1252 | } 1253 | }, 1254 | "url-parse-lax": { 1255 | "version": "3.0.0", 1256 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 1257 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 1258 | "requires": { 1259 | "prepend-http": "^2.0.0" 1260 | } 1261 | }, 1262 | "utils-merge": { 1263 | "version": "1.0.1", 1264 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1265 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1266 | }, 1267 | "uuid": { 1268 | "version": "8.3.2", 1269 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", 1270 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" 1271 | }, 1272 | "vary": { 1273 | "version": "1.1.2", 1274 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1275 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1276 | }, 1277 | "widest-line": { 1278 | "version": "3.1.0", 1279 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 1280 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 1281 | "requires": { 1282 | "string-width": "^4.0.0" 1283 | } 1284 | }, 1285 | "wrap-ansi": { 1286 | "version": "7.0.0", 1287 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1288 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1289 | "requires": { 1290 | "ansi-styles": "^4.0.0", 1291 | "string-width": "^4.1.0", 1292 | "strip-ansi": "^6.0.0" 1293 | } 1294 | }, 1295 | "wrappy": { 1296 | "version": "1.0.2", 1297 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1298 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1299 | }, 1300 | "write-file-atomic": { 1301 | "version": "3.0.3", 1302 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 1303 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 1304 | "requires": { 1305 | "imurmurhash": "^0.1.4", 1306 | "is-typedarray": "^1.0.0", 1307 | "signal-exit": "^3.0.2", 1308 | "typedarray-to-buffer": "^3.1.5" 1309 | } 1310 | }, 1311 | "xdg-basedir": { 1312 | "version": "4.0.0", 1313 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 1314 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==" 1315 | }, 1316 | "yallist": { 1317 | "version": "4.0.0", 1318 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1319 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1320 | } 1321 | } 1322 | } 1323 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "crud_using_node_sql", 3 | "version": "1.0.0", 4 | "description": "Node_with_Sql", 5 | "main": "server.js", 6 | "type": "module", 7 | "scripts": { 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "start": "node server.js", 10 | "server": "nodemon server.js" 11 | }, 12 | "author": "Niharika Dutta", 13 | "license": "ISC", 14 | "dependencies": { 15 | "dotenv": "^10.0.0", 16 | "express": "^4.17.1", 17 | "mysql2": "^2.3.3", 18 | "nodemon": "^2.0.15", 19 | "uuid": "^8.3.2" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /server.js: -------------------------------------------------------------------------------- 1 | 2 | import express from 'express'; 3 | import dotenv from 'dotenv'; 4 | import userRoutes from './Routes/user-routes.js'; 5 | 6 | 7 | dotenv.config(); 8 | const app = express(); 9 | const port = process.env.PORT || 8000; 10 | app.use(express.json()); 11 | 12 | // app.get(endpoint, callback) 13 | app.get('/', (req, res) => { 14 | res.send('get success !') 15 | }) 16 | 17 | // INSERT DATA ---- POST REQUEST 18 | /* app.get('/addpost', (req, res) => { 19 | let post = { name: 'niharika', title: 'post 1 created' }; 20 | let sqlCommand = 'INSERT INTO Users SET ?'; 21 | let query = db.query(sqlCommand, post, (err, result) => { 22 | if (err) throw err; 23 | console.log("Result = ", result); 24 | res.status(200); 25 | res.send('added '); 26 | }); 27 | }) */ 28 | 29 | 30 | // SYNTAX: app.use(path, callback) 31 | app.use('/api/user', userRoutes); 32 | 33 | 34 | // listen() function ----> used to bind and listen the connections on the specified host and port 35 | app.listen(port, function () { 36 | console.log(`App listening at http://localhost:${port} for ${process.env.NODE_ENV}`); 37 | console.log(process.env.PORT); 38 | }) 39 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Visit https://aka.ms/tsconfig.json to read more about this file */ 4 | /* Basic Options */ 5 | // "incremental": true, /* Enable incremental compilation */ 6 | "target": "es6" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, 7 | "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, 8 | // "lib": [], /* Specify library files to be included in the compilation. */ 9 | // "allowJs": true, /* Allow javascript files to be compiled. */ 10 | // "checkJs": true, /* Report errors in .js files. */ 11 | // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ 12 | // "declaration": true, /* Generates corresponding '.d.ts' file. */ 13 | // "declarationMap": true, /* Generates a sourcemap for each corresponding '.d.ts' file. */ 14 | // "sourceMap": true, /* Generates corresponding '.map' file. */ 15 | // "outFile": "./", /* Concatenate and emit output to single file. */ 16 | "outDir": "./dist" /* Redirect output structure to the directory. */, 17 | "rootDir": "./src" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, 18 | // "composite": true, /* Enable project compilation */ 19 | // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ 20 | // "removeComments": true, /* Do not emit comments to output. */ 21 | // "noEmit": true, /* Do not emit outputs. */ 22 | // "importHelpers": true, /* Import emit helpers from 'tslib'. */ 23 | // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ 24 | // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ 25 | 26 | /* Strict Type-Checking Options */ 27 | "strict": true /* Enable all strict type-checking options. */, 28 | // "noImplicitAny": true, /* Raise error on expressions and declarations with an implied 'any' type. */ 29 | // "strictNullChecks": true, /* Enable strict null checks. */ 30 | // "strictFunctionTypes": true, /* Enable strict checking of function types. */ 31 | // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ 32 | // "strictPropertyInitialization": true, /* Enable strict checking of property initialization in classes. */ 33 | // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ 34 | // "alwaysStrict": true, /* Parse in strict mode and emit "use strict" for each source file. */ 35 | 36 | /* Additional Checks */ 37 | // "noUnusedLocals": true, /* Report errors on unused locals. */ 38 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 39 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 40 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 41 | // "noUncheckedIndexedAccess": true, /* Include 'undefined' in index signature results */ 42 | 43 | /* Module Resolution Options */ 44 | "moduleResolution": "node" /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */, 45 | // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ 46 | // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ 47 | // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ 48 | // "typeRoots": [], /* List of folders to include type definitions from. */ 49 | // "types": [], /* Type declaration files to be included in compilation. */ 50 | // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ 51 | "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, 52 | // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ 53 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 54 | 55 | /* Source Map Options */ 56 | // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ 57 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 58 | // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ 59 | // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ 60 | 61 | /* Experimental Options */ 62 | // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ 63 | // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ 64 | 65 | /* Advanced Options */ 66 | "skipLibCheck": true /* Skip type checking of declaration files. */, 67 | "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */ 68 | } 69 | } 70 | --------------------------------------------------------------------------------