uptime-kuma/server/socket-handlers/docker-socket-handler.js

80 lines
2 KiB
JavaScript
Raw Normal View History

const { sendDockerHostList } = require("../client");
const { checkLogin } = require("../util-server");
const { DockerHost } = require("../docker");
2022-07-29 15:57:13 +03:00
const { log } = require("../../src/util");
2022-07-22 18:57:40 +03:00
/**
* Handlers for docker hosts
* @param {Socket} socket Socket.io instance
*/
module.exports.dockerSocketHandler = (socket) => {
socket.on("addDockerHost", async (dockerHost, dockerHostID, callback) => {
try {
checkLogin(socket);
let dockerHostBean = await DockerHost.save(dockerHost, dockerHostID, socket.userID);
await sendDockerHostList(socket);
callback({
ok: true,
msg: "Saved",
id: dockerHostBean.id,
});
} catch (e) {
callback({
ok: false,
msg: e.message,
2022-07-22 18:57:40 +03:00
});
}
});
socket.on("deleteDockerHost", async (dockerHostID, callback) => {
try {
checkLogin(socket);
await DockerHost.delete(dockerHostID, socket.userID);
await sendDockerHostList(socket);
callback({
ok: true,
msg: "Deleted",
});
} catch (e) {
callback({
ok: false,
msg: e.message,
2022-07-22 18:57:40 +03:00
});
}
});
socket.on("testDockerHost", async (dockerHost, callback) => {
try {
checkLogin(socket);
2022-07-29 15:57:13 +03:00
let amount = await DockerHost.testDockerHost(dockerHost);
let msg;
if (amount > 1) {
msg = "Connected Successfully. Amount of containers: " + amount;
} else {
msg = "Connected Successfully, but there are no containers?";
}
callback({
ok: true,
2022-07-29 15:57:13 +03:00
msg,
});
} catch (e) {
2022-07-29 15:57:13 +03:00
log.error("docker", e);
callback({
ok: false,
msg: e.message,
2022-07-22 18:57:40 +03:00
});
}
2022-07-22 18:57:40 +03:00
});
};