Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
113 commits
Select commit Hold shift + click to select a range
e607c99
[ADD] server evironment file + sample
jgrandguillaume Oct 12, 2011
badfa5e
[FIX] openerp\assert_exit_level does not exist ! in server_environment
nbessi Nov 4, 2011
242ee39
[FIX] typo
nbessi Jan 18, 2012
02a98e8
[FIX] drop the hack for the GTK client, because for 6.1 the web clien…
florentx Mar 5, 2012
b35cce3
[MRG] from upstream
Mar 5, 2012
4c6f19e
[MRG] Fix by florent.x on server_environment: drop the hack for the G…
Oct 23, 2012
3140119
[7.0] mark all unported modules as not installable
gurneyalex Jan 18, 2013
c4a6053
[7.0] 1st pass at porting server_environment
gurneyalex Jan 18, 2013
f65f22f
Generate .pot files
Mar 14, 2014
15a8fac
[PEP8] server_environment
yvaucher Jul 11, 2014
5df93fa
move all modules to __unported__ on master branch and set installable…
sbidoul Jul 12, 2014
d15348a
Moving server environment module and sample module
nbessi Sep 9, 2014
0766511
Port server environment to version 8.0
nbessi Sep 9, 2014
b2cb512
[FIX] travis
hbrunn Dec 8, 2014
ab4d65c
capture stderr as well as stdout when diagnosing
lepistone Feb 5, 2015
3467188
Add license key in __openerp__.py
yvaucher Feb 6, 2015
2b40dd1
fix pep8 W503
gurneyalex Feb 16, 2015
6b29bcf
Add OCA as author of OCA addons
gurneyalex Mar 2, 2015
4fcfac3
Add missing default oca icons
yvaucher Aug 18, 2015
e98fb5b
[FIX] unconfigured server_environment doesn't play
hbrunn Aug 18, 2015
2506daf
remove deprecated checks list
lepistone Aug 31, 2015
522b03f
[UPD] prefix versions with 8.0
sbidoul Oct 9, 2015
d0841be
[MIG] Make modules uninstallable
pedrobaeza Oct 14, 2015
b8a77d6
9.0 migration of server_environment
gurneyalex Jan 21, 2016
2380a88
[IMP] load server environment options from odoo rcfile too (#556)
sbidoul Sep 26, 2016
1c88080
[MIG] Make modules uninstallable
pedrobaeza Oct 6, 2016
b420952
[MIG] Rename manifest files
pedrobaeza Oct 6, 2016
fb676b9
Migration of server_environment to 10.0
Nov 7, 2016
ae6392e
[MIG] server_environment: Migration to 11.0
TDu Nov 13, 2017
7cc587a
server_environment: bump version
sbidoul Mar 30, 2018
f03c050
[REF] Server Environment: remove dependency on server_environement_files
ThomasBinsfeld Jun 4, 2018
5955e9d
remove obsolete .pot files [ci skip]
sbidoul Jun 15, 2018
56f4191
Add SERVER_ENV_CONFIG to configure vars from env. variable
Jul 19, 2018
b55959c
[REF] Server Environment: restrict access to server config to allowed…
ThomasBinsfeld Oct 8, 2018
5f95b9b
[MIG] server_environment from 11 to 12
sbidoul Nov 5, 2018
adb9e66
[MIG] server_environment: Migration to 13.0
grindtildeath Oct 9, 2019
28bdcc9
pre-commit, black, isort
sbidoul Oct 12, 2019
197f4d2
server_environment: lint fixes after migration
grindtildeath Oct 22, 2019
2ff4a67
server-environment: Run pre-commit
grindtildeath Oct 23, 2019
78de703
pre-commit, black, isort
sbidoul Nov 12, 2019
671b1ea
[13.0][FIX] server_environment: Change import for Serialized field
rousseldenis Dec 19, 2019
6fde997
Store the 'server.config' fields in sparse fields
Dec 3, 2019
b6a4585
server_environment: Improve tests.common to allow redefinition of ser…
grindtildeath Feb 13, 2020
16a472b
server_environment: running_env default to `test` (fix #44)
simahawk Apr 1, 2020
0e84ea5
Fix server_environment version
simahawk Jul 3, 2020
d3252d6
Add mixin for tech name
simahawk Jul 15, 2020
e92ae26
Update server_environment/serv_config.py
oscarolar Sep 22, 2020
f59bdd6
[IMP] : black, isort, prettier
mourad-ehm Oct 12, 2020
ae541f3
[MIG] server_environment: Migration to 14.0
mourad-ehm Oct 12, 2020
3bffd3c
Translated using Weblate (French)
sbidoul Dec 13, 2020
4615d49
Translated using Weblate (Spanish)
Mat-moran Feb 11, 2021
6d90af7
[UPD] Change LICENSE to LGPL
ivantodorovich Jul 6, 2021
bfcb9dd
[MIG] server_environment: migration to 15.0
JuMiSanAr Oct 18, 2021
87dea01
[FIX] Update server_env_mixin.py to avoid NoneType error
JuMiSanAr Oct 27, 2021
857cc80
15.0 server_environment is Production/Stable
gurneyalex Dec 2, 2021
ec213e9
server_environment: Update default fields label
Mar 18, 2022
8b78983
[IMP] server_environment: black, isort, prettier
FrancoMaxime Sep 1, 2022
52c9e96
[MIG] server_environment: Migration to 16.0
FrancoMaxime Sep 1, 2022
1d0b57e
Remove required from tech_name mixin
Jan 14, 2021
2080a0c
server_environment: do not copy tech_name
simahawk May 10, 2022
da71f9d
[IMP] server_environment: don't print stack trace when the field can'…
ivantodorovich Jul 12, 2022
d59753e
server_env: fix inverse method (closes #151)
simahawk Apr 4, 2023
98602ac
[IMP] Server env default fields string
qgroulard Jun 19, 2023
2629eb5
Translated using Weblate (Italian)
francesco-ooops Jun 22, 2023
3277c13
Translated using Weblate (Spanish)
Ivorra78 Jul 25, 2023
c9b1192
[FIX] don't use deprecated get_default_locale
sbidoul Aug 28, 2023
bac5ad5
Cache get_serverenvironment()
sbidoul Aug 28, 2023
9ff5b3c
Translated using Weblate (Spanish)
Ivorra78 Aug 21, 2023
39b4ab9
[IMP] server_environment: pre-commit stuff
moitabenfdz Nov 13, 2023
6a9f513
[MIG] server_environment: Migration to 17.0
moitabenfdz Nov 13, 2023
c72fd5c
[17.0][FIX]server_environment: custom fields must start with x_
moitabenfdz Nov 15, 2023
eee5823
[UPD] Update server_environment.pot
Jan 8, 2024
5928f87
[BOT] post-merge updates
OCA-git-bot Jan 8, 2024
7ef3a36
Update translation files
weblate Feb 3, 2024
e8ba538
Translated using Weblate (Spanish)
Ivorra78 Feb 12, 2024
3fae18e
Translated using Weblate (Italian)
mymage Feb 14, 2024
a34effb
[UPD] Update server_environment.pot
May 1, 2024
e60c20c
Update translation files
weblate May 1, 2024
b3a0475
Translated using Weblate (Swedish)
jakobkrabbe Jun 12, 2024
87f8341
server_environment: Fix value assignation in compute from default
grindtildeath Jun 20, 2024
d8c6321
[BOT] post-merge updates
OCA-git-bot Jun 25, 2024
0dda50e
[IMP] server_environment: allow env variable conf
petrus-v Mar 7, 2023
30ee378
[FIX] server_environment: compute_default assign
gurneyalex Jun 27, 2024
2df5f7b
[BOT] post-merge updates
OCA-git-bot Jun 28, 2024
758db03
[BOT] post-merge updates
OCA-git-bot Jul 11, 2024
25ae7ec
[MIG] server_environment: Migration to 18.0
qgroulard Sep 25, 2024
502a862
[IMP] pre-commit autofixes
sbidoul Sep 30, 2024
c01e37a
[UPD] Update server_environment.pot
Oct 4, 2024
484d030
[BOT] post-merge updates
OCA-git-bot Oct 4, 2024
528ebd5
Update translation files
weblate Oct 4, 2024
2bc3278
Translated using Weblate (Italian)
mymage Oct 5, 2024
6b59357
[FIX] server_environment: Fix tests on complex environments
etobella Dec 17, 2024
0dff106
[BOT] post-merge updates
OCA-git-bot Jan 14, 2025
d07db8f
[IMP] server_environment: hide SMTP passwords
florentx Oct 28, 2024
c891771
[FIX] server_environment: test independent from the working env
florentx Oct 29, 2024
95a6817
[UPD] Update server_environment.pot
Feb 9, 2025
6942e8a
Update translation files
weblate Feb 9, 2025
d82f0df
Translated using Weblate (Italian)
mymage Feb 9, 2025
092a22a
server_environment: fix default method not passed
hparfr Sep 25, 2023
ecda589
[BOT] post-merge updates
OCA-git-bot Apr 2, 2025
75632bf
[UPD] Update server_environment.pot
Apr 23, 2025
a6cd867
Update translation files
weblate Apr 23, 2025
c6f024b
Translated using Weblate (Italian)
mymage Apr 23, 2025
76c33b8
Translated using Weblate (Italian)
mymage May 16, 2025
6733e9b
Translated using Weblate (French)
vincent-hatakeyama May 16, 2025
3af42ad
[BOT] post-merge updates
OCA-git-bot Jun 4, 2025
284cbc2
Fix inheritance of server env techname mixin
grindtildeath Jun 2, 2025
b6888a8
[UPD] Update server_environment.pot
Jun 12, 2025
74fd733
[BOT] post-merge updates
OCA-git-bot Jun 12, 2025
0b8dff4
Update translation files
weblate Jun 12, 2025
973a837
[IMP] server_environment: pre-commit stuff
lembregtse Oct 2, 2025
64f6a60
[19.0] [MIG] server_environment: Migration to 19.0
lembregtse Oct 2, 2025
f1f46bc
[19.0] [FIX] server_environment: set env-computed fields to readonly
rven Oct 3, 2025
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
277 changes: 277 additions & 0 deletions server_environment/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,277 @@
.. image:: https://odoo-community.org/readme-banner-image
:target: https://odoo-community.org/get-involved?utm_source=readme
:alt: Odoo Community Association

======================================
server configuration environment files
======================================

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

.. |badge1| image:: https://img.shields.io/badge/maturity-Production%2FStable-green.png
:target: https://odoo-community.org/page/development-status
:alt: Production/Stable
.. |badge2| image:: https://img.shields.io/badge/license-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--env-lightgray.png?logo=github
:target: https://github.com/OCA/server-env/tree/19.0/server_environment
:alt: OCA/server-env
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/server-env-19-0/server-env-19-0-server_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/server-env&target_branch=19.0
:alt: Try me on Runboat

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

This module provides a way to define an environment in the main Odoo
configuration file and to read some configurations from files depending
on the configured environment: you define the environment in the main
configuration file, and the values for the various possible environments
are stored in the ``server_environment_files`` companion module.

The ``server_environment_files`` module is optional, the values can be
set using an environment variable with a fallback on default values in
the database.

The configuration read from the files are visible under the
Configuration menu. If you are not in the 'dev' environment you will not
be able to see the values contained in the defined secret keys (by
default : '*passw*', '*key*', '*secret*' and '*token*').

**Table of contents**

.. contents::
:local:

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

By itself, this module does little. See for instance the
``mail_environment`` addon which depends on this one to allow
configuring the incoming and outgoing mail servers depending on the
environment.

You can store your configuration values in a companion module called
``server_environment_files``. You can copy and customize the provided
``server_environment_files_sample`` module for this purpose.
Alternatively, you can provide them in environment variables
``SERVER_ENV_CONFIG`` and ``SERVER_ENV_CONFIG_SECRET``.

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

To configure this module, you need to edit the main configuration file
of your instance, and add a directive called ``running_env``. Commonly
used values are 'dev', 'test', 'production':

::

[options]
running_env=dev

Or set the ``RUNNING_ENV`` or ``ODOO_STAGE`` environment variable. If
both all are set config file will take the precedence on environment and
``RUNNING_ENV`` over ``ODOO_STAGE``.

``ODOO_STAGE`` is used for odoo.sh platform where we can't set
``RUNNING_ENV``, possible observed values are ``production``,
``staging`` and ``dev``

Values associated to keys containing 'passw' are only displayed in the
'dev' environment.

If you don't provide any value, test is used as a safe default.

You have several possibilities to set configuration values:

server_environment_files
------------------------

You can edit the settings you need in the ``server_environment_files``
addon. The ``server_environment_files_sample`` can be used as an
example:

- values common to all / most environments can be stored in the
``default/`` directory using the .ini file syntax;
- each environment you need to define is stored in its own directory
and can override or extend default values;
- you can override or extend values in the main configuration file of
your instance;

Environment variable
--------------------

You can define configuration in the environment variable
``SERVER_ENV_CONFIG`` and/or ``SERVER_ENV_CONFIG_SECRET``. The 2
variables are handled the exact same way, this is only a convenience for
the deployment where you can isolate the secrets in a different,
encrypted, file. They are multi-line environment variables in the same
configparser format than the files. If you used options in
``server_environment_files``, the options set in the environment
variable override them.

The options in the environment variable are not dependent of
``running_env``, the content of the variable must be set accordingly to
the running environment.

Example of setup:

A public file, containing that will contain public variables:

::

# These variables are not odoo standard variables,
# they are there to represent what your file could look like
export WORKERS='8'
export MAX_CRON_THREADS='1'
export LOG_LEVEL=info
export LOG_HANDLER=":INFO"
export DB_MAXCONN=5

# server environment options
export SERVER_ENV_CONFIG="
[storage_backend.my_sftp]
sftp_server=10.10.10.10
sftp_login=foo
sftp_port=22200
directory_path=Odoo
"

A second file which is encrypted and contains secrets:

::

# This variable is not an odoo standard variable,
# it is there to represent what your file could look like
export DB_PASSWORD='xxxxxxxxx'
# server environment options
export SERVER_ENV_CONFIG_SECRET="
[storage_backend.my_sftp]
sftp_password=xxxxxxxxx
"

**WARNING**

my_sftp must match the name of the record. If you want something more
reliable use server.env.techname.mixin and use tech_name field to
reference records. See "USAGE".

Default values
--------------

When using the ``server.env.mixin`` mixin, for each env-computed field,
a companion field ``<field>_env_default`` is created. This field is not
environment-dependent. It's a fallback value used when no key is set in
configuration files / environment variable.

When the default field is used, the field is made editable on Odoo.

Note: empty environment keys always take precedence over default fields

Server environment integration
------------------------------

Read the documentation of the class
`models/server_env_mixin.py <models/server_env_mixin.py>`__ and
[models/server_env_tech_name_mixin.py]
(models/server_env_tech_name_mixin.py)

Usage
=====

You can include a mixin in your model and configure the env-computed
fields by an override of ``_server_env_fields``.

::

class StorageBackend(models.Model):
_name = "storage.backend"
_inherit = ["storage.backend", "server.env.mixin"]

@property
def _server_env_fields(self):
return {"directory_path": {}}

Read the documentation of the class and methods in
`models/server_env_mixin.py <models/server_env_mixin.py>`__.

If you want to have a technical name to reference:

::

class StorageBackend(models.Model):
_name = "storage.backend"
_inherit = ["storage.backend", "server.env.techname.mixin"]

[...]

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

- it is not possible to set the environment from the command line. A
configuration file must be used.
- the module does not allow to set low level attributes such as
database server, etc.
- server.env.techname.mixin's tech_name field could leverage the new
option for computable / writable fields and get rid of some onchange
/ read / write code.

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

Bugs are tracked on `GitHub Issues <https://github.com/OCA/server-env/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-env/issues/new?body=module:%20server_environment%0Aversion:%2019.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
-------

* Camptocamp

Contributors
------------

- Florent Xicluna (Wingo) <florent.xicluna@gmail.com>
- Nicolas Bessi <nicolas.bessi@camptocamp.com>
- Alexandre Fayolle <alexandre.fayolle@camptocamp.com>
- Daniel Reis <dgreis@sapo.pt>
- Holger Brunn <hbrunn@therp.nl>
- Leonardo Pistone <leonardo.pistone@camptocamp.com>
- Adrien Peiffer <adrien.peiffer@acsone.com>
- Thierry Ducrest <thierry.ducrest@camptocamp.com>
- Guewen Baconnier <guewen.baconnier@camptocamp.com>
- Thomas Binfeld <thomas.binsfeld@acsone.eu>
- Stéphane Bidoul <stefane.bidoul@acsone.com>
- Simone Orsi <simahawk@gmail.com>

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-env <https://github.com/OCA/server-env/tree/19.0/server_environment>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
4 changes: 4 additions & 0 deletions server_environment/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
from . import monkeypatching
from . import models
from . import server_env
from .server_env import serv_config, setboolean
21 changes: 21 additions & 0 deletions server_environment/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Copyright Wingo SA
# Copyright 2018 Camptocamp (https://www.camptocamp.com).
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)

{
"name": "server configuration environment files",
"version": "19.0.1.0.0",
"depends": ["base", "base_sparse_field"],
"author": "Camptocamp,Odoo Community Association (OCA)",
"summary": "move some configurations out of the database",
"website": "https://github.com/OCA/server-env",
"license": "LGPL-3",
"development_status": "Production/Stable",
"category": "Tools",
"data": [
"security/ir.model.access.csv",
"security/res_groups.xml",
"serv_config.xml",
],
"installable": True,
}
Loading