Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[MIG] base_external_dbsource_sqlite to 14.0 #239

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .oca/oca-port/blacklist/base_external_dbsource_sqlite.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"pull_requests": {
"199": "(auto) Nothing to port from PR #199"
}
}
118 changes: 118 additions & 0 deletions base_external_dbsource_sqlite/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
=================================
External Database Source - SQLite
=================================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:2f7f7e8e4bb691849dfcdfdfd5c444f2a729d8b0095444162f4179989b662035
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/licence-LGPL--3-blue.png
:target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html
:alt: License: LGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fserver--backend-lightgray.png?logo=github
:target: https://github.com/OCA/server-backend/tree/15.0/base_external_dbsource_sqlite
:alt: OCA/server-backend
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/server-backend-15-0/server-backend-15-0-base_external_dbsource_sqlite
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
:target: https://runboat.odoo-community.org/builds?repo=OCA/server-backend&target_branch=15.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This module extends ``base_external_dbsource``, allowing you to connect to
foreign SQLite databases using SQLAlchemy.

**Table of contents**

.. contents::
:local:

Installation
============

To install this module, you need to:

* Install ``sqlalchemy`` python library

Configuration
=============

To configure this module, you need to:

#. Database sources can be configured in Settings > Configuration ->
Data sources.

Usage
=====

To use this module:

* Go to Settings > Database Structure > Database Sources
* Click on Create to enter the following information:

* Datasource name 
* Pasword
* Connector: Choose the database to which you want to connect
* Connection string: Specify how to connect to database

Known issues / Roadmap
======================

* Add X.509 authentication

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/server-backend/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/server-backend/issues/new?body=module:%20base_external_dbsource_sqlite%0Aversion:%2015.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
~~~~~~~

* Daniel Reis
* LasLabs

Contributors
~~~~~~~~~~~~

* Daniel Reis <[email protected]>
* Maxime Chambreuil <[email protected]>
* Gervais Naoussi <[email protected]>
* Dave Lasley <[email protected]>

* `Tecnativa <https://www.tecnativa.com>`_:

* Sergio Teruel

Maintainers
~~~~~~~~~~~

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
:alt: Odoo Community Association
:target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

This module is part of the `OCA/server-backend <https://github.com/OCA/server-backend/tree/15.0/base_external_dbsource_sqlite>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
1 change: 1 addition & 0 deletions base_external_dbsource_sqlite/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
15 changes: 15 additions & 0 deletions base_external_dbsource_sqlite/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Copyright <2011> <Daniel Reis, Maxime Chambreuil, Savoir-faire Linux>
# Copyright 2016 LasLabs Inc.
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
{
"name": "External Database Source - SQLite",
"version": "14.0.1.0.0",
"category": "Tools",
"author": "Daniel Reis, LasLabs, Odoo Community Association (OCA)",
"website": "https://github.com/OCA/server-backend",
"license": "LGPL-3",
"depends": ["base_external_dbsource"],
"external_dependencies": {"python": ["sqlalchemy"]},
"demo": ["demo/base_external_dbsource.xml"],
"installable": True,
}
9 changes: 9 additions & 0 deletions base_external_dbsource_sqlite/demo/base_external_dbsource.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<?xml version="1.0" ?>
<odoo>
<record model="base.external.dbsource" id="demo_sqlite">
<field name="name">SQLite Demo</field>
<field name="conn_string">Data Source=:memory:;Version=3;New=True;</field>
<field name="password">password</field>
<field name="connector">sqlite</field>
</record>
</odoo>
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 15.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr ""
24 changes: 24 additions & 0 deletions base_external_dbsource_sqlite/i18n/de.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
# Translators:
# Rudolf Schnapka <[email protected]>, 2017
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2017-05-10 00:47+0000\n"
"PO-Revision-Date: 2017-05-10 00:47+0000\n"
"Last-Translator: Rudolf Schnapka <[email protected]>, 2017\n"
"Language-Team: German (https://www.transifex.com/oca/teams/23907/de/)\n"
"Language: de\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=(n != 1);\n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Externe Datenbankquellen"
24 changes: 24 additions & 0 deletions base_external_dbsource_sqlite/i18n/es.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
# Translators:
# Fernando Lara <[email protected]>, 2017
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2017-02-22 00:54+0000\n"
"PO-Revision-Date: 2017-02-22 00:54+0000\n"
"Last-Translator: Fernando Lara <[email protected]>, 2017\n"
"Language-Team: Spanish (https://www.transifex.com/oca/teams/23907/es/)\n"
"Language: es\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=(n != 1);\n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Fuentes externas de la base de datos"
25 changes: 25 additions & 0 deletions base_external_dbsource_sqlite/i18n/hr.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
# Translators:
# Bole <[email protected]>, 2017
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2017-05-10 00:47+0000\n"
"PO-Revision-Date: 2017-05-10 00:47+0000\n"
"Last-Translator: Bole <[email protected]>, 2017\n"
"Language-Team: Croatian (https://www.transifex.com/oca/teams/23907/hr/)\n"
"Language: hr\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n"
"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Vanjske baze"
25 changes: 25 additions & 0 deletions base_external_dbsource_sqlite/i18n/nl_NL.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
# Translators:
# Peter Hageman <[email protected]>, 2017
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2017-06-22 01:11+0000\n"
"PO-Revision-Date: 2017-06-22 01:11+0000\n"
"Last-Translator: Peter Hageman <[email protected]>, 2017\n"
"Language-Team: Dutch (Netherlands) (https://www.transifex.com/oca/"
"teams/23907/nl_NL/)\n"
"Language: nl_NL\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=(n != 1);\n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Externe databasebronnen"
25 changes: 25 additions & 0 deletions base_external_dbsource_sqlite/i18n/pt_BR.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
# Translators:
# OCA Transbot <[email protected]>, 2017
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2017-01-21 04:22+0000\n"
"PO-Revision-Date: 2017-01-21 04:22+0000\n"
"Last-Translator: OCA Transbot <[email protected]>, 2017\n"
"Language-Team: Portuguese (Brazil) (https://www.transifex.com/oca/"
"teams/23907/pt_BR/)\n"
"Language: pt_BR\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=(n > 1);\n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Fontes Banco de Dados Externo"
25 changes: 25 additions & 0 deletions base_external_dbsource_sqlite/i18n/sl.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
# Translators:
# OCA Transbot <[email protected]>, 2017
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2017-01-21 04:22+0000\n"
"PO-Revision-Date: 2017-01-21 04:22+0000\n"
"Last-Translator: OCA Transbot <[email protected]>, 2017\n"
"Language-Team: Slovenian (https://www.transifex.com/oca/teams/23907/sl/)\n"
"Language: sl\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=4; plural=(n%100==1 ? 0 : n%100==2 ? 1 : n%100==3 || n"
"%100==4 ? 2 : 3);\n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Viri zunanjih podatkovnih baz"
24 changes: 24 additions & 0 deletions base_external_dbsource_sqlite/i18n/tr.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_sqlite
#
# Translators:
# OCA Transbot <[email protected]>, 2017
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.0\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2017-01-21 04:22+0000\n"
"PO-Revision-Date: 2017-01-21 04:22+0000\n"
"Last-Translator: OCA Transbot <[email protected]>, 2017\n"
"Language-Team: Turkish (https://www.transifex.com/oca/teams/23907/tr/)\n"
"Language: tr\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=(n > 1);\n"

#. module: base_external_dbsource_sqlite
#: model:ir.model,name:base_external_dbsource_sqlite.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Dış veritabanı kaynakları"
1 change: 1 addition & 0 deletions base_external_dbsource_sqlite/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import base_external_dbsource
44 changes: 44 additions & 0 deletions base_external_dbsource_sqlite/models/base_external_dbsource.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
# Copyright 2011 Daniel Reis
# Copyright 2016 LasLabs Inc.
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl.html).
import sqlalchemy

from odoo import models

from odoo.addons.base_external_dbsource.models import base_external_dbsource

CONNECTORS = base_external_dbsource.BaseExternalDbsource.CONNECTORS
CONNECTORS.append(("sqlite", "SQLite"))


class BaseExternalDbsource(models.Model):
"""It provides logic for connection to a SQLite data source."""

_inherit = "base.external.dbsource"

PWD_STRING_SQLITE = "Password=%s;"

def connection_close_sqlite(self, connection):
return connection.close()

def connection_open_sqlite(self):
return self._connection_open_sqlalchemy()

def execute_sqlite(self, sqlquery, sqlparams, metadata):
return self._execute_sqlalchemy(sqlquery, sqlparams, metadata)

def _connection_open_sqlalchemy(self):
return sqlalchemy.create_engine(self.conn_string_full).connect()

Check warning on line 31 in base_external_dbsource_sqlite/models/base_external_dbsource.py

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_sqlite/models/base_external_dbsource.py#L31

Added line #L31 was not covered by tests

def _execute_sqlalchemy(self, sqlquery, sqlparams, metadata):
rows, cols = list(), list()

Check warning on line 34 in base_external_dbsource_sqlite/models/base_external_dbsource.py

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_sqlite/models/base_external_dbsource.py#L34

Added line #L34 was not covered by tests
for record in self:
with record.connection_open() as connection:

Check warning on line 36 in base_external_dbsource_sqlite/models/base_external_dbsource.py

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_sqlite/models/base_external_dbsource.py#L36

Added line #L36 was not covered by tests
if sqlparams is None:
cur = connection.execute(sqlquery)

Check warning on line 38 in base_external_dbsource_sqlite/models/base_external_dbsource.py

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_sqlite/models/base_external_dbsource.py#L38

Added line #L38 was not covered by tests
else:
cur = connection.execute(sqlquery, sqlparams)

Check warning on line 40 in base_external_dbsource_sqlite/models/base_external_dbsource.py

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_sqlite/models/base_external_dbsource.py#L40

Added line #L40 was not covered by tests
if metadata:
cols = list(cur.keys())

Check warning on line 42 in base_external_dbsource_sqlite/models/base_external_dbsource.py

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_sqlite/models/base_external_dbsource.py#L42

Added line #L42 was not covered by tests
rows = [r for r in cur]
return rows, cols

Check warning on line 44 in base_external_dbsource_sqlite/models/base_external_dbsource.py

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_sqlite/models/base_external_dbsource.py#L44

Added line #L44 was not covered by tests
Loading
Loading