Files
server-backend/base_external_dbsource_mysql/models/base_external_dbsource.py
Pedro M. Baeza 14df31c0ec [IMP] base_external_dbsource_mysql: Don't depend on SQLite
The amount of shared code is so insignificant, that it doesn't worth to depend on
base_external_dbsource_sqlite.

[UPD] Update base_external_dbsource_mysql.pot

[ADD] icon.png
2022-12-14 14:57:07 +01:00

56 lines
1.8 KiB
Python

# Copyright 2011 Daniel Reis
# Copyright 2016 LasLabs Inc.
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl.html).
import logging
from odoo import models
_logger = logging.getLogger(__name__)
try:
from odoo.addons.base_external_dbsource.models import (
base_external_dbsource,
)
CONNECTORS = base_external_dbsource.BaseExternalDbsource.CONNECTORS
try:
import MySQLdb
CONNECTORS.append(('mysql', 'MySQL'))
assert MySQLdb
except (ImportError, AssertionError):
_logger.info('MySQLdb not available. Please install "mysqlclient" '
'python package.')
try:
import sqlalchemy
except ImportError:
_logger.info('SQLAlchemy library not available. Please '
'install "sqlalchemy" python package.')
except ImportError:
_logger.info('base_external_dbsource Odoo module not found.')
class BaseExternalDbsource(models.Model):
""" It provides logic for connection to a MySQL data source. """
_inherit = "base.external.dbsource"
def connection_close_mysql(self, connection):
return connection.close()
def connection_open_mysql(self):
return sqlalchemy.create_engine(self.conn_string_full).connect()
def execute_mysql(self, sqlquery, sqlparams, metadata):
# FIXME: Duplicated method in modules to be consolidated in base
rows, cols = list(), list()
for record in self:
with record.connection_open() as connection:
if sqlparams is None:
cur = connection.execute(sqlquery)
else:
cur = connection.execute(sqlquery, sqlparams)
if metadata:
cols = list(cur.keys())
rows = [r for r in cur]
return rows, cols