mirror of
https://github.com/django/django.git
synced 2024-12-27 03:25:58 +00:00
546740544d
Thanks Benjamin Bach for the report and initial patch.
This is a security fix; disclosure to follow shortly.
Backport of 8b93b31487
from master
58 lines
1.3 KiB
Python
58 lines
1.3 KiB
Python
from django.http import HttpResponse
|
|
from django.views.generic import RedirectView
|
|
from django.core.urlresolvers import reverse_lazy
|
|
|
|
from django.contrib.auth.decorators import user_passes_test
|
|
|
|
|
|
def empty_view(request, *args, **kwargs):
|
|
return HttpResponse('')
|
|
|
|
|
|
def kwargs_view(request, arg1=1, arg2=2):
|
|
return HttpResponse('')
|
|
|
|
|
|
def absolute_kwargs_view(request, arg1=1, arg2=2):
|
|
return HttpResponse('')
|
|
|
|
|
|
def defaults_view(request, arg1, arg2):
|
|
pass
|
|
|
|
|
|
def nested_view(request):
|
|
pass
|
|
|
|
|
|
def erroneous_view(request):
|
|
import non_existent # NOQA
|
|
|
|
|
|
def pass_resolver_match_view(request, *args, **kwargs):
|
|
response = HttpResponse('')
|
|
response.resolver_match = request.resolver_match
|
|
return response
|
|
|
|
uncallable = "Can I be a view? Pleeeease?"
|
|
|
|
|
|
class ViewClass(object):
|
|
def __call__(self, request, *args, **kwargs):
|
|
return HttpResponse('')
|
|
|
|
view_class_instance = ViewClass()
|
|
|
|
|
|
class LazyRedirectView(RedirectView):
|
|
url = reverse_lazy('named-lazy-url-redirected-to')
|
|
|
|
|
|
@user_passes_test(lambda u: u.is_authenticated(), login_url=reverse_lazy('some-login-page'))
|
|
def login_required_view(request):
|
|
return HttpResponse('Hello you')
|
|
|
|
|
|
def bad_view(request, *args, **kwargs):
|
|
raise ValueError("I don't think I'm getting good value for this view")
|