# coding:utf-8 import os import ConfigParser from datetime import datetime from django.db.models import Q from django.http import HttpResponse from django.http import HttpResponseRedirect from django.shortcuts import render_to_response from connect import BASE_DIR from jlog.models import Log from jumpserver.views import pages CONF = ConfigParser.ConfigParser() CONF.read('%s/jumpserver.conf' % BASE_DIR) def log_list_online(request): header_title, path1, path2 = u'查看日志', u'查看日志', u'在线用户' web_socket_host = CONF.get('websocket', 'web_socket_host') posts = Log.objects.filter(is_finished=0).order_by('-start_time') contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request) return render_to_response('jlog/log_online.html', locals()) def log_list_offline(request): header_title, path1, path2 = u'查看日志', u'查看日志', u'历史记录' web_socket_host = CONF.get('websocket', 'web_socket_host') posts = Log.objects.filter(is_finished=1).order_by('-start_time') contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request) return render_to_response('jlog/log_offline.html', locals()) def log_kill(request, offset): pid = offset if pid: os.kill(int(pid), 9) Log.objects.filter(pid=pid).update(is_finished=1, end_time=datetime.now()) return HttpResponseRedirect('jlog/log_offline.html', locals()) def log_history(request): if request.method == 'GET': id = request.GET.get('id', 0) log = Log.objects.get(id=int(id)) if log: log_his = "%s.his" % log.log_path if os.path.isfile(log_his): f = open(log_his) content = f.read() return HttpResponse(content) def log_search(request): keyword = request.GET.get('keyword') env = request.GET.get('env') if env == 'online': posts = contact_list = Log.objects.filter(Q(user__contains=keyword) | Q(host__contains=keyword)) \ .filter(is_finished=0).order_by('-start_time') contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request) elif env == 'offline': posts = contact_list = Log.objects.filter(Q(user__contains=keyword) | Q(host__contains=keyword)) \ .filter(is_finished=1).order_by('-start_time') contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request) return render_to_response('jlog/log_search.html', locals())