odoorpc

The odoorpc module defines the ODOO class.

The ODOO class is the entry point to manage Odoo servers. You can use this one to write Python programs that performs a variety of automated jobs that communicate with a Odoo server.

Here’s a sample session using this module:

>>> import odoorpc
>>> odoo = odoorpc.ODOO('localhost', port=8069)  # connect to localhost, default port
>>> odoo.login('dbname', 'admin', 'admin')

To catch debug logs of OdooRPC from your own code, you have to configure a logger the way you want with a log level set to DEBUG:

>>> import logging
>>> logging.basicConfig()
>>> logger = logging.getLogger('odoorpc')
>>> logger.setLevel(logging.DEBUG)

Then all queries generated by OdooRPC will be logged:

>>> import odoorpc
>>> odoo = odoorpc.ODOO()
>>> odoo.login('dbname', 'admin', 'admin')
DEBUG:odoorpc.rpc.jsonrpclib:(JSON,send) http://localhost:8069/web/session/authenticate {'jsonrpc': '2.0', 'id': 499807971, 'method': 'call', 'params': {'db': 'dbname', 'login': 'admin', 'password': '**********'}}
DEBUG:odoorpc.rpc.jsonrpclib:(JSON,recv) http://localhost:8069/web/session/authenticate {'jsonrpc': '2.0', 'id': 499807971, 'method': 'call', 'params': {'db': 'dbname', 'login': 'admin', 'password': '**********'}} => {'result': {'is_admin': True, 'server_version': '12.0-20181008', 'currencies': {'2': {'digits': [69, 2], 'position': 'before', 'symbol': '$'}, '1': {'digits': [69, 2], 'position': 'after', 'symbol': '€'}}, 'partner_display_name': 'YourCompany, Mitchell Admin', 'company_id': 1, 'username': 'admin', 'web_tours': [], 'user_companies': False, 'session_id': '61cb37d21771531f789bea631a03236aa21f06d4', 'is_system': True, 'server_version_info': [12, 0, 0, 'final', 0, ''], 'db': 'odoorpc_v12', 'name': 'Mitchell Admin', 'web.base.url': 'http://localhost:8069', 'user_context': {'lang': 'fr_FR', 'tz': 'Europe/Brussels', 'uid': 2}, 'odoobot_initialized': True, 'show_effect': 'True', 'partner_id': 3, 'uid': 2}, 'id': 499807971, 'jsonrpc': '2.0'}