Jan Dittberner
4af1a39ca4
- update dependencies - fix deprecation warnings - fix tests - skip some tests that need more work - reformat changed code with isort and black
133 lines
4.1 KiB
Python
133 lines
4.1 KiB
Python
"""
|
|
This module defines views for user database handling.
|
|
|
|
"""
|
|
from __future__ import absolute_import
|
|
|
|
from django.contrib import messages
|
|
from django.core.exceptions import SuspiciousOperation
|
|
from django.shortcuts import redirect
|
|
from django.utils.translation import gettext as _
|
|
from django.views.generic.edit import CreateView, DeleteView, UpdateView
|
|
from gvacommon.viewmixins import StaffOrSelfLoginRequiredMixin
|
|
|
|
from gvawebcore.views import HostingPackageAndCustomerMixin
|
|
|
|
from .forms import AddUserDatabaseForm, ChangeDatabaseUserPasswordForm
|
|
from .models import DB_TYPES, DatabaseUser, UserDatabase
|
|
|
|
|
|
class AddUserDatabase(
|
|
HostingPackageAndCustomerMixin, StaffOrSelfLoginRequiredMixin, CreateView
|
|
):
|
|
"""
|
|
This view is used to setup new user databases.
|
|
|
|
"""
|
|
|
|
model = UserDatabase
|
|
context_object_name = "database"
|
|
template_name_suffix = "_create"
|
|
form_class = AddUserDatabaseForm
|
|
|
|
def _get_dbtypes(self, hostingpackage):
|
|
retval = []
|
|
db_options = hostingpackage.get_databases()
|
|
for opt in db_options:
|
|
dbs_of_type = UserDatabase.objects.filter(
|
|
db_user__osuser=hostingpackage.osuser, db_user__db_type=opt["db_type"]
|
|
).count()
|
|
if dbs_of_type < opt["number"]:
|
|
retval.append((opt["db_type"], DB_TYPES[opt["db_type"]]))
|
|
if len(retval) < 1:
|
|
raise SuspiciousOperation(
|
|
_("The hosting package has no database products assigned.")
|
|
)
|
|
return retval
|
|
|
|
def get_form_kwargs(self):
|
|
kwargs = super(AddUserDatabase, self).get_form_kwargs()
|
|
kwargs["hostingpackage"] = self.get_hosting_package()
|
|
kwargs["dbtypes"] = self._get_dbtypes(kwargs["hostingpackage"])
|
|
return kwargs
|
|
|
|
def form_valid(self, form):
|
|
userdatabase = form.save()
|
|
messages.success(
|
|
self.request,
|
|
_(
|
|
"Successfully create new {type} database {dbname} for user " "{dbuser}."
|
|
).format(
|
|
type=userdatabase.db_user.db_type,
|
|
dbname=userdatabase.db_name,
|
|
dbuser=userdatabase.db_user,
|
|
),
|
|
)
|
|
return redirect(self.get_hosting_package())
|
|
|
|
|
|
class ChangeDatabaseUserPassword(
|
|
HostingPackageAndCustomerMixin, StaffOrSelfLoginRequiredMixin, UpdateView
|
|
):
|
|
"""
|
|
This view is used to change a database user's password.
|
|
|
|
"""
|
|
|
|
model = DatabaseUser
|
|
slug_field = "name"
|
|
context_object_name = "dbuser"
|
|
template_name_suffix = "_setpassword"
|
|
form_class = ChangeDatabaseUserPasswordForm
|
|
|
|
def get_form_kwargs(self):
|
|
kwargs = super(ChangeDatabaseUserPassword, self).get_form_kwargs()
|
|
kwargs["hostingpackage"] = self.get_hosting_package()
|
|
return kwargs
|
|
|
|
def get_context_data(self, **kwargs):
|
|
context = super(ChangeDatabaseUserPassword, self).get_context_data(**kwargs)
|
|
context["hostingpackage"] = self.get_hosting_package()
|
|
context["customer"] = self.get_customer_object()
|
|
return context
|
|
|
|
def form_valid(self, form):
|
|
db_user = form.save()
|
|
messages.success(
|
|
self.request,
|
|
_("Successfully changed password of database user {dbuser}.").format(
|
|
dbuser=db_user.name
|
|
),
|
|
)
|
|
return redirect(self.get_hosting_package())
|
|
|
|
|
|
class DeleteUserDatabase(
|
|
HostingPackageAndCustomerMixin, StaffOrSelfLoginRequiredMixin, DeleteView
|
|
):
|
|
"""
|
|
This view is used to delete user databases and databases users if they have
|
|
no more databases assigned.
|
|
|
|
"""
|
|
|
|
model = UserDatabase
|
|
slug_field = "db_name"
|
|
context_object_name = "database"
|
|
|
|
def get_context_data(self, **kwargs):
|
|
context = super(DeleteUserDatabase, self).get_context_data(**kwargs)
|
|
context.update(
|
|
{
|
|
"hostingpackage": self.get_hosting_package(),
|
|
"customer": self.get_customer_object(),
|
|
}
|
|
)
|
|
return context
|
|
|
|
def get_success_url(self):
|
|
messages.success(
|
|
self.request,
|
|
_("Database deleted."),
|
|
)
|
|
return self.get_hosting_package().get_absolute_url()
|