mirror of
https://github.com/taobataoma/meanTorrent.git
synced 2026-01-24 16:19:20 +01:00
* Cropping remove, nicer UI * Fix MIME-type checking, add image upload tests * Change image config settings to uploads.profile.image to build a more rational structure for configuring other types of uploads
165 lines
4.1 KiB
JavaScript
165 lines
4.1 KiB
JavaScript
'use strict';
|
|
|
|
/**
|
|
* Module dependencies
|
|
*/
|
|
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'),
|
|
validator = require('validator');
|
|
|
|
var whitelistedFields = ['firstName', 'lastName', 'email', 'username'];
|
|
|
|
/**
|
|
* Update user details
|
|
*/
|
|
exports.update = function (req, res) {
|
|
// Init Variables
|
|
var user = req.user;
|
|
|
|
if (user) {
|
|
// Update whitelisted fields only
|
|
user = _.extend(user, _.pick(req.body, whitelistedFields));
|
|
|
|
user.updated = Date.now();
|
|
user.displayName = user.firstName + ' ' + user.lastName;
|
|
|
|
user.save(function (err) {
|
|
if (err) {
|
|
return res.status(422).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(401).send({
|
|
message: 'User is not signed in'
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Update profile picture
|
|
*/
|
|
exports.changeProfilePicture = function (req, res) {
|
|
var user = req.user;
|
|
var existingImageUrl;
|
|
|
|
// Filtering to upload only images
|
|
var multerConfig = config.uploads.profile.image;
|
|
multerConfig.fileFilter = require(path.resolve('./config/lib/multer')).imageFileFilter;
|
|
var upload = multer(multerConfig).single('newProfilePicture');
|
|
|
|
if (user) {
|
|
existingImageUrl = user.profileImageURL;
|
|
uploadImage()
|
|
.then(updateUser)
|
|
.then(deleteOldImage)
|
|
.then(login)
|
|
.then(function () {
|
|
res.json(user);
|
|
})
|
|
.catch(function (err) {
|
|
res.status(422).send(err);
|
|
});
|
|
} else {
|
|
res.status(401).send({
|
|
message: 'User is not signed in'
|
|
});
|
|
}
|
|
|
|
function uploadImage () {
|
|
return new Promise(function (resolve, reject) {
|
|
upload(req, res, function (uploadError) {
|
|
if (uploadError) {
|
|
reject(errorHandler.getErrorMessage(uploadError));
|
|
} else {
|
|
resolve();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
function updateUser () {
|
|
return new Promise(function (resolve, reject) {
|
|
user.profileImageURL = config.uploads.profile.image.dest + req.file.filename;
|
|
user.save(function (err, theuser) {
|
|
if (err) {
|
|
reject(err);
|
|
} else {
|
|
resolve();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
function deleteOldImage () {
|
|
return new Promise(function (resolve, reject) {
|
|
if (existingImageUrl !== User.schema.path('profileImageURL').defaultValue) {
|
|
fs.unlink(existingImageUrl, function (unlinkError) {
|
|
if (unlinkError) {
|
|
console.log(unlinkError);
|
|
reject({
|
|
message: 'Error occurred while deleting old profile picture'
|
|
});
|
|
} else {
|
|
resolve();
|
|
}
|
|
});
|
|
} else {
|
|
resolve();
|
|
}
|
|
});
|
|
}
|
|
|
|
function login () {
|
|
return new Promise(function (resolve, reject) {
|
|
req.login(user, function (err) {
|
|
if (err) {
|
|
res.status(400).send(err);
|
|
} else {
|
|
resolve();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Send User
|
|
*/
|
|
exports.me = function (req, res) {
|
|
// Sanitize the user - short term solution. Copied from core.server.controller.js
|
|
// TODO create proper passport mock: See https://gist.github.com/mweibel/5219403
|
|
var safeUserObject = null;
|
|
if (req.user) {
|
|
safeUserObject = {
|
|
displayName: validator.escape(req.user.displayName),
|
|
provider: validator.escape(req.user.provider),
|
|
username: validator.escape(req.user.username),
|
|
created: req.user.created.toString(),
|
|
roles: req.user.roles,
|
|
profileImageURL: req.user.profileImageURL,
|
|
email: validator.escape(req.user.email),
|
|
lastName: validator.escape(req.user.lastName),
|
|
firstName: validator.escape(req.user.firstName),
|
|
additionalProvidersData: req.user.additionalProvidersData
|
|
};
|
|
}
|
|
|
|
res.json(safeUserObject || null);
|
|
};
|