當前位置: 首頁>>代碼示例>>Python>>正文


Python Permission.DoesNotExist方法代碼示例

本文整理匯總了Python中django.contrib.auth.models.Permission.DoesNotExist方法的典型用法代碼示例。如果您正苦於以下問題:Python Permission.DoesNotExist方法的具體用法?Python Permission.DoesNotExist怎麽用?Python Permission.DoesNotExist使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在django.contrib.auth.models.Permission的用法示例。


在下文中一共展示了Permission.DoesNotExist方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: create_light_admin_group

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def create_light_admin_group():
    try:
        # If "Light Admins" already exists, migration causes
        # django.db.transaction.TransactionManagementError
        # without transaction.atomic().
        with transaction.atomic():
            light_admin_group = Group.objects.create(name='Light Admins')
    except IntegrityError:
        print('\nGroup with name "Light Admins" already exists. Skipping creation.')
        return
    try:
        regular_users_perm = Permission.objects.get(codename='change_organization_regular_users')
        view_user = Permission.objects.get(codename='view_user')
    except Permission.DoesNotExist:
        print('\nMissing permissions. Skipping creation.')
        return
    light_admin_group.permissions.set([regular_users_perm, view_user]) 
開發者ID:City-of-Helsinki,項目名稱:linkedevents,代碼行數:19,代碼來源:0074_create_light_admin_group.py

示例2: create_userena_profile

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def create_userena_profile(self, user):
        """
        Creates an :class:`UserenaSignup` instance for this user.

        :param user:
            Django :class:`User` instance.

        :return: The newly created :class:`UserenaSignup` instance.

        """
        if isinstance(user.username, str):
            user.username = smart_str(user.username)

        try:
            profile = self.get(user=user)
        except self.model.DoesNotExist:
            profile = self.create(user=user, activation_key=generate_nonce())
        return profile 
開發者ID:django-userena-ce,項目名稱:django-userena-ce,代碼行數:20,代碼來源:managers.py

示例3: reissue_activation

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def reissue_activation(self, activation_key):
        """
        Creates a new ``activation_key`` resetting activation timeframe when
        users let the previous key expire.

        :param activation_key:
            String containing the secret nonce activation key.

        """
        try:
            userena = self.get(activation_key=activation_key)
        except self.model.DoesNotExist:
            return False
        try:
            userena.activation_key = generate_nonce()
            userena.save(using=self._db)
            userena.user.date_joined = get_datetime_now()
            userena.user.save(using=self._db)
            userena.send_activation_email()
            return True
        except Exception:
            return False 
開發者ID:django-userena-ce,項目名稱:django-userena-ce,代碼行數:24,代碼來源:managers.py

示例4: check_expired_activation

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def check_expired_activation(self, activation_key):
        """
        Check if ``activation_key`` is still valid.

        Raises a ``self.model.DoesNotExist`` exception if key is not present or
         ``activation_key`` is not a valid string

        :param activation_key:
            String containing the secret nonce for a valid activation.

        :return:
            True if the ket has expired, False if still valid.

        """
        if NONCE_RE.search(activation_key):
            userena = self.get(activation_key=activation_key)
            return userena.activation_key_expired()
        raise self.model.DoesNotExist 
開發者ID:django-userena-ce,項目名稱:django-userena-ce,代碼行數:20,代碼來源:managers.py

示例5: permissions_audit

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def permissions_audit(request, app_label, model, codename):
    logger.debug("permissions_audit called by user {} on {}:{}:{}".format(request.user, app_label, model, codename))
    try:
        perm = Permission.objects\
            .prefetch_related('group_set', 'user_set', 'state_set',
                              'state_set__userprofile_set', 'group_set__user_set', 'state_set__userprofile_set__user')\
            .get(content_type__app_label=app_label, content_type__model=model, codename=codename)
    except Permission.DoesNotExist:
        raise Http404

    context = {'permission': {
        'permission': perm,
        'users': perm.user_set.all(),
        'groups': perm.group_set.all(),
        'states': perm.state_set.all(),
        'group_users': [group.user_set.all() for group in perm.group_set.all()],
        'state_users': [state.userprofile_set.all() for state in perm.state_set.all()],
        }
    }

    return render(request, 'permissions_tool/audit.html', context=context) 
開發者ID:allianceauth,項目名稱:allianceauth,代碼行數:23,代碼來源:views.py

示例6: forwards

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def forwards(self, orm):
        pass
        # remove old permission label if migrated with old model metadata
        try:
            ct = ContentType.objects.get(model='xform', app_label='odk_logger')
            Permission.objects.get(content_type=ct, codename='can_view').delete()
            # add new permission label
            perm, created = Permission.objects.get_or_create(content_type=ct, codename='view_xform', name='Can view associated data')
        except (ContentType.DoesNotExist, Permission.DoesNotExist):
            pass 
開發者ID:awemulya,項目名稱:kobo-predict,代碼行數:12,代碼來源:0012_add_permission_view_xform.py

示例7: get_object

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def get_object(collection, experiment=None, channel=None):
        """ Return the resource from the request

        Args:
            collection: Collection name from the request
            experiment: Experiment name from the request
            channel: Channel name

        Returns:
            Instance of the resource from the request

        """
        try:
            if collection and experiment and channel:
                # Channel specified
                collection_obj = Collection.objects.get(name=collection)
                experiment_obj = Experiment.objects.get(name=experiment, collection=collection_obj)
                obj = Channel.objects.get(name=channel, experiment=experiment_obj)
                resource_type = 'channel'
            elif collection and experiment:
                # Experiment
                collection_obj = Collection.objects.get(name=collection)
                obj = Experiment.objects.get(name=experiment, collection=collection_obj)
                resource_type = 'experiment'
            elif collection:
                obj = Collection.objects.get(name=collection)
                resource_type = 'collection'
            else:
                return None

            return (obj, resource_type)
        except Collection.DoesNotExist:
            raise BossError("{} does not exist".format(collection), ErrorCodes.RESOURCE_NOT_FOUND)
        except Experiment.DoesNotExist:
            raise BossError("{} does not exist".format(experiment), ErrorCodes.RESOURCE_NOT_FOUND)
        except Channel.DoesNotExist:
            raise BossError("{} does not exist".format(channel), ErrorCodes.RESOURCE_NOT_FOUND)

#    @check_role("resource-manager") 
開發者ID:jhuapl-boss,項目名稱:boss,代碼行數:41,代碼來源:views_permission.py

示例8: get_permission_id_by_name

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def get_permission_id_by_name(permission):
    cache_key = 'permission_id_cache_' + permission
    perm_id = cache.get(cache_key, None)
    if perm_id is None:
        try:
            perm_id = Permission.objects.get(
                codename=permission.split('.')[1],
                content_type__app_label=permission.split('.')[0]
            ).id
        except Permission.DoesNotExist:
            return None
        cache.set(cache_key, perm_id)
    return perm_id 
開發者ID:grey0ne,項目名稱:django-protector,代碼行數:15,代碼來源:helpers.py

示例9: get_permissions

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def get_permissions(names):
    """
    Given an iterable of permission names of the form "app_label.codename",
    return an iterable of the corresponding existing Permission objects.
    """
    names = set(names)  # Eliminate redundancies
    split_names = (name.split(".", 1) for name in names)
    query_elements = [
        Q(content_type__app_label=app_label, codename=codename)
        for app_label, codename in split_names
    ]
    permissions = (
        Permission.objects.filter(reduce(or_, query_elements))
        if query_elements
        else Permission.objects.none()
    )

    if len(permissions) != len(names):
        differences = names - {
            f"{p.content_type.app_label:s}.{p.codename:s}" for p in permissions
        }
        raise Permission.DoesNotExist(
            "Some permission names were not found: {:s}".format(", ".join(differences))
        )

    return permissions 
開發者ID:openfun,項目名稱:richie,代碼行數:28,代碼來源:helpers.py

示例10: test_helpers_get_permissions_unknown

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def test_helpers_get_permissions_unknown(self):
        """Trying to retrieve a permission that does not exist should raise an exception."""
        with self.assertRaises(Permission.DoesNotExist) as context:
            get_permissions(["unknown.unknown"])

        self.assertEqual(
            str(context.exception),
            "Some permission names were not found: unknown.unknown",
        ) 
開發者ID:openfun,項目名稱:richie,代碼行數:11,代碼來源:test_helpers.py

示例11: get_permission_obj

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def get_permission_obj(pid):
    try:
        return Permission.objects.get(pk=pid)
    except Permission.DoesNotExist:
        return None 
開發者ID:rfjer,項目名稱:autoAdmin,代碼行數:7,代碼來源:common.py

示例12: has_list_permission

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def has_list_permission(self, user):
        try:
            list_perm_codename = 'list_%s' % self.opts.model_name
            perm = Permission.objects.get(
                content_type__app_label=self.opts.app_label,
                codename=list_perm_codename,
            )
            return user.has_perm(perm)
        except Permission.DoesNotExist:
            pass
        return super(ReadOnlyPermissionHelper, self).has_list_permission(user) 
開發者ID:rkhleics,項目名稱:wagtailmodeladmin,代碼行數:13,代碼來源:helpers.py

示例13: handle

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def handle(self, *args, **options):
        # Loop groups
        for group_name in GROUPS_PERMISSIONS:

            # Get or create group
            group, created = Group.objects.get_or_create(name=group_name)

            if created:
                self.stdout.write("Created group {}".format(group.__str__()))

            # Loop models in group
            for model_cls in GROUPS_PERMISSIONS[group_name]:

                # Loop permissions in group/model
                for perm_index, perm_name in enumerate(GROUPS_PERMISSIONS[group_name][model_cls]):

                    # Generate permission name as Django would generate it
                    codename = perm_name + "_" + model_cls._meta.model_name

                    try:
                        # Find permission object and add to group
                        perm = Permission.objects.get(codename=codename)
                        group.permissions.add(perm)

                    except Permission.DoesNotExist:
                        self.stdout.write("{} permission not found".format(codename)) 
開發者ID:paidem,項目名稱:guacozy,代碼行數:28,代碼來源:initgroups.py

示例14: activate_user

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def activate_user(self, activation_key):
        """
        Activate an :class:`User` by supplying a valid ``activation_key``.

        If the key is valid and an user is found, activates the user and
        return it. Also sends the ``activation_complete`` signal.

        :param activation_key:
            String containing the secret nonce for a valid activation.

        :return:
            The newly activated :class:`User` or ``False`` if not successful.

        """
        if NONCE_RE.search(activation_key):
            try:
                userena = self.get(activation_key=activation_key)
            except self.model.DoesNotExist:
                return False
            if not userena.activation_key_expired():
                userena.activation_key = userena_settings.USERENA_ACTIVATED
                user = userena.user
                user.is_active = True
                userena.save(using=self._db)
                user.save(using=self._db)

                # Send the activation_complete signal
                userena_signals.activation_complete.send(sender=None, user=user)

                return user
        return False 
開發者ID:django-userena-ce,項目名稱:django-userena-ce,代碼行數:33,代碼來源:managers.py

示例15: confirm_email

# 需要導入模塊: from django.contrib.auth.models import Permission [as 別名]
# 或者: from django.contrib.auth.models.Permission import DoesNotExist [as 別名]
def confirm_email(self, confirmation_key):
        """
        Confirm an email address by checking a ``confirmation_key``.

        A valid ``confirmation_key`` will set the newly wanted e-mail
        address as the current e-mail address. Returns the user after
        success or ``False`` when the confirmation key is
        invalid. Also sends the ``confirmation_complete`` signal.

        :param confirmation_key:
            String containing the secret nonce that is used for verification.

        :return:
            The verified :class:`User` or ``False`` if not successful.

        """
        if NONCE_RE.search(confirmation_key):
            try:
                userena = self.get(
                    email_confirmation_key=confirmation_key,
                    email_unconfirmed__isnull=False,
                )
            except self.model.DoesNotExist:
                return False
            else:
                user = userena.user
                old_email = user.email
                user.email = userena.email_unconfirmed
                userena.email_unconfirmed, userena.email_confirmation_key = "", ""
                userena.save(using=self._db)
                user.save(using=self._db)

                # Send the confirmation_complete signal
                userena_signals.confirmation_complete.send(
                    sender=None, user=user, old_email=old_email
                )

                return user
        return False 
開發者ID:django-userena-ce,項目名稱:django-userena-ce,代碼行數:41,代碼來源:managers.py


注:本文中的django.contrib.auth.models.Permission.DoesNotExist方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。