diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-03-18 14:44:34 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-03-18 14:44:34 +0000 |
commit | f20a17627041adf5dd79e441f372129296a13aa2 (patch) | |
tree | a7c748adbf5b4826905c32ba5a79a4d1638d7362 | |
parent | 1bd8b9fe4ea998c1f7e24676df4480a55aeb7663 (diff) | |
download | rspamd-f20a17627041adf5dd79e441f372129296a13aa2.tar.gz rspamd-f20a17627041adf5dd79e441f372129296a13aa2.zip |
[WebUI] Initial move towards footable
-rw-r--r-- | interface/index.html | 19 | ||||
-rw-r--r-- | interface/js/app/history.js | 182 | ||||
-rw-r--r-- | interface/js/main.js | 2 |
3 files changed, 113 insertions, 90 deletions
diff --git a/interface/index.html b/interface/index.html index 3fd348206..7715d1d58 100644 --- a/interface/index.html +++ b/interface/index.html @@ -8,6 +8,7 @@ <meta name="author" content=""> <link href="./css/bootstrap.min.css" rel="stylesheet"> <link rel="stylesheet" type="text/css" href="./css/datatables.min.css"/> + <link rel="stylesheet" type="text/css" href="./css/footable.bootstrap.min.css"/> <link rel="stylesheet" type="text/css" href="./css/d3evolution.css"> <link href="./css/rspamd.css" rel="stylesheet"> </head> @@ -302,21 +303,9 @@ <h5>History</h5> </div> <div class="widget-content nopadding"> - <table class="table table-log table-hover" id="historyLog"> - <thead> - <tr> - <th class="col1" title="Time">Time</th> - <th class="col2" title="ID">ID</th> - <th class="col3" title="IP">IP</th> - <th class="col4" title="Action">Action</th> - <th class="col5" title="Score / Req. score">Score / Req. score</th> - <th class="col6" title="Symbols">Symbols</th> - <th class="col7" title="Size">Size</th> - <th class="col8" title="Scan Time (s)"><div class="cell-overflow">Scan Time (s)</div></th> - <th class="col9" title="User">User</th> - </tr> - </thead> - </table> + <div id="historyLog"> + <table class="table" id="historyTable"></table> + </div> </div> </div> <div class="widget-box" id="errors-history"> diff --git a/interface/js/app/history.js b/interface/js/app/history.js index a19414114..76c365f4a 100644 --- a/interface/js/app/history.js +++ b/interface/js/app/history.js @@ -22,7 +22,7 @@ THE SOFTWARE. */ -define(['jquery', 'datatables'], +define(['jquery', 'datatables', 'footable'], function($) { var interface = {}; @@ -37,59 +37,33 @@ function($) { $.each(data.rows.map(function(elt) { return JSON.parse(elt);}), function (i, item) { - var action; - if (item.action === 'clean' || item.action === 'no action') { - action = 'label-success'; - } else if (item.action === 'rewrite subject' || - item.action === 'add header' || - item.action === 'probable spam') { - action = 'label-warning'; + item.action = "<div style='font-size:11px' class='label label-success'>" + item.action + "</div>"; + } else if (item.action === 'rewrite subject' || item.action === 'add header' || item.action === 'probable spam') { + item.action = "<div style='font-size:11px' class='label label-warning'>" + item.action + "</div>"; } else if (item.action === 'spam' || item.action === 'reject') { - action = 'label-danger'; + item.action = "<div style='font-size:11px' class='label label-danger'>" + item.action + "</div>"; } else { - action = 'label-info'; + item.action = "<div style='font-size:11px' class='label label-info'>" + item.action + "</div>"; } - var score; if (item.score < item.required_score) { - score = 'label-success'; + item.score = "<span class='text-success'>" + item.score.toFixed(2) + " / " + item.required_score + "</span>"; } else { - score = 'label-danger'; + item.score = "<span class='text-danger'>" + item.score.toFixed(2) + " / " + item.required_score + "</span>"; + } + + if (item.user == null) { + item.user = "none"; } var symbols = Object.keys(item.symbols); - var nitem = []; - nitem.push('<tr><td data-order="' + - item.unix_time + '">' + - unix_time_format(item.unix_time) + '</td>'); - nitem.push('<td data-order="' + item['message-id'] + - '"><div class="cell-overflow" tabindex="1" title="' + - item['message-id'] + '">' + item['message-id'] + - '</div></td>'); - nitem.push('<td data-order="' + item.ip + - '"><div class="cell-overflow" tabindex="1" title="' + - item.ip + '">' + item.ip + '</div></td>'); - nitem.push('<td data-order="' + item.action + - '"><span class="label ' + action + '">' + item.action + - '</span></td>'); - nitem.push('<td data-order="' + item.score + - '"><span class="label ' + score + '">' - + item.score.toFixed(2) + ' / ' + - item.required_score.toFixed(2) + '</span></td>'); - nitem.push( '<td data-order="' + symbols + - '"><div class="cell-overflow" tabindex="1" title="' + - symbols + '">' + symbols + '</div></td>'); - nitem.push('<td data-order="' + item.size + '">' + - item.size + '</td>'); - nitem.push('<td data-order="' + item.time_real + '">' + - item.time_real.toFixed(3) + '/' + - item.time_virtual.toFixed(3) + '</td>'); - nitem.push('<td data-order="' + item.user + - '"><div class="cell-overflow" tabindex="1" "title="' + - item.user + '">' + item.user + '</div></td></tr>'); - - items.push(nitem.join("\n")); + item.symbols = symbols + item.time = unix_time_format(item.unix_time); + item.scan_time = item.time_real.toFixed(3) + '/' + + item.time_virtual.toFixed(3); + item.id = item['message-id']; + items.push(item); }); return items; @@ -99,35 +73,27 @@ function($) { var items = []; $.each(data, function (i, item) { - var action; - if (item.action === 'clean' || item.action === 'no action') { - action = 'label-success'; + item.action = "<div style='font-size:11px' class='label label-success'>" + item.action + "</div>"; } else if (item.action === 'rewrite subject' || item.action === 'add header' || item.action === 'probable spam') { - action = 'label-warning'; + item.action = "<div style='font-size:11px' class='label label-warning'>" + item.action + "</div>"; } else if (item.action === 'spam' || item.action === 'reject') { - action = 'label-danger'; + item.action = "<div style='font-size:11px' class='label label-danger'>" + item.action + "</div>"; } else { - action = 'label-info'; + item.action = "<div style='font-size:11px' class='label label-info'>" + item.action + "</div>"; } - var score; if (item.score < item.required_score) { - score = 'label-success'; + item.score = "<span class='text-success'>" + item.score.toFixed(2) + " / " + item.required_score + "</span>"; } else { - score = 'label-danger'; + item.score = "<span class='text-danger'>" + item.score.toFixed(2) + " / " + item.required_score + "</span>"; } - items.push( - '<tr><td data-order="' + item.unix_time + '">' + item.time + '</td>' + - '<td data-order="' + item.id + '"><div class="cell-overflow" tabindex="1" title="' + item.id + '">' + item.id + '</div></td>' + - '<td data-order="' + item.ip + '"><div class="cell-overflow" tabindex="1" title="' + item.ip + '">' + item.ip + '</div></td>' + - '<td data-order="' + item.action + '"><span class="label ' + action + '">' + item.action + '</span></td>' + - '<td data-order="' + item.score + '"><span class="label ' + score + '">' + item.score.toFixed(2) + ' / ' + item.required_score.toFixed(2) + '</span></td>' + - '<td data-order="' + item.symbols + '"><div class="cell-overflow" tabindex="1" title="' + item.symbols + '">' + item.symbols + '</div></td>' + - '<td data-order="' + item.size + '">' + item.size + '</td>' + - '<td data-order="' + item.scan_time + '">' + item.scan_time.toFixed(3) + '</td>' + - '<td data-order="' + item.user + '"><div class="cell-overflow" tabindex="1" "title="' + item.user + '">' + item.user + '</div></td></tr>'); + if (item.user == null) { + item.user = "none"; + } + + items.push(item) }); return items; @@ -164,6 +130,57 @@ function($) { $('#historyLog').children('tbody').remove(); } + + FooTable.actionFilter = FooTable.Filtering.extend({ + construct : function(instance) { + this._super(instance); + this.actions = [ 'reject', 'add_header', 'greylist', + 'no action', 'soft reject' ]; + this.def = 'Any action'; + this.$action = null; + }, + $create : function() { + this._super(); + var self = this, $form_grp = $('<div/>', { + 'class' : 'form-group' + }).append($('<label/>', { + 'class' : 'sr-only', + text : 'Action' + })).prependTo(self.$form); + + self.$action = $('<select/>', { + 'class' : 'form-control' + }).on('change', { + self : self + }, self._onStatusDropdownChanged).append( + $('<option/>', { + text : self.def + })).appendTo($form_grp); + + $.each(self.actions, function(i, action) { + self.$action.append($('<option/>').text(action)); + }); + }, + _onStatusDropdownChanged : function(e) { + var self = e.data.self, selected = $(this).val(); + if (selected !== self.def) { + self.addFilter('action', selected, [ 'action' ]); + } else { + self.removeFilter('action'); + } + self.filter(); + }, + draw : function() { + this._super(); + var action = this.find('action'); + if (action instanceof FooTable.Filter) { + this.$action.val(action.query.val()); + } else { + this.$action.val(this.def); + } + } + }); + $.ajax({ dataType: 'json', url: 'history', @@ -177,19 +194,34 @@ function($) { success: function (data) { var items = process_history_data(data); - $('<tbody/>', { - html: items.join("\n") - }).insertAfter('#historyLog thead'); - tables.history = $('#historyLog').DataTable({ - "aLengthMenu": [ - [100, 200, -1], - [100, 200, "All"] - ], - "bStateSave": true, - "order": [ - [0, "desc"] + $('#historyTable').footable({ + "columns": [ + {"name":"id","title":"ID","style":{"font-size":"11px","width":300,"maxWidth":300,"overflow":"hidden","textOverflow":"ellipsis","wordBreak":"keep-all","whiteSpace":"nowrap"}}, + {"name":"ip","title":"IP address","breakpoints":"xs sm","style":{"font-size":"11px","width":150,"maxWidth":150}}, + {"name":"action","title":"Action","style":{"font-size":"11px","width":110,"maxWidth":110}}, + {"name":"score","title":"Score","style":{"font-size":"11px","maxWidth":110}}, + {"name":"symbols","title":"Symbols","breakpoints":"all","style":{"font-size":"11px","width":550,"maxWidth":550}}, + {"name":"size","title":"Message size","breakpoints":"xs sm","style":{"font-size":"11px","width":120,"maxWidth":120}}, + {"name":"scan_time","title":"Scan time","breakpoints":"xs sm","style":{"font-size":"11px","maxWidth":80}}, + {"sorted": true,"direction": "DESC","name":"time","title":"Time","style":{"font-size":"11px"}}, + {"name":"user","title":"Authenticated user","breakpoints":"xs sm","style":{"font-size":"11px","width":200,"maxWidth":200}} ], - "pageLength": history_length + "rows": items, + "paging": { + "enabled": true, + "limit": 5, + "size": 25 + }, + "filtering": { + "enabled": true, + "position": "left" + }, + "sorting": { + "enabled": true + }, + components: { + filtering: FooTable.actionFilter + } }); } }); diff --git a/interface/js/main.js b/interface/js/main.js index c2f9da983..b2c6a2103 100644 --- a/interface/js/main.js +++ b/interface/js/main.js @@ -10,6 +10,7 @@ requirejs.config({ d3evolution: 'd3evolution.min', d3pie: 'd3pie.min', datatables: 'datatables.min', + footable: 'footable.min', bootstrap: 'bootstrap.min', }, shim: { @@ -18,6 +19,7 @@ requirejs.config({ d3pie: {exports: 'd3pie', deps: ['d3', 'jquery']}, d3evolution: {exports: 'D3Evolution', deps: ['d3', 'd3pie', 'jquery']}, datatables: {deps: ['bootstrap', 'jquery']}, + footable: {deps: ['bootstrap', 'jquery']} }, map: { '*': { |