123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- # -*- coding: utf-8 -*-
- from __future__ import unicode_literals
- from django.db import models, migrations
- from django.utils.translation import ugettext as _
- import base64
- try:
- import cPickle as pickle
- except ImportError:
- import pickle
- def pickle_permissions(role, permissions):
- role.pickled_permissions = base64.encodestring(
- pickle.dumps(permissions, pickle.HIGHEST_PROTOCOL))
- def create_default_roles(apps, schema_editor):
- Role = apps.get_model('misago_acl', 'Role')
- role = Role(name=_("Member"), special_role='authenticated')
- pickle_permissions(role,
- {
- # account perms
- 'misago.users.permissions.account': {
- 'name_changes_allowed': 2,
- 'name_changes_expire': 180,
- 'can_have_signature': 0,
- 'allow_signature_links': 0,
- 'allow_signature_images': 0,
- },
- # profiles perms
- 'misago.users.permissions.profiles': {
- 'can_search_users': 1,
- 'can_see_users_emails': 0,
- 'can_see_users_ips': 0,
- 'can_see_hidden_users': 0,
- },
- # destroy users perms
- 'misago.users.permissions.destroying': {
- 'can_destroy_user_newer_than': 0,
- 'can_destroy_users_with_less_posts_than': 0,
- },
- })
- role.save()
- role = Role(name=_("Guest"), special_role='anonymous')
- pickle_permissions(role,
- {
- # account perms
- 'misago.users.permissions.account': {
- 'name_changes_allowed': 0,
- 'name_changes_expire': 0,
- 'can_have_signature': 0,
- 'allow_signature_links': 0,
- 'allow_signature_images': 0,
- },
- # profiles perms
- 'misago.users.permissions.profiles': {
- 'can_search_users': 1,
- 'can_see_users_emails': 0,
- 'can_see_users_ips': 0,
- 'can_see_hidden_users': 0,
- },
- # destroy users perms
- 'misago.users.permissions.destroying': {
- 'can_destroy_user_newer_than': 0,
- 'can_destroy_users_with_less_posts_than': 0,
- },
- })
- role.save()
- role = Role(name=_("Moderator"))
- pickle_permissions(role,
- {
- # account perms
- 'misago.users.permissions.account': {
- 'name_changes_allowed': 5,
- 'name_changes_expire': 14,
- 'can_have_signature': 1,
- 'allow_signature_links': 1,
- 'allow_signature_images': 0,
- },
- # profiles perms
- 'misago.users.permissions.profiles': {
- 'can_search_users': 1,
- 'can_see_users_emails': 1,
- 'can_see_users_ips': 1,
- 'can_see_hidden_users': 1,
- },
- # destroy users perms
- 'misago.users.permissions.destroying': {
- 'can_destroy_user_newer_than': 0,
- 'can_destroy_users_with_less_posts_than': 0,
- },
- })
- role.save()
- role = Role(name=_("Spam accounts destroyer"))
- pickle_permissions(role,
- {
- # destroy users perms
- 'misago.users.permissions.destroying': {
- 'can_destroy_user_newer_than': 2,
- 'can_destroy_users_with_less_posts_than': 20,
- },
- })
- role.save()
- class Migration(migrations.Migration):
- dependencies = [
- ('misago_acl', '0002_acl_version_tracker'),
- ]
- operations = [
- migrations.RunPython(create_default_roles),
- ]
|