2015-01-25 14:20:07 +00:00
|
|
|
{% extends 'base.html' %}
|
|
|
|
{% block content %}
|
|
|
|
{% include 'nav_cat_bar.html' %}
|
|
|
|
<style>
|
2015-02-01 15:00:23 +00:00
|
|
|
.bootstrap-dialog-body {
|
|
|
|
background-color: rgba(0, 0, 0, 0);
|
|
|
|
}
|
|
|
|
.bootstrap-dialog-message {
|
|
|
|
background-color: rgba(0, 0, 0, 0);
|
|
|
|
}
|
|
|
|
.modal-content {
|
|
|
|
background-color: rgba(0, 0, 0, 0.6);
|
|
|
|
}
|
2015-01-25 14:20:07 +00:00
|
|
|
.modal-dialog {
|
2015-02-01 15:00:23 +00:00
|
|
|
background-color: rgba(0, 0, 0, 0);
|
2015-01-25 14:20:07 +00:00
|
|
|
width: 800px;
|
|
|
|
}
|
|
|
|
.modal-body {
|
2015-02-01 15:00:23 +00:00
|
|
|
background-color: rgba(0, 0, 0, 0);
|
|
|
|
}
|
|
|
|
.modal-header {
|
|
|
|
background-color: #FFFFFF;
|
2015-01-25 14:20:07 +00:00
|
|
|
}
|
|
|
|
</style>
|
|
|
|
|
|
|
|
<div class="wrapper wrapper-content animated fadeInRight">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-lg-12">
|
2015-02-01 15:00:23 +00:00
|
|
|
<div class="ibox float-e-margins">
|
|
|
|
<div id="ibox-content" class="ibox-title">
|
|
|
|
<h5> 用户日志详细信息列表 </h5>
|
|
|
|
<div class="ibox-tools">
|
|
|
|
<a class="collapse-link">
|
|
|
|
<i class="fa fa-chevron-up"></i>
|
|
|
|
</a>
|
|
|
|
<a class="dropdown-toggle" data-toggle="dropdown" href="#">
|
|
|
|
<i class="fa fa-wrench"></i>
|
|
|
|
</a>
|
|
|
|
<ul class="dropdown-menu dropdown-user">
|
|
|
|
<li><a href="#">未启用 1</a>
|
|
|
|
</li>
|
|
|
|
<li><a href="#">未启用 2</a>
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
<a class="close-link">
|
|
|
|
<i class="fa fa-times"></i>
|
|
|
|
</a>
|
|
|
|
</div>
|
2015-01-25 14:20:07 +00:00
|
|
|
</div>
|
|
|
|
|
2015-02-01 15:00:23 +00:00
|
|
|
<div class="ibox-content">
|
|
|
|
<div class="panel blank-panel">
|
|
|
|
<div class="panel-options">
|
|
|
|
<ul class="nav nav-tabs">
|
|
|
|
<li class="active"><a data-toggle="tab" href="#tab-1" class="text-center" onclick='log_fresh'><i class="fa fa-laptop"></i> 在线 </a></li>
|
|
|
|
<li><a data-toggle="tab" href="#tab-2" class="text-center" onclick='log_fresh'><i class="fa fa-bar-chart-o"></i> 历史记录 </a></li>
|
|
|
|
</ul>
|
2015-01-25 14:20:07 +00:00
|
|
|
</div>
|
2015-02-01 15:00:23 +00:00
|
|
|
<div class="panel-body">
|
|
|
|
<div class="tab-content">
|
|
|
|
<div id="tab-1" class="ibox float-e-margins tab-pane active">
|
|
|
|
<table class="table table-striped table-bordered table-hover ">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th class="text-center"> 用户名 </th>
|
|
|
|
<th class="text-center"> 登录主机 </th>
|
|
|
|
<th class="text-center"> 实时监控 </th>
|
|
|
|
<th class="text-center"> 阻断 </th>
|
|
|
|
<th class="text-center"> 登录时间 </th>
|
|
|
|
<th class="text-center"> 结束时间 </th>
|
|
|
|
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{% for post in online %}
|
|
|
|
<tr class="gradeX">
|
|
|
|
<td id="username" class="text-center"> {{ post.user.name }} </td>
|
|
|
|
<td id="ip" class="text-center"> {{ post.asset.ip }} </td>
|
|
|
|
<td class="text-center"><a class="monitor" filename="{{ post.log_path }}"> 监控 </a></td>
|
|
|
|
<td class="text-center"><input type="button" id="cut" class="btn btn-danger btn-xs" name="cut" value="阻断" onclick='cut("{{ post.pid }}")' /></td>
|
|
|
|
<td class="text-center"> {{ post.start_time|date:"Y-m-d H:i:s" }} </td>
|
|
|
|
<td class="text-center"> {{ post.end_time|date:"Y-m-d H:i:s" }} </td>
|
|
|
|
</tr>
|
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
<div id="tab-2" class="ibox float-e-margins tab-pane">
|
|
|
|
<table class="table table-striped table-bordered table-hover ">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th class="text-center"> 用户名 </th>
|
|
|
|
<th class="text-center"> 登录主机 </th>
|
|
|
|
<th class="text-center"> 命令统计 </th>
|
|
|
|
<th class="text-center"> 登录时间 </th>
|
|
|
|
<th class="text-center"> 结束时间 </th>
|
2015-01-25 14:20:07 +00:00
|
|
|
|
2015-02-01 15:00:23 +00:00
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{% for post in offline %}
|
|
|
|
<tr class="gradeX">
|
|
|
|
<td class="text-center"> {{ post.user.name }} </td>
|
|
|
|
<td class="text-center"> {{ post.asset.ip }} </td>
|
|
|
|
<td class="text-center"> 命令统计 </td>
|
|
|
|
<td class="text-center"> {{ post.start_time|date:"Y-m-d H:i:s"}} </td>
|
|
|
|
<td class="text-center"> {{ post.end_time|date:"Y-m-d H:i:s" }} </td>
|
|
|
|
</tr>
|
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
</div>
|
2015-01-25 14:20:07 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<script src="http://{{ web_socket_host }}/socket.io/socket.io.js"></script>
|
|
|
|
<script>
|
|
|
|
$.fn.webSocket = function(opt){
|
|
|
|
var st = {};
|
|
|
|
st = $.extend(st,opt);
|
|
|
|
var message = {};
|
|
|
|
var $this = $(this);
|
|
|
|
var genUid = function(){
|
|
|
|
return new Date().getTime()+""+Math.floor(Math.random()*899+100);
|
|
|
|
};
|
|
|
|
var init = function(e){
|
|
|
|
var socket = io.connect('ws://'+globalConfig.SOCKET_HOST);
|
|
|
|
var node = $(e.target);
|
|
|
|
message.id = genUid();
|
|
|
|
message.filename = node.attr('filename');
|
2015-02-01 15:00:23 +00:00
|
|
|
var username = $('#username')[0].innerText;
|
|
|
|
var ip = $('#ip')[0].innerText;
|
2015-01-25 14:20:07 +00:00
|
|
|
BootstrapDialog.show({message:function(){
|
|
|
|
var escapeString = function (html){
|
|
|
|
var elem = document.createElement('div')
|
|
|
|
var txt = document.createTextNode(html)
|
|
|
|
elem.appendChild(txt)
|
|
|
|
return elem.innerHTML;
|
|
|
|
}
|
2015-02-01 15:00:23 +00:00
|
|
|
var tag = $('<div id="log" style="height: 500px;overflow: auto;background-color: rgba(0, 0, 0, 0);"></div>');
|
2015-01-25 14:20:07 +00:00
|
|
|
//告诉服务器端有用户登录
|
|
|
|
socket.emit('login', {userid:message.id, filename:message.filename});
|
|
|
|
socket.on('message',function(obj){
|
|
|
|
//去除log中的颜色控制字符
|
|
|
|
var regx = /\x1B\[([0-9]{1,3}((;[0-9]{1,3})*)?)?[m|K]/g;
|
|
|
|
// tag.append('<p>'+escapeString(obj.content.replace(regx,''))+'</p>');
|
|
|
|
tag.append('<p>'+escapeString(obj.content)+'</p>');
|
|
|
|
tag.animate({ scrollTop: tag[0].scrollHeight}, 1);
|
|
|
|
});
|
|
|
|
tag[0].style.color = "#00FF00";
|
|
|
|
return tag[0];
|
|
|
|
} ,
|
2015-02-01 15:00:23 +00:00
|
|
|
title:'Jumpserver实时监控 '+' 登录用户名: '+'<span class="text-info">'+username+'</span>'+' 登录主机: '+'<span class="text-info">'+ip,
|
2015-01-25 14:20:07 +00:00
|
|
|
onhide:function(){
|
|
|
|
socket.emit('disconnect');
|
|
|
|
}});
|
|
|
|
}
|
|
|
|
$this.on("click",function(e){
|
|
|
|
init(e);
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
$('.log_command').on('click',function(){
|
|
|
|
var url = $(this).attr('href');
|
|
|
|
$.ajax({url:url,success:function(data){
|
|
|
|
BootstrapDialog.show({title:'命令统计',message:data});
|
|
|
|
}});
|
|
|
|
return false;
|
|
|
|
})
|
|
|
|
globalConfig = {
|
|
|
|
SOCKET_HOST: "{{ web_socket_host }}"
|
|
|
|
}
|
|
|
|
$(".monitor").webSocket()
|
2015-02-01 15:00:23 +00:00
|
|
|
|
|
|
|
// function log_fresh(str){
|
|
|
|
// $.ajax({
|
|
|
|
// type: "GET",
|
|
|
|
// url: "/jlog/log_list/",
|
|
|
|
// data : $(".panel-body").serialize(),
|
|
|
|
// success: function(data){
|
|
|
|
// $("#tab-1").html(data);
|
|
|
|
// }
|
|
|
|
// });
|
|
|
|
|
|
|
|
function cut(num){
|
|
|
|
var g_url = "/jlog/log_kill/"+num;
|
|
|
|
console.log(g_url);
|
|
|
|
$.ajax({
|
|
|
|
type: "GET",
|
|
|
|
url: g_url,
|
|
|
|
success: window.open("/jlog/","_self")
|
|
|
|
});
|
|
|
|
}
|
2015-01-25 14:20:07 +00:00
|
|
|
</script>
|
|
|
|
{% endblock %}
|