2015-12-31 18:38:02 +01:00
|
|
|
|
<!DOCTYPE html>
|
|
|
|
|
<html lang="en">
|
|
|
|
|
<head>
|
|
|
|
|
<meta charset="utf-8">
|
|
|
|
|
<title>Rspamd Web Interface</title>
|
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
|
|
|
<meta name="description" content="">
|
|
|
|
|
<meta name="author" content="">
|
2016-11-02 17:56:53 +01:00
|
|
|
|
<link href="./css/bootstrap.min.css" rel="stylesheet">
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<link rel="stylesheet" type="text/css" href="./css/datatables.min.css"/>
|
2016-07-02 22:24:28 +02:00
|
|
|
|
<link rel="stylesheet" type="text/css" href="./css/d3evolution.css">
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<link href="./css/rspamd.css" rel="stylesheet">
|
|
|
|
|
</head>
|
|
|
|
|
|
|
|
|
|
<body>
|
|
|
|
|
|
|
|
|
|
<nav class="navbar navbar-default" id="navBar">
|
|
|
|
|
<div class="container-fluid">
|
|
|
|
|
<div class="navbar-header">
|
2016-11-15 10:55:11 +01:00
|
|
|
|
<a class="navbar-brand" href="."><img src="./img/rspamd_logo_navbar.png" style="width: 67px; margin-top: -16px;"/></a>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</div>
|
|
|
|
|
<ul class="nav pull-right navbar-nav" style="display:none">
|
|
|
|
|
<li><a href="#" data-toggle="tab" id="refresh">Refresh</a></li>
|
|
|
|
|
<li class="spinner"><a href="#" data-toggle="tab" id="disconnect">Disconnect</a></li>
|
|
|
|
|
</ul>
|
|
|
|
|
<ul class="nav navbar-nav nav-pills" role="tablist">
|
|
|
|
|
<li role="presentation" class="active"><a id="status_nav" aria-controls="status" role="tab" href="#status" data-toggle="tab">Status</a></li>
|
2016-07-01 18:37:13 +02:00
|
|
|
|
|
2016-05-26 09:33:35 +02:00
|
|
|
|
<li role="presentation"><a id="throughput_nav" aria-controls="throughput" role="tab" href="#throughput" data-toggle="tab">Throughput</a></li>
|
2016-07-01 18:37:13 +02:00
|
|
|
|
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<li role="presentation"><a id="configuration_nav" aria-controls="configuration" role="tab" href="#configuration" data-toggle="tab">Configuration</a></li>
|
2016-11-01 10:14:44 +01:00
|
|
|
|
<li role="presentation"><a id="symbols_nav" aria-controls="symbols" role="tab" href="#symbols" data-toggle="tab">Symbols</a></li>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<li role="presentation"><a id="learning_nav" aria-controls="learning" role="tab" href="#learning" data-toggle="tab">Learning</a></li>
|
|
|
|
|
<li role="presentation"><a id="scan_nav"aria-controls="scan" role="tab" href="#scan" data-toggle="tab">Scan</a></li>
|
|
|
|
|
<li role="presentation"><a id="history_nav" aria-controls="history" role="tab" href="#history" data-toggle="tab">History</a></li>
|
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
|
|
|
|
</nav>
|
|
|
|
|
|
|
|
|
|
<div id="mainUI" style="display:none">
|
|
|
|
|
|
|
|
|
|
<div class="container-fluid">
|
|
|
|
|
|
|
|
|
|
<div class="tab-content">
|
|
|
|
|
<div class="tab-pane active" id="status">
|
|
|
|
|
<div class="row">
|
|
|
|
|
<div class="col-md-12">
|
|
|
|
|
<div class="widget-box widget-plain">
|
|
|
|
|
<ul id="statWidgets" class="stat-boxes" style="display:none">
|
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-signal"></i></span>
|
|
|
|
|
<h5>Statistics</h5>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-content chart-content">
|
|
|
|
|
<div class="row row-chart">
|
|
|
|
|
<div class="chart" id="chart">
|
|
|
|
|
<span class="notice">Loading..</span>
|
|
|
|
|
<noscript>Please enable Javascript</noscript>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
2016-05-26 09:33:35 +02:00
|
|
|
|
<div class="tab-pane" id="throughput">
|
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-stats"></i></span>
|
|
|
|
|
<h5>Throughput</h5>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-content chart-content">
|
|
|
|
|
<div class="row row-chart">
|
|
|
|
|
<div class="chart" id="graph">
|
|
|
|
|
<span class="notice">Loading..</span>
|
|
|
|
|
<noscript>Please enable Javascript</noscript>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<form id="graph_controls" action="#">
|
|
|
|
|
Select dataset:
|
|
|
|
|
<select id="selData" class="form-control">
|
|
|
|
|
<option value="hourly" selected>Hourly</option>
|
|
|
|
|
<option value="daily">Daily</option>
|
|
|
|
|
<option value="weekly">Weekly</option>
|
|
|
|
|
<option value="monthly">Monthly</option>
|
|
|
|
|
</select>
|
2016-07-07 21:23:06 +02:00
|
|
|
|
Convert to:
|
|
|
|
|
<select id="selConvert" class="form-control">
|
|
|
|
|
<option value="" selected>--</option>
|
|
|
|
|
<option value="percentage">percentage</option>
|
|
|
|
|
</select>
|
2016-05-26 09:33:35 +02:00
|
|
|
|
Select chart type:
|
|
|
|
|
<select id="selType" class="form-control">
|
|
|
|
|
<option value="line" selected>Line</option>
|
|
|
|
|
<option value="area">Stacked area</option>
|
|
|
|
|
</select>
|
|
|
|
|
Select <a title="View Mike Bostock's Block." href="https://bl.ocks.org/mbostock/4342190" target="_blank">interpolation mode</a>:
|
|
|
|
|
<select id="selInterpolate" class="form-control">
|
|
|
|
|
<option value="linear" selected>linear</option>
|
2016-07-10 19:15:09 +02:00
|
|
|
|
<option value="step">step</option>
|
2016-05-26 09:33:35 +02:00
|
|
|
|
<option value="step-before">step-before</option>
|
|
|
|
|
<option value="step-after">step-after</option>
|
|
|
|
|
<option value="basis">basis</option>
|
|
|
|
|
<option value="basis-open">basis-open</option>
|
|
|
|
|
<option value="bundle">bundle</option>
|
|
|
|
|
<option value="cardinal">cardinal</option>
|
|
|
|
|
<option value="cardinal-open">cardinal-open</option>
|
|
|
|
|
<option value="monotone">monotone</option>
|
|
|
|
|
</select>
|
|
|
|
|
</form>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<div class="tab-pane" id="configuration">
|
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-tasks"></i></span><h5>Actions</h5>
|
|
|
|
|
</div>
|
2016-07-02 22:16:37 +02:00
|
|
|
|
<div class="widget-content actions-content" id="actionsBody"></div>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
2016-11-01 10:14:44 +01:00
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-list"></i></span><h5>Lists</h5>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</div>
|
2016-11-01 10:14:44 +01:00
|
|
|
|
<div class="widget-content nopadding">
|
|
|
|
|
<table class="table table-condensed table-hover" id="listMaps">
|
|
|
|
|
</table>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2016-11-01 10:14:44 +01:00
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="tab-pane" id="symbols">
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
2016-11-01 10:14:44 +01:00
|
|
|
|
<div class="buttons pull-right">
|
2016-11-01 12:25:12 +01:00
|
|
|
|
<button class="btn btn-info btn-sm" id="updateSymbols">
|
2016-11-01 10:14:44 +01:00
|
|
|
|
<i class="glyphicon glyphicon-refresh"></i> Update
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
2016-11-01 12:25:12 +01:00
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-tasks"></i></span>
|
2016-11-01 10:14:44 +01:00
|
|
|
|
<h5>Symbols and rules</h5>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-content nopadding">
|
2016-11-01 10:14:44 +01:00
|
|
|
|
<table class="table table-log table-hover" id="symbolsTable">
|
|
|
|
|
<thead>
|
2016-11-01 12:59:13 +01:00
|
|
|
|
<th title="Group">Group</th>
|
2016-11-02 18:09:50 +01:00
|
|
|
|
<th title="Symbol">Symbol</th>
|
2016-11-01 12:59:13 +01:00
|
|
|
|
<th title="Description">Description</th>
|
|
|
|
|
<th title="Score">Score</th>
|
|
|
|
|
<th title="Hits">Hits</th>
|
|
|
|
|
<th title="Avg.time">Avg.time</th>
|
|
|
|
|
<th title="Save data">Save data</th>
|
2016-11-01 10:14:44 +01:00
|
|
|
|
</thead>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="tab-pane" id="learning">
|
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-file"></i></span>
|
|
|
|
|
<h5>Learn RSPAMD</h5>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-content">
|
|
|
|
|
<div class="row">
|
|
|
|
|
<form class="col-md-6">
|
|
|
|
|
<h5>Insert raw SPAM source:</h5>
|
|
|
|
|
<textarea class="col-md-5 upload-textarea" id="spamTextSource" value=""></textarea>
|
|
|
|
|
<p><button class="btn btn-default pull-right" data-upload="spam"><i class="glyphicon glyphicon-upload"></i> Upload text</button></p>
|
|
|
|
|
</form>
|
|
|
|
|
<form class="col-md-6">
|
|
|
|
|
<h5>Insert raw HAM source:</h5>
|
|
|
|
|
<textarea class="col-md-5 upload-textarea" id="hamTextSource" value=""></textarea>
|
|
|
|
|
<p><button class="btn btn-default pull-right" data-upload="ham"><i class="glyphicon glyphicon-upload"></i> Upload text</button></p>
|
|
|
|
|
</form>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="row">
|
|
|
|
|
<form class="col-md-6">
|
|
|
|
|
<h5>Insert raw Fuzzy storage:</h5>
|
|
|
|
|
<textarea class="col-md-5 upload-textarea" id="fuzzyTextSource" value=""></textarea>
|
|
|
|
|
<div class="row">
|
|
|
|
|
<label class="pull-left">
|
|
|
|
|
Flag
|
|
|
|
|
</label>
|
|
|
|
|
<div class="pull-right col-md-10">
|
2016-07-02 22:16:37 +02:00
|
|
|
|
<input id="fuzzyFlagText" class="slider" type="slider" value="1"/>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="row">
|
|
|
|
|
<label class="pull-left">
|
|
|
|
|
Weight
|
|
|
|
|
</label>
|
|
|
|
|
<div class="pull-right col-md-10">
|
2016-07-02 22:16:37 +02:00
|
|
|
|
<input id="fuzzyWeightText" class="slider" type="slider" value="1"/>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<p><button class="btn btn-default pull-right" data-upload="fuzzy"><i class="glyphicon glyphicon-upload"></i> Upload text</button></p>
|
|
|
|
|
</form>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="tab-pane" id="scan">
|
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-info-sign"></i></span>
|
|
|
|
|
<h5>Online scan suspected message</h5>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-content">
|
|
|
|
|
<h5>Paste and scan suspicious message</h5>
|
|
|
|
|
<div class="row">
|
|
|
|
|
<form class="col-md-12 nomargin" id="scanForm">
|
|
|
|
|
<textarea class="col-md-12 scan-textarea" id="scanTextSource"></textarea>
|
|
|
|
|
<p><button class="btn btn-default btn-primary" data-upload="scan">Scan message</button>
|
|
|
|
|
<button class="btn btn-default pull-right" id="scanClean">Clean form</button></p>
|
|
|
|
|
</form>
|
|
|
|
|
</div>
|
|
|
|
|
<div id="scanResult" style="display:none">
|
|
|
|
|
<h4>Scan results:</h4>
|
|
|
|
|
<div class="well nomargin nopadding">
|
|
|
|
|
<table class="table table-log table-hover" id="scanOutput">
|
|
|
|
|
<thead>
|
|
|
|
|
<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>
|
|
|
|
|
</thead>
|
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="tab-pane" id="history">
|
|
|
|
|
|
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
|
|
|
|
<div class="buttons pull-right">
|
|
|
|
|
<button class="btn btn-danger btn-sm" id="resetHistory">
|
|
|
|
|
<i class="glyphicon glyphicon-remove-circle"></i> Reset
|
|
|
|
|
</button>
|
|
|
|
|
<button class="btn btn-info btn-sm" id="updateHistory">
|
|
|
|
|
<i class="glyphicon glyphicon-refresh"></i> Update
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-eye-open"></i></span>
|
|
|
|
|
<h5>History</h5>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-content nopadding">
|
|
|
|
|
<table class="table table-log table-hover" id="historyLog">
|
|
|
|
|
<thead>
|
|
|
|
|
<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>
|
|
|
|
|
</thead>
|
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2016-11-14 17:53:33 +01:00
|
|
|
|
<div class="widget-box">
|
|
|
|
|
<div class="widget-title">
|
|
|
|
|
<div class="buttons pull-right">
|
|
|
|
|
<button class="btn btn-info btn-sm" id="updateErrors">
|
|
|
|
|
<i class="glyphicon glyphicon-refresh"></i> Update
|
|
|
|
|
</button>
|
|
|
|
|
</div>
|
|
|
|
|
<span class="icon"><i class="glyphicon glyphicon-eye-open"></i></span>
|
|
|
|
|
<h5>Errors</h5>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="widget-content nopadding">
|
|
|
|
|
<table class="table table-log table-hover" id="errorsLog">
|
|
|
|
|
<thead>
|
|
|
|
|
<th title="Time">Time</th>
|
|
|
|
|
<th title="Worker">Worker</th>
|
|
|
|
|
<th title="PID">PID</th>
|
|
|
|
|
<th title="Module">Module</th>
|
|
|
|
|
<th title="ID">ID</th>
|
|
|
|
|
<th title="Message">Message</th>
|
|
|
|
|
</thead>
|
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<!-- Common modal -->
|
|
|
|
|
<div id="modalDialog" class="modal fade" tabindex="-1" role="dialog" aria-labelledby="modalLabel">
|
|
|
|
|
<div class="modal-dialog">
|
|
|
|
|
<div class="modal-content">
|
|
|
|
|
<div class="modal-header">
|
|
|
|
|
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
|
|
|
|
|
<h3 id="modalTitle"></h3>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-body" id="modalBody">
|
|
|
|
|
<div class="progress progress-striped active">
|
|
|
|
|
<div class="bar" style="width:100%;"></div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-footer">
|
|
|
|
|
<button class="btn btn-default" data-dismiss="modal" aria-hidden="true" id="modalClose">Close</button>
|
|
|
|
|
<button class="btn btn-primary" id="modalSave">Save changes</button>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<!-- login modal -->
|
|
|
|
|
<div id="connectDialog" class="modal" tabindex="-1" role="dialog" aria-labelledby="RSPAMD Connect">
|
|
|
|
|
<div class="modal-dialog">
|
|
|
|
|
<div class="modal-content">
|
|
|
|
|
<div class="modal-header">
|
|
|
|
|
<h3>RSPAMD Connect</h3>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="modal-body" id="connectBody">
|
|
|
|
|
<form id="connectForm">
|
|
|
|
|
<!--
|
|
|
|
|
<div class="form-group">
|
|
|
|
|
<label class="control-label" for="connectHost">Hostname</label>
|
|
|
|
|
<div class="controls">
|
|
|
|
|
<input class=col-md-2" type="text" id="connectHost" placeholder="Hostname" tabindex="1">
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
-->
|
|
|
|
|
<div class="form-group">
|
|
|
|
|
<label class="col-sm-2 control-label" for="connectPassword">Password:</label>
|
|
|
|
|
<div class="col-sm-10">
|
|
|
|
|
<input class="form-control"
|
|
|
|
|
type="password"
|
|
|
|
|
id="connectPassword"
|
|
|
|
|
placeholder="Password"
|
|
|
|
|
tabindex="1" />
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="form-group">
|
|
|
|
|
<button type="submit" id="connectButton" class="btn btn-primary" tabindex="1">Connect</button>
|
|
|
|
|
</div>
|
|
|
|
|
</form>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div id="backDrop" class="modal-backdrop fade in" style="display:none"></div>
|
2016-11-02 17:56:53 +01:00
|
|
|
|
<script src="./js/jquery-3.1.1.min.js"></script>
|
|
|
|
|
<script src="./js/bootstrap.min.js"></script>
|
2016-11-02 17:59:16 +01:00
|
|
|
|
<script src="./js/jquery.cookie.min.js"></script>
|
|
|
|
|
<script src="./js/d3.min.js"></script>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<script src="./js/d3pie.min.js"></script>
|
2016-07-02 22:24:28 +02:00
|
|
|
|
<script src="./js/d3evolution.min.js"></script>
|
2016-06-30 14:02:05 +02:00
|
|
|
|
<script src="./js/humanize.min.js"></script>
|
2016-07-02 22:24:28 +02:00
|
|
|
|
<script src="./js/datatables.min.js"></script>
|
2015-12-31 18:38:02 +01:00
|
|
|
|
<script src="./js/rspamd.js"></script>
|
|
|
|
|
</body>
|
|
|
|
|
</html>
|