mirror of
https://github.com/retspen/webvirtcloud
synced 2024-11-01 03:54:15 +00:00
144 lines
4.8 KiB
Python
144 lines
4.8 KiB
Python
from admin.decorators import superuser_only
|
|
from django.contrib import messages
|
|
from django.contrib.auth import update_session_auth_hash
|
|
from django.contrib.auth.decorators import permission_required
|
|
from django.contrib.auth.forms import PasswordChangeForm
|
|
from django.http import HttpResponseRedirect
|
|
from django.shortcuts import get_object_or_404, redirect, render
|
|
from django.urls import reverse
|
|
from django.utils.translation import ugettext_lazy as _
|
|
from instances.models import Instance
|
|
|
|
from accounts.models import *
|
|
|
|
from . import forms
|
|
from .utils import get_user_totp_device
|
|
|
|
|
|
def profile(request):
|
|
error_messages = []
|
|
publickeys = UserSSHKey.objects.filter(user_id=request.user.id)
|
|
|
|
if request.method == "POST":
|
|
if "username" in request.POST:
|
|
username = request.POST.get("username", "")
|
|
email = request.POST.get("email", "")
|
|
request.user.first_name = username
|
|
request.user.email = email
|
|
request.user.save()
|
|
return HttpResponseRedirect(request.get_full_path())
|
|
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)
|
|
if "\n" in keypublic or "\r" in keypublic:
|
|
msg = _("Invalid characters in public key")
|
|
error_messages.append(msg)
|
|
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())
|
|
return render(request, "profile.html", locals())
|
|
|
|
|
|
@superuser_only
|
|
def account(request, user_id):
|
|
error_messages = []
|
|
user = User.objects.get(id=user_id)
|
|
user_insts = UserInstance.objects.filter(user_id=user_id)
|
|
instances = Instance.objects.all().order_by("name")
|
|
publickeys = UserSSHKey.objects.filter(user_id=user_id)
|
|
if settings.OTP_ENABLED:
|
|
device = get_user_totp_device(user)
|
|
if not device:
|
|
device = user.totpdevice_set.create()
|
|
totp_url = device.config_url
|
|
|
|
return render(request, "account.html", locals())
|
|
|
|
|
|
@permission_required("accounts.change_password", raise_exception=True)
|
|
def change_password(request):
|
|
if request.method == "POST":
|
|
form = PasswordChangeForm(request.user, request.POST)
|
|
if form.is_valid():
|
|
user = form.save()
|
|
update_session_auth_hash(request, user) # Important!
|
|
messages.success(request, _("Password Changed"))
|
|
return redirect("profile")
|
|
else:
|
|
messages.error(request, _("Wrong Data Provided"))
|
|
else:
|
|
form = PasswordChangeForm(request.user)
|
|
return render(request, "accounts/change_password_form.html", {"form": form})
|
|
|
|
|
|
@superuser_only
|
|
def user_instance_create(request, user_id):
|
|
user = get_object_or_404(User, pk=user_id)
|
|
|
|
form = forms.UserInstanceForm(request.POST or None, initial={"user": user})
|
|
if form.is_valid():
|
|
form.save()
|
|
return redirect(reverse("account", args=[user.id]))
|
|
|
|
return render(
|
|
request,
|
|
"common/form.html",
|
|
{
|
|
"form": form,
|
|
"title": _("Create User Instance"),
|
|
},
|
|
)
|
|
|
|
|
|
@superuser_only
|
|
def user_instance_update(request, pk):
|
|
user_instance = get_object_or_404(UserInstance, pk=pk)
|
|
form = forms.UserInstanceForm(request.POST or None, instance=user_instance)
|
|
if form.is_valid():
|
|
form.save()
|
|
return redirect(reverse("account", args=[user_instance.user.id]))
|
|
|
|
return render(
|
|
request,
|
|
'common/form.html',
|
|
{
|
|
"form": form,
|
|
"title": _("Update User Instance"),
|
|
},
|
|
)
|
|
|
|
|
|
@superuser_only
|
|
def user_instance_delete(request, pk):
|
|
user_instance = get_object_or_404(UserInstance, pk=pk)
|
|
if request.method == "POST":
|
|
user = user_instance.user
|
|
user_instance.delete()
|
|
next = request.GET.get("next", None)
|
|
if next:
|
|
return redirect(next)
|
|
else:
|
|
return redirect(reverse("account", args=[user.id]))
|
|
|
|
return render(
|
|
request,
|
|
"common/confirm_delete.html",
|
|
{"object": user_instance},
|
|
)
|