Using: Odoo 12.0-20190128 (Community Edition)
am trying to get Keycloak working on Odoo using the base OAUTH2 setup. I am getting an access denied. In my keycloak server, I see the user in the session. I suspect the mapping is not correct. Any suggestions would be appreciated...
Errors in log:
2019-03-03 22:43:11,701 1 ERROR db odoo.addons.auth_oauth.controllers.main: OAuth2: Expecting value: line 1 column 1 (char 0)
Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/odoo/addons/auth_oauth/controllers/main.py", line 142, in signin
credentials = env['res.users'].sudo().auth_oauth(provider, kw)
File "/usr/lib/python3/dist-packages/odoo/addons/auth_oauth/models/res_users.py", line 96, in auth_oauth
validation = self._auth_oauth_validate(provider, access_token)
File "/usr/lib/python3/dist-packages/odoo/addons/auth_oauth/models/res_users.py", line 34, in _auth_oauth_validate
validation = self._auth_oauth_rpc(oauth_provider.validation_endpoint, access_token)
File "/usr/lib/python3/dist-packages/odoo/addons/auth_oauth/models/res_users.py", line 28, in _auth_oauth_rpc
return requests.get(endpoint, params={'access_token': access_token}).json()
File "/usr/lib/python3/dist-packages/requests/models.py", line 850, in json
return complexjson.loads(self.text, **kwargs)
File "/usr/lib/python3.5/json/__init__.py", line 319, in loads
return _default_decoder.decode(s)
File "/usr/lib/python3.5/json/decoder.py", line 339, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python3.5/json/decoder.py", line 357, in raw_decode
raise JSONDecodeError("Expecting value", s, err.value) from None
json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)
2019-03-03 22:43:11,704 1 INFO db werkzeug: 172.51.20.1 - - [03/Mar/2019 22:43:11] "GET /auth_oauth/signin?state={%22r%22%3A+%22https%253A%252F%252Fodoo.pathfinder.gov.bc.ca%252Fweb%22%2C+%22p%22%3A+7%2C+%22d%22%3A+%22db%22}&session_state=4946aea0-1a42-4809-a10b-030aaba4c50f&access_token=eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICI1NXhiZzcyaml6NWQ3cEtkbzdwNFhLdTB2VFA2UXMtemthZzFaY1ZKWTZVIn0.eyJqdGkiOiIzNTRkY2EzYi0wMWE4LTRmM2EtODdkZC1iOWZkZThjMzc2YTkiLCJleHAiOjE1NTE2NTM4ODYsIm5iZiI6MCwiaWF0IjoxNTUxNjUyOTg2LCJpc3MiOiJodHRwczovL3Nzby10ZXN0LnBhdGhmaW5kZXIuZ292LmJjLmNhL2F1dGgvcmVhbG1zL3NiYyIsImF1ZCI6Ik9kb28iLCJzdWIiOiI0YjZjODM5YS03NjA0LTRiMzYtOGE1My1lNzI1Mjg5ZGZjNzkiLCJ0eXAiOiJCZWFyZXIiLCJhenAiOiJPZG9vIiwiYXV0aF90aW1lIjoxNTUxNjQ1MTg3LCJzZXNzaW9uX3N0YXRlIjoiNDk0NmFlYTAtMWE0Mi00ODA5LWExMGItMDMwYWFiYTRjNTBmIiwiYWNyIjoiMCIsImFsbG93ZWQtb3JpZ2lucyI6WyIqIl0sInJlYWxtX2FjY2VzcyI6eyJyb2xlcyI6WyJpZGlyIiwib2ZmbGluZV9hY2Nlc3MiLCJhZG1pbiIsInVtYV9hdXRob3JpemF0aW9uIl19LCJyZXNvdXJjZV9hY2Nlc3MiOnsicmVhbG0tbWFuYWdlbWVudCI6eyJyb2xlcyI6WyJ2aWV3LXJlYWxtIiwidmlldy1pZGVudGl0eS1wcm92aWRlcnMiLCJtYW5hZ2UtaWRlbnRpdHktcHJvdmlkZXJzIiwiaW1wZXJzb25hdGlvbiIsInJlYWxtLWFkbWluIiwiY3JlYXRlLWNsaWVudCIsIm1hbmFnZS11c2VycyIsInF1ZXJ5LXJlYWxtcyIsInZpZXctYXV0aG9yaXphdGlvbiIsInF1ZXJ5LWNsaWVudHMiLCJxdWVyeS11c2VycyIsIm1hbmFnZS1ldmVudHMiLCJtYW5hZ2UtcmVhbG0iLCJ2aWV3LWV2ZW50cyIsInZpZXctdXNlcnMiLCJ2aWV3LWNsaWVudHMiLCJtYW5hZ2UtYXV0aG9yaXphdGlvbiIsIm1hbmFnZS1jbGllbnRzIiwicXVlcnktZ3JvdXBzIl19LCJhY2NvdW50Ijp7InJvbGVzIjpbIm1hbmFnZS1hY2NvdW50IiwibWFuYWdlLWFjY291bnQtbGlua3MiLCJ2aWV3LXByb2ZpbGUiXX19LCJuYW1lIjoiR2lsbGFuaSwgS2FyaW0gQ0lUWjpFWCIsInByZWZlcnJlZF91c2VybmFtZSI6ImlkaXIva2dpbGxhbmkiLCJnaXZlbl9uYW1lIjoiR2lsbGFuaSwgS2FyaW0gQ0lUWjpFWCIsImVtYWlsIjoia2FyaW0uZ2lsbGFuaUBnb3YuYmMuY2EifQ.MFfD0se0hcI-l6oxL7gJ_RFEDosYBKDZNO3VEVLUyPjhjN8xkK5rGycK_ZyE_D9OFbCBX8E8c9qnQWDrik7i43sfBt6luPKs7TkLQJZHtfOt6ASYsAVKJyJxjZRBm_Pume98MXEBiMEhVCU3Un5V94k3f7ae_lTnE1Vqx-t2QtMeA-KDAFz9m8mL2PbFyOnDnfeb2ar_vjHkPkMxf1iruglSj8-xHYUQ8qMATX6WsxEPLBMlFuRoGdnWstSzz_tzAmQ7sAVY0lY2oWeQVbA5Fj3_oCOMSnwYxhtpaabTPosZs1y9nvTHtBRReKgt88p0dW3FqWWzSWefCD7Lzwho1g&token_type=bearer&expires_in=900¬-before-policy=1548956992 HTTP/1.1" 303 - 2 0.002 5.174
2019-03-03 22:43:11,861 1 INFO db werkzeug: 172.51.20.1 - - [03/Mar/2019 22:43:11] "GET /web/login?oauth_error=2 HTTP/1.1" 200 - 11 0.029 0.065
2019-03-03 22:43:12,172 1 INFO db werkzeug: 172.51.20.1 - - [03/Mar/2019 22:43:12] "GET /web/webclient/qweb?mods= HTTP/1.1" 200 - 1 0.001 0.007
2019-03-03 22:43:12,174 1 INFO db werkzeug: 172.51.20.1 - - [03/Mar/2019 22:43:12] "POST /web/webclient/bootstrap_translations HTTP/1.1" 200 - 1 0.001
I also tried to install the Keycloak auth app (v10) but received errors:
Error:
Odoo Server Error
Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/odoo/tools/convert.py", line 757, in parse
self._tags[rec.tag](rec, de, mode=mode)
File "/usr/lib/python3/dist-packages/odoo/tools/convert.py", line 573, in _tag_record
model = self.env[rec_model]
File "/usr/lib/python3/dist-packages/odoo/api.py", line 821, in __getitem__
return self.registry[model_name]._browse((), self)
File "/usr/lib/python3/dist-packages/odoo/modules/registry.py", line 176, in __getitem__
return self.models[model_name]
KeyError: 'ir.values'
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/odoo/http.py", line 654, in _handle_exception
return super(JsonRequest, self)._handle_exception(exception)
File "/usr/lib/python3/dist-packages/odoo/http.py", line 312, in _handle_exception
raise pycompat.reraise(type(exception), exception, sys.exc_info()[2])
File "/usr/lib/python3/dist-packages/odoo/tools/pycompat.py", line 87, in reraise
raise value
File "/usr/lib/python3/dist-packages/odoo/http.py", line 696, in dispatch
result = self._call_function(**self.params)
File "/usr/lib/python3/dist-packages/odoo/http.py", line 344, in _call_function
return checked_call(self.db, *args, **kwargs)
File "/usr/lib/python3/dist-packages/odoo/service/model.py", line 97, in wrapper
return f(dbname, *args, **kwargs)
File "/usr/lib/python3/dist-packages/odoo/http.py", line 337, in checked_call
result = self.endpoint(*a, **kw)
File "/usr/lib/python3/dist-packages/odoo/http.py", line 939, in __call__
return self.method(*args, **kw)
File "/usr/lib/python3/dist-packages/odoo/http.py", line 517, in response_wrap
response = f(*args, **kw)
File "/usr/lib/python3/dist-packages/odoo/addons/web/controllers/main.py", line 966, in call_button
action = self._call_kw(model, method, args, {})
File "/usr/lib/python3/dist-packages/odoo/addons/web/controllers/main.py", line 954, in _call_kw
return call_kw(request.env[model], method, args, kwargs)
File "/usr/lib/python3/dist-packages/odoo/api.py", line 749, in call_kw
return _call_kw_multi(method, model, args, kwargs)
File "/usr/lib/python3/dist-packages/odoo/api.py", line 736, in _call_kw_multi
result = method(recs, *args, **kwargs)
File "<decorator-gen-61>", line 2, in button_immediate_install
File "/usr/lib/python3/dist-packages/odoo/addons/base/models/ir_module.py", line 73, in check_and_log
return method(self, *args, **kwargs)
File "/usr/lib/python3/dist-packages/odoo/addons/base/models/ir_module.py", line 444, in button_immediate_install
return self._button_immediate_function(type(self).button_install)
File "/usr/lib/python3/dist-packages/odoo/addons/base/models/ir_module.py", line 553, in _button_immediate_function
modules.registry.Registry.new(self._cr.dbname, update_module=True)
File "/usr/lib/python3/dist-packages/odoo/modules/registry.py", line 86, in new
odoo.modules.load_modules(registry._db, force_demo, status, update_module)
File "/usr/lib/python3/dist-packages/odoo/modules/loading.py", line 421, in load_modules
loaded_modules, update_module, models_to_check)
File "/usr/lib/python3/dist-packages/odoo/modules/loading.py", line 313, in load_marked_modules
perform_checks=perform_checks, models_to_check=models_to_check
File "/usr/lib/python3/dist-packages/odoo/modules/loading.py", line 222, in load_module_graph
load_data(cr, idref, mode, kind='data', package=package, report=report)
File "/usr/lib/python3/dist-packages/odoo/modules/loading.py", line 68, in load_data
tools.convert_file(cr, package.name, filename, idref, mode, noupdate, kind, report)
File "/usr/lib/python3/dist-packages/odoo/tools/convert.py", line 801, in convert_file
convert_xml_import(cr, module, fp, idref, mode, noupdate, report)
File "/usr/lib/python3/dist-packages/odoo/tools/convert.py", line 864, in convert_xml_import
obj.parse(doc.getroot(), mode=mode)
File "/usr/lib/python3/dist-packages/odoo/tools/convert.py", line 763, in parse
exc_info[2]
File "/usr/lib/python3/dist-packages/odoo/tools/pycompat.py", line 86, in reraise
raise value.with_traceback(tb)
File "/usr/lib/python3/dist-packages/odoo/tools/convert.py", line 757, in parse
self._tags[rec.tag](rec, de, mode=mode)
File "/usr/lib/python3/dist-packages/odoo/tools/convert.py", line 573, in _tag_record
model = self.env[rec_model]
File "/usr/lib/python3/dist-packages/odoo/api.py", line 821, in __getitem__
return self.registry[model_name]._browse((), self)
File "/usr/lib/python3/dist-packages/odoo/modules/registry.py", line 176, in __getitem__
return self.models[model_name]
odoo.tools.convert.ParseError: "ir.values" while parsing /mnt/extra-addons/auth_keycloak/wizard/keycloak_create_wiz.xml:55, near
<record id="action_purge_model_line_value" model="ir.values">
<field name="name">Push users to Keycloak</field>
<field name="key">action</field>
<field name="key2">client_action_multi</field>
<field name="model">res.users</field>
<field name="value" eval="'ir.actions.act_window,%d' % ref('auth_keycloak.keycloak_create_users')"/>
</record>