2020-11-20 10:02:30 +00:00
|
|
|
const mongoose = require('mongoose');
|
|
|
|
const router = require('express').Router();
|
|
|
|
const passport = require('passport');
|
|
|
|
const User = mongoose.model('User');
|
2020-11-20 10:30:12 +00:00
|
|
|
const wrapRoute = require('../../_helpers/wrapRoute');
|
2020-11-20 10:02:30 +00:00
|
|
|
const auth = require('../auth');
|
2020-04-13 00:02:40 +00:00
|
|
|
|
2020-11-20 10:30:12 +00:00
|
|
|
router.get(
|
|
|
|
'/user',
|
|
|
|
auth.required,
|
|
|
|
wrapRoute(async (req, res) => {
|
2020-11-23 23:30:55 +00:00
|
|
|
return res.json({ user: req.user.toAuthJSON() });
|
2020-11-20 10:30:12 +00:00
|
|
|
}),
|
|
|
|
);
|
2020-04-13 00:02:40 +00:00
|
|
|
|
2020-11-20 10:30:12 +00:00
|
|
|
router.put(
|
|
|
|
'/user',
|
|
|
|
auth.required,
|
|
|
|
wrapRoute(async (req, res) => {
|
2020-11-23 23:30:55 +00:00
|
|
|
const user = req.user;
|
2020-04-13 00:02:40 +00:00
|
|
|
|
2020-11-20 10:30:12 +00:00
|
|
|
// only update fields that were actually passed...
|
|
|
|
if (typeof req.body.user.username !== 'undefined') {
|
|
|
|
user.username = req.body.user.username;
|
|
|
|
}
|
|
|
|
if (typeof req.body.user.email !== 'undefined') {
|
|
|
|
user.email = req.body.user.email;
|
|
|
|
}
|
|
|
|
if (typeof req.body.user.bio !== 'undefined') {
|
|
|
|
user.bio = req.body.user.bio;
|
|
|
|
}
|
|
|
|
if (typeof req.body.user.image !== 'undefined') {
|
|
|
|
user.image = req.body.user.image;
|
|
|
|
}
|
|
|
|
if (typeof req.body.user.areTracksVisibleForAll !== 'undefined') {
|
|
|
|
user.areTracksVisibleForAll = req.body.user.areTracksVisibleForAll;
|
|
|
|
}
|
|
|
|
if (typeof req.body.user.password === 'string' && req.body.user.password !== '') {
|
|
|
|
user.setPassword(req.body.user.password);
|
|
|
|
}
|
2020-04-13 00:02:40 +00:00
|
|
|
|
2020-11-20 10:30:12 +00:00
|
|
|
await user.save();
|
|
|
|
return res.json({ user: user.toAuthJSON() });
|
|
|
|
}),
|
|
|
|
);
|
2020-04-13 00:02:40 +00:00
|
|
|
|
2020-10-20 19:25:00 +00:00
|
|
|
router.post('/users/login', function (req, res, next) {
|
|
|
|
if (!req.body.user.email) {
|
|
|
|
return res.status(422).json({ errors: { email: "can't be blank" } });
|
2020-04-13 00:02:40 +00:00
|
|
|
}
|
|
|
|
|
2020-10-20 19:25:00 +00:00
|
|
|
if (!req.body.user.password) {
|
|
|
|
return res.status(422).json({ errors: { password: "can't be blank" } });
|
2020-04-13 00:02:40 +00:00
|
|
|
}
|
|
|
|
|
2020-10-20 19:25:00 +00:00
|
|
|
passport.authenticate('local', { session: false }, function (err, user, info) {
|
2020-11-20 10:02:30 +00:00
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
}
|
2020-04-13 00:02:40 +00:00
|
|
|
|
2020-10-20 19:25:00 +00:00
|
|
|
if (user) {
|
2020-04-13 00:02:40 +00:00
|
|
|
user.token = user.generateJWT();
|
2020-10-20 19:25:00 +00:00
|
|
|
return res.json({ user: user.toAuthJSON() });
|
2020-04-13 00:02:40 +00:00
|
|
|
} else {
|
|
|
|
return res.status(422).json(info);
|
|
|
|
}
|
|
|
|
})(req, res, next);
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = router;
|