2019-12-10 04:57:57 -05:00
|
|
|
|
function readableBytes(bytes) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
var i = Math.floor(Math.log(bytes) / Math.log(1024)),
|
|
|
|
|
sizes = ["B", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
|
|
|
|
|
return (bytes / Math.pow(1024, i)).toFixed(0) + " " + sizes[i];
|
2019-12-10 04:57:57 -05:00
|
|
|
|
}
|
|
|
|
|
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const confirmBtn = $(".mini.confirm.modal .positive.button");
|
2019-12-09 05:14:31 -05:00
|
|
|
|
|
2019-12-08 03:59:58 -05:00
|
|
|
|
function showConfirm(title, content, callFn, extData) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const modal = $(".mini.confirm.modal");
|
|
|
|
|
modal.children(".header").text(title);
|
|
|
|
|
modal.children(".content").text(content);
|
|
|
|
|
if (confirmBtn.hasClass("loading")) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
modal
|
|
|
|
|
.modal({
|
|
|
|
|
closable: true,
|
|
|
|
|
onApprove: function () {
|
|
|
|
|
confirmBtn.toggleClass("loading");
|
|
|
|
|
callFn(extData);
|
|
|
|
|
return false;
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
.modal("show");
|
2019-12-08 03:59:58 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function showFormModal(modelSelector, formID, URL, getData) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
$(modelSelector)
|
|
|
|
|
.modal({
|
|
|
|
|
closable: true,
|
|
|
|
|
onApprove: function () {
|
|
|
|
|
let success = false;
|
|
|
|
|
const btn = $(modelSelector + " .positive.button");
|
|
|
|
|
const form = $(modelSelector + " form");
|
|
|
|
|
if (btn.hasClass("loading")) {
|
|
|
|
|
return success;
|
|
|
|
|
}
|
|
|
|
|
form.children(".message").remove();
|
|
|
|
|
btn.toggleClass("loading");
|
|
|
|
|
const data = getData
|
|
|
|
|
? getData()
|
|
|
|
|
: $(formID)
|
|
|
|
|
.serializeArray()
|
|
|
|
|
.reduce(function (obj, item) {
|
2021-01-20 09:15:47 -05:00
|
|
|
|
// ID 类的数据
|
2021-04-22 09:53:31 -04:00
|
|
|
|
if (
|
|
|
|
|
item.name.endsWith("_id") ||
|
|
|
|
|
item.name === "id" ||
|
|
|
|
|
item.name === "ID" ||
|
|
|
|
|
item.name === "RequestType" ||
|
|
|
|
|
item.name === "RequestMethod" ||
|
|
|
|
|
item.name === "DisplayIndex" ||
|
|
|
|
|
item.name === "Type"
|
|
|
|
|
) {
|
|
|
|
|
obj[item.name] = parseInt(item.value);
|
2021-01-20 09:15:47 -05:00
|
|
|
|
} else {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
obj[item.name] = item.value;
|
2021-01-20 09:15:47 -05:00
|
|
|
|
}
|
|
|
|
|
|
2021-04-22 09:53:31 -04:00
|
|
|
|
if (item.name.endsWith("ServersRaw")) {
|
|
|
|
|
if (item.value.length > 2) {
|
2021-04-23 07:09:04 -04:00
|
|
|
|
obj[item.name] = JSON.stringify(
|
|
|
|
|
[...item.value.matchAll(/\d+/gm)].map((k) =>
|
|
|
|
|
parseInt(k[0])
|
|
|
|
|
)
|
|
|
|
|
);
|
2021-04-22 09:53:31 -04:00
|
|
|
|
}
|
2021-01-20 09:15:47 -05:00
|
|
|
|
}
|
|
|
|
|
|
2019-12-08 03:59:58 -05:00
|
|
|
|
return obj;
|
2021-04-22 09:53:31 -04:00
|
|
|
|
}, {});
|
|
|
|
|
$.post(URL, JSON.stringify(data))
|
|
|
|
|
.done(function (resp) {
|
|
|
|
|
if (resp.code == 200) {
|
|
|
|
|
if (resp.message) {
|
|
|
|
|
$.suiAlert({
|
|
|
|
|
title: "操作成功",
|
|
|
|
|
type: "success",
|
|
|
|
|
description: resp.message,
|
|
|
|
|
time: "3",
|
|
|
|
|
position: "top-center",
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
window.location.reload();
|
|
|
|
|
} else {
|
|
|
|
|
form.append(
|
|
|
|
|
`<div class="ui negative message"><div class="header">操作失败</div><p>` +
|
|
|
|
|
resp.message +
|
|
|
|
|
`</p></div>`
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.fail(function (err) {
|
|
|
|
|
form.append(
|
|
|
|
|
`<div class="ui negative message"><div class="header">网络错误</div><p>` +
|
|
|
|
|
err.responseText +
|
|
|
|
|
`</p></div>`
|
|
|
|
|
);
|
|
|
|
|
})
|
|
|
|
|
.always(function () {
|
|
|
|
|
btn.toggleClass("loading");
|
|
|
|
|
});
|
|
|
|
|
return success;
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
.modal("show");
|
2019-12-08 03:59:58 -05:00
|
|
|
|
}
|
|
|
|
|
|
2020-12-19 10:11:16 -05:00
|
|
|
|
function addOrEditAlertRule(rule) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const modal = $(".rule.modal");
|
|
|
|
|
modal.children(".header").text((rule ? "修改" : "添加") + "报警规则");
|
|
|
|
|
modal
|
|
|
|
|
.find(".positive.button")
|
|
|
|
|
.html(
|
|
|
|
|
rule ? '修改<i class="edit icon"></i>' : '添加<i class="add icon"></i>'
|
|
|
|
|
);
|
|
|
|
|
modal.find("input[name=ID]").val(rule ? rule.ID : null);
|
|
|
|
|
modal.find("input[name=Name]").val(rule ? rule.Name : null);
|
|
|
|
|
modal.find("textarea[name=RulesRaw]").val(rule ? rule.RulesRaw : null);
|
|
|
|
|
if (rule && rule.Enable) {
|
|
|
|
|
modal.find(".ui.rule-enable.checkbox").checkbox("set checked");
|
|
|
|
|
} else {
|
|
|
|
|
modal.find(".ui.rule-enable.checkbox").checkbox("set unchecked");
|
|
|
|
|
}
|
|
|
|
|
showFormModal(".rule.modal", "#ruleForm", "/api/alert-rule");
|
2020-12-19 10:11:16 -05:00
|
|
|
|
}
|
|
|
|
|
|
2020-12-19 09:14:36 -05:00
|
|
|
|
function addOrEditNotification(notification) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const modal = $(".notification.modal");
|
|
|
|
|
modal.children(".header").text((notification ? "修改" : "添加") + "通知方式");
|
|
|
|
|
modal
|
|
|
|
|
.find(".positive.button")
|
|
|
|
|
.html(
|
|
|
|
|
notification
|
|
|
|
|
? '修改<i class="edit icon"></i>'
|
|
|
|
|
: '添加<i class="add icon"></i>'
|
|
|
|
|
);
|
|
|
|
|
modal.find("input[name=ID]").val(notification ? notification.ID : null);
|
|
|
|
|
modal.find("input[name=Name]").val(notification ? notification.Name : null);
|
|
|
|
|
modal.find("input[name=URL]").val(notification ? notification.URL : null);
|
|
|
|
|
modal
|
|
|
|
|
.find("textarea[name=RequestBody]")
|
|
|
|
|
.val(notification ? notification.RequestBody : null);
|
|
|
|
|
modal
|
|
|
|
|
.find("select[name=RequestMethod]")
|
|
|
|
|
.val(notification ? notification.RequestMethod : 1);
|
|
|
|
|
modal
|
|
|
|
|
.find("select[name=RequestType]")
|
|
|
|
|
.val(notification ? notification.RequestType : 1);
|
|
|
|
|
if (notification && notification.VerifySSL) {
|
|
|
|
|
modal.find(".ui.nf-ssl.checkbox").checkbox("set checked");
|
|
|
|
|
} else {
|
|
|
|
|
modal.find(".ui.nf-ssl.checkbox").checkbox("set unchecked");
|
|
|
|
|
}
|
|
|
|
|
showFormModal(
|
|
|
|
|
".notification.modal",
|
|
|
|
|
"#notificationForm",
|
|
|
|
|
"/api/notification"
|
|
|
|
|
);
|
2020-12-19 09:14:36 -05:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-22 08:55:27 -04:00
|
|
|
|
function addOrEditServer(server) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const modal = $(".server.modal");
|
|
|
|
|
modal.children(".header").text((server ? "修改" : "添加") + "服务器");
|
|
|
|
|
modal
|
|
|
|
|
.find(".positive.button")
|
|
|
|
|
.html(
|
|
|
|
|
server ? '修改<i class="edit icon"></i>' : '添加<i class="add icon"></i>'
|
|
|
|
|
);
|
|
|
|
|
modal.find("input[name=id]").val(server ? server.ID : null);
|
|
|
|
|
modal.find("input[name=name]").val(server ? server.Name : null);
|
|
|
|
|
modal.find("input[name=Tag]").val(server ? server.Tag : null);
|
|
|
|
|
modal
|
|
|
|
|
.find("input[name=DisplayIndex]")
|
|
|
|
|
.val(server ? server.DisplayIndex : null);
|
|
|
|
|
modal.find("textarea[name=Note]").val(server ? server.Note : null);
|
|
|
|
|
if (server) {
|
|
|
|
|
modal.find(".secret.field").attr("style", "");
|
|
|
|
|
modal.find("input[name=secret]").val(server.Secret);
|
|
|
|
|
} else {
|
|
|
|
|
modal.find(".secret.field").attr("style", "display:none");
|
|
|
|
|
modal.find("input[name=secret]").val("");
|
|
|
|
|
}
|
|
|
|
|
showFormModal(".server.modal", "#serverForm", "/api/server");
|
2019-12-08 10:18:29 -05:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-15 11:45:49 -05:00
|
|
|
|
function addOrEditMonitor(monitor) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const modal = $(".monitor.modal");
|
|
|
|
|
modal.children(".header").text((monitor ? "修改" : "添加") + "监控");
|
|
|
|
|
modal
|
|
|
|
|
.find(".positive.button")
|
|
|
|
|
.html(
|
|
|
|
|
monitor ? '修改<i class="edit icon"></i>' : '添加<i class="add icon"></i>'
|
|
|
|
|
);
|
|
|
|
|
modal.find("input[name=ID]").val(monitor ? monitor.ID : null);
|
|
|
|
|
modal.find("input[name=Name]").val(monitor ? monitor.Name : null);
|
|
|
|
|
modal.find("input[name=Target]").val(monitor ? monitor.Target : null);
|
|
|
|
|
modal.find("select[name=Type]").val(monitor ? monitor.Type : 1);
|
|
|
|
|
if (monitor && monitor.Notify) {
|
|
|
|
|
modal.find(".ui.nb-notify.checkbox").checkbox("set checked");
|
|
|
|
|
} else {
|
|
|
|
|
modal.find(".ui.nb-notify.checkbox").checkbox("set unchecked");
|
|
|
|
|
}
|
|
|
|
|
var servers;
|
|
|
|
|
if (monitor) {
|
2021-04-22 10:18:55 -04:00
|
|
|
|
servers = monitor.SkipServersRaw;
|
|
|
|
|
const serverList = JSON.parse(servers || "[]");
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const node = modal.find("i.dropdown.icon");
|
|
|
|
|
for (let i = 0; i < serverList.length; i++) {
|
|
|
|
|
node.after(
|
|
|
|
|
'<a class="ui label transition visible" data-value="' +
|
|
|
|
|
serverList[i] +
|
|
|
|
|
'" style="display: inline-block !important;">ID:' +
|
|
|
|
|
serverList[i] +
|
|
|
|
|
'<i class="delete icon"></i></a>'
|
|
|
|
|
);
|
2021-04-17 11:36:37 -04:00
|
|
|
|
}
|
2021-04-22 09:53:31 -04:00
|
|
|
|
}
|
|
|
|
|
modal
|
|
|
|
|
.find("input[name=SkipServersRaw]")
|
|
|
|
|
.val(monitor ? "[]," + servers.substr(1, servers.length - 2) : "[]");
|
|
|
|
|
showFormModal(".monitor.modal", "#monitorForm", "/api/monitor");
|
2021-01-15 11:45:49 -05:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-18 20:59:04 -05:00
|
|
|
|
function addOrEditCron(cron) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const modal = $(".cron.modal");
|
|
|
|
|
modal.children(".header").text((cron ? "修改" : "添加") + "计划任务");
|
|
|
|
|
modal
|
|
|
|
|
.find(".positive.button")
|
|
|
|
|
.html(
|
|
|
|
|
cron ? '修改<i class="edit icon"></i>' : '添加<i class="add icon"></i>'
|
|
|
|
|
);
|
|
|
|
|
modal.find("input[name=ID]").val(cron ? cron.ID : null);
|
|
|
|
|
modal.find("input[name=Name]").val(cron ? cron.Name : null);
|
|
|
|
|
modal.find("input[name=Scheduler]").val(cron ? cron.Scheduler : null);
|
|
|
|
|
modal.find("a.ui.label.visible").each((i, el) => {
|
|
|
|
|
el.remove();
|
|
|
|
|
});
|
|
|
|
|
var servers;
|
|
|
|
|
if (cron) {
|
|
|
|
|
servers = cron.ServersRaw;
|
2021-04-22 10:18:55 -04:00
|
|
|
|
const serverList = JSON.parse(servers || "[]");
|
2021-04-22 09:53:31 -04:00
|
|
|
|
const node = modal.find("i.dropdown.icon");
|
|
|
|
|
for (let i = 0; i < serverList.length; i++) {
|
|
|
|
|
node.after(
|
|
|
|
|
'<a class="ui label transition visible" data-value="' +
|
|
|
|
|
serverList[i] +
|
|
|
|
|
'" style="display: inline-block !important;">ID:' +
|
|
|
|
|
serverList[i] +
|
|
|
|
|
'<i class="delete icon"></i></a>'
|
|
|
|
|
);
|
2021-01-20 09:15:47 -05:00
|
|
|
|
}
|
2021-04-22 09:53:31 -04:00
|
|
|
|
}
|
|
|
|
|
modal
|
|
|
|
|
.find("input[name=ServersRaw]")
|
|
|
|
|
.val(cron ? "[]," + servers.substr(1, servers.length - 2) : "[]");
|
|
|
|
|
modal.find("textarea[name=Command]").val(cron ? cron.Command : null);
|
|
|
|
|
if (cron && cron.PushSuccessful) {
|
|
|
|
|
modal.find(".ui.push-successful.checkbox").checkbox("set checked");
|
|
|
|
|
} else {
|
|
|
|
|
modal.find(".ui.push-successful.checkbox").checkbox("set unchecked");
|
|
|
|
|
}
|
|
|
|
|
showFormModal(".cron.modal", "#cronForm", "/api/cron");
|
2021-01-18 20:59:04 -05:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-22 08:55:27 -04:00
|
|
|
|
function deleteRequest(api) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
$.ajax({
|
|
|
|
|
url: api,
|
|
|
|
|
type: "DELETE",
|
|
|
|
|
})
|
|
|
|
|
.done((resp) => {
|
|
|
|
|
if (resp.code == 200) {
|
|
|
|
|
if (resp.message) {
|
|
|
|
|
alert(resp.message);
|
2020-03-22 08:55:27 -04:00
|
|
|
|
} else {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
alert("删除成功");
|
2020-03-22 08:55:27 -04:00
|
|
|
|
}
|
2021-04-22 09:53:31 -04:00
|
|
|
|
window.location.reload();
|
|
|
|
|
} else {
|
|
|
|
|
alert("删除失败 " + resp.code + ":" + resp.message);
|
|
|
|
|
confirmBtn.toggleClass("loading");
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.fail((err) => {
|
|
|
|
|
alert("网络错误:" + err.responseText);
|
2020-03-22 08:55:27 -04:00
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2021-01-23 20:41:35 -05:00
|
|
|
|
function manualTrigger(btn, cronId) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
$(btn).toggleClass("loading");
|
|
|
|
|
$.ajax({
|
|
|
|
|
url: "/api/cron/" + cronId + "/manual",
|
|
|
|
|
type: "GET",
|
|
|
|
|
})
|
|
|
|
|
.done((resp) => {
|
|
|
|
|
$(btn).toggleClass("loading");
|
|
|
|
|
if (resp.code == 200) {
|
|
|
|
|
$.suiAlert({
|
|
|
|
|
title: "触发成功,等待执行结果",
|
|
|
|
|
type: "success",
|
|
|
|
|
description: resp.message,
|
|
|
|
|
time: "3",
|
|
|
|
|
position: "top-center",
|
|
|
|
|
});
|
|
|
|
|
} else {
|
2021-01-23 20:41:35 -05:00
|
|
|
|
$.suiAlert({
|
2021-04-22 09:53:31 -04:00
|
|
|
|
title: "触发失败 ",
|
|
|
|
|
type: "error",
|
|
|
|
|
description: resp.code + ":" + resp.message,
|
|
|
|
|
time: "3",
|
|
|
|
|
position: "top-center",
|
2021-01-23 20:41:35 -05:00
|
|
|
|
});
|
2021-04-22 09:53:31 -04:00
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.fail((err) => {
|
|
|
|
|
$(btn).toggleClass("loading");
|
|
|
|
|
$.suiAlert({
|
|
|
|
|
title: "触发失败 ",
|
|
|
|
|
type: "error",
|
|
|
|
|
description: "网络错误:" + err.responseText,
|
|
|
|
|
time: "3",
|
|
|
|
|
position: "top-center",
|
|
|
|
|
});
|
2021-01-23 20:41:35 -05:00
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-08 03:59:58 -05:00
|
|
|
|
function logout(id) {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
$.post("/api/logout", JSON.stringify({ id: id }))
|
|
|
|
|
.done(function (resp) {
|
|
|
|
|
if (resp.code == 200) {
|
|
|
|
|
$.suiAlert({
|
|
|
|
|
title: "注销成功",
|
|
|
|
|
type: "success",
|
|
|
|
|
description: "如需继续访问请使用 GitHub 再次登录",
|
|
|
|
|
time: "3",
|
|
|
|
|
position: "top-center",
|
|
|
|
|
});
|
|
|
|
|
window.location.reload();
|
|
|
|
|
} else {
|
2019-12-11 05:03:49 -05:00
|
|
|
|
$.suiAlert({
|
2021-04-22 09:53:31 -04:00
|
|
|
|
title: "注销失败",
|
|
|
|
|
description: resp.code + ":" + resp.message,
|
|
|
|
|
type: "error",
|
|
|
|
|
time: "3",
|
|
|
|
|
position: "top-center",
|
2019-12-11 05:03:49 -05:00
|
|
|
|
});
|
2021-04-22 09:53:31 -04:00
|
|
|
|
}
|
2019-12-08 03:59:58 -05:00
|
|
|
|
})
|
2021-04-22 09:53:31 -04:00
|
|
|
|
.fail(function (err) {
|
|
|
|
|
$.suiAlert({
|
|
|
|
|
title: "网络错误",
|
|
|
|
|
description: err.responseText,
|
|
|
|
|
type: "error",
|
|
|
|
|
time: "3",
|
|
|
|
|
position: "top-center",
|
|
|
|
|
});
|
|
|
|
|
});
|
2019-12-08 03:59:58 -05:00
|
|
|
|
}
|
2021-01-20 09:15:47 -05:00
|
|
|
|
|
|
|
|
|
$(document).ready(() => {
|
2021-04-22 09:53:31 -04:00
|
|
|
|
try {
|
|
|
|
|
$(".ui.servers.search.dropdown").dropdown({
|
|
|
|
|
clearable: true,
|
|
|
|
|
apiSettings: {
|
|
|
|
|
url: "/api/search-server?word={query}",
|
|
|
|
|
cache: false,
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
} catch (error) {}
|
|
|
|
|
});
|