From 87ab678790aab6c501aaf5dbe2294ddc5c015206 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Francisco=20Fern=C3=A1ndez=20=40PlanetaTIC?= Date: Thu, 13 Dec 2018 18:01:37 +0100 Subject: [PATCH] [FIX] auth_oauth_ip: Do not break inheritance in _auth_oauth_validate to call auth_oauth_check_client_id method --- auth_oauth_ip/models.py | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) diff --git a/auth_oauth_ip/models.py b/auth_oauth_ip/models.py index a70a7bea8..7cec7d90f 100644 --- a/auth_oauth_ip/models.py +++ b/auth_oauth_ip/models.py @@ -23,6 +23,8 @@ class res_users(models.Model): _inherit = 'res.users' def _auth_oauth_rpc(self, endpoint, access_token, local_host=None, local_port=None): + local_host = local_host or self.env.context.get('local_host') + local_port = local_port or self.env.context.get('local_port') params = werkzeug.url_encode({'access_token': access_token}) host = None try: @@ -39,7 +41,6 @@ def _auth_oauth_rpc(self, endpoint, access_token, local_host=None, local_port=No else: url = endpoint + '?' + params req = urllib.request.Request(url, headers={'host': host}) - print(('url', url)) with urllib.request.urlopen(req) as response: html = response.read() @@ -47,14 +48,6 @@ def _auth_oauth_rpc(self, endpoint, access_token, local_host=None, local_port=No @api.model def _auth_oauth_validate(self, provider, access_token): - """ return the validation data corresponding to the access token """ p = self.env['auth.oauth.provider'].browse(provider) - validation = self._auth_oauth_rpc( - p.validation_endpoint, access_token, local_host=p.local_host, local_port=p.local_port) - if validation.get("error"): - raise Exception(validation['error']) - if p.data_endpoint: - data = self._auth_oauth_rpc( - p.data_endpoint, access_token, local_host=p.local_host, local_port=p.local_port) - validation.update(data) - return validation + self = self.with_context(local_host=p.local_host, local_port=p.local_port) + return super(res_users, self)._auth_oauth_validate(provider, access_token)