jumpserver/jperm/views.py

830 lines
32 KiB
Python
Raw Normal View History

2015-01-21 15:28:56 +00:00
# coding: utf-8
2015-04-02 10:32:43 +00:00
import sys
reload(sys)
sys.setdefaultencoding('utf8')
2015-04-01 10:58:10 +00:00
2015-01-21 15:22:21 +00:00
from django.shortcuts import render_to_response
2015-02-27 14:14:09 +00:00
from django.template import RequestContext
2015-03-26 10:42:52 +00:00
from jperm.models import Perm, SudoPerm, CmdGroup, Apply
2015-02-09 00:40:54 +00:00
from django.db.models import Q
2015-03-14 09:54:17 +00:00
from jumpserver.api import *
2015-01-24 06:36:58 +00:00
2015-03-25 10:45:55 +00:00
def asset_cmd_groups_get(asset_groups_select='', cmd_groups_select=''):
2015-02-11 10:38:56 +00:00
asset_groups_select_list = []
cmd_groups_select_list = []
for asset_group_id in asset_groups_select:
2015-03-25 10:45:55 +00:00
asset_groups_select_list.extend(BisGroup.objects.filter(id=asset_group_id))
2015-02-11 10:38:56 +00:00
for cmd_group_id in cmd_groups_select:
2015-03-25 10:45:55 +00:00
cmd_groups_select_list.extend(CmdGroup.objects.filter(id=cmd_group_id))
2015-02-11 10:38:56 +00:00
2015-03-25 10:45:55 +00:00
return asset_groups_select_list, cmd_groups_select_list
2015-02-11 10:38:56 +00:00
2015-03-12 16:09:18 +00:00
@require_admin
2015-02-11 10:38:56 +00:00
def perm_add(request):
2015-03-11 09:59:15 +00:00
header_title, path1, path2 = u'主机授权添加', u'授权管理', u'授权添加'
2015-02-11 10:38:56 +00:00
if request.method == 'GET':
2015-03-05 16:24:17 +00:00
user_groups = UserGroup.objects.filter(id__gt=2)
2015-02-11 10:38:56 +00:00
asset_groups = BisGroup.objects.all()
else:
name = request.POST.get('name', '')
user_groups_select = request.POST.getlist('user_groups_select')
asset_groups_select = request.POST.getlist('asset_groups_select')
comment = request.POST.get('comment', '')
user_groups, asset_groups = user_asset_cmd_groups_get(user_groups_select, asset_groups_select, '')[0:2]
perm = Perm(name=name, comment=comment)
perm.save()
perm.user_group = user_groups
perm.asset_group = asset_groups
msg = '添加成功'
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/perm_add.html', locals(), context_instance=RequestContext(request))
2015-02-11 10:38:56 +00:00
2015-03-11 15:46:35 +00:00
def dept_add_asset(dept_id, asset_list):
dept = DEPT.objects.filter(id=dept_id)
if dept:
dept = dept[0]
new_perm_asset = []
for asset_id in asset_list:
asset = Asset.objects.filter(id=asset_id)
new_perm_asset.extend(asset)
2015-03-14 09:54:17 +00:00
dept.asset_set.clear()
dept.asset_set = new_perm_asset
2015-03-11 09:59:15 +00:00
2015-03-12 16:09:18 +00:00
@require_super_user
2015-03-11 09:59:15 +00:00
def dept_perm_edit(request):
header_title, path1, path2 = u'部门授权添加', u'授权管理', u'部门授权添加'
2015-03-11 15:46:35 +00:00
if request.method == 'GET':
dept_id = request.GET.get('id', '')
dept = DEPT.objects.filter(id=dept_id)
if dept:
dept = dept[0]
asset_all = Asset.objects.all()
2015-03-14 09:54:17 +00:00
asset_select = dept.asset_set.all()
2015-03-11 15:46:35 +00:00
assets = [asset for asset in asset_all if asset not in asset_select]
else:
dept_id = request.POST.get('dept_id')
2015-03-11 09:59:15 +00:00
asset_select = request.POST.getlist('asset_select')
2015-03-11 15:46:35 +00:00
dept_add_asset(dept_id, asset_select)
return HttpResponseRedirect('/jperm/dept_perm_list/')
2015-03-11 09:59:15 +00:00
return render_to_response('jperm/dept_perm_edit.html', locals(), context_instance=RequestContext(request))
2015-03-23 14:57:19 +00:00
@require_super_user
2015-03-05 16:24:17 +00:00
def perm_list(request):
2015-03-11 15:46:35 +00:00
header_title, path1, path2 = u'小组授权', u'授权管理', u'授权详情'
2015-03-06 16:12:38 +00:00
keyword = request.GET.get('search', '')
if keyword:
2015-03-11 15:46:35 +00:00
contact_list = UserGroup.objects.filter(Q(name__icontains=keyword) | Q(comment__icontains=keyword))
2015-03-06 16:12:38 +00:00
else:
2015-03-11 15:46:35 +00:00
contact_list = UserGroup.objects.all().order_by('name')
2015-03-07 10:25:31 +00:00
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(contact_list, request)
2015-03-05 16:24:17 +00:00
return render_to_response('jperm/perm_list.html', locals(), context_instance=RequestContext(request))
2015-03-23 14:57:19 +00:00
@require_admin
def perm_list_adm(request):
header_title, path1, path2 = u'小组授权', u'授权管理', u'授权详情'
keyword = request.GET.get('search', '')
user, dept = get_session_user_dept(request)
contact_list = dept.usergroup_set.all().order_by('name')
if keyword:
contact_list = contact_list.filter(Q(name__icontains=keyword) | Q(comment__icontains=keyword))
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(contact_list, request)
return render_to_response('jperm/perm_list.html', locals(), context_instance=RequestContext(request))
2015-03-12 16:09:18 +00:00
@require_super_user
2015-03-11 09:59:15 +00:00
def dept_perm_list(request):
header_title, path1, path2 = '查看部门', '授权管理', '部门授权'
keyword = request.GET.get('search')
if keyword:
contact_list = DEPT.objects.filter(Q(name__icontains=keyword) | Q(comment__icontains=keyword)).order_by('name')
else:
2015-04-15 04:07:59 +00:00
contact_list = DEPT.objects.filter(id__gt=2)
2015-03-11 09:59:15 +00:00
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(contact_list, request)
return render_to_response('jperm/dept_perm_list.html', locals(), context_instance=RequestContext(request))
2015-03-06 16:12:38 +00:00
2015-03-12 10:43:17 +00:00
def perm_group_update(user_group_id, asset_groups_id_list):
user_group = UserGroup.objects.filter(id=user_group_id)
if user_group:
user_group = user_group[0]
old_asset_group = [perm.asset_group for perm in user_group.perm_set.all()]
new_asset_group = []
2015-02-03 15:03:51 +00:00
2015-03-06 16:12:38 +00:00
for asset_group_id in asset_groups_id_list:
2015-03-12 10:43:17 +00:00
new_asset_group.extend(BisGroup.objects.filter(id=asset_group_id))
del_asset_group = [asset_group for asset_group in old_asset_group if asset_group not in new_asset_group]
add_asset_group = [asset_group for asset_group in new_asset_group if asset_group not in old_asset_group]
2015-02-03 15:03:51 +00:00
2015-03-12 10:43:17 +00:00
for asset_group in del_asset_group:
Perm.objects.filter(user_group=user_group, asset_group=asset_group).delete()
for asset_group in add_asset_group:
Perm(user_group=user_group, asset_group=asset_group).save()
2015-02-03 15:03:51 +00:00
2015-03-12 16:09:18 +00:00
@require_super_user
2015-01-28 16:53:15 +00:00
def perm_edit(request):
2015-01-21 15:56:18 +00:00
if request.method == 'GET':
2015-03-05 16:24:17 +00:00
header_title, path1, path2 = u'编辑授权', u'授权管理', u'授权编辑'
2015-03-12 10:43:17 +00:00
user_group_id = request.GET.get('id', '')
user_group = UserGroup.objects.filter(id=user_group_id)
if user_group:
user_group = user_group[0]
2015-02-11 10:38:56 +00:00
asset_groups_all = BisGroup.objects.all()
2015-03-12 10:43:17 +00:00
asset_groups_select = [perm.asset_group for perm in user_group.perm_set.all()]
2015-02-11 10:38:56 +00:00
asset_groups = [asset_group for asset_group in asset_groups_all if asset_group not in asset_groups_select]
2015-01-21 15:56:18 +00:00
else:
2015-03-12 10:43:17 +00:00
user_group_id = request.POST.get('user_group_id')
2015-03-06 16:12:38 +00:00
asset_group_id_list = request.POST.getlist('asset_groups_select')
2015-03-12 10:43:17 +00:00
perm_group_update(user_group_id, asset_group_id_list)
2015-03-06 16:12:38 +00:00
return HttpResponseRedirect('/jperm/perm_list/')
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/perm_edit.html', locals(), context_instance=RequestContext(request))
2015-01-28 16:53:15 +00:00
2015-03-23 14:57:19 +00:00
@require_admin
def perm_edit_adm(request):
if request.method == 'GET':
header_title, path1, path2 = u'编辑授权', u'授权管理', u'授权编辑'
user_group_id = request.GET.get('id', '')
user_group = UserGroup.objects.filter(id=user_group_id)
user, dept = get_session_user_dept(request)
if user_group:
user_group = user_group[0]
asset_groups_all = dept.bisgroup_set.all()
asset_groups_select = [perm.asset_group for perm in user_group.perm_set.all()]
asset_groups = [asset_group for asset_group in asset_groups_all if asset_group not in asset_groups_select]
else:
user_group_id = request.POST.get('user_group_id')
asset_group_id_list = request.POST.getlist('asset_groups_select')
if not validate(request, user_group=[user_group_id], asset_group=asset_group_id_list):
return HttpResponseRedirect('/jperm/perm_list/')
perm_group_update(user_group_id, asset_group_id_list)
return HttpResponseRedirect('/jperm/perm_list/')
return render_to_response('jperm/perm_edit.html', locals(), context_instance=RequestContext(request))
2015-03-12 16:09:18 +00:00
@require_admin
2015-01-30 06:54:45 +00:00
def perm_detail(request):
2015-03-05 16:24:17 +00:00
header_title, path1, path2 = u'编辑授权', u'授权管理', u'授权详情'
2015-02-11 15:32:24 +00:00
perm_id = request.GET.get('id')
perm = Perm.objects.filter(id=perm_id)
if perm:
perm = perm[0]
user_groups = perm.user_group.all()
asset_groups = perm.asset_group.all()
users_list = []
assets_list = []
for user_group in user_groups:
users_list.extend(user_group.user_set.all())
for asset_group in asset_groups:
assets_list.extend(asset_group.asset_set.all())
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/perm_detail.html', locals(), context_instance=RequestContext(request))
2015-01-30 06:54:45 +00:00
2015-03-12 16:09:18 +00:00
@require_admin
2015-01-30 06:54:45 +00:00
def perm_del(request):
2015-02-11 15:32:24 +00:00
perm_id = request.GET.get('id')
perm = Perm.objects.filter(id=perm_id)
if perm:
perm = perm[0]
perm.delete()
2015-01-30 06:54:45 +00:00
return HttpResponseRedirect('/jperm/perm_list/')
2015-03-12 16:09:18 +00:00
@require_admin
2015-01-30 08:39:34 +00:00
def perm_asset_detail(request):
2015-03-05 16:24:17 +00:00
header_title, path1, path2 = u'用户授权主机', u'权限管理', u'用户主机详情'
2015-01-30 08:39:34 +00:00
user_id = request.GET.get('id')
2015-02-12 16:00:07 +00:00
user = User.objects.filter(id=user_id)
if user:
user = user[0]
2015-03-07 09:37:26 +00:00
assets_list = user_perm_asset_api(user.username)
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/perm_asset_detail.html', locals(), context_instance=RequestContext(request))
2015-01-30 08:39:34 +00:00
2015-01-30 06:54:45 +00:00
2015-03-25 10:45:55 +00:00
# def sudo_db_add(name, user_runas, user_groups_select, asset_groups_select, cmd_groups_select, comment):
# user_groups_select_list, asset_groups_select_list, cmd_groups_select_list = \
# user_asset_cmd_groups_get(user_groups_select, asset_groups_select, cmd_groups_select)
#
# sudo_perm = SudoPerm(name=name, user_runas=user_runas, comment=comment)
# sudo_perm.save()
# sudo_perm.user_group = user_groups_select_list
# sudo_perm.asset_group = asset_groups_select_list
# sudo_perm.cmd_group = cmd_groups_select_list
2015-02-09 10:50:21 +00:00
def unicode2str(unicode_list):
return [str(i) for i in unicode_list]
2015-03-25 10:45:55 +00:00
def sudo_ldap_add(user_group, user_runas, asset_groups_select,
cmd_groups_select):
2015-02-09 00:40:54 +00:00
2015-03-15 15:23:20 +00:00
if not LDAP_ENABLE:
return True
2015-02-09 10:50:21 +00:00
assets = []
cmds = []
2015-03-25 10:45:55 +00:00
user_runas = user_runas.split(',')
if len(asset_groups_select) == 1 and asset_groups_select[0].name == 'ALL':
asset_all = True
else:
asset_all = False
for asset_group in asset_groups_select:
2015-02-10 10:53:01 +00:00
assets.extend(asset_group.asset_set.all())
2015-02-09 10:50:21 +00:00
2015-03-25 10:45:55 +00:00
if user_group.name == 'ALL':
user_all = True
users = []
else:
user_all = False
users = user_group.user_set.all()
for cmd_group in cmd_groups_select:
2015-02-09 10:50:21 +00:00
cmds.extend(cmd_group.cmd.split(','))
2015-03-25 10:45:55 +00:00
if user_all:
users_name = ['ALL']
else:
users_name = list(set([user.username for user in users]))
2015-02-10 10:53:01 +00:00
if asset_all:
assets_ip = ['ALL']
else:
2015-03-25 10:45:55 +00:00
assets_ip = list(set([asset.ip for asset in assets]))
2015-02-09 10:50:21 +00:00
2015-03-25 10:45:55 +00:00
name = 'sudo%s' % user_group.id
2015-02-09 10:50:21 +00:00
sudo_dn = 'cn=%s,ou=Sudoers,%s' % (name, LDAP_BASE_DN)
sudo_attr = {'objectClass': ['top', 'sudoRole'],
2015-03-25 10:45:55 +00:00
'cn': ['%s' % name],
2015-02-09 10:50:21 +00:00
'sudoCommand': unicode2str(cmds),
'sudoHost': unicode2str(assets_ip),
'sudoOption': ['!authenticate'],
2015-03-25 10:45:55 +00:00
'sudoRunAsUser': unicode2str(user_runas),
2015-02-09 10:50:21 +00:00
'sudoUser': unicode2str(users_name)}
2015-03-25 10:45:55 +00:00
print sudo_dn
ldap_conn.delete(sudo_dn)
2015-02-09 10:50:21 +00:00
ldap_conn.add(sudo_dn, sudo_attr)
2015-02-09 00:40:54 +00:00
2015-03-25 10:45:55 +00:00
def sudo_update(user_group, user_runas, asset_groups_select, cmd_groups_select, comment):
asset_groups_select_list, cmd_groups_select_list = \
asset_cmd_groups_get(asset_groups_select, cmd_groups_select)
sudo_perm = user_group.sudoperm_set.all()
if sudo_perm:
sudo_perm.update(user_runas=user_runas, comment=comment)
sudo_perm = sudo_perm[0]
sudo_perm.asset_group = asset_groups_select_list
sudo_perm.cmd_group = cmd_groups_select_list
else:
sudo_perm = SudoPerm(user_group=user_group, user_runas=user_runas, comment=comment)
sudo_perm.save()
sudo_perm.asset_group = asset_groups_select_list
sudo_perm.cmd_group = cmd_groups_select_list
2015-03-23 14:57:19 +00:00
2015-03-25 10:45:55 +00:00
sudo_ldap_add(user_group, user_runas, asset_groups_select_list, cmd_groups_select_list)
# @require_super_user
# def sudo_add(request):
# header_title, path1, path2 = u'Sudo授权', u'权限管理', u'添加Sudo权限'
# user_groups = UserGroup.objects.filter(id__gt=2)
# asset_groups = BisGroup.objects.all()
# cmd_groups = CmdGroup.objects.all()
#
# if request.method == 'POST':
# name = request.POST.get('name')
# users_runas = request.POST.get('runas', 'root')
# user_groups_select = request.POST.getlist('user_groups_select')
# asset_groups_select = request.POST.getlist('asset_groups_select')
# cmd_groups_select = request.POST.getlist('cmd_groups_select')
# comment = request.POST.get('comment', '')
#
# if LDAP_ENABLE:
# sudo_db_add(name, users_runas, user_groups_select, asset_groups_select, cmd_groups_select, comment)
# sudo_ldap_add(name, users_runas, user_groups_select, asset_groups_select, cmd_groups_select)
#
# msg = '添加成功'
# return render_to_response('jperm/sudo_add.html', locals(), context_instance=RequestContext(request))
# @require_admin
# def sudo_add_adm(request):
# header_title, path1, path2 = u'Sudo授权', u'权限管理', u'添加Sudo权限'
# user, dept = get_session_user_dept(request)
# user_groups = dept.usergroup_set.filter(id__gt=2)
# asset_groups = dept.bisgroup_set.all()
# cmd_groups = CmdGroup.objects.all()
#
# if request.method == 'POST':
# name = request.POST.get('name')
# users_runas = request.POST.get('runas', 'root')
# user_groups_select = request.POST.getlist('user_groups_select')
# asset_groups_select = request.POST.getlist('asset_groups_select')
# cmd_groups_select = request.POST.getlist('cmd_groups_select')
# comment = request.POST.get('comment', '')
#
# if LDAP_ENABLE:
# sudo_db_add(name, users_runas, user_groups_select, asset_groups_select, cmd_groups_select, comment)
# sudo_ldap_add(name, users_runas, user_groups_select, asset_groups_select, cmd_groups_select)
#
# msg = '添加成功'
# return render_to_response('jperm/sudo_add.html', locals(), context_instance=RequestContext(request))
2015-03-23 14:57:19 +00:00
2015-03-27 10:37:10 +00:00
@require_super_user
2015-02-06 16:07:07 +00:00
def sudo_list(request):
2015-03-05 16:24:17 +00:00
header_title, path1, path2 = u'Sudo授权', u'权限管理', u'Sudo权限详情'
2015-03-25 10:45:55 +00:00
keyword = request.GET.get('search', '')
2015-03-27 10:37:10 +00:00
contact_list = UserGroup.objects.all().order_by('name')
2015-03-25 10:45:55 +00:00
if keyword:
2015-03-27 10:37:10 +00:00
contact_list = contact_list.filter(Q(name__icontains=keyword) | Q(comment__icontains=keyword))
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(contact_list, request)
return render_to_response('jperm/sudo_list.html', locals(), context_instance=RequestContext(request))
@require_admin
def sudo_list_adm(request):
header_title, path1, path2 = u'Sudo授权', u'权限管理', u'Sudo权限详情'
keyword = request.GET.get('search', '')
user, dept = get_session_user_dept(request)
contact_list = dept.usergroup_set.all().order_by('name')
if keyword:
contact_list = contact_list.filter(Q(name__icontains=keyword) | Q(comment__icontains=keyword))
2015-02-06 16:07:07 +00:00
2015-03-07 10:25:31 +00:00
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(contact_list, request)
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/sudo_list.html', locals(), context_instance=RequestContext(request))
2015-02-06 16:07:07 +00:00
2015-03-25 10:45:55 +00:00
@require_super_user
def sudo_edit(request):
2015-03-25 10:45:55 +00:00
header_title, path1, path2 = u'Sudo授权', u'授权管理', u'Sudo授权'
if request.method == 'GET':
2015-03-25 10:45:55 +00:00
user_group_id = request.GET.get('id', '0')
user_group = UserGroup.objects.filter(id=user_group_id)
asset_group_all = BisGroup.objects.filter()
cmd_group_all = CmdGroup.objects.all()
if user_group:
user_group = user_group[0]
sudo_perm = user_group.sudoperm_set.all()
if sudo_perm:
sudo_perm = sudo_perm[0]
asset_group_permed = sudo_perm.asset_group.all()
cmd_group_permed = sudo_perm.cmd_group.all()
user_runas = sudo_perm.user_runas
comment = sudo_perm.comment
else:
asset_group_permed = []
cmd_group_permed = []
asset_groups = [asset_group for asset_group in asset_group_all if asset_group not in asset_group_permed]
cmd_groups = [cmd_group for cmd_group in cmd_group_all if cmd_group not in cmd_group_permed]
else:
2015-03-25 10:45:55 +00:00
user_group_id = request.POST.get('user_group_id', '')
users_runas = request.POST.get('runas', 'root')
asset_groups_select = request.POST.getlist('asset_groups_select')
cmd_groups_select = request.POST.getlist('cmd_groups_select')
comment = request.POST.get('comment', '')
2015-03-25 10:45:55 +00:00
user_group = UserGroup.objects.filter(id=user_group_id)
if user_group:
user_group = user_group[0]
if LDAP_ENABLE:
sudo_update(user_group, users_runas, asset_groups_select, cmd_groups_select, comment)
msg = '修改成功'
return HttpResponseRedirect('/jperm/sudo_list/')
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/sudo_edit.html', locals(), context_instance=RequestContext(request))
2015-03-27 10:37:10 +00:00
@require_admin
def sudo_edit_adm(request):
header_title, path1, path2 = u'Sudo授权', u'授权管理', u'Sudo授权'
user, dept = get_session_user_dept(request)
if request.method == 'GET':
user_group_id = request.GET.get('id', '0')
if not validate(request, user_group=[user_group_id]):
return render_to_response('/jperm/sudo_list/')
user_group = UserGroup.objects.filter(id=user_group_id)
asset_group_all = dept.bisgroup_set.all()
cmd_group_all = dept.cmdgroup_set.all()
if user_group:
user_group = user_group[0]
sudo_perm = user_group.sudoperm_set.all()
if sudo_perm:
sudo_perm = sudo_perm[0]
asset_group_permed = sudo_perm.asset_group.all()
cmd_group_permed = sudo_perm.cmd_group.all()
user_runas = sudo_perm.user_runas
comment = sudo_perm.comment
else:
asset_group_permed = []
cmd_group_permed = []
asset_groups = [asset_group for asset_group in asset_group_all if asset_group not in asset_group_permed]
cmd_groups = [cmd_group for cmd_group in cmd_group_all if cmd_group not in cmd_group_permed]
else:
user_group_id = request.POST.get('user_group_id', '')
users_runas = request.POST.get('runas', 'root')
asset_groups_select = request.POST.getlist('asset_groups_select')
cmd_groups_select = request.POST.getlist('cmd_groups_select')
comment = request.POST.get('comment', '')
user_group = UserGroup.objects.filter(id=user_group_id)
if not validate(request, user_group=[user_group_id], asset_group=asset_groups_select):
return render_to_response('/jperm/sudo_list/')
if user_group:
user_group = user_group[0]
if LDAP_ENABLE:
sudo_update(user_group, users_runas, asset_groups_select, cmd_groups_select, comment)
msg = '修改成功'
return HttpResponseRedirect('/jperm/sudo_list/')
return render_to_response('jperm/sudo_edit.html', locals(), context_instance=RequestContext(request))
2015-03-12 16:09:18 +00:00
@require_admin
2015-03-25 10:45:55 +00:00
def sudo_refresh(request):
sudo_perm_all = SudoPerm.objects.all()
for sudo_perm in sudo_perm_all:
user_group = sudo_perm.user_group
user_runas = sudo_perm.user_runas
asset_groups_select = sudo_perm.asset_group.all()
cmd_groups_select = sudo_perm.cmd_group.all()
sudo_ldap_add(user_group, user_runas, asset_groups_select, cmd_groups_select)
return HttpResponse('ok')
# @require_admin
# def sudo_detail(request):
# header_title, path1, path2 = u'Sudo授权详情', u'授权管理', u'授权详情'
# sudo_perm_id = request.GET.get('id')
# sudo_perm = SudoPerm.objects.filter(id=sudo_perm_id)
# if sudo_perm:
# sudo_perm = sudo_perm[0]
# user_groups = sudo_perm.user_group.all()
# asset_groups = sudo_perm.asset_group.all()
# cmd_groups = sudo_perm.cmd_group.all()
#
# users_list = []
# assets_list = []
# cmds_list = []
#
# for user_group in user_groups:
# users_list.extend(user_group.user_set.all())
# for asset_group in asset_groups:
# assets_list.extend(asset_group.asset_set.all())
# for cmd_group in cmd_groups:
# cmds_list.append({cmd_group.name: cmd_group.cmd.split(',')})
#
# return render_to_response('jperm/sudo_detail.html', locals(), context_instance=RequestContext(request))
# @require_admin
# def sudo_del(request):
# sudo_perm_id = request.GET.get('id', '0')
# sudo_perm = SudoPerm.objects.filter(id=int(sudo_perm_id))
# if sudo_perm:
# name = sudo_perm[0].name
# sudo_perm.delete()
# sudo_dn = 'cn=%s,ou=Sudoers,%s' % (name, LDAP_BASE_DN)
# ldap_conn.delete(sudo_dn)
# return HttpResponseRedirect('/jperm/sudo_list/')
2015-03-27 10:37:10 +00:00
@require_super_user
2015-02-09 00:40:54 +00:00
def cmd_add(request):
2015-03-05 16:24:17 +00:00
header_title, path1, path2 = u'sudo命令添加', u'授权管理', u'命令组添加'
2015-03-23 14:57:19 +00:00
dept_all = DEPT.objects.all()
2015-02-09 00:40:54 +00:00
if request.method == 'POST':
name = request.POST.get('name')
2015-03-23 14:57:19 +00:00
dept_id = request.POST.get('dept_id')
2015-02-09 00:40:54 +00:00
cmd = ','.join(request.POST.get('cmd').split())
comment = request.POST.get('comment')
2015-03-23 14:57:19 +00:00
dept = DEPT.objects.filter(id=dept_id)
2015-04-15 04:07:59 +00:00
try:
if CmdGroup.objects.filter(name=name):
error = '%s 命令组已存在'
raise ServerError(error)
if not dept:
error = u"部门不能为空"
raise ServerError(error)
except ServerError, e:
pass
else:
2015-03-23 14:57:19 +00:00
dept = dept[0]
CmdGroup.objects.create(name=name, dept=dept, cmd=cmd, comment=comment)
2015-04-15 04:07:59 +00:00
msg = u'命令组添加成功'
return HttpResponseRedirect('/jperm/cmd_list/')
2015-02-09 00:40:54 +00:00
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/sudo_cmd_add.html', locals(), context_instance=RequestContext(request))
2015-02-10 13:52:59 +00:00
2015-03-27 10:37:10 +00:00
@require_admin
def cmd_add_adm(request):
header_title, path1, path2 = u'sudo命令添加', u'授权管理', u'命令组添加'
user, dept = get_session_user_dept(request)
if request.method == 'POST':
name = request.POST.get('name')
cmd = ','.join(request.POST.get('cmd').split())
comment = request.POST.get('comment')
2015-04-15 04:07:59 +00:00
try:
if CmdGroup.objects.filter(name=name):
error = '%s 命令组已存在'
raise ServerError(error)
except ServerError, e:
pass
else:
CmdGroup.objects.create(name=name, dept=dept, cmd=cmd, comment=comment)
return HttpResponseRedirect('/jperm/cmd_list/')
2015-03-27 10:37:10 +00:00
return HttpResponseRedirect('/jperm/cmd_list/')
return render_to_response('jperm/sudo_cmd_add.html', locals(), context_instance=RequestContext(request))
2015-03-12 16:09:18 +00:00
@require_admin
2015-02-10 13:52:59 +00:00
def cmd_edit(request):
2015-03-05 16:24:17 +00:00
header_title, path1, path2 = u'sudo命令修改', u'授权管理管理', u'命令组修改'
2015-02-10 13:52:59 +00:00
cmd_group_id = request.GET.get('id')
cmd_group = CmdGroup.objects.filter(id=cmd_group_id)
2015-04-15 04:07:59 +00:00
dept_all = DEPT.objects.all()
2015-02-10 13:52:59 +00:00
if cmd_group:
cmd_group = cmd_group[0]
cmd_group_id = cmd_group.id
2015-04-15 04:07:59 +00:00
dept_id = cmd_group.dept.id
2015-02-10 13:52:59 +00:00
name = cmd_group.name
2015-03-07 09:37:26 +00:00
cmd = '\n'.join(cmd_group.cmd.split(','))
2015-02-10 13:52:59 +00:00
comment = cmd_group.comment
if request.method == 'POST':
cmd_group_id = request.POST.get('cmd_group_id')
name = request.POST.get('name')
2015-04-15 04:07:59 +00:00
dept_id = request.POST.get('dept_id')
2015-02-10 13:52:59 +00:00
cmd = ','.join(request.POST.get('cmd').split())
comment = request.POST.get('comment')
cmd_group = CmdGroup.objects.filter(id=cmd_group_id)
2015-04-15 04:07:59 +00:00
dept = DEPT.objects.filter(id=dept_id)
try:
if not dept:
error = '没有该部门'
raise ServerError(error)
if not cmd_group:
error = '没有该命令组'
except ServerError, e:
pass
else:
cmd_group.update(name=name, cmd=cmd, dept=dept[0], comment=comment)
2015-02-10 13:52:59 +00:00
return HttpResponseRedirect('/jperm/cmd_list/')
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/sudo_cmd_add.html', locals(), context_instance=RequestContext(request))
2015-02-09 00:40:54 +00:00
2015-03-12 16:09:18 +00:00
@require_admin
2015-02-09 00:40:54 +00:00
def cmd_list(request):
2015-03-05 16:24:17 +00:00
header_title, path1, path2 = u'sudo命令查看', u'权限管理', u'Sudo命令添加'
2015-02-09 00:40:54 +00:00
2015-04-09 03:27:36 +00:00
if is_super_user(request):
2015-03-27 10:37:10 +00:00
cmd_groups = contact_list = CmdGroup.objects.all()
else:
user, dept = get_session_user_dept(request)
cmd_groups = contact_list = dept.cmdgroup_set.all()
2015-02-09 00:40:54 +00:00
p = paginator = Paginator(contact_list, 10)
try:
page = int(request.GET.get('page', '1'))
except ValueError:
page = 1
try:
contacts = paginator.page(page)
except (EmptyPage, InvalidPage):
contacts = paginator.page(paginator.num_pages)
2015-02-27 14:14:09 +00:00
return render_to_response('jperm/sudo_cmd_list.html', locals(), context_instance=RequestContext(request))
2015-02-09 00:40:54 +00:00
2015-02-10 13:52:59 +00:00
2015-03-12 16:09:18 +00:00
@require_admin
2015-02-10 13:52:59 +00:00
def cmd_del(request):
cmd_group_id = request.GET.get('id')
cmd_group = CmdGroup.objects.filter(id=cmd_group_id)
if cmd_group:
cmd_group[0].delete()
return HttpResponseRedirect('/jperm/cmd_list/')
2015-03-26 10:42:52 +00:00
2015-04-09 03:27:36 +00:00
@require_admin
def cmd_detail(request):
2015-04-15 04:07:59 +00:00
cmd_ids = request.GET.get('id').split(',')
cmds = []
if len(cmd_ids) == 1:
cmd_group = CmdGroup.objects.filter(id=cmd_ids[0])
if cmd_group:
cmd_group = cmd_group[0]
cmds.extend(cmd_group.cmd.split(','))
cmd_group_name = cmd_group.name
else:
cmd_groups = []
for cmd_id in cmd_ids:
cmd_groups.extend(CmdGroup.objects.filter(id=cmd_id))
for cmd_group in cmd_groups:
cmds.extend(cmd_group.cmd.split(','))
cmds_str = ', '.join(cmds)
2015-04-09 03:27:36 +00:00
return render_to_response('jperm/sudo_cmd_detail.html', locals(), context_instance=RequestContext(request))
2015-03-26 10:42:52 +00:00
@require_login
def perm_apply(request):
header_title, path1, path2 = u'主机权限申请', u'权限管理', u'申请主机'
2015-04-16 06:32:48 +00:00
user_id, username = get_session_user_info(request)[0:2]
dept_id, deptname, dept = get_session_user_info(request)[3:6]
perm_host = user_perm_asset_api(username)
all_host = Asset.objects.filter(dept=dept)
perm_group = user_perm_group_api(username)
all_group = dept.bisgroup_set.all()
posts = [g for g in all_host if g not in perm_host]
egroup = [d for d in all_group if d not in perm_group]
2015-04-02 10:32:43 +00:00
dept_da = User.objects.filter(dept_id=dept_id, role='DA')
2015-03-26 10:42:52 +00:00
if request.method == 'POST':
applyer = request.POST.get('applyer')
dept = request.POST.get('dept')
2015-04-02 10:32:43 +00:00
da = request.POST.get('da')
2015-03-26 10:42:52 +00:00
group = request.POST.getlist('group')
hosts = request.POST.getlist('hosts')
comment = request.POST.get('comment')
2015-04-02 10:32:43 +00:00
da = User.objects.get(id=da)
mail_address = da.email
mail_title = '%s - 权限申请' % username
group_lis = ', '.join(group)
hosts_lis = ', '.join(hosts)
time_now = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
2015-04-11 04:52:00 +00:00
a = Apply.objects.create(applyer=applyer, dept=dept, bisgroup=group, date_add=datetime.datetime.now(), asset=hosts, status=0, comment=comment)
uuid = a.uuid
2015-04-15 09:32:30 +00:00
url = "http://%s:%s/jperm/apply_exec/?uuid=%s" % (SEND_IP, SEND_PORT, uuid)
2015-04-01 10:58:10 +00:00
mail_msg = """
Hi,%s:
有新的权限申请, 详情如下:
申请人: %s
申请主机组: %s
申请的主机: %s
申请时间: %s
申请说明: %s
2015-04-11 04:52:00 +00:00
请及时审批, 审批完成后, 点击以下链接或登录授权管理-权限审批页面点击确认键,告知申请人
2015-04-04 04:47:07 +00:00
2015-04-01 10:58:10 +00:00
%s
2015-04-02 10:32:43 +00:00
""" % (da.username, applyer, group_lis, hosts_lis, time_now, comment, url)
2015-04-01 10:58:10 +00:00
2015-04-15 09:32:30 +00:00
send_mail(mail_title, mail_msg, MAIL_FROM, [mail_address], fail_silently=False)
2015-04-02 10:32:43 +00:00
smg = "提交成功,已发邮件通知部门管理员。"
2015-03-26 10:42:52 +00:00
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))
2015-04-04 04:47:07 +00:00
@require_admin
2015-04-02 10:32:43 +00:00
def perm_apply_exec(request):
2015-04-04 04:47:07 +00:00
header_title, path1, path2 = u'主机权限申请', u'权限管理', u'审批完成'
2015-04-02 10:32:43 +00:00
uuid = request.GET.get('uuid')
2015-04-11 04:52:00 +00:00
user_id = request.session.get('user_id')
approver = User.objects.get(id=user_id).name
2015-04-04 04:47:07 +00:00
if uuid:
p_apply = Apply.objects.filter(uuid=str(uuid))
q_apply = Apply.objects.get(uuid=str(uuid))
if q_apply.status == 1:
smg = '此权限已经审批完成, 请勿重复审批, 十秒钟后返回首页'
return render_to_response('jperm/perm_apply_exec.html', locals(), context_instance=RequestContext(request))
else:
user = User.objects.get(username=q_apply.applyer)
mail_address = user.email
time_now = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
2015-04-11 04:52:00 +00:00
p_apply.update(status=1, approver=approver, date_end=time_now)
2015-04-04 04:47:07 +00:00
mail_title = '%s - 权限审批完成' % q_apply.applyer
mail_msg = """
Hi,%s:
您所申请的权限已由 %s %s 审批完成, 请登录验证
""" % (q_apply.applyer, q_apply.approver, time_now)
send_mail(mail_title, mail_msg, 'jkfunshion@fun.tv', [mail_address], fail_silently=False)
smg = '授权完成, 已邮件通知申请人, 十秒钟后返回首页'
return render_to_response('jperm/perm_apply_exec.html', locals(), context_instance=RequestContext(request))
else:
2015-04-11 04:52:00 +00:00
smg = '没有此授权记录, 十秒钟后返回首页'
2015-04-02 10:32:43 +00:00
return render_to_response('jperm/perm_apply_exec.html', locals(), context_instance=RequestContext(request))
2015-04-01 10:58:10 +00:00
def get_apply_posts(request, status, username, dept_name, keyword=None):
2015-03-26 10:42:52 +00:00
if is_super_user(request):
if keyword:
2015-04-01 10:58:10 +00:00
posts = Apply.objects.filter(Q(applyer__contains=keyword) | Q(approver__contains=keyword)) \
.filter(status=status).order_by('-date_add')
2015-03-26 10:42:52 +00:00
else:
2015-04-01 10:58:10 +00:00
posts = Apply.objects.filter(status=status).order_by('-date_add')
2015-03-26 10:42:52 +00:00
elif is_group_admin(request):
if keyword:
2015-04-01 10:58:10 +00:00
posts = Apply.objects.filter(Q(applyer__contains=keyword) | Q(approver__contains=keyword)) \
.filter(status=status).filter(dept=dept_name).order_by('-date_add')
2015-03-26 10:42:52 +00:00
else:
2015-04-14 09:25:56 +00:00
posts = Apply.objects.filter(status=status).filter(dept=dept_name).order_by('-date_add')
2015-03-26 10:42:52 +00:00
elif is_common_user(request):
if keyword:
2015-04-01 10:58:10 +00:00
posts = Apply.objects.filter(applyer=username).filter(status=status).filter(Q(applyer__contains=keyword) |
Q(asset__contains=keyword)).order_by('-date_add')
2015-03-26 10:42:52 +00:00
else:
2015-04-01 10:58:10 +00:00
posts = Apply.objects.filter(applyer=username).filter(status=status).order_by('-date_add')
return posts
2015-04-04 04:47:07 +00:00
@require_login
2015-04-01 10:58:10 +00:00
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
2015-04-11 04:52:00 +00:00
status_dic = {'online': 0, 'offline': 1}
status = status_dic[offset]
posts = get_apply_posts(request, status, 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_%s.html' % offset, locals(), context_instance=RequestContext(request))
2015-04-04 04:47:07 +00:00
2015-04-11 04:52:00 +00:00
@require_login
2015-04-04 04:47:07 +00:00
def perm_apply_info(request):
uuid = request.GET.get('uuid')
post = Apply.objects.get(uuid=uuid)
return render_to_response('jperm/perm_apply_info.html', locals(), context_instance=RequestContext(request))
2015-04-11 04:52:00 +00:00
@require_admin
def perm_apply_del(request):
uuid = request.GET.get('uuid')
u_apply = Apply.objects.filter(uuid=uuid)
if u_apply:
u_apply.delete()
return HttpResponseRedirect('/jperm/apply_show/online/')
@require_login
2015-04-04 04:47:07 +00:00
def perm_apply_search(request):
keyword = request.GET.get('keyword')
2015-04-11 04:52:00 +00:00
offset = request.GET.get('env')
2015-04-04 04:47:07 +00:00
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
2015-04-11 04:52:00 +00:00
status_dic = {'online': 0, 'offline': 1}
status = status_dic[offset]
posts = get_apply_posts(request, status, username, dept_name, keyword)
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request)
2015-04-04 04:47:07 +00:00
return render_to_response('jperm/perm_apply_search.html', locals(), context_instance=RequestContext(request))