Skip to content

[17.0][MIG] base_external_dbsource_firebird: Migration to 17.0 #329

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

Open
wants to merge 7 commits into
base: 17.0
Choose a base branch
from
Open
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
116 changes: 116 additions & 0 deletions base_external_dbsource_firebird/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,116 @@
===================================
External Database Source - Firebird
===================================

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

.. |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/17.0/base_external_dbsource_firebird
: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-17-0/server-backend-17-0-base_external_dbsource_firebird
: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=17.0
:alt: Try me on Runboat

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

This module extends ``base_external_dbsource``, allowing you to connect
to foreign Firebird databases.

**Table of contents**

.. contents::
:local:

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

To install this module, you need to:

- Install ``fdb`` python library

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

To configure this module, you need to:

1. 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
======================

- Setting ``metadata`` to ``True`` in ``execute_fdb`` will do nothing.
- ``execute`` is susceptible to SQL injection.

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_firebird%0Aversion:%2017.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]
- Michell Stuttgart [email protected]
- Dave Lasley [email protected]
- Abraham Anes [email protected]

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/17.0/base_external_dbsource_firebird>`_ 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_firebird/__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_firebird/__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 - Firebird",
"version": "17.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": ["fdb"]},
"demo": ["demo/base_external_dbsource.xml"],
"installable": True,
}
11 changes: 11 additions & 0 deletions base_external_dbsource_firebird/demo/base_external_dbsource.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
<?xml version="1.0" ?>
<odoo>
<record model="base.external.dbsource" id="demo_firebird">
<field name="name">Firebird Demo</field>
<field
name="conn_string"
>User=firebird;Database=SampleDatabase.fdb;DataSource=localhost;Port=3050;Dialect=3;Charset=NONE;Role=;Connection lifetime=15;Pooling=true;MinPoolSize=0;MaxPoolSize=50;Packet Size=8192;ServerType=0;</field>
<field name="password">password</field>
<field name="connector">fdb</field>
</record>
</odoo>
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * base_external_dbsource_firebird
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 10.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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.model_base_external_dbsource
msgid "External Database Sources"
msgstr ""

24 changes: 24 additions & 0 deletions base_external_dbsource_firebird/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_firebird
#
# 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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Externe Datenbankquellen"
24 changes: 24 additions & 0 deletions base_external_dbsource_firebird/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_firebird
#
# 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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.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_firebird/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_firebird
#
# 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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Vanjske baze"
25 changes: 25 additions & 0 deletions base_external_dbsource_firebird/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_firebird
#
# 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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Externe databasebronnen"
25 changes: 25 additions & 0 deletions base_external_dbsource_firebird/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_firebird
#
# 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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Fontes Banco de Dados Externo"
25 changes: 25 additions & 0 deletions base_external_dbsource_firebird/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_firebird
#
# 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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Viri zunanjih podatkovnih baz"
24 changes: 24 additions & 0 deletions base_external_dbsource_firebird/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_firebird
#
# 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_firebird
#: model:ir.model,name:base_external_dbsource_firebird.model_base_external_dbsource
msgid "External Database Sources"
msgstr "Dış veritabanı kaynakları"
1 change: 1 addition & 0 deletions base_external_dbsource_firebird/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import base_external_dbsource
42 changes: 42 additions & 0 deletions base_external_dbsource_firebird/models/base_external_dbsource.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
# Copyright 2011 Daniel Reis
# Copyright 2016 LasLabs Inc.
# Copyright 2025 Abraham Anes
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl.html).

import fdb

from odoo import fields, models


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

_inherit = "base.external.dbsource"

PWD_STRING_FDB = "Password=%s;"
connector = fields.Selection(
selection_add=[("fdb", "Firebird")], ondelete={"fdb": "cascade"}
)

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

def connection_open_fdb(self):
kwargs = {}
for option in self.conn_string_full.split(";"):
try:
key, value = option.split("=")
except ValueError:
continue
kwargs[key.lower()] = value
return fdb.connect(**kwargs)

def execute_fdb(self, sqlquery, sqlparams, metadata):
with self.connection_open_fdb() as conn:
cur = conn.cursor()

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

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_firebird/models/base_external_dbsource.py#L35-L36

Added lines #L35 - L36 were not covered by tests
if sqlparams is None:
cur.execute(sqlquery)

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

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_firebird/models/base_external_dbsource.py#L38

Added line #L38 was not covered by tests
else:
cur.execute(sqlquery, sqlparams)
rows = cur.fetchall()
return rows, []

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

View check run for this annotation

Codecov / codecov/patch

base_external_dbsource_firebird/models/base_external_dbsource.py#L40-L42

Added lines #L40 - L42 were not covered by tests
3 changes: 3 additions & 0 deletions base_external_dbsource_firebird/pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[build-system]
requires = ["whool"]
build-backend = "whool.buildapi"
Loading
Loading