mirror of
https://github.com/taobataoma/meanTorrent.git
synced 2026-01-14 11:22:21 +01:00
Fixes incorrest usage of 400 HTTP responses being returned from the
server, in favor of using 422.
Also, changed a few return codes to 401 where it was more appropriate.
See this article for reasoning behind moving to 422, and why 400 isn't
appropriate for these cases.
For ref:
6be12f8a06
Related:
https://github.com/meanjs/mean/pull/1547
https://github.com/meanjs/mean/pull/1510
94 lines
1.9 KiB
JavaScript
94 lines
1.9 KiB
JavaScript
'use strict';
|
|
|
|
/**
|
|
* Module dependencies
|
|
*/
|
|
var path = require('path'),
|
|
mongoose = require('mongoose'),
|
|
User = mongoose.model('User'),
|
|
errorHandler = require(path.resolve('./modules/core/server/controllers/errors.server.controller'));
|
|
|
|
/**
|
|
* Show the current user
|
|
*/
|
|
exports.read = function (req, res) {
|
|
res.json(req.model);
|
|
};
|
|
|
|
/**
|
|
* Update a User
|
|
*/
|
|
exports.update = function (req, res) {
|
|
var user = req.model;
|
|
|
|
// For security purposes only merge these parameters
|
|
user.firstName = req.body.firstName;
|
|
user.lastName = req.body.lastName;
|
|
user.displayName = user.firstName + ' ' + user.lastName;
|
|
user.roles = req.body.roles;
|
|
|
|
user.save(function (err) {
|
|
if (err) {
|
|
return res.status(422).send({
|
|
message: errorHandler.getErrorMessage(err)
|
|
});
|
|
}
|
|
|
|
res.json(user);
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Delete a user
|
|
*/
|
|
exports.delete = function (req, res) {
|
|
var user = req.model;
|
|
|
|
user.remove(function (err) {
|
|
if (err) {
|
|
return res.status(422).send({
|
|
message: errorHandler.getErrorMessage(err)
|
|
});
|
|
}
|
|
|
|
res.json(user);
|
|
});
|
|
};
|
|
|
|
/**
|
|
* List of Users
|
|
*/
|
|
exports.list = function (req, res) {
|
|
User.find({}, '-salt -password -providerData').sort('-created').populate('user', 'displayName').exec(function (err, users) {
|
|
if (err) {
|
|
return res.status(422).send({
|
|
message: errorHandler.getErrorMessage(err)
|
|
});
|
|
}
|
|
|
|
res.json(users);
|
|
});
|
|
};
|
|
|
|
/**
|
|
* User middleware
|
|
*/
|
|
exports.userByID = function (req, res, next, id) {
|
|
if (!mongoose.Types.ObjectId.isValid(id)) {
|
|
return res.status(400).send({
|
|
message: 'User is invalid'
|
|
});
|
|
}
|
|
|
|
User.findById(id, '-salt -password -providerData').exec(function (err, user) {
|
|
if (err) {
|
|
return next(err);
|
|
} else if (!user) {
|
|
return next(new Error('Failed to load user ' + id));
|
|
}
|
|
|
|
req.model = user;
|
|
next();
|
|
});
|
|
};
|