mirror of
https://github.com/retspen/webvirtcloud
synced 2024-11-01 12:04:15 +00:00
157 lines
No EOL
6.5 KiB
Python
157 lines
No EOL
6.5 KiB
Python
from django.http import HttpResponseRedirect
|
|
from django.core.urlresolvers import reverse
|
|
from django.shortcuts import render
|
|
from computes.models import Compute
|
|
from instances.models import Instance
|
|
from users.models import UserInstance
|
|
from computes.forms import ComputeAddTcpForm, ComputeAddSshForm, ComputeEditHostForm, ComputeAddTlsForm, ComputeAddSocketForm
|
|
from vrtManager.hostdetails import wvmHostDetails
|
|
from vrtManager.connection import CONN_SSH, CONN_TCP, CONN_TLS, CONN_SOCKET, connection_manager
|
|
from libvirt import libvirtError
|
|
|
|
|
|
def computes(request):
|
|
"""
|
|
:param request:
|
|
:return:
|
|
"""
|
|
|
|
if not request.user.is_authenticated():
|
|
return HttpResponseRedirect(reverse('index'))
|
|
|
|
if not request.user.is_superuser:
|
|
return HttpResponseRedirect(reverse('index'))
|
|
|
|
def get_hosts_status(computes):
|
|
"""
|
|
Function return all hosts all vds on host
|
|
"""
|
|
compute_data = []
|
|
for compute in computes:
|
|
compute_data.append({'id': compute.id,
|
|
'name': compute.name,
|
|
'hostname': compute.hostname,
|
|
'status': connection_manager.host_is_up(compute.type, compute.hostname),
|
|
'type': compute.type,
|
|
'login': compute.login,
|
|
'password': compute.password
|
|
})
|
|
return compute_data
|
|
|
|
error_messages = []
|
|
computes = Compute.objects.filter()
|
|
computes_info = get_hosts_status(computes)
|
|
|
|
if request.method == 'POST':
|
|
if 'host_del' in request.POST:
|
|
compute_id = request.POST.get('host_id', '')
|
|
try:
|
|
del_user_inst_on_host = UserInstance.objects.filter(compute_id=compute_id)
|
|
del_user_inst_on_host.save()
|
|
finally:
|
|
try:
|
|
del_inst_on_host = Instance.objects.filter(compute_id=compute_id)
|
|
del_inst_on_host.delete()
|
|
finally:
|
|
del_host = Compute.objects.get(id=compute_id)
|
|
del_host.delete()
|
|
return HttpResponseRedirect(request.get_full_path())
|
|
if 'host_tcp_add' in request.POST:
|
|
form = ComputeAddTcpForm(request.POST)
|
|
if form.is_valid():
|
|
data = form.cleaned_data
|
|
new_tcp_host = Compute(name=data['name'],
|
|
hostname=data['hostname'],
|
|
type=CONN_TCP,
|
|
login=data['login'],
|
|
password=data['password'])
|
|
new_tcp_host.save()
|
|
return HttpResponseRedirect(request.get_full_path())
|
|
else:
|
|
for msg_err in form.errors.values():
|
|
error_messages.append(msg_err.as_text())
|
|
if 'host_ssh_add' in request.POST:
|
|
form = ComputeAddSshForm(request.POST)
|
|
if form.is_valid():
|
|
data = form.cleaned_data
|
|
new_ssh_host = Compute(name=data['name'],
|
|
hostname=data['hostname'],
|
|
type=CONN_SSH,
|
|
login=data['login'])
|
|
new_ssh_host.save()
|
|
return HttpResponseRedirect(request.get_full_path())
|
|
else:
|
|
for msg_err in form.errors.values():
|
|
error_messages.append(msg_err.as_text())
|
|
if 'host_tls_add' in request.POST:
|
|
form = ComputeAddTlsForm(request.POST)
|
|
if form.is_valid():
|
|
data = form.cleaned_data
|
|
new_tls_host = Compute(name=data['name'],
|
|
hostname=data['hostname'],
|
|
type=CONN_TLS,
|
|
login=data['login'],
|
|
password=data['password'])
|
|
new_tls_host.save()
|
|
return HttpResponseRedirect(request.get_full_path())
|
|
else:
|
|
for msg_err in form.errors.values():
|
|
error_messages.append(msg_err.as_text())
|
|
if 'host_socket_add' in request.POST:
|
|
form = ComputeAddSocketForm(request.POST)
|
|
if form.is_valid():
|
|
data = form.cleaned_data
|
|
new_socket_host = Compute(name=data['name'],
|
|
hostname='localhost',
|
|
type=CONN_SOCKET,
|
|
login='',
|
|
password='')
|
|
new_socket_host.save()
|
|
return HttpResponseRedirect(request.get_full_path())
|
|
else:
|
|
for msg_err in form.errors.values():
|
|
error_messages.append(msg_err.as_text())
|
|
if 'host_edit' in request.POST:
|
|
form = ComputeEditHostForm(request.POST)
|
|
if form.is_valid():
|
|
data = form.cleaned_data
|
|
compute_edit = Compute.objects.get(id=data['host_id'])
|
|
compute_edit.name = data['name']
|
|
compute_edit.hostname = data['hostname']
|
|
compute_edit.login = data['login']
|
|
compute_edit.password = data['password']
|
|
compute_edit.save()
|
|
return HttpResponseRedirect(request.get_full_path())
|
|
else:
|
|
for msg_err in form.errors.values():
|
|
error_messages.append(msg_err.as_text())
|
|
return render(request, 'computes.html', locals())
|
|
|
|
def overview(request, compute_id):
|
|
"""
|
|
:param request:
|
|
:return:
|
|
"""
|
|
|
|
if not request.user.is_authenticated():
|
|
return HttpResponseRedirect(reverse('index'))
|
|
|
|
if not request.user.is_superuser:
|
|
return HttpResponseRedirect(reverse('index'))
|
|
|
|
error_messages = []
|
|
compute = Compute.objects.get(id=compute_id)
|
|
|
|
try:
|
|
conn = wvmHostDetails(compute.hostname,
|
|
compute.login,
|
|
compute.password,
|
|
compute.type)
|
|
hostname, host_arch, host_memory, logical_cpu, model_cpu, uri_conn = conn.get_node_info()
|
|
hypervisor = conn.hypervisor_type()
|
|
mem_usage = conn.get_memory_usage()
|
|
conn.close()
|
|
except libvirtError as lib_err:
|
|
error_messages.append(lib_err)
|
|
|
|
return render(request, 'overview.html', locals()) |