mirror of https://github.com/CIRCL/AIL-framework
406 lines
22 KiB
HTML
406 lines
22 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
|
|
<title>Analysis Information Leak framework Dashboard</title>
|
|
|
|
<!-- Core CSS -->
|
|
<link href="{{ url_for('static', filename='css/bootstrap.min.css') }}" rel="stylesheet">
|
|
<link href="{{ url_for('static', filename='font-awesome/css/font-awesome.css') }}" rel="stylesheet">
|
|
<link href="{{ url_for('static', filename='css/sb-admin-2.css') }}" rel="stylesheet">
|
|
<link href="{{ url_for('static', filename='css/dataTables.bootstrap.css') }}" rel="stylesheet" type="text/css" />
|
|
<link href="{{ url_for('static', filename='css/switch_checkbox.css') }}" rel="stylesheet" type="text/css" />
|
|
<script language="javascript" src="{{ url_for('static', filename='js/jquery.js')}}"></script>
|
|
<script src="{{ url_for('static', filename='js/bootstrap.min.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='js/jquery.dataTables.min.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='js/dataTables.bootstrap.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='js/jquery.flot.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='js/jquery.flot.time.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='js/jquery.flot.stack.js') }}"></script>
|
|
|
|
<style>
|
|
.sparkLineStats ul {
|
|
padding-left:0;
|
|
list-style:none
|
|
}
|
|
|
|
.btn-link {
|
|
color: #000000
|
|
}
|
|
|
|
.popover-content {
|
|
white-space:pre-wrap;
|
|
word-wrap:break-word;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
|
|
<!-- Modal -->
|
|
<div id="mymodal" class="modal fade" role="dialog">
|
|
<div class="modal-dialog modal-lg">
|
|
|
|
<!-- Modal content-->
|
|
<div id="mymodalcontent" class="modal-content">
|
|
<div id="mymodalbody" class="modal-body" max-width="8500px">
|
|
<p>Loading paste information...</p>
|
|
<img id="loading-gif-modal" src="{{url_for('static', filename='image/loading.gif') }}" height="26" width="26" style="margin: 4px;">
|
|
</div>
|
|
<div class="modal-footer">
|
|
<a id="button_show_plot" target="_blank" href=""><button type="button" class="btn btn-info">Plot term</button></a>
|
|
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
{% include 'navbar.html' %}
|
|
|
|
<div id="page-wrapper">
|
|
<div class="row">
|
|
<div class="col-lg-12">
|
|
<h1 class="page-header" data-page="page-termsfrequency" >Terms frequency: Management interface</h1>
|
|
</div>
|
|
<!-- /.col-lg-12 -->
|
|
</div>
|
|
<!-- /.row -->
|
|
<div class="row">
|
|
|
|
<!-- Panel OPTIONS -->
|
|
<div class="row">
|
|
<div class="col-lg-12">
|
|
<div class="row">
|
|
<div class="col-lg-12">
|
|
<label class="switch">
|
|
<input id="per_paste" class="switch-input" value="per_paste" type="checkbox" onclick="reload_per_paste()">
|
|
<span class="switch-label" data-on="On" data-off="Off"></span>
|
|
<span class="switch-handle"></span>
|
|
</label>
|
|
<strong style="top: 3px; position: relative;">1 term per paste</strong>
|
|
|
|
<div id="panel-today" class="panel panel-success">
|
|
<div class="panel-heading">
|
|
<strong>Manage tracked terms</strong>
|
|
</div>
|
|
<div class="panel-body">
|
|
|
|
<div style="margin-bottom: 10px;">
|
|
<table>
|
|
<tr><td><b>Regex</b>: surround the term by '<b>/</b>'. </td> <td><b style="margin-left: 20px;">/([a-z])\w+([a-z])\n/</b></td></tr>
|
|
<tr><td><b>Set of terms</b>: surround the list by '<b>\</b>'. </td> <td><b style="margin-left: 20px;">\[term1, term2, ...]\</b></td></tr>
|
|
<tr><td> - To set a custom matching <b>threshold</b> (defaut=50), append it at the end as a inner list '<b>[thresh]</b>'. </td> <td><b style="margin-left: 20px;">\[term1, term2, ..., [75]]\</b></td></tr>
|
|
</table>
|
|
</div>
|
|
<div class="form-group input-group" style="margin-bottom: 30px;">
|
|
<span class="input-group-addon"><span class="fa fa-eye"></span></span>
|
|
<input id="followTermInput" class="form-control" placeholder="Term to track." type="text" style="max-width: 400px;">
|
|
<input id="followTermEMailNotificationReceiversInput" class="form-control" placeholder="Notification E-Mails (comma separated)" type="text" style="max-width: 400px;">
|
|
<button id="followTermBtn" class="btn btn-success btn-interaction" style="margin-left: 10px;" data-section="followTerm" data-action="add"> Add term</button>
|
|
</div>
|
|
|
|
<table class="table table-striped table-bordered table-hover" id="myTable">
|
|
<thead>
|
|
<tr>
|
|
<th style="max-width: 800px;">Term</th>
|
|
<th>Added date</th>
|
|
<th>Day occurence</th>
|
|
<th>Week occurence</th>
|
|
<th>Month occurence</th>
|
|
<th># tracked paste</th>
|
|
<th>Action</th>
|
|
<th>Notification E-Mails</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<!-- SET -->
|
|
{% for set in trackSet_list %}
|
|
<tr style="background-color: #cdffca;">
|
|
<td>{{ set }}</td>
|
|
<td>{{ trackSet_list_values[loop.index0][3] }}</td>
|
|
<td>{{ trackSet_list_values[loop.index0][0] }}</td>
|
|
<td>{{ trackSet_list_values[loop.index0][1] }}</td>
|
|
<td>{{ trackSet_list_values[loop.index0][2] }}</td>
|
|
<td>{{ trackSet_list_num_of_paste[loop.index0] }}</td>
|
|
<td><p style="margin: 0px; white-space: nowrap;">
|
|
<span data-toggle="modal" data-target="#mymodal" data-term="{{ set }}" ><button class="btn-link" data-toggle="tooltip" data-placement="right" title="Show concerned paste(s)"><span class="glyphicon glyphicon-info-sign"></span></button></span>
|
|
<button class="btn-link btn-interaction" data-toggle="tooltip" data-placement="left" title="Remove this term" data-content="{{ set }}" data-section="followTerm" data-action="delete"><span class="glyphicon glyphicon-trash"></span></button>
|
|
<input id="checkBoxEMailAlerts" type="checkbox" title="Toggle E-Mail notifications" class="btn-link btn-interaction" data-content="{{ set }}" data-section="followTerm" data-action="toggleEMailNotification" {% if notificationEnabledDict[set] %} checked {% endif %}>
|
|
</p></td>
|
|
<td style="white-space:pre">{{ notificationEMailTermMapping[set] }}</td>
|
|
</tr>
|
|
{% endfor %}
|
|
<!-- REGEX -->
|
|
{% for regex in trackReg_list %}
|
|
<tr style="background-color: #fffdca;">
|
|
<td>{{ regex }}</td>
|
|
<td>{{ trackReg_list_values[loop.index0][3] }}</td>
|
|
<td>{{ trackReg_list_values[loop.index0][0] }}</td>
|
|
<td>{{ trackReg_list_values[loop.index0][1] }}</td>
|
|
<td>{{ trackReg_list_values[loop.index0][2] }}</td>
|
|
<td>{{ trackReg_list_num_of_paste[loop.index0] }}</td>
|
|
<td><p style="margin: 0px; white-space: nowrap;">
|
|
<span data-toggle="modal" data-target="#mymodal" data-term="{{ regex }}" ><button class="btn-link" data-toggle="tooltip" data-placement="right" title="Show concerned paste(s)"><span class="glyphicon glyphicon-info-sign"></span></button></span>
|
|
<button class="btn-link btn-interaction" data-toggle="tooltip" data-placement="left" title="Remove this term" data-content="{{ regex }}" data-section="followTerm" data-action="delete"><span class="glyphicon glyphicon-trash"></span></button>
|
|
<input id="checkBoxEMailAlerts" type="checkbox" title="Toggle E-Mail notifications" class="btn-link btn-interaction" data-content="{{ regex }}" data-section="followTerm" data-action="toggleEMailNotification" {% if notificationEnabledDict[regex] %} checked {% endif %}>
|
|
</p></td>
|
|
<td style="white-space:pre">{{ notificationEMailTermMapping[regex] }}</td>
|
|
</tr>
|
|
{% endfor %}
|
|
<!-- Normal term -->
|
|
{% for term in track_list %}
|
|
<tr>
|
|
<td>{{ term }}</td>
|
|
<td>{{ track_list_values[loop.index0][3] }}</td>
|
|
<td>{{ track_list_values[loop.index0][0] }}</td>
|
|
<td>{{ track_list_values[loop.index0][1] }}</td>
|
|
<td>{{ track_list_values[loop.index0][2] }}</td>
|
|
<td>{{ track_list_num_of_paste[loop.index0] }}</td>
|
|
<td><p style="margin: 0px; white-space: nowrap;">
|
|
<span data-toggle="modal" data-target="#mymodal" data-term="{{ term }}" ><button class="btn-link" data-toggle="tooltip" data-placement="right" title="Show concerned paste(s)"><span class="glyphicon glyphicon-info-sign"></span></button></span>
|
|
<button class="btn-link btn-interaction" data-toggle="tooltip" data-placement="left" title="Remove this term" data-content="{{ term }}" data-section="followTerm" data-action="delete"><span class="glyphicon glyphicon-trash"></span></button>
|
|
<input id="checkBoxEMailAlerts" type="checkbox" title="Toggle E-Mail notifications" class="btn-link btn-interaction" data-content="{{ term }}" data-section="followTerm" data-action="toggleEMailNotification" {% if notificationEnabledDict[term] %} checked {% endif %}>
|
|
</p></td>
|
|
<td style="white-space:pre">{{ notificationEMailTermMapping[term] }}</td>
|
|
</tr>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
<!-- /.panel-body -->
|
|
</div>
|
|
</div>
|
|
<!-- /.panel -->
|
|
</div>
|
|
<!-- /.panel -->
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Panel OPTIONS -->
|
|
<div class="col-lg-12">
|
|
<div class="row">
|
|
<div class="col-lg-12">
|
|
<div id="panel-today" class="panel panel-danger">
|
|
<div class="panel-heading">
|
|
<strong>Manage blacklisted terms</strong>
|
|
</div>
|
|
<div class="panel-body">
|
|
|
|
<div class="form-group input-group" style="margin-bottom: 30px;">
|
|
<span class="input-group-addon"><span class="fa fa-eye-slash "></span></span>
|
|
<input id="blacklistTermInput" class="form-control" placeholder="Term to track" type="text" style="max-width: 400px;">
|
|
<button id="blacklistTermBtn" class="btn btn-danger btn-interaction" style="margin-left: 10px;" data-section="blacklistTerm" data-action="add"> Black list a term</button>
|
|
</div>
|
|
|
|
<table class="table table-striped table-bordered table-hover" id="myTable2">
|
|
<thead>
|
|
<tr>
|
|
<th style="max-width: 800px;">Term</th>
|
|
<th>Added date</th>
|
|
<th>Action</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{% for term, date in black_list %}
|
|
<tr>
|
|
<td>{{ term }}</td>
|
|
<td>{{ date }}</td>
|
|
<td><p style="margin: 0px;">
|
|
<button class="btn-link btn-interaction" data-toggle="tooltip" data-placement="right" title="Remove this term" data-content="{{ term }}" data-section="blacklistTerm" data-action="delete"><span class="glyphicon glyphicon-trash"></span></button>
|
|
</p></td>
|
|
</tr>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
<!-- /.panel-body -->
|
|
</div>
|
|
</div>
|
|
<!-- /.panel -->
|
|
</div>
|
|
<!-- /.panel -->
|
|
</div>
|
|
</div>
|
|
|
|
<!-- /.row -->
|
|
</div>
|
|
<!-- /#page-wrapper -->
|
|
</div>
|
|
|
|
|
|
<!-- import graph function -->
|
|
<script>
|
|
function reload_per_paste() {
|
|
var checked = $("#per_paste").prop( "checked" ) ? 1 : 0;
|
|
window.location.href = {{ url_for('terms.terms_management') }}+"?per_paste="+checked;
|
|
}
|
|
|
|
|
|
var table_track;
|
|
var table_black;
|
|
|
|
function bindEventsForCurrentPage() {
|
|
// On click, get html content from url and update the corresponding modal
|
|
$("[data-toggle='modal']").unbind().on("click.openmodal", function (event) {
|
|
//console.log(data);
|
|
event.preventDefault();
|
|
var the_modal=$(this);
|
|
var url = "{{ url_for('terms.terms_management_query_paste') }}?term=" + encodeURIComponent($(this).attr('data-term'));
|
|
$.getJSON(url, function (data) {
|
|
if (data.length != 0) {
|
|
var html_to_add = "";
|
|
html_to_add += "<table id=\"modal-table\" class=\"table table-striped\">";
|
|
html_to_add += "<thead>";
|
|
html_to_add += "<tr>";
|
|
html_to_add += "<th>Source</th>";
|
|
html_to_add += "<th>Date</th>";
|
|
html_to_add += "<th>Encoding</th>";
|
|
html_to_add += "<th>Size (Kb)</th>";
|
|
html_to_add += "<th># lines</th>";
|
|
html_to_add += "<th>Max length</th>";
|
|
html_to_add += "<th>Preview</th>";
|
|
html_to_add += "</tr>";
|
|
html_to_add += "</thead>";
|
|
html_to_add += "<tbody>";
|
|
for (i=0; i<data.length; i++) {
|
|
curr_data = data[i];
|
|
html_to_add += "<tr>";
|
|
html_to_add += "<td>"+curr_data.source+"</td>";
|
|
html_to_add += "<td>"+curr_data.date+"</td>";
|
|
html_to_add += "<td>"+curr_data.encoding+"</td>";
|
|
html_to_add += "<td>"+curr_data.size+"</td>";
|
|
html_to_add += "<td>"+curr_data.lineinfo[0]+"</td>";
|
|
html_to_add += "<td>"+curr_data.lineinfo[1]+"</td>";
|
|
html_to_add += "<td><div class=\"row\"><button class=\"btn btn-xs btn-default\" data-toggle=\"popover\" data-placement=\"left\" data-content=\""+curr_data.content.replace(/\"/g, "\'")+"\">Preview content</button><a target=\"_blank\" href=\"{{ url_for('showsavedpastes.showsavedpaste') }}?paste="+curr_data.path+"&num=0\"> <button type=\"button\" class=\"btn btn-xs btn-info\">Show Paste</button></a></div></td>";
|
|
|
|
html_to_add += "</tr>";
|
|
}
|
|
html_to_add += "</tbody>";
|
|
html_to_add += "</table>";
|
|
$("#mymodalbody").html(html_to_add);
|
|
$("[data-toggle=popover]").popover();
|
|
$("#button_show_plot").attr("href", "{{ url_for('terms.terms_plot_tool')}}"+"?term="+the_modal.attr('data-term') );
|
|
$('#modal-table').DataTable();
|
|
} else {
|
|
$("#mymodalbody").html("No paste containing this term has been received yet.");
|
|
$("#button_show_plot").attr("href", "{{ url_for('terms.terms_plot_tool')}}"+"?term="+the_modal.attr('data-term') );
|
|
}
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
$(document).ready(function(){
|
|
bindEventsForCurrentPage();
|
|
activePage = $('h1.page-header').attr('data-page');
|
|
$("#"+activePage).addClass("active");
|
|
if({{ per_paste }} == 1) {
|
|
$("#per_paste").attr('checked', true)
|
|
}
|
|
|
|
$('[data-toggle="tooltip"]').tooltip();
|
|
table_track = $('#myTable').DataTable();
|
|
table_black = $('#myTable2').DataTable();
|
|
|
|
table_track.on( 'draw.dt', function () {
|
|
perform_binding();
|
|
});
|
|
table_black.on( 'draw.dt', function () {
|
|
perform_binding();
|
|
});
|
|
|
|
|
|
$("#followTermInput").keyup(function(event){
|
|
if(event.keyCode == 13){
|
|
$("#followTermBtn").click();
|
|
$("#followTermInput").val("");
|
|
}
|
|
});
|
|
|
|
$("#blacklistTermInput").keyup(function(event){
|
|
if(event.keyCode == 13){
|
|
$("#blacklistTermBtn").click();
|
|
$("#blacklistTermInput").val("");
|
|
}
|
|
});
|
|
|
|
perform_binding();
|
|
|
|
$("#mymodal").on('hidden.bs.modal', function () {
|
|
$("#mymodalbody").html("<p>Loading paste information...</p>");
|
|
var loading_gif = "<img id='loading-gif-modal' class='img-center' src=\"{{url_for('static', filename='image/loading.gif') }}\" height='26' width='26' style='margin: 4px;'>";
|
|
$("#mymodalbody").append(loading_gif); // Show the loading GIF
|
|
});
|
|
|
|
|
|
});
|
|
</script>
|
|
|
|
<script>
|
|
|
|
|
|
|
|
function perform_binding() {
|
|
$(".btn-interaction").unbind("click.interaction");
|
|
$(".btn-interaction").bind("click.interaction", perform_operation);
|
|
}
|
|
|
|
function perform_operation(){
|
|
var curr_section = $(this).attr('data-section');
|
|
var curr_action = $(this).attr('data-action');
|
|
if (curr_action == "add") {
|
|
var curr_term = $('#'+curr_section+'Input').val();
|
|
var email_addresses = $('#followTermEMailNotificationReceiversInput').val();
|
|
} else {
|
|
var curr_term = $(this).attr('data-content');
|
|
var email_addresses = "";
|
|
}
|
|
var data_to_send = { section: curr_section, action: curr_action, term: curr_term, emailAddresses: email_addresses};
|
|
|
|
if (curr_term != "") {
|
|
console.log(data_to_send);
|
|
$.get("{{ url_for('terms.terms_management_action') }}", data_to_send, function(data, status){
|
|
if(status == "success") {
|
|
var json = data;
|
|
|
|
if(json.section == "followTerm") {
|
|
if(json.action == "add") {
|
|
// query data
|
|
$.get("{{ url_for('terms.terms_management_query') }}", { term: json.term, section: json.section }, function(data2, status){
|
|
reload_per_paste();
|
|
});
|
|
} else if (json.action == "delete") {
|
|
// Find indexes of row which have the term in the first column
|
|
var index = table_track.rows().eq( 0 ).filter( function (rowIdx) {
|
|
console.log(table_track.cell( rowIdx, 0 ).data())
|
|
return table_track.cell( rowIdx, 0 ).data() === json.term;
|
|
} );
|
|
table_track.rows(index).remove().draw( false );
|
|
}
|
|
} else if(json.section == "blacklistTerm"){
|
|
if(json.action == "add") {
|
|
$.get("{{ url_for('terms.terms_management_query') }}", { term: json.term, section: json.section }, function(data2, status){
|
|
console.log(data2);
|
|
var action_button = "<button class=\"btn-link btn-interaction\" data-toggle=\"tooltip\" data-placement=\"right\" title=\"Remove this term\" data-content=\"" + json.term + "\" data-section=\"blacklistTerm\" data-action=\"delete\"><span class=\"glyphicon glyphicon-trash\"></span></button>"
|
|
table_black.row.add( [ json.term, data2[3], action_button ] ).draw( false );
|
|
perform_binding();
|
|
});
|
|
} else if (json.action == "delete") {
|
|
// Find indexes of row which have the term in the first column
|
|
var index = table_black.rows().eq( 0 ).filter( function (rowIdx) {
|
|
return table_black.cell( rowIdx, 0 ).data() === json.term;
|
|
} );
|
|
table_black.rows(index).remove().draw( false );
|
|
}
|
|
}
|
|
|
|
|
|
|
|
}
|
|
});
|
|
}
|
|
}
|
|
</script>
|