2015-01-21 15:28:56 +00:00
|
|
|
# coding: utf-8
|
|
|
|
|
2015-01-21 15:22:21 +00:00
|
|
|
from django.shortcuts import render_to_response
|
2015-03-06 16:12:38 +00:00
|
|
|
from django.http import HttpResponseRedirect, HttpResponse
|
2015-02-27 14:14:09 +00:00
|
|
|
from django.template import RequestContext
|
2015-03-11 09:59:15 +00:00
|
|
|
from juser.models import User, UserGroup, DEPT
|
2015-01-28 16:53:15 +00:00
|
|
|
from jasset.models import Asset, BisGroup
|
2015-03-26 10:42:52 +00:00
|
|
|
from jperm.models import Perm, SudoPerm, CmdGroup, Apply
|
2015-01-24 06:36:58 +00:00
|
|
|
from django.core.paginator import Paginator, EmptyPage, InvalidPage
|
2015-02-09 00:40:54 +00:00
|
|
|
from django.db.models import Q
|
2015-03-07 10:25:31 +00:00
|
|
|
from jumpserver.views import LDAP_ENABLE, ldap_conn, CONF, page_list_return, pages
|
2015-03-14 09:54:17 +00:00
|
|
|
from jumpserver.api import *
|
2015-01-24 06:36:58 +00:00
|
|
|
|
|
|
|
|
2015-02-11 10:38:56 +00:00
|
|
|
def user_asset_cmd_groups_get(user_groups_select='', asset_groups_select='', cmd_groups_select=''):
|
|
|
|
user_groups_select_list = []
|
|
|
|
asset_groups_select_list = []
|
|
|
|
cmd_groups_select_list = []
|
|
|
|
|
|
|
|
for user_group_id in user_groups_select:
|
|
|
|
user_groups_select_list.append(UserGroup.objects.get(id=user_group_id))
|
|
|
|
|
|
|
|
for asset_group_id in asset_groups_select:
|
|
|
|
asset_groups_select_list.append(BisGroup.objects.get(id=asset_group_id))
|
|
|
|
|
|
|
|
for cmd_group_id in cmd_groups_select:
|
|
|
|
cmd_groups_select_list.append(CmdGroup.objects.get(id=cmd_group_id))
|
|
|
|
|
|
|
|
return user_groups_select_list, asset_groups_select_list, cmd_groups_select_list
|
|
|
|
|
|
|
|
|
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:
|
|
|
|
contact_list = DEPT.objects.filter(id__gt=1)
|
|
|
|
|
|
|
|
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-02-10 10:53:01 +00:00
|
|
|
def sudo_db_add(name, user_runas, user_groups_select, asset_groups_select, cmd_groups_select, comment):
|
2015-02-09 00:40:54 +00:00
|
|
|
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)
|
|
|
|
|
2015-02-09 16:21:08 +00:00
|
|
|
sudo_perm = SudoPerm(name=name, user_runas=user_runas, comment=comment)
|
2015-02-09 00:40:54 +00:00
|
|
|
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 16:21:08 +00:00
|
|
|
def sudo_db_update(sudo_perm_id, 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.objects.filter(id=sudo_perm_id)
|
|
|
|
if sudo_perm:
|
|
|
|
sudo_perm.update(name=name, user_runas=user_runas, comment=comment)
|
|
|
|
sudo_perm = sudo_perm[0]
|
|
|
|
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-02-10 10:53:01 +00:00
|
|
|
def sudo_ldap_add(name, users_runas, user_groups_select, asset_groups_select,
|
|
|
|
cmd_groups_select, update=False, old_name=''):
|
2015-02-09 00:40:54 +00:00
|
|
|
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)
|
|
|
|
|
2015-03-15 15:23:20 +00:00
|
|
|
if not LDAP_ENABLE:
|
|
|
|
return True
|
|
|
|
|
2015-02-09 10:50:21 +00:00
|
|
|
users = []
|
|
|
|
assets = []
|
|
|
|
cmds = []
|
2015-02-09 16:21:08 +00:00
|
|
|
users_runas = users_runas.split(',')
|
2015-02-10 10:53:01 +00:00
|
|
|
asset_all = False
|
2015-02-09 10:50:21 +00:00
|
|
|
|
|
|
|
for user_group in user_groups_select_list:
|
|
|
|
users.extend(user_group.user_set.all())
|
|
|
|
|
|
|
|
for asset_group in asset_groups_select_list:
|
2015-02-10 10:53:01 +00:00
|
|
|
if u'ALL' in asset_group.name:
|
|
|
|
asset_all = True
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
assets.extend(asset_group.asset_set.all())
|
2015-02-09 10:50:21 +00:00
|
|
|
|
|
|
|
for cmd_group in cmd_groups_select_list:
|
|
|
|
cmds.extend(cmd_group.cmd.split(','))
|
|
|
|
|
2015-02-09 16:21:08 +00:00
|
|
|
users_name = [user.username for user in users]
|
2015-02-10 10:53:01 +00:00
|
|
|
if asset_all:
|
|
|
|
assets_ip = ['ALL']
|
|
|
|
else:
|
|
|
|
assets_ip = [asset.ip for asset in assets]
|
2015-02-09 10:50:21 +00:00
|
|
|
|
|
|
|
sudo_dn = 'cn=%s,ou=Sudoers,%s' % (name, LDAP_BASE_DN)
|
|
|
|
sudo_attr = {'objectClass': ['top', 'sudoRole'],
|
|
|
|
'cn': ['%s' % str(name)],
|
|
|
|
'sudoCommand': unicode2str(cmds),
|
|
|
|
'sudoHost': unicode2str(assets_ip),
|
|
|
|
'sudoOption': ['!authenticate'],
|
|
|
|
'sudoRunAsUser': unicode2str(users_runas),
|
|
|
|
'sudoUser': unicode2str(users_name)}
|
|
|
|
|
2015-02-09 16:21:08 +00:00
|
|
|
if update:
|
2015-02-10 10:53:01 +00:00
|
|
|
old_sudo_dn = 'cn=%s,ou=Sudoers,%s' % (old_name, LDAP_BASE_DN)
|
|
|
|
ldap_conn.delete(old_sudo_dn)
|
2015-02-09 16:21:08 +00:00
|
|
|
|
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-23 14:57:19 +00:00
|
|
|
@require_super_user
|
2015-02-09 00:40:54 +00:00
|
|
|
def sudo_add(request):
|
2015-03-05 16:24:17 +00:00
|
|
|
header_title, path1, path2 = u'Sudo授权', u'权限管理', u'添加Sudo权限'
|
2015-03-07 09:37:26 +00:00
|
|
|
user_groups = UserGroup.objects.filter(id__gt=2)
|
2015-03-03 14:44:00 +00:00
|
|
|
asset_groups = BisGroup.objects.all()
|
2015-02-09 00:40:54 +00:00
|
|
|
cmd_groups = CmdGroup.objects.all()
|
|
|
|
|
|
|
|
if request.method == 'POST':
|
2015-02-09 10:50:21 +00:00
|
|
|
name = request.POST.get('name')
|
2015-02-09 16:21:08 +00:00
|
|
|
users_runas = request.POST.get('runas', 'root')
|
2015-02-09 00:40:54 +00:00
|
|
|
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', '')
|
|
|
|
|
2015-03-15 15:23:20 +00:00
|
|
|
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)
|
2015-02-09 00:40:54 +00:00
|
|
|
|
|
|
|
msg = '添加成功'
|
2015-02-27 14:14:09 +00:00
|
|
|
return render_to_response('jperm/sudo_add.html', locals(), context_instance=RequestContext(request))
|
2015-02-09 00:40:54 +00:00
|
|
|
|
|
|
|
|
2015-03-23 14:57:19 +00:00
|
|
|
@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-12 16:09:18 +00:00
|
|
|
@require_admin
|
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-07 10:25:31 +00:00
|
|
|
contact_list = SudoPerm.objects.all()
|
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-12 16:09:18 +00:00
|
|
|
@require_admin
|
2015-02-09 16:21:08 +00:00
|
|
|
def sudo_edit(request):
|
2015-03-05 16:24:17 +00:00
|
|
|
header_title, path1, path2 = u'Sudo授权', u'授权管理', u'Sudo修改'
|
2015-02-09 16:21:08 +00:00
|
|
|
|
|
|
|
if request.method == 'GET':
|
|
|
|
sudo_perm_id = request.GET.get('id', '0')
|
|
|
|
sudo_perm = SudoPerm.objects.filter(id=int(sudo_perm_id))
|
|
|
|
if sudo_perm:
|
2015-03-07 09:37:26 +00:00
|
|
|
user_group_all = UserGroup.objects.filter(id__gt=2)
|
2015-02-09 16:21:08 +00:00
|
|
|
asset_group_all = BisGroup.objects.filter()
|
|
|
|
cmd_group_all = CmdGroup.objects.all()
|
|
|
|
|
|
|
|
sudo_perm = sudo_perm[0]
|
|
|
|
user_group_permed = sudo_perm.user_group.all()
|
|
|
|
asset_group_permed = sudo_perm.asset_group.all()
|
|
|
|
cmd_group_permed = sudo_perm.cmd_group.all()
|
|
|
|
|
|
|
|
user_groups = [user_group for user_group in user_group_all if user_group not in user_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]
|
|
|
|
|
|
|
|
name = sudo_perm.name
|
|
|
|
user_runas = sudo_perm.user_runas
|
|
|
|
comment = sudo_perm.comment
|
|
|
|
|
|
|
|
else:
|
|
|
|
sudo_perm_id = request.POST.get('sudo_perm_id')
|
|
|
|
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', '')
|
|
|
|
|
2015-02-10 10:53:01 +00:00
|
|
|
sudo_perm = SudoPerm.objects.get(id=sudo_perm_id)
|
|
|
|
old_name = sudo_perm.name
|
2015-03-15 15:23:20 +00:00
|
|
|
if LDAP_ENABLE:
|
|
|
|
sudo_db_update(sudo_perm_id, 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, update=True, old_name=str(old_name))
|
2015-02-09 16:21:08 +00:00
|
|
|
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-02-09 16:21:08 +00:00
|
|
|
|
|
|
|
|
2015-03-12 16:09:18 +00:00
|
|
|
@require_admin
|
2015-02-09 16:21:08 +00:00
|
|
|
def sudo_detail(request):
|
2015-03-05 16:24:17 +00:00
|
|
|
header_title, path1, path2 = u'Sudo授权详情', u'授权管理', u'授权详情'
|
2015-02-09 16:21:08 +00:00
|
|
|
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:
|
2015-02-10 10:53:01 +00:00
|
|
|
cmds_list.append({cmd_group.name: cmd_group.cmd.split(',')})
|
2015-02-09 16:21:08 +00:00
|
|
|
|
2015-02-27 14:14:09 +00:00
|
|
|
return render_to_response('jperm/sudo_detail.html', locals(), context_instance=RequestContext(request))
|
2015-02-09 16:21:08 +00:00
|
|
|
|
|
|
|
|
2015-03-12 16:09:18 +00:00
|
|
|
@require_admin
|
2015-02-09 16:21:08 +00:00
|
|
|
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-12 16:09:18 +00:00
|
|
|
@require_admin
|
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)
|
|
|
|
if dept:
|
|
|
|
dept = dept[0]
|
|
|
|
CmdGroup.objects.create(name=name, dept=dept, cmd=cmd, comment=comment)
|
|
|
|
else:
|
|
|
|
error = u"部门不能为空"
|
2015-02-09 00:40:54 +00:00
|
|
|
msg = u'命令组添加成功'
|
|
|
|
|
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-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_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)
|
|
|
|
|
|
|
|
if cmd_group:
|
|
|
|
cmd_group = cmd_group[0]
|
|
|
|
cmd_group_id = cmd_group.id
|
|
|
|
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')
|
|
|
|
cmd = ','.join(request.POST.get('cmd').split())
|
|
|
|
comment = request.POST.get('comment')
|
|
|
|
|
|
|
|
cmd_group = CmdGroup.objects.filter(id=cmd_group_id)
|
|
|
|
if cmd_group:
|
|
|
|
cmd_group.update(name=name, cmd=cmd, comment=comment)
|
|
|
|
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
|
|
|
|
|
|
|
cmd_groups = contact_list = CmdGroup.objects.all()
|
|
|
|
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
|
|
|
|
|
|
|
|
|
|
|
@require_login
|
|
|
|
def perm_apply(request):
|
|
|
|
header_title, path1, path2 = u'主机权限申请', u'权限管理', u'申请主机'
|
|
|
|
user_id = request.session.get('user_id')
|
|
|
|
username = User.objects.get(id=user_id).username
|
|
|
|
dept_id = get_user_dept(request)
|
|
|
|
deptname = DEPT.objects.get(id=dept_id).name
|
|
|
|
dept = DEPT.objects.get(id=dept_id)
|
|
|
|
posts = Asset.objects.filter(dept=dept)
|
|
|
|
egroup = dept.bisgroup_set.all()
|
|
|
|
|
|
|
|
if request.method == 'POST':
|
|
|
|
applyer = request.POST.get('applyer')
|
|
|
|
dept = request.POST.get('dept')
|
|
|
|
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
|
|
|
|
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):
|
|
|
|
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')
|
|
|
|
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, 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')
|
|
|
|
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))
|