diff --git a/check_process b/check_process
index 9de44be..ab58cea 100644
--- a/check_process
+++ b/check_process
@@ -1,8 +1,8 @@
;; Test complet sans multisite
auto_remove=1
; Manifest
- domain="domain.tld" (DOMAIN)
- version="12"
+ domain="domain.tld"
+ version="14"
oca=0
admin_password="testpassw0rD"
lang="en_US"
@@ -17,24 +17,8 @@
upgrade=1
backup_restore=1
multi_instance=1
- wrong_user=1
- wrong_path=0
- incorrect_path=0
- corrupt_source=1
- fail_download_source=1
- port_already_use=1
- final_path_already_use=1
-;;; Levels
- Level 1=auto
- Level 2=auto
- Level 3=auto
- Level 4=1
- Level 5=auto
- Level 6=auto
- Level 7=auto
- Level 8=0
- Level 9=0
- Level 10=0
+ port_already_use=0
+ change_url=0
;;; Options
Email=ljf+libreerp_ynh@reflexlibre.net
Notification=down
diff --git a/conf/12.src b/conf/12.src
index da62001..295c3d4 100644
--- a/conf/12.src
+++ b/conf/12.src
@@ -1,5 +1,5 @@
-SOURCE_URL=https://github.com/odoo/odoo/archive/206e0b71ac74147a989db60cddae801534b97bdc.tar.gz
-SOURCE_SUM=a6d8d28bb7f20ac88fd149c652d7e4ce0f35241e46e7a3a347265dae0d7535fe
+SOURCE_URL=https://github.com/odoo/odoo/archive/336c9aab3619abb5bfbeb07f87ae014facdefb0b.tar.gz
+SOURCE_SUM=3d37bc31383bfad827c3fdbab4daa3914ad036fd70fe1f20925ed18d2b9e1f87
SOURCE_FILENAME=odoo-12.tar.gz
SOURCE_FORMAT=tar.gz
SOURCE_SUM_PRG=sha256sum
diff --git a/conf/14.src b/conf/14.src
new file mode 100644
index 0000000..8da0284
--- /dev/null
+++ b/conf/14.src
@@ -0,0 +1,5 @@
+SOURCE_URL=https://github.com/odoo/odoo/archive/d8322e64c6d999ffc72093b2ef2db91532138c89.tar.gz
+SOURCE_SUM=40cbbc93ab594f614499ccdd04922590c420bfadeaf2f889853a5d58073e5fef
+SOURCE_FILENAME=odoo-14.tar.gz
+SOURCE_FORMAT=tar.gz
+SOURCE_SUM_PRG=sha256sum
diff --git a/conf/app.service.j2 b/conf/app.service.j2
index 600de12..b1304f1 100644
--- a/conf/app.service.j2
+++ b/conf/app.service.j2
@@ -1,16 +1,16 @@
[Unit]
-Description={{ app }}
+Description=__APP__
Requires=postgresql.service
After=network.target postgresql.service
[Service]
Type=simple
-SyslogIdentifier={{ app }}
+SyslogIdentifier=__APP__
PermissionsStartOnly=true
-User={{ app }}
-Group={{ app }}
+User=__APP__
+Group=__APP__
Environment=PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin
-ExecStart={{ bin_file }} --config {{ conf_file }} --logfile /var/log/{{ app }}.log
+ExecStart=__BIN_FILE__ --config __CONF_FILE__ --logfile /var/log/__APP__.log
Restart=always
RestartSec=3
StandardOutput=journal+console
diff --git a/conf/app.src b/conf/app.src
index 62eab80..7b93ab8 100644
--- a/conf/app.src
+++ b/conf/app.src
@@ -1,4 +1,4 @@
-SOURCE_URL=https://downloads.wkhtmltopdf.org/0.12/0.12.4/wkhtmltox-0.12.4_linux-generic-amd64.tar.xz
+SOURCE_URL=https://github.com/wkhtmltopdf/wkhtmltopdf/releases/download/0.12.4/wkhtmltox-0.12.4_linux-generic-amd64.tar.xz
SOURCE_SUM=049b2cdec9a8254f0ef8ac273afaf54f7e25459a273e27189591edc7d7cf29db
SOURCE_FILE=wkhtmltox-0.12.4_linux-generic-amd64.tar.xz
SOURCE_FORMAT=tar.xz
diff --git a/conf/nginx.conf.j2 b/conf/nginx.conf.j2
index 40ff7ea..7a361c9 100644
--- a/conf/nginx.conf.j2
+++ b/conf/nginx.conf.j2
@@ -2,10 +2,15 @@ location / {
if ($scheme = http) {
rewrite ^ https://$server_name$request_uri? permanent;
}
- try_files $uri @{{ app }};
+ try_files $uri @__APP__;
}
-location @{{ app }} {
- proxy_pass http://127.0.0.1:{{ port }};
+location @__APP__ {
+ proxy_pass http://127.0.0.1:__PORT__;
+
+ client_max_body_size 50M;
+ client_body_timeout 60m;
+ fastcgi_read_timeout 60m;
+
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
proxy_buffers 16 64k;
proxy_buffer_size 128k;
@@ -20,7 +25,7 @@ location @{{ app }} {
proxy_send_timeout 720s;
}
location /longpolling {
- proxy_pass http://127.0.0.1:{{ port_chat }};
+ proxy_pass http://127.0.0.1:__PORT_CHAT__;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
@@ -34,7 +39,7 @@ location ~* /web/static/ {
proxy_cache_valid 200 90m;
proxy_buffering on;
expires 864000;
- proxy_pass http://127.0.0.1:{{ port }};
+ proxy_pass http://127.0.0.1:__PORT__;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
diff --git a/conf/oca-12.src b/conf/oca-12.src
new file mode 100644
index 0000000..5e7f51d
--- /dev/null
+++ b/conf/oca-12.src
@@ -0,0 +1,5 @@
+SOURCE_URL=https://github.com/OCA/OCB/archive/4df6b0b164c6f384fdb7df40e51e80780572273a.tar.gz
+SOURCE_SUM=e064dcd121ca207cbfa18c5f5f63c394ee6a1ca03f9ebbd6b88e6a62dda6bca0
+SOURCE_FILENAME=odoo-12.tar.gz
+SOURCE_FORMAT=tar.gz
+SOURCE_SUM_PRG=sha256sum
diff --git a/conf/oca-14.src b/conf/oca-14.src
new file mode 100644
index 0000000..4f5e8f4
--- /dev/null
+++ b/conf/oca-14.src
@@ -0,0 +1,5 @@
+SOURCE_URL=https://github.com/OCA/OCB/archive/b7dc86b530718c090ba26b8eea0154d1c50c05f2.tar.gz
+SOURCE_SUM=d2ca8bbe913e90f1623c6f2375d4cd2c40d4ed4abb650e66f7691669cbab90fa
+SOURCE_FILENAME=odoo-14.tar.gz
+SOURCE_FORMAT=tar.gz
+SOURCE_SUM_PRG=sha256sum
diff --git a/conf/server.conf.j2 b/conf/server.conf.j2
index 432078a..4947406 100644
--- a/conf/server.conf.j2
+++ b/conf/server.conf.j2
@@ -1,22 +1,18 @@
[options]
; This is the password that allows database operations:
without_demo = all
-admin_passwd = {{ admin_password }}
+admin_passwd = __ADMIN_PASSWORD__
db_host = localhost
db_port = 5432
-db_user = {{ db_name }}
-db_password = {{ db_pass }}
-{% if preinstall == '1' %}
-dbfilter = ^{{ db_name }}$
-{% else %}
-db_name = {{ db_name }}
-{% if app_version > 9 %}dbfilter = False{% endif %}
-list_db = False
-{% endif %}
-addons_path = {{ final_path }}/{{ APPNAME }}/addons,{{ final_path }}/custom-addons
+db_user = __DB_NAME__
+db_password = __DB_PASS__
+__CONTENT__
+__CONTENT2__
+__CONTENT3__
+addons_path = __FINAL_PATH__/__APPNAME__/addons,__FINAL_PATH__/custom-addons
proxy_mode = true
-logfile = /var/log/{{ app }}.log
+logfile = /var/log/__APP__.log
xmlrpc_interface = 127.0.0.1
netrpc_interface = 127.0.0.1
-xmlrpc_port = {{ port }}
-longpolling_port = {{ port_chat }}
+xmlrpc_port = __PORT__
+longpolling_port = __PORT_CHAT__
diff --git a/manifest.json b/manifest.json
index aa74be2..3f2e54e 100644
--- a/manifest.json
+++ b/manifest.json
@@ -34,8 +34,8 @@
"example": "erp.domain.org"
}, {
"name": "version",
- "choices": ["8", "9", "10", "11", "12"],
- "default": "12",
+ "choices": ["11", "12", "14"],
+ "default": "14",
"ask": {
"en": "Choose the version you want",
"fr": "Choisissez la version désirée"
diff --git a/scripts/_common.sh b/scripts/_common.sh
index acd31da..463f944 100644
--- a/scripts/_common.sh
+++ b/scripts/_common.sh
@@ -2,31 +2,35 @@
# Common variables
#
-export APPNAME="libreerp"
+export appname="libreerp"
export FORKNAME="odoo"
-DEPENDENCIES="curl postgresql xfonts-75dpi xfonts-base wkhtmltopdf node-less python3-dev gcc libldap2-dev libssl-dev libsasl2-dev python3-pip python3-dev python3-venv python3-wheel libxslt-dev libzip-dev python3-setuptools python-virtualenv python-wheel python-setuptools libjpeg-dev zlib1g-dev virtualenv libfreetype6-dev"
+DEPENDENCIES="curl postgresql xfonts-75dpi xfonts-base wkhtmltopdf node-less python3-dev gcc libldap2-dev libssl-dev libsasl2-dev python3-pip python3-dev python3-venv python3-wheel libxslt-dev libzip-dev python3-setuptools libjpeg-dev zlib1g-dev libfreetype6-dev libffi-dev libpq-dev"
function debranding() {
# Remove Odoo references to avoid trademark issue
- if [ -d $final_path/$APPNAME/$FORKNAME ]; then
- python_app=$final_path/$APPNAME/$FORKNAME
+ if [ -d $final_path/$appname/$FORKNAME ]; then
+ python_app=$final_path/$appname/$FORKNAME
else
- python_app=$final_path/$APPNAME/openerp
+ python_app=$final_path/$appname/openerp
fi
- find $final_path/$APPNAME -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/Powered by ]*>Odoo<\/a>//g' {} \;
- find $final_path/$APPNAME -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/]*>Powered by <[^>]*>Odoo<\/[^>]*><\/a>//g' {} \;
- find $final_path/$APPNAME -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/Powered by <[^>]*>Odoo<\/[^>]*>//g' {} \;
- find $final_path/$APPNAME -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/Powered by <[^>]*>]*Odoo[^>]*><\/a>//g' {} \;
- sed -i 's/]*>My Odoo.com account<\/a>//g' $final_path/$APPNAME/addons/web/static/src/xml/base.xml
- sed -i 's/]*>Documentation<\/a>//g' $final_path/$APPNAME/addons/web/static/src/xml/base.xml
- sed -i 's/]*>Support<\/a>//g' $final_path/$APPNAME/addons/web/static/src/xml/base.xml
+ find $final_path/$appname -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/Powered by ]*>Odoo<\/a>//g' {} \;
+ find $final_path/$appname -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/]*>Powered by <[^>]*>Odoo<\/[^>]*><\/a>//g' {} \;
+ find $final_path/$appname -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/Powered by <[^>]*>Odoo<\/[^>]*>//g' {} \;
+ find $final_path/$appname -type f \( -iname '*.xml' -o -iname '*.po' \) -exec sed -i 's/Powered by <[^>]*>]*Odoo[^>]*><\/a>//g' {} \;
+ sed -i 's/]*>My Odoo.com account<\/a>//g' $final_path/$appname/addons/web/static/src/xml/base.xml
+ sed -i 's/]*>Documentation<\/a>//g' $final_path/$appname/addons/web/static/src/xml/base.xml
+ sed -i 's/]*>Support<\/a>//g' $final_path/$appname/addons/web/static/src/xml/base.xml
cp ../conf/logo_type.png $python_app/addons/base/static/img/logo_white.png
- cp ../conf/favicon.ico $final_path/$APPNAME/addons/web/static/src/img/favicon.ico
+ cp ../conf/favicon.ico $final_path/$appname/addons/web/static/src/img/favicon.ico
}
function setup_files() {
- ynh_setup_source $final_path/$APPNAME $app_version
+ if [[ $oca -eq 0 ]]; then
+ ynh_setup_source $final_path/$appname $app_version
+ else
+ ynh_setup_source $final_path/$appname "oca-$app_version"
+ fi
debranding
mkdir -p $final_path/custom-addons
chown -R $app:$app $final_path
@@ -38,10 +42,10 @@ function setup_files() {
chown $app:$app $conf_file
# Autoinstall the LDAP auth module
- if ls $final_path/$APPNAME/$FORKNAME-bin > /dev/null ; then
- ynh_replace_string "^{$" "{'auto_install': True," ${final_path}/$APPNAME/addons/auth_ldap/__manifest__.py
+ if ls $final_path/$appname/$FORKNAME-bin > /dev/null ; then
+ ynh_replace_string "^{$" "{'auto_install': True," ${final_path}/$appname/addons/auth_ldap/__manifest__.py
else
- ynh_replace_string "'auto_install': False" "'auto_install': True" ${final_path}/$APPNAME/addons/auth_ldap/__openerp__.py
+ ynh_replace_string "'auto_install': False" "'auto_install': True" ${final_path}/$appname/addons/auth_ldap/__openerp__.py
fi
fi
@@ -63,14 +67,14 @@ function install_dependencies() {
fi
fi
pushd $final_path
- if grep "python3" $final_path/$APPNAME/$FORKNAME-bin ; then
+ if grep "python3" $final_path/$appname/$FORKNAME-bin ; then
python3 -m venv venv
venv/bin/pip3 install wheel
- venv/bin/pip3 install -r $APPNAME/requirements.txt
+ venv/bin/pip3 install -r $appname/requirements.txt
else
virtualenv venv
venv/bin/pip install wheel
- venv/bin/pip install -r $APPNAME/requirements.txt
+ venv/bin/pip install -r $appname/requirements.txt
fi
popd
}
diff --git a/scripts/_future.sh b/scripts/_future.sh
index 30e25be..7695cee 100644
--- a/scripts/_future.sh
+++ b/scripts/_future.sh
@@ -32,11 +32,26 @@ ynh_sso_access () {
ynh_configure () {
local TEMPLATE=$1
local DEST=$2
+ content=""
+ content2=""
+ content3=""
+ if [[ $preinstall == '1' ]]
+ then
+ content="dbfilter = $db_name"
+ else
+ content="db_name = $db_name"
+ if [[ $app_version > 9 ]]
+ then
+ content2="dbfilter = False"
+ fi
+ content3="list_db = False"
+ fi
+
mkdir -p "$(dirname $DEST)"
if [ -f '../manifest.json' ] ; then
- ynh_render_template "${YNH_CWD}/../conf/$TEMPLATE.j2" "$DEST"
+ ynh_add_config "${YNH_CWD}/../conf/$TEMPLATE.j2" "$DEST"
else
- ynh_render_template "${YNH_CWD}/../settings/conf/$TEMPLATE.j2" "$DEST"
+ ynh_add_config "${YNH_CWD}/../settings/conf/$TEMPLATE.j2" "$DEST"
fi
}
diff --git a/scripts/backup b/scripts/backup
index 3413100..6ddf741 100644
--- a/scripts/backup
+++ b/scripts/backup
@@ -14,7 +14,7 @@ final_path=$(ynh_app_setting_get "$app" final_path)
conf_file=$(ynh_app_setting_get "$app" conf_file)
# Backup sources & data
-ynh_backup "${final_path}/$APPNAME"
+ynh_backup "${final_path}/$appname"
ynh_backup "${final_path}/custom-addons"
ynh_backup "${final_path}/.local"
diff --git a/scripts/install b/scripts/install
index 82e8434..eb13e98 100644
--- a/scripts/install
+++ b/scripts/install
@@ -15,12 +15,12 @@ export app_version=$YNH_APP_ARG_VERSION
export is_public=0
export final_path="/var/www/$app"
export conf_file=/etc/$app/main.conf
-export bin_file="$final_path/venv/bin/python $final_path/$APPNAME/$FORKNAME-bin"
+export bin_file="$final_path/venv/bin/python3 $final_path/$appname/$FORKNAME-bin"
if [ "$app_version" = "9" ]; then
- bin_file="$final_path/venv/bin/python $final_path/$APPNAME/$FORKNAME.py"
+ bin_file="$final_path/venv/bin/python3 $final_path/$appname/$FORKNAME.py"
fi
if [ "$app_version" = "8" ]; then
- bin_file="$final_path/venv/bin/python $final_path/$APPNAME/$FORKNAME.py"
+ bin_file="$final_path/venv/bin/python3 $final_path/$appname/$FORKNAME.py"
fi
export db_name=$(ynh_sanitize_dbid $app)
export port=$(ynh_find_port 8069)
@@ -43,8 +43,9 @@ function setup_database() {
ynh_configure server.conf $conf_file
chown $app:$app $conf_file
# Load translation
- #param=" --without-demo True --addons-path $final_path/$APPNAME/addons --db_user $app --db_password $db_pass --db_host 127.0.0.1 --db_port 5432 --db-filter '^$app\$' -d $app "
+ #param=" --without-demo True --addons-path $final_path/$appname/addons --db_user $app --db_password $db_pass --db_host 127.0.0.1 --db_port 5432 --db-filter '^$app\$' -d $app "
param=" -c $conf_file -d $app "
+ sudo -u $app $bin_file -c $conf_file --stop-after-init -i base -d $app
sudo -u $app $bin_file -c $conf_file --stop-after-init -i auth_ldap -d $app
sudo -u $app $bin_file -c $conf_file --stop-after-init --load-language $lang -d $app
# Configure language, timezone and ldap
diff --git a/scripts/restore b/scripts/restore
index ac1e39f..62df297 100644
--- a/scripts/restore
+++ b/scripts/restore
@@ -19,13 +19,14 @@ export db_pass=$(ynh_app_setting_get $app psqlpwd)
export final_path=$(ynh_app_setting_get $app final_path)
export conf_file=$(ynh_app_setting_get $app conf_file)
export is_public=0
-export bin_file="$final_path/venv/bin/python $final_path/$APPNAME/$FORKNAME-bin"
+export bin_file="$final_path/venv/bin/python $final_path/$appname/$FORKNAME-bin"
if [ "$app_version" = "9" ]; then
- bin_file="$final_path/venv/bin/python $final_path/$APPNAME/$FORKNAME.py"
+ bin_file="$final_path/venv/bin/python $final_path/$appname/$FORKNAME.py"
fi
if [ "$app_version" = "8" ]; then
- bin_file="$final_path/venv/bin/python $final_path/$APPNAME/$FORKNAME.py"
+ bin_file="$final_path/venv/bin/python $final_path/$appname/$FORKNAME.py"
fi
+export preinstall=0
#=================================================
# CHECK IF THE APP CAN BE RESTORED