summaryrefslogtreecommitdiffstats
path: root/testapi/opnfv_testapi/ui
diff options
context:
space:
mode:
authorSerenaFeng <feng.xiaowei@zte.com.cn>2017-05-18 20:06:26 +0800
committerSerenaFeng <feng.xiaowei@zte.com.cn>2017-05-18 20:06:26 +0800
commitc6bda58ba44dddb9151862d75a53224e7ad03227 (patch)
tree1d8e74ee8eeb3d7b69dd350396fb009a5d3e8a0c /testapi/opnfv_testapi/ui
parentd57892f46ca4864f2188d0e4fccb97d3987c10d1 (diff)
support showing user's specified contents after signin
Change-Id: Ia8897860757a2395873ff6972a508c38d7139854 Signed-off-by: SerenaFeng <feng.xiaowei@zte.com.cn>
Diffstat (limited to 'testapi/opnfv_testapi/ui')
-rw-r--r--testapi/opnfv_testapi/ui/auth/base.py (renamed from testapi/opnfv_testapi/ui/auth/utils.py)12
-rw-r--r--testapi/opnfv_testapi/ui/auth/sign.py (renamed from testapi/opnfv_testapi/ui/auth/handlers.py)26
-rw-r--r--testapi/opnfv_testapi/ui/auth/user.py24
3 files changed, 53 insertions, 9 deletions
diff --git a/testapi/opnfv_testapi/ui/auth/utils.py b/testapi/opnfv_testapi/ui/auth/base.py
index c3912ad..bea87c4 100644
--- a/testapi/opnfv_testapi/ui/auth/utils.py
+++ b/testapi/opnfv_testapi/ui/auth/base.py
@@ -3,6 +3,18 @@ import string
from six.moves.urllib import parse
+from opnfv_testapi.resources import handlers
+
+
+class BaseHandler(handlers.GenericApiHandler):
+ def __init__(self, application, request, **kwargs):
+ super(BaseHandler, self).__init__(application, request, **kwargs)
+ self.table = 'users'
+
+ def set_cookies(self, cookies):
+ for cookie_n, cookie_v in cookies:
+ self.set_secure_cookie(cookie_n, cookie_v)
+
def get_token(length=30):
"""Get random token."""
diff --git a/testapi/opnfv_testapi/ui/auth/handlers.py b/testapi/opnfv_testapi/ui/auth/sign.py
index 511952d..c92196a 100644
--- a/testapi/opnfv_testapi/ui/auth/handlers.py
+++ b/testapi/opnfv_testapi/ui/auth/sign.py
@@ -1,21 +1,19 @@
from six.moves.urllib import parse
from opnfv_testapi.common import config
-from opnfv_testapi.resources import handlers
+from opnfv_testapi.ui.auth import base
from opnfv_testapi.ui.auth import constants as const
-from opnfv_testapi.ui.auth import utils
-
CONF = config.Config()
-class SigninHandler(handlers.GenericApiHandler):
+class SigninHandler(base.BaseHandler):
def get(self):
- csrf_token = utils.get_token()
+ csrf_token = base.get_token()
return_endpoint = parse.urljoin(CONF.api_url,
CONF.osid_openid_return_to)
- return_to = utils.set_query_params(return_endpoint,
- {const.CSRF_TOKEN: csrf_token})
+ return_to = base.set_query_params(return_endpoint,
+ {const.CSRF_TOKEN: csrf_token})
params = {
const.OPENID_MODE: CONF.osid_openid_mode,
@@ -28,10 +26,20 @@ class SigninHandler(handlers.GenericApiHandler):
const.OPENID_NS_SREG_REQUIRED: CONF.osid_openid_sreg_required,
}
url = CONF.osid_openstack_openid_endpoint
- url = utils.set_query_params(url, params)
+ url = base.set_query_params(url, params)
self.redirect(url=url, permanent=False)
-class SigninReturnHandler(handlers.GenericApiHandler):
+class SigninReturnHandler(base.BaseHandler):
def get(self):
+ openid = self.get_query_argument(const.OPENID_CLAIMED_ID)
+ user_info = {
+ 'openid': openid,
+ 'email': self.get_query_argument(const.OPENID_NS_SREG_EMAIL),
+ 'fullname': self.get_query_argument(const.OPENID_NS_SREG_FULLNAME)
+ }
+
+ self.db_save(self.table, user_info)
+ if not self.get_secure_cookie('openid'):
+ self.set_secure_cookie('openid', openid)
self.redirect(url=CONF.ui_url)
diff --git a/testapi/opnfv_testapi/ui/auth/user.py b/testapi/opnfv_testapi/ui/auth/user.py
new file mode 100644
index 0000000..140bca5
--- /dev/null
+++ b/testapi/opnfv_testapi/ui/auth/user.py
@@ -0,0 +1,24 @@
+from tornado import gen
+from tornado import web
+
+from opnfv_testapi.common import raises
+from opnfv_testapi.ui.auth import base
+
+
+class ProfileHandler(base.BaseHandler):
+ @web.asynchronous
+ @gen.coroutine
+ def get(self):
+ openid = self.get_secure_cookie('openid')
+ if openid:
+ try:
+ user = yield self.db_find_one({'openid': openid})
+ self.finish_request({
+ "openid": user.get('openid'),
+ "email": user.get('email'),
+ "fullname": user.get('fullname'),
+ "is_admin": False
+ })
+ except Exception:
+ pass
+ raises.Unauthorized('Unauthorized')