Update: User.update
This commit is contained in:
parent
48919a95d9
commit
d69f4badff
1 changed files with 56 additions and 46 deletions
|
|
@ -1,6 +1,6 @@
|
||||||
const db = require("../models/mongodb.model");
|
const db = require("../models/mongodb.model");
|
||||||
const {sendError, sendMessage} = require ("../config/response.config");
|
const {sendError, sendMessage} = require ("../config/response.config");
|
||||||
const {checkLogin, setSessionCookie, getSession, getToken} = require("../config/sessionJWT.config");
|
const {checkLogin, setSessionCookie} = require("../config/sessionJWT.config");
|
||||||
const ObjectId = require('mongoose').Types.ObjectId;
|
const ObjectId = require('mongoose').Types.ObjectId;
|
||||||
const roles = require("../models/objects/role.model");
|
const roles = require("../models/objects/role.model");
|
||||||
const User = db.users;
|
const User = db.users;
|
||||||
|
|
@ -202,10 +202,10 @@ exports.findAll = (req, res) => {
|
||||||
|
|
||||||
User.find(query, {hashPass: false}, query_sort)
|
User.find(query, {hashPass: false}, query_sort)
|
||||||
.then(data => {
|
.then(data => {
|
||||||
sendMessage(res, 5, data, token)
|
return sendMessage(res, 5, data, token)
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
sendError(res,500,100,err.message || "Some error occurred while retrieving users.", token);
|
return sendError(res,500,100,err.message || "Some error occurred while retrieving users.", token);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
@ -215,32 +215,34 @@ exports.findOne = (req, res) => {
|
||||||
const token = checkLogin(req, res);
|
const token = checkLogin(req, res);
|
||||||
if(token && typeof req.params.id !== 'undefined') {
|
if(token && typeof req.params.id !== 'undefined') {
|
||||||
let id = null;
|
let id = null;
|
||||||
if(typeof token.id !== 'undefined' && req.params.id === token.id){
|
if(typeof token.id !== 'undefined' && token.id === req.params.id){
|
||||||
id = req.params.id;
|
id = req.params.id;
|
||||||
} else {
|
} else {
|
||||||
if (typeof token.role !== 'undefined' &&
|
if(typeof token.role !== 'undefined' &&
|
||||||
typeof token.role.permission !== 'undefined' &&
|
typeof token.role.permission !== 'undefined' &&
|
||||||
|
typeof token.role.isAccepted !== 'undefined' &&
|
||||||
|
token.role.isAccepted === true &&
|
||||||
token.role.permission >= roles.Admin.permission) {
|
token.role.permission >= roles.Admin.permission) {
|
||||||
id = req.params.id;
|
id = req.params.id;
|
||||||
} else {
|
} else {
|
||||||
sendError(res, 500, -1, `Cannot find User with id=${id}. User do not have the permission`, token);
|
return sendError(res, 500, 106, `User do not have the permission.`, token);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(id){
|
if(id){
|
||||||
User.findById(id, {hashPass: false})
|
User.findById(id, {hashPass: false})
|
||||||
.then(data => {
|
.then(data => {
|
||||||
if(data){
|
if(data){
|
||||||
sendMessage(res, 1, data, token);
|
return sendMessage(res, 6, data, token);
|
||||||
} else {
|
} else {
|
||||||
sendError(res,404,-1,"User not found with id " + id, token);
|
return sendError(res,404,105,`User not found with id=${id}`, token);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
sendError(res,500,-1,err.message || "Error retrieving User with id=" + id, token);
|
return sendError(res,500,100,err.message || `Some error occurred while finding the User with id=${id}`, token);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
sendError(res, 500, -1, `No id given`, token);
|
return sendError(res, 500, -1, `No id given`, token);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -249,57 +251,65 @@ exports.update = (req, res) => {
|
||||||
const token = checkLogin(req, res);
|
const token = checkLogin(req, res);
|
||||||
if(token && typeof req.params.id !== 'undefined') {
|
if(token && typeof req.params.id !== 'undefined') {
|
||||||
let id = null;
|
let id = null;
|
||||||
if(typeof token.id !== 'undefined' && req.params.id === token.id){
|
if(typeof token.id !== 'undefined' && token.id === req.params.id){
|
||||||
id = req.params.id;
|
id = req.params.id;
|
||||||
} else {
|
} else {
|
||||||
if (typeof token.role !== 'undefined' &&
|
if(typeof token.role !== 'undefined' &&
|
||||||
typeof token.role.permission !== 'undefined' &&
|
typeof token.role.permission !== 'undefined' &&
|
||||||
|
typeof token.role.isAccepted !== 'undefined' &&
|
||||||
|
token.role.isAccepted === true &&
|
||||||
token.role.permission >= roles.Admin.permission) {
|
token.role.permission >= roles.Admin.permission) {
|
||||||
id = req.params.id;
|
id = req.params.id;
|
||||||
} else {
|
} else {
|
||||||
sendError(res, 500, -1, `Cannot update User with id=${id}. User do not have the permission`, token);
|
return sendError(res, 500, 106, `User do not have the permission.`, token);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(id){
|
if(id){
|
||||||
User.findById(id, {hashPass: false})
|
let update = null;
|
||||||
.then(user => {
|
if(typeof req.body._id !== 'undefined' || typeof req.body.id !== 'undefined'){
|
||||||
if(user){
|
return sendError(res, 500, -1, `User do not have the permission to modify id or _id`, token);
|
||||||
const history = new History({update: user});
|
} else{
|
||||||
history
|
if(typeof req.body.role !== 'undefined' ||
|
||||||
.save(history)
|
typeof req.body.isActive !== 'undefined' ||
|
||||||
.then(data => {
|
typeof req.body.lastConnexion !== 'undefined' ||
|
||||||
if(data) {
|
typeof req.body.createdAt !== 'undefined'||
|
||||||
|
typeof req.body.updatedAt !== 'undefined'){
|
||||||
|
if(typeof token.role !== 'undefined' &&
|
||||||
|
typeof token.role.permission !== 'undefined' &&
|
||||||
|
typeof token.role.isAccepted !== 'undefined' &&
|
||||||
|
token.role.isAccepted === true &&
|
||||||
|
token.role.permission >= roles.Admin.permission) {
|
||||||
|
update = true;
|
||||||
|
} else{
|
||||||
|
return sendError(res, 500, 106, `User do not have the permission to modify these keys.`, token);
|
||||||
|
}
|
||||||
|
} else{
|
||||||
|
update = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(update === true){
|
||||||
User.findByIdAndUpdate(id, req.body, {useFindAndModify: false})
|
User.findByIdAndUpdate(id, req.body, {useFindAndModify: false})
|
||||||
.then(data => {
|
.then(data => {
|
||||||
|
if(data) {
|
||||||
data.hashPass = undefined;
|
data.hashPass = undefined;
|
||||||
console.log(data);
|
Object.keys(req.body).forEach(key => data[key] = req.body[key]);
|
||||||
if (data) {
|
sendMessage(res, 7, data, token);
|
||||||
sendMessage(res, 1, {message: "User was updated successfully."}, token);
|
|
||||||
} else {
|
} else {
|
||||||
sendError(res, 404, -1, `Cannot update User with id=${id}. Maybe User was not found.`, token);
|
sendError(res, 404, -1, `User not found with id=${id}`, token);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
sendError(res, 500, -1, err.message || "Error updating User with id=" + id, token);
|
sendError(res, 500, -1, err.message || `Some error occurred while updating the User with id=${id}`, token);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
sendError(res, 500,-1,err.message || "Some error occurred while creating the User.");
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
sendError(res,404,-1,"User not found with id " + id, token);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
sendError(res,500,-1,err.message || "Error retrieving User with id=" + id, token);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
sendError(res, 500, -1, `No id given`, token);
|
return sendError(res, 500, -1, `No id given`, token);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Delete a User with the specified id in the request
|
// Delete a User with the specified id in the request
|
||||||
exports.delete = (req, res) => {
|
exports.delete = (req, res) => {
|
||||||
const token = checkLogin(req, res);
|
const token = checkLogin(req, res);
|
||||||
|
|
|
||||||
Reference in a new issue