diff --git a/carrier_account_environment/README.rst b/carrier_account_environment/README.rst new file mode 100644 index 0000000000..589d2e2fa1 --- /dev/null +++ b/carrier_account_environment/README.rst @@ -0,0 +1,142 @@ +====================================================== +Carrier accounts configuration with server_environment +====================================================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:15c18b3a9f9749e2a79ca683e39b3f1d2dde711298fd126fe7aab57058705e88 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |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-AGPL--3-blue.png + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fdelivery--carrier-lightgray.png?logo=github + :target: https://github.com/OCA/delivery-carrier/tree/17.0/carrier_account_environment + :alt: OCA/delivery-carrier +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/delivery-carrier-17-0/delivery-carrier-17-0-carrier_account_environment + :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/delivery-carrier&target_branch=17.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module allows to configure carrier informations using the +server_environment mechanism: you can then have different servers for +the production and the test environment. + +**Table of contents** + +.. contents:: + :local: + +Configuration +============= + +With this module installed, the delivery carrier are configured in the +server_environment_files module (which is a module you should provide, +see the documentation of server_environment for more information). + +In the configuration file of each environment, you may first use the +section [carrier_account]. + +Then for each server, you can define additional values or override the +default values with a section named [carrier_account.resource_name] +where "resource_name" is the name of the server. + +Example of config file : + +:: + + [carrier_account] + # here is the default format + file_format = 'ZPL' + + + [carrier_account.mycarrier] + name = mycarrier + account = 587 + password = 123promenons-nous-dans-les-bois456cueillir-des-saucisses + + + [carrier_account.mycarrier2] + name = mycarrier2 + account = 666 + password = wazaaaaa + file_format = PDF + +As an alternative of server_environment_files, there is also a module +named server_environment_data_encryption which allow to set the +environement dependent values directly in the database, by the user +itself. It will be encrypted, to avoid security issues with secrets, see +the documentationn of server_environment_data_encryption for more +information. The advantage of setting the environment dependent value +directly in the database is that it does not require a developper/odoo +administrator to change a carrier account. + +Usage +===== + +Once configured, Odoo will read the carrier values from the +configuration file related to each environment defined in the main Odoo +file or in carrier.account model. + +Bug Tracker +=========== + +Bugs are tracked on `GitHub 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 `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +------- + +* Akretion +* Camptocamp + +Contributors +------------ + +- David Béal +- Guewen Baconnier +- `Heliconia Solutions Pvt. Ltd. `__ + + - Bhavesh Heliconia + +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. + +.. |maintainer-florian-dacosta| image:: https://github.com/florian-dacosta.png?size=40px + :target: https://github.com/florian-dacosta + :alt: florian-dacosta + +Current `maintainer `__: + +|maintainer-florian-dacosta| + +This module is part of the `OCA/delivery-carrier `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/carrier_account_environment/__init__.py b/carrier_account_environment/__init__.py new file mode 100644 index 0000000000..0650744f6b --- /dev/null +++ b/carrier_account_environment/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/carrier_account_environment/__manifest__.py b/carrier_account_environment/__manifest__.py new file mode 100644 index 0000000000..54b1ae3ccb --- /dev/null +++ b/carrier_account_environment/__manifest__.py @@ -0,0 +1,16 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). + +{ + "name": "Carrier accounts configuration with server_environment", + "version": "17.0.1.0.0", + "category": "Tools", + "summary": "Configure carriers with server_environment_files", + "maintainers": ["florian-dacosta"], + "author": "Akretion, Camptocamp, Odoo Community Association (OCA)", + "license": "AGPL-3", + "website": "https://github.com/OCA/delivery-carrier", + "depends": [ + "server_environment", + "delivery_carrier_account", + ], +} diff --git a/carrier_account_environment/i18n/carrier_account_environment.pot b/carrier_account_environment/i18n/carrier_account_environment.pot new file mode 100644 index 0000000000..30a4bfc60e --- /dev/null +++ b/carrier_account_environment/i18n/carrier_account_environment.pot @@ -0,0 +1,24 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * carrier_account_environment +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.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: carrier_account_environment +#: model:ir.model,name:carrier_account_environment.model_carrier_account +msgid "Base account datas" +msgstr "" + +#. module: carrier_account_environment +#: model:ir.model.fields,field_description:carrier_account_environment.field_carrier_account__server_env_defaults +msgid "Server Env Defaults" +msgstr "" diff --git a/carrier_account_environment/i18n/carrier_environment.pot b/carrier_account_environment/i18n/carrier_environment.pot new file mode 100644 index 0000000000..ef4d90f71f --- /dev/null +++ b/carrier_account_environment/i18n/carrier_environment.pot @@ -0,0 +1,20 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * carrier_environment +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.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: carrier_environment +#: model:ir.model,name:carrier_environment.model_carrier_account +msgid "Base account datas" +msgstr "" + diff --git a/carrier_account_environment/i18n/es.po b/carrier_account_environment/i18n/es.po new file mode 100644 index 0000000000..8cf25a64a2 --- /dev/null +++ b/carrier_account_environment/i18n/es.po @@ -0,0 +1,27 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * carrier_account_environment +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2024-01-30 14:33+0000\n" +"Last-Translator: Ivorra78 \n" +"Language-Team: none\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" +"X-Generator: Weblate 4.17\n" + +#. module: carrier_account_environment +#: model:ir.model,name:carrier_account_environment.model_carrier_account +msgid "Base account datas" +msgstr "Datos de la cuenta base" + +#. module: carrier_account_environment +#: model:ir.model.fields,field_description:carrier_account_environment.field_carrier_account__server_env_defaults +msgid "Server Env Defaults" +msgstr "Valores por Defecto del Entorno del Servidor" diff --git a/carrier_account_environment/i18n/it.po b/carrier_account_environment/i18n/it.po new file mode 100644 index 0000000000..c649517d85 --- /dev/null +++ b/carrier_account_environment/i18n/it.po @@ -0,0 +1,27 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * carrier_account_environment +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2024-08-22 10:06+0000\n" +"Last-Translator: mymage \n" +"Language-Team: none\n" +"Language: it\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" +"X-Generator: Weblate 5.6.2\n" + +#. module: carrier_account_environment +#: model:ir.model,name:carrier_account_environment.model_carrier_account +msgid "Base account datas" +msgstr "Dati account base" + +#. module: carrier_account_environment +#: model:ir.model.fields,field_description:carrier_account_environment.field_carrier_account__server_env_defaults +msgid "Server Env Defaults" +msgstr "Server ambiente predefinito" diff --git a/carrier_account_environment/i18n/pt_BR.po b/carrier_account_environment/i18n/pt_BR.po new file mode 100644 index 0000000000..d790b5fa74 --- /dev/null +++ b/carrier_account_environment/i18n/pt_BR.po @@ -0,0 +1,28 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * carrier_account_environment +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2024-07-05 19:47+0000\n" +"Last-Translator: rodrigosottomaiormacedo " +"\n" +"Language-Team: none\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" +"X-Generator: Weblate 4.17\n" + +#. module: carrier_account_environment +#: model:ir.model,name:carrier_account_environment.model_carrier_account +msgid "Base account datas" +msgstr "Dados da conta base" + +#. module: carrier_account_environment +#: model:ir.model.fields,field_description:carrier_account_environment.field_carrier_account__server_env_defaults +msgid "Server Env Defaults" +msgstr "Padrões de ambiente do servidor" diff --git a/carrier_account_environment/models/__init__.py b/carrier_account_environment/models/__init__.py new file mode 100644 index 0000000000..2553ae394c --- /dev/null +++ b/carrier_account_environment/models/__init__.py @@ -0,0 +1 @@ +from . import carrier_account diff --git a/carrier_account_environment/models/carrier_account.py b/carrier_account_environment/models/carrier_account.py new file mode 100644 index 0000000000..5effe45a75 --- /dev/null +++ b/carrier_account_environment/models/carrier_account.py @@ -0,0 +1,28 @@ +# Copyright 2019 David BEAL @ Akretion +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). + +from odoo import api, models + + +class CarrierAccount(models.Model): + _name = "carrier.account" + _inherit = ["carrier.account", "server.env.mixin"] + + @property + def _server_env_fields(self): + carrier_fields = super()._server_env_fields + carrier_fields.update( + { + "account": {}, + "password": {}, + } + ) + return carrier_fields + + @api.model + def _server_env_global_section_name(self): + """Name of the global section in the configuration files + + Can be customized in your model + """ + return "carrier_account" diff --git a/carrier_account_environment/pyproject.toml b/carrier_account_environment/pyproject.toml new file mode 100644 index 0000000000..4231d0cccb --- /dev/null +++ b/carrier_account_environment/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" diff --git a/carrier_account_environment/readme/CONFIGURE.md b/carrier_account_environment/readme/CONFIGURE.md new file mode 100644 index 0000000000..268737cd5f --- /dev/null +++ b/carrier_account_environment/readme/CONFIGURE.md @@ -0,0 +1,38 @@ +With this module installed, the delivery carrier are configured in the +server_environment_files module (which is a module you should provide, +see the documentation of server_environment for more information). + +In the configuration file of each environment, you may first use the +section \[carrier_account\]. + +Then for each server, you can define additional values or override the +default values with a section named \[carrier_account.resource_name\] +where "resource_name" is the name of the server. + +Example of config file : + + [carrier_account] + # here is the default format + file_format = 'ZPL' + + + [carrier_account.mycarrier] + name = mycarrier + account = 587 + password = 123promenons-nous-dans-les-bois456cueillir-des-saucisses + + + [carrier_account.mycarrier2] + name = mycarrier2 + account = 666 + password = wazaaaaa + file_format = PDF + +As an alternative of server_environment_files, there is also a module +named server_environment_data_encryption which allow to set the +environement dependent values directly in the database, by the user +itself. It will be encrypted, to avoid security issues with secrets, see +the documentationn of server_environment_data_encryption for more +information. The advantage of setting the environment dependent value +directly in the database is that it does not require a developper/odoo +administrator to change a carrier account. diff --git a/carrier_account_environment/readme/CONTRIBUTORS.md b/carrier_account_environment/readme/CONTRIBUTORS.md new file mode 100644 index 0000000000..f9a4982f43 --- /dev/null +++ b/carrier_account_environment/readme/CONTRIBUTORS.md @@ -0,0 +1,4 @@ +- David Béal \<\> +- Guewen Baconnier \<\> +- [Heliconia Solutions Pvt. Ltd.](https://www.heliconia.io) + - Bhavesh Heliconia diff --git a/carrier_account_environment/readme/DESCRIPTION.md b/carrier_account_environment/readme/DESCRIPTION.md new file mode 100644 index 0000000000..13f1ded9e4 --- /dev/null +++ b/carrier_account_environment/readme/DESCRIPTION.md @@ -0,0 +1,3 @@ +This module allows to configure carrier informations using the +server_environment mechanism: you can then have different servers for +the production and the test environment. diff --git a/carrier_account_environment/readme/USAGE.md b/carrier_account_environment/readme/USAGE.md new file mode 100644 index 0000000000..46cf3e3130 --- /dev/null +++ b/carrier_account_environment/readme/USAGE.md @@ -0,0 +1,3 @@ +Once configured, Odoo will read the carrier values from the +configuration file related to each environment defined in the main Odoo +file or in carrier.account model. diff --git a/carrier_account_environment/static/description/icon.png b/carrier_account_environment/static/description/icon.png new file mode 100644 index 0000000000..3a0328b516 Binary files /dev/null and b/carrier_account_environment/static/description/icon.png differ diff --git a/carrier_account_environment/static/description/index.html b/carrier_account_environment/static/description/index.html new file mode 100644 index 0000000000..93f1df171d --- /dev/null +++ b/carrier_account_environment/static/description/index.html @@ -0,0 +1,479 @@ + + + + + +Carrier accounts configuration with server_environment + + + +
+

Carrier accounts configuration with server_environment

+ + +

Beta License: AGPL-3 OCA/delivery-carrier Translate me on Weblate Try me on Runboat

+

This module allows to configure carrier informations using the +server_environment mechanism: you can then have different servers for +the production and the test environment.

+

Table of contents

+ +
+

Configuration

+

With this module installed, the delivery carrier are configured in the +server_environment_files module (which is a module you should provide, +see the documentation of server_environment for more information).

+

In the configuration file of each environment, you may first use the +section [carrier_account].

+

Then for each server, you can define additional values or override the +default values with a section named [carrier_account.resource_name] +where “resource_name” is the name of the server.

+

Example of config file :

+
+[carrier_account]
+# here is the default format
+file_format = 'ZPL'
+
+
+[carrier_account.mycarrier]
+name = mycarrier
+account = 587
+password = 123promenons-nous-dans-les-bois456cueillir-des-saucisses
+
+
+[carrier_account.mycarrier2]
+name = mycarrier2
+account = 666
+password = wazaaaaa
+file_format = PDF
+
+

As an alternative of server_environment_files, there is also a module +named server_environment_data_encryption which allow to set the +environement dependent values directly in the database, by the user +itself. It will be encrypted, to avoid security issues with secrets, see +the documentationn of server_environment_data_encryption for more +information. The advantage of setting the environment dependent value +directly in the database is that it does not require a developper/odoo +administrator to change a carrier account.

+
+
+

Usage

+

Once configured, Odoo will read the carrier values from the +configuration file related to each environment defined in the main Odoo +file or in carrier.account model.

+
+
+

Bug Tracker

+

Bugs are tracked on GitHub 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.

+

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

+
+
+

Credits

+
+

Authors

+
    +
  • Akretion
  • +
  • Camptocamp
  • +
+
+
+

Contributors

+ +
+
+

Maintainers

+

This module is maintained by the OCA.

+ +Odoo Community Association + +

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.

+

Current maintainer:

+

florian-dacosta

+

This module is part of the OCA/delivery-carrier project on GitHub.

+

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

+
+
+
+ + diff --git a/carrier_account_environment/tests/__init__.py b/carrier_account_environment/tests/__init__.py new file mode 100644 index 0000000000..948a4f17c3 --- /dev/null +++ b/carrier_account_environment/tests/__init__.py @@ -0,0 +1 @@ +from . import test_carrier_account_environment diff --git a/carrier_account_environment/tests/test_carrier_account_environment.py b/carrier_account_environment/tests/test_carrier_account_environment.py new file mode 100644 index 0000000000..a0e2d340c8 --- /dev/null +++ b/carrier_account_environment/tests/test_carrier_account_environment.py @@ -0,0 +1,26 @@ +# Copyright 2019 David BEAL @ Akretion +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). + +from odoo.addons.base.tests.common import BaseCommon + + +class TestCarrierAccount(BaseCommon): + @classmethod + def setUpClass(cls): + super().setUpClass() + cls.carrier_account = cls.env["carrier.account"].create( + {"name": "Test Carrier"} + ) + + def test_server_env_fields(self): + """Test that _server_env_fields includes expected fields.""" + server_env_fields = self.carrier_account._server_env_fields + self.assertIn("account", server_env_fields) + self.assertIn("password", server_env_fields) + + def test_server_env_global_section_name(self): + """Test that _server_env_global_section_name + returns the correct section name.""" + self.assertEqual( + self.carrier_account._server_env_global_section_name(), "carrier_account" + )