jumpserver/jasset/views.py

571 lines
20 KiB
Python
Raw Normal View History

# coding:utf-8
2015-02-09 11:02:25 +00:00
from django.db.models import Q
2015-12-19 09:26:34 +00:00
from jasset.asset_api import *
2015-03-26 10:42:52 +00:00
from jumpserver.api import *
2015-12-19 09:26:34 +00:00
from jumpserver.models import Setting
from jasset.forms import AssetForm, IdcForm
from jasset.models import Asset, IDC, AssetGroup, ASSET_TYPE, ASSET_STATUS
from jperm.perm_api import get_group_asset_perm, get_group_user_perm
2014-12-22 09:18:51 +00:00
2015-12-19 09:26:34 +00:00
@require_role('admin')
def group_add(request):
"""
Group add view
添加资产组
"""
header_title, path1, path2 = u'添加资产组', u'资产管理', u'添加资产组'
asset_all = Asset.objects.all()
2015-12-19 09:26:34 +00:00
if request.method == 'POST':
name = request.POST.get('name', '')
asset_select = request.POST.getlist('asset_select', [])
comment = request.POST.get('comment', '')
2015-12-19 09:26:34 +00:00
try:
if not name:
emg = u'组名不能为空'
raise ServerError(emg)
2015-12-19 09:26:34 +00:00
asset_group_test = get_object(AssetGroup, name=name)
if asset_group_test:
emg = u"该组名 %s 已存在" % name
raise ServerError(emg)
2015-04-18 04:30:45 +00:00
2015-12-19 09:26:34 +00:00
except ServerError:
pass
2015-04-18 04:30:45 +00:00
2015-12-19 09:26:34 +00:00
else:
db_add_group(name=name, comment=comment, asset_select=asset_select)
smg = u"主机组 %s 添加成功" % name
2015-04-19 10:36:41 +00:00
2015-12-19 09:26:34 +00:00
return my_render('jasset/group_add.html', locals(), request)
2015-04-16 11:03:02 +00:00
2015-12-19 09:26:34 +00:00
@require_role('admin')
def group_edit(request):
"""
Group edit view
编辑资产组
"""
header_title, path1, path2 = u'编辑主机组', u'资产管理', u'编辑主机组'
group_id = request.GET.get('id', '')
group = get_object(AssetGroup, id=group_id)
2015-04-16 11:03:02 +00:00
2015-12-19 09:26:34 +00:00
asset_all = Asset.objects.all()
asset_select = Asset.objects.filter(group=group)
asset_no_select = [a for a in asset_all if a not in asset_select]
2015-03-24 10:34:00 +00:00
if request.method == 'POST':
2015-12-19 09:26:34 +00:00
name = request.POST.get('name', '')
asset_select = request.POST.getlist('asset_select', [])
comment = request.POST.get('comment', '')
try:
if not name:
emg = u'组名不能为空'
raise ServerError(emg)
if group.name != name:
asset_group_test = get_object(AssetGroup, name=name)
if asset_group_test:
emg = u"该组名 %s 已存在" % name
raise ServerError(emg)
except ServerError:
pass
else:
2015-12-19 09:26:34 +00:00
group.asset_set.clear()
db_update_group(id=group_id, name=name, comment=comment, asset_select=asset_select)
smg = u"主机组 %s 添加成功" % name
return HttpResponseRedirect(reverse('asset_group_list'))
return my_render('jasset/group_edit.html', locals(), request)
2015-12-19 09:26:34 +00:00
@require_role('admin')
def group_list(request):
"""
list asset group
列出资产组
"""
header_title, path1, path2 = u'查看资产组', u'资产管理', u'查看资产组'
keyword = request.GET.get('keyword', '')
asset_group_list = AssetGroup.objects.all()
group_id = request.GET.get('id')
if group_id:
asset_group_list = asset_group_list.filter(id=group_id)
if keyword:
asset_group_list = asset_group_list.filter(Q(name__contains=keyword) | Q(comment__contains=keyword))
2015-12-19 09:26:34 +00:00
asset_group_list, p, asset_groups, page_range, current_page, show_first, show_end = pages(asset_group_list, request)
return my_render('jasset/group_list.html', locals(), request)
@require_role('admin')
def group_del(request):
"""
Group delete view
删除主机组
"""
group_ids = request.GET.get('id', '')
group_id_list = group_ids.split(',')
for group_id in group_id_list:
AssetGroup.objects.filter(id=group_id).delete()
return HttpResponse(u'删除成功')
@require_role('admin')
def asset_add(request):
"""
Asset add view
添加资产
"""
header_title, path1, path2 = u'添加资产', u'资产管理', u'添加资产'
asset_group_all = AssetGroup.objects.all()
af = AssetForm()
default_setting = get_object(Setting, name='default')
default_port = default_setting.field2 if default_setting else ''
if request.method == 'POST':
2015-12-19 09:26:34 +00:00
af_post = AssetForm(request.POST)
ip = request.POST.get('ip', '')
hostname = request.POST.get('hostname', '')
is_active = True if request.POST.get('is_active') == '1' else False
use_default_auth = request.POST.get('use_default_auth', '')
try:
2015-12-29 06:20:47 +00:00
if Asset.objects.filter(hostname=unicode(hostname)):
2015-12-19 09:26:34 +00:00
error = u'该主机名 %s 已存在!' % hostname
raise ServerError(error)
except ServerError:
pass
else:
if af_post.is_valid():
asset_save = af_post.save(commit=False)
if not use_default_auth:
password = request.POST.get('password', '')
password_encode = CRYPTOR.encrypt(password)
asset_save.password = password_encode
if not ip:
asset_save.ip = hostname
asset_save.is_active = True if is_active else False
asset_save.save()
af_post.save_m2m()
msg = u'主机 %s 添加成功' % hostname
2015-04-16 11:03:02 +00:00
else:
2015-12-19 09:26:34 +00:00
esg = u'主机 %s 添加失败' % hostname
2015-04-14 09:25:56 +00:00
2015-12-19 09:26:34 +00:00
return my_render('jasset/asset_add.html', locals(), request)
2015-04-14 09:25:56 +00:00
2015-12-19 09:26:34 +00:00
@require_role('admin')
def asset_add_batch(request):
header_title, path1, path2 = u'添加资产', u'资产管理', u'批量添加'
return my_render('jasset/asset_add_batch.html', locals(), request)
2015-04-14 09:25:56 +00:00
2015-12-19 09:26:34 +00:00
@require_role('admin')
def asset_del(request):
"""
del a asset
删除主机
"""
asset_id = request.GET.get('id', '')
if asset_id:
Asset.objects.filter(id=asset_id).delete()
2015-02-05 10:53:57 +00:00
2015-12-19 09:26:34 +00:00
if request.method == 'POST':
asset_batch = request.GET.get('arg', '')
asset_id_all = str(request.POST.get('asset_id_all', ''))
2015-02-05 10:53:57 +00:00
2015-12-19 09:26:34 +00:00
if asset_batch:
for asset_id in asset_id_all.split(','):
asset = get_object(Asset, id=asset_id)
asset.delete()
2015-12-19 09:26:34 +00:00
return HttpResponse(u'删除成功')
2015-04-07 11:15:45 +00:00
2015-12-19 09:26:34 +00:00
@require_role(role='super')
def asset_edit(request):
"""
edit a asset
修改主机
"""
header_title, path1, path2 = u'修改资产', u'资产管理', u'修改资产'
2015-04-07 11:15:45 +00:00
2015-12-19 09:26:34 +00:00
asset_id = request.GET.get('id', '')
username = request.user.username
asset = get_object(Asset, id=asset_id)
if asset:
password_old = asset.password
# asset_old = copy_model_instance(asset)
af = AssetForm(instance=asset)
if request.method == 'POST':
af_post = AssetForm(request.POST, instance=asset)
ip = request.POST.get('ip', '')
hostname = request.POST.get('hostname', '')
password = request.POST.get('password', '')
is_active = True if request.POST.get('is_active') == '1' else False
use_default_auth = request.POST.get('use_default_auth', '')
try:
asset_test = get_object(Asset, hostname=hostname)
if asset_test and asset_id != unicode(asset_test.id):
emg = u'该主机名 %s 已存在!' % hostname
raise ServerError(emg)
except ServerError:
pass
2015-04-18 08:58:15 +00:00
else:
2015-12-19 09:26:34 +00:00
if af_post.is_valid():
af_save = af_post.save(commit=False)
if use_default_auth:
af_save.username = ''
af_save.password = ''
af_save.port = None
else:
if password:
password_encode = CRYPTOR.encrypt(password)
af_save.password = password_encode
else:
af_save.password = password_old
af_save.is_active = True if is_active else False
af_save.save()
af_post.save_m2m()
# asset_new = get_object(Asset, id=asset_id)
# asset_diff_one(asset_old, asset_new)
info = asset_diff(af_post.__dict__.get('initial'), request.POST)
db_asset_alert(asset, username, info)
smg = u'主机 %s 修改成功' % ip
2015-04-05 14:52:37 +00:00
else:
2015-12-19 09:26:34 +00:00
emg = u'主机 %s 修改失败' % ip
return my_render('jasset/error.html', locals(), request)
return HttpResponseRedirect(reverse('asset_detail')+'?id=%s' % asset_id)
return my_render('jasset/asset_edit.html', locals(), request)
@require_role('user')
def asset_list(request):
"""
asset list view
"""
header_title, path1, path2 = u'查看资产', u'资产管理', u'查看资产'
username = request.user.username
user_perm = request.session['role_id']
idc_all = IDC.objects.filter()
asset_group_all = AssetGroup.objects.all()
asset_types = ASSET_TYPE
asset_status = ASSET_STATUS
idc_name = request.GET.get('idc', '')
group_name = request.GET.get('group', '')
asset_type = request.GET.get('asset_type', '')
status = request.GET.get('status', '')
keyword = request.GET.get('keyword', '')
export = request.GET.get("export", False)
group_id = request.GET.get("group_id", '')
idc_id = request.GET.get("idc_id", '')
asset_id_all = request.GET.getlist("id", '')
2015-04-05 14:52:37 +00:00
2015-12-19 09:26:34 +00:00
if group_id:
group = get_object(AssetGroup, id=group_id)
if group:
asset_find = Asset.objects.filter(group=group)
elif idc_id:
idc = get_object(IDC, id=idc_id)
if idc:
asset_find = Asset.objects.filter(idc=idc)
2015-04-13 13:25:43 +00:00
else:
2015-12-19 09:26:34 +00:00
if user_perm != 0:
asset_find = Asset.objects.all()
else:
asset_id_all = []
user = get_object(User, username=username)
asset_perm = get_group_user_perm(user) if user else {'asset': ''}
user_asset_perm = asset_perm['asset'].keys()
for asset in user_asset_perm:
asset_id_all.append(asset.id)
asset_find = Asset.objects.filter(pk__in=asset_id_all)
asset_group_all = list(asset_perm['asset_group'])
2015-04-13 13:25:43 +00:00
2015-12-19 09:26:34 +00:00
if idc_name:
asset_find = asset_find.filter(idc__name__contains=idc_name)
2015-04-13 13:25:43 +00:00
2015-12-19 09:26:34 +00:00
if group_name:
asset_find = asset_find.filter(group__name__contains=group_name)
2015-04-13 13:25:43 +00:00
2015-12-19 09:26:34 +00:00
if asset_type:
asset_find = asset_find.filter(asset_type__contains=asset_type)
2015-04-13 13:25:43 +00:00
2015-12-19 09:26:34 +00:00
if status:
asset_find = asset_find.filter(status__contains=status)
2015-04-13 13:25:43 +00:00
2015-12-19 09:26:34 +00:00
if keyword:
asset_find = asset_find.filter(
Q(hostname__contains=keyword) |
Q(other_ip__contains=keyword) |
Q(ip__contains=keyword) |
Q(remote_ip__contains=keyword) |
Q(comment__contains=keyword) |
Q(username__contains=keyword) |
Q(group__name__contains=keyword) |
Q(cpu__contains=keyword) |
Q(memory__contains=keyword) |
Q(disk__contains=keyword) |
Q(brand__contains=keyword) |
Q(cabinet__contains=keyword) |
Q(sn__contains=keyword) |
Q(system_type__contains=keyword) |
Q(system_version__contains=keyword))
if export:
if asset_id_all:
asset_find = []
for asset_id in asset_id_all:
asset = get_object(Asset, id=asset_id)
if asset:
asset_find.append(asset)
s = write_excel(asset_find)
if s[0]:
file_name = s[1]
smg = u'excel文件已生成请点击下载!'
return my_render('jasset/asset_excel_download.html', locals(), request)
assets_list, p, assets, page_range, current_page, show_first, show_end = pages(asset_find, request)
if user_perm != 0:
return my_render('jasset/asset_list.html', locals(), request)
else:
return my_render('jasset/asset_cu_list.html', locals(), request)
2015-12-19 09:26:34 +00:00
@require_role('admin')
def asset_edit_batch(request):
af = AssetForm()
name = request.user.username
asset_group_all = AssetGroup.objects.all()
2015-12-19 09:26:34 +00:00
if request.method == 'POST':
env = request.POST.get('env', '')
idc_id = request.POST.get('idc', '')
port = request.POST.get('port', '')
use_default_auth = request.POST.get('use_default_auth', '')
username = request.POST.get('username', '')
password = request.POST.get('password', '')
group = request.POST.getlist('group', [])
cabinet = request.POST.get('cabinet', '')
comment = request.POST.get('comment', '')
asset_id_all = unicode(request.GET.get('asset_id_all', ''))
asset_id_all = asset_id_all.split(',')
for asset_id in asset_id_all:
alert_list = []
asset = get_object(Asset, id=asset_id)
if asset:
if env:
if asset.env != env:
asset.env = env
alert_list.append([u'运行环境', asset.env, env])
if idc_id:
idc = get_object(IDC, id=idc_id)
name_old = asset.idc.name if asset.idc else u''
if idc and idc.name != name_old:
asset.idc = idc
alert_list.append([u'机房', name_old, idc.name])
if port:
if unicode(asset.port) != port:
asset.port = port
alert_list.append([u'端口号', asset.port, port])
if use_default_auth:
if use_default_auth == 'default':
asset.use_default_auth = 1
asset.username = ''
asset.password = ''
alert_list.append([u'使用默认管理账号', asset.use_default_auth, u'默认'])
elif use_default_auth == 'user_passwd':
asset.use_default_auth = 0
asset.username = username
password_encode = CRYPTOR.encrypt(password)
asset.password = password_encode
alert_list.append([u'使用默认管理账号', asset.use_default_auth, username])
if group:
group_new, group_old, group_new_name, group_old_name = [], asset.group.all(), [], []
for group_id in group:
g = get_object(AssetGroup, id=group_id)
if g:
group_new.append(g)
if not set(group_new) < set(group_old):
group_instance = list(set(group_new) | set(group_old))
for g in group_instance:
group_new_name.append(g.name)
for g in group_old:
group_old_name.append(g.name)
asset.group = group_instance
alert_list.append([u'主机组', ','.join(group_old_name), ','.join(group_new_name)])
if cabinet:
if asset.cabinet != cabinet:
asset.cabinet = cabinet
alert_list.append([u'机柜号', asset.cabinet, cabinet])
if comment:
if asset.comment != comment:
asset.comment = comment
alert_list.append([u'备注', asset.comment, comment])
asset.save()
if alert_list:
recode_name = unicode(name) + ' - ' + u'批量'
AssetRecord.objects.create(asset=asset, username=recode_name, content=alert_list)
return my_render('jasset/asset_update_status.html', locals(), request)
return my_render('jasset/asset_edit_batch.html', locals(), request)
@require_role('admin')
def asset_detail(request):
"""
Asset detail view
"""
2015-03-04 15:14:07 +00:00
header_title, path1, path2 = u'主机详细信息', u'资产管理', u'主机详情'
2015-12-19 09:26:34 +00:00
asset_id = request.GET.get('id', '')
asset = get_object(Asset, id=asset_id)
perm_info = get_group_asset_perm(asset)
log = Log.objects.filter(host=asset.hostname)
if perm_info:
user_perm = []
for perm, value in perm_info.items():
if perm == 'user':
for user, role_dic in value.items():
user_perm.append([user, role_dic.get('role', '')])
elif perm == 'user_group' or perm == 'rule':
user_group_perm = value
print perm_info
asset_record = AssetRecord.objects.filter(asset=asset).order_by('-alert_time')
return my_render('jasset/asset_detail.html', locals(), request)
@require_role('admin')
def asset_update(request):
"""
Asset update host info via ansible view
"""
asset_id = request.GET.get('id', '')
asset = get_object(Asset, id=asset_id)
name = request.user.username
if not asset:
return HttpResponseRedirect(reverse('asset_detail')+'?id=%s' % asset_id)
2015-04-13 13:25:43 +00:00
else:
2015-12-19 09:26:34 +00:00
asset_ansible_update([asset], name)
return HttpResponseRedirect(reverse('asset_detail')+'?id=%s' % asset_id)
2015-12-19 09:26:34 +00:00
@require_role('admin')
def asset_update_batch(request):
if request.method == 'POST':
arg = request.GET.get('arg', '')
name = unicode(request.user.username) + ' - ' + u'自动更新'
if arg == 'all':
asset_list = Asset.objects.all()
else:
asset_list = []
asset_id_all = unicode(request.POST.get('asset_id_all', ''))
asset_id_all = asset_id_all.split(',')
for asset_id in asset_id_all:
asset = get_object(Asset, id=asset_id)
if asset:
asset_list.append(asset)
asset_ansible_update(asset_list, name)
return HttpResponse(u'批量更新成功!')
return HttpResponse(u'批量更新成功!')
@require_role('admin')
2015-04-11 04:52:00 +00:00
def idc_add(request):
2015-12-19 09:26:34 +00:00
"""
IDC add view
"""
2015-03-04 15:14:07 +00:00
header_title, path1, path2 = u'添加IDC', u'资产管理', u'添加IDC'
2015-01-11 11:27:21 +00:00
if request.method == 'POST':
2015-12-19 09:26:34 +00:00
idc_form = IdcForm(request.POST)
if idc_form.is_valid():
idc_name = idc_form.cleaned_data['name']
2015-01-11 11:27:21 +00:00
2015-12-19 09:26:34 +00:00
if IDC.objects.filter(name=idc_name):
emg = u'添加失败, 此IDC %s 已存在!' % idc_name
return my_render('jasset/idc_add.html', locals(), request)
else:
idc_form.save()
smg = u'IDC: %s添加成功' % idc_name
return HttpResponseRedirect(reverse('idc_list'))
else:
idc_form = IdcForm()
2015-04-18 04:30:45 +00:00
return my_render('jasset/idc_add.html', locals(), request)
2015-12-19 09:26:34 +00:00
@require_role('admin')
2015-04-11 04:52:00 +00:00
def idc_list(request):
2015-12-19 09:26:34 +00:00
"""
IDC list view
"""
2015-03-04 15:14:07 +00:00
header_title, path1, path2 = u'查看IDC', u'资产管理', u'查看IDC'
2015-12-19 09:26:34 +00:00
posts = IDC.objects.all()
2015-03-12 10:54:26 +00:00
keyword = request.GET.get('keyword', '')
if keyword:
posts = IDC.objects.filter(Q(name__contains=keyword) | Q(comment__contains=keyword))
else:
2015-04-09 03:09:18 +00:00
posts = IDC.objects.exclude(name='ALL').order_by('id')
2015-03-07 09:37:40 +00:00
contact_list, p, contacts, page_range, current_page, show_first, show_end = pages(posts, request)
2015-04-18 04:30:45 +00:00
return my_render('jasset/idc_list.html', locals(), request)
2015-01-11 11:27:21 +00:00
2015-12-19 09:26:34 +00:00
@require_role('admin')
2015-04-11 04:52:00 +00:00
def idc_edit(request):
2015-12-19 09:26:34 +00:00
"""
IDC edit view
"""
2015-03-12 03:03:53 +00:00
header_title, path1, path2 = u'编辑IDC', u'资产管理', u'编辑IDC'
2015-04-16 11:03:02 +00:00
idc_id = request.GET.get('id', '')
2015-12-19 09:26:34 +00:00
idc = get_object(IDC, id=idc_id)
2015-03-12 03:03:53 +00:00
if request.method == 'POST':
2015-12-19 09:26:34 +00:00
idc_form = IdcForm(request.POST, instance=idc)
if idc_form.is_valid():
idc_form.save()
return HttpResponseRedirect(reverse('idc_list'))
2015-04-13 13:25:43 +00:00
else:
2015-12-19 09:26:34 +00:00
idc_form = IdcForm(instance=idc)
return my_render('jasset/idc_edit.html', locals(), request)
2015-04-13 13:25:43 +00:00
2015-12-19 09:26:34 +00:00
@require_role('admin')
2015-04-11 11:56:53 +00:00
def idc_del(request):
2015-12-19 09:26:34 +00:00
"""
IDC delete view
"""
idc_ids = request.GET.get('id', '')
idc_id_list = idc_ids.split(',')
2015-01-11 11:27:21 +00:00
2015-12-19 09:26:34 +00:00
for idc_id in idc_id_list:
IDC.objects.filter(id=idc_id).delete()
2015-12-19 09:26:34 +00:00
return HttpResponseRedirect(reverse('idc_list'))
2015-01-11 11:27:21 +00:00
2015-12-19 09:26:34 +00:00
@require_role('admin')
def asset_upload(request):
"""
Upload asset excel file view
"""
if request.method == 'POST':
2015-12-19 09:26:34 +00:00
excel_file = request.FILES.get('file_name', '')
ret = excel_to_db(excel_file)
if ret:
smg = u'批量添加成功'
else:
emg = u'批量添加失败,请检查格式.'
return my_render('jasset/asset_add_batch.html', locals(), request)