私はwebapp2でユーザーの認証とログイン/ログアウトに成功し、ユーザーがログインしているかどうかを知るためのデコレータがあり、これが機能します。
class MyPageHandler(NewBaseHandler):
"""
Only accessible to users that are logged in
"""
@user_required
def get(self):
user = self.auth.get_user_by_session()
self.render_template('mypage.htm', {'user': self.auth.get_user_by_session()})
ここで、ユーザー名として基本的なものを追加したいと思います。これはExpandoモデルであるため、webapp2_extrasで提供されるUserモデルをサブクラス化する必要がないのではないかと思います。ユーザー名を追加する方法、またはユーザーをユーザー名で更新する方法を教えてください。試していませんが、auth_idを表示できると思いますが、ユーザー名と同じではありませんか?
ありがとう
アップデート
Userモデルはexpandoモデルであるため、たとえばユーザーを作成するときに、次のように「プロパティを追加するだけ」のようです。
username = self.request.POST.get('username')
password = self.request.POST.get('password')
# Passing password_raw=password so password will be hashed
# Returns a tuple, where first value is BOOL. If True ok, If False no new user is created
user = self.auth.store.user_model.create_user(username, password_raw=password)
user.name = username
上記のコードを徹底的にテストしていませんが、webapp2では、機能を取得するためにUserクラスをサブクラス化する必要はないようです。
解決策/回避策
class SecureRequestHandler(BaseHandler):
"""
Only accessible to users that are logged in
"""
@user_required
def get(self, **kwargs):
a = self.app.config.get('foo')
auser = self.auth.get_user_by_session()
userid = auser['user_id']
user = auth_models.User.get_by_id(auser['user_id'])
try:
return "Secure zone %s <a href='%s'>Logout</a>" % (user.name, self.auth_config['logout_url'])
except (AttributeError, KeyError), e:
return "Secure zone"