1
0
Fork 0
mirror of https://github.com/retspen/webvirtcloud synced 2025-01-26 15:15:20 +00:00
webvirtcloud/accounts/views.py

137 lines
5.8 KiB
Python
Raw Normal View History

from django.conf import settings
from django.core.validators import ValidationError
2015-03-03 09:34:09 +00:00
from django.http import HttpResponseRedirect
from django.shortcuts import render
from django.urls import reverse
2015-03-11 09:39:44 +00:00
from django.utils.translation import ugettext_lazy as _
from accounts.forms import UserAddForm
from accounts.models import *
from admin.decorators import superuser_only
2015-03-11 09:39:44 +00:00
from instances.models import Instance
2020-05-19 16:53:54 +00:00
import sass
import os
2015-03-02 08:52:07 +00:00
2015-03-18 15:13:44 +00:00
def profile(request):
"""
:param request:
:return:
"""
2015-03-24 12:45:38 +00:00
error_messages = []
# user = User.objects.get(id=request.user.id)
2015-05-27 11:10:57 +00:00
publickeys = UserSSHKey.objects.filter(user_id=request.user.id)
2015-03-24 12:45:38 +00:00
2020-05-19 16:53:54 +00:00
themes_list = os.listdir(settings.SCSS_DIR +"/wvc-theme")
2015-03-24 12:45:38 +00:00
if request.method == 'POST':
if 'username' in request.POST:
username = request.POST.get('username', '')
email = request.POST.get('email', '')
user.first_name = username
user.email = email
request.user.save()
2015-03-24 12:45:38 +00:00
return HttpResponseRedirect(request.get_full_path())
if 'oldpasswd' in request.POST:
oldpasswd = request.POST.get('oldpasswd', '')
password1 = request.POST.get('passwd1', '')
password2 = request.POST.get('passwd2', '')
2015-03-25 09:36:37 +00:00
if not password1 or not password2:
error_messages.append("Passwords didn't enter")
2015-03-24 12:45:38 +00:00
if password1 and password2 and password1 != password2:
error_messages.append("Passwords don't match")
if not request.user.check_password(oldpasswd):
2015-03-24 12:45:38 +00:00
error_messages.append("Old password is wrong!")
if not error_messages:
request.user.set_password(password1)
request.user.save()
2015-03-24 12:45:38 +00:00
return HttpResponseRedirect(request.get_full_path())
2015-05-27 11:10:57 +00:00
if 'keyname' in request.POST:
keyname = request.POST.get('keyname', '')
keypublic = request.POST.get('keypublic', '')
for key in publickeys:
if keyname == key.keyname:
msg = _("Key name already exist")
error_messages.append(msg)
if keypublic == key.keypublic:
msg = _("Public key already exist")
error_messages.append(msg)
2018-07-26 09:33:12 +00:00
if '\n' in keypublic or '\r' in keypublic:
msg = _("Invalid characters in public key")
error_messages.append(msg)
2015-05-27 11:10:57 +00:00
if not error_messages:
addkeypublic = UserSSHKey(user_id=request.user.id, keyname=keyname, keypublic=keypublic)
addkeypublic.save()
return HttpResponseRedirect(request.get_full_path())
if 'keydelete' in request.POST:
keyid = request.POST.get('keyid', '')
delkeypublic = UserSSHKey.objects.get(id=keyid)
delkeypublic.delete()
return HttpResponseRedirect(request.get_full_path())
2020-05-19 16:53:54 +00:00
if 'change_theme' in request.POST:
theme = request.POST.get('theme_select', '')
scss_var = f"@import '{settings.SCSS_DIR}/wvc-theme/{theme}/variables';"
scss_bootswatch = f"@import '{settings.SCSS_DIR}/wvc-theme/{theme}/bootswatch';"
scss_boot = f"@import '{settings.SCSS_DIR}/bootstrap-overrides.scss';"
with open(settings.SCSS_DIR + "/wvc-main.scss", "w") as main:
main.write(scss_var + "\n" + scss_boot + "\n" + scss_bootswatch)
css_compressed = sass.compile(string=scss_var + "\n"+ scss_boot + "\n" + scss_bootswatch, output_style='compressed')
with open("static/" + "css/wvc-main.min.css", "w") as css:
css.write(css_compressed)
return HttpResponseRedirect(request.get_full_path())
2015-04-02 13:20:46 +00:00
return render(request, 'profile.html', locals())
2015-03-18 15:13:44 +00:00
2019-09-10 06:48:31 +00:00
@superuser_only
2015-03-18 15:13:44 +00:00
def account(request, user_id):
2015-03-02 08:52:07 +00:00
"""
:param request:
2019-09-10 06:48:31 +00:00
:param user_id:
2015-03-02 08:52:07 +00:00
:return:
"""
2015-03-11 09:39:44 +00:00
error_messages = []
2015-03-02 08:52:07 +00:00
user = User.objects.get(id=user_id)
2015-03-10 14:24:10 +00:00
user_insts = UserInstance.objects.filter(user_id=user_id)
instances = Instance.objects.all().order_by('name')
publickeys = UserSSHKey.objects.filter(user_id=user_id)
2015-03-10 14:24:10 +00:00
if request.method == 'POST':
if 'delete' in request.POST:
user_inst = request.POST.get('user_inst', '')
del_user_inst = UserInstance.objects.get(id=user_inst)
del_user_inst.delete()
return HttpResponseRedirect(request.get_full_path())
2015-03-16 13:46:44 +00:00
if 'permission' in request.POST:
2015-03-10 14:24:10 +00:00
user_inst = request.POST.get('user_inst', '')
inst_vnc = request.POST.get('inst_vnc', '')
2015-03-10 14:24:10 +00:00
inst_change = request.POST.get('inst_change', '')
inst_delete = request.POST.get('inst_delete', '')
edit_user_inst = UserInstance.objects.get(id=user_inst)
edit_user_inst.is_change = bool(inst_change)
edit_user_inst.is_delete = bool(inst_delete)
edit_user_inst.is_vnc = bool(inst_vnc)
2015-03-10 14:24:10 +00:00
edit_user_inst.save()
return HttpResponseRedirect(request.get_full_path())
2015-03-11 09:39:44 +00:00
if 'add' in request.POST:
inst_id = request.POST.get('inst_id', '')
if settings.ALLOW_INSTANCE_MULTIPLE_OWNER:
check_inst = UserInstance.objects.filter(instance_id=int(inst_id), user_id=int(user_id))
else:
check_inst = UserInstance.objects.filter(instance_id=int(inst_id))
if check_inst:
2015-03-11 09:39:44 +00:00
msg = _("Instance already added")
error_messages.append(msg)
else:
add_user_inst = UserInstance(instance_id=int(inst_id), user_id=int(user_id))
2015-03-11 09:39:44 +00:00
add_user_inst.save()
return HttpResponseRedirect(request.get_full_path())
2015-03-02 08:52:07 +00:00
2015-04-02 13:20:46 +00:00
return render(request, 'account.html', locals())