| @@ 141-201 (lines=61) @@ | ||
| 138 | db.get("SELECT * FROM users WHERE apiKey = ? AND email = ?", |
|
| 139 | apiKey, |
|
| 140 | email, |
|
| 141 | (err, rows) => { |
|
| 142 | if (err) { |
|
| 143 | return res.status(500).json({ |
|
| 144 | errors: { |
|
| 145 | status: 500, |
|
| 146 | source: "/login", |
|
| 147 | title: "Database error", |
|
| 148 | detail: err.message |
|
| 149 | } |
|
| 150 | }); |
|
| 151 | } |
|
| 152 | ||
| 153 | if (rows === undefined) { |
|
| 154 | return res.status(401).json({ |
|
| 155 | errors: { |
|
| 156 | status: 401, |
|
| 157 | source: "/login", |
|
| 158 | title: "User not found", |
|
| 159 | detail: "User with provided email not found." |
|
| 160 | } |
|
| 161 | }); |
|
| 162 | } |
|
| 163 | ||
| 164 | const user = rows; |
|
| 165 | ||
| 166 | bcrypt.compare(password, user.password, (err, result) => { |
|
| 167 | if (err) { |
|
| 168 | return res.status(500).json({ |
|
| 169 | errors: { |
|
| 170 | status: 500, |
|
| 171 | source: "/login", |
|
| 172 | title: "bcrypt error", |
|
| 173 | detail: "bcrypt error" |
|
| 174 | } |
|
| 175 | }); |
|
| 176 | } |
|
| 177 | ||
| 178 | if (result) { |
|
| 179 | let payload = { api_key: user.apiKey, email: user.email }; |
|
| 180 | let jwtToken = jwt.sign(payload, jwtSecret, { expiresIn: '24h' }); |
|
| 181 | ||
| 182 | return res.json({ |
|
| 183 | data: { |
|
| 184 | type: "success", |
|
| 185 | message: "User logged in", |
|
| 186 | user: payload, |
|
| 187 | token: jwtToken |
|
| 188 | } |
|
| 189 | }); |
|
| 190 | } else { |
|
| 191 | return res.status(401).json({ |
|
| 192 | errors: { |
|
| 193 | status: 401, |
|
| 194 | source: "/login", |
|
| 195 | title: "Wrong password", |
|
| 196 | detail: "Password is incorrect." |
|
| 197 | } |
|
| 198 | }); |
|
| 199 | } |
|
| 200 | }); |
|
| 201 | }); |
|
| 202 | } |
|
| 203 | ||
| 204 | function register(res, body) { |
|
| @@ 274-334 (lines=61) @@ | ||
| 271 | db.get("SELECT * FROM users WHERE apiKey = ? AND email = ?", |
|
| 272 | apiKey, |
|
| 273 | email, |
|
| 274 | (err, rows) => { |
|
| 275 | if (err) { |
|
| 276 | return res.status(500).json({ |
|
| 277 | errors: { |
|
| 278 | status: 500, |
|
| 279 | source: "/login", |
|
| 280 | title: "Database error", |
|
| 281 | detail: err.message |
|
| 282 | } |
|
| 283 | }); |
|
| 284 | } |
|
| 285 | ||
| 286 | if (rows === undefined) { |
|
| 287 | return res.status(401).json({ |
|
| 288 | errors: { |
|
| 289 | status: 401, |
|
| 290 | source: "/login", |
|
| 291 | title: "User not found", |
|
| 292 | detail: "User with provided email not found." |
|
| 293 | } |
|
| 294 | }); |
|
| 295 | } |
|
| 296 | ||
| 297 | const user = rows; |
|
| 298 | ||
| 299 | bcrypt.compare(password, user.password, (err, result) => { |
|
| 300 | if (err) { |
|
| 301 | return res.status(500).json({ |
|
| 302 | errors: { |
|
| 303 | status: 500, |
|
| 304 | source: "/login", |
|
| 305 | title: "bcrypt error", |
|
| 306 | detail: "bcrypt error" |
|
| 307 | } |
|
| 308 | }); |
|
| 309 | } |
|
| 310 | ||
| 311 | if (result) { |
|
| 312 | let payload = { api_key: user.apiKey, email: user.email }; |
|
| 313 | let jwtToken = jwt.sign(payload, jwtSecret, { expiresIn: '24h' }); |
|
| 314 | ||
| 315 | return res.json({ |
|
| 316 | data: { |
|
| 317 | type: "success", |
|
| 318 | message: "User logged in", |
|
| 319 | user: payload, |
|
| 320 | token: jwtToken |
|
| 321 | } |
|
| 322 | }); |
|
| 323 | } |
|
| 324 | ||
| 325 | return res.status(401).json({ |
|
| 326 | errors: { |
|
| 327 | status: 401, |
|
| 328 | source: "/login", |
|
| 329 | title: "Wrong password", |
|
| 330 | detail: "Password is incorrect." |
|
| 331 | } |
|
| 332 | }); |
|
| 333 | }); |
|
| 334 | }); |
|
| 335 | }, |
|
| 336 | ||
| 337 | register: function(res, body) { |
|