views.py 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. from django.core.urlresolvers import reverse as django_reverse
  2. from django import forms
  3. from django.utils.translation import ugettext as _
  4. from misago.admin import site
  5. from misago.admin.widgets import *
  6. from misago.forms import Form
  7. from misago.utils import slugify
  8. from misago.users.admin.roles.forms import RoleForm
  9. from misago.acl.models import Role
  10. def reverse(route, target=None):
  11. if target:
  12. return django_reverse(route, kwargs={'target': target.pk, 'slug': slugify(target.name)})
  13. return django_reverse(route)
  14. """
  15. Views
  16. """
  17. class List(ListWidget):
  18. admin = site.get_action('roles')
  19. id = 'list'
  20. columns=(
  21. ('role', _("Role")),
  22. )
  23. table_form_button = _('Reorder Roles')
  24. nothing_checked_message = _('You have to check at least one role.')
  25. actions=(
  26. ('delete', _("Delete selected roles"), _("Are you sure you want to delete selected roles?")),
  27. )
  28. def sort_items(self, request, page_items, sorting_method):
  29. return page_items.order_by('name')
  30. def get_item_actions(self, request, item):
  31. return (
  32. self.action('pencil', _("Edit Role"), reverse('admin_users_roles_edit', item)),
  33. self.action('remove', _("Delete Role"), reverse('admin_users_roles_delete', item), post=True, prompt=_("Are you sure you want to delete this role?")),
  34. )
  35. def action_delete(self, request, items, checked):
  36. for item in items:
  37. if unicode(item.pk) in checked:
  38. if item.token:
  39. return BasicMessage(_('You cannot delete system roles.'), 'error'), reverse('admin_users_roles')
  40. if item.protected and not request.user.is_god():
  41. return BasicMessage(_('You cannot delete protected roles.'), 'error'), reverse('admin_users_roles')
  42. if item.user_set.count() > 0:
  43. return BasicMessage(_('You cannot delete roles that are assigned to users.'), 'error'), reverse('admin_users_roles')
  44. Role.objects.filter(id__in=checked).delete()
  45. return BasicMessage(_('Selected roles have been deleted successfully.'), 'success'), reverse('admin_users_roles')
  46. class New(FormWidget):
  47. admin = site.get_action('roles')
  48. id = 'new'
  49. fallback = 'admin_users_roles'
  50. form = RoleForm
  51. submit_button = _("Save Role")
  52. def get_new_url(self, request, model):
  53. return reverse('admin_users_roles')
  54. def get_edit_url(self, request, model):
  55. return reverse('admin_users_roles_edit', model)
  56. def submit_form(self, request, form, target):
  57. new_role = Role(
  58. name = form.cleaned_data['name'],
  59. )
  60. new_role.save(force_insert=True)
  61. return new_role, BasicMessage(_('New Role has been created.'), 'success')
  62. class Edit(FormWidget):
  63. admin = site.get_action('roles')
  64. id = 'edit'
  65. name = _("Edit Role")
  66. fallback = 'admin_users_roles'
  67. form = RoleForm
  68. target_name = 'name'
  69. notfound_message = _('Requested Role could not be found.')
  70. submit_fallback = True
  71. def get_url(self, request, model):
  72. return reverse('admin_users_roles_edit', model)
  73. def get_edit_url(self, request, model):
  74. return self.get_url(request, model)
  75. def get_initial_data(self, request, model):
  76. return {
  77. 'name': model.name,
  78. }
  79. def submit_form(self, request, form, target):
  80. target.name = form.cleaned_data['name']
  81. target.save(force_update=True)
  82. return target, BasicMessage(_('Changes in role "%(name)s" have been saved.' % {'name': self.original_name}), 'success')
  83. class Delete(ButtonWidget):
  84. admin = site.get_action('roles')
  85. id = 'delete'
  86. fallback = 'admin_users_roles'
  87. notfound_message = _('Requested role could not be found.')
  88. def action(self, request, target):
  89. if target.token:
  90. return BasicMessage(_('You cannot delete system roles.'), 'error'), reverse('admin_users_roles')
  91. if target.protected and not request.user.is_god():
  92. return BasicMessage(_('This role is protected.'), 'error'), reverse('admin_users_roles')
  93. if target.user_set.count() > 0:
  94. return BasicMessage(_('This role is assigned to one or more usets.'), 'error'), reverse('admin_users_roles')
  95. target.delete()
  96. return BasicMessage(_('Role "%(name)s" has been deleted.' % {'name': target.name}), 'success'), False