2020-07-07 20:49:31 +08:00
|
|
|
# The core application of the Mia project.
|
|
|
|
# by imacat <imacat@mail.imacat.idv.tw>, 2020/7/4
|
|
|
|
|
|
|
|
# Copyright (c) 2020 imacat.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
2020-07-08 07:24:36 +08:00
|
|
|
"""The views of the Mia core application.
|
2020-07-07 20:49:31 +08:00
|
|
|
|
|
|
|
"""
|
2020-08-09 14:07:47 +08:00
|
|
|
from django.contrib import messages
|
2020-07-06 23:06:45 +08:00
|
|
|
from django.contrib.auth import logout as logout_user
|
2020-08-09 14:07:47 +08:00
|
|
|
from django.contrib.messages.views import SuccessMessageMixin
|
2020-08-09 22:08:15 +08:00
|
|
|
from django.http import HttpResponse, JsonResponse
|
|
|
|
from django.shortcuts import redirect, render
|
2020-08-09 22:41:22 +08:00
|
|
|
from django.urls import reverse
|
2020-08-09 22:11:02 +08:00
|
|
|
from django.utils.decorators import method_decorator
|
2020-08-09 22:41:22 +08:00
|
|
|
from django.utils.translation import gettext_noop
|
2020-08-09 22:08:15 +08:00
|
|
|
from django.views.decorators.http import require_POST, require_GET
|
2020-08-09 20:47:53 +08:00
|
|
|
from django.views.generic import DeleteView as CoreDeleteView, ListView, \
|
|
|
|
DetailView
|
2020-08-09 20:22:37 +08:00
|
|
|
|
2020-08-09 22:08:15 +08:00
|
|
|
from . import stored_post
|
|
|
|
from .digest_auth import login_required
|
|
|
|
from .forms import UserForm
|
|
|
|
from .models import User
|
2020-08-09 22:41:22 +08:00
|
|
|
from .utils import strip_post
|
2020-08-09 14:07:47 +08:00
|
|
|
|
|
|
|
|
|
|
|
class DeleteView(SuccessMessageMixin, CoreDeleteView):
|
|
|
|
"""The delete form view, with SuccessMessageMixin."""
|
|
|
|
|
|
|
|
def delete(self, request, *args, **kwargs):
|
|
|
|
response = super(DeleteView, self).delete(request, *args, **kwargs)
|
|
|
|
messages.success(request, self.get_success_message({}))
|
|
|
|
return response
|
2020-07-06 23:22:20 +08:00
|
|
|
|
|
|
|
|
2020-07-06 23:04:14 +08:00
|
|
|
@require_POST
|
2020-07-06 23:06:45 +08:00
|
|
|
def logout(request):
|
2020-07-06 23:04:14 +08:00
|
|
|
"""The view to log out a user.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
request (HttpRequest): The request.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
HttpRedirectResponse: The redirect response.
|
|
|
|
"""
|
2020-07-06 23:06:45 +08:00
|
|
|
logout_user(request)
|
2020-07-06 23:04:14 +08:00
|
|
|
if "next" in request.POST:
|
|
|
|
request.session["logout"] = True
|
|
|
|
return redirect(request.POST["next"])
|
2020-08-09 19:08:47 +08:00
|
|
|
return redirect("home")
|
2020-07-09 23:18:37 +08:00
|
|
|
|
|
|
|
|
2020-08-09 22:11:02 +08:00
|
|
|
@method_decorator(require_GET, name="dispatch")
|
|
|
|
@method_decorator(login_required, name="dispatch")
|
2020-08-09 20:22:37 +08:00
|
|
|
class UserListView(ListView):
|
|
|
|
"""The view to list the users."""
|
|
|
|
queryset = User.objects.order_by("login_id")
|
|
|
|
|
|
|
|
|
2020-08-09 22:11:02 +08:00
|
|
|
@method_decorator(require_GET, name="dispatch")
|
|
|
|
@method_decorator(login_required, name="dispatch")
|
2020-08-09 20:47:53 +08:00
|
|
|
class UserView(DetailView):
|
|
|
|
"""The view of a user."""
|
|
|
|
def get_object(self, queryset=None):
|
|
|
|
return self.request.resolver_match.kwargs["user"]
|
|
|
|
|
|
|
|
|
2020-08-09 22:08:15 +08:00
|
|
|
@require_GET
|
|
|
|
@login_required
|
|
|
|
def user_form(request, user=None):
|
|
|
|
"""The view to edit an accounting transaction.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
request (HttpRequest): The request.
|
|
|
|
user (User): The account.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
HttpResponse: The response.
|
|
|
|
"""
|
|
|
|
previous_post = stored_post.get_previous_post(request)
|
|
|
|
if previous_post is not None:
|
|
|
|
form = UserForm(previous_post)
|
|
|
|
elif user is not None:
|
|
|
|
form = UserForm({
|
|
|
|
"login_id": user.login_id,
|
|
|
|
"name": user.name,
|
|
|
|
"is_disabled": user.is_disabled,
|
|
|
|
})
|
|
|
|
else:
|
|
|
|
form = UserForm()
|
|
|
|
form.user = user
|
|
|
|
form.current_user = request.user
|
|
|
|
return render(request, "mia_core/user_form.html", {
|
|
|
|
"form": form,
|
|
|
|
})
|
|
|
|
|
|
|
|
|
2020-08-09 22:41:22 +08:00
|
|
|
def user_store(request, user=None):
|
|
|
|
"""The view to store a user.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
request (HttpRequest): The request.
|
|
|
|
user (Account): The user.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
HttpResponseRedirect: The response.
|
|
|
|
"""
|
|
|
|
post = request.POST.dict()
|
|
|
|
strip_post(post)
|
|
|
|
form = UserForm(post)
|
|
|
|
form.user = user
|
|
|
|
form.current_user = request.user
|
|
|
|
if not form.is_valid():
|
|
|
|
if user is None:
|
|
|
|
url = reverse("mia_core:users.create")
|
|
|
|
else:
|
|
|
|
url = reverse("mia_core:users.edit", args=(user,))
|
|
|
|
return stored_post.error_redirect(request, url, post)
|
|
|
|
if user is None:
|
|
|
|
user = User()
|
|
|
|
user.login_id = form["login_id"].value()
|
|
|
|
if form["password"].value() is not None:
|
|
|
|
user.set_digest_password(
|
|
|
|
form["login_id"].value(), form["password"].value())
|
|
|
|
user.name = form["name"].value()
|
|
|
|
user.is_disabled = form["is_disabled"].value()
|
|
|
|
if not user.is_dirty():
|
2020-08-09 22:53:56 +08:00
|
|
|
message = gettext_noop("This user account was not changed.")
|
2020-08-09 22:41:22 +08:00
|
|
|
else:
|
|
|
|
user.save(current_user=request.user)
|
|
|
|
message = gettext_noop("This user account was saved successfully.")
|
|
|
|
messages.success(request, message)
|
|
|
|
return redirect("mia_core:users.detail", user)
|
|
|
|
|
|
|
|
|
2020-08-09 22:53:56 +08:00
|
|
|
@require_POST
|
|
|
|
@login_required
|
|
|
|
def user_delete(request, user):
|
|
|
|
"""The view to delete an user.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
request (HttpRequest): The request.
|
|
|
|
user (User): The user.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
HttpResponseRedirect: The response.
|
|
|
|
"""
|
|
|
|
message = None
|
|
|
|
if user.pk == request.user.pk:
|
|
|
|
message = gettext_noop("You cannot delete your own account.")
|
|
|
|
elif user.is_in_use():
|
|
|
|
message = gettext_noop(
|
|
|
|
"You cannot delete this account because it is in use.")
|
|
|
|
elif user.is_deleted:
|
|
|
|
message = gettext_noop("This account is already deleted.")
|
|
|
|
if message is not None:
|
|
|
|
messages.error(request, message)
|
|
|
|
return redirect("mia_core:users.detail", user)
|
|
|
|
user.delete()
|
|
|
|
message = gettext_noop("This user account was deleted successfully.")
|
|
|
|
messages.success(request, message)
|
|
|
|
return redirect("mia_core:users")
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-08-09 22:08:15 +08:00
|
|
|
def api_users_exists(request, login_id):
|
|
|
|
"""The view to check whether a user with a log in ID exists.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
request (HttpRequest): The request.
|
|
|
|
login_id (str): The log in ID.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
JsonResponse: The response.
|
|
|
|
"""
|
|
|
|
try:
|
|
|
|
User.objects.get(login_id=login_id)
|
|
|
|
except User.DoesNotExist:
|
|
|
|
return JsonResponse(False, safe=False)
|
|
|
|
return JsonResponse(True, safe=False)
|
|
|
|
|
|
|
|
|
2020-08-09 18:23:20 +08:00
|
|
|
# TODO: To be removed.
|
2020-07-14 09:59:56 +08:00
|
|
|
def todo(request, **kwargs):
|
2020-07-09 23:18:37 +08:00
|
|
|
"""A dummy placeholder view for the URL settings that are not
|
|
|
|
implemented yet.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
HttpResponse: A dummy response.
|
|
|
|
"""
|
|
|
|
return HttpResponse("TODO: To be done.")
|