├── .env ├── .github └── ISSUE_TEMPLATE │ ├── home-page-feature.md │ ├── login-feature.md │ ├── logout-feature.md │ ├── profile-feature.md │ ├── redux-feature.md │ └── update-feature.md ├── .gitignore ├── CONTRIBUTING.md ├── README.md ├── designs ├── css │ └── main.css ├── img │ ├── argentBankLogo.png │ ├── bank-tree.jpeg │ ├── icon-chat.png │ ├── icon-money.png │ └── icon-security.png ├── index.html ├── sign-in.html ├── user.html └── wireframes │ ├── edit-user-name.png │ └── transactions.png ├── package-lock.json ├── package.json ├── server ├── controllers │ └── userController.js ├── database │ ├── connection.js │ └── models │ │ └── userModel.js ├── middleware │ └── tokenValidation.js ├── routes │ └── userRoutes.js ├── scripts │ └── populateDatabase.js ├── server.js └── services │ └── userService.js └── swagger.yaml /.env: -------------------------------------------------------------------------------- 1 | DATABASE_URL="mongodb://localhost/argentBankDB" -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/home-page-feature.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: '#1 Landing Page' 3 | about: Issue for the landing page requirement 4 | title: User can see the home page 5 | labels: '' 6 | assignees: '' 7 | --- 8 | 9 | A user should be able to: 10 | 11 | - [ ] Navigate to the home page (`/`) 12 | - [ ] See all placeholder data from mockup 13 | 14 | For more information on accessing the design assets, see the [Design Assets section in the README](https://github.com/OpenClassrooms-Student-Center/Project-10-Bank-API#design-assets). 15 | -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/login-feature.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: '#2 Login Requirement' 3 | about: Issue for the login requirement 4 | title: User can login to the system 5 | labels: '' 6 | assignees: '' 7 | --- 8 | 9 | A user should be able to: 10 | 11 | - [ ] Navigate to the login page (`/login`) 12 | - [ ] Fill out credentials 13 | - [ ] Login to the back-end API with JWT tokens for authentication 14 | - [ ] Successfully navigate to a profile page (`/profile`) 15 | 16 | For more information on accessing the design assets, see the [Design Assets section in the README](https://github.com/OpenClassrooms-Student-Center/Project-10-Bank-API#design-assets). 17 | -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/logout-feature.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: '#3 Logout Requirement' 3 | about: Issue for the logout requirement 4 | title: User can logout to the system 5 | labels: '' 6 | assignees: '' 7 | --- 8 | 9 | A user should be able to: 10 | 11 | - [ ] See the logout button when logged in 12 | - [ ] Click the logout button 13 | - [ ] Be returned to the home page (`/`) 14 | 15 | For more information on accessing the design assets, see the [Design Assets section in the README](https://github.com/OpenClassrooms-Student-Center/Project-10-Bank-API#design-assets). 16 | -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/profile-feature.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: '#4 Privacy Requirement' 3 | about: Issue for the privacy requirement 4 | title: User can only see their own profile 5 | labels: '' 6 | assignees: '' 7 | --- 8 | 9 | After successfully logging in, a user should be able to: 10 | 11 | - [ ] See their profile page 12 | - [ ] See their first name on the profile page 13 | - [ ] See placeholder bank account information 14 | 15 | For more information on accessing the design assets, see the [Design Assets section in the README](https://github.com/OpenClassrooms-Student-Center/Project-10-Bank-API#design-assets). 16 | -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/redux-feature.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: '#6 Redux Requirement' 3 | about: Issue for the Redux requirement 4 | title: State management is done through Redux 5 | labels: '' 6 | assignees: '' 7 | --- 8 | 9 | The React app contains an implementation of Redux for state management that: 10 | 11 | - [ ] a store to manage all of the data 12 | - [ ] action(s) for sending information 13 | - [ ] reducer(s) for handling application state changes 14 | -------------------------------------------------------------------------------- /.github/ISSUE_TEMPLATE/update-feature.md: -------------------------------------------------------------------------------- 1 | --- 2 | name: '#5 Update Profile Feature' 3 | about: Issue for the profile update requirement 4 | title: User can update their profile 5 | labels: '' 6 | assignees: '' 7 | --- 8 | 9 | A user should be able to: 10 | 11 | - [ ] Edit their profile (first name and last name). - [ ] This data should be persisted to the database. 12 | 13 | For more information on accessing the design assets, see the [Design Assets section in the README](https://github.com/OpenClassrooms-Student-Center/Project-10-Bank-API#design-assets). 14 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # IDE files 2 | .idea 3 | 4 | # Logs 5 | logs 6 | *.log 7 | 8 | # Runtime data 9 | pids 10 | *.pid 11 | *.seed 12 | 13 | # Directory for instrumented libs generated by jscoverage/JSCover 14 | lib-cov 15 | 16 | # Coverage directory used by tools like istanbul 17 | coverage 18 | 19 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 20 | .grunt 21 | 22 | # Compiled binary addons (http://nodejs.org/api/addons.html) 23 | build/Release 24 | 25 | # Dependency directory 26 | # Commenting this out is preferred by some people, see 27 | # https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git 28 | node_modules 29 | 30 | # Users Environment Variables 31 | .lock-wscript 32 | 33 | # Runtime configuration for swagger app 34 | config/runtime.yaml 35 | 36 | .DS_Store -------------------------------------------------------------------------------- /CONTRIBUTING.md: -------------------------------------------------------------------------------- 1 | # Contributing 2 | 3 | To contribute to this codebase, it's important to use the issue templates we have created to track the work that you are doing. 4 | 5 | ## Instructions 6 | 7 | 1. Fork the [Project 10 Bank API repository](https://github.com/OpenClassrooms-Student-Center/Project-10-Bank-API) 8 | 1. Once it's complete, click on the `Settings` tab in your newly forked repository 9 | 1. Scroll down to the `Features` section and enable `Issues` 10 | 1. Click on the newly visible `Issues` tab 11 | 1. Click on `New Issue` 12 | 1. Use the `Get Started` button on each issue to create a total of 4 issues to track the requirements 13 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Project #10 - Argent Bank API 2 | 3 | This codebase contains the code needed to run the backend for Argent Bank. 4 | 5 | ## Getting Started 6 | 7 | ### Prerequisites 8 | 9 | Argent Bank uses the following tech stack: 10 | 11 | - [Node.js v12](https://nodejs.org/en/) 12 | - [MongoDB Community Server](https://www.mongodb.com/try/download/community) 13 | 14 | Please make sure you have the right versions and download both packages. You can verify this by using the following commands in your terminal: 15 | 16 | ```bash 17 | # Check Node.js version 18 | node --version 19 | 20 | # Check Mongo version 21 | mongo --version 22 | ``` 23 | 24 | ### Instructions 25 | 26 | 1. Fork this repo 27 | 1. Clone the repo onto your computer 28 | 1. Open a terminal window in the cloned project 29 | 1. Run the following commands: 30 | 31 | ```bash 32 | # Install dependencies 33 | npm install 34 | 35 | # Start local dev server 36 | npm run dev:server 37 | 38 | # Populate database with two users 39 | npm run populate-db 40 | ``` 41 | 42 | Your server should now be running at http://locahost:3001 and you will now have two users in your MongoDB database! 43 | 44 | ## Populated Database Data 45 | 46 | Once you run the `populate-db` script, you should have two users in your database: 47 | 48 | ### Tony Stark 49 | 50 | - First Name: `Tony` 51 | - Last Name: `Stark` 52 | - Email: `tony@stark.com` 53 | - Password: `password123` 54 | 55 | ### Steve Rogers 56 | 57 | - First Name: `Steve`, 58 | - Last Name: `Rogers`, 59 | - Email: `steve@rogers.com`, 60 | - Password: `password456` 61 | 62 | ## API Documentation 63 | 64 | To learn more about how the API works, once you have started your local environment, you can visit: http://localhost:3001/api-docs 65 | 66 | ## Design Assets 67 | 68 | Static HTML and CSS has been created for most of the site and is located in: `/designs`. 69 | 70 | For some of the dynamic features, like toggling user editing, there is a mock-up for it in `/designs/wireframes/edit-user-name.png`. 71 | 72 | And for the API model that you will be proposing for transactitons, the wireframe can be found in `/designs/wireframes/transactions.png`. 73 | -------------------------------------------------------------------------------- /designs/css/main.css: -------------------------------------------------------------------------------- 1 | html { 2 | font-family: Avenir, Helvetica, Arial, sans-serif; 3 | -webkit-font-smoothing: antialiased; 4 | -moz-osx-font-smoothing: grayscale; 5 | text-align: center; 6 | color: #2c3e50; 7 | } 8 | 9 | body { 10 | margin: 0; 11 | display: flex; 12 | flex-direction: column; 13 | min-height: 100vh; 14 | } 15 | 16 | .main { 17 | flex: 1; 18 | } 19 | 20 | .bg-dark { 21 | background-color: #12002b; 22 | } 23 | 24 | .sr-only { 25 | border: 0 !important; 26 | clip: rect(1px, 1px, 1px, 1px) !important; /* 1 */ 27 | -webkit-clip-path: inset(50%) !important; 28 | clip-path: inset(50%) !important; /* 2 */ 29 | height: 1px !important; 30 | margin: -1px !important; 31 | overflow: hidden !important; 32 | padding: 0 !important; 33 | position: absolute !important; 34 | width: 1px !important; 35 | white-space: nowrap !important; /* 3 */ 36 | } 37 | 38 | .main-nav { 39 | display: flex; 40 | justify-content: space-between; 41 | align-items: center; 42 | padding: 5px 20px; 43 | } 44 | 45 | .main-nav a { 46 | font-weight: bold; 47 | color: #2c3e50; 48 | } 49 | 50 | .main-nav a.router-link-exact-active { 51 | color: #42b983; 52 | } 53 | 54 | .main-nav-item { 55 | text-decoration: none; 56 | margin-right: 0.5rem; 57 | } 58 | 59 | .main-nav-item:hover { 60 | text-decoration: underline; 61 | } 62 | 63 | .main-nav-logo { 64 | display: flex; 65 | align-items: center; 66 | } 67 | 68 | .main-nav-logo-image { 69 | max-width: 100%; 70 | width: 200px; 71 | } 72 | 73 | .hero { 74 | background-image: url('../img/bank-tree.jpeg'); 75 | background-position: 0 -50px; 76 | background-size: cover; 77 | background-repeat: no-repeat; 78 | height: 300px; 79 | position: relative; 80 | } 81 | 82 | .hero-content { 83 | position: relative; 84 | top: 2rem; 85 | width: 200px; 86 | background: white; 87 | padding: 2rem; 88 | text-align: left; 89 | margin: 0 auto; 90 | } 91 | 92 | .hero-content .subtitle { 93 | font-weight: bold; 94 | font-size: 1rem; 95 | margin: 0; 96 | } 97 | 98 | .hero-content .text { 99 | margin-bottom: 0; 100 | font-size: 0.9rem; 101 | } 102 | 103 | @media (min-width: 920px) { 104 | .hero { 105 | height: 400px; 106 | background-position: 0% 33%; 107 | } 108 | 109 | .hero-content { 110 | position: absolute; 111 | top: 50px; 112 | right: 50px; 113 | width: 300px; 114 | margin: 2rem; 115 | } 116 | 117 | .hero-content .subtitle { 118 | font-size: 1.5rem; 119 | } 120 | 121 | .hero-content .text { 122 | font-size: 1.2rem; 123 | } 124 | } 125 | 126 | .features { 127 | display: flex; 128 | flex-direction: column; 129 | } 130 | 131 | @media (min-width: 920px) { 132 | .features { 133 | flex-direction: row; 134 | } 135 | } 136 | 137 | .feature-icon { 138 | width: 100px; 139 | border: 10px solid #00bc77; 140 | border-radius: 50%; 141 | padding: 1rem; 142 | } 143 | 144 | .feature-item { 145 | flex: 1; 146 | padding: 2.5rem; 147 | } 148 | 149 | .feature-item-title { 150 | color: #222; 151 | font-size: 1.25rem; 152 | font-weight: bold; 153 | margin-bottom: 0.5rem; 154 | } 155 | 156 | .sign-in-button { 157 | display: block; 158 | width: 100%; 159 | padding: 8px; 160 | font-size: 1.1rem; 161 | font-weight: bold; 162 | margin-top: 1rem; 163 | border-color: #00bc77; 164 | background-color: #00bc77; 165 | color: #fff; 166 | } 167 | 168 | .sign-in-content { 169 | box-sizing: border-box; 170 | background-color: white; 171 | width: 300px; 172 | margin: 0 auto; 173 | margin-top: 3rem; 174 | padding: 2rem; 175 | } 176 | 177 | .sign-in-icon { 178 | font-size: 5rem; 179 | } 180 | 181 | .input-remember { 182 | display: flex; 183 | } 184 | 185 | .input-remember label { 186 | margin-left: 0.25rem; 187 | } 188 | 189 | .input-wrapper { 190 | display: flex; 191 | flex-direction: column; 192 | text-align: left; 193 | margin-bottom: 1rem; 194 | } 195 | 196 | .input-wrapper label { 197 | font-weight: bold; 198 | } 199 | 200 | .input-wrapper input { 201 | padding: 5px; 202 | font-size: 1.2rem; 203 | } 204 | 205 | .footer { 206 | display: flex; 207 | justify-content: center; 208 | border-top: 2px solid #ccc; 209 | padding: 2rem 0 1.5rem; 210 | } 211 | 212 | .footer-text { 213 | margin: 0; 214 | padding: 0; 215 | } 216 | 217 | .account { 218 | display: flex; 219 | justify-content: space-between; 220 | align-items: center; 221 | border: 1px solid black; 222 | background-color: #fff; 223 | width: 80%; 224 | margin: 0 auto; 225 | flex-direction: column; 226 | padding: 1.5rem; 227 | box-sizing: border-box; 228 | text-align: left; 229 | margin-bottom: 2rem; 230 | } 231 | 232 | .account-amount { 233 | margin: 0; 234 | font-size: 2.5rem; 235 | font-weight: bold; 236 | } 237 | 238 | .account-amount-description { 239 | margin: 0; 240 | } 241 | 242 | .account-title { 243 | margin: 0; 244 | padding: 0; 245 | font-size: 1rem; 246 | font-weight: normal; 247 | } 248 | 249 | .account-content-wrapper { 250 | width: 100%; 251 | flex: 1; 252 | } 253 | 254 | .edit-button { 255 | border-color: #00bc77; 256 | background-color: #00bc77; 257 | color: #fff; 258 | font-weight: bold; 259 | padding: 10px; 260 | } 261 | 262 | .header { 263 | color: #fff; 264 | margin-bottom: 2rem; 265 | } 266 | 267 | .transaction-button { 268 | display: block; 269 | width: 100%; 270 | padding: 8px; 271 | font-size: 1.1rem; 272 | font-weight: bold; 273 | margin-top: 1rem; 274 | border-color: #00bc77; 275 | background-color: #00bc77; 276 | color: #fff; 277 | } 278 | 279 | @media (min-width: 720px) { 280 | .account { 281 | flex-direction: row; 282 | } 283 | 284 | .account-content-wrapper.cta { 285 | flex: 0; 286 | } 287 | 288 | .transaction-button { 289 | width: 200px; 290 | } 291 | } 292 | -------------------------------------------------------------------------------- /designs/img/argentBankLogo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/OpenClassrooms-Student-Center/Project-10-Bank-API/50bdfb882747640cb7bb1afe9fcd9814083ba52f/designs/img/argentBankLogo.png -------------------------------------------------------------------------------- /designs/img/bank-tree.jpeg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/OpenClassrooms-Student-Center/Project-10-Bank-API/50bdfb882747640cb7bb1afe9fcd9814083ba52f/designs/img/bank-tree.jpeg -------------------------------------------------------------------------------- /designs/img/icon-chat.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/OpenClassrooms-Student-Center/Project-10-Bank-API/50bdfb882747640cb7bb1afe9fcd9814083ba52f/designs/img/icon-chat.png -------------------------------------------------------------------------------- /designs/img/icon-money.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/OpenClassrooms-Student-Center/Project-10-Bank-API/50bdfb882747640cb7bb1afe9fcd9814083ba52f/designs/img/icon-money.png -------------------------------------------------------------------------------- /designs/img/icon-security.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/OpenClassrooms-Student-Center/Project-10-Bank-API/50bdfb882747640cb7bb1afe9fcd9814083ba52f/designs/img/icon-security.png -------------------------------------------------------------------------------- /designs/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | Argent Bank - Home Page 7 | 8 | 12 | 13 | 14 | 30 |
31 |
32 |
33 |

Promoted Content

34 |

No fees.

35 |

No minimum deposit.

36 |

High interest rates.

37 |

Open a savings account with Argent Bank today!

38 |
39 |
40 |
41 |

Features

42 |
43 | Chat Icon 44 |

You are our #1 priority

45 |

46 | Need to talk to a representative? You can get in touch through our 47 | 24/7 chat or through a phone call in less than 5 minutes. 48 |

49 |
50 |
51 | Chat Icon 56 |

More savings means higher rates

57 |

58 | The more you save with us, the higher your interest rate will be! 59 |

60 |
61 |
62 | Chat Icon 67 |

Security you can trust

68 |

69 | We use top of the line encryption to make sure your data and money 70 | is always safe. 71 |

72 |
73 |
74 |
75 | 78 | 79 | 80 | -------------------------------------------------------------------------------- /designs/sign-in.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | Argent Bank - Home Page 7 | 8 | 12 | 13 | 14 | 30 |
31 |
32 | 33 |

Sign In

34 |
35 |
36 | 38 |
39 |
40 | 42 |
43 |
44 | 47 |
48 | 49 | 50 | 51 | 52 | 53 |
54 |
55 |
56 | 59 | 60 | 61 | 62 | 63 | -------------------------------------------------------------------------------- /designs/user.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | Argent Bank - Home Page 7 | 8 | 12 | 13 | 14 | 34 |
35 |
36 |

Welcome back
Tony Jarvis!

37 | 38 |
39 |

Accounts

40 |
41 | 46 | 49 |
50 |
51 | 56 | 59 |
60 |
61 | 66 | 69 |
70 |
71 | 74 | 75 | 76 | -------------------------------------------------------------------------------- /designs/wireframes/edit-user-name.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/OpenClassrooms-Student-Center/Project-10-Bank-API/50bdfb882747640cb7bb1afe9fcd9814083ba52f/designs/wireframes/edit-user-name.png -------------------------------------------------------------------------------- /designs/wireframes/transactions.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/OpenClassrooms-Student-Center/Project-10-Bank-API/50bdfb882747640cb7bb1afe9fcd9814083ba52f/designs/wireframes/transactions.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "argent-bank-api", 3 | "version": "0.0.1", 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/color-name": { 23 | "version": "1.1.1", 24 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 25 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 26 | "dev": true 27 | }, 28 | "abbrev": { 29 | "version": "1.1.1", 30 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 31 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 32 | }, 33 | "accepts": { 34 | "version": "1.3.7", 35 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 36 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 37 | "requires": { 38 | "mime-types": "~2.1.24", 39 | "negotiator": "0.6.2" 40 | } 41 | }, 42 | "ansi-align": { 43 | "version": "3.0.0", 44 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.0.tgz", 45 | "integrity": "sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw==", 46 | "dev": true, 47 | "requires": { 48 | "string-width": "^3.0.0" 49 | }, 50 | "dependencies": { 51 | "string-width": { 52 | "version": "3.1.0", 53 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 54 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 55 | "dev": true, 56 | "requires": { 57 | "emoji-regex": "^7.0.1", 58 | "is-fullwidth-code-point": "^2.0.0", 59 | "strip-ansi": "^5.1.0" 60 | } 61 | } 62 | } 63 | }, 64 | "ansi-regex": { 65 | "version": "4.1.0", 66 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 67 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 68 | "dev": true 69 | }, 70 | "ansi-styles": { 71 | "version": "4.2.1", 72 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 73 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 74 | "dev": true, 75 | "requires": { 76 | "@types/color-name": "^1.1.1", 77 | "color-convert": "^2.0.1" 78 | } 79 | }, 80 | "anymatch": { 81 | "version": "3.1.1", 82 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 83 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 84 | "dev": true, 85 | "requires": { 86 | "normalize-path": "^3.0.0", 87 | "picomatch": "^2.0.4" 88 | } 89 | }, 90 | "aproba": { 91 | "version": "1.2.0", 92 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 93 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" 94 | }, 95 | "are-we-there-yet": { 96 | "version": "1.1.5", 97 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 98 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 99 | "requires": { 100 | "delegates": "^1.0.0", 101 | "readable-stream": "^2.0.6" 102 | } 103 | }, 104 | "argparse": { 105 | "version": "1.0.10", 106 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 107 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 108 | "requires": { 109 | "sprintf-js": "~1.0.2" 110 | } 111 | }, 112 | "array-flatten": { 113 | "version": "1.1.1", 114 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 115 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 116 | }, 117 | "axios": { 118 | "version": "0.19.2", 119 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.19.2.tgz", 120 | "integrity": "sha512-fjgm5MvRHLhx+osE2xoekY70AhARk3a6hkN+3Io1jc00jtquGvxYlKlsFUhmUET0V5te6CcZI7lcv2Ym61mjHA==", 121 | "requires": { 122 | "follow-redirects": "1.5.10" 123 | } 124 | }, 125 | "balanced-match": { 126 | "version": "1.0.0", 127 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 128 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 129 | }, 130 | "bcrypt": { 131 | "version": "5.0.0", 132 | "resolved": "https://registry.npmjs.org/bcrypt/-/bcrypt-5.0.0.tgz", 133 | "integrity": "sha512-jB0yCBl4W/kVHM2whjfyqnxTmOHkCX4kHEa5nYKSoGeYe8YrjTYTc87/6bwt1g8cmV0QrbhKriETg9jWtcREhg==", 134 | "requires": { 135 | "node-addon-api": "^3.0.0", 136 | "node-pre-gyp": "0.15.0" 137 | } 138 | }, 139 | "binary-extensions": { 140 | "version": "2.1.0", 141 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz", 142 | "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==", 143 | "dev": true 144 | }, 145 | "bl": { 146 | "version": "2.2.0", 147 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.0.tgz", 148 | "integrity": "sha512-wbgvOpqopSr7uq6fJrLH8EsvYMJf9gzfo2jCsL2eTy75qXPukA4pCgHamOQkZtY5vmfVtjB+P3LNlMHW5CEZXA==", 149 | "requires": { 150 | "readable-stream": "^2.3.5", 151 | "safe-buffer": "^5.1.1" 152 | } 153 | }, 154 | "bluebird": { 155 | "version": "3.5.1", 156 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", 157 | "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==" 158 | }, 159 | "body-parser": { 160 | "version": "1.19.0", 161 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 162 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 163 | "requires": { 164 | "bytes": "3.1.0", 165 | "content-type": "~1.0.4", 166 | "debug": "2.6.9", 167 | "depd": "~1.1.2", 168 | "http-errors": "1.7.2", 169 | "iconv-lite": "0.4.24", 170 | "on-finished": "~2.3.0", 171 | "qs": "6.7.0", 172 | "raw-body": "2.4.0", 173 | "type-is": "~1.6.17" 174 | } 175 | }, 176 | "boxen": { 177 | "version": "4.2.0", 178 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz", 179 | "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==", 180 | "dev": true, 181 | "requires": { 182 | "ansi-align": "^3.0.0", 183 | "camelcase": "^5.3.1", 184 | "chalk": "^3.0.0", 185 | "cli-boxes": "^2.2.0", 186 | "string-width": "^4.1.0", 187 | "term-size": "^2.1.0", 188 | "type-fest": "^0.8.1", 189 | "widest-line": "^3.1.0" 190 | } 191 | }, 192 | "brace-expansion": { 193 | "version": "1.1.11", 194 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 195 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 196 | "requires": { 197 | "balanced-match": "^1.0.0", 198 | "concat-map": "0.0.1" 199 | } 200 | }, 201 | "braces": { 202 | "version": "3.0.2", 203 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 204 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 205 | "dev": true, 206 | "requires": { 207 | "fill-range": "^7.0.1" 208 | } 209 | }, 210 | "bson": { 211 | "version": "1.1.4", 212 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.4.tgz", 213 | "integrity": "sha512-S/yKGU1syOMzO86+dGpg2qGoDL0zvzcb262G+gqEy6TgP6rt6z6qxSFX/8X6vLC91P7G7C3nLs0+bvDzmvBA3Q==" 214 | }, 215 | "buffer-equal-constant-time": { 216 | "version": "1.0.1", 217 | "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", 218 | "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk=" 219 | }, 220 | "bytes": { 221 | "version": "3.1.0", 222 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 223 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 224 | }, 225 | "cacheable-request": { 226 | "version": "6.1.0", 227 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 228 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 229 | "dev": true, 230 | "requires": { 231 | "clone-response": "^1.0.2", 232 | "get-stream": "^5.1.0", 233 | "http-cache-semantics": "^4.0.0", 234 | "keyv": "^3.0.0", 235 | "lowercase-keys": "^2.0.0", 236 | "normalize-url": "^4.1.0", 237 | "responselike": "^1.0.2" 238 | }, 239 | "dependencies": { 240 | "get-stream": { 241 | "version": "5.1.0", 242 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.1.0.tgz", 243 | "integrity": "sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw==", 244 | "dev": true, 245 | "requires": { 246 | "pump": "^3.0.0" 247 | } 248 | }, 249 | "lowercase-keys": { 250 | "version": "2.0.0", 251 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 252 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", 253 | "dev": true 254 | } 255 | } 256 | }, 257 | "camelcase": { 258 | "version": "5.3.1", 259 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 260 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 261 | "dev": true 262 | }, 263 | "chalk": { 264 | "version": "3.0.0", 265 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 266 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 267 | "dev": true, 268 | "requires": { 269 | "ansi-styles": "^4.1.0", 270 | "supports-color": "^7.1.0" 271 | }, 272 | "dependencies": { 273 | "has-flag": { 274 | "version": "4.0.0", 275 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 276 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 277 | "dev": true 278 | }, 279 | "supports-color": { 280 | "version": "7.1.0", 281 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 282 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 283 | "dev": true, 284 | "requires": { 285 | "has-flag": "^4.0.0" 286 | } 287 | } 288 | } 289 | }, 290 | "chokidar": { 291 | "version": "3.4.0", 292 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.4.0.tgz", 293 | "integrity": "sha512-aXAaho2VJtisB/1fg1+3nlLJqGOuewTzQpd/Tz0yTg2R0e4IGtshYvtjowyEumcBv2z+y4+kc75Mz7j5xJskcQ==", 294 | "dev": true, 295 | "requires": { 296 | "anymatch": "~3.1.1", 297 | "braces": "~3.0.2", 298 | "fsevents": "~2.1.2", 299 | "glob-parent": "~5.1.0", 300 | "is-binary-path": "~2.1.0", 301 | "is-glob": "~4.0.1", 302 | "normalize-path": "~3.0.0", 303 | "readdirp": "~3.4.0" 304 | } 305 | }, 306 | "chownr": { 307 | "version": "1.1.4", 308 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 309 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==" 310 | }, 311 | "ci-info": { 312 | "version": "2.0.0", 313 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 314 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 315 | "dev": true 316 | }, 317 | "cli-boxes": { 318 | "version": "2.2.0", 319 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.0.tgz", 320 | "integrity": "sha512-gpaBrMAizVEANOpfZp/EEUixTXDyGt7DFzdK5hU+UbWt/J0lB0w20ncZj59Z9a93xHb9u12zF5BS6i9RKbtg4w==", 321 | "dev": true 322 | }, 323 | "clone-response": { 324 | "version": "1.0.2", 325 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 326 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 327 | "dev": true, 328 | "requires": { 329 | "mimic-response": "^1.0.0" 330 | } 331 | }, 332 | "code-point-at": { 333 | "version": "1.1.0", 334 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 335 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 336 | }, 337 | "color-convert": { 338 | "version": "2.0.1", 339 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 340 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 341 | "dev": true, 342 | "requires": { 343 | "color-name": "~1.1.4" 344 | } 345 | }, 346 | "color-name": { 347 | "version": "1.1.4", 348 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 349 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 350 | "dev": true 351 | }, 352 | "concat-map": { 353 | "version": "0.0.1", 354 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 355 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 356 | }, 357 | "configstore": { 358 | "version": "5.0.1", 359 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 360 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 361 | "dev": true, 362 | "requires": { 363 | "dot-prop": "^5.2.0", 364 | "graceful-fs": "^4.1.2", 365 | "make-dir": "^3.0.0", 366 | "unique-string": "^2.0.0", 367 | "write-file-atomic": "^3.0.0", 368 | "xdg-basedir": "^4.0.0" 369 | } 370 | }, 371 | "console-control-strings": { 372 | "version": "1.1.0", 373 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 374 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" 375 | }, 376 | "content-disposition": { 377 | "version": "0.5.3", 378 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 379 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 380 | "requires": { 381 | "safe-buffer": "5.1.2" 382 | } 383 | }, 384 | "content-type": { 385 | "version": "1.0.4", 386 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 387 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 388 | }, 389 | "cookie": { 390 | "version": "0.4.0", 391 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 392 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 393 | }, 394 | "cookie-signature": { 395 | "version": "1.0.6", 396 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 397 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 398 | }, 399 | "core-util-is": { 400 | "version": "1.0.2", 401 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 402 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 403 | }, 404 | "cors": { 405 | "version": "2.8.5", 406 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 407 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 408 | "requires": { 409 | "object-assign": "^4", 410 | "vary": "^1" 411 | } 412 | }, 413 | "crypto-random-string": { 414 | "version": "2.0.0", 415 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 416 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 417 | "dev": true 418 | }, 419 | "debug": { 420 | "version": "2.6.9", 421 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 422 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 423 | "requires": { 424 | "ms": "2.0.0" 425 | } 426 | }, 427 | "decompress-response": { 428 | "version": "3.3.0", 429 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 430 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 431 | "dev": true, 432 | "requires": { 433 | "mimic-response": "^1.0.0" 434 | } 435 | }, 436 | "deep-extend": { 437 | "version": "0.6.0", 438 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 439 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==" 440 | }, 441 | "defer-to-connect": { 442 | "version": "1.1.3", 443 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 444 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==", 445 | "dev": true 446 | }, 447 | "delegates": { 448 | "version": "1.0.0", 449 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 450 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" 451 | }, 452 | "denque": { 453 | "version": "1.4.1", 454 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.4.1.tgz", 455 | "integrity": "sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ==" 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 | "dot-prop": { 473 | "version": "5.2.0", 474 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.2.0.tgz", 475 | "integrity": "sha512-uEUyaDKoSQ1M4Oq8l45hSE26SnTxL6snNnqvK/VWx5wJhmff5z0FUVJDKDanor/6w3kzE3i7XZOk+7wC0EXr1A==", 476 | "dev": true, 477 | "requires": { 478 | "is-obj": "^2.0.0" 479 | } 480 | }, 481 | "dotenv": { 482 | "version": "8.2.0", 483 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", 484 | "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" 485 | }, 486 | "duplexer3": { 487 | "version": "0.1.4", 488 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 489 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 490 | "dev": true 491 | }, 492 | "ecdsa-sig-formatter": { 493 | "version": "1.0.11", 494 | "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", 495 | "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", 496 | "requires": { 497 | "safe-buffer": "^5.0.1" 498 | } 499 | }, 500 | "ee-first": { 501 | "version": "1.1.1", 502 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 503 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 504 | }, 505 | "emoji-regex": { 506 | "version": "7.0.3", 507 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 508 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 509 | "dev": true 510 | }, 511 | "encodeurl": { 512 | "version": "1.0.2", 513 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 514 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 515 | }, 516 | "end-of-stream": { 517 | "version": "1.4.4", 518 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 519 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 520 | "dev": true, 521 | "requires": { 522 | "once": "^1.4.0" 523 | } 524 | }, 525 | "escape-goat": { 526 | "version": "2.1.1", 527 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 528 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==", 529 | "dev": true 530 | }, 531 | "escape-html": { 532 | "version": "1.0.3", 533 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 534 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 535 | }, 536 | "etag": { 537 | "version": "1.8.1", 538 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 539 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 540 | }, 541 | "express": { 542 | "version": "4.17.1", 543 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 544 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 545 | "requires": { 546 | "accepts": "~1.3.7", 547 | "array-flatten": "1.1.1", 548 | "body-parser": "1.19.0", 549 | "content-disposition": "0.5.3", 550 | "content-type": "~1.0.4", 551 | "cookie": "0.4.0", 552 | "cookie-signature": "1.0.6", 553 | "debug": "2.6.9", 554 | "depd": "~1.1.2", 555 | "encodeurl": "~1.0.2", 556 | "escape-html": "~1.0.3", 557 | "etag": "~1.8.1", 558 | "finalhandler": "~1.1.2", 559 | "fresh": "0.5.2", 560 | "merge-descriptors": "1.0.1", 561 | "methods": "~1.1.2", 562 | "on-finished": "~2.3.0", 563 | "parseurl": "~1.3.3", 564 | "path-to-regexp": "0.1.7", 565 | "proxy-addr": "~2.0.5", 566 | "qs": "6.7.0", 567 | "range-parser": "~1.2.1", 568 | "safe-buffer": "5.1.2", 569 | "send": "0.17.1", 570 | "serve-static": "1.14.1", 571 | "setprototypeof": "1.1.1", 572 | "statuses": "~1.5.0", 573 | "type-is": "~1.6.18", 574 | "utils-merge": "1.0.1", 575 | "vary": "~1.1.2" 576 | } 577 | }, 578 | "fill-range": { 579 | "version": "7.0.1", 580 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 581 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 582 | "dev": true, 583 | "requires": { 584 | "to-regex-range": "^5.0.1" 585 | } 586 | }, 587 | "finalhandler": { 588 | "version": "1.1.2", 589 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 590 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 591 | "requires": { 592 | "debug": "2.6.9", 593 | "encodeurl": "~1.0.2", 594 | "escape-html": "~1.0.3", 595 | "on-finished": "~2.3.0", 596 | "parseurl": "~1.3.3", 597 | "statuses": "~1.5.0", 598 | "unpipe": "~1.0.0" 599 | } 600 | }, 601 | "follow-redirects": { 602 | "version": "1.5.10", 603 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.5.10.tgz", 604 | "integrity": "sha512-0V5l4Cizzvqt5D44aTXbFZz+FtyXV1vrDN6qrelxtfYQKW0KO0W2T/hkE8xvGa/540LkZlkaUjO4ailYTFtHVQ==", 605 | "requires": { 606 | "debug": "=3.1.0" 607 | }, 608 | "dependencies": { 609 | "debug": { 610 | "version": "3.1.0", 611 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 612 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 613 | "requires": { 614 | "ms": "2.0.0" 615 | } 616 | } 617 | } 618 | }, 619 | "forwarded": { 620 | "version": "0.1.2", 621 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 622 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 623 | }, 624 | "fresh": { 625 | "version": "0.5.2", 626 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 627 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 628 | }, 629 | "fs-minipass": { 630 | "version": "1.2.7", 631 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", 632 | "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", 633 | "requires": { 634 | "minipass": "^2.6.0" 635 | } 636 | }, 637 | "fs.realpath": { 638 | "version": "1.0.0", 639 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 640 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 641 | }, 642 | "fsevents": { 643 | "version": "2.1.3", 644 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 645 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 646 | "dev": true, 647 | "optional": true 648 | }, 649 | "gauge": { 650 | "version": "2.7.4", 651 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 652 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 653 | "requires": { 654 | "aproba": "^1.0.3", 655 | "console-control-strings": "^1.0.0", 656 | "has-unicode": "^2.0.0", 657 | "object-assign": "^4.1.0", 658 | "signal-exit": "^3.0.0", 659 | "string-width": "^1.0.1", 660 | "strip-ansi": "^3.0.1", 661 | "wide-align": "^1.1.0" 662 | }, 663 | "dependencies": { 664 | "ansi-regex": { 665 | "version": "2.1.1", 666 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 667 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 668 | }, 669 | "is-fullwidth-code-point": { 670 | "version": "1.0.0", 671 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 672 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 673 | "requires": { 674 | "number-is-nan": "^1.0.0" 675 | } 676 | }, 677 | "string-width": { 678 | "version": "1.0.2", 679 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 680 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 681 | "requires": { 682 | "code-point-at": "^1.0.0", 683 | "is-fullwidth-code-point": "^1.0.0", 684 | "strip-ansi": "^3.0.0" 685 | } 686 | }, 687 | "strip-ansi": { 688 | "version": "3.0.1", 689 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 690 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 691 | "requires": { 692 | "ansi-regex": "^2.0.0" 693 | } 694 | } 695 | } 696 | }, 697 | "get-stream": { 698 | "version": "4.1.0", 699 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 700 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 701 | "dev": true, 702 | "requires": { 703 | "pump": "^3.0.0" 704 | } 705 | }, 706 | "glob": { 707 | "version": "7.1.6", 708 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 709 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 710 | "requires": { 711 | "fs.realpath": "^1.0.0", 712 | "inflight": "^1.0.4", 713 | "inherits": "2", 714 | "minimatch": "^3.0.4", 715 | "once": "^1.3.0", 716 | "path-is-absolute": "^1.0.0" 717 | } 718 | }, 719 | "glob-parent": { 720 | "version": "5.1.1", 721 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 722 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 723 | "dev": true, 724 | "requires": { 725 | "is-glob": "^4.0.1" 726 | } 727 | }, 728 | "global-dirs": { 729 | "version": "2.0.1", 730 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.0.1.tgz", 731 | "integrity": "sha512-5HqUqdhkEovj2Of/ms3IeS/EekcO54ytHRLV4PEY2rhRwrHXLQjeVEES0Lhka0xwNDtGYn58wyC4s5+MHsOO6A==", 732 | "dev": true, 733 | "requires": { 734 | "ini": "^1.3.5" 735 | } 736 | }, 737 | "got": { 738 | "version": "9.6.0", 739 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 740 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 741 | "dev": true, 742 | "requires": { 743 | "@sindresorhus/is": "^0.14.0", 744 | "@szmarczak/http-timer": "^1.1.2", 745 | "cacheable-request": "^6.0.0", 746 | "decompress-response": "^3.3.0", 747 | "duplexer3": "^0.1.4", 748 | "get-stream": "^4.1.0", 749 | "lowercase-keys": "^1.0.1", 750 | "mimic-response": "^1.0.1", 751 | "p-cancelable": "^1.0.0", 752 | "to-readable-stream": "^1.0.0", 753 | "url-parse-lax": "^3.0.0" 754 | } 755 | }, 756 | "graceful-fs": { 757 | "version": "4.2.4", 758 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", 759 | "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==", 760 | "dev": true 761 | }, 762 | "has-flag": { 763 | "version": "3.0.0", 764 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 765 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 766 | "dev": true 767 | }, 768 | "has-unicode": { 769 | "version": "2.0.1", 770 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 771 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" 772 | }, 773 | "has-yarn": { 774 | "version": "2.1.0", 775 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 776 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==", 777 | "dev": true 778 | }, 779 | "http-cache-semantics": { 780 | "version": "4.1.0", 781 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 782 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==", 783 | "dev": true 784 | }, 785 | "http-errors": { 786 | "version": "1.7.2", 787 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 788 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 789 | "requires": { 790 | "depd": "~1.1.2", 791 | "inherits": "2.0.3", 792 | "setprototypeof": "1.1.1", 793 | "statuses": ">= 1.5.0 < 2", 794 | "toidentifier": "1.0.0" 795 | } 796 | }, 797 | "iconv-lite": { 798 | "version": "0.4.24", 799 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 800 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 801 | "requires": { 802 | "safer-buffer": ">= 2.1.2 < 3" 803 | } 804 | }, 805 | "ignore-by-default": { 806 | "version": "1.0.1", 807 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 808 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 809 | "dev": true 810 | }, 811 | "ignore-walk": { 812 | "version": "3.0.3", 813 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz", 814 | "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==", 815 | "requires": { 816 | "minimatch": "^3.0.4" 817 | } 818 | }, 819 | "import-lazy": { 820 | "version": "2.1.0", 821 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 822 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 823 | "dev": true 824 | }, 825 | "imurmurhash": { 826 | "version": "0.1.4", 827 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 828 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 829 | "dev": true 830 | }, 831 | "inflight": { 832 | "version": "1.0.6", 833 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 834 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 835 | "requires": { 836 | "once": "^1.3.0", 837 | "wrappy": "1" 838 | } 839 | }, 840 | "inherits": { 841 | "version": "2.0.3", 842 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 843 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 844 | }, 845 | "ini": { 846 | "version": "1.3.5", 847 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 848 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 849 | }, 850 | "ipaddr.js": { 851 | "version": "1.9.1", 852 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 853 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 854 | }, 855 | "is-binary-path": { 856 | "version": "2.1.0", 857 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 858 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 859 | "dev": true, 860 | "requires": { 861 | "binary-extensions": "^2.0.0" 862 | } 863 | }, 864 | "is-ci": { 865 | "version": "2.0.0", 866 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 867 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 868 | "dev": true, 869 | "requires": { 870 | "ci-info": "^2.0.0" 871 | } 872 | }, 873 | "is-extglob": { 874 | "version": "2.1.1", 875 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 876 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 877 | "dev": true 878 | }, 879 | "is-fullwidth-code-point": { 880 | "version": "2.0.0", 881 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 882 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 883 | }, 884 | "is-glob": { 885 | "version": "4.0.1", 886 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 887 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 888 | "dev": true, 889 | "requires": { 890 | "is-extglob": "^2.1.1" 891 | } 892 | }, 893 | "is-installed-globally": { 894 | "version": "0.3.2", 895 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.2.tgz", 896 | "integrity": "sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g==", 897 | "dev": true, 898 | "requires": { 899 | "global-dirs": "^2.0.1", 900 | "is-path-inside": "^3.0.1" 901 | } 902 | }, 903 | "is-npm": { 904 | "version": "4.0.0", 905 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz", 906 | "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==", 907 | "dev": true 908 | }, 909 | "is-number": { 910 | "version": "7.0.0", 911 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 912 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 913 | "dev": true 914 | }, 915 | "is-obj": { 916 | "version": "2.0.0", 917 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 918 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 919 | "dev": true 920 | }, 921 | "is-path-inside": { 922 | "version": "3.0.2", 923 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.2.tgz", 924 | "integrity": "sha512-/2UGPSgmtqwo1ktx8NDHjuPwZWmHhO+gj0f93EkhLB5RgW9RZevWYYlIkS6zePc6U2WpOdQYIwHe9YC4DWEBVg==", 925 | "dev": true 926 | }, 927 | "is-typedarray": { 928 | "version": "1.0.0", 929 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 930 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 931 | "dev": true 932 | }, 933 | "is-yarn-global": { 934 | "version": "0.3.0", 935 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 936 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==", 937 | "dev": true 938 | }, 939 | "isarray": { 940 | "version": "1.0.0", 941 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 942 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 943 | }, 944 | "json-buffer": { 945 | "version": "3.0.0", 946 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 947 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=", 948 | "dev": true 949 | }, 950 | "jsonwebtoken": { 951 | "version": "8.5.1", 952 | "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz", 953 | "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==", 954 | "requires": { 955 | "jws": "^3.2.2", 956 | "lodash.includes": "^4.3.0", 957 | "lodash.isboolean": "^3.0.3", 958 | "lodash.isinteger": "^4.0.4", 959 | "lodash.isnumber": "^3.0.3", 960 | "lodash.isplainobject": "^4.0.6", 961 | "lodash.isstring": "^4.0.1", 962 | "lodash.once": "^4.0.0", 963 | "ms": "^2.1.1", 964 | "semver": "^5.6.0" 965 | }, 966 | "dependencies": { 967 | "ms": { 968 | "version": "2.1.2", 969 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 970 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 971 | } 972 | } 973 | }, 974 | "jwa": { 975 | "version": "1.4.1", 976 | "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", 977 | "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", 978 | "requires": { 979 | "buffer-equal-constant-time": "1.0.1", 980 | "ecdsa-sig-formatter": "1.0.11", 981 | "safe-buffer": "^5.0.1" 982 | } 983 | }, 984 | "jws": { 985 | "version": "3.2.2", 986 | "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", 987 | "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", 988 | "requires": { 989 | "jwa": "^1.4.1", 990 | "safe-buffer": "^5.0.1" 991 | } 992 | }, 993 | "kareem": { 994 | "version": "2.3.1", 995 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.1.tgz", 996 | "integrity": "sha512-l3hLhffs9zqoDe8zjmb/mAN4B8VT3L56EUvKNqLFVs9YlFA+zx7ke1DO8STAdDyYNkeSo1nKmjuvQeI12So8Xw==" 997 | }, 998 | "keyv": { 999 | "version": "3.1.0", 1000 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 1001 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 1002 | "dev": true, 1003 | "requires": { 1004 | "json-buffer": "3.0.0" 1005 | } 1006 | }, 1007 | "latest-version": { 1008 | "version": "5.1.0", 1009 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 1010 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 1011 | "dev": true, 1012 | "requires": { 1013 | "package-json": "^6.3.0" 1014 | } 1015 | }, 1016 | "lodash.includes": { 1017 | "version": "4.3.0", 1018 | "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", 1019 | "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8=" 1020 | }, 1021 | "lodash.isboolean": { 1022 | "version": "3.0.3", 1023 | "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", 1024 | "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY=" 1025 | }, 1026 | "lodash.isinteger": { 1027 | "version": "4.0.4", 1028 | "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", 1029 | "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M=" 1030 | }, 1031 | "lodash.isnumber": { 1032 | "version": "3.0.3", 1033 | "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", 1034 | "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w=" 1035 | }, 1036 | "lodash.isplainobject": { 1037 | "version": "4.0.6", 1038 | "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", 1039 | "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs=" 1040 | }, 1041 | "lodash.isstring": { 1042 | "version": "4.0.1", 1043 | "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", 1044 | "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE=" 1045 | }, 1046 | "lodash.once": { 1047 | "version": "4.1.1", 1048 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1049 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1050 | }, 1051 | "lowercase-keys": { 1052 | "version": "1.0.1", 1053 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 1054 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 1055 | "dev": true 1056 | }, 1057 | "make-dir": { 1058 | "version": "3.1.0", 1059 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1060 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1061 | "dev": true, 1062 | "requires": { 1063 | "semver": "^6.0.0" 1064 | }, 1065 | "dependencies": { 1066 | "semver": { 1067 | "version": "6.3.0", 1068 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1069 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1070 | "dev": true 1071 | } 1072 | } 1073 | }, 1074 | "media-typer": { 1075 | "version": "0.3.0", 1076 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1077 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1078 | }, 1079 | "memory-pager": { 1080 | "version": "1.5.0", 1081 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1082 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1083 | "optional": true 1084 | }, 1085 | "merge-descriptors": { 1086 | "version": "1.0.1", 1087 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1088 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1089 | }, 1090 | "methods": { 1091 | "version": "1.1.2", 1092 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1093 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1094 | }, 1095 | "mime": { 1096 | "version": "1.6.0", 1097 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1098 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1099 | }, 1100 | "mime-db": { 1101 | "version": "1.44.0", 1102 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", 1103 | "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==" 1104 | }, 1105 | "mime-types": { 1106 | "version": "2.1.27", 1107 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", 1108 | "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", 1109 | "requires": { 1110 | "mime-db": "1.44.0" 1111 | } 1112 | }, 1113 | "mimic-response": { 1114 | "version": "1.0.1", 1115 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 1116 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", 1117 | "dev": true 1118 | }, 1119 | "minimatch": { 1120 | "version": "3.0.4", 1121 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1122 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1123 | "requires": { 1124 | "brace-expansion": "^1.1.7" 1125 | } 1126 | }, 1127 | "minimist": { 1128 | "version": "1.2.5", 1129 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1130 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1131 | }, 1132 | "minipass": { 1133 | "version": "2.9.0", 1134 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", 1135 | "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", 1136 | "requires": { 1137 | "safe-buffer": "^5.1.2", 1138 | "yallist": "^3.0.0" 1139 | } 1140 | }, 1141 | "minizlib": { 1142 | "version": "1.3.3", 1143 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", 1144 | "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", 1145 | "requires": { 1146 | "minipass": "^2.9.0" 1147 | } 1148 | }, 1149 | "mkdirp": { 1150 | "version": "0.5.5", 1151 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1152 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1153 | "requires": { 1154 | "minimist": "^1.2.5" 1155 | } 1156 | }, 1157 | "mongodb": { 1158 | "version": "3.5.9", 1159 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.5.9.tgz", 1160 | "integrity": "sha512-vXHBY1CsGYcEPoVWhwgxIBeWqP3dSu9RuRDsoLRPTITrcrgm1f0Ubu1xqF9ozMwv53agmEiZm0YGo+7WL3Nbug==", 1161 | "requires": { 1162 | "bl": "^2.2.0", 1163 | "bson": "^1.1.4", 1164 | "denque": "^1.4.1", 1165 | "require_optional": "^1.0.1", 1166 | "safe-buffer": "^5.1.2", 1167 | "saslprep": "^1.0.0" 1168 | } 1169 | }, 1170 | "mongoose": { 1171 | "version": "5.9.21", 1172 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-5.9.21.tgz", 1173 | "integrity": "sha512-HQUemnKJdrE8ig+d3RTeOan6DWasmda8V97fs1ymozTNSuh2eGaf4D92/BrXYCw5QTgE/Ff5SxalndfgLn3DGg==", 1174 | "requires": { 1175 | "bson": "^1.1.4", 1176 | "kareem": "2.3.1", 1177 | "mongodb": "3.5.9", 1178 | "mongoose-legacy-pluralize": "1.0.2", 1179 | "mpath": "0.7.0", 1180 | "mquery": "3.2.2", 1181 | "ms": "2.1.2", 1182 | "regexp-clone": "1.0.0", 1183 | "safe-buffer": "5.1.2", 1184 | "sift": "7.0.1", 1185 | "sliced": "1.0.1" 1186 | }, 1187 | "dependencies": { 1188 | "ms": { 1189 | "version": "2.1.2", 1190 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1191 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1192 | } 1193 | } 1194 | }, 1195 | "mongoose-legacy-pluralize": { 1196 | "version": "1.0.2", 1197 | "resolved": "https://registry.npmjs.org/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz", 1198 | "integrity": "sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ==" 1199 | }, 1200 | "mpath": { 1201 | "version": "0.7.0", 1202 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.7.0.tgz", 1203 | "integrity": "sha512-Aiq04hILxhz1L+f7sjGyn7IxYzWm1zLNNXcfhDtx04kZ2Gk7uvFdgZ8ts1cWa/6d0TQmag2yR8zSGZUmp0tFNg==" 1204 | }, 1205 | "mquery": { 1206 | "version": "3.2.2", 1207 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-3.2.2.tgz", 1208 | "integrity": "sha512-XB52992COp0KP230I3qloVUbkLUxJIu328HBP2t2EsxSFtf4W1HPSOBWOXf1bqxK4Xbb66lfMJ+Bpfd9/yZE1Q==", 1209 | "requires": { 1210 | "bluebird": "3.5.1", 1211 | "debug": "3.1.0", 1212 | "regexp-clone": "^1.0.0", 1213 | "safe-buffer": "5.1.2", 1214 | "sliced": "1.0.1" 1215 | }, 1216 | "dependencies": { 1217 | "debug": { 1218 | "version": "3.1.0", 1219 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1220 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1221 | "requires": { 1222 | "ms": "2.0.0" 1223 | } 1224 | } 1225 | } 1226 | }, 1227 | "ms": { 1228 | "version": "2.0.0", 1229 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1230 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1231 | }, 1232 | "needle": { 1233 | "version": "2.5.0", 1234 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.5.0.tgz", 1235 | "integrity": "sha512-o/qITSDR0JCyCKEQ1/1bnUXMmznxabbwi/Y4WwJElf+evwJNFNwIDMCCt5IigFVxgeGBJESLohGtIS9gEzo1fA==", 1236 | "requires": { 1237 | "debug": "^3.2.6", 1238 | "iconv-lite": "^0.4.4", 1239 | "sax": "^1.2.4" 1240 | }, 1241 | "dependencies": { 1242 | "debug": { 1243 | "version": "3.2.6", 1244 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1245 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1246 | "requires": { 1247 | "ms": "^2.1.1" 1248 | } 1249 | }, 1250 | "ms": { 1251 | "version": "2.1.2", 1252 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1253 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1254 | } 1255 | } 1256 | }, 1257 | "negotiator": { 1258 | "version": "0.6.2", 1259 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1260 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 1261 | }, 1262 | "node-addon-api": { 1263 | "version": "3.0.0", 1264 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.0.0.tgz", 1265 | "integrity": "sha512-sSHCgWfJ+Lui/u+0msF3oyCgvdkhxDbkCS6Q8uiJquzOimkJBvX6hl5aSSA7DR1XbMpdM8r7phjcF63sF4rkKg==" 1266 | }, 1267 | "node-pre-gyp": { 1268 | "version": "0.15.0", 1269 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.15.0.tgz", 1270 | "integrity": "sha512-7QcZa8/fpaU/BKenjcaeFF9hLz2+7S9AqyXFhlH/rilsQ/hPZKK32RtR5EQHJElgu+q5RfbJ34KriI79UWaorA==", 1271 | "requires": { 1272 | "detect-libc": "^1.0.2", 1273 | "mkdirp": "^0.5.3", 1274 | "needle": "^2.5.0", 1275 | "nopt": "^4.0.1", 1276 | "npm-packlist": "^1.1.6", 1277 | "npmlog": "^4.0.2", 1278 | "rc": "^1.2.7", 1279 | "rimraf": "^2.6.1", 1280 | "semver": "^5.3.0", 1281 | "tar": "^4.4.2" 1282 | }, 1283 | "dependencies": { 1284 | "nopt": { 1285 | "version": "4.0.3", 1286 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz", 1287 | "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==", 1288 | "requires": { 1289 | "abbrev": "1", 1290 | "osenv": "^0.1.4" 1291 | } 1292 | } 1293 | } 1294 | }, 1295 | "nodemon": { 1296 | "version": "2.0.4", 1297 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.4.tgz", 1298 | "integrity": "sha512-Ltced+hIfTmaS28Zjv1BM552oQ3dbwPqI4+zI0SLgq+wpJhSyqgYude/aZa/3i31VCQWMfXJVxvu86abcam3uQ==", 1299 | "dev": true, 1300 | "requires": { 1301 | "chokidar": "^3.2.2", 1302 | "debug": "^3.2.6", 1303 | "ignore-by-default": "^1.0.1", 1304 | "minimatch": "^3.0.4", 1305 | "pstree.remy": "^1.1.7", 1306 | "semver": "^5.7.1", 1307 | "supports-color": "^5.5.0", 1308 | "touch": "^3.1.0", 1309 | "undefsafe": "^2.0.2", 1310 | "update-notifier": "^4.0.0" 1311 | }, 1312 | "dependencies": { 1313 | "debug": { 1314 | "version": "3.2.6", 1315 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1316 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1317 | "dev": true, 1318 | "requires": { 1319 | "ms": "^2.1.1" 1320 | } 1321 | }, 1322 | "ms": { 1323 | "version": "2.1.2", 1324 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1325 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1326 | "dev": true 1327 | } 1328 | } 1329 | }, 1330 | "nopt": { 1331 | "version": "1.0.10", 1332 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1333 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1334 | "dev": true, 1335 | "requires": { 1336 | "abbrev": "1" 1337 | } 1338 | }, 1339 | "normalize-path": { 1340 | "version": "3.0.0", 1341 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1342 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1343 | "dev": true 1344 | }, 1345 | "normalize-url": { 1346 | "version": "4.5.0", 1347 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.0.tgz", 1348 | "integrity": "sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ==", 1349 | "dev": true 1350 | }, 1351 | "npm-bundled": { 1352 | "version": "1.1.1", 1353 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz", 1354 | "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==", 1355 | "requires": { 1356 | "npm-normalize-package-bin": "^1.0.1" 1357 | } 1358 | }, 1359 | "npm-normalize-package-bin": { 1360 | "version": "1.0.1", 1361 | "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", 1362 | "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==" 1363 | }, 1364 | "npm-packlist": { 1365 | "version": "1.4.8", 1366 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.8.tgz", 1367 | "integrity": "sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A==", 1368 | "requires": { 1369 | "ignore-walk": "^3.0.1", 1370 | "npm-bundled": "^1.0.1", 1371 | "npm-normalize-package-bin": "^1.0.1" 1372 | } 1373 | }, 1374 | "npmlog": { 1375 | "version": "4.1.2", 1376 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 1377 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 1378 | "requires": { 1379 | "are-we-there-yet": "~1.1.2", 1380 | "console-control-strings": "~1.1.0", 1381 | "gauge": "~2.7.3", 1382 | "set-blocking": "~2.0.0" 1383 | } 1384 | }, 1385 | "number-is-nan": { 1386 | "version": "1.0.1", 1387 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1388 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1389 | }, 1390 | "object-assign": { 1391 | "version": "4.1.1", 1392 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1393 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1394 | }, 1395 | "on-finished": { 1396 | "version": "2.3.0", 1397 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1398 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1399 | "requires": { 1400 | "ee-first": "1.1.1" 1401 | } 1402 | }, 1403 | "once": { 1404 | "version": "1.4.0", 1405 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1406 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1407 | "requires": { 1408 | "wrappy": "1" 1409 | } 1410 | }, 1411 | "os-homedir": { 1412 | "version": "1.0.2", 1413 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1414 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1415 | }, 1416 | "os-tmpdir": { 1417 | "version": "1.0.2", 1418 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1419 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1420 | }, 1421 | "osenv": { 1422 | "version": "0.1.5", 1423 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1424 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1425 | "requires": { 1426 | "os-homedir": "^1.0.0", 1427 | "os-tmpdir": "^1.0.0" 1428 | } 1429 | }, 1430 | "p-cancelable": { 1431 | "version": "1.1.0", 1432 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 1433 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==", 1434 | "dev": true 1435 | }, 1436 | "package-json": { 1437 | "version": "6.5.0", 1438 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 1439 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 1440 | "dev": true, 1441 | "requires": { 1442 | "got": "^9.6.0", 1443 | "registry-auth-token": "^4.0.0", 1444 | "registry-url": "^5.0.0", 1445 | "semver": "^6.2.0" 1446 | }, 1447 | "dependencies": { 1448 | "semver": { 1449 | "version": "6.3.0", 1450 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1451 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1452 | "dev": true 1453 | } 1454 | } 1455 | }, 1456 | "parseurl": { 1457 | "version": "1.3.3", 1458 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1459 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 1460 | }, 1461 | "path-is-absolute": { 1462 | "version": "1.0.1", 1463 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1464 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1465 | }, 1466 | "path-to-regexp": { 1467 | "version": "0.1.7", 1468 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1469 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 1470 | }, 1471 | "picomatch": { 1472 | "version": "2.2.2", 1473 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 1474 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 1475 | "dev": true 1476 | }, 1477 | "prepend-http": { 1478 | "version": "2.0.0", 1479 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 1480 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=", 1481 | "dev": true 1482 | }, 1483 | "process-nextick-args": { 1484 | "version": "2.0.1", 1485 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1486 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 1487 | }, 1488 | "proxy-addr": { 1489 | "version": "2.0.6", 1490 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", 1491 | "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", 1492 | "requires": { 1493 | "forwarded": "~0.1.2", 1494 | "ipaddr.js": "1.9.1" 1495 | } 1496 | }, 1497 | "pstree.remy": { 1498 | "version": "1.1.8", 1499 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 1500 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 1501 | "dev": true 1502 | }, 1503 | "pump": { 1504 | "version": "3.0.0", 1505 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1506 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1507 | "dev": true, 1508 | "requires": { 1509 | "end-of-stream": "^1.1.0", 1510 | "once": "^1.3.1" 1511 | } 1512 | }, 1513 | "pupa": { 1514 | "version": "2.0.1", 1515 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.0.1.tgz", 1516 | "integrity": "sha512-hEJH0s8PXLY/cdXh66tNEQGndDrIKNqNC5xmrysZy3i5C3oEoLna7YAOad+7u125+zH1HNXUmGEkrhb3c2VriA==", 1517 | "dev": true, 1518 | "requires": { 1519 | "escape-goat": "^2.0.0" 1520 | } 1521 | }, 1522 | "qs": { 1523 | "version": "6.7.0", 1524 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 1525 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 1526 | }, 1527 | "range-parser": { 1528 | "version": "1.2.1", 1529 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1530 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 1531 | }, 1532 | "raw-body": { 1533 | "version": "2.4.0", 1534 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1535 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1536 | "requires": { 1537 | "bytes": "3.1.0", 1538 | "http-errors": "1.7.2", 1539 | "iconv-lite": "0.4.24", 1540 | "unpipe": "1.0.0" 1541 | } 1542 | }, 1543 | "rc": { 1544 | "version": "1.2.8", 1545 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1546 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1547 | "requires": { 1548 | "deep-extend": "^0.6.0", 1549 | "ini": "~1.3.0", 1550 | "minimist": "^1.2.0", 1551 | "strip-json-comments": "~2.0.1" 1552 | } 1553 | }, 1554 | "readable-stream": { 1555 | "version": "2.3.7", 1556 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1557 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1558 | "requires": { 1559 | "core-util-is": "~1.0.0", 1560 | "inherits": "~2.0.3", 1561 | "isarray": "~1.0.0", 1562 | "process-nextick-args": "~2.0.0", 1563 | "safe-buffer": "~5.1.1", 1564 | "string_decoder": "~1.1.1", 1565 | "util-deprecate": "~1.0.1" 1566 | } 1567 | }, 1568 | "readdirp": { 1569 | "version": "3.4.0", 1570 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.4.0.tgz", 1571 | "integrity": "sha512-0xe001vZBnJEK+uKcj8qOhyAKPzIT+gStxWr3LCB0DwcXR5NZJ3IaC+yGnHCYzB/S7ov3m3EEbZI2zeNvX+hGQ==", 1572 | "dev": true, 1573 | "requires": { 1574 | "picomatch": "^2.2.1" 1575 | } 1576 | }, 1577 | "regexp-clone": { 1578 | "version": "1.0.0", 1579 | "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-1.0.0.tgz", 1580 | "integrity": "sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw==" 1581 | }, 1582 | "registry-auth-token": { 1583 | "version": "4.1.1", 1584 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.1.1.tgz", 1585 | "integrity": "sha512-9bKS7nTl9+/A1s7tnPeGrUpRcVY+LUh7bfFgzpndALdPfXQBfQV77rQVtqgUV3ti4vc/Ik81Ex8UJDWDQ12zQA==", 1586 | "dev": true, 1587 | "requires": { 1588 | "rc": "^1.2.8" 1589 | } 1590 | }, 1591 | "registry-url": { 1592 | "version": "5.1.0", 1593 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 1594 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 1595 | "dev": true, 1596 | "requires": { 1597 | "rc": "^1.2.8" 1598 | } 1599 | }, 1600 | "require_optional": { 1601 | "version": "1.0.1", 1602 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1603 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1604 | "requires": { 1605 | "resolve-from": "^2.0.0", 1606 | "semver": "^5.1.0" 1607 | } 1608 | }, 1609 | "resolve-from": { 1610 | "version": "2.0.0", 1611 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1612 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=" 1613 | }, 1614 | "responselike": { 1615 | "version": "1.0.2", 1616 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 1617 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 1618 | "dev": true, 1619 | "requires": { 1620 | "lowercase-keys": "^1.0.0" 1621 | } 1622 | }, 1623 | "rimraf": { 1624 | "version": "2.7.1", 1625 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1626 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1627 | "requires": { 1628 | "glob": "^7.1.3" 1629 | } 1630 | }, 1631 | "safe-buffer": { 1632 | "version": "5.1.2", 1633 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1634 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1635 | }, 1636 | "safer-buffer": { 1637 | "version": "2.1.2", 1638 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1639 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 1640 | }, 1641 | "saslprep": { 1642 | "version": "1.0.3", 1643 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 1644 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 1645 | "optional": true, 1646 | "requires": { 1647 | "sparse-bitfield": "^3.0.3" 1648 | } 1649 | }, 1650 | "sax": { 1651 | "version": "1.2.4", 1652 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 1653 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" 1654 | }, 1655 | "semver": { 1656 | "version": "5.7.1", 1657 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1658 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1659 | }, 1660 | "semver-diff": { 1661 | "version": "3.1.1", 1662 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 1663 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 1664 | "dev": true, 1665 | "requires": { 1666 | "semver": "^6.3.0" 1667 | }, 1668 | "dependencies": { 1669 | "semver": { 1670 | "version": "6.3.0", 1671 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1672 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1673 | "dev": true 1674 | } 1675 | } 1676 | }, 1677 | "send": { 1678 | "version": "0.17.1", 1679 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1680 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1681 | "requires": { 1682 | "debug": "2.6.9", 1683 | "depd": "~1.1.2", 1684 | "destroy": "~1.0.4", 1685 | "encodeurl": "~1.0.2", 1686 | "escape-html": "~1.0.3", 1687 | "etag": "~1.8.1", 1688 | "fresh": "0.5.2", 1689 | "http-errors": "~1.7.2", 1690 | "mime": "1.6.0", 1691 | "ms": "2.1.1", 1692 | "on-finished": "~2.3.0", 1693 | "range-parser": "~1.2.1", 1694 | "statuses": "~1.5.0" 1695 | }, 1696 | "dependencies": { 1697 | "ms": { 1698 | "version": "2.1.1", 1699 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1700 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 1701 | } 1702 | } 1703 | }, 1704 | "serve-static": { 1705 | "version": "1.14.1", 1706 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1707 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1708 | "requires": { 1709 | "encodeurl": "~1.0.2", 1710 | "escape-html": "~1.0.3", 1711 | "parseurl": "~1.3.3", 1712 | "send": "0.17.1" 1713 | } 1714 | }, 1715 | "set-blocking": { 1716 | "version": "2.0.0", 1717 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1718 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1719 | }, 1720 | "setprototypeof": { 1721 | "version": "1.1.1", 1722 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1723 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1724 | }, 1725 | "sift": { 1726 | "version": "7.0.1", 1727 | "resolved": "https://registry.npmjs.org/sift/-/sift-7.0.1.tgz", 1728 | "integrity": "sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g==" 1729 | }, 1730 | "signal-exit": { 1731 | "version": "3.0.3", 1732 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", 1733 | "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==" 1734 | }, 1735 | "sliced": { 1736 | "version": "1.0.1", 1737 | "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz", 1738 | "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E=" 1739 | }, 1740 | "sparse-bitfield": { 1741 | "version": "3.0.3", 1742 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1743 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 1744 | "optional": true, 1745 | "requires": { 1746 | "memory-pager": "^1.0.2" 1747 | } 1748 | }, 1749 | "sprintf-js": { 1750 | "version": "1.0.3", 1751 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1752 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 1753 | }, 1754 | "statuses": { 1755 | "version": "1.5.0", 1756 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1757 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 1758 | }, 1759 | "string-width": { 1760 | "version": "4.2.0", 1761 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 1762 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 1763 | "dev": true, 1764 | "requires": { 1765 | "emoji-regex": "^8.0.0", 1766 | "is-fullwidth-code-point": "^3.0.0", 1767 | "strip-ansi": "^6.0.0" 1768 | }, 1769 | "dependencies": { 1770 | "ansi-regex": { 1771 | "version": "5.0.0", 1772 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 1773 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 1774 | "dev": true 1775 | }, 1776 | "emoji-regex": { 1777 | "version": "8.0.0", 1778 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1779 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1780 | "dev": true 1781 | }, 1782 | "is-fullwidth-code-point": { 1783 | "version": "3.0.0", 1784 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1785 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1786 | "dev": true 1787 | }, 1788 | "strip-ansi": { 1789 | "version": "6.0.0", 1790 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 1791 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 1792 | "dev": true, 1793 | "requires": { 1794 | "ansi-regex": "^5.0.0" 1795 | } 1796 | } 1797 | } 1798 | }, 1799 | "string_decoder": { 1800 | "version": "1.1.1", 1801 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1802 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1803 | "requires": { 1804 | "safe-buffer": "~5.1.0" 1805 | } 1806 | }, 1807 | "strip-ansi": { 1808 | "version": "5.2.0", 1809 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1810 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1811 | "dev": true, 1812 | "requires": { 1813 | "ansi-regex": "^4.1.0" 1814 | } 1815 | }, 1816 | "strip-json-comments": { 1817 | "version": "2.0.1", 1818 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1819 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 1820 | }, 1821 | "supports-color": { 1822 | "version": "5.5.0", 1823 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1824 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1825 | "dev": true, 1826 | "requires": { 1827 | "has-flag": "^3.0.0" 1828 | } 1829 | }, 1830 | "swagger-ui-dist": { 1831 | "version": "3.28.0", 1832 | "resolved": "https://registry.npmjs.org/swagger-ui-dist/-/swagger-ui-dist-3.28.0.tgz", 1833 | "integrity": "sha512-aPkfTzPv9djSiZI1NUkWr5HynCUsH+jaJ0WSx+/t19wq7MMGg9clHm9nGoIpAtqml1G51ofI+I75Ym72pukzFg==" 1834 | }, 1835 | "swagger-ui-express": { 1836 | "version": "4.1.4", 1837 | "resolved": "https://registry.npmjs.org/swagger-ui-express/-/swagger-ui-express-4.1.4.tgz", 1838 | "integrity": "sha512-Ea96ecpC+Iq9GUqkeD/LFR32xSs8gYqmTW1gXCuKg81c26WV6ZC2FsBSPVExQP6WkyUuz5HEiR0sEv/HCC343g==", 1839 | "requires": { 1840 | "swagger-ui-dist": "^3.18.1" 1841 | } 1842 | }, 1843 | "tar": { 1844 | "version": "4.4.13", 1845 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", 1846 | "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", 1847 | "requires": { 1848 | "chownr": "^1.1.1", 1849 | "fs-minipass": "^1.2.5", 1850 | "minipass": "^2.8.6", 1851 | "minizlib": "^1.2.1", 1852 | "mkdirp": "^0.5.0", 1853 | "safe-buffer": "^5.1.2", 1854 | "yallist": "^3.0.3" 1855 | } 1856 | }, 1857 | "term-size": { 1858 | "version": "2.2.0", 1859 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.0.tgz", 1860 | "integrity": "sha512-a6sumDlzyHVJWb8+YofY4TW112G6p2FCPEAFk+59gIYHv3XHRhm9ltVQ9kli4hNWeQBwSpe8cRN25x0ROunMOw==", 1861 | "dev": true 1862 | }, 1863 | "to-readable-stream": { 1864 | "version": "1.0.0", 1865 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 1866 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==", 1867 | "dev": true 1868 | }, 1869 | "to-regex-range": { 1870 | "version": "5.0.1", 1871 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1872 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1873 | "dev": true, 1874 | "requires": { 1875 | "is-number": "^7.0.0" 1876 | } 1877 | }, 1878 | "toidentifier": { 1879 | "version": "1.0.0", 1880 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1881 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 1882 | }, 1883 | "touch": { 1884 | "version": "3.1.0", 1885 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 1886 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 1887 | "dev": true, 1888 | "requires": { 1889 | "nopt": "~1.0.10" 1890 | } 1891 | }, 1892 | "type-fest": { 1893 | "version": "0.8.1", 1894 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1895 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1896 | "dev": true 1897 | }, 1898 | "type-is": { 1899 | "version": "1.6.18", 1900 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1901 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1902 | "requires": { 1903 | "media-typer": "0.3.0", 1904 | "mime-types": "~2.1.24" 1905 | } 1906 | }, 1907 | "typedarray-to-buffer": { 1908 | "version": "3.1.5", 1909 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 1910 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 1911 | "dev": true, 1912 | "requires": { 1913 | "is-typedarray": "^1.0.0" 1914 | } 1915 | }, 1916 | "undefsafe": { 1917 | "version": "2.0.3", 1918 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.3.tgz", 1919 | "integrity": "sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A==", 1920 | "dev": true, 1921 | "requires": { 1922 | "debug": "^2.2.0" 1923 | } 1924 | }, 1925 | "unique-string": { 1926 | "version": "2.0.0", 1927 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 1928 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 1929 | "dev": true, 1930 | "requires": { 1931 | "crypto-random-string": "^2.0.0" 1932 | } 1933 | }, 1934 | "unpipe": { 1935 | "version": "1.0.0", 1936 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1937 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 1938 | }, 1939 | "update-notifier": { 1940 | "version": "4.1.0", 1941 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.1.0.tgz", 1942 | "integrity": "sha512-w3doE1qtI0/ZmgeoDoARmI5fjDoT93IfKgEGqm26dGUOh8oNpaSTsGNdYRN/SjOuo10jcJGwkEL3mroKzktkew==", 1943 | "dev": true, 1944 | "requires": { 1945 | "boxen": "^4.2.0", 1946 | "chalk": "^3.0.0", 1947 | "configstore": "^5.0.1", 1948 | "has-yarn": "^2.1.0", 1949 | "import-lazy": "^2.1.0", 1950 | "is-ci": "^2.0.0", 1951 | "is-installed-globally": "^0.3.1", 1952 | "is-npm": "^4.0.0", 1953 | "is-yarn-global": "^0.3.0", 1954 | "latest-version": "^5.0.0", 1955 | "pupa": "^2.0.1", 1956 | "semver-diff": "^3.1.1", 1957 | "xdg-basedir": "^4.0.0" 1958 | } 1959 | }, 1960 | "url-parse-lax": { 1961 | "version": "3.0.0", 1962 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 1963 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 1964 | "dev": true, 1965 | "requires": { 1966 | "prepend-http": "^2.0.0" 1967 | } 1968 | }, 1969 | "util-deprecate": { 1970 | "version": "1.0.2", 1971 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1972 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 1973 | }, 1974 | "utils-merge": { 1975 | "version": "1.0.1", 1976 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1977 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 1978 | }, 1979 | "vary": { 1980 | "version": "1.1.2", 1981 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1982 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 1983 | }, 1984 | "wide-align": { 1985 | "version": "1.1.3", 1986 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1987 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1988 | "requires": { 1989 | "string-width": "^1.0.2 || 2" 1990 | }, 1991 | "dependencies": { 1992 | "ansi-regex": { 1993 | "version": "3.0.0", 1994 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1995 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 1996 | }, 1997 | "string-width": { 1998 | "version": "2.1.1", 1999 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2000 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2001 | "requires": { 2002 | "is-fullwidth-code-point": "^2.0.0", 2003 | "strip-ansi": "^4.0.0" 2004 | } 2005 | }, 2006 | "strip-ansi": { 2007 | "version": "4.0.0", 2008 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2009 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2010 | "requires": { 2011 | "ansi-regex": "^3.0.0" 2012 | } 2013 | } 2014 | } 2015 | }, 2016 | "widest-line": { 2017 | "version": "3.1.0", 2018 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 2019 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 2020 | "dev": true, 2021 | "requires": { 2022 | "string-width": "^4.0.0" 2023 | } 2024 | }, 2025 | "wrappy": { 2026 | "version": "1.0.2", 2027 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2028 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2029 | }, 2030 | "write-file-atomic": { 2031 | "version": "3.0.3", 2032 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 2033 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 2034 | "dev": true, 2035 | "requires": { 2036 | "imurmurhash": "^0.1.4", 2037 | "is-typedarray": "^1.0.0", 2038 | "signal-exit": "^3.0.2", 2039 | "typedarray-to-buffer": "^3.1.5" 2040 | } 2041 | }, 2042 | "xdg-basedir": { 2043 | "version": "4.0.0", 2044 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 2045 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 2046 | "dev": true 2047 | }, 2048 | "yallist": { 2049 | "version": "3.1.1", 2050 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 2051 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" 2052 | }, 2053 | "yamljs": { 2054 | "version": "0.3.0", 2055 | "resolved": "https://registry.npmjs.org/yamljs/-/yamljs-0.3.0.tgz", 2056 | "integrity": "sha512-C/FsVVhht4iPQYXOInoxUM/1ELSf9EsgKH34FofQOp6hwCPrW4vG4w5++TED3xRUo8gD7l0P1J1dLlDYzODsTQ==", 2057 | "requires": { 2058 | "argparse": "^1.0.7", 2059 | "glob": "^7.0.5" 2060 | } 2061 | } 2062 | } 2063 | } 2064 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "argent-bank-api", 3 | "version": "0.0.1", 4 | "private": true, 5 | "description": "Project #10 - Argent Bank", 6 | "keywords": [], 7 | "author": "", 8 | "license": "", 9 | "main": "index.js", 10 | "dependencies": { 11 | "axios": "^0.19.2", 12 | "bcrypt": "^5.0.0", 13 | "cors": "^2.8.5", 14 | "dotenv": "^8.2.0", 15 | "express": "^4.17.1", 16 | "jsonwebtoken": "^8.5.1", 17 | "mongoose": "^5.9.21", 18 | "swagger-ui-express": "^4.1.4", 19 | "yamljs": "^0.3.0" 20 | }, 21 | "scripts": { 22 | "dev:server": "nodemon ./server/server.js", 23 | "populate-db": "node ./server/scripts/populateDatabase.js", 24 | "server": "node ./server/server.js" 25 | }, 26 | "devDependencies": { 27 | "nodemon": "^2.0.4" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /server/controllers/userController.js: -------------------------------------------------------------------------------- 1 | const userService = require('../services/userService') 2 | 3 | module.exports.createUser = async (req, res) => { 4 | let response = {} 5 | 6 | try { 7 | const responseFromService = await userService.createUser(req.body) 8 | response.status = 200 9 | response.message = 'User successfully created' 10 | response.body = responseFromService 11 | } catch (error) { 12 | console.error('Something went wrong in userController.js', error) 13 | response.status = 400 14 | response.message = error.message 15 | } 16 | 17 | return res.status(response.status).send(response) 18 | } 19 | 20 | module.exports.loginUser = async (req, res) => { 21 | let response = {} 22 | 23 | try { 24 | const responseFromService = await userService.loginUser(req.body) 25 | response.status = 200 26 | response.message = 'User successfully logged in' 27 | response.body = responseFromService 28 | } catch (error) { 29 | console.error('Error in loginUser (userController.js)') 30 | response.status = 400 31 | response.message = error.message 32 | } 33 | 34 | return res.status(response.status).send(response) 35 | } 36 | 37 | module.exports.getUserProfile = async (req, res) => { 38 | let response = {} 39 | 40 | try { 41 | const responseFromService = await userService.getUserProfile(req) 42 | response.status = 200 43 | response.message = 'Successfully got user profile data' 44 | response.body = responseFromService 45 | } catch (error) { 46 | console.log('Error in userController.js') 47 | response.status = 400 48 | response.message = error.message 49 | } 50 | 51 | return res.status(response.status).send(response) 52 | } 53 | 54 | module.exports.updateUserProfile = async (req, res) => { 55 | let response = {} 56 | 57 | try { 58 | const responseFromService = await userService.updateUserProfile(req) 59 | response.status = 200 60 | response.message = 'Successfully updated user profile data' 61 | response.body = responseFromService 62 | } catch (error) { 63 | console.log('Error in updateUserProfile - userController.js') 64 | response.status = 400 65 | response.message = error.message 66 | } 67 | 68 | return res.status(response.status).send(response) 69 | } 70 | -------------------------------------------------------------------------------- /server/database/connection.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose') 2 | const databaseUrl = 3 | process.env.DATABASE_URL || 'mongodb://localhost/argentBankDB' 4 | 5 | module.exports = async () => { 6 | try { 7 | await mongoose.connect(databaseUrl, { useNewUrlParser: true }) 8 | console.log('Database successfully connected') 9 | } catch (error) { 10 | console.error(`Database Connectivity Error: ${error}`) 11 | throw new Error(error) 12 | } 13 | } 14 | -------------------------------------------------------------------------------- /server/database/models/userModel.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose') 2 | 3 | const userSchema = new mongoose.Schema( 4 | { 5 | email: String, 6 | password: String, 7 | firstName: String, 8 | lastName: String 9 | }, 10 | { 11 | timestamps: true, 12 | toObject: { 13 | transform: (doc, ret, options) => { 14 | ret.id = ret._id 15 | delete ret._id 16 | delete ret.password 17 | delete ret.__v 18 | return ret 19 | } 20 | } 21 | } 22 | ) 23 | 24 | module.exports = mongoose.model('User', userSchema) 25 | -------------------------------------------------------------------------------- /server/middleware/tokenValidation.js: -------------------------------------------------------------------------------- 1 | const jwt = require('jsonwebtoken') 2 | const { restart } = require('nodemon') 3 | 4 | module.exports.validateToken = (req, res, next) => { 5 | let response = {} 6 | 7 | try { 8 | if (!req.headers.authorization) { 9 | throw new Error('Token is missing from header') 10 | } 11 | 12 | const userToken = req.headers.authorization.split('Bearer')[1].trim() 13 | const decodedToken = jwt.verify( 14 | userToken, 15 | process.env.SECRET_KEY || 'default-secret-key' 16 | ) 17 | return next() 18 | } catch (error) { 19 | console.error('Error in tokenValidation.js', error) 20 | response.status = 401 21 | response.message = error.message 22 | } 23 | 24 | return res.status(response.status).send(response) 25 | } 26 | -------------------------------------------------------------------------------- /server/routes/userRoutes.js: -------------------------------------------------------------------------------- 1 | const express = require('express') 2 | const router = express.Router() 3 | const userController = require('../controllers/userController') 4 | const tokenValidation = require('../middleware/tokenValidation') 5 | 6 | router.post('/signup', userController.createUser) 7 | 8 | router.post('/login', userController.loginUser) 9 | 10 | router.post( 11 | '/profile', 12 | tokenValidation.validateToken, 13 | userController.getUserProfile 14 | ) 15 | 16 | router.put( 17 | '/profile', 18 | tokenValidation.validateToken, 19 | userController.updateUserProfile 20 | ) 21 | 22 | module.exports = router 23 | -------------------------------------------------------------------------------- /server/scripts/populateDatabase.js: -------------------------------------------------------------------------------- 1 | const axios = require('axios') 2 | const signupApi = 'http://localhost:3001/api/v1/user/signup' 3 | 4 | const users = [ 5 | { 6 | firstName: 'Tony', 7 | lastName: 'Stark', 8 | email: 'tony@stark.com', 9 | password: 'password123' 10 | }, 11 | { 12 | firstName: 'Steve', 13 | lastName: 'Rogers', 14 | email: 'steve@rogers.com', 15 | password: 'password456' 16 | } 17 | ] 18 | 19 | users.forEach(user => { 20 | axios 21 | .post(signupApi, user) 22 | .then(response => console.log(response)) 23 | .catch(error => console.log(error)) 24 | }) 25 | -------------------------------------------------------------------------------- /server/server.js: -------------------------------------------------------------------------------- 1 | const express = require('express') 2 | const dotEnv = require('dotenv') 3 | const cors = require('cors') 4 | const swaggerUi = require('swagger-ui-express') 5 | const yaml = require('yamljs') 6 | const swaggerDocs = yaml.load('./swagger.yaml') 7 | const dbConnection = require('./database/connection') 8 | 9 | dotEnv.config() 10 | 11 | const app = express() 12 | const PORT = process.env.PORT || 3001 13 | 14 | // Connect to the database 15 | dbConnection() 16 | 17 | // Handle CORS issues 18 | app.use(cors()) 19 | 20 | // Request payload middleware 21 | app.use(express.json()) 22 | app.use(express.urlencoded({ extended: true })) 23 | 24 | // Handle custom routes 25 | app.use('/api/v1/user', require('./routes/userRoutes')) 26 | 27 | // API Documentation 28 | if (process.env.NODE_ENV !== 'production') { 29 | app.use('/api-docs', swaggerUi.serve, swaggerUi.setup(swaggerDocs)) 30 | } 31 | 32 | app.get('/', (req, res, next) => { 33 | res.send('Hello from my Express server v2!') 34 | }) 35 | 36 | app.listen(PORT, () => { 37 | console.log(`Server listening on http://localhost:${PORT}`) 38 | }) 39 | -------------------------------------------------------------------------------- /server/services/userService.js: -------------------------------------------------------------------------------- 1 | const User = require('../database/models/userModel') 2 | const bcrypt = require('bcrypt') 3 | const jwt = require('jsonwebtoken') 4 | 5 | module.exports.createUser = async serviceData => { 6 | try { 7 | const user = await User.findOne({ email: serviceData.email }) 8 | if (user) { 9 | throw new Error('Email already exists') 10 | } 11 | 12 | const hashPassword = await bcrypt.hash(serviceData.password, 12) 13 | 14 | const newUser = new User({ 15 | email: serviceData.email, 16 | password: hashPassword, 17 | firstName: serviceData.firstName, 18 | lastName: serviceData.lastName 19 | }) 20 | 21 | let result = await newUser.save() 22 | 23 | return result 24 | } catch (error) { 25 | console.error('Error in userService.js', error) 26 | throw new Error(error) 27 | } 28 | } 29 | 30 | module.exports.getUserProfile = async serviceData => { 31 | try { 32 | const jwtToken = serviceData.headers.authorization.split('Bearer')[1].trim() 33 | const decodedJwtToken = jwt.decode(jwtToken) 34 | const user = await User.findOne({ _id: decodedJwtToken.id }) 35 | 36 | if (!user) { 37 | throw new Error('User not found!') 38 | } 39 | 40 | return user.toObject() 41 | } catch (error) { 42 | console.error('Error in userService.js', error) 43 | throw new Error(error) 44 | } 45 | } 46 | 47 | module.exports.loginUser = async serviceData => { 48 | try { 49 | const user = await User.findOne({ email: serviceData.email }) 50 | 51 | if (!user) { 52 | throw new Error('User not found!') 53 | } 54 | 55 | const isValid = await bcrypt.compare(serviceData.password, user.password) 56 | 57 | if (!isValid) { 58 | throw new Error('Password is invalid') 59 | } 60 | 61 | const token = jwt.sign( 62 | { id: user._id }, 63 | process.env.SECRET_KEY || 'default-secret-key', 64 | { expiresIn: '1d' } 65 | ) 66 | 67 | return { token } 68 | } catch (error) { 69 | console.error('Error in userService.js', error) 70 | throw new Error(error) 71 | } 72 | } 73 | 74 | module.exports.updateUserProfile = async serviceData => { 75 | try { 76 | const jwtToken = serviceData.headers.authorization.split('Bearer')[1].trim() 77 | const decodedJwtToken = jwt.decode(jwtToken) 78 | const user = await User.findOneAndUpdate( 79 | { _id: decodedJwtToken.id }, 80 | { 81 | firstName: serviceData.body.firstName, 82 | lastName: serviceData.body.lastName 83 | }, 84 | { new: true } 85 | ) 86 | 87 | if (!user) { 88 | throw new Error('User not found!') 89 | } 90 | 91 | return user.toObject() 92 | } catch (error) { 93 | console.error('Error in userService.js', error) 94 | throw new Error(error) 95 | } 96 | } 97 | -------------------------------------------------------------------------------- /swagger.yaml: -------------------------------------------------------------------------------- 1 | swagger: '2.0' 2 | info: 3 | title: Bank Argent API documentation 4 | description: Contains all available API endpoints in this codebase 5 | version: '1.0.0' 6 | termsOfService: 'http://swagger.io/terms/' 7 | host: localhost:3001 8 | basePath: /api/v1 9 | schemes: 10 | - http 11 | paths: 12 | /user/login: 13 | post: 14 | tags: 15 | - User Module 16 | summary: Login 17 | description: API for Login 18 | parameters: 19 | - in: body 20 | name: body 21 | description: Login Payload 22 | required: true 23 | schema: 24 | $ref: '#/definitions/Login' 25 | produces: 26 | - application/json 27 | responses: 28 | '200': 29 | description: Login Successfully 30 | schema: 31 | $ref: '#/definitions/LoginResponse' 32 | '400': 33 | description: Invalid Fields 34 | '500': 35 | description: Internal Server Error 36 | /user/signup: 37 | post: 38 | tags: 39 | - User Module 40 | summary: Signup 41 | description: API for Signup 42 | parameters: 43 | - in: body 44 | name: body 45 | description: Signup Payload 46 | required: true 47 | schema: 48 | $ref: '#/definitions/User' 49 | produces: 50 | - application/json 51 | responses: 52 | '200': 53 | description: Signup Successfully 54 | schema: 55 | $ref: '#/definitions/ApiResponse' 56 | '400': 57 | description: Invalid Fields 58 | '500': 59 | description: Internal Server Error 60 | /user/profile: 61 | post: 62 | security: 63 | - Bearer: [] 64 | tags: 65 | - User Module 66 | summary: User Profile API 67 | description: API for fetching a user profile 68 | parameters: 69 | - in: header 70 | name: Authorization 71 | description: Attach Bearer JWT token 72 | required: true 73 | produces: 74 | - application/json 75 | responses: 76 | '200': 77 | description: User profile retrieved successully 78 | schema: 79 | $ref: '#/definitions/ApiResponse' 80 | '400': 81 | description: Invalid Fields 82 | '500': 83 | description: Internal Server Error 84 | put: 85 | security: 86 | - Bearer: [] 87 | tags: 88 | - User Module 89 | summary: User Profile API 90 | description: API for updating a user profile 91 | parameters: 92 | - in: header 93 | name: Authorization 94 | description: Attach Bearer JWT token 95 | required: true 96 | - in: body 97 | name: body 98 | description: Update user profile attributes 99 | required: true 100 | schema: 101 | $ref: '#/definitions/UserProfile' 102 | produces: 103 | - application/json 104 | responses: 105 | '200': 106 | description: User profile retrieved successully 107 | schema: 108 | $ref: '#/definitions/ApiResponse' 109 | '400': 110 | description: Invalid Fields 111 | '500': 112 | description: Internal Server Error 113 | securityDefinitions: 114 | Bearer: 115 | type: apiKey 116 | name: Authorization 117 | in: header 118 | definitions: 119 | User: 120 | properties: 121 | email: 122 | type: string 123 | description: user email 124 | password: 125 | type: string 126 | description: user password 127 | firstName: 128 | type: string 129 | description: user first name 130 | lastName: 131 | type: string 132 | description: user last name 133 | Login: 134 | properties: 135 | email: 136 | type: string 137 | description: user email 138 | password: 139 | type: string 140 | description: user password 141 | ApiResponse: 142 | type: object 143 | properties: 144 | status: 145 | type: integer 146 | message: 147 | type: string 148 | body: 149 | type: object 150 | properties: 151 | id: 152 | type: string 153 | email: 154 | type: string 155 | LoginResponse: 156 | type: object 157 | properties: 158 | token: 159 | type: string 160 | UserProfile: 161 | type: object 162 | properties: 163 | firstName: 164 | type: string 165 | lastName: 166 | type: string 167 | --------------------------------------------------------------------------------