mirror of
https://github.com/vyme-fr/MercuryCloud_Dashboard.git
synced 2026-01-18 16:47:30 +01:00
63 lines
2.7 KiB
JavaScript
63 lines
2.7 KiB
JavaScript
var router = require('express').Router();
|
|
const server = require('../../server.js')
|
|
var jsonParser = server.parser.json()
|
|
const route_name = "/services/delete-service"
|
|
const config = require('../../config.json')
|
|
const permissions_manager = require("../../utils/permissions-manager.js")
|
|
server.logger(" [INFO] /api" + route_name + " route loaded !")
|
|
|
|
router.delete('', jsonParser, function (req, res) {
|
|
ipInfo = server.ip(req);
|
|
var response = "OK"
|
|
var error = false
|
|
var forwardedIpsStr = req.header('x-forwarded-for');
|
|
var IP = '';
|
|
|
|
if (forwardedIpsStr) {
|
|
IP = forwardedIps = forwardedIpsStr.split(',')[0];
|
|
}
|
|
var sql = `SELECT token FROM users WHERE uuid = '${req.query.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.query.token) {
|
|
permissions_manager.has_permission(req.query.uuid, "DELETESERVICE").then(function (result) {
|
|
if (result) {
|
|
var sql = `SELECT * FROM services WHERE id = '${req.body.id}'`;
|
|
server.con.query(sql, function (err, result) {
|
|
if (err) { server.logger(" [ERROR] Database error\n " + err), error = true, response = "Database error" };
|
|
if (result[0].category == 'pterodactyl') {
|
|
service_config = JSON.parse(result[0].configuration)
|
|
server.fetch(config.pterodactyl_url + "/api/application/servers/" + service_config.id, {
|
|
"method": "DELETE",
|
|
"headers": {
|
|
"Accept": "application/json",
|
|
"Content-Type": "application/json",
|
|
"Authorization": `Bearer ${config.pterodactyl_api_key}`,
|
|
}
|
|
}).catch(err => { server.logger(" [ERROR] Pterodactyl API error : " + err); return res.json({ "error": true, "code": 503, "msg": "Pterodactyl API error : " + err }) })
|
|
}
|
|
var sql = `DELETE FROM services WHERE id='${req.body.id}'`;
|
|
server.con.query(sql, function (err) {
|
|
if (err) { server.logger(" [ERROR] Database error\n " + err), error = true, response = "Database error" };
|
|
});
|
|
server.logger(" [DEBUG] Service " + req.body.id + " deleted 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 })
|
|
}
|
|
}
|
|
});
|
|
})
|
|
|
|
module.exports = router; |