61 lines
1 KiB
JavaScript
Executable file
61 lines
1 KiB
JavaScript
Executable file
'use strict';
|
|
|
|
/**
|
|
* Module dependencies.
|
|
*/
|
|
var _ = require('lodash'),
|
|
errorHandler = require('../errors.server.controller.js'),
|
|
mongoose = require('mongoose');
|
|
|
|
/**
|
|
* Update user details
|
|
*/
|
|
exports.update = function(req, res) {
|
|
// Init Variables
|
|
var user = req.user;
|
|
|
|
// For security measurement we remove the roles from the req.body object
|
|
delete req.body.roles;
|
|
|
|
if (user) {
|
|
// Merge existing user
|
|
user = _.extend(user, req.body);
|
|
user.updated = Date.now();
|
|
|
|
user.save(function(err) {
|
|
if (err) {
|
|
return res.status(500).send({
|
|
message: errorHandler.getErrorMessage(err)
|
|
});
|
|
}
|
|
req.login(user, function(loginErr) {
|
|
if (err) {
|
|
res.status(500).send(loginErr);
|
|
} else {
|
|
res.json(user);
|
|
}
|
|
});
|
|
|
|
});
|
|
} else {
|
|
res.status(401).send({
|
|
message: 'User is not signed in'
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Send User
|
|
*/
|
|
exports.getUser = function(req, res) {
|
|
var _user = req.user;
|
|
delete _user.password;
|
|
delete _user.salt;
|
|
delete _user.provider;
|
|
delete _user.__v;
|
|
|
|
res.json(req.user || null);
|
|
|
|
res.end();
|
|
};
|