Files
MercuryCloud_Dashboard/api/routes/users/infos/user-info.js
Savalet f7d514d2ce Update
2023-05-21 17:45:43 +02:00

197 lines
8.8 KiB
JavaScript

let router = require('express').Router({ mergeParams: true });
const server = require('../../../server.js')
let jsonParser = server.parser.json()
const route_name = "/users/:user_uuid"
const permissions_manager = require("../../../utils/permissions-manager")
server.logger(" [INFO] /api" + route_name + " route loaded !")
// GET INFOS //
router.get('', function (req, res) {
const start = process.hrtime()
ipInfo = server.ip(req);
let IP = ""
if (req.headers['x-forwarded-for'] == undefined) {
IP = req.socket.remoteAddress.replace("::ffff:", "")
} else {
IP = req.headers['x-forwarded-for'].split(',')[0]
}
let sql = `SELECT token FROM users WHERE uuid = '${req.cookies.uuid}'`;
server.con.query(sql, function (err, result) {
if (err) { server.logger(" [ERROR] Database error\n " + err) }
if (result.length == 0) {
return res.json({ 'error': true, 'code': 404 })
} else {
if (result[0].token == req.cookies.token) {
permissions_manager.has_permission(req.cookies.uuid, "LISTUSERS").then(function (result) {
if (result) {
let id = req.params.user_uuid
if (id == undefined) { return res.json({ 'error': true, 'msg': "User id params is required", "code": 101 }) }
if (id == "") { return res.json({ 'error': true, 'msg': "User id params is required", "code": 102 }) }
let sql = `SELECT * FROM users WHERE uuid = '${id}'`;
server.con.query(sql, function (err, result) {
if (err) { server.logger(" [ERROR] Database error\n " + err) }
if (result.length > 0) {
let sql = `SELECT * FROM roles WHERE id = '${result[0].role}'`;
server.con.query(sql, function (err, result1) {
if (err) { server.logger(" [ERROR] Database error\n " + err) }
return res.json({
'error': false,
'data': {
'uuid': result[0].uuid,
'username': result[0].username,
'mail': result[0].mail,
'role': result[0].role,
'role_name': result1[0].name,
'permissions': result1[0].permissions,
'first_name': result[0].first_name,
'last_name': result[0].last_name,
'tel': result[0].tel,
'address_1': result[0].address_1,
'address_2': result[0].address_2,
'city': result[0].city,
'zip': result[0].zip,
'country': result[0].country,
'state': result[0].state
}
})
})
} else {
return res.json({
'error': false,
'data': {
'uuid': 404
}
})
}
});
} else {
return res.json({
"error": true,
"code": 403
})
}
})
} else {
return res.json({ 'error': true, 'code': 403 })
}
}
});
res.on('finish', () => {
const durationInMilliseconds = server.getDurationInMilliseconds(start)
server.logger(` [DEBUG] ${req.method} ${route_name} [FINISHED] [FROM ${IP}] in ${durationInMilliseconds.toLocaleString()} ms`)
})
})
// EDIT //
router.put('', jsonParser, function (req, res) {
const start = process.hrtime()
ipInfo = server.ip(req);
let response = "OK"
let error = false
let IP = ""
if (req.headers['x-forwarded-for'] == undefined) {
IP = req.socket.remoteAddress.replace("::ffff:", "")
} else {
IP = req.headers['x-forwarded-for'].split(',')[0]
}
let sql = `SELECT token FROM users WHERE uuid = '${req.cookies.uuid}'`;
server.con.query(sql, function (err, result) {
if (err) { server.logger(" [ERROR] Database error\n " + err) }
if (result.length == 0) {
return res.json({ 'error': true, 'code': 404 })
} else {
if (result[0].token === req.cookies.token) {
permissions_manager.has_permission(req.cookies.uuid, "EDITUSER").then(function (result) {
if (result) {
let id = req.params.user_uuid
if (id == undefined) { return res.json({ 'error': true, 'msg': "User id params is required", "code": 101 }) }
if (id == "") { return res.json({ 'error': true, 'msg': "User id params is required", "code": 102 }) }
if (req.body.password != "Q@4%738r$7") {
server.bcrypt.hash(req.body.password, 10, function (err, hash) {
let sql = `UPDATE users SET username = '${req.body.username}', token = '${server.crypto.randomBytes(20).toString('hex')}', password = '${hash}', role = '${req.body.role}', mail = '${req.body.mail}', first_name = '${req.body.first_name}', last_name = '${req.body.last_name}', tel = '${req.body.tel}', address_1 = '${req.body.address_1}', address_2 = '${req.body.address_2}', city = '${req.body.city}', zip = '${req.body.zip}', country = '${req.body.country}', state = '${req.body.state}' WHERE uuid = '${id}';`;
server.con.query(sql, function (err, result) {
if (err) { server.logger(" [ERROR] Database error\n " + err); return res.json({ "error": true, "msg": "Database error : " + err }) }
});
server.logger(" [DEBUG] User " + req.body.username + " updated !")
return res.json({ "error": false, "response": "OK" });
})
} else {
let sql = `UPDATE users SET username = '${req.body.username}', role = '${req.body.role}', mail = '${req.body.mail.toLowerCase()}', first_name = '${req.body.first_name}', last_name = '${req.body.last_name}', tel = '${req.body.tel}', address_1 = '${req.body.address_1}', address_2 = '${req.body.address_2}', city = '${req.body.city}', zip = '${req.body.zip}', country = '${req.body.country}', state = '${req.body.state}' WHERE uuid = '${id}';`;
server.con.query(sql, function (err, result) {
if (err) { server.logger(" [ERROR] Database error\n " + err); return res.json({ "error": true, "msg": "Database error : " + err }) }
});
server.logger(" [DEBUG] User " + req.body.username + " updated !")
return res.json({ "error": false, "response": "OK" });
}
} else {
return res.json({
"error": true,
"code": 403
})
}
})
} else {
return res.json({ 'error': true, 'code': 403 })
}
}
});
res.on('finish', () => {
const durationInMilliseconds = server.getDurationInMilliseconds(start)
server.logger(` [DEBUG] ${req.method} ${route_name} [FINISHED] [FROM ${IP}] in ${durationInMilliseconds.toLocaleString()} ms`)
})
})
// DELETE //
router.delete('', jsonParser, function (req, res) {
const start = process.hrtime()
ipInfo = server.ip(req);
let response = "OK"
let error = false
let sql = `SELECT token FROM users WHERE uuid = '${req.cookies.uuid}'`;
server.con.query(sql, function (err, result) {
let IP = ""
if (req.headers['x-forwarded-for'] == undefined) {
IP = req.socket.remoteAddress.replace("::ffff:", "")
} else {
IP = req.headers['x-forwarded-for'].split(',')[0]
}
if (err) { server.logger(" [ERROR] Database error\n " + err) }
if (result.length == 0) {
returnres.json({ 'error': true, 'code': 404 })
} else {
if (result[0].token === req.cookies.token) {
permissions_manager.has_permission(req.cookies.uuid, "DELETEUSER").then(function (result) {
let id = req.params.user_uuid
if (id == undefined) { return res.json({ 'error': true, 'msg': "User id params is required", "code": 101 }) }
if (id == "") { return res.json({ 'error': true, 'msg': "User id params is required", "code": 102 }) }
if (result) {
let sql = `DELETE FROM users WHERE uuid='${id}'`;
server.con.query(sql, function (err, result) {
if (err) { server.logger(" [ERROR] Database error\n " + err), error = true, response = "Database error" }
});
server.logger(" [DEBUG] User " + id + " deleted by " + req.cookies.uuid + " from " + IP + " !")
return res.json({ "error": error, "response": response });
} else {
return res.json({
"error": true,
"code": 403
})
}
})
} else {
return res.json({ 'error': true, 'code': 403 })
}
}
});
res.on('finish', () => {
const durationInMilliseconds = server.getDurationInMilliseconds(start)
server.logger(` [DEBUG] ${req.method} ${route_name} [FINISHED] [FROM ${IP}] in ${durationInMilliseconds.toLocaleString()} ms`)
})
})
module.exports = router;