Files
meanTorrent/modules/users/server/controllers/users/users.profile.server.controller.js

106 lines
2.6 KiB
JavaScript
Raw Normal View History

2014-11-10 23:12:33 +02:00
'use strict';
/**
* Module dependencies
2014-11-10 23:12:33 +02:00
*/
var _ = require('lodash'),
fs = require('fs'),
path = require('path'),
errorHandler = require(path.resolve('./modules/core/server/controllers/errors.server.controller')),
mongoose = require('mongoose'),
multer = require('multer'),
config = require(path.resolve('./config/config')),
User = mongoose.model('User');
2014-11-10 23:12:33 +02:00
/**
* Update user details
*/
exports.update = function (req, res) {
// Init Variables
var user = req.user;
2014-11-10 23:12:33 +02:00
// For security measurement we remove the roles from the req.body object
delete req.body.roles;
2014-11-10 23:12:33 +02:00
// For security measurement do not use _id from the req.body object
delete req.body._id;
if (user) {
// Merge existing user
user = _.extend(user, req.body);
user.updated = Date.now();
user.displayName = user.firstName + ' ' + user.lastName;
2014-11-10 23:12:33 +02:00
user.save(function (err) {
if (err) {
return res.status(400).send({
message: errorHandler.getErrorMessage(err)
});
} else {
req.login(user, function (err) {
if (err) {
res.status(400).send(err);
} else {
res.json(user);
}
});
}
});
} else {
res.status(400).send({
message: 'User is not signed in'
});
}
2014-11-10 23:12:33 +02:00
};
/**
* Update profile picture
*/
exports.changeProfilePicture = function (req, res) {
var user = req.user;
var upload = multer(config.uploads.profileUpload).single('newProfilePicture');
var profileUploadFileFilter = require(path.resolve('./config/lib/multer')).profileUploadFileFilter;
// Filtering to upload only images
upload.fileFilter = profileUploadFileFilter;
2014-11-10 23:12:33 +02:00
if (user) {
upload(req, res, function (uploadError) {
if (uploadError) {
return res.status(400).send({
message: 'Error occurred while uploading profile picture'
});
} else {
user.profileImageURL = config.uploads.profileUpload.dest + req.file.filename;
2014-11-10 23:12:33 +02:00
user.save(function (saveError) {
if (saveError) {
return res.status(400).send({
message: errorHandler.getErrorMessage(saveError)
});
} else {
req.login(user, function (err) {
if (err) {
res.status(400).send(err);
} else {
res.json(user);
}
});
}
});
}
});
} else {
res.status(400).send({
message: 'User is not signed in'
});
}
2014-11-10 23:12:33 +02:00
};
/**
* Send User
*/
exports.me = function (req, res) {
res.json(req.user || null);
2014-11-10 23:12:33 +02:00
};