auth_http_remote_user: slight reorganization and some comments (logic remains identical)
parent
436ffcd53f
commit
68e96cd782
|
@ -49,12 +49,7 @@ class Home(main.Home):
|
||||||
return werkzeug.exceptions.Unauthorized().get_response()
|
return werkzeug.exceptions.Unauthorized().get_response()
|
||||||
return super(Home, self).web_client(s_action, **kw)
|
return super(Home, self).web_client(s_action, **kw)
|
||||||
|
|
||||||
def _get_user_id_from_headers(self, res_users, headers, cr):
|
def _search_user(self, res_users, login, cr):
|
||||||
login = headers.get(self._REMOTE_USER_ATTRIBUTE, None)
|
|
||||||
if not login:
|
|
||||||
_logger.info("Expected fields '%s' not found in http headers\n %s",
|
|
||||||
self._REMOTE_USER_ATTRIBUTE, headers)
|
|
||||||
return None
|
|
||||||
user_ids = res_users.search(cr, SUPERUSER_ID, [('login', '=', login),
|
user_ids = res_users.search(cr, SUPERUSER_ID, [('login', '=', login),
|
||||||
('active', '=', True)])
|
('active', '=', True)])
|
||||||
assert len(user_ids) < 2
|
assert len(user_ids) < 2
|
||||||
|
@ -67,24 +62,30 @@ class Home(main.Home):
|
||||||
registry = openerp.registry(db_name)
|
registry = openerp.registry(db_name)
|
||||||
with registry.cursor() as cr:
|
with registry.cursor() as cr:
|
||||||
if AuthFromHttpRemoteUserInstalled._name not in registry:
|
if AuthFromHttpRemoteUserInstalled._name not in registry:
|
||||||
|
# module not installed in database,
|
||||||
|
# continue usual behavior
|
||||||
return
|
return
|
||||||
res_users = registry.get('res.users')
|
|
||||||
# get the user
|
|
||||||
headers = http.request.httprequest.headers.environ
|
|
||||||
user_id = self._get_user_id_from_headers(res_users,
|
|
||||||
headers,
|
|
||||||
cr)
|
|
||||||
|
|
||||||
|
headers = http.request.httprequest.headers.environ
|
||||||
|
|
||||||
|
login = headers.get(self._REMOTE_USER_ATTRIBUTE, None)
|
||||||
|
if not login:
|
||||||
|
# no HTTP_REMOTE_USER header,
|
||||||
|
# continue usual behavior
|
||||||
|
return
|
||||||
|
|
||||||
|
res_users = registry.get('res.users')
|
||||||
|
|
||||||
|
user_id = self._search_user(res_users, login, cr)
|
||||||
if not user_id:
|
if not user_id:
|
||||||
if self._REMOTE_USER_ATTRIBUTE in headers:
|
# HTTP_REMOTE_USER login not found in database
|
||||||
request.session.logout(keep_db=True)
|
request.session.logout(keep_db=True)
|
||||||
raise http.AuthenticationError()
|
raise http.AuthenticationError()
|
||||||
else:
|
|
||||||
return None
|
|
||||||
|
|
||||||
request_uid = request.session.uid
|
request_uid = request.session.uid
|
||||||
if request_uid:
|
if request_uid:
|
||||||
if request_uid == user_id:
|
if request_uid == user_id:
|
||||||
|
# already authenticated
|
||||||
return
|
return
|
||||||
else:
|
else:
|
||||||
request.session.logout(keep_db=True)
|
request.session.logout(keep_db=True)
|
||||||
|
|
Loading…
Reference in New Issue