forked from OCA/server-backend
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch '14.0-mig-base_external_dbsource_sqlite' of git+ssh://gi…
…thub.com/efatto/server-backend into 14.0
- Loading branch information
Showing
28 changed files
with
936 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
{ | ||
"pull_requests": { | ||
"199": "(auto) Nothing to port from PR #199" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from . import models |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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
9
base_external_dbsource_sqlite/demo/base_external_dbsource.xml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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> |
19 changes: 19 additions & 0 deletions
19
base_external_dbsource_sqlite/i18n/base_external_dbsource_sqlite.pot
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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 "" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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ı" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from . import base_external_dbsource |
44 changes: 44 additions & 0 deletions
44
base_external_dbsource_sqlite/models/base_external_dbsource.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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() | ||
|
||
def _execute_sqlalchemy(self, sqlquery, sqlparams, metadata): | ||
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 |
Oops, something went wrong.