├── ReadMe.md ├── client ├── .gitignore ├── README.md ├── package-lock.json ├── package.json ├── public │ ├── bootstrap.min.css │ ├── favicon.ico │ ├── index.html │ ├── logo192.png │ ├── logo512.png │ ├── manifest.json │ └── robots.txt └── src │ ├── assets │ └── DefaultAvatar.png │ ├── components │ ├── App.js │ ├── Bootstrap │ │ ├── Card.js │ │ ├── FormGroup.js │ │ └── Header.js │ ├── Dashboard │ │ ├── Dashboard.js │ │ ├── _ProfileCompleteness.js │ │ ├── _VerifiedUserSection.js │ │ └── _VerifyUserSection.js │ ├── Home │ │ ├── Login.js │ │ └── Register.js │ └── Profile │ │ └── Profile.js │ ├── index.js │ ├── reportWebVitals.js │ ├── services │ ├── Auth.js │ └── Users.js │ ├── setupTests.js │ ├── styles │ ├── App.scss │ ├── Bootstrap │ │ └── Header.scss │ ├── Profile.scss │ ├── ProfileCompleteness.scss │ └── index.scss │ └── tests │ └── App.test.js └── server ├── .gitignore ├── constants ├── Users.json └── salt.json ├── helpers └── Users.js ├── package-lock.json ├── package.json ├── routes ├── api.js ├── api │ ├── auth.js │ └── users.js └── root.js └── server.js /ReadMe.md: -------------------------------------------------------------------------------- 1 | # Community Class Room 2 | 3 | ## Intro 4 | 5 | ## Motivation 6 | 7 | ## Tech Stack Used 8 | 9 | ### PreRequisites 10 | 11 | ### Installation Instructions 12 | 13 | ## Features 14 | 15 | - Marketing Public Pages 16 | - Basic Design from the Theme 17 | - Authenticated Dashboard Journey 18 | - User Dashboard 19 | - Enrolled Courses 20 | - Course Suggestion 21 | - Pie Chart: Techs 22 | - Pie Chart: Completion Status 23 | - User Profile 24 | - Basic Details 25 | - Education Details 26 | - Contact Details 27 | - User Settings 28 | - Edit Basic Details 29 | - Edit Education Details 30 | - Edit Contact Details 31 | - Change Password 32 | - Delete Account 33 | - Courses Paths 34 | - List 35 | - Courses List 36 | - Filters & Sorting Options 37 | - Favourite / Saved Courses 38 | - Custom Course Lists 39 | - Course Detail 40 | - About the Course 41 | - About the Author 42 | - Comments & Rating 43 | - Course Enrolment Journey 44 | - Steps of Enrolment 45 | - Admin Dashboard 46 | - List of Users 47 | - List of Courses 48 | - Specific Lists 49 | - Stale Users 50 | - Stale Courses 51 | - Course Completion Status 52 | - Admin Profile 53 | - Edit Basic Details 54 | - Edit Education Details 55 | - Edit Contact Details 56 | - Change Password 57 | - Admin Settings 58 | - Admin User Management 59 | - Admin Course Management 60 | -------------------------------------------------------------------------------- /client/.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | /node_modules 5 | /.pnp 6 | .pnp.js 7 | 8 | # testing 9 | /coverage 10 | 11 | # production 12 | /build 13 | 14 | # misc 15 | .DS_Store 16 | .env.local 17 | .env.development.local 18 | .env.test.local 19 | .env.production.local 20 | 21 | npm-debug.log* 22 | yarn-debug.log* 23 | yarn-error.log* 24 | -------------------------------------------------------------------------------- /client/README.md: -------------------------------------------------------------------------------- 1 | # Getting Started with Create React App 2 | 3 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). 4 | 5 | ## Available Scripts 6 | 7 | In the project directory, you can run: 8 | 9 | ### `npm start` 10 | 11 | Runs the app in the development mode.\ 12 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser. 13 | 14 | The page will reload if you make edits.\ 15 | You will also see any lint errors in the console. 16 | 17 | ### `npm test` 18 | 19 | Launches the test runner in the interactive watch mode.\ 20 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information. 21 | 22 | ### `npm run build` 23 | 24 | Builds the app for production to the `build` folder.\ 25 | It correctly bundles React in production mode and optimizes the build for the best performance. 26 | 27 | The build is minified and the filenames include the hashes.\ 28 | Your app is ready to be deployed! 29 | 30 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information. 31 | 32 | ### `npm run eject` 33 | 34 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!** 35 | 36 | If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project. 37 | 38 | Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own. 39 | 40 | You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it. 41 | 42 | ## Learn More 43 | 44 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started). 45 | 46 | To learn React, check out the [React documentation](https://reactjs.org/). 47 | 48 | ### Code Splitting 49 | 50 | This section has moved here: [https://facebook.github.io/create-react-app/docs/code-splitting](https://facebook.github.io/create-react-app/docs/code-splitting) 51 | 52 | ### Analyzing the Bundle Size 53 | 54 | This section has moved here: [https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size](https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size) 55 | 56 | ### Making a Progressive Web App 57 | 58 | This section has moved here: [https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app](https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app) 59 | 60 | ### Advanced Configuration 61 | 62 | This section has moved here: [https://facebook.github.io/create-react-app/docs/advanced-configuration](https://facebook.github.io/create-react-app/docs/advanced-configuration) 63 | 64 | ### Deployment 65 | 66 | This section has moved here: [https://facebook.github.io/create-react-app/docs/deployment](https://facebook.github.io/create-react-app/docs/deployment) 67 | 68 | ### `npm run build` fails to minify 69 | 70 | This section has moved here: [https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify](https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify) 71 | -------------------------------------------------------------------------------- /client/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "client", 3 | "version": "0.1.0", 4 | "proxy": "http://localhost:5000/", 5 | "private": true, 6 | "dependencies": { 7 | "@testing-library/jest-dom": "^5.14.1", 8 | "@testing-library/react": "^11.2.7", 9 | "@testing-library/user-event": "^12.8.3", 10 | "axios": "^0.21.4", 11 | "node-sass": "^6.0.1", 12 | "react": "^17.0.2", 13 | "react-dom": "^17.0.2", 14 | "react-router-dom": "^5.3.0", 15 | "react-scripts": "4.0.3", 16 | "web-vitals": "^1.1.2" 17 | }, 18 | "scripts": { 19 | "start": "react-scripts start", 20 | "build": "react-scripts build", 21 | "test": "react-scripts test", 22 | "eject": "react-scripts eject" 23 | }, 24 | "eslintConfig": { 25 | "extends": [ 26 | "react-app", 27 | "react-app/jest" 28 | ] 29 | }, 30 | "browserslist": { 31 | "production": [ 32 | ">0.2%", 33 | "not dead", 34 | "not op_mini all" 35 | ], 36 | "development": [ 37 | "last 1 chrome version", 38 | "last 1 firefox version", 39 | "last 1 safari version" 40 | ] 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /client/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/praveenscience/CommClassRoom-FullStack/d153287bc2572e75fd8622b030fe54385b051078/client/public/favicon.ico -------------------------------------------------------------------------------- /client/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 12 | 13 | 17 | 18 | 27 | Community Classroom Dashboard 28 | 29 | 30 | 34 | 35 | 36 | 37 | 38 |
39 | 49 | 50 | 51 | -------------------------------------------------------------------------------- /client/public/logo192.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/praveenscience/CommClassRoom-FullStack/d153287bc2572e75fd8622b030fe54385b051078/client/public/logo192.png -------------------------------------------------------------------------------- /client/public/logo512.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/praveenscience/CommClassRoom-FullStack/d153287bc2572e75fd8622b030fe54385b051078/client/public/logo512.png -------------------------------------------------------------------------------- /client/public/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "short_name": "React App", 3 | "name": "Create React App Sample", 4 | "icons": [ 5 | { 6 | "src": "favicon.ico", 7 | "sizes": "64x64 32x32 24x24 16x16", 8 | "type": "image/x-icon" 9 | }, 10 | { 11 | "src": "logo192.png", 12 | "type": "image/png", 13 | "sizes": "192x192" 14 | }, 15 | { 16 | "src": "logo512.png", 17 | "type": "image/png", 18 | "sizes": "512x512" 19 | } 20 | ], 21 | "start_url": ".", 22 | "display": "standalone", 23 | "theme_color": "#000000", 24 | "background_color": "#ffffff" 25 | } 26 | -------------------------------------------------------------------------------- /client/public/robots.txt: -------------------------------------------------------------------------------- 1 | # https://www.robotstxt.org/robotstxt.html 2 | User-agent: * 3 | Disallow: 4 | -------------------------------------------------------------------------------- /client/src/assets/DefaultAvatar.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/praveenscience/CommClassRoom-FullStack/d153287bc2572e75fd8622b030fe54385b051078/client/src/assets/DefaultAvatar.png -------------------------------------------------------------------------------- /client/src/components/App.js: -------------------------------------------------------------------------------- 1 | import { Component } from "react"; 2 | import { Switch, Route } from "react-router-dom"; 3 | import { LoginUser, LogoutUser, RegisterUser } from "../services/Auth"; 4 | import Card from "./Bootstrap/Card"; 5 | import Header from "./Bootstrap/Header"; 6 | import Dashboard from "./Dashboard/Dashboard"; 7 | import Login from "./Home/Login"; 8 | import Register from "./Home/Register"; 9 | import Profile from "./Profile/Profile"; 10 | 11 | const InitState = { 12 | User: null, 13 | Users: null, 14 | Forms: { 15 | Login: { 16 | Username: "", 17 | Password: "" 18 | }, 19 | Register: { 20 | FullName: "", 21 | Email: "", 22 | Username: "", 23 | Role: "", 24 | Password: "", 25 | "Confirm Password": "" 26 | } 27 | }, 28 | Errors: { 29 | Login: [], 30 | Register: [] 31 | }, 32 | Successes: { 33 | Login: [], 34 | Register: [] 35 | } 36 | }; 37 | class App extends Component { 38 | state = { ...InitState }; 39 | handleFormChange = (Form, Name, Value) => { 40 | const Forms = { ...this.state.Forms }; 41 | Forms[Form] = { ...this.state.Forms[Form] }; 42 | Forms[Form][Name] = Value; 43 | this.setState({ 44 | Forms 45 | }); 46 | }; 47 | handleLogin = e => { 48 | e.preventDefault(); 49 | const Errors = { ...this.state.Errors }; 50 | const Successes = { ...this.state.Successes }; 51 | Errors.Login = []; 52 | Successes.Login = []; 53 | this.setState({ 54 | Errors, 55 | Successes 56 | }); 57 | const { Username, Password } = this.state.Forms.Login; 58 | LoginUser(Username, Password) 59 | .then(res => { 60 | const Successes = { ...this.state.Successes }; 61 | if (res.status === 200) { 62 | Successes.Login.push( 63 | "User logged in Successfully! Taking you to the dashboard..." 64 | ); 65 | this.setState( 66 | { 67 | Successes 68 | }, 69 | () => { 70 | setTimeout(() => { 71 | this.setState({ 72 | User: res.data 73 | }); 74 | }, 2000); 75 | } 76 | ); 77 | } 78 | }) 79 | .catch(err => { 80 | const Errors = { ...this.state.Errors }; 81 | Errors.Login.push(err.response.data.Error); 82 | this.setState({ 83 | Errors 84 | }); 85 | }); 86 | }; 87 | handleRegister = e => { 88 | e.preventDefault(); 89 | const Errors = { ...this.state.Errors }; 90 | Errors.Register = []; 91 | const Successes = { ...this.state.Successes }; 92 | Successes.Register = []; 93 | this.setState({ 94 | Errors, 95 | Successes 96 | }); 97 | const { Username, Email, Password, FullName, Role } = 98 | this.state.Forms.Register; 99 | RegisterUser(Username, Password, FullName, Email, Role) 100 | .then(res => { 101 | const Successes = { ...this.state.Successes }; 102 | Successes.Register.push(res.data.Message); 103 | this.setState({ 104 | Successes 105 | }); 106 | }) 107 | .catch(err => { 108 | const Errors = { ...this.state.Errors }; 109 | Errors.Register.push(err.response.data.Error); 110 | this.setState({ 111 | Errors 112 | }); 113 | }); 114 | }; 115 | handleLogout = e => { 116 | e.preventDefault(); 117 | LogoutUser().then(() => { 118 | this.setState({ ...InitState }); 119 | }); 120 | }; 121 | render() { 122 | return ( 123 |
124 |
125 | Community Classroom 126 |
127 |
128 | {this.state.User ? ( 129 | 130 | 131 | 136 | 137 | } 140 | /> 141 | 142 | ) : ( 143 |
144 |
145 | 153 |
154 |
155 | 163 |
164 |
165 | )} 166 |
167 |
168 | ); 169 | } 170 | } 171 | 172 | export default App; 173 | -------------------------------------------------------------------------------- /client/src/components/Bootstrap/Card.js: -------------------------------------------------------------------------------- 1 | const Card = ({ 2 | Image, 3 | ImgAlign, 4 | Header, 5 | TextHeader, 6 | Title, 7 | Text, 8 | children, 9 | Footer, 10 | className 11 | }) => { 12 | return ( 13 |
14 | {Image && ( 15 | {Header 20 | )} 21 | {Header && 22 | (TextHeader ? ( 23 |
{Header}
24 | ) : ( 25 |
{Header}
26 | ))} 27 | {(Title || Text || children) && ( 28 |
29 | {Title &&
{Title}
} 30 | {Text &&

{Text}

} 31 | {children} 32 |
33 | )} 34 | {Footer &&
{Footer}
} 35 |
36 | ); 37 | }; 38 | 39 | export default Card; 40 | -------------------------------------------------------------------------------- /client/src/components/Bootstrap/FormGroup.js: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | 3 | const FormGroup = ({ 4 | Id, 5 | Label, 6 | Type, 7 | onChange, 8 | Value, 9 | defaultValue, 10 | Checked, 11 | defaultChecked, 12 | Desc 13 | }) => { 14 | return ( 15 |
16 | 17 | 29 | {Desc && ( 30 | 31 | {Desc} 32 | 33 | )} 34 |
35 | ); 36 | }; 37 | 38 | export default FormGroup; 39 | -------------------------------------------------------------------------------- /client/src/components/Bootstrap/Header.js: -------------------------------------------------------------------------------- 1 | const Header = ({ dark, children, className, pages, to, Link }) => { 2 | dark = !!dark ? "dark" : "light"; 3 | return ( 4 | 34 | ); 35 | }; 36 | 37 | export default Header; 38 | -------------------------------------------------------------------------------- /client/src/components/Dashboard/Dashboard.js: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import { Link } from "react-router-dom"; 3 | import { VerifyUser } from "../../services/Auth"; 4 | import FormGroup from "../Bootstrap/FormGroup"; 5 | import ProfileCompleteness from "./_ProfileCompleteness"; 6 | import VerifiedUserSection from "./_VerifiedUserSection"; 7 | import VerifyUserSection from "./_VerifyUserSection"; 8 | 9 | const Dashboard = ({ Card, handleLogout, User }) => { 10 | const [Code, setCode] = useState(""); 11 | const [Output, setOutput] = useState(null); 12 | const handleVerifyUser = e => { 13 | e.preventDefault(); 14 | VerifyUser(User.Username, Code) 15 | .then(res => { 16 | if (res.status === 200) { 17 | setOutput( 18 | "Verification was successful. Please relogin to enable all the features." 19 | ); 20 | setTimeout(() => { 21 | handleLogout({ preventDefault: () => {} }); 22 | }, 2500); 23 | } 24 | }) 25 | .catch(() => { 26 | setOutput("Error! Invalid Code."); 27 | }); 28 | }; 29 | return ( 30 | 31 |
32 |
33 |
34 |

Welcome to Community Classroom.

35 | {User.VerifyHash ? ( 36 | 46 | ) : ( 47 | 48 | )} 49 | 53 | My Profile 54 | 55 | 58 |
59 |
60 | 61 |
62 |
63 |
64 |
65 | ); 66 | }; 67 | 68 | export default Dashboard; 69 | -------------------------------------------------------------------------------- /client/src/components/Dashboard/_ProfileCompleteness.js: -------------------------------------------------------------------------------- 1 | import Card from "../Bootstrap/Card"; 2 | import DefaultAvatar from "../../assets/DefaultAvatar.png"; 3 | 4 | const ProfileCompleteness = ({ User }) => { 5 | const [Personal, Socials] = [ 6 | [ 7 | [...Object.values(User.Personal), User.Avatar].filter(v => v !== null) 8 | .length, 9 | [...Object.values(User.Personal), User.Avatar].length 10 | ], 11 | [ 12 | Object.values(User.Socials).filter(v => v !== null).length, 13 | Object.values(User.Socials).length 14 | ] 15 | ]; 16 | const Areas = { 17 | Personal, 18 | Socials 19 | }; 20 | return ( 21 | 22 |
23 | {User.Name} 28 |
29 | {Object.keys(Areas).map(progress => ( 30 |
31 | 32 | {progress}{" "} 33 | 34 | ( 35 | {((Areas[progress][0] / Areas[progress][1]) * 100).toFixed(0) + 36 | "%"}{" "} 37 | complete) 38 | 39 | 40 |
41 |
51 | {((Areas[progress][0] / Areas[progress][1]) * 100).toFixed(0) + 52 | "%"} 53 |
54 |
55 |
56 | ))} 57 |
58 | ); 59 | }; 60 | 61 | export default ProfileCompleteness; 62 | -------------------------------------------------------------------------------- /client/src/components/Dashboard/_VerifiedUserSection.js: -------------------------------------------------------------------------------- 1 | const VerifiedUserSection = () => { 2 | return ( 3 | <> 4 |

Thanks for verifying and becoming a full user.

5 | 6 | ); 7 | }; 8 | 9 | export default VerifiedUserSection; 10 | -------------------------------------------------------------------------------- /client/src/components/Dashboard/_VerifyUserSection.js: -------------------------------------------------------------------------------- 1 | const VerifyUserSection = ({ 2 | Output, 3 | User, 4 | handleVerifyUser, 5 | FormGroup, 6 | Code, 7 | setCode 8 | }) => { 9 | return ( 10 |
11 |

Unverified Account

12 | {Output && ( 13 |
19 | {Output} 20 |
21 | )} 22 |

23 | Please verify your account as soon as possible, check your email for 24 | further information. Alternatively, if you know the Verification Code, 25 | please enter here. 26 |

27 |
31 | { 38 | setCode(e.target.value); 39 | }} 40 | /> 41 | 42 | 43 |
44 | ); 45 | }; 46 | 47 | export default VerifyUserSection; 48 | -------------------------------------------------------------------------------- /client/src/components/Home/Login.js: -------------------------------------------------------------------------------- 1 | import FormGroup from "../Bootstrap/FormGroup"; 2 | 3 | const Login = ({ 4 | Card, 5 | Forms, 6 | Errors, 7 | Successes, 8 | handleFormChange, 9 | handleFormSubmit 10 | }) => { 11 | const OnChangeDummy = () => {}; 12 | const handleChange = e => { 13 | handleFormChange("Login", e.target.name, e.target.value); 14 | }; 15 | return ( 16 |
17 | 21 | {Successes.length > 0 && ( 22 |
{Successes}
23 | )} 24 | {Errors.length > 0 && ( 25 |
{Errors}
26 | )} 27 |
28 | {Object.keys(Forms).map(fg => ( 29 | 37 | ))} 38 | 50 | 51 |
52 |
53 | ); 54 | }; 55 | 56 | export default Login; 57 | -------------------------------------------------------------------------------- /client/src/components/Home/Register.js: -------------------------------------------------------------------------------- 1 | import FormGroup from "../Bootstrap/FormGroup"; 2 | 3 | const Register = ({ 4 | Card, 5 | Forms, 6 | Errors, 7 | Successes, 8 | handleFormChange, 9 | handleFormSubmit 10 | }) => { 11 | const OnChangeDummy = () => {}; 12 | const FormElements = { ...Forms }; 13 | delete FormElements.Role; 14 | const handleChange = e => { 15 | handleFormChange( 16 | "Register", 17 | e.target.name.replace("Reg", ""), 18 | e.target.value 19 | ); 20 | }; 21 | return ( 22 |
23 | 27 | {Successes.length > 0 && ( 28 |
{Successes}
29 | )} 30 | {Errors.length > 0 && ( 31 |
{Errors}
32 | )} 33 |
34 | {Object.keys(FormElements).map(fg => ( 35 | -1 ? "password" : "text"} 38 | key={fg} 39 | Label={fg} 40 | Value={Forms[fg]} 41 | onChange={OnChangeDummy} 42 | /> 43 | ))} 44 |
45 | 46 | 57 |
58 | 73 | 74 |
75 |
76 | ); 77 | }; 78 | 79 | export default Register; 80 | -------------------------------------------------------------------------------- /client/src/components/Profile/Profile.js: -------------------------------------------------------------------------------- 1 | import React, { useEffect, useState } from "react"; 2 | import { Link } from "react-router-dom"; 3 | import { GetUser } from "../../services/Users"; 4 | import DefaultAvatar from "../../assets/DefaultAvatar.png"; 5 | 6 | const Profile = ({ Card, match }) => { 7 | const [User, setUser] = useState(null); 8 | const Username = match.params.Username; 9 | useEffect(() => { 10 | if (Username) { 11 | GetUser(Username).then(res => { 12 | setUser(res.data); 13 | }); 14 | } 15 | }, [Username]); 16 | let UserRows; 17 | if (User) { 18 | UserRows = [ 19 | { 20 | Name: "Full Name", 21 | Value: User.Name 22 | }, 23 | { 24 | Name: "Role", 25 | Value: User.Role 26 | }, 27 | { 28 | Name: "Verification Status", 29 | Value: User.VerifyHash ? "Not Verified" : "Verified" 30 | }, 31 | { 32 | Name: "Member From", 33 | Value: 34 | new Date(User.CreatedAt).toDateString() + 35 | " at " + 36 | new Date(User.CreatedAt).toLocaleTimeString().substr(0, 5) 37 | } 38 | ]; 39 | if (User.Institute) { 40 | UserRows.push({ 41 | Name: "Phone Number", 42 | Value: User.Institute 43 | }); 44 | } 45 | if (User.Personal.Gender) { 46 | UserRows.push({ 47 | Name: "Gender", 48 | Value: User.Personal.Gender 49 | }); 50 | } 51 | if (User.Personal.Phone) { 52 | UserRows.push({ 53 | Name: "Phone Number", 54 | Value: User.Personal.Phone 55 | }); 56 | } 57 | if (User.Personal.Location) { 58 | UserRows.push({ 59 | Name: "Phone Number", 60 | Value: User.Personal.Location 61 | }); 62 | } 63 | } 64 | return ( 65 |
66 | {User ? ( 67 | <> 68 | 69 |
70 |
71 |
72 |
73 | {User.Name} 78 |
79 |
80 |
81 |
82 | {UserRows.map((row, key) => ( 83 |
84 | {row.Name} 85 |
86 |
{row.Value}
87 |
88 |
89 | ))} 90 |
91 |
92 |
93 |
94 |
95 | {Object.keys(User.Socials).filter(social => User.Socials[social]) 96 | .length > 0 && ( 97 | 98 |
99 |
100 | {Object.keys(User.Socials) 101 | .filter(social => User.Socials[social]) 102 | .map(social => ( 103 | 108 | {social} 109 | 110 | ))} 111 |
112 |
113 |
114 | )} 115 | 116 | ) : ( 117 |
118 |

Loading...

119 | Loading... 120 |
121 | )} 122 | 123 | Back to Dashboard 124 | 125 |
126 | ); 127 | }; 128 | 129 | export default Profile; 130 | -------------------------------------------------------------------------------- /client/src/index.js: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import ReactDOM from "react-dom"; 3 | import { BrowserRouter as Router } from "react-router-dom"; 4 | import App from "./components/App"; 5 | import reportWebVitals from "./reportWebVitals"; 6 | 7 | import "./styles/index.scss"; 8 | 9 | ReactDOM.render( 10 | 11 | 12 | 13 | 14 | , 15 | document.getElementById("root") 16 | ); 17 | 18 | // If you want to start measuring performance in your app, pass a function 19 | // to log results (for example: reportWebVitals(console.log)) 20 | // or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals 21 | reportWebVitals(); 22 | -------------------------------------------------------------------------------- /client/src/reportWebVitals.js: -------------------------------------------------------------------------------- 1 | const reportWebVitals = onPerfEntry => { 2 | if (onPerfEntry && onPerfEntry instanceof Function) { 3 | import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => { 4 | getCLS(onPerfEntry); 5 | getFID(onPerfEntry); 6 | getFCP(onPerfEntry); 7 | getLCP(onPerfEntry); 8 | getTTFB(onPerfEntry); 9 | }); 10 | } 11 | }; 12 | 13 | export default reportWebVitals; 14 | -------------------------------------------------------------------------------- /client/src/services/Auth.js: -------------------------------------------------------------------------------- 1 | import Axios from "axios"; 2 | 3 | export const LoginUser = (Username, Password) => 4 | Axios.post("/api/auth/login", { Username, Password }); 5 | 6 | export const RegisterUser = (Username, Password, Name, Email, Role) => 7 | Axios.post("/api/auth/register", { Username, Password, Name, Email, Role }); 8 | 9 | export const LogoutUser = () => Axios.post("/api/auth/logout"); 10 | 11 | export const VerifyUser = (Username, Code) => 12 | Axios.get(`/api/auth/verify/${Username}?Code=${Code}`); 13 | -------------------------------------------------------------------------------- /client/src/services/Users.js: -------------------------------------------------------------------------------- 1 | import Axios from "axios"; 2 | 3 | export const GetUser = Username => Axios.get("/api/users/" + Username); 4 | -------------------------------------------------------------------------------- /client/src/setupTests.js: -------------------------------------------------------------------------------- 1 | // jest-dom adds custom jest matchers for asserting on DOM nodes. 2 | // allows you to do things like: 3 | // expect(element).toHaveTextContent(/react/i) 4 | // learn more: https://github.com/testing-library/jest-dom 5 | import '@testing-library/jest-dom'; 6 | -------------------------------------------------------------------------------- /client/src/styles/App.scss: -------------------------------------------------------------------------------- 1 | .App { 2 | @import "Bootstrap/Header"; 3 | @import "Profile"; 4 | @import "ProfileCompleteness"; 5 | } 6 | -------------------------------------------------------------------------------- /client/src/styles/Bootstrap/Header.scss: -------------------------------------------------------------------------------- 1 | .Header { 2 | margin-bottom: 15px; 3 | .navbar-brand { 4 | font-size: 2em; 5 | font-weight: normal; 6 | letter-spacing: normal; 7 | } 8 | } 9 | -------------------------------------------------------------------------------- /client/src/styles/Profile.scss: -------------------------------------------------------------------------------- 1 | .Profile { 2 | &-Role { 3 | position: relative; 4 | top: -3px; 5 | margin-left: 5px; 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /client/src/styles/ProfileCompleteness.scss: -------------------------------------------------------------------------------- 1 | .ProfileCompleteness { 2 | &Wrapper { 3 | @media screen and (max-width: 768px) { 4 | order: -1; 5 | margin-bottom: 15px; 6 | } 7 | } 8 | } 9 | -------------------------------------------------------------------------------- /client/src/styles/index.scss: -------------------------------------------------------------------------------- 1 | body { 2 | font-family: "Gemunu Libre", sans-serif; 3 | pre { 4 | font-family: monospace; 5 | font-weight: normal; 6 | font-size: 1.2em; 7 | } 8 | @import "App"; 9 | } 10 | -------------------------------------------------------------------------------- /client/src/tests/App.test.js: -------------------------------------------------------------------------------- 1 | import { render, screen } from "@testing-library/react"; 2 | import App from "../components/App"; 3 | 4 | test("renders the app page", () => { 5 | render(); 6 | const linkElement = screen.getByText(/community classroom/i); 7 | expect(linkElement).toBeInTheDocument(); 8 | }); 9 | -------------------------------------------------------------------------------- /server/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ -------------------------------------------------------------------------------- /server/constants/Users.json: -------------------------------------------------------------------------------- 1 | {"praveen":{"Name":"Praveen Kumar Purushothaman","Password":"473482ea0ca7d2837f2efea004cbc762","Role":"Mentor","Avatar":"https://www.gravatar.com/avatar/f0285ad1973e938e2d2f40254c247f6f?s=512","VerifyHash":"a994856e6625bd2e1ceff105d3ac5c25","Institute":null,"Personal":{"Gender":null,"Email":"praveenscience@gmail.com","Phone":null,"Location":null},"Socials":{"Facebook":null,"Instagram":null,"Twitter":null,"LinkedIn":null,"GitHub":null,"StackOverflow":null,"WhatsApp":null,"Telegram":null,"Discord":null},"CreatedAt":"2021-10-07T16:12:46.726Z"}} -------------------------------------------------------------------------------- /server/constants/salt.json: -------------------------------------------------------------------------------- 1 | "c0mmun!7y Cl@ssr00m" 2 | -------------------------------------------------------------------------------- /server/helpers/Users.js: -------------------------------------------------------------------------------- 1 | const fs = require("fs"); 2 | const md5 = require("md5"); 3 | const Salt = require("../constants/salt.json"); 4 | // Temporary Users Data. 5 | const ReadUsers = () => fs.readFileSync(__dirname + "/../constants/Users.json"); 6 | 7 | // Create a hashing function. 8 | const HashPwd = Password => md5(Salt + Password); 9 | 10 | const CheckUserNamePassword = (Username, Password) => { 11 | // Load the users from file. 12 | const Users = JSON.parse(ReadUsers().toString()); 13 | // Convert all the usernames into lowercase. 14 | Username = Username.toLowerCase(); 15 | // Hash the password with the salt. 16 | Password = HashPwd(Password); 17 | // Check if the user exists or not. 18 | if (typeof Users[Username] !== "undefined") { 19 | // User exists. 20 | // Check if password is right or wrong. 21 | if (Users[Username].Password === Password) { 22 | // Correct Username and Password. 23 | // Remove the password and send the user object. 24 | const User = { ...Users[Username] }; 25 | delete User.Password; 26 | if (User.VerifyHash) { 27 | User.VerifyHash = true; 28 | } 29 | return { ...User, Username }; 30 | } else { 31 | // Wrong Username and Password. 32 | return -1; 33 | } 34 | } else { 35 | // User does not exist. 36 | return 0; 37 | } 38 | }; 39 | 40 | const RegisterNewUser = (Username, Password, Name, Email, Role) => { 41 | // Load the users from file. 42 | const Users = JSON.parse(ReadUsers().toString()); 43 | // Convert all the usernames into lowercase. 44 | Username = Username.toLowerCase(); 45 | // Hash the password with the salt. 46 | Password = HashPwd(Password); 47 | // Create a Default user template. 48 | const NewUser = { 49 | Name, 50 | Password, 51 | Role, 52 | Avatar: `https://www.gravatar.com/avatar/${md5(Email)}?s=512`, 53 | VerifyHash: HashPwd(new Date().getTime()), 54 | Institute: null, 55 | Personal: { 56 | Gender: null, 57 | Email, 58 | Phone: null, 59 | Location: null 60 | }, 61 | Socials: { 62 | Facebook: null, 63 | Instagram: null, 64 | Twitter: null, 65 | LinkedIn: null, 66 | GitHub: null, 67 | StackOverflow: null, 68 | WhatsApp: null, 69 | Telegram: null, 70 | Discord: null 71 | }, 72 | CreatedAt: new Date() 73 | }; 74 | // Check if the user exists or not. 75 | if (typeof Users[Username] === "undefined") { 76 | // User doesn't exist. 77 | // Add the new user to the data. 78 | Users[Username] = NewUser; 79 | // Once changing something in the Users object, make it permanent. 80 | fs.writeFileSync( 81 | __dirname + "/../constants/Users.json", 82 | JSON.stringify(Users) 83 | ); 84 | return true; 85 | } else { 86 | // User already exists. 87 | return false; 88 | } 89 | }; 90 | 91 | const ListAllUsers = () => JSON.parse(ReadUsers().toString()); 92 | 93 | // 1 => Success. 94 | // 0 => User found, but code wrong or already verified. 95 | // -1 => User not found. 96 | const VerifyUser = (Username, Code) => { 97 | // Load the users from file. 98 | const Users = JSON.parse(ReadUsers().toString()); 99 | // Check if the user exists or not. 100 | if (typeof Users[Username] !== "undefined") { 101 | if (Users[Username].VerifyHash === Code) { 102 | // Delete the verification hash. 103 | Users[Username].VerifyHash = null; 104 | // Once changing something in the Users object, make it permanent. 105 | fs.writeFileSync( 106 | __dirname + "/../constants/Users.json", 107 | JSON.stringify(Users) 108 | ); 109 | return 1; 110 | } else { 111 | return 0; 112 | } 113 | } else { 114 | return -1; 115 | } 116 | }; 117 | 118 | module.exports = { 119 | CheckUserNamePassword, 120 | RegisterNewUser, 121 | ListAllUsers, 122 | VerifyUser 123 | }; 124 | -------------------------------------------------------------------------------- /server/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "1.0.0", 9 | "license": "ISC", 10 | "dependencies": { 11 | "express": "^4.17.1", 12 | "express-session": "^1.17.2", 13 | "md5": "^2.3.0", 14 | "morgan": "^1.10.0", 15 | "nodemon": "^2.0.12" 16 | } 17 | }, 18 | "node_modules/@sindresorhus/is": { 19 | "version": "0.14.0", 20 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 21 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==", 22 | "engines": { 23 | "node": ">=6" 24 | } 25 | }, 26 | "node_modules/@szmarczak/http-timer": { 27 | "version": "1.1.2", 28 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 29 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 30 | "dependencies": { 31 | "defer-to-connect": "^1.0.1" 32 | }, 33 | "engines": { 34 | "node": ">=6" 35 | } 36 | }, 37 | "node_modules/abbrev": { 38 | "version": "1.1.1", 39 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 40 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 41 | }, 42 | "node_modules/accepts": { 43 | "version": "1.3.7", 44 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 45 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 46 | "dependencies": { 47 | "mime-types": "~2.1.24", 48 | "negotiator": "0.6.2" 49 | }, 50 | "engines": { 51 | "node": ">= 0.6" 52 | } 53 | }, 54 | "node_modules/ansi-align": { 55 | "version": "3.0.0", 56 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.0.tgz", 57 | "integrity": "sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw==", 58 | "dependencies": { 59 | "string-width": "^3.0.0" 60 | } 61 | }, 62 | "node_modules/ansi-align/node_modules/ansi-regex": { 63 | "version": "4.1.0", 64 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 65 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 66 | "engines": { 67 | "node": ">=6" 68 | } 69 | }, 70 | "node_modules/ansi-align/node_modules/emoji-regex": { 71 | "version": "7.0.3", 72 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 73 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 74 | }, 75 | "node_modules/ansi-align/node_modules/is-fullwidth-code-point": { 76 | "version": "2.0.0", 77 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 78 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 79 | "engines": { 80 | "node": ">=4" 81 | } 82 | }, 83 | "node_modules/ansi-align/node_modules/string-width": { 84 | "version": "3.1.0", 85 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 86 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 87 | "dependencies": { 88 | "emoji-regex": "^7.0.1", 89 | "is-fullwidth-code-point": "^2.0.0", 90 | "strip-ansi": "^5.1.0" 91 | }, 92 | "engines": { 93 | "node": ">=6" 94 | } 95 | }, 96 | "node_modules/ansi-align/node_modules/strip-ansi": { 97 | "version": "5.2.0", 98 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 99 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 100 | "dependencies": { 101 | "ansi-regex": "^4.1.0" 102 | }, 103 | "engines": { 104 | "node": ">=6" 105 | } 106 | }, 107 | "node_modules/ansi-regex": { 108 | "version": "5.0.1", 109 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 110 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 111 | "engines": { 112 | "node": ">=8" 113 | } 114 | }, 115 | "node_modules/ansi-styles": { 116 | "version": "4.3.0", 117 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 118 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 119 | "dependencies": { 120 | "color-convert": "^2.0.1" 121 | }, 122 | "engines": { 123 | "node": ">=8" 124 | }, 125 | "funding": { 126 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 127 | } 128 | }, 129 | "node_modules/anymatch": { 130 | "version": "3.1.2", 131 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 132 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 133 | "dependencies": { 134 | "normalize-path": "^3.0.0", 135 | "picomatch": "^2.0.4" 136 | }, 137 | "engines": { 138 | "node": ">= 8" 139 | } 140 | }, 141 | "node_modules/array-flatten": { 142 | "version": "1.1.1", 143 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 144 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 145 | }, 146 | "node_modules/balanced-match": { 147 | "version": "1.0.2", 148 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 149 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 150 | }, 151 | "node_modules/basic-auth": { 152 | "version": "2.0.1", 153 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 154 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 155 | "dependencies": { 156 | "safe-buffer": "5.1.2" 157 | }, 158 | "engines": { 159 | "node": ">= 0.8" 160 | } 161 | }, 162 | "node_modules/binary-extensions": { 163 | "version": "2.2.0", 164 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 165 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 166 | "engines": { 167 | "node": ">=8" 168 | } 169 | }, 170 | "node_modules/body-parser": { 171 | "version": "1.19.0", 172 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 173 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 174 | "dependencies": { 175 | "bytes": "3.1.0", 176 | "content-type": "~1.0.4", 177 | "debug": "2.6.9", 178 | "depd": "~1.1.2", 179 | "http-errors": "1.7.2", 180 | "iconv-lite": "0.4.24", 181 | "on-finished": "~2.3.0", 182 | "qs": "6.7.0", 183 | "raw-body": "2.4.0", 184 | "type-is": "~1.6.17" 185 | }, 186 | "engines": { 187 | "node": ">= 0.8" 188 | } 189 | }, 190 | "node_modules/boxen": { 191 | "version": "4.2.0", 192 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz", 193 | "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==", 194 | "dependencies": { 195 | "ansi-align": "^3.0.0", 196 | "camelcase": "^5.3.1", 197 | "chalk": "^3.0.0", 198 | "cli-boxes": "^2.2.0", 199 | "string-width": "^4.1.0", 200 | "term-size": "^2.1.0", 201 | "type-fest": "^0.8.1", 202 | "widest-line": "^3.1.0" 203 | }, 204 | "engines": { 205 | "node": ">=8" 206 | }, 207 | "funding": { 208 | "url": "https://github.com/sponsors/sindresorhus" 209 | } 210 | }, 211 | "node_modules/brace-expansion": { 212 | "version": "1.1.11", 213 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 214 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 215 | "dependencies": { 216 | "balanced-match": "^1.0.0", 217 | "concat-map": "0.0.1" 218 | } 219 | }, 220 | "node_modules/braces": { 221 | "version": "3.0.2", 222 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 223 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 224 | "dependencies": { 225 | "fill-range": "^7.0.1" 226 | }, 227 | "engines": { 228 | "node": ">=8" 229 | } 230 | }, 231 | "node_modules/bytes": { 232 | "version": "3.1.0", 233 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 234 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 235 | "engines": { 236 | "node": ">= 0.8" 237 | } 238 | }, 239 | "node_modules/cacheable-request": { 240 | "version": "6.1.0", 241 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 242 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 243 | "dependencies": { 244 | "clone-response": "^1.0.2", 245 | "get-stream": "^5.1.0", 246 | "http-cache-semantics": "^4.0.0", 247 | "keyv": "^3.0.0", 248 | "lowercase-keys": "^2.0.0", 249 | "normalize-url": "^4.1.0", 250 | "responselike": "^1.0.2" 251 | }, 252 | "engines": { 253 | "node": ">=8" 254 | } 255 | }, 256 | "node_modules/cacheable-request/node_modules/get-stream": { 257 | "version": "5.2.0", 258 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 259 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 260 | "dependencies": { 261 | "pump": "^3.0.0" 262 | }, 263 | "engines": { 264 | "node": ">=8" 265 | }, 266 | "funding": { 267 | "url": "https://github.com/sponsors/sindresorhus" 268 | } 269 | }, 270 | "node_modules/cacheable-request/node_modules/lowercase-keys": { 271 | "version": "2.0.0", 272 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 273 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", 274 | "engines": { 275 | "node": ">=8" 276 | } 277 | }, 278 | "node_modules/camelcase": { 279 | "version": "5.3.1", 280 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 281 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 282 | "engines": { 283 | "node": ">=6" 284 | } 285 | }, 286 | "node_modules/chalk": { 287 | "version": "3.0.0", 288 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 289 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 290 | "dependencies": { 291 | "ansi-styles": "^4.1.0", 292 | "supports-color": "^7.1.0" 293 | }, 294 | "engines": { 295 | "node": ">=8" 296 | } 297 | }, 298 | "node_modules/chalk/node_modules/has-flag": { 299 | "version": "4.0.0", 300 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 301 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 302 | "engines": { 303 | "node": ">=8" 304 | } 305 | }, 306 | "node_modules/chalk/node_modules/supports-color": { 307 | "version": "7.2.0", 308 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 309 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 310 | "dependencies": { 311 | "has-flag": "^4.0.0" 312 | }, 313 | "engines": { 314 | "node": ">=8" 315 | } 316 | }, 317 | "node_modules/charenc": { 318 | "version": "0.0.2", 319 | "resolved": "https://registry.npmjs.org/charenc/-/charenc-0.0.2.tgz", 320 | "integrity": "sha1-wKHS86cJLgN3S/qD8UwPxXkKhmc=", 321 | "engines": { 322 | "node": "*" 323 | } 324 | }, 325 | "node_modules/chokidar": { 326 | "version": "3.5.2", 327 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 328 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 329 | "dependencies": { 330 | "anymatch": "~3.1.2", 331 | "braces": "~3.0.2", 332 | "glob-parent": "~5.1.2", 333 | "is-binary-path": "~2.1.0", 334 | "is-glob": "~4.0.1", 335 | "normalize-path": "~3.0.0", 336 | "readdirp": "~3.6.0" 337 | }, 338 | "engines": { 339 | "node": ">= 8.10.0" 340 | }, 341 | "optionalDependencies": { 342 | "fsevents": "~2.3.2" 343 | } 344 | }, 345 | "node_modules/ci-info": { 346 | "version": "2.0.0", 347 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 348 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" 349 | }, 350 | "node_modules/cli-boxes": { 351 | "version": "2.2.1", 352 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", 353 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==", 354 | "engines": { 355 | "node": ">=6" 356 | }, 357 | "funding": { 358 | "url": "https://github.com/sponsors/sindresorhus" 359 | } 360 | }, 361 | "node_modules/clone-response": { 362 | "version": "1.0.2", 363 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 364 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 365 | "dependencies": { 366 | "mimic-response": "^1.0.0" 367 | } 368 | }, 369 | "node_modules/color-convert": { 370 | "version": "2.0.1", 371 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 372 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 373 | "dependencies": { 374 | "color-name": "~1.1.4" 375 | }, 376 | "engines": { 377 | "node": ">=7.0.0" 378 | } 379 | }, 380 | "node_modules/color-name": { 381 | "version": "1.1.4", 382 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 383 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 384 | }, 385 | "node_modules/concat-map": { 386 | "version": "0.0.1", 387 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 388 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 389 | }, 390 | "node_modules/configstore": { 391 | "version": "5.0.1", 392 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 393 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 394 | "dependencies": { 395 | "dot-prop": "^5.2.0", 396 | "graceful-fs": "^4.1.2", 397 | "make-dir": "^3.0.0", 398 | "unique-string": "^2.0.0", 399 | "write-file-atomic": "^3.0.0", 400 | "xdg-basedir": "^4.0.0" 401 | }, 402 | "engines": { 403 | "node": ">=8" 404 | } 405 | }, 406 | "node_modules/content-disposition": { 407 | "version": "0.5.3", 408 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 409 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 410 | "dependencies": { 411 | "safe-buffer": "5.1.2" 412 | }, 413 | "engines": { 414 | "node": ">= 0.6" 415 | } 416 | }, 417 | "node_modules/content-type": { 418 | "version": "1.0.4", 419 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 420 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 421 | "engines": { 422 | "node": ">= 0.6" 423 | } 424 | }, 425 | "node_modules/cookie": { 426 | "version": "0.4.0", 427 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 428 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==", 429 | "engines": { 430 | "node": ">= 0.6" 431 | } 432 | }, 433 | "node_modules/cookie-signature": { 434 | "version": "1.0.6", 435 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 436 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 437 | }, 438 | "node_modules/crypt": { 439 | "version": "0.0.2", 440 | "resolved": "https://registry.npmjs.org/crypt/-/crypt-0.0.2.tgz", 441 | "integrity": "sha1-iNf/fsDfuG9xPch7u0LQRNPmxBs=", 442 | "engines": { 443 | "node": "*" 444 | } 445 | }, 446 | "node_modules/crypto-random-string": { 447 | "version": "2.0.0", 448 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 449 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 450 | "engines": { 451 | "node": ">=8" 452 | } 453 | }, 454 | "node_modules/debug": { 455 | "version": "2.6.9", 456 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 457 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 458 | "dependencies": { 459 | "ms": "2.0.0" 460 | } 461 | }, 462 | "node_modules/decompress-response": { 463 | "version": "3.3.0", 464 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 465 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 466 | "dependencies": { 467 | "mimic-response": "^1.0.0" 468 | }, 469 | "engines": { 470 | "node": ">=4" 471 | } 472 | }, 473 | "node_modules/deep-extend": { 474 | "version": "0.6.0", 475 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 476 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 477 | "engines": { 478 | "node": ">=4.0.0" 479 | } 480 | }, 481 | "node_modules/defer-to-connect": { 482 | "version": "1.1.3", 483 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 484 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==" 485 | }, 486 | "node_modules/depd": { 487 | "version": "1.1.2", 488 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 489 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 490 | "engines": { 491 | "node": ">= 0.6" 492 | } 493 | }, 494 | "node_modules/destroy": { 495 | "version": "1.0.4", 496 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 497 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 498 | }, 499 | "node_modules/dot-prop": { 500 | "version": "5.3.0", 501 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 502 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 503 | "dependencies": { 504 | "is-obj": "^2.0.0" 505 | }, 506 | "engines": { 507 | "node": ">=8" 508 | } 509 | }, 510 | "node_modules/duplexer3": { 511 | "version": "0.1.4", 512 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 513 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=" 514 | }, 515 | "node_modules/ee-first": { 516 | "version": "1.1.1", 517 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 518 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 519 | }, 520 | "node_modules/emoji-regex": { 521 | "version": "8.0.0", 522 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 523 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 524 | }, 525 | "node_modules/encodeurl": { 526 | "version": "1.0.2", 527 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 528 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 529 | "engines": { 530 | "node": ">= 0.8" 531 | } 532 | }, 533 | "node_modules/end-of-stream": { 534 | "version": "1.4.4", 535 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 536 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 537 | "dependencies": { 538 | "once": "^1.4.0" 539 | } 540 | }, 541 | "node_modules/escape-goat": { 542 | "version": "2.1.1", 543 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 544 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==", 545 | "engines": { 546 | "node": ">=8" 547 | } 548 | }, 549 | "node_modules/escape-html": { 550 | "version": "1.0.3", 551 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 552 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 553 | }, 554 | "node_modules/etag": { 555 | "version": "1.8.1", 556 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 557 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 558 | "engines": { 559 | "node": ">= 0.6" 560 | } 561 | }, 562 | "node_modules/express": { 563 | "version": "4.17.1", 564 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 565 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 566 | "dependencies": { 567 | "accepts": "~1.3.7", 568 | "array-flatten": "1.1.1", 569 | "body-parser": "1.19.0", 570 | "content-disposition": "0.5.3", 571 | "content-type": "~1.0.4", 572 | "cookie": "0.4.0", 573 | "cookie-signature": "1.0.6", 574 | "debug": "2.6.9", 575 | "depd": "~1.1.2", 576 | "encodeurl": "~1.0.2", 577 | "escape-html": "~1.0.3", 578 | "etag": "~1.8.1", 579 | "finalhandler": "~1.1.2", 580 | "fresh": "0.5.2", 581 | "merge-descriptors": "1.0.1", 582 | "methods": "~1.1.2", 583 | "on-finished": "~2.3.0", 584 | "parseurl": "~1.3.3", 585 | "path-to-regexp": "0.1.7", 586 | "proxy-addr": "~2.0.5", 587 | "qs": "6.7.0", 588 | "range-parser": "~1.2.1", 589 | "safe-buffer": "5.1.2", 590 | "send": "0.17.1", 591 | "serve-static": "1.14.1", 592 | "setprototypeof": "1.1.1", 593 | "statuses": "~1.5.0", 594 | "type-is": "~1.6.18", 595 | "utils-merge": "1.0.1", 596 | "vary": "~1.1.2" 597 | }, 598 | "engines": { 599 | "node": ">= 0.10.0" 600 | } 601 | }, 602 | "node_modules/express-session": { 603 | "version": "1.17.2", 604 | "resolved": "https://registry.npmjs.org/express-session/-/express-session-1.17.2.tgz", 605 | "integrity": "sha512-mPcYcLA0lvh7D4Oqr5aNJFMtBMKPLl++OKKxkHzZ0U0oDq1rpKBnkR5f5vCHR26VeArlTOEF9td4x5IjICksRQ==", 606 | "dependencies": { 607 | "cookie": "0.4.1", 608 | "cookie-signature": "1.0.6", 609 | "debug": "2.6.9", 610 | "depd": "~2.0.0", 611 | "on-headers": "~1.0.2", 612 | "parseurl": "~1.3.3", 613 | "safe-buffer": "5.2.1", 614 | "uid-safe": "~2.1.5" 615 | }, 616 | "engines": { 617 | "node": ">= 0.8.0" 618 | } 619 | }, 620 | "node_modules/express-session/node_modules/cookie": { 621 | "version": "0.4.1", 622 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 623 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==", 624 | "engines": { 625 | "node": ">= 0.6" 626 | } 627 | }, 628 | "node_modules/express-session/node_modules/depd": { 629 | "version": "2.0.0", 630 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 631 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 632 | "engines": { 633 | "node": ">= 0.8" 634 | } 635 | }, 636 | "node_modules/express-session/node_modules/safe-buffer": { 637 | "version": "5.2.1", 638 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 639 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 640 | "funding": [ 641 | { 642 | "type": "github", 643 | "url": "https://github.com/sponsors/feross" 644 | }, 645 | { 646 | "type": "patreon", 647 | "url": "https://www.patreon.com/feross" 648 | }, 649 | { 650 | "type": "consulting", 651 | "url": "https://feross.org/support" 652 | } 653 | ] 654 | }, 655 | "node_modules/fill-range": { 656 | "version": "7.0.1", 657 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 658 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 659 | "dependencies": { 660 | "to-regex-range": "^5.0.1" 661 | }, 662 | "engines": { 663 | "node": ">=8" 664 | } 665 | }, 666 | "node_modules/finalhandler": { 667 | "version": "1.1.2", 668 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 669 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 670 | "dependencies": { 671 | "debug": "2.6.9", 672 | "encodeurl": "~1.0.2", 673 | "escape-html": "~1.0.3", 674 | "on-finished": "~2.3.0", 675 | "parseurl": "~1.3.3", 676 | "statuses": "~1.5.0", 677 | "unpipe": "~1.0.0" 678 | }, 679 | "engines": { 680 | "node": ">= 0.8" 681 | } 682 | }, 683 | "node_modules/forwarded": { 684 | "version": "0.2.0", 685 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 686 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 687 | "engines": { 688 | "node": ">= 0.6" 689 | } 690 | }, 691 | "node_modules/fresh": { 692 | "version": "0.5.2", 693 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 694 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 695 | "engines": { 696 | "node": ">= 0.6" 697 | } 698 | }, 699 | "node_modules/fsevents": { 700 | "version": "2.3.2", 701 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 702 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 703 | "hasInstallScript": true, 704 | "optional": true, 705 | "os": [ 706 | "darwin" 707 | ], 708 | "engines": { 709 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 710 | } 711 | }, 712 | "node_modules/get-stream": { 713 | "version": "4.1.0", 714 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 715 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 716 | "dependencies": { 717 | "pump": "^3.0.0" 718 | }, 719 | "engines": { 720 | "node": ">=6" 721 | } 722 | }, 723 | "node_modules/glob-parent": { 724 | "version": "5.1.2", 725 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 726 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 727 | "dependencies": { 728 | "is-glob": "^4.0.1" 729 | }, 730 | "engines": { 731 | "node": ">= 6" 732 | } 733 | }, 734 | "node_modules/global-dirs": { 735 | "version": "2.1.0", 736 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.1.0.tgz", 737 | "integrity": "sha512-MG6kdOUh/xBnyo9cJFeIKkLEc1AyFq42QTU4XiX51i2NEdxLxLWXIjEjmqKeSuKR7pAZjTqUVoT2b2huxVLgYQ==", 738 | "dependencies": { 739 | "ini": "1.3.7" 740 | }, 741 | "engines": { 742 | "node": ">=8" 743 | }, 744 | "funding": { 745 | "url": "https://github.com/sponsors/sindresorhus" 746 | } 747 | }, 748 | "node_modules/got": { 749 | "version": "9.6.0", 750 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 751 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 752 | "dependencies": { 753 | "@sindresorhus/is": "^0.14.0", 754 | "@szmarczak/http-timer": "^1.1.2", 755 | "cacheable-request": "^6.0.0", 756 | "decompress-response": "^3.3.0", 757 | "duplexer3": "^0.1.4", 758 | "get-stream": "^4.1.0", 759 | "lowercase-keys": "^1.0.1", 760 | "mimic-response": "^1.0.1", 761 | "p-cancelable": "^1.0.0", 762 | "to-readable-stream": "^1.0.0", 763 | "url-parse-lax": "^3.0.0" 764 | }, 765 | "engines": { 766 | "node": ">=8.6" 767 | } 768 | }, 769 | "node_modules/graceful-fs": { 770 | "version": "4.2.8", 771 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 772 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==" 773 | }, 774 | "node_modules/has-flag": { 775 | "version": "3.0.0", 776 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 777 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 778 | "engines": { 779 | "node": ">=4" 780 | } 781 | }, 782 | "node_modules/has-yarn": { 783 | "version": "2.1.0", 784 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 785 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==", 786 | "engines": { 787 | "node": ">=8" 788 | } 789 | }, 790 | "node_modules/http-cache-semantics": { 791 | "version": "4.1.0", 792 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 793 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==" 794 | }, 795 | "node_modules/http-errors": { 796 | "version": "1.7.2", 797 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 798 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 799 | "dependencies": { 800 | "depd": "~1.1.2", 801 | "inherits": "2.0.3", 802 | "setprototypeof": "1.1.1", 803 | "statuses": ">= 1.5.0 < 2", 804 | "toidentifier": "1.0.0" 805 | }, 806 | "engines": { 807 | "node": ">= 0.6" 808 | } 809 | }, 810 | "node_modules/iconv-lite": { 811 | "version": "0.4.24", 812 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 813 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 814 | "dependencies": { 815 | "safer-buffer": ">= 2.1.2 < 3" 816 | }, 817 | "engines": { 818 | "node": ">=0.10.0" 819 | } 820 | }, 821 | "node_modules/ignore-by-default": { 822 | "version": "1.0.1", 823 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 824 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=" 825 | }, 826 | "node_modules/import-lazy": { 827 | "version": "2.1.0", 828 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 829 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 830 | "engines": { 831 | "node": ">=4" 832 | } 833 | }, 834 | "node_modules/imurmurhash": { 835 | "version": "0.1.4", 836 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 837 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 838 | "engines": { 839 | "node": ">=0.8.19" 840 | } 841 | }, 842 | "node_modules/inherits": { 843 | "version": "2.0.3", 844 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 845 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 846 | }, 847 | "node_modules/ini": { 848 | "version": "1.3.7", 849 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.7.tgz", 850 | "integrity": "sha512-iKpRpXP+CrP2jyrxvg1kMUpXDyRUFDWurxbnVT1vQPx+Wz9uCYsMIqYuSBLV+PAaZG/d7kRLKRFc9oDMsH+mFQ==" 851 | }, 852 | "node_modules/ipaddr.js": { 853 | "version": "1.9.1", 854 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 855 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 856 | "engines": { 857 | "node": ">= 0.10" 858 | } 859 | }, 860 | "node_modules/is-binary-path": { 861 | "version": "2.1.0", 862 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 863 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 864 | "dependencies": { 865 | "binary-extensions": "^2.0.0" 866 | }, 867 | "engines": { 868 | "node": ">=8" 869 | } 870 | }, 871 | "node_modules/is-buffer": { 872 | "version": "1.1.6", 873 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 874 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" 875 | }, 876 | "node_modules/is-ci": { 877 | "version": "2.0.0", 878 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 879 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 880 | "dependencies": { 881 | "ci-info": "^2.0.0" 882 | }, 883 | "bin": { 884 | "is-ci": "bin.js" 885 | } 886 | }, 887 | "node_modules/is-extglob": { 888 | "version": "2.1.1", 889 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 890 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 891 | "engines": { 892 | "node": ">=0.10.0" 893 | } 894 | }, 895 | "node_modules/is-fullwidth-code-point": { 896 | "version": "3.0.0", 897 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 898 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 899 | "engines": { 900 | "node": ">=8" 901 | } 902 | }, 903 | "node_modules/is-glob": { 904 | "version": "4.0.1", 905 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 906 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 907 | "dependencies": { 908 | "is-extglob": "^2.1.1" 909 | }, 910 | "engines": { 911 | "node": ">=0.10.0" 912 | } 913 | }, 914 | "node_modules/is-installed-globally": { 915 | "version": "0.3.2", 916 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.2.tgz", 917 | "integrity": "sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g==", 918 | "dependencies": { 919 | "global-dirs": "^2.0.1", 920 | "is-path-inside": "^3.0.1" 921 | }, 922 | "engines": { 923 | "node": ">=8" 924 | }, 925 | "funding": { 926 | "url": "https://github.com/sponsors/sindresorhus" 927 | } 928 | }, 929 | "node_modules/is-npm": { 930 | "version": "4.0.0", 931 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz", 932 | "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==", 933 | "engines": { 934 | "node": ">=8" 935 | } 936 | }, 937 | "node_modules/is-number": { 938 | "version": "7.0.0", 939 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 940 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 941 | "engines": { 942 | "node": ">=0.12.0" 943 | } 944 | }, 945 | "node_modules/is-obj": { 946 | "version": "2.0.0", 947 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 948 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 949 | "engines": { 950 | "node": ">=8" 951 | } 952 | }, 953 | "node_modules/is-path-inside": { 954 | "version": "3.0.3", 955 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 956 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 957 | "engines": { 958 | "node": ">=8" 959 | } 960 | }, 961 | "node_modules/is-typedarray": { 962 | "version": "1.0.0", 963 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 964 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 965 | }, 966 | "node_modules/is-yarn-global": { 967 | "version": "0.3.0", 968 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 969 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==" 970 | }, 971 | "node_modules/json-buffer": { 972 | "version": "3.0.0", 973 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 974 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=" 975 | }, 976 | "node_modules/keyv": { 977 | "version": "3.1.0", 978 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 979 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 980 | "dependencies": { 981 | "json-buffer": "3.0.0" 982 | } 983 | }, 984 | "node_modules/latest-version": { 985 | "version": "5.1.0", 986 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 987 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 988 | "dependencies": { 989 | "package-json": "^6.3.0" 990 | }, 991 | "engines": { 992 | "node": ">=8" 993 | } 994 | }, 995 | "node_modules/lowercase-keys": { 996 | "version": "1.0.1", 997 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 998 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 999 | "engines": { 1000 | "node": ">=0.10.0" 1001 | } 1002 | }, 1003 | "node_modules/make-dir": { 1004 | "version": "3.1.0", 1005 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1006 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1007 | "dependencies": { 1008 | "semver": "^6.0.0" 1009 | }, 1010 | "engines": { 1011 | "node": ">=8" 1012 | }, 1013 | "funding": { 1014 | "url": "https://github.com/sponsors/sindresorhus" 1015 | } 1016 | }, 1017 | "node_modules/make-dir/node_modules/semver": { 1018 | "version": "6.3.0", 1019 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1020 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1021 | "bin": { 1022 | "semver": "bin/semver.js" 1023 | } 1024 | }, 1025 | "node_modules/md5": { 1026 | "version": "2.3.0", 1027 | "resolved": "https://registry.npmjs.org/md5/-/md5-2.3.0.tgz", 1028 | "integrity": "sha512-T1GITYmFaKuO91vxyoQMFETst+O71VUPEU3ze5GNzDm0OWdP8v1ziTaAEPUr/3kLsY3Sftgz242A1SetQiDL7g==", 1029 | "dependencies": { 1030 | "charenc": "0.0.2", 1031 | "crypt": "0.0.2", 1032 | "is-buffer": "~1.1.6" 1033 | } 1034 | }, 1035 | "node_modules/media-typer": { 1036 | "version": "0.3.0", 1037 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1038 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", 1039 | "engines": { 1040 | "node": ">= 0.6" 1041 | } 1042 | }, 1043 | "node_modules/merge-descriptors": { 1044 | "version": "1.0.1", 1045 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1046 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1047 | }, 1048 | "node_modules/methods": { 1049 | "version": "1.1.2", 1050 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1051 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1052 | "engines": { 1053 | "node": ">= 0.6" 1054 | } 1055 | }, 1056 | "node_modules/mime": { 1057 | "version": "1.6.0", 1058 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1059 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1060 | "bin": { 1061 | "mime": "cli.js" 1062 | }, 1063 | "engines": { 1064 | "node": ">=4" 1065 | } 1066 | }, 1067 | "node_modules/mime-db": { 1068 | "version": "1.49.0", 1069 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.49.0.tgz", 1070 | "integrity": "sha512-CIc8j9URtOVApSFCQIF+VBkX1RwXp/oMMOrqdyXSBXq5RWNEsRfyj1kiRnQgmNXmHxPoFIxOroKA3zcU9P+nAA==", 1071 | "engines": { 1072 | "node": ">= 0.6" 1073 | } 1074 | }, 1075 | "node_modules/mime-types": { 1076 | "version": "2.1.32", 1077 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.32.tgz", 1078 | "integrity": "sha512-hJGaVS4G4c9TSMYh2n6SQAGrC4RnfU+daP8G7cSCmaqNjiOoUY0VHCMS42pxnQmVF1GWwFhbHWn3RIxCqTmZ9A==", 1079 | "dependencies": { 1080 | "mime-db": "1.49.0" 1081 | }, 1082 | "engines": { 1083 | "node": ">= 0.6" 1084 | } 1085 | }, 1086 | "node_modules/mimic-response": { 1087 | "version": "1.0.1", 1088 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 1089 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", 1090 | "engines": { 1091 | "node": ">=4" 1092 | } 1093 | }, 1094 | "node_modules/minimatch": { 1095 | "version": "3.0.4", 1096 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1097 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1098 | "dependencies": { 1099 | "brace-expansion": "^1.1.7" 1100 | }, 1101 | "engines": { 1102 | "node": "*" 1103 | } 1104 | }, 1105 | "node_modules/minimist": { 1106 | "version": "1.2.5", 1107 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1108 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1109 | }, 1110 | "node_modules/morgan": { 1111 | "version": "1.10.0", 1112 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz", 1113 | "integrity": "sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==", 1114 | "dependencies": { 1115 | "basic-auth": "~2.0.1", 1116 | "debug": "2.6.9", 1117 | "depd": "~2.0.0", 1118 | "on-finished": "~2.3.0", 1119 | "on-headers": "~1.0.2" 1120 | }, 1121 | "engines": { 1122 | "node": ">= 0.8.0" 1123 | } 1124 | }, 1125 | "node_modules/morgan/node_modules/depd": { 1126 | "version": "2.0.0", 1127 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 1128 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 1129 | "engines": { 1130 | "node": ">= 0.8" 1131 | } 1132 | }, 1133 | "node_modules/ms": { 1134 | "version": "2.0.0", 1135 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1136 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1137 | }, 1138 | "node_modules/negotiator": { 1139 | "version": "0.6.2", 1140 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1141 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", 1142 | "engines": { 1143 | "node": ">= 0.6" 1144 | } 1145 | }, 1146 | "node_modules/nodemon": { 1147 | "version": "2.0.12", 1148 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.12.tgz", 1149 | "integrity": "sha512-egCTmNZdObdBxUBw6ZNwvZ/xzk24CKRs5K6d+5zbmrMr7rOpPmfPeF6OxM3DDpaRx331CQRFEktn+wrFFfBSOA==", 1150 | "hasInstallScript": true, 1151 | "dependencies": { 1152 | "chokidar": "^3.2.2", 1153 | "debug": "^3.2.6", 1154 | "ignore-by-default": "^1.0.1", 1155 | "minimatch": "^3.0.4", 1156 | "pstree.remy": "^1.1.7", 1157 | "semver": "^5.7.1", 1158 | "supports-color": "^5.5.0", 1159 | "touch": "^3.1.0", 1160 | "undefsafe": "^2.0.3", 1161 | "update-notifier": "^4.1.0" 1162 | }, 1163 | "bin": { 1164 | "nodemon": "bin/nodemon.js" 1165 | }, 1166 | "engines": { 1167 | "node": ">=8.10.0" 1168 | }, 1169 | "funding": { 1170 | "type": "opencollective", 1171 | "url": "https://opencollective.com/nodemon" 1172 | } 1173 | }, 1174 | "node_modules/nodemon/node_modules/debug": { 1175 | "version": "3.2.7", 1176 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 1177 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 1178 | "dependencies": { 1179 | "ms": "^2.1.1" 1180 | } 1181 | }, 1182 | "node_modules/nodemon/node_modules/ms": { 1183 | "version": "2.1.3", 1184 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1185 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1186 | }, 1187 | "node_modules/nopt": { 1188 | "version": "1.0.10", 1189 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1190 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1191 | "dependencies": { 1192 | "abbrev": "1" 1193 | }, 1194 | "bin": { 1195 | "nopt": "bin/nopt.js" 1196 | }, 1197 | "engines": { 1198 | "node": "*" 1199 | } 1200 | }, 1201 | "node_modules/normalize-path": { 1202 | "version": "3.0.0", 1203 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1204 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1205 | "engines": { 1206 | "node": ">=0.10.0" 1207 | } 1208 | }, 1209 | "node_modules/normalize-url": { 1210 | "version": "4.5.1", 1211 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz", 1212 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==", 1213 | "engines": { 1214 | "node": ">=8" 1215 | } 1216 | }, 1217 | "node_modules/on-finished": { 1218 | "version": "2.3.0", 1219 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1220 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1221 | "dependencies": { 1222 | "ee-first": "1.1.1" 1223 | }, 1224 | "engines": { 1225 | "node": ">= 0.8" 1226 | } 1227 | }, 1228 | "node_modules/on-headers": { 1229 | "version": "1.0.2", 1230 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 1231 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", 1232 | "engines": { 1233 | "node": ">= 0.8" 1234 | } 1235 | }, 1236 | "node_modules/once": { 1237 | "version": "1.4.0", 1238 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1239 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1240 | "dependencies": { 1241 | "wrappy": "1" 1242 | } 1243 | }, 1244 | "node_modules/p-cancelable": { 1245 | "version": "1.1.0", 1246 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 1247 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==", 1248 | "engines": { 1249 | "node": ">=6" 1250 | } 1251 | }, 1252 | "node_modules/package-json": { 1253 | "version": "6.5.0", 1254 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 1255 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 1256 | "dependencies": { 1257 | "got": "^9.6.0", 1258 | "registry-auth-token": "^4.0.0", 1259 | "registry-url": "^5.0.0", 1260 | "semver": "^6.2.0" 1261 | }, 1262 | "engines": { 1263 | "node": ">=8" 1264 | } 1265 | }, 1266 | "node_modules/package-json/node_modules/semver": { 1267 | "version": "6.3.0", 1268 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1269 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1270 | "bin": { 1271 | "semver": "bin/semver.js" 1272 | } 1273 | }, 1274 | "node_modules/parseurl": { 1275 | "version": "1.3.3", 1276 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1277 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1278 | "engines": { 1279 | "node": ">= 0.8" 1280 | } 1281 | }, 1282 | "node_modules/path-to-regexp": { 1283 | "version": "0.1.7", 1284 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1285 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1286 | }, 1287 | "node_modules/picomatch": { 1288 | "version": "2.3.0", 1289 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1290 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1291 | "engines": { 1292 | "node": ">=8.6" 1293 | }, 1294 | "funding": { 1295 | "url": "https://github.com/sponsors/jonschlinkert" 1296 | } 1297 | }, 1298 | "node_modules/prepend-http": { 1299 | "version": "2.0.0", 1300 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 1301 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=", 1302 | "engines": { 1303 | "node": ">=4" 1304 | } 1305 | }, 1306 | "node_modules/proxy-addr": { 1307 | "version": "2.0.7", 1308 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 1309 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 1310 | "dependencies": { 1311 | "forwarded": "0.2.0", 1312 | "ipaddr.js": "1.9.1" 1313 | }, 1314 | "engines": { 1315 | "node": ">= 0.10" 1316 | } 1317 | }, 1318 | "node_modules/pstree.remy": { 1319 | "version": "1.1.8", 1320 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1321 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 1322 | }, 1323 | "node_modules/pump": { 1324 | "version": "3.0.0", 1325 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1326 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1327 | "dependencies": { 1328 | "end-of-stream": "^1.1.0", 1329 | "once": "^1.3.1" 1330 | } 1331 | }, 1332 | "node_modules/pupa": { 1333 | "version": "2.1.1", 1334 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", 1335 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", 1336 | "dependencies": { 1337 | "escape-goat": "^2.0.0" 1338 | }, 1339 | "engines": { 1340 | "node": ">=8" 1341 | } 1342 | }, 1343 | "node_modules/qs": { 1344 | "version": "6.7.0", 1345 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 1346 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", 1347 | "engines": { 1348 | "node": ">=0.6" 1349 | } 1350 | }, 1351 | "node_modules/random-bytes": { 1352 | "version": "1.0.0", 1353 | "resolved": "https://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz", 1354 | "integrity": "sha1-T2ih3Arli9P7lYSMMDJNt11kNgs=", 1355 | "engines": { 1356 | "node": ">= 0.8" 1357 | } 1358 | }, 1359 | "node_modules/range-parser": { 1360 | "version": "1.2.1", 1361 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1362 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1363 | "engines": { 1364 | "node": ">= 0.6" 1365 | } 1366 | }, 1367 | "node_modules/raw-body": { 1368 | "version": "2.4.0", 1369 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1370 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1371 | "dependencies": { 1372 | "bytes": "3.1.0", 1373 | "http-errors": "1.7.2", 1374 | "iconv-lite": "0.4.24", 1375 | "unpipe": "1.0.0" 1376 | }, 1377 | "engines": { 1378 | "node": ">= 0.8" 1379 | } 1380 | }, 1381 | "node_modules/rc": { 1382 | "version": "1.2.8", 1383 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1384 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1385 | "dependencies": { 1386 | "deep-extend": "^0.6.0", 1387 | "ini": "~1.3.0", 1388 | "minimist": "^1.2.0", 1389 | "strip-json-comments": "~2.0.1" 1390 | }, 1391 | "bin": { 1392 | "rc": "cli.js" 1393 | } 1394 | }, 1395 | "node_modules/readdirp": { 1396 | "version": "3.6.0", 1397 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1398 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1399 | "dependencies": { 1400 | "picomatch": "^2.2.1" 1401 | }, 1402 | "engines": { 1403 | "node": ">=8.10.0" 1404 | } 1405 | }, 1406 | "node_modules/registry-auth-token": { 1407 | "version": "4.2.1", 1408 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz", 1409 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==", 1410 | "dependencies": { 1411 | "rc": "^1.2.8" 1412 | }, 1413 | "engines": { 1414 | "node": ">=6.0.0" 1415 | } 1416 | }, 1417 | "node_modules/registry-url": { 1418 | "version": "5.1.0", 1419 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1420 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1421 | "dependencies": { 1422 | "rc": "^1.2.8" 1423 | }, 1424 | "engines": { 1425 | "node": ">=8" 1426 | } 1427 | }, 1428 | "node_modules/responselike": { 1429 | "version": "1.0.2", 1430 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1431 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1432 | "dependencies": { 1433 | "lowercase-keys": "^1.0.0" 1434 | } 1435 | }, 1436 | "node_modules/safe-buffer": { 1437 | "version": "5.1.2", 1438 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1439 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1440 | }, 1441 | "node_modules/safer-buffer": { 1442 | "version": "2.1.2", 1443 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1444 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1445 | }, 1446 | "node_modules/semver": { 1447 | "version": "5.7.1", 1448 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1449 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1450 | "bin": { 1451 | "semver": "bin/semver" 1452 | } 1453 | }, 1454 | "node_modules/semver-diff": { 1455 | "version": "3.1.1", 1456 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1457 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1458 | "dependencies": { 1459 | "semver": "^6.3.0" 1460 | }, 1461 | "engines": { 1462 | "node": ">=8" 1463 | } 1464 | }, 1465 | "node_modules/semver-diff/node_modules/semver": { 1466 | "version": "6.3.0", 1467 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1468 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1469 | "bin": { 1470 | "semver": "bin/semver.js" 1471 | } 1472 | }, 1473 | "node_modules/send": { 1474 | "version": "0.17.1", 1475 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1476 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1477 | "dependencies": { 1478 | "debug": "2.6.9", 1479 | "depd": "~1.1.2", 1480 | "destroy": "~1.0.4", 1481 | "encodeurl": "~1.0.2", 1482 | "escape-html": "~1.0.3", 1483 | "etag": "~1.8.1", 1484 | "fresh": "0.5.2", 1485 | "http-errors": "~1.7.2", 1486 | "mime": "1.6.0", 1487 | "ms": "2.1.1", 1488 | "on-finished": "~2.3.0", 1489 | "range-parser": "~1.2.1", 1490 | "statuses": "~1.5.0" 1491 | }, 1492 | "engines": { 1493 | "node": ">= 0.8.0" 1494 | } 1495 | }, 1496 | "node_modules/send/node_modules/ms": { 1497 | "version": "2.1.1", 1498 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1499 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1500 | }, 1501 | "node_modules/serve-static": { 1502 | "version": "1.14.1", 1503 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1504 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1505 | "dependencies": { 1506 | "encodeurl": "~1.0.2", 1507 | "escape-html": "~1.0.3", 1508 | "parseurl": "~1.3.3", 1509 | "send": "0.17.1" 1510 | }, 1511 | "engines": { 1512 | "node": ">= 0.8.0" 1513 | } 1514 | }, 1515 | "node_modules/setprototypeof": { 1516 | "version": "1.1.1", 1517 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1518 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1519 | }, 1520 | "node_modules/signal-exit": { 1521 | "version": "3.0.4", 1522 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.4.tgz", 1523 | "integrity": "sha512-rqYhcAnZ6d/vTPGghdrw7iumdcbXpsk1b8IG/rz+VWV51DM0p7XCtMoJ3qhPLIbp3tvyt3pKRbaaEMZYpHto8Q==" 1524 | }, 1525 | "node_modules/statuses": { 1526 | "version": "1.5.0", 1527 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1528 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 1529 | "engines": { 1530 | "node": ">= 0.6" 1531 | } 1532 | }, 1533 | "node_modules/string-width": { 1534 | "version": "4.2.2", 1535 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 1536 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 1537 | "dependencies": { 1538 | "emoji-regex": "^8.0.0", 1539 | "is-fullwidth-code-point": "^3.0.0", 1540 | "strip-ansi": "^6.0.0" 1541 | }, 1542 | "engines": { 1543 | "node": ">=8" 1544 | } 1545 | }, 1546 | "node_modules/strip-ansi": { 1547 | "version": "6.0.0", 1548 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1549 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1550 | "dependencies": { 1551 | "ansi-regex": "^5.0.0" 1552 | }, 1553 | "engines": { 1554 | "node": ">=8" 1555 | } 1556 | }, 1557 | "node_modules/strip-json-comments": { 1558 | "version": "2.0.1", 1559 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1560 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1561 | "engines": { 1562 | "node": ">=0.10.0" 1563 | } 1564 | }, 1565 | "node_modules/supports-color": { 1566 | "version": "5.5.0", 1567 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1568 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1569 | "dependencies": { 1570 | "has-flag": "^3.0.0" 1571 | }, 1572 | "engines": { 1573 | "node": ">=4" 1574 | } 1575 | }, 1576 | "node_modules/term-size": { 1577 | "version": "2.2.1", 1578 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.1.tgz", 1579 | "integrity": "sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==", 1580 | "engines": { 1581 | "node": ">=8" 1582 | }, 1583 | "funding": { 1584 | "url": "https://github.com/sponsors/sindresorhus" 1585 | } 1586 | }, 1587 | "node_modules/to-readable-stream": { 1588 | "version": "1.0.0", 1589 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1590 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==", 1591 | "engines": { 1592 | "node": ">=6" 1593 | } 1594 | }, 1595 | "node_modules/to-regex-range": { 1596 | "version": "5.0.1", 1597 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1598 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1599 | "dependencies": { 1600 | "is-number": "^7.0.0" 1601 | }, 1602 | "engines": { 1603 | "node": ">=8.0" 1604 | } 1605 | }, 1606 | "node_modules/toidentifier": { 1607 | "version": "1.0.0", 1608 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1609 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 1610 | "engines": { 1611 | "node": ">=0.6" 1612 | } 1613 | }, 1614 | "node_modules/touch": { 1615 | "version": "3.1.0", 1616 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1617 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1618 | "dependencies": { 1619 | "nopt": "~1.0.10" 1620 | }, 1621 | "bin": { 1622 | "nodetouch": "bin/nodetouch.js" 1623 | } 1624 | }, 1625 | "node_modules/type-fest": { 1626 | "version": "0.8.1", 1627 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1628 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1629 | "engines": { 1630 | "node": ">=8" 1631 | } 1632 | }, 1633 | "node_modules/type-is": { 1634 | "version": "1.6.18", 1635 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1636 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1637 | "dependencies": { 1638 | "media-typer": "0.3.0", 1639 | "mime-types": "~2.1.24" 1640 | }, 1641 | "engines": { 1642 | "node": ">= 0.6" 1643 | } 1644 | }, 1645 | "node_modules/typedarray-to-buffer": { 1646 | "version": "3.1.5", 1647 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1648 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1649 | "dependencies": { 1650 | "is-typedarray": "^1.0.0" 1651 | } 1652 | }, 1653 | "node_modules/uid-safe": { 1654 | "version": "2.1.5", 1655 | "resolved": "https://registry.npmjs.org/uid-safe/-/uid-safe-2.1.5.tgz", 1656 | "integrity": "sha512-KPHm4VL5dDXKz01UuEd88Df+KzynaohSL9fBh096KWAxSKZQDI2uBrVqtvRM4rwrIrRRKsdLNML/lnaaVSRioA==", 1657 | "dependencies": { 1658 | "random-bytes": "~1.0.0" 1659 | }, 1660 | "engines": { 1661 | "node": ">= 0.8" 1662 | } 1663 | }, 1664 | "node_modules/undefsafe": { 1665 | "version": "2.0.3", 1666 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.3.tgz", 1667 | "integrity": "sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A==", 1668 | "dependencies": { 1669 | "debug": "^2.2.0" 1670 | } 1671 | }, 1672 | "node_modules/unique-string": { 1673 | "version": "2.0.0", 1674 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 1675 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 1676 | "dependencies": { 1677 | "crypto-random-string": "^2.0.0" 1678 | }, 1679 | "engines": { 1680 | "node": ">=8" 1681 | } 1682 | }, 1683 | "node_modules/unpipe": { 1684 | "version": "1.0.0", 1685 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1686 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 1687 | "engines": { 1688 | "node": ">= 0.8" 1689 | } 1690 | }, 1691 | "node_modules/update-notifier": { 1692 | "version": "4.1.3", 1693 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.1.3.tgz", 1694 | "integrity": "sha512-Yld6Z0RyCYGB6ckIjffGOSOmHXj1gMeE7aROz4MG+XMkmixBX4jUngrGXNYz7wPKBmtoD4MnBa2Anu7RSKht/A==", 1695 | "dependencies": { 1696 | "boxen": "^4.2.0", 1697 | "chalk": "^3.0.0", 1698 | "configstore": "^5.0.1", 1699 | "has-yarn": "^2.1.0", 1700 | "import-lazy": "^2.1.0", 1701 | "is-ci": "^2.0.0", 1702 | "is-installed-globally": "^0.3.1", 1703 | "is-npm": "^4.0.0", 1704 | "is-yarn-global": "^0.3.0", 1705 | "latest-version": "^5.0.0", 1706 | "pupa": "^2.0.1", 1707 | "semver-diff": "^3.1.1", 1708 | "xdg-basedir": "^4.0.0" 1709 | }, 1710 | "engines": { 1711 | "node": ">=8" 1712 | }, 1713 | "funding": { 1714 | "url": "https://github.com/yeoman/update-notifier?sponsor=1" 1715 | } 1716 | }, 1717 | "node_modules/url-parse-lax": { 1718 | "version": "3.0.0", 1719 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 1720 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 1721 | "dependencies": { 1722 | "prepend-http": "^2.0.0" 1723 | }, 1724 | "engines": { 1725 | "node": ">=4" 1726 | } 1727 | }, 1728 | "node_modules/utils-merge": { 1729 | "version": "1.0.1", 1730 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1731 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 1732 | "engines": { 1733 | "node": ">= 0.4.0" 1734 | } 1735 | }, 1736 | "node_modules/vary": { 1737 | "version": "1.1.2", 1738 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1739 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 1740 | "engines": { 1741 | "node": ">= 0.8" 1742 | } 1743 | }, 1744 | "node_modules/widest-line": { 1745 | "version": "3.1.0", 1746 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 1747 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 1748 | "dependencies": { 1749 | "string-width": "^4.0.0" 1750 | }, 1751 | "engines": { 1752 | "node": ">=8" 1753 | } 1754 | }, 1755 | "node_modules/wrappy": { 1756 | "version": "1.0.2", 1757 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1758 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1759 | }, 1760 | "node_modules/write-file-atomic": { 1761 | "version": "3.0.3", 1762 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 1763 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 1764 | "dependencies": { 1765 | "imurmurhash": "^0.1.4", 1766 | "is-typedarray": "^1.0.0", 1767 | "signal-exit": "^3.0.2", 1768 | "typedarray-to-buffer": "^3.1.5" 1769 | } 1770 | }, 1771 | "node_modules/xdg-basedir": { 1772 | "version": "4.0.0", 1773 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 1774 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 1775 | "engines": { 1776 | "node": ">=8" 1777 | } 1778 | } 1779 | }, 1780 | "dependencies": { 1781 | "@sindresorhus/is": { 1782 | "version": "0.14.0", 1783 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 1784 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==" 1785 | }, 1786 | "@szmarczak/http-timer": { 1787 | "version": "1.1.2", 1788 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 1789 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 1790 | "requires": { 1791 | "defer-to-connect": "^1.0.1" 1792 | } 1793 | }, 1794 | "abbrev": { 1795 | "version": "1.1.1", 1796 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 1797 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 1798 | }, 1799 | "accepts": { 1800 | "version": "1.3.7", 1801 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 1802 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 1803 | "requires": { 1804 | "mime-types": "~2.1.24", 1805 | "negotiator": "0.6.2" 1806 | } 1807 | }, 1808 | "ansi-align": { 1809 | "version": "3.0.0", 1810 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.0.tgz", 1811 | "integrity": "sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw==", 1812 | "requires": { 1813 | "string-width": "^3.0.0" 1814 | }, 1815 | "dependencies": { 1816 | "ansi-regex": { 1817 | "version": "4.1.0", 1818 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1819 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" 1820 | }, 1821 | "emoji-regex": { 1822 | "version": "7.0.3", 1823 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 1824 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 1825 | }, 1826 | "is-fullwidth-code-point": { 1827 | "version": "2.0.0", 1828 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1829 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 1830 | }, 1831 | "string-width": { 1832 | "version": "3.1.0", 1833 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1834 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1835 | "requires": { 1836 | "emoji-regex": "^7.0.1", 1837 | "is-fullwidth-code-point": "^2.0.0", 1838 | "strip-ansi": "^5.1.0" 1839 | } 1840 | }, 1841 | "strip-ansi": { 1842 | "version": "5.2.0", 1843 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1844 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1845 | "requires": { 1846 | "ansi-regex": "^4.1.0" 1847 | } 1848 | } 1849 | } 1850 | }, 1851 | "ansi-regex": { 1852 | "version": "5.0.1", 1853 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1854 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" 1855 | }, 1856 | "ansi-styles": { 1857 | "version": "4.3.0", 1858 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1859 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1860 | "requires": { 1861 | "color-convert": "^2.0.1" 1862 | } 1863 | }, 1864 | "anymatch": { 1865 | "version": "3.1.2", 1866 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 1867 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 1868 | "requires": { 1869 | "normalize-path": "^3.0.0", 1870 | "picomatch": "^2.0.4" 1871 | } 1872 | }, 1873 | "array-flatten": { 1874 | "version": "1.1.1", 1875 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 1876 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 1877 | }, 1878 | "balanced-match": { 1879 | "version": "1.0.2", 1880 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1881 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 1882 | }, 1883 | "basic-auth": { 1884 | "version": "2.0.1", 1885 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 1886 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 1887 | "requires": { 1888 | "safe-buffer": "5.1.2" 1889 | } 1890 | }, 1891 | "binary-extensions": { 1892 | "version": "2.2.0", 1893 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1894 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==" 1895 | }, 1896 | "body-parser": { 1897 | "version": "1.19.0", 1898 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 1899 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 1900 | "requires": { 1901 | "bytes": "3.1.0", 1902 | "content-type": "~1.0.4", 1903 | "debug": "2.6.9", 1904 | "depd": "~1.1.2", 1905 | "http-errors": "1.7.2", 1906 | "iconv-lite": "0.4.24", 1907 | "on-finished": "~2.3.0", 1908 | "qs": "6.7.0", 1909 | "raw-body": "2.4.0", 1910 | "type-is": "~1.6.17" 1911 | } 1912 | }, 1913 | "boxen": { 1914 | "version": "4.2.0", 1915 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz", 1916 | "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==", 1917 | "requires": { 1918 | "ansi-align": "^3.0.0", 1919 | "camelcase": "^5.3.1", 1920 | "chalk": "^3.0.0", 1921 | "cli-boxes": "^2.2.0", 1922 | "string-width": "^4.1.0", 1923 | "term-size": "^2.1.0", 1924 | "type-fest": "^0.8.1", 1925 | "widest-line": "^3.1.0" 1926 | } 1927 | }, 1928 | "brace-expansion": { 1929 | "version": "1.1.11", 1930 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1931 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1932 | "requires": { 1933 | "balanced-match": "^1.0.0", 1934 | "concat-map": "0.0.1" 1935 | } 1936 | }, 1937 | "braces": { 1938 | "version": "3.0.2", 1939 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1940 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1941 | "requires": { 1942 | "fill-range": "^7.0.1" 1943 | } 1944 | }, 1945 | "bytes": { 1946 | "version": "3.1.0", 1947 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 1948 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 1949 | }, 1950 | "cacheable-request": { 1951 | "version": "6.1.0", 1952 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 1953 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 1954 | "requires": { 1955 | "clone-response": "^1.0.2", 1956 | "get-stream": "^5.1.0", 1957 | "http-cache-semantics": "^4.0.0", 1958 | "keyv": "^3.0.0", 1959 | "lowercase-keys": "^2.0.0", 1960 | "normalize-url": "^4.1.0", 1961 | "responselike": "^1.0.2" 1962 | }, 1963 | "dependencies": { 1964 | "get-stream": { 1965 | "version": "5.2.0", 1966 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", 1967 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", 1968 | "requires": { 1969 | "pump": "^3.0.0" 1970 | } 1971 | }, 1972 | "lowercase-keys": { 1973 | "version": "2.0.0", 1974 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 1975 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==" 1976 | } 1977 | } 1978 | }, 1979 | "camelcase": { 1980 | "version": "5.3.1", 1981 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 1982 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" 1983 | }, 1984 | "chalk": { 1985 | "version": "3.0.0", 1986 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 1987 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 1988 | "requires": { 1989 | "ansi-styles": "^4.1.0", 1990 | "supports-color": "^7.1.0" 1991 | }, 1992 | "dependencies": { 1993 | "has-flag": { 1994 | "version": "4.0.0", 1995 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1996 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 1997 | }, 1998 | "supports-color": { 1999 | "version": "7.2.0", 2000 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2001 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2002 | "requires": { 2003 | "has-flag": "^4.0.0" 2004 | } 2005 | } 2006 | } 2007 | }, 2008 | "charenc": { 2009 | "version": "0.0.2", 2010 | "resolved": "https://registry.npmjs.org/charenc/-/charenc-0.0.2.tgz", 2011 | "integrity": "sha1-wKHS86cJLgN3S/qD8UwPxXkKhmc=" 2012 | }, 2013 | "chokidar": { 2014 | "version": "3.5.2", 2015 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 2016 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 2017 | "requires": { 2018 | "anymatch": "~3.1.2", 2019 | "braces": "~3.0.2", 2020 | "fsevents": "~2.3.2", 2021 | "glob-parent": "~5.1.2", 2022 | "is-binary-path": "~2.1.0", 2023 | "is-glob": "~4.0.1", 2024 | "normalize-path": "~3.0.0", 2025 | "readdirp": "~3.6.0" 2026 | } 2027 | }, 2028 | "ci-info": { 2029 | "version": "2.0.0", 2030 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 2031 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" 2032 | }, 2033 | "cli-boxes": { 2034 | "version": "2.2.1", 2035 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", 2036 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==" 2037 | }, 2038 | "clone-response": { 2039 | "version": "1.0.2", 2040 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 2041 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 2042 | "requires": { 2043 | "mimic-response": "^1.0.0" 2044 | } 2045 | }, 2046 | "color-convert": { 2047 | "version": "2.0.1", 2048 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2049 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2050 | "requires": { 2051 | "color-name": "~1.1.4" 2052 | } 2053 | }, 2054 | "color-name": { 2055 | "version": "1.1.4", 2056 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2057 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 2058 | }, 2059 | "concat-map": { 2060 | "version": "0.0.1", 2061 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2062 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 2063 | }, 2064 | "configstore": { 2065 | "version": "5.0.1", 2066 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 2067 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 2068 | "requires": { 2069 | "dot-prop": "^5.2.0", 2070 | "graceful-fs": "^4.1.2", 2071 | "make-dir": "^3.0.0", 2072 | "unique-string": "^2.0.0", 2073 | "write-file-atomic": "^3.0.0", 2074 | "xdg-basedir": "^4.0.0" 2075 | } 2076 | }, 2077 | "content-disposition": { 2078 | "version": "0.5.3", 2079 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 2080 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 2081 | "requires": { 2082 | "safe-buffer": "5.1.2" 2083 | } 2084 | }, 2085 | "content-type": { 2086 | "version": "1.0.4", 2087 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 2088 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 2089 | }, 2090 | "cookie": { 2091 | "version": "0.4.0", 2092 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 2093 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 2094 | }, 2095 | "cookie-signature": { 2096 | "version": "1.0.6", 2097 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 2098 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 2099 | }, 2100 | "crypt": { 2101 | "version": "0.0.2", 2102 | "resolved": "https://registry.npmjs.org/crypt/-/crypt-0.0.2.tgz", 2103 | "integrity": "sha1-iNf/fsDfuG9xPch7u0LQRNPmxBs=" 2104 | }, 2105 | "crypto-random-string": { 2106 | "version": "2.0.0", 2107 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 2108 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==" 2109 | }, 2110 | "debug": { 2111 | "version": "2.6.9", 2112 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2113 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2114 | "requires": { 2115 | "ms": "2.0.0" 2116 | } 2117 | }, 2118 | "decompress-response": { 2119 | "version": "3.3.0", 2120 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 2121 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 2122 | "requires": { 2123 | "mimic-response": "^1.0.0" 2124 | } 2125 | }, 2126 | "deep-extend": { 2127 | "version": "0.6.0", 2128 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 2129 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 2130 | }, 2131 | "defer-to-connect": { 2132 | "version": "1.1.3", 2133 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 2134 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==" 2135 | }, 2136 | "depd": { 2137 | "version": "1.1.2", 2138 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 2139 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 2140 | }, 2141 | "destroy": { 2142 | "version": "1.0.4", 2143 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 2144 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 2145 | }, 2146 | "dot-prop": { 2147 | "version": "5.3.0", 2148 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", 2149 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", 2150 | "requires": { 2151 | "is-obj": "^2.0.0" 2152 | } 2153 | }, 2154 | "duplexer3": { 2155 | "version": "0.1.4", 2156 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 2157 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=" 2158 | }, 2159 | "ee-first": { 2160 | "version": "1.1.1", 2161 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 2162 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 2163 | }, 2164 | "emoji-regex": { 2165 | "version": "8.0.0", 2166 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2167 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2168 | }, 2169 | "encodeurl": { 2170 | "version": "1.0.2", 2171 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 2172 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 2173 | }, 2174 | "end-of-stream": { 2175 | "version": "1.4.4", 2176 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 2177 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 2178 | "requires": { 2179 | "once": "^1.4.0" 2180 | } 2181 | }, 2182 | "escape-goat": { 2183 | "version": "2.1.1", 2184 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 2185 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==" 2186 | }, 2187 | "escape-html": { 2188 | "version": "1.0.3", 2189 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 2190 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 2191 | }, 2192 | "etag": { 2193 | "version": "1.8.1", 2194 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 2195 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 2196 | }, 2197 | "express": { 2198 | "version": "4.17.1", 2199 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 2200 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 2201 | "requires": { 2202 | "accepts": "~1.3.7", 2203 | "array-flatten": "1.1.1", 2204 | "body-parser": "1.19.0", 2205 | "content-disposition": "0.5.3", 2206 | "content-type": "~1.0.4", 2207 | "cookie": "0.4.0", 2208 | "cookie-signature": "1.0.6", 2209 | "debug": "2.6.9", 2210 | "depd": "~1.1.2", 2211 | "encodeurl": "~1.0.2", 2212 | "escape-html": "~1.0.3", 2213 | "etag": "~1.8.1", 2214 | "finalhandler": "~1.1.2", 2215 | "fresh": "0.5.2", 2216 | "merge-descriptors": "1.0.1", 2217 | "methods": "~1.1.2", 2218 | "on-finished": "~2.3.0", 2219 | "parseurl": "~1.3.3", 2220 | "path-to-regexp": "0.1.7", 2221 | "proxy-addr": "~2.0.5", 2222 | "qs": "6.7.0", 2223 | "range-parser": "~1.2.1", 2224 | "safe-buffer": "5.1.2", 2225 | "send": "0.17.1", 2226 | "serve-static": "1.14.1", 2227 | "setprototypeof": "1.1.1", 2228 | "statuses": "~1.5.0", 2229 | "type-is": "~1.6.18", 2230 | "utils-merge": "1.0.1", 2231 | "vary": "~1.1.2" 2232 | } 2233 | }, 2234 | "express-session": { 2235 | "version": "1.17.2", 2236 | "resolved": "https://registry.npmjs.org/express-session/-/express-session-1.17.2.tgz", 2237 | "integrity": "sha512-mPcYcLA0lvh7D4Oqr5aNJFMtBMKPLl++OKKxkHzZ0U0oDq1rpKBnkR5f5vCHR26VeArlTOEF9td4x5IjICksRQ==", 2238 | "requires": { 2239 | "cookie": "0.4.1", 2240 | "cookie-signature": "1.0.6", 2241 | "debug": "2.6.9", 2242 | "depd": "~2.0.0", 2243 | "on-headers": "~1.0.2", 2244 | "parseurl": "~1.3.3", 2245 | "safe-buffer": "5.2.1", 2246 | "uid-safe": "~2.1.5" 2247 | }, 2248 | "dependencies": { 2249 | "cookie": { 2250 | "version": "0.4.1", 2251 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 2252 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==" 2253 | }, 2254 | "depd": { 2255 | "version": "2.0.0", 2256 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 2257 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 2258 | }, 2259 | "safe-buffer": { 2260 | "version": "5.2.1", 2261 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2262 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2263 | } 2264 | } 2265 | }, 2266 | "fill-range": { 2267 | "version": "7.0.1", 2268 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2269 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2270 | "requires": { 2271 | "to-regex-range": "^5.0.1" 2272 | } 2273 | }, 2274 | "finalhandler": { 2275 | "version": "1.1.2", 2276 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 2277 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 2278 | "requires": { 2279 | "debug": "2.6.9", 2280 | "encodeurl": "~1.0.2", 2281 | "escape-html": "~1.0.3", 2282 | "on-finished": "~2.3.0", 2283 | "parseurl": "~1.3.3", 2284 | "statuses": "~1.5.0", 2285 | "unpipe": "~1.0.0" 2286 | } 2287 | }, 2288 | "forwarded": { 2289 | "version": "0.2.0", 2290 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 2291 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 2292 | }, 2293 | "fresh": { 2294 | "version": "0.5.2", 2295 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 2296 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 2297 | }, 2298 | "fsevents": { 2299 | "version": "2.3.2", 2300 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2301 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2302 | "optional": true 2303 | }, 2304 | "get-stream": { 2305 | "version": "4.1.0", 2306 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 2307 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 2308 | "requires": { 2309 | "pump": "^3.0.0" 2310 | } 2311 | }, 2312 | "glob-parent": { 2313 | "version": "5.1.2", 2314 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2315 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2316 | "requires": { 2317 | "is-glob": "^4.0.1" 2318 | } 2319 | }, 2320 | "global-dirs": { 2321 | "version": "2.1.0", 2322 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.1.0.tgz", 2323 | "integrity": "sha512-MG6kdOUh/xBnyo9cJFeIKkLEc1AyFq42QTU4XiX51i2NEdxLxLWXIjEjmqKeSuKR7pAZjTqUVoT2b2huxVLgYQ==", 2324 | "requires": { 2325 | "ini": "1.3.7" 2326 | } 2327 | }, 2328 | "got": { 2329 | "version": "9.6.0", 2330 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 2331 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 2332 | "requires": { 2333 | "@sindresorhus/is": "^0.14.0", 2334 | "@szmarczak/http-timer": "^1.1.2", 2335 | "cacheable-request": "^6.0.0", 2336 | "decompress-response": "^3.3.0", 2337 | "duplexer3": "^0.1.4", 2338 | "get-stream": "^4.1.0", 2339 | "lowercase-keys": "^1.0.1", 2340 | "mimic-response": "^1.0.1", 2341 | "p-cancelable": "^1.0.0", 2342 | "to-readable-stream": "^1.0.0", 2343 | "url-parse-lax": "^3.0.0" 2344 | } 2345 | }, 2346 | "graceful-fs": { 2347 | "version": "4.2.8", 2348 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 2349 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==" 2350 | }, 2351 | "has-flag": { 2352 | "version": "3.0.0", 2353 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2354 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 2355 | }, 2356 | "has-yarn": { 2357 | "version": "2.1.0", 2358 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 2359 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==" 2360 | }, 2361 | "http-cache-semantics": { 2362 | "version": "4.1.0", 2363 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 2364 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==" 2365 | }, 2366 | "http-errors": { 2367 | "version": "1.7.2", 2368 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 2369 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 2370 | "requires": { 2371 | "depd": "~1.1.2", 2372 | "inherits": "2.0.3", 2373 | "setprototypeof": "1.1.1", 2374 | "statuses": ">= 1.5.0 < 2", 2375 | "toidentifier": "1.0.0" 2376 | } 2377 | }, 2378 | "iconv-lite": { 2379 | "version": "0.4.24", 2380 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2381 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2382 | "requires": { 2383 | "safer-buffer": ">= 2.1.2 < 3" 2384 | } 2385 | }, 2386 | "ignore-by-default": { 2387 | "version": "1.0.1", 2388 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 2389 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=" 2390 | }, 2391 | "import-lazy": { 2392 | "version": "2.1.0", 2393 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 2394 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=" 2395 | }, 2396 | "imurmurhash": { 2397 | "version": "0.1.4", 2398 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2399 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 2400 | }, 2401 | "inherits": { 2402 | "version": "2.0.3", 2403 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 2404 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 2405 | }, 2406 | "ini": { 2407 | "version": "1.3.7", 2408 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.7.tgz", 2409 | "integrity": "sha512-iKpRpXP+CrP2jyrxvg1kMUpXDyRUFDWurxbnVT1vQPx+Wz9uCYsMIqYuSBLV+PAaZG/d7kRLKRFc9oDMsH+mFQ==" 2410 | }, 2411 | "ipaddr.js": { 2412 | "version": "1.9.1", 2413 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 2414 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 2415 | }, 2416 | "is-binary-path": { 2417 | "version": "2.1.0", 2418 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2419 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2420 | "requires": { 2421 | "binary-extensions": "^2.0.0" 2422 | } 2423 | }, 2424 | "is-buffer": { 2425 | "version": "1.1.6", 2426 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 2427 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" 2428 | }, 2429 | "is-ci": { 2430 | "version": "2.0.0", 2431 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 2432 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 2433 | "requires": { 2434 | "ci-info": "^2.0.0" 2435 | } 2436 | }, 2437 | "is-extglob": { 2438 | "version": "2.1.1", 2439 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2440 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 2441 | }, 2442 | "is-fullwidth-code-point": { 2443 | "version": "3.0.0", 2444 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2445 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 2446 | }, 2447 | "is-glob": { 2448 | "version": "4.0.1", 2449 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 2450 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 2451 | "requires": { 2452 | "is-extglob": "^2.1.1" 2453 | } 2454 | }, 2455 | "is-installed-globally": { 2456 | "version": "0.3.2", 2457 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.2.tgz", 2458 | "integrity": "sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g==", 2459 | "requires": { 2460 | "global-dirs": "^2.0.1", 2461 | "is-path-inside": "^3.0.1" 2462 | } 2463 | }, 2464 | "is-npm": { 2465 | "version": "4.0.0", 2466 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz", 2467 | "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==" 2468 | }, 2469 | "is-number": { 2470 | "version": "7.0.0", 2471 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2472 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 2473 | }, 2474 | "is-obj": { 2475 | "version": "2.0.0", 2476 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 2477 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==" 2478 | }, 2479 | "is-path-inside": { 2480 | "version": "3.0.3", 2481 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2482 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==" 2483 | }, 2484 | "is-typedarray": { 2485 | "version": "1.0.0", 2486 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 2487 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" 2488 | }, 2489 | "is-yarn-global": { 2490 | "version": "0.3.0", 2491 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 2492 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==" 2493 | }, 2494 | "json-buffer": { 2495 | "version": "3.0.0", 2496 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 2497 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=" 2498 | }, 2499 | "keyv": { 2500 | "version": "3.1.0", 2501 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 2502 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 2503 | "requires": { 2504 | "json-buffer": "3.0.0" 2505 | } 2506 | }, 2507 | "latest-version": { 2508 | "version": "5.1.0", 2509 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 2510 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 2511 | "requires": { 2512 | "package-json": "^6.3.0" 2513 | } 2514 | }, 2515 | "lowercase-keys": { 2516 | "version": "1.0.1", 2517 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 2518 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==" 2519 | }, 2520 | "make-dir": { 2521 | "version": "3.1.0", 2522 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2523 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2524 | "requires": { 2525 | "semver": "^6.0.0" 2526 | }, 2527 | "dependencies": { 2528 | "semver": { 2529 | "version": "6.3.0", 2530 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2531 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 2532 | } 2533 | } 2534 | }, 2535 | "md5": { 2536 | "version": "2.3.0", 2537 | "resolved": "https://registry.npmjs.org/md5/-/md5-2.3.0.tgz", 2538 | "integrity": "sha512-T1GITYmFaKuO91vxyoQMFETst+O71VUPEU3ze5GNzDm0OWdP8v1ziTaAEPUr/3kLsY3Sftgz242A1SetQiDL7g==", 2539 | "requires": { 2540 | "charenc": "0.0.2", 2541 | "crypt": "0.0.2", 2542 | "is-buffer": "~1.1.6" 2543 | } 2544 | }, 2545 | "media-typer": { 2546 | "version": "0.3.0", 2547 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 2548 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 2549 | }, 2550 | "merge-descriptors": { 2551 | "version": "1.0.1", 2552 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 2553 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 2554 | }, 2555 | "methods": { 2556 | "version": "1.1.2", 2557 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 2558 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 2559 | }, 2560 | "mime": { 2561 | "version": "1.6.0", 2562 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2563 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 2564 | }, 2565 | "mime-db": { 2566 | "version": "1.49.0", 2567 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.49.0.tgz", 2568 | "integrity": "sha512-CIc8j9URtOVApSFCQIF+VBkX1RwXp/oMMOrqdyXSBXq5RWNEsRfyj1kiRnQgmNXmHxPoFIxOroKA3zcU9P+nAA==" 2569 | }, 2570 | "mime-types": { 2571 | "version": "2.1.32", 2572 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.32.tgz", 2573 | "integrity": "sha512-hJGaVS4G4c9TSMYh2n6SQAGrC4RnfU+daP8G7cSCmaqNjiOoUY0VHCMS42pxnQmVF1GWwFhbHWn3RIxCqTmZ9A==", 2574 | "requires": { 2575 | "mime-db": "1.49.0" 2576 | } 2577 | }, 2578 | "mimic-response": { 2579 | "version": "1.0.1", 2580 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 2581 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==" 2582 | }, 2583 | "minimatch": { 2584 | "version": "3.0.4", 2585 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2586 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2587 | "requires": { 2588 | "brace-expansion": "^1.1.7" 2589 | } 2590 | }, 2591 | "minimist": { 2592 | "version": "1.2.5", 2593 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 2594 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 2595 | }, 2596 | "morgan": { 2597 | "version": "1.10.0", 2598 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz", 2599 | "integrity": "sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==", 2600 | "requires": { 2601 | "basic-auth": "~2.0.1", 2602 | "debug": "2.6.9", 2603 | "depd": "~2.0.0", 2604 | "on-finished": "~2.3.0", 2605 | "on-headers": "~1.0.2" 2606 | }, 2607 | "dependencies": { 2608 | "depd": { 2609 | "version": "2.0.0", 2610 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 2611 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" 2612 | } 2613 | } 2614 | }, 2615 | "ms": { 2616 | "version": "2.0.0", 2617 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2618 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2619 | }, 2620 | "negotiator": { 2621 | "version": "0.6.2", 2622 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 2623 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 2624 | }, 2625 | "nodemon": { 2626 | "version": "2.0.12", 2627 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.12.tgz", 2628 | "integrity": "sha512-egCTmNZdObdBxUBw6ZNwvZ/xzk24CKRs5K6d+5zbmrMr7rOpPmfPeF6OxM3DDpaRx331CQRFEktn+wrFFfBSOA==", 2629 | "requires": { 2630 | "chokidar": "^3.2.2", 2631 | "debug": "^3.2.6", 2632 | "ignore-by-default": "^1.0.1", 2633 | "minimatch": "^3.0.4", 2634 | "pstree.remy": "^1.1.7", 2635 | "semver": "^5.7.1", 2636 | "supports-color": "^5.5.0", 2637 | "touch": "^3.1.0", 2638 | "undefsafe": "^2.0.3", 2639 | "update-notifier": "^4.1.0" 2640 | }, 2641 | "dependencies": { 2642 | "debug": { 2643 | "version": "3.2.7", 2644 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", 2645 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", 2646 | "requires": { 2647 | "ms": "^2.1.1" 2648 | } 2649 | }, 2650 | "ms": { 2651 | "version": "2.1.3", 2652 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2653 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 2654 | } 2655 | } 2656 | }, 2657 | "nopt": { 2658 | "version": "1.0.10", 2659 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 2660 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 2661 | "requires": { 2662 | "abbrev": "1" 2663 | } 2664 | }, 2665 | "normalize-path": { 2666 | "version": "3.0.0", 2667 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2668 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" 2669 | }, 2670 | "normalize-url": { 2671 | "version": "4.5.1", 2672 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz", 2673 | "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==" 2674 | }, 2675 | "on-finished": { 2676 | "version": "2.3.0", 2677 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2678 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2679 | "requires": { 2680 | "ee-first": "1.1.1" 2681 | } 2682 | }, 2683 | "on-headers": { 2684 | "version": "1.0.2", 2685 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 2686 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" 2687 | }, 2688 | "once": { 2689 | "version": "1.4.0", 2690 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2691 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2692 | "requires": { 2693 | "wrappy": "1" 2694 | } 2695 | }, 2696 | "p-cancelable": { 2697 | "version": "1.1.0", 2698 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 2699 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==" 2700 | }, 2701 | "package-json": { 2702 | "version": "6.5.0", 2703 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 2704 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 2705 | "requires": { 2706 | "got": "^9.6.0", 2707 | "registry-auth-token": "^4.0.0", 2708 | "registry-url": "^5.0.0", 2709 | "semver": "^6.2.0" 2710 | }, 2711 | "dependencies": { 2712 | "semver": { 2713 | "version": "6.3.0", 2714 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2715 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 2716 | } 2717 | } 2718 | }, 2719 | "parseurl": { 2720 | "version": "1.3.3", 2721 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2722 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2723 | }, 2724 | "path-to-regexp": { 2725 | "version": "0.1.7", 2726 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2727 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2728 | }, 2729 | "picomatch": { 2730 | "version": "2.3.0", 2731 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 2732 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==" 2733 | }, 2734 | "prepend-http": { 2735 | "version": "2.0.0", 2736 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 2737 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=" 2738 | }, 2739 | "proxy-addr": { 2740 | "version": "2.0.7", 2741 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2742 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2743 | "requires": { 2744 | "forwarded": "0.2.0", 2745 | "ipaddr.js": "1.9.1" 2746 | } 2747 | }, 2748 | "pstree.remy": { 2749 | "version": "1.1.8", 2750 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 2751 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" 2752 | }, 2753 | "pump": { 2754 | "version": "3.0.0", 2755 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 2756 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 2757 | "requires": { 2758 | "end-of-stream": "^1.1.0", 2759 | "once": "^1.3.1" 2760 | } 2761 | }, 2762 | "pupa": { 2763 | "version": "2.1.1", 2764 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", 2765 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", 2766 | "requires": { 2767 | "escape-goat": "^2.0.0" 2768 | } 2769 | }, 2770 | "qs": { 2771 | "version": "6.7.0", 2772 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 2773 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 2774 | }, 2775 | "random-bytes": { 2776 | "version": "1.0.0", 2777 | "resolved": "https://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz", 2778 | "integrity": "sha1-T2ih3Arli9P7lYSMMDJNt11kNgs=" 2779 | }, 2780 | "range-parser": { 2781 | "version": "1.2.1", 2782 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2783 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 2784 | }, 2785 | "raw-body": { 2786 | "version": "2.4.0", 2787 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 2788 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 2789 | "requires": { 2790 | "bytes": "3.1.0", 2791 | "http-errors": "1.7.2", 2792 | "iconv-lite": "0.4.24", 2793 | "unpipe": "1.0.0" 2794 | } 2795 | }, 2796 | "rc": { 2797 | "version": "1.2.8", 2798 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 2799 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 2800 | "requires": { 2801 | "deep-extend": "^0.6.0", 2802 | "ini": "~1.3.0", 2803 | "minimist": "^1.2.0", 2804 | "strip-json-comments": "~2.0.1" 2805 | } 2806 | }, 2807 | "readdirp": { 2808 | "version": "3.6.0", 2809 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2810 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2811 | "requires": { 2812 | "picomatch": "^2.2.1" 2813 | } 2814 | }, 2815 | "registry-auth-token": { 2816 | "version": "4.2.1", 2817 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz", 2818 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==", 2819 | "requires": { 2820 | "rc": "^1.2.8" 2821 | } 2822 | }, 2823 | "registry-url": { 2824 | "version": "5.1.0", 2825 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 2826 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 2827 | "requires": { 2828 | "rc": "^1.2.8" 2829 | } 2830 | }, 2831 | "responselike": { 2832 | "version": "1.0.2", 2833 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 2834 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 2835 | "requires": { 2836 | "lowercase-keys": "^1.0.0" 2837 | } 2838 | }, 2839 | "safe-buffer": { 2840 | "version": "5.1.2", 2841 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2842 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2843 | }, 2844 | "safer-buffer": { 2845 | "version": "2.1.2", 2846 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2847 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2848 | }, 2849 | "semver": { 2850 | "version": "5.7.1", 2851 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 2852 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 2853 | }, 2854 | "semver-diff": { 2855 | "version": "3.1.1", 2856 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 2857 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 2858 | "requires": { 2859 | "semver": "^6.3.0" 2860 | }, 2861 | "dependencies": { 2862 | "semver": { 2863 | "version": "6.3.0", 2864 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2865 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 2866 | } 2867 | } 2868 | }, 2869 | "send": { 2870 | "version": "0.17.1", 2871 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 2872 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 2873 | "requires": { 2874 | "debug": "2.6.9", 2875 | "depd": "~1.1.2", 2876 | "destroy": "~1.0.4", 2877 | "encodeurl": "~1.0.2", 2878 | "escape-html": "~1.0.3", 2879 | "etag": "~1.8.1", 2880 | "fresh": "0.5.2", 2881 | "http-errors": "~1.7.2", 2882 | "mime": "1.6.0", 2883 | "ms": "2.1.1", 2884 | "on-finished": "~2.3.0", 2885 | "range-parser": "~1.2.1", 2886 | "statuses": "~1.5.0" 2887 | }, 2888 | "dependencies": { 2889 | "ms": { 2890 | "version": "2.1.1", 2891 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2892 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 2893 | } 2894 | } 2895 | }, 2896 | "serve-static": { 2897 | "version": "1.14.1", 2898 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 2899 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 2900 | "requires": { 2901 | "encodeurl": "~1.0.2", 2902 | "escape-html": "~1.0.3", 2903 | "parseurl": "~1.3.3", 2904 | "send": "0.17.1" 2905 | } 2906 | }, 2907 | "setprototypeof": { 2908 | "version": "1.1.1", 2909 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 2910 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 2911 | }, 2912 | "signal-exit": { 2913 | "version": "3.0.4", 2914 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.4.tgz", 2915 | "integrity": "sha512-rqYhcAnZ6d/vTPGghdrw7iumdcbXpsk1b8IG/rz+VWV51DM0p7XCtMoJ3qhPLIbp3tvyt3pKRbaaEMZYpHto8Q==" 2916 | }, 2917 | "statuses": { 2918 | "version": "1.5.0", 2919 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2920 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 2921 | }, 2922 | "string-width": { 2923 | "version": "4.2.2", 2924 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 2925 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 2926 | "requires": { 2927 | "emoji-regex": "^8.0.0", 2928 | "is-fullwidth-code-point": "^3.0.0", 2929 | "strip-ansi": "^6.0.0" 2930 | } 2931 | }, 2932 | "strip-ansi": { 2933 | "version": "6.0.0", 2934 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2935 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2936 | "requires": { 2937 | "ansi-regex": "^5.0.0" 2938 | } 2939 | }, 2940 | "strip-json-comments": { 2941 | "version": "2.0.1", 2942 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2943 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 2944 | }, 2945 | "supports-color": { 2946 | "version": "5.5.0", 2947 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2948 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2949 | "requires": { 2950 | "has-flag": "^3.0.0" 2951 | } 2952 | }, 2953 | "term-size": { 2954 | "version": "2.2.1", 2955 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.1.tgz", 2956 | "integrity": "sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==" 2957 | }, 2958 | "to-readable-stream": { 2959 | "version": "1.0.0", 2960 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 2961 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==" 2962 | }, 2963 | "to-regex-range": { 2964 | "version": "5.0.1", 2965 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2966 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2967 | "requires": { 2968 | "is-number": "^7.0.0" 2969 | } 2970 | }, 2971 | "toidentifier": { 2972 | "version": "1.0.0", 2973 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 2974 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 2975 | }, 2976 | "touch": { 2977 | "version": "3.1.0", 2978 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2979 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2980 | "requires": { 2981 | "nopt": "~1.0.10" 2982 | } 2983 | }, 2984 | "type-fest": { 2985 | "version": "0.8.1", 2986 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2987 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==" 2988 | }, 2989 | "type-is": { 2990 | "version": "1.6.18", 2991 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2992 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2993 | "requires": { 2994 | "media-typer": "0.3.0", 2995 | "mime-types": "~2.1.24" 2996 | } 2997 | }, 2998 | "typedarray-to-buffer": { 2999 | "version": "3.1.5", 3000 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 3001 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 3002 | "requires": { 3003 | "is-typedarray": "^1.0.0" 3004 | } 3005 | }, 3006 | "uid-safe": { 3007 | "version": "2.1.5", 3008 | "resolved": "https://registry.npmjs.org/uid-safe/-/uid-safe-2.1.5.tgz", 3009 | "integrity": "sha512-KPHm4VL5dDXKz01UuEd88Df+KzynaohSL9fBh096KWAxSKZQDI2uBrVqtvRM4rwrIrRRKsdLNML/lnaaVSRioA==", 3010 | "requires": { 3011 | "random-bytes": "~1.0.0" 3012 | } 3013 | }, 3014 | "undefsafe": { 3015 | "version": "2.0.3", 3016 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.3.tgz", 3017 | "integrity": "sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A==", 3018 | "requires": { 3019 | "debug": "^2.2.0" 3020 | } 3021 | }, 3022 | "unique-string": { 3023 | "version": "2.0.0", 3024 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 3025 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 3026 | "requires": { 3027 | "crypto-random-string": "^2.0.0" 3028 | } 3029 | }, 3030 | "unpipe": { 3031 | "version": "1.0.0", 3032 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 3033 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 3034 | }, 3035 | "update-notifier": { 3036 | "version": "4.1.3", 3037 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.1.3.tgz", 3038 | "integrity": "sha512-Yld6Z0RyCYGB6ckIjffGOSOmHXj1gMeE7aROz4MG+XMkmixBX4jUngrGXNYz7wPKBmtoD4MnBa2Anu7RSKht/A==", 3039 | "requires": { 3040 | "boxen": "^4.2.0", 3041 | "chalk": "^3.0.0", 3042 | "configstore": "^5.0.1", 3043 | "has-yarn": "^2.1.0", 3044 | "import-lazy": "^2.1.0", 3045 | "is-ci": "^2.0.0", 3046 | "is-installed-globally": "^0.3.1", 3047 | "is-npm": "^4.0.0", 3048 | "is-yarn-global": "^0.3.0", 3049 | "latest-version": "^5.0.0", 3050 | "pupa": "^2.0.1", 3051 | "semver-diff": "^3.1.1", 3052 | "xdg-basedir": "^4.0.0" 3053 | } 3054 | }, 3055 | "url-parse-lax": { 3056 | "version": "3.0.0", 3057 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 3058 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 3059 | "requires": { 3060 | "prepend-http": "^2.0.0" 3061 | } 3062 | }, 3063 | "utils-merge": { 3064 | "version": "1.0.1", 3065 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 3066 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 3067 | }, 3068 | "vary": { 3069 | "version": "1.1.2", 3070 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 3071 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 3072 | }, 3073 | "widest-line": { 3074 | "version": "3.1.0", 3075 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 3076 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 3077 | "requires": { 3078 | "string-width": "^4.0.0" 3079 | } 3080 | }, 3081 | "wrappy": { 3082 | "version": "1.0.2", 3083 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3084 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 3085 | }, 3086 | "write-file-atomic": { 3087 | "version": "3.0.3", 3088 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 3089 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 3090 | "requires": { 3091 | "imurmurhash": "^0.1.4", 3092 | "is-typedarray": "^1.0.0", 3093 | "signal-exit": "^3.0.2", 3094 | "typedarray-to-buffer": "^3.1.5" 3095 | } 3096 | }, 3097 | "xdg-basedir": { 3098 | "version": "4.0.0", 3099 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 3100 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==" 3101 | } 3102 | } 3103 | } 3104 | -------------------------------------------------------------------------------- /server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "description": "This is the server side of Community Classroom.", 5 | "main": "server.js", 6 | "scripts": { 7 | "start": "nodemon --ignore constants/ server", 8 | "test": "echo \"Error: no test specified\" && exit 1" 9 | }, 10 | "keywords": [ 11 | "NodeJS", 12 | "ExpressJS", 13 | "REST", 14 | "API" 15 | ], 16 | "author": "Praveen Kumar", 17 | "license": "ISC", 18 | "dependencies": { 19 | "express": "^4.17.1", 20 | "express-session": "^1.17.2", 21 | "md5": "^2.3.0", 22 | "morgan": "^1.10.0", 23 | "nodemon": "^2.0.12" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /server/routes/api.js: -------------------------------------------------------------------------------- 1 | // Import Express JS library. 2 | const express = require("express"); 3 | // Create a Router App. 4 | const app = express.Router(); 5 | // Import the routes. 6 | const auth = require("./api/auth"); 7 | const users = require("./api/users"); 8 | 9 | // Create a Get Request handler for /. 10 | app.get("/", (req, res) => { 11 | res.json("Welcome to Community Classroom API!"); 12 | }); 13 | // Routes handler. 14 | app.use("/auth", auth); 15 | app.use("/users", users); 16 | 17 | // Export the Router. 18 | module.exports = app; 19 | -------------------------------------------------------------------------------- /server/routes/api/auth.js: -------------------------------------------------------------------------------- 1 | // Import Express JS library. 2 | const express = require("express"); 3 | const { 4 | CheckUserNamePassword, 5 | RegisterNewUser, 6 | VerifyUser 7 | } = require("../../helpers/Users"); 8 | // Create a Router App. 9 | const app = express.Router(); 10 | 11 | // Endpoint to Verify a User. 12 | app.get("/verify/:Username", (req, res) => { 13 | const Username = req.params.Username; 14 | const Code = req.query.Code; 15 | switch (VerifyUser(Username, Code)) { 16 | case -1: 17 | res.status(404).json({ 18 | Error: "User not found." 19 | }); 20 | break; 21 | case 0: 22 | res.status(400).json({ 23 | Error: "Invalid code or user has already been verified." 24 | }); 25 | break; 26 | case 1: 27 | res.json({ 28 | Message: "User successfully verified." 29 | }); 30 | break; 31 | } 32 | }); 33 | // Endpoint to check current logged in user. 34 | app.get("/login", (req, res) => { 35 | if (req.session.CurrentUser) { 36 | res.json(req.session.CurrentUser); 37 | } else { 38 | res.status(400).json({ 39 | Error: "Not Logged In." 40 | }); 41 | } 42 | }); 43 | // Endpoint to login a user. 44 | app.post("/login", (req, res) => { 45 | const { Username, Password } = req.body; 46 | if (!Username || !Password) { 47 | res.status(400).json({ 48 | Error: "Both Username and Password fields are mandatory." 49 | }); 50 | } else if (typeof Username === "string" && typeof Password === "string") { 51 | switch (CheckUserNamePassword(Username, Password)) { 52 | case 0: 53 | res.status(404).json({ 54 | Error: "User does not exist." 55 | }); 56 | req.session.CurrentUser = null; 57 | break; 58 | case -1: 59 | res.status(400).json({ 60 | Error: "Invalid username or password." 61 | }); 62 | req.session.CurrentUser = null; 63 | break; 64 | default: 65 | req.session.CurrentUser = CheckUserNamePassword(Username, Password); 66 | res.json(req.session.CurrentUser); 67 | } 68 | } else { 69 | res.status(400).json({ 70 | Error: 71 | "Both Username and Password fields are supposed to be string values." 72 | }); 73 | } 74 | }); 75 | // Endpoint to register a new user. 76 | app.post("/register", (req, res) => { 77 | const { Username, Password, Name, Email, Role } = req.body; 78 | if ( 79 | typeof Username === "string" && 80 | typeof Password === "string" && 81 | typeof Name === "string" && 82 | typeof Email === "string" && 83 | typeof Role === "string" 84 | ) { 85 | // User input is right. 86 | // Call the registration function. 87 | if (RegisterNewUser(Username, Password, Name, Email, Role)) { 88 | res.status(201).json({ 89 | Message: "User Created Successfully." 90 | }); 91 | } else { 92 | res.status(409).json({ 93 | Error: "Username already exists." 94 | }); 95 | } 96 | } else { 97 | // User input is wrong. 98 | res.status(400).json({ 99 | Error: "All five fields are mandatory and should be a string." 100 | }); 101 | } 102 | }); 103 | 104 | // Endpoint to logout a user. 105 | app.post("/logout", (req, res) => { 106 | req.session.CurrentUser = null; 107 | res.status(204).json({ 108 | Message: "User logged out successfully." 109 | }); 110 | }); 111 | // Export the Router. 112 | module.exports = app; 113 | -------------------------------------------------------------------------------- /server/routes/api/users.js: -------------------------------------------------------------------------------- 1 | const express = require("express"); 2 | const { ListAllUsers } = require("../../helpers/Users"); 3 | // Create a Router App. 4 | const app = express.Router(); 5 | 6 | // All users without password! 7 | const AllUsers = () => { 8 | const AllUsersObject = ListAllUsers(); 9 | const AllUsersArray = Object.keys(AllUsersObject).map(Username => { 10 | const CurUser = { 11 | Username, 12 | ...AllUsersObject[Username] 13 | }; 14 | delete CurUser.Password; 15 | if (CurUser.VerifyHash) { 16 | CurUser.VerifyHash = true; 17 | } 18 | return CurUser; 19 | }); 20 | return AllUsersArray; 21 | }; 22 | 23 | // List all the users endpoint. 24 | app.get("/", (req, res) => { 25 | if (req.session.CurrentUser) { 26 | res.json(AllUsers()); 27 | } else { 28 | res.status(400).json({ 29 | Error: "Not Logged In." 30 | }); 31 | } 32 | }); 33 | 34 | // Get one single user. 35 | app.get("/:Username", (req, res) => { 36 | if (req.session.CurrentUser) { 37 | const Username = req.params.Username.toLowerCase(); 38 | const User = AllUsers().find(user => user.Username === Username); 39 | if (User) { 40 | res.json(User); 41 | } else { 42 | res.status(404).json({ 43 | Error: "No such user exists." 44 | }); 45 | } 46 | } else { 47 | res.status(400).json({ 48 | Error: "Not Logged In." 49 | }); 50 | } 51 | }); 52 | 53 | // Export the Router. 54 | module.exports = app; 55 | -------------------------------------------------------------------------------- /server/routes/root.js: -------------------------------------------------------------------------------- 1 | // Import Express JS library. 2 | const express = require("express"); 3 | // Create a Router App. 4 | const app = express.Router(); 5 | // Import the routes. 6 | const api = require("./api"); 7 | 8 | // Create a Get Request handler for /. 9 | app.get("/", (req, res) => { 10 | res.json("Welcome to Community Classroom!"); 11 | }); 12 | 13 | // API routes handler. 14 | app.use("/api", api); 15 | 16 | // Export the Router. 17 | module.exports = app; 18 | -------------------------------------------------------------------------------- /server/server.js: -------------------------------------------------------------------------------- 1 | // Import the Express JS Framework. 2 | const express = require("express"); 3 | // Import Sessions. 4 | const session = require("express-session"); 5 | // Import Morgan. 6 | const morgan = require("morgan"); 7 | // Initialising an app instance. 8 | const app = express(); 9 | // Configure a port address. 10 | const port = 5000; 11 | // Import routes. 12 | const root = require("./routes/root"); 13 | 14 | // Add some custom middleware. 15 | app.use(express.json()); // for parsing application/json 16 | app.use(express.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded 17 | app.use(morgan("dev")); 18 | 19 | // Create a session config object. 20 | const SessionConfig = { 21 | secret: "c0mmun!7y Cl@ssr00m", 22 | resave: false, 23 | saveUninitialized: true, 24 | cookie: {} 25 | }; 26 | // If running in prod, do some extra secure stuff. 27 | // I am not even sure if the below condition shows true. 28 | if (app.get("env") === "production") { 29 | app.set("trust proxy", 1); // trust first proxy 30 | sess.cookie.secure = true; // serve secure cookies 31 | } 32 | // Initialise the middleware. 33 | app.use(session(SessionConfig)); 34 | 35 | // Add the routes as middleware - route handler. 36 | app.use("/", root); 37 | 38 | // Make the app listen to a port. 39 | app.listen(port, () => { 40 | console.log(`Server started in port ${port}.`); 41 | }); 42 | --------------------------------------------------------------------------------