コード例 #1
0
class Log(models.Model):
    ADD = 1
    EDIT = 2
    DELETE = 3

    OPERATION_CHOICES = [[ADD, u'Cadastro'], [EDIT, u'Edição'], [DELETE, u'Exclusão']]

    content_type = models.ForeignKey(ContentType, verbose_name=u'Objeto', filter=True)
    operation = models.IntegerField(verbose_name=u'Operação', choices=OPERATION_CHOICES, filter=True)
    user = models.ForeignKey('admin.User', filter=True)
    date = models.DateTimeField(verbose_name=u'Data/Hora', auto_now=True, filter=True)
    object_id = models.IntegerField(verbose_name=u'Identificador', search=True)
    object_description = models.CharField(verbose_name=u'Descrição do Objeto')
    content = models.TextField(verbose_name=u'Conteúdo', null=True)

    fieldsets = (
        (u'Dados Gerais', {'fields': (
        ('content_type', 'operation'), ('user', 'date'), ('object_id', 'object_description'), 'get_tags')}),
        (u'Índices', {'relations': ('logindex_set',)}),
    )

    objects = models.Manager()

    class Meta:
        verbose_name = u'Log'
        verbose_name_plural = u'Logs'
        icon = 'fa-history'
        list_per_page = 25

    def __unicode__(self):
        return 'Log #%s' % self.pk

    def can_add(self):
        return False

    def can_edit(self):
        return False

    def can_delete(self):
        return False

    def get_action_description(self):
        return (u'adicionou', u'editou', u'removeu')[self.operation - 1]

    def get_style(self):
        return ('success', 'info', 'danger')[self.operation - 1]

    def get_icon(self):
        return ('plus', 'pencil', 'trash-o')[self.operation - 1]

    @meta(u'Tags', formatter='log_tags')
    def get_tags(self):
        return json.loads(self.content)

    def create_indexes(self, instance):
        for log_index in get_metadata(instance.__class__, 'logging', (), iterable=True):
            index_object = getattr2(instance, log_index)
            if index_object:
                index_content_type = ContentType.objects.get_for_model(index_object.__class__)
                LogIndex.objects.create(log=self, content_type=index_content_type, object_id=index_object.pk)
コード例 #2
0
class Log(models.Model):
    ADD = 1
    EDIT = 2
    DELETE = 3

    OPERATION_CHOICES = [[ADD, _('Add')], [EDIT, _('Edit')], [DELETE, _('Delete')]]

    content_type = models.ForeignKey(ContentType, verbose_name=_('Content Type'), filter=True)
    operation = models.IntegerField(verbose_name=_('Operation'), choices=OPERATION_CHOICES, filter=True)
    user = models.ForeignKey('admin.User', filter=True, verbose_name=_('User'))
    date = models.DateTimeField(verbose_name=_('Date/Time'), auto_now=True, filter=True)
    object_id = models.IntegerField(verbose_name=_('Identifier'), search=True)
    object_description = models.CharField(verbose_name=_('Object Description'))
    content = models.TextField(verbose_name=_('Content'), null=True)

    fieldsets = (
        (_('General Data'), {'fields': (
            ('content_type', 'operation'), ('user', 'date'), ('object_id', 'object_description'), 'get_tags')}),
        (_('Indexes'), {'relations': ('logindex_set',)}),
    )

    objects = models.Manager()

    class Meta:
        verbose_name = _('Log')
        verbose_name_plural = _('Logs')
        icon = 'fa-history'
        list_per_page = 25

    def __str__(self):
        return 'Log #{}'.format(self.pk)

    def can_add(self):
        return False

    def can_edit(self):
        return False

    def can_delete(self):
        return False

    def get_action_description(self):
        return (_('added'), _('edited'), _('deleted'))[self.operation - 1]

    def get_style(self):
        return ('success', 'info', 'danger')[self.operation - 1]

    def get_icon(self):
        return ('plus', 'pencil', 'trash-o')[self.operation - 1]

    @meta('Tags')
    def get_tags(self):
        return json.loads(self.content)

    def create_indexes(self, instance):
        for log_index in get_metadata(instance.__class__, 'logging', (), iterable=True):
            index_object = getattr2(instance, log_index)
            if index_object:
                index_content_type = ContentType.objects.get_for_model(index_object.__class__)
                LogIndex.objects.create(log=self, content_type=index_content_type, object_id=index_object.pk)
コード例 #3
0
ファイル: models.py プロジェクト: allysonbarros/djangoplus
class Settings(models.Model):
    class Meta:
        verbose_name = 'Configuração'
        verbose_name_plural = 'Configurações'

    fieldsets = (
        ('Configuração Geral', {
            'fields': (('initials', 'name'), ('logo', 'logo_pdf'),
                       ('icon', 'background'))
        }),
        ('Social', {
            'fields': (('twitter', 'facebook'), ('google', 'pinterest'),
                       ('linkedin', 'rss'))
        }),
        ('Direitos Autorais', {
            'fields': ('company', ('phone_1', 'phone_2'), 'address', 'email')
        }),
        ('Aparência', {
            'fields': ('default_color', )
        }),
        ('Servidor', {
            'fields': (('server_address', 'system_email_address'), )
        }),
        ('Versão', {
            'fields': ('version', )
        }),
    )

    # Application
    initials = models.CharField('Nome', default='Django+')
    name = models.CharField('Descrição', default='Django Plus')
    logo = models.ImageField('Logotipo',
                             upload_to='config',
                             null=True,
                             blank=True,
                             default='')
    logo_pdf = models.ImageField('Logotipo para PDF',
                                 upload_to='config',
                                 help_text='Imagem sem fundo transparente',
                                 null=True,
                                 blank=True,
                                 default='')
    icon = models.ImageField('Ícone',
                             upload_to='config',
                             null=True,
                             blank=True)
    background = models.ImageField('Background',
                                   upload_to='config',
                                   default='',
                                   blank=True)

    # Social params
    twitter = models.CharField('Twitter', null=True, blank=True)
    facebook = models.CharField('Facebook', null=True, blank=True)
    google = models.CharField('Google', null=True, blank=True)
    pinterest = models.CharField('pinterest', null=True, blank=True)
    linkedin = models.CharField('Linkedin', null=True, blank=True)
    rss = models.CharField('RSS', null=True, blank=True)

    # Company
    company = models.CharField('Empresa', null=True, blank=True)
    address = models.TextField('Endereço', null=True, blank=True)
    phone_1 = models.PhoneField('Telefone Principal', null=True, blank=True)
    phone_2 = models.PhoneField('Telefone Secundário', null=True, blank=True)
    email = models.CharField('E-mail', null=True, blank=True)

    # Server configuration
    version = models.CharField('Versão do Sistema', exclude=True)
    server_address = models.CharField('Endereço de Acesso',
                                      default='http://*****:*****@djangoplus.net')

    @staticmethod
    def default():
        from djangoplus.cache import loader
        if not loader.settings_instance:
            loader.settings_instance = Settings.objects.first()
        if not loader.settings_instance:
            settings = Settings()
            settings.initials = 'Sistema'
            settings.name = 'Sistema de gerenciamento online, responsivo e multiplataforma'
            settings.twitter = 'https://twitter.com/'
            settings.facebook = 'https://www.facebook.com/'
            settings.google = 'https://plus.google.com/'
            settings.pinterest = 'https://www.pinterest.com/'
            settings.linkedin = 'https://www.linkedin.com/'
            settings.rss = 'https://www.rss.com/'
            settings.company = ''
            settings.address = ''
            settings.phone_1 = ''
            settings.phone_2 = ''
            settings.email = ''
            settings.version = '1.0'
            settings.save()
            loader.settings_instance = settings
        return loader.settings_instance

    def save(self, *args, **kwargs):
        from djangoplus.cache import loader
        super(Settings, self).save(*args, **kwargs)
        loader.settings_instance = self
コード例 #4
0
ファイル: models.py プロジェクト: adelsonllima/djangoplus
class Settings(models.Model):

    class Meta:
        verbose_name = _('Settings')
        verbose_name_plural = _('Settings')

    fieldsets = (
        (_('General Data'), {'fields': (('initials', 'name'), ('logo', 'logo_pdf'), ('icon', 'background'))}),
        (_('Social Data'), {'fields': (('twitter', 'facebook'), ('google', 'pinterest'), ('linkedin', 'rss'))}),
        (_('Copyright'), {'fields': ('company', ('phone_1', 'phone_2'), 'address', 'email')}),
        (_('Look and Feel'), {'fields': ('default_color',)}),
        (_('Server'), {'fields': (('server_address', 'system_email_address'),)}),
        (_('Version'), {'fields': ('version',)}),
    )

    # Application
    initials = models.CharField(_('Name'), default='Django+')
    name = models.CharField(_('Description'), default='Django Plus')
    logo = models.ImageField(_('Logo'), upload_to='config', null=True, blank=True, default='')
    logo_pdf = models.ImageField(_('PDF Logo'), upload_to='config', help_text=_('No-background image'),
                                 null=True, blank=True, default='')
    icon = models.ImageField(_('Icon'), upload_to='config', null=True, blank=True)
    background = models.ImageField('Background', upload_to='config', default='', blank=True)

    # Social params
    twitter = models.CharField('Twitter', null=True, blank=True)
    facebook = models.CharField('Facebook', null=True, blank=True)
    google = models.CharField('Google', null=True, blank=True)
    pinterest = models.CharField('Pinterest', null=True, blank=True)
    linkedin = models.CharField('Linkedin', null=True, blank=True)
    rss = models.CharField('RSS', null=True, blank=True)

    # Company
    company = models.CharField(_('Company Name'), null=True, blank=True)
    address = models.TextField(_('Address'), null=True, blank=True)
    phone_1 = models.PhoneField(_('Primary Phome'), null=True, blank=True)
    phone_2 = models.PhoneField(_('Secondary Phone'), null=True, blank=True)
    email = models.CharField(_('Email'), null=True, blank=True)

    # Server configuration
    version = models.CharField(_('System Version'), exclude=True)
    server_address = models.CharField(_('Server URL'), default='http://*****:*****@djangoplus.net')

    @staticmethod
    def default():
        from djangoplus.cache import CACHE
        if not CACHE['SETTINGS_INSTANCE']:
            CACHE['SETTINGS_INSTANCE'] = Settings.objects.first()
        if not CACHE['SETTINGS_INSTANCE']:
            s = Settings()
            s.initials = _('System')
            s.name = _('Online, responsive e multiplatform system')
            s.twitter = 'https://twitter.com/'
            s.facebook = 'https://www.facebook.com/'
            s.google = 'https://plus.google.com/'
            s.pinterest = 'https://www.pinterest.com/'
            s.linkedin = 'https://www.linkedin.com/'
            s.rss = 'https://www.rss.com/'
            s.company = ''
            s.address = ''
            s.phone_1 = ''
            s.phone_2 = ''
            s.email = ''
            s.version = '1.0'
            s.save()
            CACHE['SETTINGS_INSTANCE'] = s
        return CACHE['SETTINGS_INSTANCE']

    def save(self, *args, **kwargs):
        from djangoplus.cache import CACHE
        super(Settings, self).save(*args, **kwargs)
        CACHE['SETTINGS_INSTANCE'] = self
コード例 #5
0
ファイル: models.py プロジェクト: adelsonllima/djangoplus
class Log(models.Model):
    ADD = 1
    EDIT = 2
    DELETE = 3

    OPERATION_CHOICES = [[ADD, _('Add')], [EDIT, _('Edit')], [DELETE, _('Delete')]]

    content_type = models.ForeignKey(ContentType, verbose_name=_('Content Type'), filter=True)
    operation = models.IntegerField(verbose_name=_('Operation'), choices=OPERATION_CHOICES, filter=True)
    user = models.ForeignKey('admin.User', filter=True, verbose_name=_('User'))
    date = models.DateTimeField(verbose_name=_('Date/Time'), auto_now=True, filter=True)
    object_id = models.IntegerField(verbose_name=_('Identifier'), search=True)
    object_description = models.CharField(verbose_name=_('Object Description'))
    content = models.TextField(verbose_name=_('Content'), null=True, search=True)

    fieldsets = (
        (_('General Data'), {'fields': (
            ('content_type', 'operation'), ('user', 'date'), ('object_id', 'object_description'), 'get_tags')}),
        (_('Indexes'), {'relations': ('logindex_set',), 'condition': 'has_index'}),
    )

    objects = models.Manager()

    class Meta:
        verbose_name = _('Log')
        verbose_name_plural = _('Logs')
        icon = 'fa-history'
        list_per_page = 25
        list_display = 'content_type', 'object_id', 'operation', 'user', 'date', 'get_tags'
        order_by = '-date'

    def __str__(self):
        return 'Log #{}'.format(self.pk)

    def can_add(self):
        return False

    def can_edit(self):
        return False

    def can_delete(self):
        return False

    def has_index(self):
        return self.logindex_set.exists()

    def get_action_description(self):
        return (_('added'), _('edited'), _('deleted'))[self.operation - 1]

    def get_style(self):
        return ('success', 'info', 'danger')[self.operation - 1]

    def get_icon(self):
        return ('plus', 'pencil', 'trash-o')[self.operation - 1]

    @meta('Alterações')
    def get_tags(self):
        data = []
        for attr, old, new in json.loads(self.content):
            data.append('{} : {} >> {}'.format(attr, old, new))

        for log_index in self.logindex_set.all():
            date = datetime.datetime(
                log_index.log.date.year, log_index.log.date.month, log_index.log.date.day,
                log_index.log.date.hour, log_index.log.date.minute, log_index.log.date.second
            )
            qs = Log.objects.filter(
                content_type=log_index.content_type, user=log_index.log.user, date__startswith=date,
                object_id=log_index.object_id
            )
            for log in qs:
                for attr, old, new in json.loads(log.content):
                    data.append('{} : {} >> {}'.format(attr, old, new))

        return ' | '.join(data)

    def create_indexes(self, instance):
        for log_index in get_metadata(instance.__class__, 'logging', (), iterable=True):
            index_object = getattr2(instance, log_index)
            if index_object:
                index_content_type = ContentType.objects.get_for_model(index_object.__class__)
                LogIndex.objects.create(log=self, content_type=index_content_type, object_id=index_object.pk)
コード例 #6
0
class Settings(models.Model):

    class Meta:
        verbose_name = u'Configuração'
        verbose_name_plural = u'Configurações'

    fieldsets = (
        (u'Configuração Geral', {'fields': (('initials', 'name'), ('logo', 'logo_pdf'), ('icon', 'background'))}),
        (u'Social', {'fields': (('twitter', 'facebook'), ('google', 'pinterest'), ('linkedin', 'rss'))}),
        (u'Contato', {'fields': (('phone_1', 'phone_2'), 'address', 'email')}),
        (u'Aparência', {'fields': ('default_color',)}),
        (u'Servidor', {'fields': (('server_address', 'system_email_address'),)}),
        (u'Versão', {'fields': ('version',)}),
    )

    # Application
    initials = models.CharField(u'Nome', default=u'Django+')
    name = models.CharField(u'Descrição', default=u'Django Plus')
    logo = models.ImageField(u'Logotipo', upload_to='config', null=True, blank=True, default='')
    logo_pdf = models.ImageField(u'Logotipo para PDF', upload_to='config', help_text=u'Imagem sem fundo transparente',
                                 null=True, blank=True, default='')
    icon = models.ImageField(u'Ícone', upload_to='config', null=True, blank=True)
    background = models.ImageField(u'Background', upload_to='config', default='', blank=True)

    # Social params
    twitter = models.CharField(u'Twitter', null=True, blank=True)
    facebook = models.CharField(u'Facebook', null=True, blank=True)
    google = models.CharField(u'Google', null=True, blank=True)
    pinterest = models.CharField(u'pinterest', null=True, blank=True)
    linkedin = models.CharField(u'Linkedin', null=True, blank=True)
    rss = models.CharField(u'RSS', null=True, blank=True)

    # Contact info
    address = models.TextField(u'Endereço', null=True, blank=True)
    phone_1 = models.PhoneField(u'Telefone Principal', null=True, blank=True)
    phone_2 = models.PhoneField(u'Telefone Secundário', null=True, blank=True)
    email = models.CharField(u'E-mail', null=True, blank=True)

    # Server configuration
    version = models.CharField(u'Versão do Sistema', exclude=True)
    server_address = models.CharField(u'Endereço de Acesso', default=u'http://*****:*****@djangoplus.net')

    @staticmethod
    def default():
        qs = Settings.objects.all()
        if qs.exists():
            return qs[0]
        else:
            settings = Settings()
            settings.initials = u'Sistema'
            settings.name = u'Sistema de gerenciamento online, responsivo e multiplataforma'
            settings.twitter = u'https://twitter.com/'
            settings.facebook = u'https://www.facebook.com/'
            settings.google = u'https://plus.google.com/'
            settings.pinterest = u'https://www.pinterest.com/'
            settings.linkedin = u'https://www.linkedin.com/'
            settings.rss = u'https://www.rss.com/'
            settings.address = u''
            settings.phone_1 = u''
            settings.phone_2 = u''
            settings.email = u''
            settings.version = '1.0'
            settings.save()
            return settings
コード例 #7
0
class User(AbstractBaseUser, PermissionsMixin):
    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = ['email']

    name = models.CharField(u'Nome', max_length=30, blank=True, search=True)
    username = models.CharField(u'Login', max_length=30, unique=True)
    email = models.CharField(u'E-mail', max_length=75, blank=True, default='')
    active = models.BooleanField(verbose_name=u'Ativo?', default=True, filter=True)
    photo = models.ImageField(upload_to='profiles', null=True, blank=True, default='', verbose_name=u'Foto', exclude=True)

    permission_mapping = models.TextField(verbose_name=u'Mapeamento de Permissão', default='{}', exclude=True, display=False)
    organization = models.ForeignKey(Organization, verbose_name=u'Organização', null=True, blank=True, display=False)
    unit = models.ForeignKey(Unit, verbose_name=u'Unidade', null=True, blank=True, display=False)

    objects = UserManager()

    fieldsets = (
        (u'Identificação', {'fields': (('name', 'email'),)}),
        (u'Acesso', {'fields': (('username', 'is_superuser'), ('active',))}),
        (u'Funções', {'relations': ('role_set',)}),
        (u'Mapeamento de Permissão', {'fields': (('organization', 'unit'), 'permission_mapping')}),
    )

    class Meta():
        verbose_name = u'Usuário'
        verbose_name_plural = u'Usuários'
        list_display = 'username', 'name', 'groups'
        add_form = 'UserForm'
        can_admin = u'Gerenciador de Usuários'
        icon = 'fa-user'

    def save(self, *args, **kwargs):
        super(User, self).save(*args, **kwargs)

    def __unicode__(self):
        return self.name or self.username

    @action('Alterar Senha', input='ChangePasswordForm', inline=True)
    def change_password(self, new_password, confirm_password):
        self.set_password(new_password)
        self.save()

    def units(self, group_name=None):
        qs = self.role_set.all()
        if group_name:
            qs = qs.filter(group__name=group_name)
        return qs.values_list('units', flat=True)

    def in_group(self, *group_names):
        return self.role_set.filter(group__name__in=group_names).exists()

    def in_other_group(self, group_name):
        return self.is_superuser or self.role_set.exclude(group__name=group_name).exists()

    def get_permission_mapping(self, model, obj=None):
        from djangoplus.cache import loader
        import json
        permission_mapping = json.loads(self.permission_mapping or '{}')
        permission_mapping_key = obj and '%s:%s' % (model.__name__, type(obj).__name__) or model.__name__
        if 0 and permission_mapping_key in permission_mapping:
            return permission_mapping[permission_mapping_key]

        organization_lookups = []
        unit_lookups = []
        role_lookups = dict()
        lookups = dict(list_lookups=[], edit_lookups=[], delete_lookups=[])

        for lookup in get_metadata(model, 'list_lookups', (), iterable=True):
            field = get_field(model, lookup)
            if hasattr(field.rel.to, 'organization_ptr') or hasattr(field.rel.to, 'unit_ptr'):
                if hasattr(field.rel.to, 'organization_ptr'):
                    organization_lookups.append(lookup)
                if hasattr(field.rel.to, 'unit_ptr'):
                    unit_lookups.append(lookup)
            else:
                role_username = get_metadata(field.rel.to, 'role_username')
                if role_username:
                    role_lookups[get_metadata(field.rel.to, 'verbose_name')] = '%s__%s' % (lookup, role_username)
                for subclass in field.rel.to.__subclasses__():
                    role_username = get_metadata(subclass, 'role_username')
                    if role_username:
                        role_lookups[get_metadata(subclass, 'verbose_name')] = '%s__%s__%s' % (
                            lookup, subclass.__name__.lower(), role_username)

        if hasattr(model, 'organization_ptr') and 'id' not in organization_lookups:
            organization_lookups.append('id')

        if hasattr(model, 'unit_ptr') and 'id' not in unit_lookups:
            unit_lookups.append('id')

        if get_metadata(model, 'role_username') and 'id' not in role_lookups:
            role_lookups[get_metadata(model, 'verbose_name')] = get_metadata(model, 'role_username')

        for field in get_metadata(model, 'fields'):
            if hasattr(field, 'rel') and field.rel and hasattr(field.rel, 'to') and field.rel.to:
                if field.rel.to in loader.role_models:
                    role_lookups[get_metadata(field.rel.to, 'verbose_name')] = '%s__%s' % (field.name, loader.role_models[field.rel.to]['username_field'])
                if field.rel.to in loader.abstract_role_models:
                    for to in loader.abstract_role_models[field.rel.to]:
                        role_lookups[get_metadata(to, 'verbose_name')] = '%s__%s__%s' % (
                            field.name, to.__name__.lower(), loader.role_models[to])
                if hasattr(field.rel.to, 'unit_ptr_id') and field.name not in unit_lookups:
                    unit_lookups.append(field.name)
                if hasattr(field.rel.to, 'organization_ptr_id') and field.name not in organization_lookups:
                    organization_lookups.append(field.name)

        for organization_lookup in organization_lookups:
            if loader.unit_model:
                if organization_lookup == 'id':
                    unit_lookup = loader.unit_model.__name__.lower()
                else:
                    unit_lookup = '%s__%s' % (organization_lookup, loader.unit_model.__name__.lower())
                if unit_lookup not in unit_lookups and not hasattr(model, 'unit_ptr'):
                    unit_lookups.append(unit_lookup)

        for unit_lookup in unit_lookups:
            if loader.organization_model:
                if unit_lookup == 'id':
                    organization_lookup = loader.organization_model.__name__.lower()
                else:
                    organization_lookup = '%s__%s' % (unit_lookup, loader.organization_model.__name__.lower())
                if organization_lookup not in organization_lookups and not hasattr(model, 'organization_ptr'):
                    organization_lookups.append(organization_lookup)

        groups = dict()
        for group_name, organization_id, unit_id in self.role_set.values_list('group__name', 'organizations', 'units'):
            if group_name not in groups:
                groups[group_name] = dict(username_lookups=[], organization_ids=[], unit_ids=[])
            if group_name in role_lookups:
                groups[group_name]['username_lookups'].append(role_lookups[group_name])
            if organization_id and not self.unit_id and (organization_id == self.organization_id or not self.organization_id):
                groups[group_name]['organization_ids'].append(organization_id)
            if self.unit_id or unit_id:
                groups[group_name]['unit_ids'].append(self.unit_id or unit_id)

        if model in loader.permissions_by_scope:
            for group_name in groups:

                username_lookups = groups[group_name]['username_lookups']
                unit_ids = list(set(groups[group_name]['unit_ids']))
                organization_ids = list(set(groups[group_name]['organization_ids']))

                if obj:

                    can_list = can_list_by_role = can_list_by_unit = can_list_by_organization = False

                    if type(obj) in loader.permissions_by_scope:
                        can_list = group_name in loader.permissions_by_scope[type(obj)].get('add', [])
                        can_list_by_role = group_name in loader.permissions_by_scope[type(obj)].get('add_by_role', [])
                        can_list_by_unit = group_name in loader.permissions_by_scope[type(obj)].get('add_by_unit', [])
                        can_list_by_organization = group_name in loader.permissions_by_scope[type(obj)].get('add_by_organization', [])

                        if (can_list or can_list_by_role or can_list_by_unit or can_list_by_organization) is False:
                            can_list = group_name in loader.permissions_by_scope[type(obj)].get('list', [])
                            can_list_by_role = group_name in loader.permissions_by_scope[type(obj)].get('list_by_role', [])
                            can_list_by_unit = group_name in loader.permissions_by_scope[type(obj)].get('list_by_unit', [])
                            can_list_by_organization = group_name in loader.permissions_by_scope[type(obj)].get('list_by_organization', [])

                    if (can_list or can_list_by_role or can_list_by_unit or can_list_by_organization) is False:
                        can_list = group_name in loader.permissions_by_scope[model].get('list', [])
                        can_list_by_role = group_name in loader.permissions_by_scope[model].get('list_by_role', [])
                        can_list_by_unit = group_name in loader.permissions_by_scope[model].get('list_by_unit', [])
                        can_list_by_organization = group_name in loader.permissions_by_scope[model].get('list_by_organization', [])

                else:
                    can_list = group_name in loader.permissions_by_scope[model].get('list', [])
                    can_list_by_role = group_name in loader.permissions_by_scope[model].get('list_by_role', [])
                    can_list_by_unit = group_name in loader.permissions_by_scope[model].get('list_by_unit', [])
                    can_list_by_organization = group_name in loader.permissions_by_scope[model].get('list_by_organization', [])

                if can_list:
                    lookups['list_lookups'] = []
                else:
                    if can_list_by_role:
                        for username_lookup in username_lookups:
                            lookups['list_lookups'].append((username_lookup, (self.username,)))
                    if can_list_by_unit or self.unit_id:
                        if unit_ids and 0 not in unit_ids:
                            for unit_lookup in unit_lookups:
                                lookups['list_lookups'].append(('%s' % unit_lookup, unit_ids))
                    if can_list_by_organization:
                        if organization_ids and 0 not in organization_ids:
                            for organization_lookup in organization_lookups:
                                lookups['list_lookups'].append(('%s' % organization_lookup, organization_ids))

                can_edit = group_name in loader.permissions_by_scope[model].get('edit', [])
                can_edit_by_role = group_name in loader.permissions_by_scope[model].get('edit_by_role', [])
                can_edit_by_unit = group_name in loader.permissions_by_scope[model].get('edit_by_unit', [])
                can_edit_by_organization = group_name in loader.permissions_by_scope[model].get('edit_by_organization', [])

                if can_edit:
                    lookups['edit_lookups'] = None
                else:
                    if can_edit_by_role:
                        for username_lookup in username_lookups:
                            lookups['edit_lookups'].append((username_lookup, (self.username,)))
                    if can_edit_by_unit and unit_ids:
                        for unit_lookup in unit_lookups:
                            lookups['edit_lookups'].append((unit_lookup, unit_ids))
                    if can_edit_by_organization and organization_ids:
                        for organization_lookup in organization_lookups:
                            lookups['edit_lookups'].append((organization_lookup, organization_ids))

                can_delete = group_name in loader.permissions_by_scope[model].get('delete', [])
                can_delete_by_role = group_name in loader.permissions_by_scope[model].get('delete_by_role', [])
                can_delete_by_unit = group_name in loader.permissions_by_scope[model].get('delete_by_unit', [])
                can_delete_by_organization = group_name in loader.permissions_by_scope[model].get('delete_by_organization', [])

                if can_delete:
                    lookups['delete_lookups'] = None
                else:
                    if can_delete_by_role:
                        for username_lookup in username_lookups:
                            lookups['delete_lookups'].append((username_lookup, (self.username,)))
                    if can_delete_by_unit and unit_ids:
                        for unit_lookup in unit_lookups:
                            lookups['delete_lookups'].append((unit_lookup, unit_ids))
                    if can_delete_by_organization and organization_ids:
                        for organization_lookup in organization_lookups:
                            lookups['delete_lookups'].append((organization_lookup, organization_ids))

                for actions_dict in (loader.actions, loader.class_actions):
                    for category in actions_dict.get(model, ()):
                        for key in actions_dict[model][category].keys():
                            execute_lookups = []
                            view_name = actions_dict[model][category][key]['view_name']
                            can_execute = group_name in loader.permissions_by_scope[model].get('%s' % view_name, [])
                            can_execute_by_role = group_name in loader.permissions_by_scope[model].get('%s_by_role' % view_name, [])
                            can_execute_by_unit = group_name in loader.permissions_by_scope[model].get('%s_by_unit' % view_name, [])
                            can_execute_by_organization = group_name in loader.permissions_by_scope[model].get('%s_by_organization' % view_name, [])
                            if can_execute:
                                execute_lookups = None
                            else:
                                if can_execute_by_role:
                                    for username_lookup in username_lookups:
                                        execute_lookups.append((username_lookup, (self.username,)))
                                if can_execute_by_unit and unit_ids:
                                    for unit_lookup in unit_lookups:
                                        execute_lookups.append((unit_lookup, unit_ids))
                                if can_execute_by_organization and organization_ids:
                                    for organization_lookup in organization_lookups:
                                        execute_lookups.append((organization_lookup, organization_ids))
                            if execute_lookups:
                                if view_name not in lookups:
                                    lookups[view_name] = []
                                lookups[view_name] += execute_lookups

            if loader.permissions_by_scope[model].get('list_by_unit') and not unit_lookups:
                raise Exception('A "lookup" meta-attribute must point to a Unit model in %s' % model)
            if loader.permissions_by_scope[model].get('list_by_organization') and (not organization_lookups and not unit_lookups):
                raise Exception('A "lookup" meta-attribute must point to a Unit or Organization model in %s' % model)
            if loader.permissions_by_scope[model].get('list_by_role') and not role_lookups:
                raise Exception('A "lookup" meta-attribute must point to a role model in %s' % model)

        permission_mapping[permission_mapping_key] = lookups

        self.permission_mapping = json.dumps(permission_mapping)
        self.save()

        return permission_mapping[permission_mapping_key]

    # gieve a set of group or permission names, this method returns the groups the user belongs to
    def find_groups(self, perm_or_group, exclude=None):
        qs = self.groups.all()
        if perm_or_group:
            permissions = []
            groups = []
            for item in perm_or_group:
                if '.' in item:
                    permissions.append(item.split('.')[1])
                else:
                    groups.append(item)
            if permissions:
                qs = qs.filter(permissions__codename__in=permissions)
            if groups:
                qs = qs.filter(name__in=groups)

        if exclude:
            qs = qs.exclude(name=exclude)
        return qs

    def email_user(self, subject, message, from_email=None, **kwargs):
        send_mail(subject, message, from_email, [self.email], **kwargs)