From e1b9134d7f9c8e42e5c680fd6abbde97314c49c6 Mon Sep 17 00:00:00 2001
From: halcyon <864072399@qq.com>
Date: Wed, 1 Apr 2015 18:58:10 +0800
Subject: [PATCH] 0402
---
jperm/models.py | 1 +
jperm/urls.py | 2 +-
jperm/views.py | 78 +++++++++++++++-------
jumpserver.conf | 6 ++
jumpserver/settings.py | 7 ++
jumpserver/templatetags/mytags.py | 6 ++
templates/jperm/perm_log_offline.html | 96 +++++++++++++++++++++++++++
templates/jperm/perm_log_online.html | 93 ++++++++++++++++++++++++++
templates/nav.html | 4 +-
9 files changed, 266 insertions(+), 27 deletions(-)
create mode 100644 templates/jperm/perm_log_offline.html
create mode 100644 templates/jperm/perm_log_online.html
diff --git a/jperm/models.py b/jperm/models.py
index 6cfcceb76..a865d005a 100644
--- a/jperm/models.py
+++ b/jperm/models.py
@@ -42,6 +42,7 @@ class Apply(models.Model):
bisgroup = models.CharField(max_length=500)
asset = models.CharField(max_length=500)
comment = models.TextField(blank=True, null=True)
+ status = models.IntegerField(max_length=2)
date_add = models.DateTimeField(default=datetime.datetime.now(), null=True)
date_end = models.DateTimeField(null=True)
diff --git a/jperm/urls.py b/jperm/urls.py
index 9a840afe4..c15807260 100644
--- a/jperm/urls.py
+++ b/jperm/urls.py
@@ -25,5 +25,5 @@ urlpatterns = patterns('jperm.views',
(r'^cmd_del/$', 'cmd_del'),
(r'^cmd_edit/$', 'cmd_edit'),
(r'^apply/$', 'perm_apply'),
- (r'^apply/online/$', 'perm_apply_log'),
+ (r'^apply_show/(\w+)/$', 'perm_apply_log'),
)
diff --git a/jperm/views.py b/jperm/views.py
index 0308af278..e91c8b670 100644
--- a/jperm/views.py
+++ b/jperm/views.py
@@ -1,5 +1,10 @@
# coding: utf-8
+import ast
+import datetime
+
+
+from django.core.mail import send_mail
from django.shortcuts import render_to_response
from django.http import HttpResponseRedirect, HttpResponse
from django.template import RequestContext
@@ -537,6 +542,7 @@ def perm_apply(request):
dept = DEPT.objects.get(id=dept_id)
posts = Asset.objects.filter(dept=dept)
egroup = dept.bisgroup_set.all()
+ mail_address = 'wangyong@fun.tv'
if request.method == 'POST':
applyer = request.POST.get('applyer')
@@ -544,41 +550,65 @@ def perm_apply(request):
group = request.POST.getlist('group')
hosts = request.POST.getlist('hosts')
comment = request.POST.get('comment')
-
- Apply.objects.create(applyer=applyer, dept=dept, bisgroup=group, asset=hosts, comment=comment)
print applyer, dept, group, hosts, comment
+ url = 'http://127.0.0.1:8000/jperm/apply/exec/?id='
+ mail_title = '权限申请'
+ mail_msg = """
+ Hi,%s:
+ 有新的权限申请, 详情如下:
+ 申请人: %s
+ 申请主机组: %s
+ 申请的主机: %s
+ 申请时间: %s
+ 申请说明: %s
+ 请及时审批, 审批完成后点击以下链接,告知各位。
+ %s
+ """ % (u'123', applyer, group, hosts, datetime.datetime.now(), comment, url)
+ send_mail(mail_title, mail_msg, 'jkfunshion@fun.tv', [mail_address], fail_silently=False)
+ smg = "提交成功,已转交运维上线。"
+
+ Apply.objects.create(applyer=applyer, dept=dept, bisgroup=group, asset=hosts, status=0, comment=comment)
return render_to_response('jperm/perm_apply.html', locals(), context_instance=RequestContext(request))
return render_to_response('jperm/perm_apply.html', locals(), context_instance=RequestContext(request))
-def perm_apply_log(request):
+def get_apply_posts(request, status, username, dept_name, keyword=None):
+ if is_super_user(request):
+ if keyword:
+ posts = Apply.objects.filter(Q(applyer__contains=keyword) | Q(approver__contains=keyword)) \
+ .filter(status=status).order_by('-date_add')
+ else:
+ posts = Apply.objects.filter(status=status).order_by('-date_add')
+
+ elif is_group_admin(request):
+ if keyword:
+ posts = Apply.objects.filter(Q(applyer__contains=keyword) | Q(approver__contains=keyword)) \
+ .filter(status=status).filter(dept=dept_name).order_by('-date_add')
+ else:
+ posts = Log.objects.filter(status=status).filter(dept=dept_name).order_by('-date_add')
+
+ elif is_common_user(request):
+ if keyword:
+ posts = Apply.objects.filter(applyer=username).filter(status=status).filter(Q(applyer__contains=keyword) |
+ Q(asset__contains=keyword)).order_by('-date_add')
+ else:
+ posts = Apply.objects.filter(applyer=username).filter(status=status).order_by('-date_add')
+ return posts
+
+
+def perm_apply_log(request, offset):
header_title, path1, path2 = u'权限申请记录', u'权限管理', u'申请记录'
keyword = request.GET.get('keyword')
dept_id = get_user_dept(request)
dept_name = DEPT.objects.get(id=dept_id).name
user_id = request.session.get('user_id')
username = User.objects.get(id=user_id).username
- if is_super_user(request):
- if keyword:
- posts = Log.objects.filter(Q(user__contains=keyword) | Q(host__contains=keyword)) \
- .filter(is_finished=1).order_by('-start_time')
- else:
- posts = Log.objects.filter(is_finished=1).order_by('-start_time')
+ if offset == 'online':
+ posts = get_apply_posts(request, 0, username, dept_name, keyword)
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request)
+ return render_to_response('jperm/perm_log_online.html', locals(), context_instance=RequestContext(request))
- elif is_group_admin(request):
- if keyword:
- posts = Log.objects.filter(Q(user__contains=keyword) | Q(host__contains=keyword)) \
- .filter(is_finished=1).filter(dept_name=dept_name).order_by('-start_time')
- else:
- posts = Log.objects.filter(is_finished=1).filter(dept_name=dept_name).order_by('-start_time')
+ elif offset == 'offline':
+ posts = get_apply_posts(request, 1, username, dept_name, keyword)
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request)
-
- elif is_common_user(request):
- if keyword:
- posts = Apply.objects.filter(applyer=username).filter(Q(applyer__contains=keyword) | Q(asset__contains=keyword))\
- .order_by('-date_add')
- else:
- posts = Apply.objects.filter(applyer=username).order_by('-date_add')
- contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request)
- return render_to_response('jperm/perm_log.html', locals(), context_instance=RequestContext(request))
+ return render_to_response('jperm/perm_log_offline.html', locals(), context_instance=RequestContext(request))
diff --git a/jumpserver.conf b/jumpserver.conf
index 8de09fc8b..95250fbea 100644
--- a/jumpserver.conf
+++ b/jumpserver.conf
@@ -20,3 +20,9 @@ web_socket_host = 127.0.0.1:3000
[web]
key = 88aaaf7ffe3c6c04
+[mail]
+email_host = 'mail.funshion.com'
+email_port = '25'
+email_host_user = 'jkfunshion'
+email_host_password = 'jkmail%'
+email_use_tls = False
\ No newline at end of file
diff --git a/jumpserver/settings.py b/jumpserver/settings.py
index 489577dc1..db905dfde 100644
--- a/jumpserver/settings.py
+++ b/jumpserver/settings.py
@@ -121,3 +121,10 @@ USE_TZ = False
STATIC_URL = '/static/'
+# mail config
+EMAIL_HOST = config.get('mail', 'email_host')
+EMAIL_PORT = config.get('mail', 'email_port')
+EMAIL_HOST_USER = config.get('mail', 'email_host_user')
+EMAIL_HOST_PASSWORD = config.get('mail', 'email_host_password')
+EMAIL_USE_TLS = config.get('mail', 'email_use_tls')
+
diff --git a/jumpserver/templatetags/mytags.py b/jumpserver/templatetags/mytags.py
index 1f264f4e4..b414dfc3d 100644
--- a/jumpserver/templatetags/mytags.py
+++ b/jumpserver/templatetags/mytags.py
@@ -1,6 +1,7 @@
# coding: utf-8
import re
+import ast
import time
from django import template
@@ -160,6 +161,11 @@ def group_type_to_str(type_name):
return group_types.get(type_name)
+@register.filter(name='ast_to_list')
+def ast_to_list(lis):
+ return ast.literal_eval(lis)
+
+
# @register.filter(name='perm_asset_count')
# def perm_asset_count(user_id):
# return len(perm_user_asset(user_id))
diff --git a/templates/jperm/perm_log_offline.html b/templates/jperm/perm_log_offline.html
new file mode 100644
index 000000000..6839d32ab
--- /dev/null
+++ b/templates/jperm/perm_log_offline.html
@@ -0,0 +1,96 @@
+{% extends 'base.html' %}
+{% load mytags %}
+{% block content %}
+{% include 'nav_cat_bar.html' %}
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 申请人 |
+ 所属部门 |
+ 申请主机组 |
+ 申请主机 |
+ 批准人 |
+ 申请时间 |
+ 批准时间 |
+ 备注 |
+
+
+
+
+ {% for post in contacts.object_list %}
+
+ {{ post.applyer }} |
+ {{ post.dept }} |
+ {% for i in post.bisgroup|ast_to_list %} {{ i }} {% endfor %} |
+ {% for i in post.asset|ast_to_list %} {{ i }} {% endfor %} |
+ {{ post.approver }} |
+
+
+
+ {{ post.date_add|date:"Y-m-d H:i:s"}} |
+ {{ post.date_end|date:"Y-m-d H:i:s" }} |
+ {{ post.comment }} |
+
+ {% endfor %}
+
+
+
+
+
+ {% include 'paginator.html' %}
+
+
+
+
+
+
+
+
+{% endblock %}
\ No newline at end of file
diff --git a/templates/jperm/perm_log_online.html b/templates/jperm/perm_log_online.html
new file mode 100644
index 000000000..cae9b204e
--- /dev/null
+++ b/templates/jperm/perm_log_online.html
@@ -0,0 +1,93 @@
+{% extends 'base.html' %}
+{% block content %}
+{% include 'nav_cat_bar.html' %}
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 申请人 |
+ 所属部门 |
+ 申请主机组 |
+ 申请主机 |
+ 申请时间 |
+ 批准时间 |
+ 备注 |
+
+
+
+
+ {% for post in contacts.object_list %}
+
+ {{ post.applyer }} |
+ {{ post.dept }} |
+ {{ post.bisgroup }} |
+ {{ post.asset }} |
+
+
+
+ {{ post.date_add|date:"Y-m-d H:i:s"}} |
+ {{ post.date_end|date:"Y-m-d H:i:s" }} |
+ {{ post.comment }} |
+
+ {% endfor %}
+
+
+
+
+
+ {% include 'paginator.html' %}
+
+
+
+
+
+
+
+
+{% endblock %}
\ No newline at end of file
diff --git a/templates/nav.html b/templates/nav.html
index 93cb66523..745c07d5e 100644
--- a/templates/nav.html
+++ b/templates/nav.html
@@ -143,8 +143,8 @@
权限申请