├── .gitignore
├── README.md
├── client
├── .env
├── .eslintcache
├── README.md
├── package-lock.json
├── package.json
├── public
│ ├── favicon.ico
│ ├── index.html
│ ├── logo192.png
│ ├── logo512.png
│ ├── manifest.json
│ └── robots.txt
└── src
│ ├── App.js
│ ├── assets
│ ├── bigStar.png
│ └── star.png
│ ├── components
│ ├── AppRouter.js
│ ├── BrandBar.js
│ ├── DeviceItem.js
│ ├── DeviceList.js
│ ├── NavBar.js
│ ├── Pages.js
│ ├── TypeBar.js
│ └── modals
│ │ ├── CreateBrand.js
│ │ ├── CreateDevice.js
│ │ └── CreateType.js
│ ├── http
│ ├── deviceAPI.js
│ ├── index.js
│ └── userAPI.js
│ ├── index.js
│ ├── pages
│ ├── Admin.js
│ ├── Auth.js
│ ├── Basket.js
│ ├── DevicePage.js
│ └── Shop.js
│ ├── routes.js
│ ├── store
│ ├── DeviceStore.js
│ └── UserStore.js
│ └── utils
│ └── consts.js
└── server
├── .env
├── controllers
├── brandController.js
├── deviceController.js
├── typeController.js
└── userController.js
├── db.js
├── error
└── ApiError.js
├── index.js
├── middleware
├── ErrorHandlingMiddleware.js
├── authMiddleware.js
└── checkRoleMiddleware.js
├── models
└── models.js
├── package-lock.json
├── package.json
├── routes
├── brandRouter.js
├── deviceRouter.js
├── index.js
├── typeRouter.js
└── userRouter.js
└── static
├── 0c80d66c-3e86-402d-92f4-14f4a0d5d8c7.jpg
├── 0da16062-c12b-4c01-913b-ec3a60ba0b7a.jpg
├── 0edac1f1-766c-4490-9e8e-5dcc81fcb13f.jpg
├── 22e891e4-d020-4006-a60b-2be97b62672e.jpg
├── 25e8795f-cac0-46ed-904a-09cf83337a21.jpg
├── 33b8d5e9-2bbd-488b-8453-0652a3b5c889.jpg
├── 5101f28d-a388-4c0a-9be8-073e9570e99a.jpg
├── 935bb0a5-c599-4e2e-a2f3-373d5c0b9057.jpg
├── 963e7f53-3fb1-40e6-a6ef-5f45802cb72d.jpg
├── a4be5d23-292c-40c3-96b4-eba60e6e70f2.jpg
├── b7870f83-1156-4edb-99c2-7e0d952e33d6.jpg
├── c18e1353-0bf5-4ee3-b589-2f20678b3e12.jpg
├── d4d0f38e-495d-44ad-af60-bcc9641fcb02.jpg
└── e1646781-9115-417d-886d-976c2749a023.jpg
/.gitignore:
--------------------------------------------------------------------------------
1 | .idea
2 | /client/node_modules
3 | /client/.pnp
4 | /client/.pnp.js
5 |
6 |
7 | /coverage
8 |
9 | /build
10 |
11 | /client/.DS_Store
12 | /client/.env.local
13 | /client/.env.development.local
14 | /client/.env.test.local
15 | /client/.env.production.local
16 |
17 | /client/npm-debug.log*
18 | /client/yarn-debug.log*
19 | /client/yarn-error.log*
20 |
21 | /server/node_modules
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Не забудь поставить звезду
2 |
3 | ## npm run dev - запуск сервера
4 |
5 | ## npm start - запуск клиента
6 |
--------------------------------------------------------------------------------
/client/.env:
--------------------------------------------------------------------------------
1 | REACT_APP_API_URL='http://localhost:5000/'
2 |
--------------------------------------------------------------------------------
/client/.eslintcache:
--------------------------------------------------------------------------------
1 | [{"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\index.js":"1","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\App.js":"2","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\AppRouter.js":"3","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\routes.js":"4","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Basket.js":"5","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Shop.js":"6","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Admin.js":"7","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Auth.js":"8","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\DevicePage.js":"9","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\utils\\consts.js":"10","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\store\\UserStore.js":"11","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\store\\DeviceStore.js":"12","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\NavBar.js":"13","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\TypeBar.js":"14","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\BrandBar.js":"15","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\DeviceList.js":"16","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\DeviceItem.js":"17","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\modals\\CreateBrand.js":"18","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\modals\\CreateDevice.js":"19","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\modals\\CreateType.js":"20","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\http\\userAPI.js":"21","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\http\\index.js":"22","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\http\\deviceAPI.js":"23","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\Pages.js":"24"},{"size":439,"mtime":1611565726466,"results":"25","hashOfConfig":"26"},{"size":860,"mtime":1611566935762,"results":"27","hashOfConfig":"26"},{"size":820,"mtime":1611562949633,"results":"28","hashOfConfig":"26"},{"size":810,"mtime":1611558623082,"results":"29","hashOfConfig":"26"},{"size":157,"mtime":1611558335275,"results":"30","hashOfConfig":"26"},{"size":1586,"mtime":1611570048310,"results":"31","hashOfConfig":"26"},{"size":1591,"mtime":1611563479005,"results":"32","hashOfConfig":"26"},{"size":3224,"mtime":1611566592822,"results":"33","hashOfConfig":"26"},{"size":2282,"mtime":1611567992613,"results":"34","hashOfConfig":"26"},{"size":234,"mtime":1611558527514,"results":"35","hashOfConfig":"26"},{"size":424,"mtime":1611566488644,"results":"36","hashOfConfig":"26"},{"size":1363,"mtime":1611570449649,"results":"37","hashOfConfig":"26"},{"size":1897,"mtime":1611566993618,"results":"38","hashOfConfig":"26"},{"size":777,"mtime":1611560745463,"results":"39","hashOfConfig":"26"},{"size":785,"mtime":1611560987442,"results":"40","hashOfConfig":"26"},{"size":510,"mtime":1611561167368,"results":"41","hashOfConfig":"26"},{"size":1117,"mtime":1611567513135,"results":"42","hashOfConfig":"26"},{"size":1415,"mtime":1611568344902,"results":"43","hashOfConfig":"26"},{"size":6256,"mtime":1611569296961,"results":"44","hashOfConfig":"26"},{"size":1399,"mtime":1611568178381,"results":"45","hashOfConfig":"26"},{"size":715,"mtime":1611566683643,"results":"46","hashOfConfig":"26"},{"size":428,"mtime":1611565828865,"results":"47","hashOfConfig":"26"},{"size":1034,"mtime":1611569929150,"results":"48","hashOfConfig":"26"},{"size":831,"mtime":1611569858639,"results":"49","hashOfConfig":"26"},{"filePath":"50","messages":"51","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},"6tyl49",{"filePath":"52","messages":"53","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"54","messages":"55","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"57","messages":"58","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"59","messages":"60","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"61","messages":"62","errorCount":0,"warningCount":2,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"63","messages":"64","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"65","messages":"66","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":"67","usedDeprecatedRules":"56"},{"filePath":"68","messages":"69","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"70","messages":"71","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"72","messages":"73","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},{"filePath":"74","messages":"75","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},{"filePath":"76","messages":"77","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},{"filePath":"78","messages":"79","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":"80","usedDeprecatedRules":"56"},{"filePath":"81","messages":"82","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"83","messages":"84","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"85","messages":"86","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},{"filePath":"87","messages":"88","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"89","messages":"90","errorCount":0,"warningCount":2,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"91","messages":"92","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},{"filePath":"93","messages":"94","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"95","messages":"96","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"56"},{"filePath":"97","messages":"98","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"99","messages":"100","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\index.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\App.js",["101"],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\AppRouter.js",[],["102","103"],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\routes.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Basket.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Shop.js",["104","105"],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Admin.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\Auth.js",["106"],"import React, {useContext, useState} from 'react';\r\nimport {Container, Form} from \"react-bootstrap\";\r\nimport Card from \"react-bootstrap/Card\";\r\nimport Button from \"react-bootstrap/Button\";\r\nimport Row from \"react-bootstrap/Row\";\r\nimport {NavLink, useLocation, useHistory} from \"react-router-dom\";\r\nimport {LOGIN_ROUTE, REGISTRATION_ROUTE, SHOP_ROUTE} from \"../utils/consts\";\r\nimport {login, registration} from \"../http/userAPI\";\r\nimport {observer} from \"mobx-react-lite\";\r\nimport {Context} from \"../index\";\r\n\r\nconst Auth = observer(() => {\r\n const {user} = useContext(Context)\r\n const location = useLocation()\r\n const history = useHistory()\r\n const isLogin = location.pathname === LOGIN_ROUTE\r\n const [email, setEmail] = useState('')\r\n const [password, setPassword] = useState('')\r\n\r\n const click = async () => {\r\n try {\r\n let data;\r\n if (isLogin) {\r\n data = await login(email, password);\r\n } else {\r\n data = await registration(email, password);\r\n }\r\n user.setUser(user)\r\n user.setIsAuth(true)\r\n history.push(SHOP_ROUTE)\r\n } catch (e) {\r\n alert(e.response.data.message)\r\n }\r\n\r\n }\r\n\r\n return (\r\n \r\n \r\n {isLogin ? 'Авторизация' : \"Регистрация\"} \r\n setEmail(e.target.value)}\r\n />\r\n setPassword(e.target.value)}\r\n type=\"password\"\r\n />\r\n \r\n {isLogin ?\r\n \r\n Нет аккаунта? Зарегистрируйся! \r\n
\r\n :\r\n \r\n Есть аккаунт? Войдите! \r\n
\r\n }\r\n \r\n {isLogin ? 'Войти' : 'Регистрация'}\r\n \r\n
\r\n\r\n \r\n \r\n \r\n );\r\n});\r\n\r\nexport default Auth;\r\n","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\pages\\DevicePage.js",["107"],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\utils\\consts.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\store\\UserStore.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\store\\DeviceStore.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\NavBar.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\TypeBar.js",["108"],"import React, {useContext} from 'react';\r\nimport {observer} from \"mobx-react-lite\";\r\nimport {Context} from \"../index\";\r\nimport Col from \"react-bootstrap/Col\";\r\nimport ListGroup from \"react-bootstrap/ListGroup\";\r\n\r\nconst TypeBar = observer(() => {\r\n const {device} = useContext(Context)\r\n return (\r\n \r\n {device.types.map(type =>\r\n device.setSelectedType(type)}\r\n key={type.id}\r\n >\r\n {type.name}\r\n \r\n )}\r\n \r\n );\r\n});\r\n\r\nexport default TypeBar;\r\n","C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\BrandBar.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\DeviceList.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\DeviceItem.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\modals\\CreateBrand.js",["109"],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\modals\\CreateDevice.js",["110","111"],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\modals\\CreateType.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\http\\userAPI.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\http\\index.js",[],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\http\\deviceAPI.js",["112"],"C:\\Users\\tim\\Desktop\\javascript\\online-store-course\\client\\src\\components\\Pages.js",[],{"ruleId":"113","severity":1,"message":"114","line":19,"column":8,"nodeType":"115","endLine":19,"endColumn":10,"suggestions":"116"},{"ruleId":"117","replacedBy":"118"},{"ruleId":"119","replacedBy":"120"},{"ruleId":"113","severity":1,"message":"121","line":23,"column":8,"nodeType":"115","endLine":23,"endColumn":10,"suggestions":"122"},{"ruleId":"113","severity":1,"message":"121","line":30,"column":8,"nodeType":"115","endLine":30,"endColumn":65,"suggestions":"123"},{"ruleId":"124","severity":1,"message":"125","line":26,"column":17,"nodeType":"126","messageId":"127","endLine":26,"endColumn":21},{"ruleId":"113","severity":1,"message":"128","line":12,"column":8,"nodeType":"115","endLine":12,"endColumn":10,"suggestions":"129"},{"ruleId":"124","severity":1,"message":"130","line":4,"column":8,"nodeType":"126","messageId":"127","endLine":4,"endColumn":11},{"ruleId":"124","severity":1,"message":"131","line":4,"column":22,"nodeType":"126","messageId":"127","endLine":4,"endColumn":32},{"ruleId":"124","severity":1,"message":"132","line":5,"column":36,"nodeType":"126","messageId":"127","endLine":5,"endColumn":48},{"ruleId":"113","severity":1,"message":"121","line":18,"column":8,"nodeType":"115","endLine":18,"endColumn":10,"suggestions":"133"},{"ruleId":"124","severity":1,"message":"134","line":2,"column":8,"nodeType":"126","messageId":"127","endLine":2,"endColumn":18},"react-hooks/exhaustive-deps","React Hook useEffect has a missing dependency: 'user'. Either include it or remove the dependency array.","ArrayExpression",["135"],"no-native-reassign",["136"],"no-negated-in-lhs",["137"],"React Hook useEffect has a missing dependency: 'device'. Either include it or remove the dependency array.",["138"],["139"],"no-unused-vars","'data' is assigned a value but never used.","Identifier","unusedVar","React Hook useEffect has a missing dependency: 'id'. Either include it or remove the dependency array.",["140"],"'Col' is defined but never used.","'createType' is defined but never used.","'fetchDevices' is defined but never used.",["141"],"'jwt_decode' is defined but never used.",{"desc":"142","fix":"143"},"no-global-assign","no-unsafe-negation",{"desc":"144","fix":"145"},{"desc":"146","fix":"147"},{"desc":"148","fix":"149"},{"desc":"144","fix":"150"},"Update the dependencies array to be: [user]",{"range":"151","text":"152"},"Update the dependencies array to be: [device]",{"range":"153","text":"154"},"Update the dependencies array to be: [device.page, device.selectedType, device.selectedBrand, device]",{"range":"155","text":"156"},"Update the dependencies array to be: [id]",{"range":"157","text":"158"},{"range":"159","text":"154"},[641,643],"[user]",[897,899],"[device]",[1136,1193],"[device.page, device.selectedType, device.selectedBrand, device]",[468,470],"[id]",[764,766]]
--------------------------------------------------------------------------------
/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 | "private": true,
5 | "dependencies": {
6 | "@testing-library/jest-dom": "^5.11.9",
7 | "@testing-library/react": "^11.2.3",
8 | "@testing-library/user-event": "^12.6.2",
9 | "axios": "^0.21.1",
10 | "bootstrap": "^4.6.0",
11 | "jwt-decode": "^3.1.2",
12 | "mobx": "^6.0.5",
13 | "mobx-react-lite": "^3.1.7",
14 | "react": "^17.0.1",
15 | "react-bootstrap": "^1.4.3",
16 | "react-dom": "^17.0.1",
17 | "react-router-dom": "^5.2.0",
18 | "react-scripts": "4.0.1",
19 | "web-vitals": "^0.2.4"
20 | },
21 | "scripts": {
22 | "start": "react-scripts start",
23 | "build": "react-scripts build",
24 | "test": "react-scripts test",
25 | "eject": "react-scripts eject"
26 | },
27 | "eslintConfig": {
28 | "extends": [
29 | "react-app",
30 | "react-app/jest"
31 | ]
32 | },
33 | "browserslist": {
34 | "production": [
35 | ">0.2%",
36 | "not dead",
37 | "not op_mini all"
38 | ],
39 | "development": [
40 | "last 1 chrome version",
41 | "last 1 firefox version",
42 | "last 1 safari version"
43 | ]
44 | }
45 | }
46 |
--------------------------------------------------------------------------------
/client/public/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/client/public/favicon.ico
--------------------------------------------------------------------------------
/client/public/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
12 | React App
13 |
14 |
15 | You need to enable JavaScript to run this app.
16 |
17 |
18 |
19 |
--------------------------------------------------------------------------------
/client/public/logo192.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/client/public/logo192.png
--------------------------------------------------------------------------------
/client/public/logo512.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/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/App.js:
--------------------------------------------------------------------------------
1 | import React, {useContext, useEffect, useState} from 'react';
2 | import {BrowserRouter} from "react-router-dom";
3 | import AppRouter from "./components/AppRouter";
4 | import NavBar from "./components/NavBar";
5 | import {observer} from "mobx-react-lite";
6 | import {Context} from "./index";
7 | import {check} from "./http/userAPI";
8 | import {Spinner} from "react-bootstrap";
9 |
10 | const App = observer(() => {
11 | const {user} = useContext(Context)
12 | const [loading, setLoading] = useState(true)
13 |
14 | useEffect(() => {
15 | check().then(data => {
16 | user.setUser(true)
17 | user.setIsAuth(true)
18 | }).finally(() => setLoading(false))
19 | }, [])
20 |
21 | if (loading) {
22 | return
23 | }
24 |
25 | return (
26 |
27 |
28 |
29 |
30 | );
31 | });
32 |
33 | export default App;
34 |
--------------------------------------------------------------------------------
/client/src/assets/bigStar.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/client/src/assets/bigStar.png
--------------------------------------------------------------------------------
/client/src/assets/star.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/client/src/assets/star.png
--------------------------------------------------------------------------------
/client/src/components/AppRouter.js:
--------------------------------------------------------------------------------
1 | import React, {useContext} from 'react';
2 | import {Switch, Route, Redirect} from 'react-router-dom'
3 | import {authRoutes, publicRoutes} from "../routes";
4 | import {SHOP_ROUTE} from "../utils/consts";
5 | import {Context} from "../index";
6 | import {observer} from "mobx-react-lite";
7 |
8 | const AppRouter = observer(() => {
9 | const {user} = useContext(Context)
10 |
11 | console.log(user)
12 | return (
13 |
14 | {user.isAuth && authRoutes.map(({path, Component}) =>
15 |
16 | )}
17 | {publicRoutes.map(({path, Component}) =>
18 |
19 | )}
20 |
21 |
22 | );
23 | });
24 |
25 | export default AppRouter;
26 |
--------------------------------------------------------------------------------
/client/src/components/BrandBar.js:
--------------------------------------------------------------------------------
1 | import React, {useContext} from 'react';
2 | import {observer} from "mobx-react-lite";
3 | import {Context} from "../index";
4 | import {Card, Row} from "react-bootstrap";
5 |
6 | const BrandBar = observer(() => {
7 | const {device} = useContext(Context)
8 |
9 | return (
10 |
11 | {device.brands.map(brand =>
12 | device.setSelectedBrand(brand)}
17 | border={brand.id === device.selectedBrand.id ? 'danger' : 'light'}
18 | >
19 | {brand.name}
20 |
21 | )}
22 |
23 | );
24 | });
25 |
26 | export default BrandBar;
27 |
--------------------------------------------------------------------------------
/client/src/components/DeviceItem.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import {Card, Col} from "react-bootstrap";
3 | import Image from "react-bootstrap/Image";
4 | import star from '../assets/star.png'
5 | import {useHistory} from "react-router-dom"
6 | import {DEVICE_ROUTE} from "../utils/consts";
7 |
8 | const DeviceItem = ({device}) => {
9 | const history = useHistory()
10 | return (
11 | history.push(DEVICE_ROUTE + '/' + device.id)}>
12 |
13 |
14 |
15 |
Samsung...
16 |
17 |
{device.rating}
18 |
19 |
20 |
21 | {device.name}
22 |
23 |
24 | );
25 | };
26 |
27 | export default DeviceItem;
28 |
--------------------------------------------------------------------------------
/client/src/components/DeviceList.js:
--------------------------------------------------------------------------------
1 | import React, {useContext} from 'react';
2 | import {observer} from "mobx-react-lite";
3 | import {Context} from "../index";
4 | import {Row} from "react-bootstrap";
5 | import DeviceItem from "./DeviceItem";
6 |
7 | const DeviceList = observer(() => {
8 | const {device} = useContext(Context)
9 |
10 | return (
11 |
12 | {device.devices.map(device =>
13 |
14 | )}
15 |
16 | );
17 | });
18 |
19 | export default DeviceList;
20 |
--------------------------------------------------------------------------------
/client/src/components/NavBar.js:
--------------------------------------------------------------------------------
1 | import React, {useContext} from 'react';
2 | import {Context} from "../index";
3 | import Navbar from "react-bootstrap/Navbar";
4 | import Nav from "react-bootstrap/Nav";
5 | import {NavLink} from "react-router-dom";
6 | import {ADMIN_ROUTE, LOGIN_ROUTE, SHOP_ROUTE} from "../utils/consts";
7 | import {Button} from "react-bootstrap";
8 | import {observer} from "mobx-react-lite";
9 | import Container from "react-bootstrap/Container";
10 | import {useHistory} from 'react-router-dom'
11 | const NavBar = observer(() => {
12 | const {user} = useContext(Context)
13 | const history = useHistory()
14 |
15 | const logOut = () => {
16 | user.setUser({})
17 | user.setIsAuth(false)
18 | }
19 |
20 | return (
21 |
22 |
23 | КупиДевайс
24 | {user.isAuth ?
25 |
26 | history.push(ADMIN_ROUTE)}
29 | >
30 | Админ панель
31 |
32 | logOut()}
35 | className="ml-2"
36 | >
37 | Выйти
38 |
39 |
40 | :
41 |
42 | history.push(LOGIN_ROUTE)}>Авторизация
43 |
44 | }
45 |
46 |
47 |
48 | );
49 | });
50 |
51 | export default NavBar;
52 |
--------------------------------------------------------------------------------
/client/src/components/Pages.js:
--------------------------------------------------------------------------------
1 | import React, {useContext} from 'react';
2 | import {observer} from "mobx-react-lite";
3 | import {Context} from "../index";
4 | import {Pagination} from "react-bootstrap";
5 |
6 | const Pages = observer(() => {
7 | const {device} = useContext(Context)
8 | const pageCount = Math.ceil(device.totalCount / device.limit)
9 | const pages = []
10 |
11 | for (let i = 0; i < pageCount; i++) {
12 | pages.push(i + 1)
13 | }
14 |
15 | return (
16 |
17 | {pages.map(page =>
18 | device.setPage(page)}
22 | >
23 | {page}
24 |
25 | )}
26 |
27 | );
28 | });
29 |
30 | export default Pages;
31 |
--------------------------------------------------------------------------------
/client/src/components/TypeBar.js:
--------------------------------------------------------------------------------
1 | import React, {useContext} from 'react';
2 | import {observer} from "mobx-react-lite";
3 | import {Context} from "../index";
4 | import Col from "react-bootstrap/Col";
5 | import ListGroup from "react-bootstrap/ListGroup";
6 |
7 | const TypeBar = observer(() => {
8 | const {device} = useContext(Context)
9 | return (
10 |
11 | {device.types.map(type =>
12 | device.setSelectedType(type)}
16 | key={type.id}
17 | >
18 | {type.name}
19 |
20 | )}
21 |
22 | );
23 | });
24 |
25 | export default TypeBar;
26 |
--------------------------------------------------------------------------------
/client/src/components/modals/CreateBrand.js:
--------------------------------------------------------------------------------
1 | import React, {useState} from 'react';
2 | import Modal from "react-bootstrap/Modal";
3 | import {Button, Form} from "react-bootstrap";
4 | import {createBrand, createType} from "../../http/deviceAPI";
5 |
6 | const CreateBrand = ({show, onHide}) => {
7 | const [value, setValue] = useState('')
8 |
9 | const addBrand = () => {
10 | createBrand({name: value}).then(data => {
11 | setValue('')
12 | onHide()
13 | })
14 | }
15 | return (
16 |
21 |
22 |
23 | Добавить тип
24 |
25 |
26 |
27 | setValue(e.target.value)}
31 | placeholder={"Введите название типа"}
32 | />
33 |
34 |
35 |
36 | Закрыть
37 | Добавить
38 |
39 |
40 | );
41 | };
42 |
43 | export default CreateBrand;
44 |
--------------------------------------------------------------------------------
/client/src/components/modals/CreateDevice.js:
--------------------------------------------------------------------------------
1 | import React, {useContext, useEffect, useState} from 'react';
2 | import Modal from "react-bootstrap/Modal";
3 | import {Button, Dropdown, Form, Row, Col} from "react-bootstrap";
4 | import {Context} from "../../index";
5 | import {createDevice, fetchBrands, fetchDevices, fetchTypes} from "../../http/deviceAPI";
6 | import {observer} from "mobx-react-lite";
7 |
8 | const CreateDevice = observer(({show, onHide}) => {
9 | const {device} = useContext(Context)
10 | const [name, setName] = useState('')
11 | const [price, setPrice] = useState(0)
12 | const [file, setFile] = useState(null)
13 | const [info, setInfo] = useState([])
14 |
15 | useEffect(() => {
16 | fetchTypes().then(data => device.setTypes(data))
17 | fetchBrands().then(data => device.setBrands(data))
18 | }, [])
19 |
20 | const addInfo = () => {
21 | setInfo([...info, {title: '', description: '', number: Date.now()}])
22 | }
23 | const removeInfo = (number) => {
24 | setInfo(info.filter(i => i.number !== number))
25 | }
26 | const changeInfo = (key, value, number) => {
27 | setInfo(info.map(i => i.number === number ? {...i, [key]: value} : i))
28 | }
29 |
30 | const selectFile = e => {
31 | setFile(e.target.files[0])
32 | }
33 |
34 | const addDevice = () => {
35 | const formData = new FormData()
36 | formData.append('name', name)
37 | formData.append('price', `${price}`)
38 | formData.append('img', file)
39 | formData.append('brandId', device.selectedBrand.id)
40 | formData.append('typeId', device.selectedType.id)
41 | formData.append('info', JSON.stringify(info))
42 | createDevice(formData).then(data => onHide())
43 | }
44 |
45 | return (
46 |
51 |
52 |
53 | Добавить устройство
54 |
55 |
56 |
57 | setName(e.target.value)}
87 | className="mt-3"
88 | placeholder="Введите название устройства"
89 | />
90 | setPrice(Number(e.target.value))}
93 | className="mt-3"
94 | placeholder="Введите стоимость устройства"
95 | type="number"
96 | />
97 |
102 |
103 |
107 | Добавить новое свойство
108 |
109 | {info.map(i =>
110 |
111 |
112 | changeInfo('title', e.target.value, i.number)}
115 | placeholder="Введите название свойства"
116 | />
117 |
118 |
119 | changeInfo('description', e.target.value, i.number)}
122 | placeholder="Введите описание свойства"
123 | />
124 |
125 |
126 | removeInfo(i.number)}
128 | variant={"outline-danger"}
129 | >
130 | Удалить
131 |
132 |
133 |
134 | )}
135 |
136 |
137 |
138 | Закрыть
139 | Добавить
140 |
141 |
142 | );
143 | });
144 |
145 | export default CreateDevice;
146 |
--------------------------------------------------------------------------------
/client/src/components/modals/CreateType.js:
--------------------------------------------------------------------------------
1 | import React, {useState} from 'react';
2 | import Modal from "react-bootstrap/Modal";
3 | import {Form, Button} from "react-bootstrap";
4 | import {createType} from "../../http/deviceAPI";
5 |
6 | const CreateType = ({show, onHide}) => {
7 | const [value, setValue] = useState('')
8 |
9 | const addType = () => {
10 | createType({name: value}).then(data => {
11 | setValue('')
12 | onHide()
13 | })
14 | }
15 |
16 | return (
17 |
22 |
23 |
24 | Добавить тип
25 |
26 |
27 |
28 | setValue(e.target.value)}
32 | placeholder={"Введите название типа"}
33 | />
34 |
35 |
36 |
37 | Закрыть
38 | Добавить
39 |
40 |
41 | );
42 | };
43 |
44 | export default CreateType;
45 |
--------------------------------------------------------------------------------
/client/src/http/deviceAPI.js:
--------------------------------------------------------------------------------
1 | import {$authHost, $host} from "./index";
2 | import jwt_decode from "jwt-decode";
3 |
4 | export const createType = async (type) => {
5 | const {data} = await $authHost.post('api/type', type)
6 | return data
7 | }
8 |
9 | export const fetchTypes = async () => {
10 | const {data} = await $host.get('api/type')
11 | return data
12 | }
13 |
14 | export const createBrand = async (brand) => {
15 | const {data} = await $authHost.post('api/brand', brand)
16 | return data
17 | }
18 |
19 | export const fetchBrands = async () => {
20 | const {data} = await $host.get('api/brand', )
21 | return data
22 | }
23 |
24 | export const createDevice = async (device) => {
25 | const {data} = await $authHost.post('api/device', device)
26 | return data
27 | }
28 |
29 | export const fetchDevices = async (typeId, brandId, page, limit= 5) => {
30 | const {data} = await $host.get('api/device', {params: {
31 | typeId, brandId, page, limit
32 | }})
33 | return data
34 | }
35 |
36 | export const fetchOneDevice = async (id) => {
37 | const {data} = await $host.get('api/device/' + id)
38 | return data
39 | }
40 |
--------------------------------------------------------------------------------
/client/src/http/index.js:
--------------------------------------------------------------------------------
1 | import axios from "axios";
2 |
3 | const $host = axios.create({
4 | baseURL: process.env.REACT_APP_API_URL
5 | })
6 |
7 | const $authHost = axios.create({
8 | baseURL: process.env.REACT_APP_API_URL
9 | })
10 |
11 | const authInterceptor = config => {
12 | config.headers.authorization = `Bearer ${localStorage.getItem('token')}`
13 | return config
14 | }
15 |
16 | $authHost.interceptors.request.use(authInterceptor)
17 |
18 | export {
19 | $host,
20 | $authHost
21 | }
22 |
--------------------------------------------------------------------------------
/client/src/http/userAPI.js:
--------------------------------------------------------------------------------
1 | import {$authHost, $host} from "./index";
2 | import jwt_decode from "jwt-decode";
3 |
4 | export const registration = async (email, password) => {
5 | const {data} = await $host.post('api/user/registration', {email, password, role: 'ADMIN'})
6 | localStorage.setItem('token', data.token)
7 | return jwt_decode(data.token)
8 | }
9 |
10 | export const login = async (email, password) => {
11 | const {data} = await $host.post('api/user/login', {email, password})
12 | localStorage.setItem('token', data.token)
13 | return jwt_decode(data.token)
14 | }
15 |
16 | export const check = async () => {
17 | const {data} = await $authHost.get('api/user/auth' )
18 | localStorage.setItem('token', data.token)
19 | return jwt_decode(data.token)
20 | }
21 |
--------------------------------------------------------------------------------
/client/src/index.js:
--------------------------------------------------------------------------------
1 | import React, {createContext} from 'react';
2 | import ReactDOM from 'react-dom';
3 | import App from './App';
4 | import UserStore from "./store/UserStore";
5 | import DeviceStore from "./store/DeviceStore";
6 |
7 | export const Context = createContext(null)
8 |
9 | ReactDOM.render(
10 |
14 |
15 | ,
16 | document.getElementById('root')
17 | );
18 |
19 |
--------------------------------------------------------------------------------
/client/src/pages/Admin.js:
--------------------------------------------------------------------------------
1 | import React, {useState} from 'react';
2 | import {Button, Container} from "react-bootstrap";
3 | import CreateBrand from "../components/modals/CreateBrand";
4 | import CreateDevice from "../components/modals/CreateDevice";
5 | import CreateType from "../components/modals/CreateType";
6 |
7 | const Admin = () => {
8 | const [brandVisible, setBrandVisible] = useState(false)
9 | const [typeVisible, setTypeVisible] = useState(false)
10 | const [deviceVisible, setDeviceVisible] = useState(false)
11 |
12 | return (
13 |
14 | setTypeVisible(true)}
18 | >
19 | Добавить тип
20 |
21 | setBrandVisible(true)}
25 | >
26 | Добавить бренд
27 |
28 | setDeviceVisible(true)}
32 | >
33 | Добавить устройство
34 |
35 | setBrandVisible(false)}/>
36 | setDeviceVisible(false)}/>
37 | setTypeVisible(false)}/>
38 |
39 | );
40 | };
41 |
42 | export default Admin;
43 |
--------------------------------------------------------------------------------
/client/src/pages/Auth.js:
--------------------------------------------------------------------------------
1 | import React, {useContext, useState} from 'react';
2 | import {Container, Form} from "react-bootstrap";
3 | import Card from "react-bootstrap/Card";
4 | import Button from "react-bootstrap/Button";
5 | import Row from "react-bootstrap/Row";
6 | import {NavLink, useLocation, useHistory} from "react-router-dom";
7 | import {LOGIN_ROUTE, REGISTRATION_ROUTE, SHOP_ROUTE} from "../utils/consts";
8 | import {login, registration} from "../http/userAPI";
9 | import {observer} from "mobx-react-lite";
10 | import {Context} from "../index";
11 |
12 | const Auth = observer(() => {
13 | const {user} = useContext(Context)
14 | const location = useLocation()
15 | const history = useHistory()
16 | const isLogin = location.pathname === LOGIN_ROUTE
17 | const [email, setEmail] = useState('')
18 | const [password, setPassword] = useState('')
19 |
20 | const click = async () => {
21 | try {
22 | let data;
23 | if (isLogin) {
24 | data = await login(email, password);
25 | } else {
26 | data = await registration(email, password);
27 | }
28 | user.setUser(user)
29 | user.setIsAuth(true)
30 | history.push(SHOP_ROUTE)
31 | } catch (e) {
32 | alert(e.response.data.message)
33 | }
34 |
35 | }
36 |
37 | return (
38 |
42 |
43 | {isLogin ? 'Авторизация' : "Регистрация"}
44 | setEmail(e.target.value)}
50 | />
51 | setPassword(e.target.value)}
56 | type="password"
57 | />
58 |
59 | {isLogin ?
60 |
61 | Нет аккаунта? Зарегистрируйся!
62 |
63 | :
64 |
65 | Есть аккаунт? Войдите!
66 |
67 | }
68 |
72 | {isLogin ? 'Войти' : 'Регистрация'}
73 |
74 |
75 |
76 |
77 |
78 |
79 | );
80 | });
81 |
82 | export default Auth;
83 |
--------------------------------------------------------------------------------
/client/src/pages/Basket.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 |
3 | const Basket = () => {
4 | return (
5 |
6 | basket
7 |
8 | );
9 | };
10 |
11 | export default Basket;
12 |
--------------------------------------------------------------------------------
/client/src/pages/DevicePage.js:
--------------------------------------------------------------------------------
1 | import React, {useEffect, useState} from 'react';
2 | import {Button, Card, Col, Container, Image, Row} from "react-bootstrap";
3 | import bigStar from '../assets/bigStar.png'
4 | import {useParams} from 'react-router-dom'
5 | import {fetchOneDevice} from "../http/deviceAPI";
6 |
7 | const DevicePage = () => {
8 | const [device, setDevice] = useState({info: []})
9 | const {id} = useParams()
10 | useEffect(() => {
11 | fetchOneDevice(id).then(data => setDevice(data))
12 | }, [])
13 |
14 | return (
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 | {device.name}
23 |
27 | {device.rating}
28 |
29 |
30 |
31 |
32 |
36 | От: {device.price} руб.
37 | Добавить в корзину
38 |
39 |
40 |
41 |
42 | Характеристики
43 | {device.info.map((info, index) =>
44 |
45 | {info.title}: {info.description}
46 |
47 | )}
48 |
49 |
50 | );
51 | };
52 |
53 | export default DevicePage;
54 |
--------------------------------------------------------------------------------
/client/src/pages/Shop.js:
--------------------------------------------------------------------------------
1 | import React, {useContext, useEffect} from 'react';
2 | import {Container} from "react-bootstrap";
3 | import Row from "react-bootstrap/Row";
4 | import Col from "react-bootstrap/Col";
5 | import TypeBar from "../components/TypeBar";
6 | import BrandBar from "../components/BrandBar";
7 | import DeviceList from "../components/DeviceList";
8 | import {observer} from "mobx-react-lite";
9 | import {Context} from "../index";
10 | import {fetchBrands, fetchDevices, fetchTypes} from "../http/deviceAPI";
11 | import Pages from "../components/Pages";
12 |
13 | const Shop = observer(() => {
14 | const {device} = useContext(Context)
15 |
16 | useEffect(() => {
17 | fetchTypes().then(data => device.setTypes(data))
18 | fetchBrands().then(data => device.setBrands(data))
19 | fetchDevices(null, null, 1, 2).then(data => {
20 | device.setDevices(data.rows)
21 | device.setTotalCount(data.count)
22 | })
23 | }, [])
24 |
25 | useEffect(() => {
26 | fetchDevices(device.selectedType.id, device.selectedBrand.id, device.page, 2).then(data => {
27 | device.setDevices(data.rows)
28 | device.setTotalCount(data.count)
29 | })
30 | }, [device.page, device.selectedType, device.selectedBrand,])
31 |
32 | return (
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 | );
46 | });
47 |
48 | export default Shop;
49 |
--------------------------------------------------------------------------------
/client/src/routes.js:
--------------------------------------------------------------------------------
1 | import Admin from "./pages/Admin";
2 | import {ADMIN_ROUTE, BASKET_ROUTE, DEVICE_ROUTE, LOGIN_ROUTE, REGISTRATION_ROUTE, SHOP_ROUTE} from "./utils/consts";
3 | import Basket from "./pages/Basket";
4 | import Shop from "./pages/Shop";
5 | import Auth from "./pages/Auth";
6 | import DevicePage from "./pages/DevicePage";
7 |
8 | export const authRoutes = [
9 | {
10 | path: ADMIN_ROUTE,
11 | Component: Admin
12 | },
13 | {
14 | path: BASKET_ROUTE,
15 | Component: Basket
16 | },
17 | ]
18 |
19 | export const publicRoutes = [
20 | {
21 | path: SHOP_ROUTE,
22 | Component: Shop
23 | },
24 | {
25 | path: LOGIN_ROUTE,
26 | Component: Auth
27 | },
28 | {
29 | path: REGISTRATION_ROUTE,
30 | Component: Auth
31 | },
32 | {
33 | path: DEVICE_ROUTE + '/:id',
34 | Component: DevicePage
35 | },
36 | ]
37 |
--------------------------------------------------------------------------------
/client/src/store/DeviceStore.js:
--------------------------------------------------------------------------------
1 | import {makeAutoObservable} from "mobx";
2 |
3 | export default class DeviceStore {
4 | constructor() {
5 | this._types = []
6 | this._brands = []
7 | this._devices = []
8 | this._selectedType = {}
9 | this._selectedBrand = {}
10 | this._page = 1
11 | this._totalCount = 0
12 | this._limit = 3
13 | makeAutoObservable(this)
14 | }
15 |
16 | setTypes(types) {
17 | this._types = types
18 | }
19 | setBrands(brands) {
20 | this._brands = brands
21 | }
22 | setDevices(devices) {
23 | this._devices = devices
24 | }
25 |
26 | setSelectedType(type) {
27 | this.setPage(1)
28 | this._selectedType = type
29 | }
30 | setSelectedBrand(brand) {
31 | this.setPage(1)
32 | this._selectedBrand = brand
33 | }
34 | setPage(page) {
35 | this._page = page
36 | }
37 | setTotalCount(count) {
38 | this._totalCount = count
39 | }
40 |
41 | get types() {
42 | return this._types
43 | }
44 | get brands() {
45 | return this._brands
46 | }
47 | get devices() {
48 | return this._devices
49 | }
50 | get selectedType() {
51 | return this._selectedType
52 | }
53 | get selectedBrand() {
54 | return this._selectedBrand
55 | }
56 | get totalCount() {
57 | return this._totalCount
58 | }
59 | get page() {
60 | return this._page
61 | }
62 | get limit() {
63 | return this._limit
64 | }
65 | }
66 |
--------------------------------------------------------------------------------
/client/src/store/UserStore.js:
--------------------------------------------------------------------------------
1 | import {makeAutoObservable} from "mobx";
2 |
3 | export default class UserStore {
4 | constructor() {
5 | this._isAuth = false
6 | this._user = {}
7 | makeAutoObservable(this)
8 | }
9 |
10 | setIsAuth(bool) {
11 | this._isAuth = bool
12 | }
13 | setUser(user) {
14 | this._user = user
15 | }
16 |
17 | get isAuth() {
18 | return this._isAuth
19 | }
20 | get user() {
21 | return this._user
22 | }
23 | }
24 |
--------------------------------------------------------------------------------
/client/src/utils/consts.js:
--------------------------------------------------------------------------------
1 | export const ADMIN_ROUTE = '/admin'
2 | export const LOGIN_ROUTE = '/login'
3 | export const REGISTRATION_ROUTE = '/registration'
4 | export const SHOP_ROUTE = '/'
5 | export const BASKET_ROUTE = '/basket'
6 | export const DEVICE_ROUTE = '/device'
7 |
--------------------------------------------------------------------------------
/server/.env:
--------------------------------------------------------------------------------
1 | PORT=5000
2 | DB_NAME=online_store
3 | DB_USER=postgres
4 | DB_PASSWORD=root
5 | DB_HOST=localhost
6 | DB_PORT=5432
7 | SECRET_KEY=random_secret_key123
8 |
--------------------------------------------------------------------------------
/server/controllers/brandController.js:
--------------------------------------------------------------------------------
1 | const {Brand} = require('../models/models')
2 | const ApiError = require('../error/ApiError');
3 |
4 | class BrandController {
5 | async create(req, res) {
6 | const {name} = req.body
7 | const brand = await Brand.create({name})
8 | return res.json(brand)
9 | }
10 |
11 | async getAll(req, res) {
12 | const brands = await Brand.findAll()
13 | return res.json(brands)
14 | }
15 |
16 | }
17 |
18 | module.exports = new BrandController()
19 |
--------------------------------------------------------------------------------
/server/controllers/deviceController.js:
--------------------------------------------------------------------------------
1 | const uuid = require('uuid')
2 | const path = require('path');
3 | const {Device, DeviceInfo} = require('../models/models')
4 | const ApiError = require('../error/ApiError');
5 |
6 | class DeviceController {
7 | async create(req, res, next) {
8 | try {
9 | let {name, price, brandId, typeId, info} = req.body
10 | const {img} = req.files
11 | let fileName = uuid.v4() + ".jpg"
12 | img.mv(path.resolve(__dirname, '..', 'static', fileName))
13 | const device = await Device.create({name, price, brandId, typeId, img: fileName});
14 |
15 | if (info) {
16 | info = JSON.parse(info)
17 | info.forEach(i =>
18 | DeviceInfo.create({
19 | title: i.title,
20 | description: i.description,
21 | deviceId: device.id
22 | })
23 | )
24 | }
25 |
26 | return res.json(device)
27 | } catch (e) {
28 | next(ApiError.badRequest(e.message))
29 | }
30 |
31 | }
32 |
33 | async getAll(req, res) {
34 | let {brandId, typeId, limit, page} = req.query
35 | page = page || 1
36 | limit = limit || 9
37 | let offset = page * limit - limit
38 | let devices;
39 | if (!brandId && !typeId) {
40 | devices = await Device.findAndCountAll({limit, offset})
41 | }
42 | if (brandId && !typeId) {
43 | devices = await Device.findAndCountAll({where:{brandId}, limit, offset})
44 | }
45 | if (!brandId && typeId) {
46 | devices = await Device.findAndCountAll({where:{typeId}, limit, offset})
47 | }
48 | if (brandId && typeId) {
49 | devices = await Device.findAndCountAll({where:{typeId, brandId}, limit, offset})
50 | }
51 | return res.json(devices)
52 | }
53 |
54 | async getOne(req, res) {
55 | const {id} = req.params
56 | const device = await Device.findOne(
57 | {
58 | where: {id},
59 | include: [{model: DeviceInfo, as: 'info'}]
60 | },
61 | )
62 | return res.json(device)
63 | }
64 | }
65 |
66 | module.exports = new DeviceController()
67 |
--------------------------------------------------------------------------------
/server/controllers/typeController.js:
--------------------------------------------------------------------------------
1 | const {Type} = require('../models/models')
2 | const ApiError = require('../error/ApiError');
3 |
4 | class TypeController {
5 | async create(req, res) {
6 | const {name} = req.body
7 | const type = await Type.create({name})
8 | return res.json(type)
9 | }
10 |
11 | async getAll(req, res) {
12 | const types = await Type.findAll()
13 | return res.json(types)
14 | }
15 |
16 | }
17 |
18 | module.exports = new TypeController()
19 |
--------------------------------------------------------------------------------
/server/controllers/userController.js:
--------------------------------------------------------------------------------
1 | const ApiError = require('../error/ApiError');
2 | const bcrypt = require('bcrypt')
3 | const jwt = require('jsonwebtoken')
4 | const {User, Basket} = require('../models/models')
5 |
6 | const generateJwt = (id, email, role) => {
7 | return jwt.sign(
8 | {id, email, role},
9 | process.env.SECRET_KEY,
10 | {expiresIn: '24h'}
11 | )
12 | }
13 |
14 | class UserController {
15 | async registration(req, res, next) {
16 | const {email, password, role} = req.body
17 | if (!email || !password) {
18 | return next(ApiError.badRequest('Некорректный email или password'))
19 | }
20 | const candidate = await User.findOne({where: {email}})
21 | if (candidate) {
22 | return next(ApiError.badRequest('Пользователь с таким email уже существует'))
23 | }
24 | const hashPassword = await bcrypt.hash(password, 5)
25 | const user = await User.create({email, role, password: hashPassword})
26 | const basket = await Basket.create({userId: user.id})
27 | const token = generateJwt(user.id, user.email, user.role)
28 | return res.json({token})
29 | }
30 |
31 | async login(req, res, next) {
32 | const {email, password} = req.body
33 | const user = await User.findOne({where: {email}})
34 | if (!user) {
35 | return next(ApiError.internal('Пользователь не найден'))
36 | }
37 | let comparePassword = bcrypt.compareSync(password, user.password)
38 | if (!comparePassword) {
39 | return next(ApiError.internal('Указан неверный пароль'))
40 | }
41 | const token = generateJwt(user.id, user.email, user.role)
42 | return res.json({token})
43 | }
44 |
45 | async check(req, res, next) {
46 | const token = generateJwt(req.user.id, req.user.email, req.user.role)
47 | return res.json({token})
48 | }
49 | }
50 |
51 | module.exports = new UserController()
52 |
--------------------------------------------------------------------------------
/server/db.js:
--------------------------------------------------------------------------------
1 | const {Sequelize} = require('sequelize')
2 |
3 | module.exports = new Sequelize(
4 | process.env.DB_NAME, // Название БД
5 | process.env.DB_USER, // Пользователь
6 | process.env.DB_PASSWORD, // ПАРОЛЬ
7 | {
8 | dialect: 'postgres',
9 | host: process.env.DB_HOST,
10 | port: process.env.DB_PORT
11 | }
12 | )
13 |
--------------------------------------------------------------------------------
/server/error/ApiError.js:
--------------------------------------------------------------------------------
1 | class ApiError extends Error{
2 | constructor(status, message) {
3 | super();
4 | this.status = status
5 | this.message = message
6 | }
7 |
8 | static badRequest(message) {
9 | return new ApiError(404, message)
10 | }
11 |
12 | static internal(message) {
13 | return new ApiError(500, message)
14 | }
15 |
16 | static forbidden(message) {
17 | return new ApiError(403, message)
18 | }
19 | }
20 |
21 | module.exports = ApiError
22 |
--------------------------------------------------------------------------------
/server/index.js:
--------------------------------------------------------------------------------
1 | require('dotenv').config()
2 | const express = require('express')
3 | const sequelize = require('./db')
4 | const models = require('./models/models')
5 | const cors = require('cors')
6 | const fileUpload = require('express-fileupload')
7 | const router = require('./routes/index')
8 | const errorHandler = require('./middleware/ErrorHandlingMiddleware')
9 | const path = require('path')
10 |
11 | const PORT = process.env.PORT || 5000
12 |
13 | const app = express()
14 | app.use(cors())
15 | app.use(express.json())
16 | app.use(express.static(path.resolve(__dirname, 'static')))
17 | app.use(fileUpload({}))
18 | app.use('/api', router)
19 |
20 | // Обработка ошибок, последний Middleware
21 | app.use(errorHandler)
22 |
23 | const start = async () => {
24 | try {
25 | await sequelize.authenticate()
26 | await sequelize.sync()
27 | app.listen(PORT, () => console.log(`Server started on port ${PORT}`))
28 | } catch (e) {
29 | console.log(e)
30 | }
31 | }
32 |
33 |
34 | start()
35 |
--------------------------------------------------------------------------------
/server/middleware/ErrorHandlingMiddleware.js:
--------------------------------------------------------------------------------
1 | const ApiError = require('../error/ApiError');
2 |
3 | module.exports = function (err, req, res, next) {
4 | if (err instanceof ApiError) {
5 | return res.status(err.status).json({message: err.message})
6 | }
7 | return res.status(500).json({message: "Непредвиденная ошибка!"})
8 | }
9 |
--------------------------------------------------------------------------------
/server/middleware/authMiddleware.js:
--------------------------------------------------------------------------------
1 | const jwt = require('jsonwebtoken')
2 |
3 | module.exports = function (req, res, next) {
4 | if (req.method === "OPTIONS") {
5 | next()
6 | }
7 | try {
8 | const token = req.headers.authorization.split(' ')[1] // Bearer asfasnfkajsfnjk
9 | if (!token) {
10 | return res.status(401).json({message: "Не авторизован"})
11 | }
12 | const decoded = jwt.verify(token, process.env.SECRET_KEY)
13 | req.user = decoded
14 | next()
15 | } catch (e) {
16 | res.status(401).json({message: "Не авторизован"})
17 | }
18 | };
19 |
--------------------------------------------------------------------------------
/server/middleware/checkRoleMiddleware.js:
--------------------------------------------------------------------------------
1 | const jwt = require('jsonwebtoken')
2 |
3 | module.exports = function(role) {
4 | return function (req, res, next) {
5 | if (req.method === "OPTIONS") {
6 | next()
7 | }
8 | try {
9 | const token = req.headers.authorization.split(' ')[1] // Bearer asfasnfkajsfnjk
10 | if (!token) {
11 | return res.status(401).json({message: "Не авторизован"})
12 | }
13 | const decoded = jwt.verify(token, process.env.SECRET_KEY)
14 | if (decoded.role !== role) {
15 | return res.status(403).json({message: "Нет доступа"})
16 | }
17 | req.user = decoded;
18 | next()
19 | } catch (e) {
20 | res.status(401).json({message: "Не авторизован"})
21 | }
22 | };
23 | }
24 |
25 |
26 |
27 |
--------------------------------------------------------------------------------
/server/models/models.js:
--------------------------------------------------------------------------------
1 | const sequelize = require('../db')
2 | const {DataTypes} = require('sequelize')
3 |
4 | const User = sequelize.define('user', {
5 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
6 | email: {type: DataTypes.STRING, unique: true,},
7 | password: {type: DataTypes.STRING},
8 | role: {type: DataTypes.STRING, defaultValue: "USER"},
9 | })
10 |
11 | const Basket = sequelize.define('basket', {
12 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
13 | })
14 |
15 | const BasketDevice = sequelize.define('basket_device', {
16 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
17 | })
18 |
19 | const Device = sequelize.define('device', {
20 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
21 | name: {type: DataTypes.STRING, unique: true, allowNull: false},
22 | price: {type: DataTypes.INTEGER, allowNull: false},
23 | rating: {type: DataTypes.INTEGER, defaultValue: 0},
24 | img: {type: DataTypes.STRING, allowNull: false},
25 | })
26 |
27 | const Type = sequelize.define('type', {
28 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
29 | name: {type: DataTypes.STRING, unique: true, allowNull: false},
30 | })
31 |
32 | const Brand = sequelize.define('brand', {
33 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
34 | name: {type: DataTypes.STRING, unique: true, allowNull: false},
35 | })
36 |
37 | const Rating = sequelize.define('rating', {
38 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
39 | rate: {type: DataTypes.INTEGER, allowNull: false},
40 | })
41 |
42 | const DeviceInfo = sequelize.define('device_info', {
43 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
44 | title: {type: DataTypes.STRING, allowNull: false},
45 | description: {type: DataTypes.STRING, allowNull: false},
46 | })
47 |
48 | const TypeBrand = sequelize.define('type_brand', {
49 | id: {type: DataTypes.INTEGER, primaryKey: true, autoIncrement: true},
50 | })
51 |
52 |
53 | User.hasOne(Basket)
54 | Basket.belongsTo(User)
55 |
56 | User.hasMany(Rating)
57 | Rating.belongsTo(User)
58 |
59 | Basket.hasMany(BasketDevice)
60 | BasketDevice.belongsTo(Basket)
61 |
62 | Type.hasMany(Device)
63 | Device.belongsTo(Type)
64 |
65 | Brand.hasMany(Device)
66 | Device.belongsTo(Brand)
67 |
68 | Device.hasMany(Rating)
69 | Rating.belongsTo(Device)
70 |
71 | Device.hasMany(BasketDevice)
72 | BasketDevice.belongsTo(Device)
73 |
74 | Device.hasMany(DeviceInfo, {as: 'info'});
75 | DeviceInfo.belongsTo(Device)
76 |
77 | Type.belongsToMany(Brand, {through: TypeBrand })
78 | Brand.belongsToMany(Type, {through: TypeBrand })
79 |
80 | module.exports = {
81 | User,
82 | Basket,
83 | BasketDevice,
84 | Device,
85 | Type,
86 | Brand,
87 | Rating,
88 | TypeBrand,
89 | DeviceInfo
90 | }
91 |
92 |
93 |
94 |
95 |
96 |
--------------------------------------------------------------------------------
/server/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "server",
3 | "version": "1.0.0",
4 | "lockfileVersion": 1,
5 | "requires": true,
6 | "dependencies": {
7 | "@sindresorhus/is": {
8 | "version": "0.14.0",
9 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz",
10 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==",
11 | "dev": true
12 | },
13 | "@szmarczak/http-timer": {
14 | "version": "1.1.2",
15 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz",
16 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==",
17 | "dev": true,
18 | "requires": {
19 | "defer-to-connect": "^1.0.1"
20 | }
21 | },
22 | "@types/node": {
23 | "version": "14.14.22",
24 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.14.22.tgz",
25 | "integrity": "sha512-g+f/qj/cNcqKkc3tFqlXOYjrmZA+jNBiDzbP3kH+B+otKFqAdPgVTGP1IeKRdMml/aE69as5S4FqtxAbl+LaMw=="
26 | },
27 | "abbrev": {
28 | "version": "1.1.1",
29 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
30 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q=="
31 | },
32 | "accepts": {
33 | "version": "1.3.7",
34 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz",
35 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==",
36 | "requires": {
37 | "mime-types": "~2.1.24",
38 | "negotiator": "0.6.2"
39 | }
40 | },
41 | "ansi-align": {
42 | "version": "3.0.0",
43 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.0.tgz",
44 | "integrity": "sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw==",
45 | "dev": true,
46 | "requires": {
47 | "string-width": "^3.0.0"
48 | },
49 | "dependencies": {
50 | "string-width": {
51 | "version": "3.1.0",
52 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz",
53 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==",
54 | "dev": true,
55 | "requires": {
56 | "emoji-regex": "^7.0.1",
57 | "is-fullwidth-code-point": "^2.0.0",
58 | "strip-ansi": "^5.1.0"
59 | }
60 | }
61 | }
62 | },
63 | "ansi-regex": {
64 | "version": "4.1.0",
65 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz",
66 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==",
67 | "dev": true
68 | },
69 | "ansi-styles": {
70 | "version": "4.3.0",
71 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
72 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
73 | "dev": true,
74 | "requires": {
75 | "color-convert": "^2.0.1"
76 | }
77 | },
78 | "any-promise": {
79 | "version": "1.3.0",
80 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz",
81 | "integrity": "sha1-q8av7tzqUugJzcA3au0845Y10X8="
82 | },
83 | "anymatch": {
84 | "version": "3.1.1",
85 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz",
86 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==",
87 | "dev": true,
88 | "requires": {
89 | "normalize-path": "^3.0.0",
90 | "picomatch": "^2.0.4"
91 | }
92 | },
93 | "aproba": {
94 | "version": "1.2.0",
95 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz",
96 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw=="
97 | },
98 | "are-we-there-yet": {
99 | "version": "1.1.5",
100 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz",
101 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==",
102 | "requires": {
103 | "delegates": "^1.0.0",
104 | "readable-stream": "^2.0.6"
105 | },
106 | "dependencies": {
107 | "readable-stream": {
108 | "version": "2.3.7",
109 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz",
110 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==",
111 | "requires": {
112 | "core-util-is": "~1.0.0",
113 | "inherits": "~2.0.3",
114 | "isarray": "~1.0.0",
115 | "process-nextick-args": "~2.0.0",
116 | "safe-buffer": "~5.1.1",
117 | "string_decoder": "~1.1.1",
118 | "util-deprecate": "~1.0.1"
119 | }
120 | },
121 | "string_decoder": {
122 | "version": "1.1.1",
123 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
124 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
125 | "requires": {
126 | "safe-buffer": "~5.1.0"
127 | }
128 | }
129 | }
130 | },
131 | "array-flatten": {
132 | "version": "1.1.1",
133 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
134 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
135 | },
136 | "balanced-match": {
137 | "version": "1.0.0",
138 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
139 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c="
140 | },
141 | "bcrypt": {
142 | "version": "5.0.0",
143 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.0.0.tgz",
144 | "integrity": "sha512-jB0yCBl4W/kVHM2whjfyqnxTmOHkCX4kHEa5nYKSoGeYe8YrjTYTc87/6bwt1g8cmV0QrbhKriETg9jWtcREhg==",
145 | "requires": {
146 | "node-addon-api": "^3.0.0",
147 | "node-pre-gyp": "0.15.0"
148 | }
149 | },
150 | "binary-extensions": {
151 | "version": "2.2.0",
152 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
153 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
154 | "dev": true
155 | },
156 | "body-parser": {
157 | "version": "1.19.0",
158 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz",
159 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==",
160 | "requires": {
161 | "bytes": "3.1.0",
162 | "content-type": "~1.0.4",
163 | "debug": "2.6.9",
164 | "depd": "~1.1.2",
165 | "http-errors": "1.7.2",
166 | "iconv-lite": "0.4.24",
167 | "on-finished": "~2.3.0",
168 | "qs": "6.7.0",
169 | "raw-body": "2.4.0",
170 | "type-is": "~1.6.17"
171 | }
172 | },
173 | "boxen": {
174 | "version": "4.2.0",
175 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz",
176 | "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==",
177 | "dev": true,
178 | "requires": {
179 | "ansi-align": "^3.0.0",
180 | "camelcase": "^5.3.1",
181 | "chalk": "^3.0.0",
182 | "cli-boxes": "^2.2.0",
183 | "string-width": "^4.1.0",
184 | "term-size": "^2.1.0",
185 | "type-fest": "^0.8.1",
186 | "widest-line": "^3.1.0"
187 | }
188 | },
189 | "brace-expansion": {
190 | "version": "1.1.11",
191 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
192 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
193 | "requires": {
194 | "balanced-match": "^1.0.0",
195 | "concat-map": "0.0.1"
196 | }
197 | },
198 | "braces": {
199 | "version": "3.0.2",
200 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
201 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
202 | "dev": true,
203 | "requires": {
204 | "fill-range": "^7.0.1"
205 | }
206 | },
207 | "buffer-equal-constant-time": {
208 | "version": "1.0.1",
209 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz",
210 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk="
211 | },
212 | "buffer-writer": {
213 | "version": "2.0.0",
214 | "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz",
215 | "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw=="
216 | },
217 | "busboy": {
218 | "version": "0.3.1",
219 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-0.3.1.tgz",
220 | "integrity": "sha512-y7tTxhGKXcyBxRKAni+awqx8uqaJKrSFSNFSeRG5CsWNdmy2BIK+6VGWEW7TZnIO/533mtMEA4rOevQV815YJw==",
221 | "requires": {
222 | "dicer": "0.3.0"
223 | }
224 | },
225 | "bytes": {
226 | "version": "3.1.0",
227 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz",
228 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg=="
229 | },
230 | "cacheable-request": {
231 | "version": "6.1.0",
232 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz",
233 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==",
234 | "dev": true,
235 | "requires": {
236 | "clone-response": "^1.0.2",
237 | "get-stream": "^5.1.0",
238 | "http-cache-semantics": "^4.0.0",
239 | "keyv": "^3.0.0",
240 | "lowercase-keys": "^2.0.0",
241 | "normalize-url": "^4.1.0",
242 | "responselike": "^1.0.2"
243 | },
244 | "dependencies": {
245 | "get-stream": {
246 | "version": "5.2.0",
247 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz",
248 | "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==",
249 | "dev": true,
250 | "requires": {
251 | "pump": "^3.0.0"
252 | }
253 | },
254 | "lowercase-keys": {
255 | "version": "2.0.0",
256 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz",
257 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==",
258 | "dev": true
259 | }
260 | }
261 | },
262 | "camelcase": {
263 | "version": "5.3.1",
264 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
265 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
266 | "dev": true
267 | },
268 | "chalk": {
269 | "version": "3.0.0",
270 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz",
271 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==",
272 | "dev": true,
273 | "requires": {
274 | "ansi-styles": "^4.1.0",
275 | "supports-color": "^7.1.0"
276 | },
277 | "dependencies": {
278 | "has-flag": {
279 | "version": "4.0.0",
280 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
281 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
282 | "dev": true
283 | },
284 | "supports-color": {
285 | "version": "7.2.0",
286 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
287 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
288 | "dev": true,
289 | "requires": {
290 | "has-flag": "^4.0.0"
291 | }
292 | }
293 | }
294 | },
295 | "chokidar": {
296 | "version": "3.5.1",
297 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.1.tgz",
298 | "integrity": "sha512-9+s+Od+W0VJJzawDma/gvBNQqkTiqYTWLuZoyAsivsI4AaWTCzHG06/TMjsf1cYe9Cb97UCEhjz7HvnPk2p/tw==",
299 | "dev": true,
300 | "requires": {
301 | "anymatch": "~3.1.1",
302 | "braces": "~3.0.2",
303 | "fsevents": "~2.3.1",
304 | "glob-parent": "~5.1.0",
305 | "is-binary-path": "~2.1.0",
306 | "is-glob": "~4.0.1",
307 | "normalize-path": "~3.0.0",
308 | "readdirp": "~3.5.0"
309 | }
310 | },
311 | "chownr": {
312 | "version": "1.1.4",
313 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz",
314 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg=="
315 | },
316 | "ci-info": {
317 | "version": "2.0.0",
318 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz",
319 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==",
320 | "dev": true
321 | },
322 | "cli-boxes": {
323 | "version": "2.2.1",
324 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz",
325 | "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==",
326 | "dev": true
327 | },
328 | "clone-response": {
329 | "version": "1.0.2",
330 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz",
331 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=",
332 | "dev": true,
333 | "requires": {
334 | "mimic-response": "^1.0.0"
335 | }
336 | },
337 | "code-point-at": {
338 | "version": "1.1.0",
339 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz",
340 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c="
341 | },
342 | "color-convert": {
343 | "version": "2.0.1",
344 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
345 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
346 | "dev": true,
347 | "requires": {
348 | "color-name": "~1.1.4"
349 | }
350 | },
351 | "color-name": {
352 | "version": "1.1.4",
353 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
354 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
355 | "dev": true
356 | },
357 | "concat-map": {
358 | "version": "0.0.1",
359 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
360 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s="
361 | },
362 | "configstore": {
363 | "version": "5.0.1",
364 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz",
365 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==",
366 | "dev": true,
367 | "requires": {
368 | "dot-prop": "^5.2.0",
369 | "graceful-fs": "^4.1.2",
370 | "make-dir": "^3.0.0",
371 | "unique-string": "^2.0.0",
372 | "write-file-atomic": "^3.0.0",
373 | "xdg-basedir": "^4.0.0"
374 | }
375 | },
376 | "console-control-strings": {
377 | "version": "1.1.0",
378 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz",
379 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4="
380 | },
381 | "content-disposition": {
382 | "version": "0.5.3",
383 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz",
384 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==",
385 | "requires": {
386 | "safe-buffer": "5.1.2"
387 | }
388 | },
389 | "content-type": {
390 | "version": "1.0.4",
391 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
392 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA=="
393 | },
394 | "cookie": {
395 | "version": "0.4.0",
396 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz",
397 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg=="
398 | },
399 | "cookie-signature": {
400 | "version": "1.0.6",
401 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
402 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
403 | },
404 | "core-util-is": {
405 | "version": "1.0.2",
406 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
407 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac="
408 | },
409 | "cors": {
410 | "version": "2.8.5",
411 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz",
412 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==",
413 | "requires": {
414 | "object-assign": "^4",
415 | "vary": "^1"
416 | }
417 | },
418 | "crypto-random-string": {
419 | "version": "2.0.0",
420 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz",
421 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==",
422 | "dev": true
423 | },
424 | "debug": {
425 | "version": "2.6.9",
426 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
427 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
428 | "requires": {
429 | "ms": "2.0.0"
430 | }
431 | },
432 | "decompress-response": {
433 | "version": "3.3.0",
434 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz",
435 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=",
436 | "dev": true,
437 | "requires": {
438 | "mimic-response": "^1.0.0"
439 | }
440 | },
441 | "deep-extend": {
442 | "version": "0.6.0",
443 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
444 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA=="
445 | },
446 | "defer-to-connect": {
447 | "version": "1.1.3",
448 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz",
449 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==",
450 | "dev": true
451 | },
452 | "delegates": {
453 | "version": "1.0.0",
454 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz",
455 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o="
456 | },
457 | "depd": {
458 | "version": "1.1.2",
459 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
460 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak="
461 | },
462 | "destroy": {
463 | "version": "1.0.4",
464 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
465 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
466 | },
467 | "detect-libc": {
468 | "version": "1.0.3",
469 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz",
470 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups="
471 | },
472 | "dicer": {
473 | "version": "0.3.0",
474 | "resolved": "https://registry.npmjs.org/dicer/-/dicer-0.3.0.tgz",
475 | "integrity": "sha512-MdceRRWqltEG2dZqO769g27N/3PXfcKl04VhYnBlo2YhH7zPi88VebsjTKclaOyiuMaGU72hTfw3VkUitGcVCA==",
476 | "requires": {
477 | "streamsearch": "0.1.2"
478 | }
479 | },
480 | "dot-prop": {
481 | "version": "5.3.0",
482 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz",
483 | "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==",
484 | "dev": true,
485 | "requires": {
486 | "is-obj": "^2.0.0"
487 | }
488 | },
489 | "dotenv": {
490 | "version": "8.2.0",
491 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz",
492 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw=="
493 | },
494 | "dottie": {
495 | "version": "2.0.2",
496 | "resolved": "https://registry.npmjs.org/dottie/-/dottie-2.0.2.tgz",
497 | "integrity": "sha512-fmrwR04lsniq/uSr8yikThDTrM7epXHBAAjH9TbeH3rEA8tdCO7mRzB9hdmdGyJCxF8KERo9CITcm3kGuoyMhg=="
498 | },
499 | "duplexer3": {
500 | "version": "0.1.4",
501 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz",
502 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=",
503 | "dev": true
504 | },
505 | "ecdsa-sig-formatter": {
506 | "version": "1.0.11",
507 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz",
508 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==",
509 | "requires": {
510 | "safe-buffer": "^5.0.1"
511 | }
512 | },
513 | "ee-first": {
514 | "version": "1.1.1",
515 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
516 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
517 | },
518 | "emoji-regex": {
519 | "version": "7.0.3",
520 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz",
521 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==",
522 | "dev": true
523 | },
524 | "encodeurl": {
525 | "version": "1.0.2",
526 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
527 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k="
528 | },
529 | "end-of-stream": {
530 | "version": "1.4.4",
531 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
532 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
533 | "dev": true,
534 | "requires": {
535 | "once": "^1.4.0"
536 | }
537 | },
538 | "escape-goat": {
539 | "version": "2.1.1",
540 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz",
541 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==",
542 | "dev": true
543 | },
544 | "escape-html": {
545 | "version": "1.0.3",
546 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
547 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
548 | },
549 | "etag": {
550 | "version": "1.8.1",
551 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
552 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc="
553 | },
554 | "express": {
555 | "version": "4.17.1",
556 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz",
557 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==",
558 | "requires": {
559 | "accepts": "~1.3.7",
560 | "array-flatten": "1.1.1",
561 | "body-parser": "1.19.0",
562 | "content-disposition": "0.5.3",
563 | "content-type": "~1.0.4",
564 | "cookie": "0.4.0",
565 | "cookie-signature": "1.0.6",
566 | "debug": "2.6.9",
567 | "depd": "~1.1.2",
568 | "encodeurl": "~1.0.2",
569 | "escape-html": "~1.0.3",
570 | "etag": "~1.8.1",
571 | "finalhandler": "~1.1.2",
572 | "fresh": "0.5.2",
573 | "merge-descriptors": "1.0.1",
574 | "methods": "~1.1.2",
575 | "on-finished": "~2.3.0",
576 | "parseurl": "~1.3.3",
577 | "path-to-regexp": "0.1.7",
578 | "proxy-addr": "~2.0.5",
579 | "qs": "6.7.0",
580 | "range-parser": "~1.2.1",
581 | "safe-buffer": "5.1.2",
582 | "send": "0.17.1",
583 | "serve-static": "1.14.1",
584 | "setprototypeof": "1.1.1",
585 | "statuses": "~1.5.0",
586 | "type-is": "~1.6.18",
587 | "utils-merge": "1.0.1",
588 | "vary": "~1.1.2"
589 | }
590 | },
591 | "express-fileupload": {
592 | "version": "1.2.1",
593 | "resolved": "https://registry.npmjs.org/express-fileupload/-/express-fileupload-1.2.1.tgz",
594 | "integrity": "sha512-fWPNAkBj+Azt9Itmcz/Reqdg3LeBfaXptDEev2JM8bCC0yDptglCnlizhf0YZauyU5X/g6v7v4Xxqhg8tmEfEA==",
595 | "requires": {
596 | "busboy": "^0.3.1"
597 | }
598 | },
599 | "fill-range": {
600 | "version": "7.0.1",
601 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
602 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
603 | "dev": true,
604 | "requires": {
605 | "to-regex-range": "^5.0.1"
606 | }
607 | },
608 | "finalhandler": {
609 | "version": "1.1.2",
610 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz",
611 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==",
612 | "requires": {
613 | "debug": "2.6.9",
614 | "encodeurl": "~1.0.2",
615 | "escape-html": "~1.0.3",
616 | "on-finished": "~2.3.0",
617 | "parseurl": "~1.3.3",
618 | "statuses": "~1.5.0",
619 | "unpipe": "~1.0.0"
620 | }
621 | },
622 | "forwarded": {
623 | "version": "0.1.2",
624 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz",
625 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ="
626 | },
627 | "fresh": {
628 | "version": "0.5.2",
629 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
630 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac="
631 | },
632 | "fs-minipass": {
633 | "version": "1.2.7",
634 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz",
635 | "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==",
636 | "requires": {
637 | "minipass": "^2.6.0"
638 | }
639 | },
640 | "fs.realpath": {
641 | "version": "1.0.0",
642 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
643 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8="
644 | },
645 | "fsevents": {
646 | "version": "2.3.1",
647 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.1.tgz",
648 | "integrity": "sha512-YR47Eg4hChJGAB1O3yEAOkGO+rlzutoICGqGo9EZ4lKWokzZRSyIW1QmTzqjtw8MJdj9srP869CuWw/hyzSiBw==",
649 | "dev": true,
650 | "optional": true
651 | },
652 | "gauge": {
653 | "version": "2.7.4",
654 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz",
655 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=",
656 | "requires": {
657 | "aproba": "^1.0.3",
658 | "console-control-strings": "^1.0.0",
659 | "has-unicode": "^2.0.0",
660 | "object-assign": "^4.1.0",
661 | "signal-exit": "^3.0.0",
662 | "string-width": "^1.0.1",
663 | "strip-ansi": "^3.0.1",
664 | "wide-align": "^1.1.0"
665 | },
666 | "dependencies": {
667 | "ansi-regex": {
668 | "version": "2.1.1",
669 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
670 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8="
671 | },
672 | "is-fullwidth-code-point": {
673 | "version": "1.0.0",
674 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz",
675 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
676 | "requires": {
677 | "number-is-nan": "^1.0.0"
678 | }
679 | },
680 | "string-width": {
681 | "version": "1.0.2",
682 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz",
683 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
684 | "requires": {
685 | "code-point-at": "^1.0.0",
686 | "is-fullwidth-code-point": "^1.0.0",
687 | "strip-ansi": "^3.0.0"
688 | }
689 | },
690 | "strip-ansi": {
691 | "version": "3.0.1",
692 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
693 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
694 | "requires": {
695 | "ansi-regex": "^2.0.0"
696 | }
697 | }
698 | }
699 | },
700 | "get-stream": {
701 | "version": "4.1.0",
702 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
703 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
704 | "dev": true,
705 | "requires": {
706 | "pump": "^3.0.0"
707 | }
708 | },
709 | "glob": {
710 | "version": "7.1.6",
711 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz",
712 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==",
713 | "requires": {
714 | "fs.realpath": "^1.0.0",
715 | "inflight": "^1.0.4",
716 | "inherits": "2",
717 | "minimatch": "^3.0.4",
718 | "once": "^1.3.0",
719 | "path-is-absolute": "^1.0.0"
720 | }
721 | },
722 | "glob-parent": {
723 | "version": "5.1.1",
724 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz",
725 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==",
726 | "dev": true,
727 | "requires": {
728 | "is-glob": "^4.0.1"
729 | }
730 | },
731 | "global-dirs": {
732 | "version": "2.1.0",
733 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.1.0.tgz",
734 | "integrity": "sha512-MG6kdOUh/xBnyo9cJFeIKkLEc1AyFq42QTU4XiX51i2NEdxLxLWXIjEjmqKeSuKR7pAZjTqUVoT2b2huxVLgYQ==",
735 | "dev": true,
736 | "requires": {
737 | "ini": "1.3.7"
738 | }
739 | },
740 | "got": {
741 | "version": "9.6.0",
742 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz",
743 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==",
744 | "dev": true,
745 | "requires": {
746 | "@sindresorhus/is": "^0.14.0",
747 | "@szmarczak/http-timer": "^1.1.2",
748 | "cacheable-request": "^6.0.0",
749 | "decompress-response": "^3.3.0",
750 | "duplexer3": "^0.1.4",
751 | "get-stream": "^4.1.0",
752 | "lowercase-keys": "^1.0.1",
753 | "mimic-response": "^1.0.1",
754 | "p-cancelable": "^1.0.0",
755 | "to-readable-stream": "^1.0.0",
756 | "url-parse-lax": "^3.0.0"
757 | }
758 | },
759 | "graceful-fs": {
760 | "version": "4.2.4",
761 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz",
762 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==",
763 | "dev": true
764 | },
765 | "has-flag": {
766 | "version": "3.0.0",
767 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
768 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
769 | "dev": true
770 | },
771 | "has-unicode": {
772 | "version": "2.0.1",
773 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz",
774 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk="
775 | },
776 | "has-yarn": {
777 | "version": "2.1.0",
778 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz",
779 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==",
780 | "dev": true
781 | },
782 | "http-cache-semantics": {
783 | "version": "4.1.0",
784 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz",
785 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==",
786 | "dev": true
787 | },
788 | "http-errors": {
789 | "version": "1.7.2",
790 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz",
791 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==",
792 | "requires": {
793 | "depd": "~1.1.2",
794 | "inherits": "2.0.3",
795 | "setprototypeof": "1.1.1",
796 | "statuses": ">= 1.5.0 < 2",
797 | "toidentifier": "1.0.0"
798 | }
799 | },
800 | "iconv-lite": {
801 | "version": "0.4.24",
802 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
803 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
804 | "requires": {
805 | "safer-buffer": ">= 2.1.2 < 3"
806 | }
807 | },
808 | "ignore-by-default": {
809 | "version": "1.0.1",
810 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz",
811 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=",
812 | "dev": true
813 | },
814 | "ignore-walk": {
815 | "version": "3.0.3",
816 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz",
817 | "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==",
818 | "requires": {
819 | "minimatch": "^3.0.4"
820 | }
821 | },
822 | "import-lazy": {
823 | "version": "2.1.0",
824 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz",
825 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=",
826 | "dev": true
827 | },
828 | "imurmurhash": {
829 | "version": "0.1.4",
830 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
831 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
832 | "dev": true
833 | },
834 | "inflection": {
835 | "version": "1.12.0",
836 | "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.12.0.tgz",
837 | "integrity": "sha1-ogCTVlbW9fa8TcdQLhrstwMihBY="
838 | },
839 | "inflight": {
840 | "version": "1.0.6",
841 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
842 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
843 | "requires": {
844 | "once": "^1.3.0",
845 | "wrappy": "1"
846 | }
847 | },
848 | "inherits": {
849 | "version": "2.0.3",
850 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
851 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
852 | },
853 | "ini": {
854 | "version": "1.3.7",
855 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.7.tgz",
856 | "integrity": "sha512-iKpRpXP+CrP2jyrxvg1kMUpXDyRUFDWurxbnVT1vQPx+Wz9uCYsMIqYuSBLV+PAaZG/d7kRLKRFc9oDMsH+mFQ=="
857 | },
858 | "ipaddr.js": {
859 | "version": "1.9.1",
860 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
861 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g=="
862 | },
863 | "is-binary-path": {
864 | "version": "2.1.0",
865 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
866 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
867 | "dev": true,
868 | "requires": {
869 | "binary-extensions": "^2.0.0"
870 | }
871 | },
872 | "is-ci": {
873 | "version": "2.0.0",
874 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz",
875 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==",
876 | "dev": true,
877 | "requires": {
878 | "ci-info": "^2.0.0"
879 | }
880 | },
881 | "is-extglob": {
882 | "version": "2.1.1",
883 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
884 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
885 | "dev": true
886 | },
887 | "is-fullwidth-code-point": {
888 | "version": "2.0.0",
889 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz",
890 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8="
891 | },
892 | "is-glob": {
893 | "version": "4.0.1",
894 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz",
895 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==",
896 | "dev": true,
897 | "requires": {
898 | "is-extglob": "^2.1.1"
899 | }
900 | },
901 | "is-installed-globally": {
902 | "version": "0.3.2",
903 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.2.tgz",
904 | "integrity": "sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g==",
905 | "dev": true,
906 | "requires": {
907 | "global-dirs": "^2.0.1",
908 | "is-path-inside": "^3.0.1"
909 | }
910 | },
911 | "is-npm": {
912 | "version": "4.0.0",
913 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz",
914 | "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==",
915 | "dev": true
916 | },
917 | "is-number": {
918 | "version": "7.0.0",
919 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
920 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
921 | "dev": true
922 | },
923 | "is-obj": {
924 | "version": "2.0.0",
925 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz",
926 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==",
927 | "dev": true
928 | },
929 | "is-path-inside": {
930 | "version": "3.0.2",
931 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.2.tgz",
932 | "integrity": "sha512-/2UGPSgmtqwo1ktx8NDHjuPwZWmHhO+gj0f93EkhLB5RgW9RZevWYYlIkS6zePc6U2WpOdQYIwHe9YC4DWEBVg==",
933 | "dev": true
934 | },
935 | "is-typedarray": {
936 | "version": "1.0.0",
937 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
938 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=",
939 | "dev": true
940 | },
941 | "is-yarn-global": {
942 | "version": "0.3.0",
943 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz",
944 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==",
945 | "dev": true
946 | },
947 | "isarray": {
948 | "version": "1.0.0",
949 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
950 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE="
951 | },
952 | "json-buffer": {
953 | "version": "3.0.0",
954 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz",
955 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=",
956 | "dev": true
957 | },
958 | "jsonwebtoken": {
959 | "version": "8.5.1",
960 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz",
961 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==",
962 | "requires": {
963 | "jws": "^3.2.2",
964 | "lodash.includes": "^4.3.0",
965 | "lodash.isboolean": "^3.0.3",
966 | "lodash.isinteger": "^4.0.4",
967 | "lodash.isnumber": "^3.0.3",
968 | "lodash.isplainobject": "^4.0.6",
969 | "lodash.isstring": "^4.0.1",
970 | "lodash.once": "^4.0.0",
971 | "ms": "^2.1.1",
972 | "semver": "^5.6.0"
973 | },
974 | "dependencies": {
975 | "ms": {
976 | "version": "2.1.3",
977 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
978 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
979 | },
980 | "semver": {
981 | "version": "5.7.1",
982 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
983 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ=="
984 | }
985 | }
986 | },
987 | "jwa": {
988 | "version": "1.4.1",
989 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz",
990 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==",
991 | "requires": {
992 | "buffer-equal-constant-time": "1.0.1",
993 | "ecdsa-sig-formatter": "1.0.11",
994 | "safe-buffer": "^5.0.1"
995 | }
996 | },
997 | "jws": {
998 | "version": "3.2.2",
999 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz",
1000 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==",
1001 | "requires": {
1002 | "jwa": "^1.4.1",
1003 | "safe-buffer": "^5.0.1"
1004 | }
1005 | },
1006 | "keyv": {
1007 | "version": "3.1.0",
1008 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz",
1009 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==",
1010 | "dev": true,
1011 | "requires": {
1012 | "json-buffer": "3.0.0"
1013 | }
1014 | },
1015 | "latest-version": {
1016 | "version": "5.1.0",
1017 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz",
1018 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==",
1019 | "dev": true,
1020 | "requires": {
1021 | "package-json": "^6.3.0"
1022 | }
1023 | },
1024 | "lodash": {
1025 | "version": "4.17.20",
1026 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz",
1027 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA=="
1028 | },
1029 | "lodash.includes": {
1030 | "version": "4.3.0",
1031 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz",
1032 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8="
1033 | },
1034 | "lodash.isboolean": {
1035 | "version": "3.0.3",
1036 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz",
1037 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY="
1038 | },
1039 | "lodash.isinteger": {
1040 | "version": "4.0.4",
1041 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz",
1042 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M="
1043 | },
1044 | "lodash.isnumber": {
1045 | "version": "3.0.3",
1046 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz",
1047 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w="
1048 | },
1049 | "lodash.isplainobject": {
1050 | "version": "4.0.6",
1051 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
1052 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs="
1053 | },
1054 | "lodash.isstring": {
1055 | "version": "4.0.1",
1056 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz",
1057 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE="
1058 | },
1059 | "lodash.once": {
1060 | "version": "4.1.1",
1061 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz",
1062 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w="
1063 | },
1064 | "lowercase-keys": {
1065 | "version": "1.0.1",
1066 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
1067 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==",
1068 | "dev": true
1069 | },
1070 | "lru-cache": {
1071 | "version": "6.0.0",
1072 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
1073 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
1074 | "requires": {
1075 | "yallist": "^4.0.0"
1076 | }
1077 | },
1078 | "make-dir": {
1079 | "version": "3.1.0",
1080 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
1081 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
1082 | "dev": true,
1083 | "requires": {
1084 | "semver": "^6.0.0"
1085 | },
1086 | "dependencies": {
1087 | "semver": {
1088 | "version": "6.3.0",
1089 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1090 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1091 | "dev": true
1092 | }
1093 | }
1094 | },
1095 | "media-typer": {
1096 | "version": "0.3.0",
1097 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
1098 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g="
1099 | },
1100 | "merge-descriptors": {
1101 | "version": "1.0.1",
1102 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
1103 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
1104 | },
1105 | "methods": {
1106 | "version": "1.1.2",
1107 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
1108 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4="
1109 | },
1110 | "mime": {
1111 | "version": "1.6.0",
1112 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
1113 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="
1114 | },
1115 | "mime-db": {
1116 | "version": "1.45.0",
1117 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.45.0.tgz",
1118 | "integrity": "sha512-CkqLUxUk15hofLoLyljJSrukZi8mAtgd+yE5uO4tqRZsdsAJKv0O+rFMhVDRJgozy+yG6md5KwuXhD4ocIoP+w=="
1119 | },
1120 | "mime-types": {
1121 | "version": "2.1.28",
1122 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.28.tgz",
1123 | "integrity": "sha512-0TO2yJ5YHYr7M2zzT7gDU1tbwHxEUWBCLt0lscSNpcdAfFyJOVEpRYNS7EXVcTLNj/25QO8gulHC5JtTzSE2UQ==",
1124 | "requires": {
1125 | "mime-db": "1.45.0"
1126 | }
1127 | },
1128 | "mimic-response": {
1129 | "version": "1.0.1",
1130 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz",
1131 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==",
1132 | "dev": true
1133 | },
1134 | "minimatch": {
1135 | "version": "3.0.4",
1136 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
1137 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
1138 | "requires": {
1139 | "brace-expansion": "^1.1.7"
1140 | }
1141 | },
1142 | "minimist": {
1143 | "version": "1.2.5",
1144 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
1145 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw=="
1146 | },
1147 | "minipass": {
1148 | "version": "2.9.0",
1149 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz",
1150 | "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==",
1151 | "requires": {
1152 | "safe-buffer": "^5.1.2",
1153 | "yallist": "^3.0.0"
1154 | },
1155 | "dependencies": {
1156 | "yallist": {
1157 | "version": "3.1.1",
1158 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
1159 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g=="
1160 | }
1161 | }
1162 | },
1163 | "minizlib": {
1164 | "version": "1.3.3",
1165 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz",
1166 | "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==",
1167 | "requires": {
1168 | "minipass": "^2.9.0"
1169 | }
1170 | },
1171 | "mkdirp": {
1172 | "version": "0.5.5",
1173 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz",
1174 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==",
1175 | "requires": {
1176 | "minimist": "^1.2.5"
1177 | }
1178 | },
1179 | "moment": {
1180 | "version": "2.29.1",
1181 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz",
1182 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ=="
1183 | },
1184 | "moment-timezone": {
1185 | "version": "0.5.32",
1186 | "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.32.tgz",
1187 | "integrity": "sha512-Z8QNyuQHQAmWucp8Knmgei8YNo28aLjJq6Ma+jy1ZSpSk5nyfRT8xgUbSQvD2+2UajISfenndwvFuH3NGS+nvA==",
1188 | "requires": {
1189 | "moment": ">= 2.9.0"
1190 | }
1191 | },
1192 | "ms": {
1193 | "version": "2.0.0",
1194 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
1195 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
1196 | },
1197 | "needle": {
1198 | "version": "2.6.0",
1199 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.6.0.tgz",
1200 | "integrity": "sha512-KKYdza4heMsEfSWD7VPUIz3zX2XDwOyX2d+geb4vrERZMT5RMU6ujjaD+I5Yr54uZxQ2w6XRTAhHBbSCyovZBg==",
1201 | "requires": {
1202 | "debug": "^3.2.6",
1203 | "iconv-lite": "^0.4.4",
1204 | "sax": "^1.2.4"
1205 | },
1206 | "dependencies": {
1207 | "debug": {
1208 | "version": "3.2.7",
1209 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
1210 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
1211 | "requires": {
1212 | "ms": "^2.1.1"
1213 | }
1214 | },
1215 | "ms": {
1216 | "version": "2.1.3",
1217 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1218 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
1219 | }
1220 | }
1221 | },
1222 | "negotiator": {
1223 | "version": "0.6.2",
1224 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz",
1225 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw=="
1226 | },
1227 | "node-addon-api": {
1228 | "version": "3.1.0",
1229 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.1.0.tgz",
1230 | "integrity": "sha512-flmrDNB06LIl5lywUz7YlNGZH/5p0M7W28k8hzd9Lshtdh1wshD2Y+U4h9LD6KObOy1f+fEVdgprPrEymjM5uw=="
1231 | },
1232 | "node-pre-gyp": {
1233 | "version": "0.15.0",
1234 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.15.0.tgz",
1235 | "integrity": "sha512-7QcZa8/fpaU/BKenjcaeFF9hLz2+7S9AqyXFhlH/rilsQ/hPZKK32RtR5EQHJElgu+q5RfbJ34KriI79UWaorA==",
1236 | "requires": {
1237 | "detect-libc": "^1.0.2",
1238 | "mkdirp": "^0.5.3",
1239 | "needle": "^2.5.0",
1240 | "nopt": "^4.0.1",
1241 | "npm-packlist": "^1.1.6",
1242 | "npmlog": "^4.0.2",
1243 | "rc": "^1.2.7",
1244 | "rimraf": "^2.6.1",
1245 | "semver": "^5.3.0",
1246 | "tar": "^4.4.2"
1247 | },
1248 | "dependencies": {
1249 | "nopt": {
1250 | "version": "4.0.3",
1251 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz",
1252 | "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==",
1253 | "requires": {
1254 | "abbrev": "1",
1255 | "osenv": "^0.1.4"
1256 | }
1257 | },
1258 | "semver": {
1259 | "version": "5.7.1",
1260 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
1261 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ=="
1262 | }
1263 | }
1264 | },
1265 | "nodemon": {
1266 | "version": "2.0.7",
1267 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.7.tgz",
1268 | "integrity": "sha512-XHzK69Awgnec9UzHr1kc8EomQh4sjTQ8oRf8TsGrSmHDx9/UmiGG9E/mM3BuTfNeFwdNBvrqQq/RHL0xIeyFOA==",
1269 | "dev": true,
1270 | "requires": {
1271 | "chokidar": "^3.2.2",
1272 | "debug": "^3.2.6",
1273 | "ignore-by-default": "^1.0.1",
1274 | "minimatch": "^3.0.4",
1275 | "pstree.remy": "^1.1.7",
1276 | "semver": "^5.7.1",
1277 | "supports-color": "^5.5.0",
1278 | "touch": "^3.1.0",
1279 | "undefsafe": "^2.0.3",
1280 | "update-notifier": "^4.1.0"
1281 | },
1282 | "dependencies": {
1283 | "debug": {
1284 | "version": "3.2.7",
1285 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
1286 | "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
1287 | "dev": true,
1288 | "requires": {
1289 | "ms": "^2.1.1"
1290 | }
1291 | },
1292 | "ms": {
1293 | "version": "2.1.3",
1294 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1295 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
1296 | "dev": true
1297 | },
1298 | "semver": {
1299 | "version": "5.7.1",
1300 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
1301 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
1302 | "dev": true
1303 | }
1304 | }
1305 | },
1306 | "nopt": {
1307 | "version": "1.0.10",
1308 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz",
1309 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=",
1310 | "dev": true,
1311 | "requires": {
1312 | "abbrev": "1"
1313 | }
1314 | },
1315 | "normalize-path": {
1316 | "version": "3.0.0",
1317 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
1318 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
1319 | "dev": true
1320 | },
1321 | "normalize-url": {
1322 | "version": "4.5.0",
1323 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.0.tgz",
1324 | "integrity": "sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ==",
1325 | "dev": true
1326 | },
1327 | "npm-bundled": {
1328 | "version": "1.1.1",
1329 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz",
1330 | "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==",
1331 | "requires": {
1332 | "npm-normalize-package-bin": "^1.0.1"
1333 | }
1334 | },
1335 | "npm-normalize-package-bin": {
1336 | "version": "1.0.1",
1337 | "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz",
1338 | "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA=="
1339 | },
1340 | "npm-packlist": {
1341 | "version": "1.4.8",
1342 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.8.tgz",
1343 | "integrity": "sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A==",
1344 | "requires": {
1345 | "ignore-walk": "^3.0.1",
1346 | "npm-bundled": "^1.0.1",
1347 | "npm-normalize-package-bin": "^1.0.1"
1348 | }
1349 | },
1350 | "npmlog": {
1351 | "version": "4.1.2",
1352 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz",
1353 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==",
1354 | "requires": {
1355 | "are-we-there-yet": "~1.1.2",
1356 | "console-control-strings": "~1.1.0",
1357 | "gauge": "~2.7.3",
1358 | "set-blocking": "~2.0.0"
1359 | }
1360 | },
1361 | "number-is-nan": {
1362 | "version": "1.0.1",
1363 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz",
1364 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0="
1365 | },
1366 | "object-assign": {
1367 | "version": "4.1.1",
1368 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
1369 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM="
1370 | },
1371 | "on-finished": {
1372 | "version": "2.3.0",
1373 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
1374 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
1375 | "requires": {
1376 | "ee-first": "1.1.1"
1377 | }
1378 | },
1379 | "once": {
1380 | "version": "1.4.0",
1381 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
1382 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
1383 | "requires": {
1384 | "wrappy": "1"
1385 | }
1386 | },
1387 | "os-homedir": {
1388 | "version": "1.0.2",
1389 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz",
1390 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M="
1391 | },
1392 | "os-tmpdir": {
1393 | "version": "1.0.2",
1394 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
1395 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ="
1396 | },
1397 | "osenv": {
1398 | "version": "0.1.5",
1399 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz",
1400 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==",
1401 | "requires": {
1402 | "os-homedir": "^1.0.0",
1403 | "os-tmpdir": "^1.0.0"
1404 | }
1405 | },
1406 | "p-cancelable": {
1407 | "version": "1.1.0",
1408 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz",
1409 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==",
1410 | "dev": true
1411 | },
1412 | "package-json": {
1413 | "version": "6.5.0",
1414 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz",
1415 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==",
1416 | "dev": true,
1417 | "requires": {
1418 | "got": "^9.6.0",
1419 | "registry-auth-token": "^4.0.0",
1420 | "registry-url": "^5.0.0",
1421 | "semver": "^6.2.0"
1422 | },
1423 | "dependencies": {
1424 | "semver": {
1425 | "version": "6.3.0",
1426 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1427 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1428 | "dev": true
1429 | }
1430 | }
1431 | },
1432 | "packet-reader": {
1433 | "version": "1.0.0",
1434 | "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz",
1435 | "integrity": "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ=="
1436 | },
1437 | "parseurl": {
1438 | "version": "1.3.3",
1439 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
1440 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ=="
1441 | },
1442 | "path-is-absolute": {
1443 | "version": "1.0.1",
1444 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
1445 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18="
1446 | },
1447 | "path-to-regexp": {
1448 | "version": "0.1.7",
1449 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
1450 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
1451 | },
1452 | "pg": {
1453 | "version": "8.5.1",
1454 | "resolved": "https://registry.npmjs.org/pg/-/pg-8.5.1.tgz",
1455 | "integrity": "sha512-9wm3yX9lCfjvA98ybCyw2pADUivyNWT/yIP4ZcDVpMN0og70BUWYEGXPCTAQdGTAqnytfRADb7NERrY1qxhIqw==",
1456 | "requires": {
1457 | "buffer-writer": "2.0.0",
1458 | "packet-reader": "1.0.0",
1459 | "pg-connection-string": "^2.4.0",
1460 | "pg-pool": "^3.2.2",
1461 | "pg-protocol": "^1.4.0",
1462 | "pg-types": "^2.1.0",
1463 | "pgpass": "1.x"
1464 | }
1465 | },
1466 | "pg-connection-string": {
1467 | "version": "2.4.0",
1468 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.4.0.tgz",
1469 | "integrity": "sha512-3iBXuv7XKvxeMrIgym7njT+HlZkwZqqGX4Bu9cci8xHZNT+Um1gWKqCsAzcC0d95rcKMU5WBg6YRUcHyV0HZKQ=="
1470 | },
1471 | "pg-hstore": {
1472 | "version": "2.3.3",
1473 | "resolved": "https://registry.npmjs.org/pg-hstore/-/pg-hstore-2.3.3.tgz",
1474 | "integrity": "sha512-qpeTpdkguFgfdoidtfeTho1Q1zPVPbtMHgs8eQ+Aan05iLmIs3Z3oo5DOZRclPGoQ4i68I1kCtQSJSa7i0ZVYg==",
1475 | "requires": {
1476 | "underscore": "^1.7.0"
1477 | }
1478 | },
1479 | "pg-int8": {
1480 | "version": "1.0.1",
1481 | "resolved": "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz",
1482 | "integrity": "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw=="
1483 | },
1484 | "pg-pool": {
1485 | "version": "3.2.2",
1486 | "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-3.2.2.tgz",
1487 | "integrity": "sha512-ORJoFxAlmmros8igi608iVEbQNNZlp89diFVx6yV5v+ehmpMY9sK6QgpmgoXbmkNaBAx8cOOZh9g80kJv1ooyA=="
1488 | },
1489 | "pg-protocol": {
1490 | "version": "1.4.0",
1491 | "resolved": "https://registry.npmjs.org/pg-protocol/-/pg-protocol-1.4.0.tgz",
1492 | "integrity": "sha512-El+aXWcwG/8wuFICMQjM5ZSAm6OWiJicFdNYo+VY3QP+8vI4SvLIWVe51PppTzMhikUJR+PsyIFKqfdXPz/yxA=="
1493 | },
1494 | "pg-types": {
1495 | "version": "2.2.0",
1496 | "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-2.2.0.tgz",
1497 | "integrity": "sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA==",
1498 | "requires": {
1499 | "pg-int8": "1.0.1",
1500 | "postgres-array": "~2.0.0",
1501 | "postgres-bytea": "~1.0.0",
1502 | "postgres-date": "~1.0.4",
1503 | "postgres-interval": "^1.1.0"
1504 | }
1505 | },
1506 | "pgpass": {
1507 | "version": "1.0.4",
1508 | "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.4.tgz",
1509 | "integrity": "sha512-YmuA56alyBq7M59vxVBfPJrGSozru8QAdoNlWuW3cz8l+UX3cWge0vTvjKhsSHSJpo3Bom8/Mm6hf0TR5GY0+w==",
1510 | "requires": {
1511 | "split2": "^3.1.1"
1512 | }
1513 | },
1514 | "picomatch": {
1515 | "version": "2.2.2",
1516 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz",
1517 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==",
1518 | "dev": true
1519 | },
1520 | "postgres-array": {
1521 | "version": "2.0.0",
1522 | "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz",
1523 | "integrity": "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA=="
1524 | },
1525 | "postgres-bytea": {
1526 | "version": "1.0.0",
1527 | "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz",
1528 | "integrity": "sha1-AntTPAqokOJtFy1Hz5zOzFIazTU="
1529 | },
1530 | "postgres-date": {
1531 | "version": "1.0.7",
1532 | "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.7.tgz",
1533 | "integrity": "sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q=="
1534 | },
1535 | "postgres-interval": {
1536 | "version": "1.2.0",
1537 | "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz",
1538 | "integrity": "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==",
1539 | "requires": {
1540 | "xtend": "^4.0.0"
1541 | }
1542 | },
1543 | "prepend-http": {
1544 | "version": "2.0.0",
1545 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz",
1546 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=",
1547 | "dev": true
1548 | },
1549 | "process-nextick-args": {
1550 | "version": "2.0.1",
1551 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
1552 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag=="
1553 | },
1554 | "proxy-addr": {
1555 | "version": "2.0.6",
1556 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz",
1557 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==",
1558 | "requires": {
1559 | "forwarded": "~0.1.2",
1560 | "ipaddr.js": "1.9.1"
1561 | }
1562 | },
1563 | "pstree.remy": {
1564 | "version": "1.1.8",
1565 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz",
1566 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==",
1567 | "dev": true
1568 | },
1569 | "pump": {
1570 | "version": "3.0.0",
1571 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
1572 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
1573 | "dev": true,
1574 | "requires": {
1575 | "end-of-stream": "^1.1.0",
1576 | "once": "^1.3.1"
1577 | }
1578 | },
1579 | "pupa": {
1580 | "version": "2.1.1",
1581 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz",
1582 | "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==",
1583 | "dev": true,
1584 | "requires": {
1585 | "escape-goat": "^2.0.0"
1586 | }
1587 | },
1588 | "qs": {
1589 | "version": "6.7.0",
1590 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz",
1591 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ=="
1592 | },
1593 | "range-parser": {
1594 | "version": "1.2.1",
1595 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
1596 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg=="
1597 | },
1598 | "raw-body": {
1599 | "version": "2.4.0",
1600 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz",
1601 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==",
1602 | "requires": {
1603 | "bytes": "3.1.0",
1604 | "http-errors": "1.7.2",
1605 | "iconv-lite": "0.4.24",
1606 | "unpipe": "1.0.0"
1607 | }
1608 | },
1609 | "rc": {
1610 | "version": "1.2.8",
1611 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
1612 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
1613 | "requires": {
1614 | "deep-extend": "^0.6.0",
1615 | "ini": "~1.3.0",
1616 | "minimist": "^1.2.0",
1617 | "strip-json-comments": "~2.0.1"
1618 | }
1619 | },
1620 | "readable-stream": {
1621 | "version": "3.6.0",
1622 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz",
1623 | "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==",
1624 | "requires": {
1625 | "inherits": "^2.0.3",
1626 | "string_decoder": "^1.1.1",
1627 | "util-deprecate": "^1.0.1"
1628 | }
1629 | },
1630 | "readdirp": {
1631 | "version": "3.5.0",
1632 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.5.0.tgz",
1633 | "integrity": "sha512-cMhu7c/8rdhkHXWsY+osBhfSy0JikwpHK/5+imo+LpeasTF8ouErHrlYkwT0++njiyuDvc7OFY5T3ukvZ8qmFQ==",
1634 | "dev": true,
1635 | "requires": {
1636 | "picomatch": "^2.2.1"
1637 | }
1638 | },
1639 | "registry-auth-token": {
1640 | "version": "4.2.1",
1641 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.1.tgz",
1642 | "integrity": "sha512-6gkSb4U6aWJB4SF2ZvLb76yCBjcvufXBqvvEx1HbmKPkutswjW1xNVRY0+daljIYRbogN7O0etYSlbiaEQyMyw==",
1643 | "dev": true,
1644 | "requires": {
1645 | "rc": "^1.2.8"
1646 | }
1647 | },
1648 | "registry-url": {
1649 | "version": "5.1.0",
1650 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz",
1651 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==",
1652 | "dev": true,
1653 | "requires": {
1654 | "rc": "^1.2.8"
1655 | }
1656 | },
1657 | "responselike": {
1658 | "version": "1.0.2",
1659 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz",
1660 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=",
1661 | "dev": true,
1662 | "requires": {
1663 | "lowercase-keys": "^1.0.0"
1664 | }
1665 | },
1666 | "retry-as-promised": {
1667 | "version": "3.2.0",
1668 | "resolved": "https://registry.npmjs.org/retry-as-promised/-/retry-as-promised-3.2.0.tgz",
1669 | "integrity": "sha512-CybGs60B7oYU/qSQ6kuaFmRd9sTZ6oXSc0toqePvV74Ac6/IFZSI1ReFQmtCN+uvW1Mtqdwpvt/LGOiCBAY2Mg==",
1670 | "requires": {
1671 | "any-promise": "^1.3.0"
1672 | }
1673 | },
1674 | "rimraf": {
1675 | "version": "2.7.1",
1676 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz",
1677 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==",
1678 | "requires": {
1679 | "glob": "^7.1.3"
1680 | }
1681 | },
1682 | "safe-buffer": {
1683 | "version": "5.1.2",
1684 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
1685 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g=="
1686 | },
1687 | "safer-buffer": {
1688 | "version": "2.1.2",
1689 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
1690 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
1691 | },
1692 | "sax": {
1693 | "version": "1.2.4",
1694 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz",
1695 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw=="
1696 | },
1697 | "semver": {
1698 | "version": "7.3.4",
1699 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.4.tgz",
1700 | "integrity": "sha512-tCfb2WLjqFAtXn4KEdxIhalnRtoKFN7nAwj0B3ZXCbQloV2tq5eDbcTmT68JJD3nRJq24/XgxtQKFIpQdtvmVw==",
1701 | "requires": {
1702 | "lru-cache": "^6.0.0"
1703 | }
1704 | },
1705 | "semver-diff": {
1706 | "version": "3.1.1",
1707 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz",
1708 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==",
1709 | "dev": true,
1710 | "requires": {
1711 | "semver": "^6.3.0"
1712 | },
1713 | "dependencies": {
1714 | "semver": {
1715 | "version": "6.3.0",
1716 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
1717 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
1718 | "dev": true
1719 | }
1720 | }
1721 | },
1722 | "send": {
1723 | "version": "0.17.1",
1724 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz",
1725 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==",
1726 | "requires": {
1727 | "debug": "2.6.9",
1728 | "depd": "~1.1.2",
1729 | "destroy": "~1.0.4",
1730 | "encodeurl": "~1.0.2",
1731 | "escape-html": "~1.0.3",
1732 | "etag": "~1.8.1",
1733 | "fresh": "0.5.2",
1734 | "http-errors": "~1.7.2",
1735 | "mime": "1.6.0",
1736 | "ms": "2.1.1",
1737 | "on-finished": "~2.3.0",
1738 | "range-parser": "~1.2.1",
1739 | "statuses": "~1.5.0"
1740 | },
1741 | "dependencies": {
1742 | "ms": {
1743 | "version": "2.1.1",
1744 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz",
1745 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg=="
1746 | }
1747 | }
1748 | },
1749 | "sequelize": {
1750 | "version": "6.4.0",
1751 | "resolved": "https://registry.npmjs.org/sequelize/-/sequelize-6.4.0.tgz",
1752 | "integrity": "sha512-XiSAaYMidgLHgOFz0d0rMlSXP07YoL3GwuG0KTtXR6moR+lfdAA93vhLaN9K6f1ElLMutNTx2f7bNK6mACYfIA==",
1753 | "requires": {
1754 | "debug": "^4.1.1",
1755 | "dottie": "^2.0.0",
1756 | "inflection": "1.12.0",
1757 | "lodash": "^4.17.20",
1758 | "moment": "^2.26.0",
1759 | "moment-timezone": "^0.5.31",
1760 | "retry-as-promised": "^3.2.0",
1761 | "semver": "^7.3.2",
1762 | "sequelize-pool": "^6.0.0",
1763 | "toposort-class": "^1.0.1",
1764 | "uuid": "^8.1.0",
1765 | "validator": "^10.11.0",
1766 | "wkx": "^0.5.0"
1767 | },
1768 | "dependencies": {
1769 | "debug": {
1770 | "version": "4.3.1",
1771 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.1.tgz",
1772 | "integrity": "sha512-doEwdvm4PCeK4K3RQN2ZC2BYUBaxwLARCqZmMjtF8a51J2Rb0xpVloFRnCODwqjpwnAoao4pelN8l3RJdv3gRQ==",
1773 | "requires": {
1774 | "ms": "2.1.2"
1775 | }
1776 | },
1777 | "ms": {
1778 | "version": "2.1.2",
1779 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
1780 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w=="
1781 | }
1782 | }
1783 | },
1784 | "sequelize-pool": {
1785 | "version": "6.1.0",
1786 | "resolved": "https://registry.npmjs.org/sequelize-pool/-/sequelize-pool-6.1.0.tgz",
1787 | "integrity": "sha512-4YwEw3ZgK/tY/so+GfnSgXkdwIJJ1I32uZJztIEgZeAO6HMgj64OzySbWLgxj+tXhZCJnzRfkY9gINw8Ft8ZMg=="
1788 | },
1789 | "serve-static": {
1790 | "version": "1.14.1",
1791 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz",
1792 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==",
1793 | "requires": {
1794 | "encodeurl": "~1.0.2",
1795 | "escape-html": "~1.0.3",
1796 | "parseurl": "~1.3.3",
1797 | "send": "0.17.1"
1798 | }
1799 | },
1800 | "set-blocking": {
1801 | "version": "2.0.0",
1802 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
1803 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc="
1804 | },
1805 | "setprototypeof": {
1806 | "version": "1.1.1",
1807 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz",
1808 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw=="
1809 | },
1810 | "signal-exit": {
1811 | "version": "3.0.3",
1812 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz",
1813 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA=="
1814 | },
1815 | "split2": {
1816 | "version": "3.2.2",
1817 | "resolved": "https://registry.npmjs.org/split2/-/split2-3.2.2.tgz",
1818 | "integrity": "sha512-9NThjpgZnifTkJpzTZ7Eue85S49QwpNhZTq6GRJwObb6jnLFNGB7Qm73V5HewTROPyxD0C29xqmaI68bQtV+hg==",
1819 | "requires": {
1820 | "readable-stream": "^3.0.0"
1821 | }
1822 | },
1823 | "statuses": {
1824 | "version": "1.5.0",
1825 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
1826 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow="
1827 | },
1828 | "streamsearch": {
1829 | "version": "0.1.2",
1830 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-0.1.2.tgz",
1831 | "integrity": "sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo="
1832 | },
1833 | "string-width": {
1834 | "version": "4.2.0",
1835 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz",
1836 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==",
1837 | "dev": true,
1838 | "requires": {
1839 | "emoji-regex": "^8.0.0",
1840 | "is-fullwidth-code-point": "^3.0.0",
1841 | "strip-ansi": "^6.0.0"
1842 | },
1843 | "dependencies": {
1844 | "ansi-regex": {
1845 | "version": "5.0.0",
1846 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz",
1847 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==",
1848 | "dev": true
1849 | },
1850 | "emoji-regex": {
1851 | "version": "8.0.0",
1852 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
1853 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
1854 | "dev": true
1855 | },
1856 | "is-fullwidth-code-point": {
1857 | "version": "3.0.0",
1858 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
1859 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
1860 | "dev": true
1861 | },
1862 | "strip-ansi": {
1863 | "version": "6.0.0",
1864 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
1865 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
1866 | "dev": true,
1867 | "requires": {
1868 | "ansi-regex": "^5.0.0"
1869 | }
1870 | }
1871 | }
1872 | },
1873 | "string_decoder": {
1874 | "version": "1.3.0",
1875 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz",
1876 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==",
1877 | "requires": {
1878 | "safe-buffer": "~5.2.0"
1879 | },
1880 | "dependencies": {
1881 | "safe-buffer": {
1882 | "version": "5.2.1",
1883 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
1884 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ=="
1885 | }
1886 | }
1887 | },
1888 | "strip-ansi": {
1889 | "version": "5.2.0",
1890 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz",
1891 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==",
1892 | "dev": true,
1893 | "requires": {
1894 | "ansi-regex": "^4.1.0"
1895 | }
1896 | },
1897 | "strip-json-comments": {
1898 | "version": "2.0.1",
1899 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
1900 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo="
1901 | },
1902 | "supports-color": {
1903 | "version": "5.5.0",
1904 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
1905 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
1906 | "dev": true,
1907 | "requires": {
1908 | "has-flag": "^3.0.0"
1909 | }
1910 | },
1911 | "tar": {
1912 | "version": "4.4.13",
1913 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz",
1914 | "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==",
1915 | "requires": {
1916 | "chownr": "^1.1.1",
1917 | "fs-minipass": "^1.2.5",
1918 | "minipass": "^2.8.6",
1919 | "minizlib": "^1.2.1",
1920 | "mkdirp": "^0.5.0",
1921 | "safe-buffer": "^5.1.2",
1922 | "yallist": "^3.0.3"
1923 | },
1924 | "dependencies": {
1925 | "yallist": {
1926 | "version": "3.1.1",
1927 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
1928 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g=="
1929 | }
1930 | }
1931 | },
1932 | "term-size": {
1933 | "version": "2.2.1",
1934 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.1.tgz",
1935 | "integrity": "sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==",
1936 | "dev": true
1937 | },
1938 | "to-readable-stream": {
1939 | "version": "1.0.0",
1940 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz",
1941 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==",
1942 | "dev": true
1943 | },
1944 | "to-regex-range": {
1945 | "version": "5.0.1",
1946 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
1947 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
1948 | "dev": true,
1949 | "requires": {
1950 | "is-number": "^7.0.0"
1951 | }
1952 | },
1953 | "toidentifier": {
1954 | "version": "1.0.0",
1955 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz",
1956 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw=="
1957 | },
1958 | "toposort-class": {
1959 | "version": "1.0.1",
1960 | "resolved": "https://registry.npmjs.org/toposort-class/-/toposort-class-1.0.1.tgz",
1961 | "integrity": "sha1-f/0feMi+KMO6Rc1OGj9e4ZO9mYg="
1962 | },
1963 | "touch": {
1964 | "version": "3.1.0",
1965 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz",
1966 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==",
1967 | "dev": true,
1968 | "requires": {
1969 | "nopt": "~1.0.10"
1970 | }
1971 | },
1972 | "type-fest": {
1973 | "version": "0.8.1",
1974 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz",
1975 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==",
1976 | "dev": true
1977 | },
1978 | "type-is": {
1979 | "version": "1.6.18",
1980 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
1981 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
1982 | "requires": {
1983 | "media-typer": "0.3.0",
1984 | "mime-types": "~2.1.24"
1985 | }
1986 | },
1987 | "typedarray-to-buffer": {
1988 | "version": "3.1.5",
1989 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz",
1990 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==",
1991 | "dev": true,
1992 | "requires": {
1993 | "is-typedarray": "^1.0.0"
1994 | }
1995 | },
1996 | "undefsafe": {
1997 | "version": "2.0.3",
1998 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.3.tgz",
1999 | "integrity": "sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A==",
2000 | "dev": true,
2001 | "requires": {
2002 | "debug": "^2.2.0"
2003 | }
2004 | },
2005 | "underscore": {
2006 | "version": "1.12.0",
2007 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.12.0.tgz",
2008 | "integrity": "sha512-21rQzss/XPMjolTiIezSu3JAjgagXKROtNrYFEOWK109qY1Uv2tVjPTZ1ci2HgvQDA16gHYSthQIJfB+XId/rQ=="
2009 | },
2010 | "unique-string": {
2011 | "version": "2.0.0",
2012 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz",
2013 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==",
2014 | "dev": true,
2015 | "requires": {
2016 | "crypto-random-string": "^2.0.0"
2017 | }
2018 | },
2019 | "unpipe": {
2020 | "version": "1.0.0",
2021 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
2022 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw="
2023 | },
2024 | "update-notifier": {
2025 | "version": "4.1.3",
2026 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.1.3.tgz",
2027 | "integrity": "sha512-Yld6Z0RyCYGB6ckIjffGOSOmHXj1gMeE7aROz4MG+XMkmixBX4jUngrGXNYz7wPKBmtoD4MnBa2Anu7RSKht/A==",
2028 | "dev": true,
2029 | "requires": {
2030 | "boxen": "^4.2.0",
2031 | "chalk": "^3.0.0",
2032 | "configstore": "^5.0.1",
2033 | "has-yarn": "^2.1.0",
2034 | "import-lazy": "^2.1.0",
2035 | "is-ci": "^2.0.0",
2036 | "is-installed-globally": "^0.3.1",
2037 | "is-npm": "^4.0.0",
2038 | "is-yarn-global": "^0.3.0",
2039 | "latest-version": "^5.0.0",
2040 | "pupa": "^2.0.1",
2041 | "semver-diff": "^3.1.1",
2042 | "xdg-basedir": "^4.0.0"
2043 | }
2044 | },
2045 | "url-parse-lax": {
2046 | "version": "3.0.0",
2047 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz",
2048 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=",
2049 | "dev": true,
2050 | "requires": {
2051 | "prepend-http": "^2.0.0"
2052 | }
2053 | },
2054 | "util-deprecate": {
2055 | "version": "1.0.2",
2056 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
2057 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
2058 | },
2059 | "utils-merge": {
2060 | "version": "1.0.1",
2061 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
2062 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM="
2063 | },
2064 | "uuid": {
2065 | "version": "8.3.2",
2066 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
2067 | "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg=="
2068 | },
2069 | "validator": {
2070 | "version": "10.11.0",
2071 | "resolved": "https://registry.npmjs.org/validator/-/validator-10.11.0.tgz",
2072 | "integrity": "sha512-X/p3UZerAIsbBfN/IwahhYaBbY68EN/UQBWHtsbXGT5bfrH/p4NQzUCG1kF/rtKaNpnJ7jAu6NGTdSNtyNIXMw=="
2073 | },
2074 | "vary": {
2075 | "version": "1.1.2",
2076 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
2077 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw="
2078 | },
2079 | "wide-align": {
2080 | "version": "1.1.3",
2081 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz",
2082 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==",
2083 | "requires": {
2084 | "string-width": "^1.0.2 || 2"
2085 | },
2086 | "dependencies": {
2087 | "ansi-regex": {
2088 | "version": "3.0.0",
2089 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz",
2090 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg="
2091 | },
2092 | "string-width": {
2093 | "version": "2.1.1",
2094 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz",
2095 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==",
2096 | "requires": {
2097 | "is-fullwidth-code-point": "^2.0.0",
2098 | "strip-ansi": "^4.0.0"
2099 | }
2100 | },
2101 | "strip-ansi": {
2102 | "version": "4.0.0",
2103 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz",
2104 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=",
2105 | "requires": {
2106 | "ansi-regex": "^3.0.0"
2107 | }
2108 | }
2109 | }
2110 | },
2111 | "widest-line": {
2112 | "version": "3.1.0",
2113 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz",
2114 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==",
2115 | "dev": true,
2116 | "requires": {
2117 | "string-width": "^4.0.0"
2118 | }
2119 | },
2120 | "wkx": {
2121 | "version": "0.5.0",
2122 | "resolved": "https://registry.npmjs.org/wkx/-/wkx-0.5.0.tgz",
2123 | "integrity": "sha512-Xng/d4Ichh8uN4l0FToV/258EjMGU9MGcA0HV2d9B/ZpZB3lqQm7nkOdZdm5GhKtLLhAE7PiVQwN4eN+2YJJUg==",
2124 | "requires": {
2125 | "@types/node": "*"
2126 | }
2127 | },
2128 | "wrappy": {
2129 | "version": "1.0.2",
2130 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
2131 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8="
2132 | },
2133 | "write-file-atomic": {
2134 | "version": "3.0.3",
2135 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz",
2136 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==",
2137 | "dev": true,
2138 | "requires": {
2139 | "imurmurhash": "^0.1.4",
2140 | "is-typedarray": "^1.0.0",
2141 | "signal-exit": "^3.0.2",
2142 | "typedarray-to-buffer": "^3.1.5"
2143 | }
2144 | },
2145 | "xdg-basedir": {
2146 | "version": "4.0.0",
2147 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz",
2148 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==",
2149 | "dev": true
2150 | },
2151 | "xtend": {
2152 | "version": "4.0.2",
2153 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz",
2154 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ=="
2155 | },
2156 | "yallist": {
2157 | "version": "4.0.0",
2158 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
2159 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A=="
2160 | }
2161 | }
2162 | }
2163 |
--------------------------------------------------------------------------------
/server/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "server",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "index.js",
6 | "scripts": {
7 | "dev": "nodemon index.js"
8 | },
9 | "keywords": [],
10 | "author": "",
11 | "license": "ISC",
12 | "dependencies": {
13 | "bcrypt": "^5.0.0",
14 | "cors": "^2.8.5",
15 | "dotenv": "^8.2.0",
16 | "express": "^4.17.1",
17 | "express-fileupload": "^1.2.1",
18 | "jsonwebtoken": "^8.5.1",
19 | "pg": "^8.5.1",
20 | "pg-hstore": "^2.3.3",
21 | "sequelize": "^6.4.0",
22 | "uuid": "^8.3.2"
23 | },
24 | "devDependencies": {
25 | "nodemon": "^2.0.7"
26 | }
27 | }
28 |
--------------------------------------------------------------------------------
/server/routes/brandRouter.js:
--------------------------------------------------------------------------------
1 | const Router = require('express')
2 | const router = new Router()
3 | const brandController = require('../controllers/brandController')
4 |
5 | router.post('/', brandController.create)
6 | router.get('/', brandController.getAll)
7 |
8 | module.exports = router
9 |
--------------------------------------------------------------------------------
/server/routes/deviceRouter.js:
--------------------------------------------------------------------------------
1 | const Router = require('express')
2 | const router = new Router()
3 | const deviceController = require('../controllers/deviceController')
4 |
5 | router.post('/', deviceController.create)
6 | router.get('/', deviceController.getAll)
7 | router.get('/:id', deviceController.getOne)
8 |
9 | module.exports = router
10 |
--------------------------------------------------------------------------------
/server/routes/index.js:
--------------------------------------------------------------------------------
1 | const Router = require('express')
2 | const router = new Router()
3 | const deviceRouter = require('./deviceRouter')
4 | const userRouter = require('./userRouter')
5 | const brandRouter = require('./brandRouter')
6 | const typeRouter = require('./typeRouter')
7 |
8 | router.use('/user', userRouter)
9 | router.use('/type', typeRouter)
10 | router.use('/brand', brandRouter)
11 | router.use('/device', deviceRouter)
12 |
13 | module.exports = router
14 |
--------------------------------------------------------------------------------
/server/routes/typeRouter.js:
--------------------------------------------------------------------------------
1 | const Router = require('express')
2 | const router = new Router()
3 | const typeController = require('../controllers/typeController')
4 | const checkRole = require('../middleware/checkRoleMiddleware')
5 |
6 | router.post('/', checkRole('ADMIN'), typeController.create)
7 | router.get('/', typeController.getAll)
8 |
9 | module.exports = router
10 |
--------------------------------------------------------------------------------
/server/routes/userRouter.js:
--------------------------------------------------------------------------------
1 | const Router = require('express')
2 | const router = new Router()
3 | const userController = require('../controllers/userController')
4 | const authMiddleware = require('../middleware/authMiddleware')
5 |
6 | router.post('/registration', userController.registration)
7 | router.post('/login', userController.login)
8 | router.get('/auth', authMiddleware, userController.check)
9 |
10 | module.exports = router
11 |
--------------------------------------------------------------------------------
/server/static/0c80d66c-3e86-402d-92f4-14f4a0d5d8c7.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/0c80d66c-3e86-402d-92f4-14f4a0d5d8c7.jpg
--------------------------------------------------------------------------------
/server/static/0da16062-c12b-4c01-913b-ec3a60ba0b7a.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/0da16062-c12b-4c01-913b-ec3a60ba0b7a.jpg
--------------------------------------------------------------------------------
/server/static/0edac1f1-766c-4490-9e8e-5dcc81fcb13f.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/0edac1f1-766c-4490-9e8e-5dcc81fcb13f.jpg
--------------------------------------------------------------------------------
/server/static/22e891e4-d020-4006-a60b-2be97b62672e.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/22e891e4-d020-4006-a60b-2be97b62672e.jpg
--------------------------------------------------------------------------------
/server/static/25e8795f-cac0-46ed-904a-09cf83337a21.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/25e8795f-cac0-46ed-904a-09cf83337a21.jpg
--------------------------------------------------------------------------------
/server/static/33b8d5e9-2bbd-488b-8453-0652a3b5c889.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/33b8d5e9-2bbd-488b-8453-0652a3b5c889.jpg
--------------------------------------------------------------------------------
/server/static/5101f28d-a388-4c0a-9be8-073e9570e99a.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/5101f28d-a388-4c0a-9be8-073e9570e99a.jpg
--------------------------------------------------------------------------------
/server/static/935bb0a5-c599-4e2e-a2f3-373d5c0b9057.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/935bb0a5-c599-4e2e-a2f3-373d5c0b9057.jpg
--------------------------------------------------------------------------------
/server/static/963e7f53-3fb1-40e6-a6ef-5f45802cb72d.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/963e7f53-3fb1-40e6-a6ef-5f45802cb72d.jpg
--------------------------------------------------------------------------------
/server/static/a4be5d23-292c-40c3-96b4-eba60e6e70f2.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/a4be5d23-292c-40c3-96b4-eba60e6e70f2.jpg
--------------------------------------------------------------------------------
/server/static/b7870f83-1156-4edb-99c2-7e0d952e33d6.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/b7870f83-1156-4edb-99c2-7e0d952e33d6.jpg
--------------------------------------------------------------------------------
/server/static/c18e1353-0bf5-4ee3-b589-2f20678b3e12.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/c18e1353-0bf5-4ee3-b589-2f20678b3e12.jpg
--------------------------------------------------------------------------------
/server/static/d4d0f38e-495d-44ad-af60-bcc9641fcb02.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/d4d0f38e-495d-44ad-af60-bcc9641fcb02.jpg
--------------------------------------------------------------------------------
/server/static/e1646781-9115-417d-886d-976c2749a023.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/utimur/online-store-full-course/73bb63b6d68dc1de3ffbf00cb96e249a50da503e/server/static/e1646781-9115-417d-886d-976c2749a023.jpg
--------------------------------------------------------------------------------