Google AppEngine Login Decorator

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
from django.http import HttpResponsePermanentRedirect
from google.appengine.api import users

def loginrequired(func):
    def redirect_to_login(request):
        return HttpResponsePermanentRedirect(users.create_login_url(request.get_full_path()))

    user = users.get_current_user()
    if user:
        return func
    else:
        return redirect_to_login

@loginrequired
def i_am_protected(request):
    pass # clearly, this is a top secret view that needs protecting.

More like this

  1. Managing Google AppEngine datastore maintenance by cvedovini 2 years, 11 months ago
  2. ImageField for Google App Engine by davepeck 3 years, 7 months ago
  3. login_required decorator that doesn't redirect by brutasse 2 years, 4 months ago
  4. HTML/JS template filter to show localized dates/times by mback2k 4 years, 2 months ago
  5. Conditional cache decorator by alexisbellido 9 months, 4 weeks ago

Comments

dan.v (on April 15, 2008):

You probably want something like this instead:

def login_required(func):
    def _wrapper(request, *args, **kw):
        user = users.get_current_user()
        if user:
            return func(request, *args, **kw)
        else:
            return HttpResponseRedirect(users.create_login_url(request.get_full_path()))

    return _wrapper

#

(Forgotten your password?)