|
@@ -1,5 +1,6 @@
|
|
|
import copy
|
|
|
from django.core.urlresolvers import reverse as django_reverse
|
|
|
+from django.shortcuts import redirect
|
|
|
from django.utils.translation import ugettext as _
|
|
|
from misago.acl.builder import build_form
|
|
|
from misago.admin import site
|
|
@@ -7,6 +8,7 @@ from misago.admin.widgets import *
|
|
|
from misago.utils import slugify
|
|
|
from misago.forms import Form, YesNoSwitch
|
|
|
from misago.forums.models import Forum
|
|
|
+from misago.forumroles.models import ForumRole
|
|
|
from misago.roles.forms import RoleForm
|
|
|
from misago.roles.models import Role
|
|
|
|
|
@@ -34,7 +36,7 @@ class List(ListWidget):
|
|
|
|
|
|
def get_item_actions(self, request, item):
|
|
|
return (
|
|
|
- self.action('list', _("Forums Permissions"), reverse('admin_roles_forums', item)),
|
|
|
+ self.action('list', _("Forums Permissions"), reverse('admin_roles_masks', item)),
|
|
|
self.action('adjust', _("Role Permissions"), reverse('admin_roles_acl', item)),
|
|
|
self.action('pencil', _("Edit Role"), reverse('admin_roles_edit', item)),
|
|
|
self.action('remove', _("Delete Role"), reverse('admin_roles_delete', item), post=True, prompt=_("Are you sure you want to delete this role?")),
|
|
@@ -72,7 +74,7 @@ class New(FormWidget):
|
|
|
name = form.cleaned_data['name'],
|
|
|
)
|
|
|
new_role.save(force_insert=True)
|
|
|
- return new_role, Message(_('New Role has been created.'), 'success')
|
|
|
+ return new_role, Message(_('New Role has been created.'), 'success')
|
|
|
|
|
|
|
|
|
class Edit(FormWidget):
|
|
@@ -82,6 +84,7 @@ class Edit(FormWidget):
|
|
|
fallback = 'admin_roles'
|
|
|
form = RoleForm
|
|
|
target_name = 'name'
|
|
|
+ translate_target_name = True
|
|
|
notfound_message = _('Requested Role could not be found.')
|
|
|
submit_fallback = True
|
|
|
|
|
@@ -92,13 +95,23 @@ class Edit(FormWidget):
|
|
|
return self.get_url(request, model)
|
|
|
|
|
|
def get_initial_data(self, request, model):
|
|
|
- return {
|
|
|
- 'name': model.name,
|
|
|
- }
|
|
|
+ if request.user.is_god():
|
|
|
+ return {'name': model.name, 'protected': model.protected}
|
|
|
+ return {'name': model.name}
|
|
|
+
|
|
|
+ def get_and_validate_target(self, request, target):
|
|
|
+ result = super(Edit, self).get_and_validate_target(request, target)
|
|
|
+ if result and result.protected and not request.user.is_god():
|
|
|
+ request.messages.set_flash(Message(_('Role "%(name)s" is protected, you cannot edit it.') % {'name': _(result.name)}), 'error', self.admin.id)
|
|
|
+ return None
|
|
|
+ return result
|
|
|
|
|
|
def submit_form(self, request, form, target):
|
|
|
target.name = form.cleaned_data['name']
|
|
|
+ if request.user.is_god():
|
|
|
+ target.protected = form.cleaned_data['protected']
|
|
|
target.save(force_update=True)
|
|
|
+ request.monitor['acl_version'] = int(request.monitor['acl_version']) + 1
|
|
|
return target, Message(_('Changes in role "%(name)s" have been saved.') % {'name': self.original_name}, 'success')
|
|
|
|
|
|
|
|
@@ -112,52 +125,72 @@ class Forums(ListWidget):
|
|
|
template = 'forums'
|
|
|
|
|
|
def get_url(self):
|
|
|
- reverse('admin_roles_forums', self.role)
|
|
|
+ return reverse('admin_roles_masks', self.role)
|
|
|
|
|
|
def get_items(self, request):
|
|
|
return Forum.objects.get(token='root').get_descendants()
|
|
|
-
|
|
|
+
|
|
|
def sort_items(self, request, page_items, sorting_method):
|
|
|
return page_items.order_by('lft')
|
|
|
-
|
|
|
+
|
|
|
def add_template_variables(self, variables):
|
|
|
variables['target'] = _(self.role.name)
|
|
|
return variables
|
|
|
|
|
|
def get_table_form(self, request, page_items):
|
|
|
+ perms = {}
|
|
|
+ try:
|
|
|
+ forums = self.role.get_permissions()['forums']
|
|
|
+ for fid in forums:
|
|
|
+ perms[str(fid)] = str(forums[fid])
|
|
|
+ except KeyError:
|
|
|
+ pass
|
|
|
+
|
|
|
perms_form = {}
|
|
|
+ roles_select = [("0", _("No Access"))]
|
|
|
+ for role in self.roles:
|
|
|
+ roles_select.append((str(role.pk), _(role.name)))
|
|
|
+
|
|
|
for item in page_items:
|
|
|
- perms_form['show_' + str(item.pk)] = forms.BooleanField(widget=YesNoSwitch,required=False)
|
|
|
- perms_form['read_' + str(item.pk)] = forms.BooleanField(widget=YesNoSwitch,required=False)
|
|
|
- perms_form['start_' + str(item.pk)] = forms.BooleanField(widget=YesNoSwitch,required=False)
|
|
|
- perms_form['reply_' + str(item.pk)] = forms.BooleanField(widget=YesNoSwitch,required=False)
|
|
|
- perms_form['upload_' + str(item.pk)] = forms.BooleanField(widget=YesNoSwitch,required=False)
|
|
|
- perms_form['download_' + str(item.pk)] = forms.BooleanField(widget=YesNoSwitch,required=False)
|
|
|
+ perms_form['forum_' + str(item.pk)] = forms.ChoiceField(choices=roles_select,initial=(perms[str(item.pk)] if str(item.pk) in perms else "0"))
|
|
|
|
|
|
# Turn dict into object
|
|
|
- return type('OrderRanksForm', (Form,), perms_form)
|
|
|
+ return type('ChangeForumRolesForm', (Form,), perms_form)
|
|
|
|
|
|
def table_action(self, request, page_items, cleaned_data):
|
|
|
+ perms = {}
|
|
|
for item in page_items:
|
|
|
- item.order = cleaned_data['pos_' + str(item.pk)]
|
|
|
- item.save(force_update=True)
|
|
|
- return Message(_('Ranks order has been changed'), 'success'), reverse('admin_ranks')
|
|
|
+ if cleaned_data['forum_' + str(item.pk)] != "0":
|
|
|
+ perms[item.pk] = long(cleaned_data['forum_' + str(item.pk)])
|
|
|
+ print perms
|
|
|
+ role_perms = self.role.get_permissions()
|
|
|
+ role_perms['forums'] = perms
|
|
|
+ self.role.set_permissions(role_perms)
|
|
|
+ self.role.save(force_update=True)
|
|
|
+ return Message(_('Forum permissions have been saved.'), 'success'), self.get_url()
|
|
|
|
|
|
def __call__(self, request, slug, target):
|
|
|
try:
|
|
|
self.role = Role.objects.get(id=target)
|
|
|
+ if self.role and self.role.protected and not request.user.is_god():
|
|
|
+ request.messages.set_flash(Message(_('Role "%(name)s" is protected, you cannot edit it.') % {'name': _(self.role.name)}), 'error', self.admin.id)
|
|
|
+ return redirect(reverse('admin_roles'))
|
|
|
except Role.DoesNotExist:
|
|
|
- request.set_flash(Message(_('Requested Role could not be found.')), 'error', 'roles')
|
|
|
- return reverse('admin_roles')
|
|
|
+ request.set_flash(Message(_('Requested Role could not be found.')), 'error', self.admin.id)
|
|
|
+ return redirect(reverse('admin_roles'))
|
|
|
+ self.roles = ForumRole.objects.order_by('name').all()
|
|
|
+ if not self.roles:
|
|
|
+ request.set_flash(Message(_('No forum roles are currently set.')), 'error', self.admin.id)
|
|
|
+ return redirect(reverse('admin_roles'))
|
|
|
return super(Forums, self).__call__(request)
|
|
|
|
|
|
-
|
|
|
class ACL(FormWidget):
|
|
|
admin = site.get_action('roles')
|
|
|
id = 'acl'
|
|
|
name = _("Change Role Permissions")
|
|
|
fallback = 'admin_roles'
|
|
|
target_name = 'name'
|
|
|
+ translate_target_name = True
|
|
|
notfound_message = _('Requested Role could not be found.')
|
|
|
submit_fallback = True
|
|
|
|
|
@@ -179,6 +212,13 @@ class ACL(FormWidget):
|
|
|
initial[field] = raw_acl[field]
|
|
|
return initial
|
|
|
|
|
|
+ def get_and_validate_target(self, request, target):
|
|
|
+ result = super(ACL, self).get_and_validate_target(request, target)
|
|
|
+ if result and result.protected and not request.user.is_god():
|
|
|
+ request.messages.set_flash(Message(_('Role "%(name)s" is protected, you cannot edit it.') % {'name': _(result.name)}), 'error', self.admin.id)
|
|
|
+ return None
|
|
|
+ return result
|
|
|
+
|
|
|
def submit_form(self, request, form, target):
|
|
|
raw_acl = target.get_permissions()
|
|
|
for perm in form.cleaned_data:
|
|
@@ -202,7 +242,7 @@ class Delete(ButtonWidget):
|
|
|
if target.protected and not request.user.is_god():
|
|
|
return Message(_('This role is protected.'), 'error'), reverse('admin_roles')
|
|
|
if target.user_set.count() > 0:
|
|
|
- return Message(_('This role is assigned to one or more usets.'), 'error'), reverse('admin_roles')
|
|
|
+ return Message(_('This role is assigned to one or more users.'), 'error'), reverse('admin_roles')
|
|
|
|
|
|
target.delete()
|
|
|
- return Message(_('Role "%(name)s" has been deleted.') % {'name': target.name}, 'success'), False
|
|
|
+ return Message(_('Role "%(name)s" has been deleted.') % {'name': _(target.name)}, 'success'), False
|