views.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. from django.core.urlresolvers import reverse as django_reverse
  2. from django.utils.translation import ugettext as _
  3. from misago.acl.builder import build_form
  4. from misago.admin import site
  5. from misago.admin.widgets import *
  6. from misago.utils import slugify
  7. from misago.roles.forms import RoleForm, PermsForm
  8. from misago.roles.models import Role
  9. def reverse(route, target=None):
  10. if target:
  11. return django_reverse(route, kwargs={'target': target.pk, 'slug': slugify(target.name)})
  12. return django_reverse(route)
  13. """
  14. Views
  15. """
  16. class List(ListWidget):
  17. admin = site.get_action('roles')
  18. id = 'list'
  19. columns=(
  20. ('role', _("Role")),
  21. )
  22. nothing_checked_message = _('You have to check at least one role.')
  23. actions=(
  24. ('delete', _("Delete selected roles"), _("Are you sure you want to delete selected roles?")),
  25. )
  26. def sort_items(self, request, page_items, sorting_method):
  27. return page_items.order_by('name')
  28. def get_item_actions(self, request, item):
  29. return (
  30. self.action('adjust', _("Role Permissions"), reverse('admin_roles_acl', item)),
  31. self.action('pencil', _("Edit Role"), reverse('admin_roles_edit', item)),
  32. self.action('remove', _("Delete Role"), reverse('admin_roles_delete', item), post=True, prompt=_("Are you sure you want to delete this role?")),
  33. )
  34. def action_delete(self, request, items, checked):
  35. for item in items:
  36. if unicode(item.pk) in checked:
  37. if item.token:
  38. return Message(_('You cannot delete system roles.'), 'error'), reverse('admin_roles')
  39. if item.protected and not request.user.is_god():
  40. return Message(_('You cannot delete protected roles.'), 'error'), reverse('admin_roles')
  41. if item.user_set.count() > 0:
  42. return Message(_('You cannot delete roles that are assigned to users.'), 'error'), reverse('admin_roles')
  43. Role.objects.filter(id__in=checked).delete()
  44. return Message(_('Selected roles have been deleted successfully.'), 'success'), reverse('admin_roles')
  45. class New(FormWidget):
  46. admin = site.get_action('roles')
  47. id = 'new'
  48. fallback = 'admin_roles'
  49. form = RoleForm
  50. submit_button = _("Save Role")
  51. def get_new_url(self, request, model):
  52. return reverse('admin_roles_new')
  53. def get_edit_url(self, request, model):
  54. return reverse('admin_roles_edit', model)
  55. def submit_form(self, request, form, target):
  56. new_role = Role(
  57. name = form.cleaned_data['name'],
  58. )
  59. new_role.save(force_insert=True)
  60. return new_role, Message(_('New Role has been created.'), 'success')
  61. class Edit(FormWidget):
  62. admin = site.get_action('roles')
  63. id = 'edit'
  64. name = _("Edit Role")
  65. fallback = 'admin_roles'
  66. form = RoleForm
  67. target_name = 'name'
  68. notfound_message = _('Requested Role could not be found.')
  69. submit_fallback = True
  70. def get_url(self, request, model):
  71. return reverse('admin_roles_edit', model)
  72. def get_edit_url(self, request, model):
  73. return self.get_url(request, model)
  74. def get_initial_data(self, request, model):
  75. return {
  76. 'name': model.name,
  77. }
  78. def submit_form(self, request, form, target):
  79. target.name = form.cleaned_data['name']
  80. target.save(force_update=True)
  81. return target, Message(_('Changes in role "%(name)s" have been saved.') % {'name': self.original_name}, 'success')
  82. class ACL(FormWidget):
  83. admin = site.get_action('roles')
  84. id = 'acl'
  85. name = _("Change Role Permissions")
  86. fallback = 'admin_roles'
  87. form = PermsForm
  88. target_name = 'name'
  89. notfound_message = _('Requested Role could not be found.')
  90. submit_fallback = True
  91. def get_form(self, request, target):
  92. self.form = build_form(request, self.form, target)
  93. return self.form
  94. def get_url(self, request, model):
  95. return reverse('admin_roles_acl', model)
  96. def get_edit_url(self, request, model):
  97. return self.get_url(request, model)
  98. def get_initial_data(self, request, model):
  99. raw_acl = model.get_permissions()
  100. initial = {}
  101. for field in self.form.base_fields:
  102. if field in raw_acl:
  103. initial[field] = raw_acl[field]
  104. return initial
  105. def submit_form(self, request, form, target):
  106. raw_acl = model.get_permissions()
  107. for perm in form.cleaned_data:
  108. raw_acl[perm] = form.cleaned_data[perm]
  109. target.set_permissions(raw_acl)
  110. target.save(force_update=True)
  111. request.model['acl_version'] = int(request.model['acl_version']) + 1
  112. return target, Message(_('Role "%(name)s" permissions have been changed.') % {'name': self.original_name}, 'success')
  113. class Delete(ButtonWidget):
  114. admin = site.get_action('roles')
  115. id = 'delete'
  116. fallback = 'admin_roles'
  117. notfound_message = _('Requested Role could not be found.')
  118. def action(self, request, target):
  119. if target.token:
  120. return Message(_('You cannot delete system roles.'), 'error'), reverse('admin_roles')
  121. if target.protected and not request.user.is_god():
  122. return Message(_('This role is protected.'), 'error'), reverse('admin_roles')
  123. if target.user_set.count() > 0:
  124. return Message(_('This role is assigned to one or more usets.'), 'error'), reverse('admin_roles')
  125. target.delete()
  126. return Message(_('Role "%(name)s" has been deleted.') % {'name': target.name}, 'success'), False