Files
mayan-edms/mayan/apps/user_management/views.py
Roberto Rosario 111250fd99 Update usage of "an user"
Signed-off-by: Roberto Rosario <roberto.rosario.gonzalez@gmail.com>
2019-06-15 02:17:55 -04:00

331 lines
10 KiB
Python

from __future__ import absolute_import, unicode_literals
from django.contrib import messages
from django.contrib.auth.models import Group
from django.http import HttpResponseRedirect
from django.shortcuts import get_object_or_404
from django.template import RequestContext
from django.urls import reverse, reverse_lazy
from django.utils.translation import ungettext, ugettext_lazy as _
from mayan.apps.common.generics import (
AddRemoveView, MultipleObjectConfirmActionView,
SingleObjectCreateView, SingleObjectDeleteView, SingleObjectDetailView,
SingleObjectEditView, SingleObjectListView
)
from .forms import UserForm
from .icons import icon_group_setup, icon_user_setup
from .links import link_group_create, link_user_create
from .permissions import (
permission_group_create, permission_group_delete, permission_group_edit,
permission_group_view, permission_user_create, permission_user_delete,
permission_user_edit, permission_user_view
)
from .querysets import get_user_queryset
class CurrentUserDetailsView(SingleObjectDetailView):
fields = (
'username', 'first_name', 'last_name', 'email', 'last_login',
'date_joined', 'groups'
)
def get_extra_context(self, **kwargs):
return {
'object': None,
'title': _('Current user details'),
}
def get_object(self):
return self.request.user
class CurrentUserEditView(SingleObjectEditView):
extra_context = {'object': None, 'title': _('Edit current user details')}
form_class = UserForm
post_action_redirect = reverse_lazy(
viewname='user_management:current_user_details'
)
def get_object(self):
return self.request.user
class GroupCreateView(SingleObjectCreateView):
extra_context = {'title': _('Create new group')}
fields = ('name',)
model = Group
post_action_redirect = reverse_lazy(
viewname='user_management:group_list'
)
view_permission = permission_group_create
def get_save_extra_data(self):
return {'_user': self.request.user}
class GroupDeleteView(SingleObjectDeleteView):
model = Group
object_permission = permission_group_delete
post_action_redirect = reverse_lazy(
viewname='user_management:group_list'
)
def get_extra_context(self):
return {
'object': self.get_object(),
'title': _('Delete the group: %s?') % self.get_object(),
}
class GroupEditView(SingleObjectEditView):
fields = ('name',)
model = Group
object_permission = permission_group_edit
post_action_redirect = reverse_lazy(
viewname='user_management:group_list'
)
def get_extra_context(self):
return {
'object': self.get_object(),
'title': _('Edit group: %s') % self.get_object(),
}
def get_save_extra_data(self):
return {'_user': self.request.user}
class GroupListView(SingleObjectListView):
model = Group
object_permission = permission_group_view
def get_extra_context(self):
return {
'hide_link': True,
'hide_object': True,
'no_results_icon': icon_group_setup,
'no_results_main_link': link_group_create.resolve(
context=RequestContext(request=self.request)
),
'no_results_text': _(
'User groups are organizational units. They should '
'mirror the organizational units of your organization. '
'Groups can\'t be used for access control. Use roles '
'for permissions and access control, add groups to '
'them.'
),
'no_results_title': _('There are no user groups'),
'title': _('Groups'),
}
class GroupUsersView(AddRemoveView):
main_object_method_add = 'users_add'
main_object_method_remove = 'users_remove'
main_object_model = Group
main_object_permission = permission_group_edit
main_object_pk_url_kwarg = 'pk'
secondary_object_permission = permission_user_edit
secondary_object_source_queryset = get_user_queryset()
list_available_title = _('Available users')
list_added_title = _('Group users')
def get_actions_extra_kwargs(self):
return {'_user': self.request.user}
def get_extra_context(self):
return {
'object': self.main_object,
'title': _('Users of group: %s') % self.main_object,
}
def get_list_added_queryset(self):
return self.main_object.get_users(
permission=permission_user_edit, user=self.request.user
)
class UserCreateView(SingleObjectCreateView):
extra_context = {
'title': _('Create new user'),
}
form_class = UserForm
view_permission = permission_user_create
def form_valid(self, form):
super(UserCreateView, self).form_valid(form=form)
return HttpResponseRedirect(
reverse(
viewname='authentication:user_set_password',
kwargs={'pk': self.object.pk}
)
)
def get_save_extra_data(self):
return {'_user': self.request.user}
class UserDeleteView(MultipleObjectConfirmActionView):
object_permission = permission_user_delete
source_queryset = get_user_queryset()
success_message = _('User delete request performed on %(count)d user')
success_message_plural = _(
'User delete request performed on %(count)d users'
)
def get_extra_context(self):
queryset = self.object_list
result = {
'title': ungettext(
singular='Delete user',
plural='Delete users',
number=queryset.count()
)
}
if queryset.count() == 1:
result.update(
{
'object': queryset.first(),
'title': _('Delete user: %s') % queryset.first()
}
)
return result
def object_action(self, form, instance):
try:
if instance.is_superuser or instance.is_staff:
messages.error(
message=_(
'Super user and staff user deleting is not '
'allowed, use the admin interface for these cases.'
), request=self.request
)
else:
instance.delete()
messages.success(
message=_(
'User "%s" deleted successfully.'
) % instance, request=self.request
)
except Exception as exception:
messages.error(
message=_(
'Error deleting user "%(user)s": %(error)s'
) % {'user': instance, 'error': exception},
request=self.request
)
class UserDetailsView(SingleObjectDetailView):
fields = (
'username', 'first_name', 'last_name', 'email', 'last_login',
'date_joined', 'groups',
)
object_permission = permission_user_view
pk_url_kwarg = 'pk'
source_queryset = get_user_queryset()
def get_extra_context(self, **kwargs):
return {
'object': self.get_object(),
'title': _('Details of user: %s') % self.get_object()
}
class UserEditView(SingleObjectEditView):
fields = ('username', 'first_name', 'last_name', 'email', 'is_active',)
object_permission = permission_user_edit
post_action_redirect = reverse_lazy(
viewname='user_management:user_list'
)
source_queryset = get_user_queryset()
def get_extra_context(self):
return {
'object': self.get_object(),
'title': _('Edit user: %s') % self.get_object(),
}
def get_save_extra_data(self):
return {'_user': self.request.user}
class UserGroupsView(AddRemoveView):
main_object_method_add = 'groups_add'
main_object_method_remove = 'groups_remove'
main_object_permission = permission_user_edit
main_object_source_queryset = get_user_queryset()
main_object_pk_url_kwarg = 'pk'
secondary_object_model = Group
secondary_object_permission = permission_group_edit
list_available_title = _('Available groups')
# Translators: "User groups" here refer to the group list of a specific
# user.
list_added_title = _('User groups')
def get_actions_extra_kwargs(self):
return {'_user': self.request.user}
def get_extra_context(self):
return {
'object': self.main_object,
'title': _('Groups of user: %s') % self.main_object,
}
def get_list_added_queryset(self):
return self.main_object.get_groups(
permission=permission_group_edit, user=self.request.user
)
class UserListView(SingleObjectListView):
object_permission = permission_user_view
def get_extra_context(self):
return {
'hide_link': True,
'hide_object': True,
'no_results_icon': icon_user_setup,
'no_results_main_link': link_user_create.resolve(
context=RequestContext(request=self.request)
),
'no_results_text': _(
'User accounts can be create from this view. After creating '
'a user account you will prompted to set a password for it. '
),
'no_results_title': _('There are no user accounts'),
'title': _('Users'),
}
def get_source_queryset(self):
return get_user_queryset()
class UserOptionsEditView(SingleObjectEditView):
fields = ('block_password_change',)
object_permission = permission_user_edit
def get_extra_context(self):
return {
'title': _(
'Edit options for user: %s'
) % self.get_user(),
'object': self.get_user()
}
def get_object(self, queryset=None):
return self.get_user().user_options
def get_post_action_redirect(self):
return reverse(viewname='user_management:user_list')
def get_user(self):
return get_object_or_404(
klass=get_user_queryset(), pk=self.kwargs['pk']
)