aboutsummaryrefslogtreecommitdiffstats
path: root/interface
diff options
context:
space:
mode:
Diffstat (limited to 'interface')
-rw-r--r--interface/index.html12
-rw-r--r--interface/js/app/config.js139
-rw-r--r--interface/js/app/rspamd.js4
3 files changed, 84 insertions, 71 deletions
diff --git a/interface/index.html b/interface/index.html
index da5eaf351..d70c557e5 100644
--- a/interface/index.html
+++ b/interface/index.html
@@ -202,7 +202,17 @@
<span class="icon mr-3"><i class="fas fa-tasks"></i></span>
<span class="h6 font-weight-bolder my-2">Actions</span>
</div>
- <div class="card-body actions-content" id="actionsBody"></div>
+ <div class="card-body pb-2">
+ <form id="actionsForm">
+ <fieldset id="actionsFormField" class="ro-disable"></fieldset>
+ </form>
+ </div>
+ <div class="card-footer ro-hide">
+ <div class="btn-group">
+ <button class="btn btn-primary" type="button" id="saveActionsBtn">Save actions</button>
+ <button class="btn btn-warning" type="button" id="saveActionsClusterBtn">Save cluster</button>
+ </div>
+ </div>
</div>
<div class="card bg-light shadow my-3">
<div class="card-header text-secondary py-2">
diff --git a/interface/js/app/config.js b/interface/js/app/config.js
index 36cdafeea..986db5748 100644
--- a/interface/js/app/config.js
+++ b/interface/js/app/config.js
@@ -27,23 +27,10 @@ define(["jquery"],
"use strict";
var ui = {};
- function loadActionsFromForm() {
- var values = [];
- var inputs = $("#actionsForm :input[data-id=\"action\"]");
- // Rspamd order: [spam, rewrite_subject, probable_spam, greylist]
- values[0] = parseFloat(inputs[3].value);
- values[1] = parseFloat(inputs[2].value);
- values[2] = parseFloat(inputs[1].value);
- values[3] = parseFloat(inputs[0].value);
-
- return JSON.stringify(values);
- }
-
ui.getActions = function getActions(rspamd, checked_server) {
rspamd.query("actions", {
success: function (data) {
- $("#actionsBody").empty();
- $("#actionsForm").empty();
+ $("#actionsFormField").empty();
var items = [];
$.each(data[0].data, function (i, item) {
var idx = -1;
@@ -64,11 +51,13 @@ define(["jquery"],
if (idx >= 0) {
items.push({
idx: idx,
- html: "<div class=\"form-group\">" +
- "<label class=\"col-form-label col-md-2 float-left\">" + label + "</label>" +
- "<div class=\"controls slider-controls col-md-10\">" +
- "<input class=\"action-scores form-control\" data-id=\"action\" type=\"number\" value=\"" + item.value + "\">" +
- "</div>" +
+ html:
+ '<div class="form-group">' +
+ '<label class="col-form-label col-md-2 float-left">' + label + "</label>" +
+ '<div class="controls slider-controls col-md-10">' +
+ '<input class="action-scores form-control" data-id="action" type="number" value="' +
+ item.value + '">' +
+ "</div>" +
"</div>"
});
}
@@ -78,62 +67,65 @@ define(["jquery"],
return a.idx - b.idx;
});
- $("#actionsBody").html("<form id=\"actionsForm\"><fieldset id=\"actionsFormField\">" +
- items.map(function (e) {
- return e.html;
- }).join("") +
- "<div class=\"form-group\">" +
- "<div class=\"btn-group\">" +
- "<button class=\"btn btn-primary\" type=\"button\" id=\"saveActionsBtn\">Save actions</button>" +
- "<button class=\"btn btn-primary\" type=\"button\" id=\"saveActionsClusterBtn\">Save cluster</button>" +
- "</div></div></fieldset></form>");
- if (rspamd.read_only) {
- $("#saveActionsClusterBtn").attr("disabled", true);
- $("#saveActionsBtn").attr("disabled", true);
- $("#actionsFormField").attr("disabled", true);
- }
-
- function saveActions(server) {
- var elts = loadActionsFromForm();
- // String to array for comparison
- var eltsArray = JSON.parse(loadActionsFromForm());
- if (eltsArray[0] < 0) {
- rspamd.alertMessage("alert-modal alert-error", "Spam can not be negative");
- } else if (eltsArray[1] < 0) {
- rspamd.alertMessage("alert-modal alert-error", "Rewrite subject can not be negative");
- } else if (eltsArray[2] < 0) {
- rspamd.alertMessage("alert-modal alert-error", "Probable spam can not be negative");
- } else if (eltsArray[3] < 0) {
- rspamd.alertMessage("alert-modal alert-error", "Greylist can not be negative");
- } else if (
- (eltsArray[2] === null || eltsArray[3] < eltsArray[2]) &&
- (eltsArray[1] === null || eltsArray[2] < eltsArray[1]) &&
- (eltsArray[0] === null || eltsArray[1] < eltsArray[0])
- ) {
- rspamd.query("saveactions", {
- method: "POST",
- params: {
- data: elts,
- dataType: "json"
- },
- server: server
- });
- } else {
- rspamd.alertMessage("alert-modal alert-error", "Incorrect order of metric actions threshold");
- }
- }
-
- $("#saveActionsBtn").on("click", function () {
- saveActions();
- });
- $("#saveActionsClusterBtn").on("click", function () {
- saveActions("All SERVERS");
- });
+ $("#actionsFormField").html(
+ items.map(function (e) {
+ return e.html;
+ }).join(""));
},
server: (checked_server === "All SERVERS") ? "local" : checked_server
});
};
+ ui.saveActions = function (rspamd, server) {
+ function descending(arr) {
+ var desc = true;
+ var filtered = arr.filter(function (el) {
+ return el !== null;
+ });
+ for (var i = 0; i < filtered.length - 1; i++) {
+ if (filtered[i + 1] >= filtered[i]) {
+ desc = false;
+ break;
+ }
+ }
+ return desc;
+ }
+
+ var elts = (function () {
+ var values = [];
+ var inputs = $("#actionsForm :input[data-id=\"action\"]");
+ // Rspamd order: [spam, rewrite_subject, probable_spam, greylist]
+ values[0] = parseFloat(inputs[3].value);
+ values[1] = parseFloat(inputs[2].value);
+ values[2] = parseFloat(inputs[1].value);
+ values[3] = parseFloat(inputs[0].value);
+
+ return JSON.stringify(values);
+ }());
+ // String to array for comparison
+ var eltsArray = JSON.parse(elts);
+ if (eltsArray[0] < 0) {
+ rspamd.alertMessage("alert-modal alert-error", "Spam can not be negative");
+ } else if (eltsArray[1] < 0) {
+ rspamd.alertMessage("alert-modal alert-error", "Rewrite subject can not be negative");
+ } else if (eltsArray[2] < 0) {
+ rspamd.alertMessage("alert-modal alert-error", "Probable spam can not be negative");
+ } else if (eltsArray[3] < 0) {
+ rspamd.alertMessage("alert-modal alert-error", "Greylist can not be negative");
+ } else if (descending(eltsArray)) {
+ rspamd.query("saveactions", {
+ method: "POST",
+ params: {
+ data: elts,
+ dataType: "json"
+ },
+ server: server
+ });
+ } else {
+ rspamd.alertMessage("alert-modal alert-error", "Incorrect order of actions thresholds");
+ }
+ };
+
ui.getMaps = function (rspamd, checked_server) {
var $listmaps = $("#listMaps");
$listmaps.closest(".card").hide();
@@ -199,6 +191,13 @@ define(["jquery"],
$("#map-textarea").remove();
});
+ $("#saveActionsBtn").on("click", function () {
+ ui.saveActions(rspamd);
+ });
+ $("#saveActionsClusterBtn").on("click", function () {
+ ui.saveActions(rspamd, "All SERVERS");
+ });
+
function saveMap(server) {
rspamd.query("savemap", {
success: function () {
diff --git a/interface/js/app/rspamd.js b/interface/js/app/rspamd.js
index be7594e30..f08363c62 100644
--- a/interface/js/app/rspamd.js
+++ b/interface/js/app/rspamd.js
@@ -276,11 +276,15 @@ function ($, D3pie, visibility, NProgress, stickyTabs, tab_stat, tab_graph, tab_
// So when we store the boolean true or false, it actually stores the strings "true" or "false".
ui.read_only = sessionStorage.getItem("read_only") === "true";
if (ui.read_only) {
+ $(".ro-disable").attr("disabled", true);
+ $(".ro-hide").hide();
$(".learn").hide();
$("#resetHistory").attr("disabled", true);
$("#errors-history").hide();
$("#selectors_nav").hide();
} else {
+ $(".ro-disable").removeAttr("disabled", true);
+ $(".ro-hide").show();
$(".learn").show();
$("#resetHistory").removeAttr("disabled", true);
$("#errors-history").show();