Fixed typos and improved documentation for permission_required decorator addition from [3779]

git-svn-id: http://code.djangoproject.com/svn/django/trunk@3835 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Adrian Holovaty 2006-09-25 17:33:17 +00:00
parent 33a9a8f21a
commit 227626dcd0
2 changed files with 23 additions and 13 deletions

View File

@ -29,8 +29,8 @@ login_required.__doc__ = (
def permission_required(perm, login_url=LOGIN_URL): def permission_required(perm, login_url=LOGIN_URL):
""" """
Decorator for views that checks if a user has a particular permission Decorator for views that checks whether a user has a particular permission
enabled, redirectiing to the log-in page if necessary. enabled, redirecting to the log-in page if necessary.
""" """
return user_passes_test(lambda u: u.has_perm(perm), login_url=login_url) return user_passes_test(lambda u: u.has_perm(perm), login_url=login_url)

View File

@ -456,9 +456,9 @@ As a shortcut, you can use the convenient ``user_passes_test`` decorator::
# ... # ...
my_view = user_passes_test(lambda u: u.has_perm('polls.can_vote'))(my_view) my_view = user_passes_test(lambda u: u.has_perm('polls.can_vote'))(my_view)
We are using this particular test as a relatively simple example, however be We're using this particular test as a relatively simple example. However, if
aware that if you just want to test if a permission is available to a user, you just want to test whether a permission is available to a user, you can use
you can use the ``permission_required()`` decorator described below. the ``permission_required()`` decorator, described later in this document.
Here's the same thing, using Python 2.4's decorator syntax:: Here's the same thing, using Python 2.4's decorator syntax::
@ -495,20 +495,30 @@ Example in Python 2.4 syntax::
The permission_required decorator The permission_required decorator
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Since checking whether a user has a particular permission available to them is a **New in Django development version**
relatively common operation, Django provides a shortcut for that particular
case: the ``permission_required()`` decorator. Using this decorator, the It's a relatively common task to check whether a user has a particular
earlier example can be written as:: permission. For that reason, Django provides a shortcut for that case: the
``permission_required()`` decorator. Using this decorator, the earlier example
can be written as::
from django.contrib.auth.decorators import permission_required from django.contrib.auth.decorators import permission_required
def my_view(request): def my_view(request):
# ... # ...
my_view = permission_required('polls.can_vote')(my_view) my_view = permission_required('polls.can_vote')(my_view)
Note that ``permission_required()`` also takes an optional ``login_url`` Note that ``permission_required()`` also takes an optional ``login_url``
parameter. parameter. Example::
from django.contrib.auth.decorators import permission_required
def my_view(request):
# ...
my_view = permission_required('polls.can_vote', login_url='/loginpage/')(my_view)
As in the ``login_required`` decorator, ``login_url`` defaults to
``'/accounts/login/'``.
Limiting access to generic views Limiting access to generic views
-------------------------------- --------------------------------