mirror of
https://github.com/YunoHost-Apps/mautrix_whatsapp_ynh.git
synced 2024-09-03 19:46:01 +02:00
init settings install upgrade
This commit is contained in:
parent
80bff155fd
commit
d8dcdfae9e
2 changed files with 138 additions and 55 deletions
|
@ -25,7 +25,7 @@ ynh_abort_if_errors
|
||||||
|
|
||||||
appserviceid=$YNH_APP_INSTANCE_NAME
|
appserviceid=$YNH_APP_INSTANCE_NAME
|
||||||
synapsenumber=$YNH_APP_ARG_SYNAPSENUMBER
|
synapsenumber=$YNH_APP_ARG_SYNAPSENUMBER
|
||||||
username=$YNH_APP_ARG_BOTNAME
|
botname=$YNH_APP_ARG_BOTNAME
|
||||||
bot_synapse_adm=$YNH_APP_ARG_BOT_SYNAPSE_ADM
|
bot_synapse_adm=$YNH_APP_ARG_BOT_SYNAPSE_ADM
|
||||||
encryption=$YNH_APP_ARG_ENCRYPTION
|
encryption=$YNH_APP_ARG_ENCRYPTION
|
||||||
botadmin=$YNH_APP_ARG_BOTADMIN
|
botadmin=$YNH_APP_ARG_BOTADMIN
|
||||||
|
@ -57,8 +57,8 @@ async_media="false"
|
||||||
displayname="WhatsApp bridge bot"
|
displayname="WhatsApp bridge bot"
|
||||||
avatar="mxc://maunium.net/NeXNQarUbrlYBiPCpprYsRqr"
|
avatar="mxc://maunium.net/NeXNQarUbrlYBiPCpprYsRqr"
|
||||||
ephemeral_events="true"
|
ephemeral_events="true"
|
||||||
metrics_enabled="false"
|
enable_metrics="false"
|
||||||
listen="127.0.0.1:8001"
|
metrics_listen_port="127.0.0.1:8001"
|
||||||
os_name="Mautrix-WhatsApp bridge"
|
os_name="Mautrix-WhatsApp bridge"
|
||||||
browser_name="unknown"
|
browser_name="unknown"
|
||||||
username_template="whatsapp_{{.}}"
|
username_template="whatsapp_{{.}}"
|
||||||
|
@ -66,9 +66,9 @@ personal_filtering_spaces="false"
|
||||||
delivery_receipts="false"
|
delivery_receipts="false"
|
||||||
send_presence_on_typing="false"
|
send_presence_on_typing="false"
|
||||||
url_previews="false"
|
url_previews="false"
|
||||||
default="false"
|
encryption_default="false"
|
||||||
require="false"
|
encryption_require="false"
|
||||||
enabled="true"
|
enable_relaybot="true"
|
||||||
admin_only="true"
|
admin_only="true"
|
||||||
print_level="INFO"
|
print_level="INFO"
|
||||||
existingUsers=$botusers
|
existingUsers=$botusers
|
||||||
|
@ -79,8 +79,8 @@ ynh_app_setting_set --app=$app --key=async_media --value=$async_media
|
||||||
ynh_app_setting_set --app=$app --key=displayname --value=$displayname
|
ynh_app_setting_set --app=$app --key=displayname --value=$displayname
|
||||||
ynh_app_setting_set --app=$app --key=avatar --value=$avatar
|
ynh_app_setting_set --app=$app --key=avatar --value=$avatar
|
||||||
ynh_app_setting_set --app=$app --key=ephemeral_events --value=$ephemeral_events
|
ynh_app_setting_set --app=$app --key=ephemeral_events --value=$ephemeral_events
|
||||||
ynh_app_setting_set --app=$app --key=metrics_enabled --value=$metrics_enabled
|
ynh_app_setting_set --app=$app --key=enable_metrics --value=$enable_metrics
|
||||||
ynh_app_setting_set --app=$app --key=listen --value=$listen
|
ynh_app_setting_set --app=$app --key=metrics_listen_port --value=$metrics_listen_port
|
||||||
ynh_app_setting_set --app=$app --key=os_name --value=$os_name
|
ynh_app_setting_set --app=$app --key=os_name --value=$os_name
|
||||||
ynh_app_setting_set --app=$app --key=browser_name --value=$browser_name
|
ynh_app_setting_set --app=$app --key=browser_name --value=$browser_name
|
||||||
ynh_app_setting_set --app=$app --key=username_template --value=$username_template
|
ynh_app_setting_set --app=$app --key=username_template --value=$username_template
|
||||||
|
@ -88,9 +88,9 @@ ynh_app_setting_set --app=$app --key=personal_filtering_spaces --value=$personal
|
||||||
ynh_app_setting_set --app=$app --key=delivery_receipts --value=$delivery_receipts
|
ynh_app_setting_set --app=$app --key=delivery_receipts --value=$delivery_receipts
|
||||||
ynh_app_setting_set --app=$app --key=send_presence_on_typing --value=$send_presence_on_typing
|
ynh_app_setting_set --app=$app --key=send_presence_on_typing --value=$send_presence_on_typing
|
||||||
ynh_app_setting_set --app=$app --key=url_previews --value=$url_previews
|
ynh_app_setting_set --app=$app --key=url_previews --value=$url_previews
|
||||||
ynh_app_setting_set --app=$app --key=default --value=$default
|
ynh_app_setting_set --app=$app --key=encryption_default --value=$encryption_default
|
||||||
ynh_app_setting_set --app=$app --key=require --value=$require
|
ynh_app_setting_set --app=$app --key=encryption_require --value=$encryption_require
|
||||||
ynh_app_setting_set --app=$app --key=enabled --value=$enabled
|
ynh_app_setting_set --app=$app --key=enable_relaybot --value=$enable_relaybot
|
||||||
ynh_app_setting_set --app=$app --key=admin_only --value=$admin_only
|
ynh_app_setting_set --app=$app --key=admin_only --value=$admin_only
|
||||||
ynh_app_setting_set --app=$app --key=print_level --value=$print_level
|
ynh_app_setting_set --app=$app --key=print_level --value=$print_level
|
||||||
ynh_app_setting_set --app=$app --key=existingUsers --value=$existingUsers
|
ynh_app_setting_set --app=$app --key=existingUsers --value=$existingUsers
|
||||||
|
@ -115,7 +115,7 @@ fi
|
||||||
ynh_script_progression --message="Storing installation settings..." --weight=7
|
ynh_script_progression --message="Storing installation settings..." --weight=7
|
||||||
|
|
||||||
ynh_app_setting_set --app=$app --key=appserviceid --value=$appserviceid
|
ynh_app_setting_set --app=$app --key=appserviceid --value=$appserviceid
|
||||||
ynh_app_setting_set --app=$app --key=username --value=$username
|
ynh_app_setting_set --app=$app --key=botname --value=$botname
|
||||||
ynh_app_setting_set --app=$app --key=bot_synapse_adm --value=$bot_synapse_adm
|
ynh_app_setting_set --app=$app --key=bot_synapse_adm --value=$bot_synapse_adm
|
||||||
ynh_app_setting_set --app=$app --key=encryption --value=$encryption
|
ynh_app_setting_set --app=$app --key=encryption --value=$encryption
|
||||||
ynh_app_setting_set --app=$app --key=botadmin --value=$botadmin
|
ynh_app_setting_set --app=$app --key=botadmin --value=$botadmin
|
||||||
|
@ -239,8 +239,8 @@ sleep 30
|
||||||
# (Note that, by default, non-admins might not have your homeserver's permission to create communities.)
|
# (Note that, by default, non-admins might not have your homeserver's permission to create communities.)
|
||||||
if [ "$bot_synapse_adm" = true ]
|
if [ "$bot_synapse_adm" = true ]
|
||||||
then
|
then
|
||||||
ynh_psql_execute_as_root --database=$synapse_db_name --sql="UPDATE users SET admin = 1 WHERE name = ""$username"";"
|
ynh_psql_execute_as_root --database=$synapse_db_name --sql="UPDATE users SET admin = 1 WHERE name = ""$botname"";"
|
||||||
#yunohost app action run $synapse_instance set_admin_user -a username=$username
|
#yunohost app action run $synapse_instance set_admin_user -a username=$botname
|
||||||
fi
|
fi
|
||||||
ynh_systemd_action --service_name=$app --action="restart"
|
ynh_systemd_action --service_name=$app --action="restart"
|
||||||
|
|
||||||
|
|
165
scripts/upgrade
165
scripts/upgrade
|
@ -32,6 +32,32 @@ server_name=$(ynh_app_setting_get --app=$app --key=server_name)
|
||||||
synapse_db_name="matrix_$synapse_instance"
|
synapse_db_name="matrix_$synapse_instance"
|
||||||
bot_synapse_db_user="@$botname:$server_name"
|
bot_synapse_db_user="@$botname:$server_name"
|
||||||
|
|
||||||
|
#=================================================
|
||||||
|
# GET CONFIG PANEL SETTINGS
|
||||||
|
#=================================================
|
||||||
|
async_media=$(ynh_app_setting_get --app=$app --key=async_media)
|
||||||
|
displayname=$(ynh_app_setting_get --app=$app --key=displayname)
|
||||||
|
avatar=$(ynh_app_setting_get --app=$app --key=avatar)
|
||||||
|
ephemeral_events=$(ynh_app_setting_get --app=$app --key=ephemeral_events)
|
||||||
|
enable_metrics=$(ynh_app_setting_get --app=$app --key=enable_metrics)
|
||||||
|
metrics_listen_port=$(ynh_app_setting_get --app=$app --key=metrics_listen_port)
|
||||||
|
os_name=$(ynh_app_setting_get --app=$app --key=os_name)
|
||||||
|
browser_name=$(ynh_app_setting_get --app=$app --key=browser_name)
|
||||||
|
username_template=$(ynh_app_setting_get --app=$app --key=username_template)
|
||||||
|
personal_filtering_spaces=$(ynh_app_setting_get --app=$app --key=personal_filtering_spaces)
|
||||||
|
delivery_receipts=$(ynh_app_setting_get --app=$app --key=delivery_receipts)
|
||||||
|
send_presence_on_typing=$(ynh_app_setting_get --app=$app --key=send_presence_on_typing)
|
||||||
|
url_previews=$(ynh_app_setting_get --app=$app --key=url_previews)
|
||||||
|
encryption_default=$(ynh_app_setting_get --app=$app --key=encryption_default)
|
||||||
|
encryption_require=$(ynh_app_setting_get --app=$app --key=encryption_require)
|
||||||
|
enable_relaybot=$(ynh_app_setting_get --app=$app --key=enable_relaybot)
|
||||||
|
admin_only=$(ynh_app_setting_get --app=$app --key=admin_only)
|
||||||
|
print_level=$(ynh_app_setting_get --app=$app --key=print_level)
|
||||||
|
existingUsers=$(ynh_app_setting_get --app=$app --key=existingUsers)
|
||||||
|
existingAdmins=$(ynh_app_setting_get --app=$app --key=existingAdmins)
|
||||||
|
existingRelayUsers=$(ynh_app_setting_get --app=$app --key=existingRelayUsers)
|
||||||
|
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
# CHECK VERSION
|
# CHECK VERSION
|
||||||
#=================================================
|
#=================================================
|
||||||
|
@ -67,56 +93,113 @@ ynh_systemd_action --service_name=$app --action="stop" --log_path="/var/log/$app
|
||||||
#=================================================
|
#=================================================
|
||||||
ynh_script_progression --message="Ensuring downward compatibility..." --weight=1
|
ynh_script_progression --message="Ensuring downward compatibility..." --weight=1
|
||||||
|
|
||||||
# Migration from <=1.10.0 to >0.2.1
|
# SET STANDARD SETTINGS FROM DEFAULT CONFIG
|
||||||
ynh_secure_remove --file="$final_path"/community.go
|
|
||||||
ynh_secure_remove --file="$final_path"/database/upgrades/2019-05-23-protoupgrade.go
|
|
||||||
ynh_secure_remove --file="$final_path"/database/upgrades/2019-05-16-message-delete-cascade.go
|
|
||||||
src_path="$final_path"_src
|
|
||||||
ynh_secure_remove --file="$src_path"
|
|
||||||
src_path="$final_path"/src
|
|
||||||
ynh_secure_remove --file="$src_path"
|
|
||||||
|
|
||||||
# Upgrade from >0.2.0
|
if [ -z "$async_media" ]
|
||||||
botname=$(ynh_app_setting_get --app=$app --key=botname)
|
|
||||||
db_name=$(ynh_app_setting_get --app=$app --key=db_name)
|
|
||||||
db_pwd=$(ynh_app_setting_get --app=$app --key=db_pwd)
|
|
||||||
|
|
||||||
# Upgrade from <=0.2.0
|
|
||||||
if [ -z "$botname" ]
|
|
||||||
then
|
then
|
||||||
botname=$(ynh_app_setting_get --app=$app --key=whatsappbot)
|
async_media="false"
|
||||||
ynh_app_setting_set --app=$app --key=botname --value=$botname
|
ynh_app_setting_set --app=$app --key=async_media --value=$async_media
|
||||||
fi
|
fi
|
||||||
if [ -z "$db_name" ]
|
if [ -z "$displayname" ]
|
||||||
then
|
then
|
||||||
db_name=$(ynh_app_setting_get --app=$app --key=$app)
|
displayname="WhatsApp bridge bot"
|
||||||
ynh_app_setting_set --app=$app --key=db_name --value=$db_name
|
ynh_app_setting_set --app=$app --key=displayname --value=$displayname
|
||||||
fi
|
fi
|
||||||
if [ -z "$db_pwd" ]
|
if [ -z "$avatar" ]
|
||||||
then
|
then
|
||||||
db_pwd=$(ynh_app_setting_get --app=$app --key=mautrix_whatsapp_db_pwd)
|
avatar="mxc://maunium.net/NeXNQarUbrlYBiPCpprYsRqr"
|
||||||
ynh_app_setting_set --app=$app --key=db_pwd --value=$db_pwd
|
ynh_app_setting_set --app=$app --key=avatar --value=$avatar
|
||||||
fi
|
fi
|
||||||
|
if [ -z "$ephemeral_events" ]
|
||||||
# If appserviceid doesn't exist, create it
|
|
||||||
if [ -z "$appserviceid" ]
|
|
||||||
then
|
then
|
||||||
appserviceid=$app
|
ephemeral_events="true"
|
||||||
ynh_app_setting_set --app=$app --key=appserviceid --value=$appserviceid
|
ynh_app_setting_set --app=$app --key=ephemeral_events --value=$ephemeral_events
|
||||||
|
fi
|
||||||
|
if [ -z "$enable_metrics" ]
|
||||||
|
then
|
||||||
|
enable_metrics="false"
|
||||||
|
ynh_app_setting_set --app=$app --key=enable_metrics --value=$enable_metrics
|
||||||
|
fi
|
||||||
|
if [ -z "$metrics_listen_port" ]
|
||||||
|
then
|
||||||
|
metrics_listen_port="127.0.0.1:8001"
|
||||||
|
ynh_app_setting_set --app=$app --key=metrics_listen_port --value=$metrics_listen_port
|
||||||
|
fi
|
||||||
|
if [ -z "$os_name" ]
|
||||||
|
then
|
||||||
|
os_name="Mautrix-WhatsApp bridge"
|
||||||
|
ynh_app_setting_set --app=$app --key=os_name --value=$os_name
|
||||||
|
fi
|
||||||
|
if [ -z "$browser_name" ]
|
||||||
|
then
|
||||||
|
browser_name="unknown"
|
||||||
|
ynh_app_setting_set --app=$app --key=browser_name --value=$browser_name
|
||||||
|
fi
|
||||||
|
if [ -z "$username_template" ]
|
||||||
|
then
|
||||||
|
username_template="whatsapp_{{.}}"
|
||||||
|
ynh_app_setting_set --app=$app --key=username_template --value=$username_template
|
||||||
|
fi
|
||||||
|
if [ -z "$personal_filtering_spaces" ]
|
||||||
|
then
|
||||||
|
personal_filtering_spaces="false"
|
||||||
|
ynh_app_setting_set --app=$app --key=personal_filtering_spaces --value=$personal_filtering_spaces
|
||||||
|
fi
|
||||||
|
if [ -z "$delivery_receipts" ]
|
||||||
|
then
|
||||||
|
delivery_receipts="false"
|
||||||
|
ynh_app_setting_set --app=$app --key=delivery_receipts --value=$delivery_receipts
|
||||||
|
fi
|
||||||
|
if [ -z "$send_presence_on_typing" ]
|
||||||
|
then
|
||||||
|
send_presence_on_typing="false"
|
||||||
|
ynh_app_setting_set --app=$app --key=send_presence_on_typing --value=$send_presence_on_typing
|
||||||
|
fi
|
||||||
|
if [ -z "$url_previews" ]
|
||||||
|
then
|
||||||
|
url_previews="false"
|
||||||
|
ynh_app_setting_set --app=$app --key=url_previews --value=$url_previews
|
||||||
|
fi
|
||||||
|
if [ -z "$encryption_default" ]
|
||||||
|
then
|
||||||
|
encryption_default="false"
|
||||||
|
ynh_app_setting_set --app=$app --key=encryption_default --value=$encryption_default
|
||||||
|
fi
|
||||||
|
if [ -z "$encryption_require" ]
|
||||||
|
then
|
||||||
|
encryption_require="false"
|
||||||
|
ynh_app_setting_set --app=$app --key=encryption_require --value=$encryption_require
|
||||||
|
fi
|
||||||
|
if [ -z "$enable_relaybot" ]
|
||||||
|
then
|
||||||
|
enable_relaybot="true"
|
||||||
|
ynh_app_setting_set --app=$app --key=enable_relaybot --value=$enable_relaybot
|
||||||
|
fi
|
||||||
|
if [ -z "$admin_only" ]
|
||||||
|
then
|
||||||
|
admin_only="true"
|
||||||
|
ynh_app_setting_set --app=$app --key=admin_only --value=$admin_only
|
||||||
|
fi
|
||||||
|
if [ -z "$print_level" ]
|
||||||
|
then
|
||||||
|
print_level="INFO"
|
||||||
|
ynh_app_setting_set --app=$app --key=print_level --value=$print_level
|
||||||
|
fi
|
||||||
|
if [ -z "$existingUsers" ]
|
||||||
|
then
|
||||||
|
existingUsers=$botusers
|
||||||
|
ynh_app_setting_set --app=$app --key=existingUsers --value=$existingUsers
|
||||||
|
fi
|
||||||
|
if [ -z "$existingAdmins" ]
|
||||||
|
then
|
||||||
|
existingAdmins=$botadmin
|
||||||
|
ynh_app_setting_set --app=$app --key=existingAdmins --value=$existingAdmins
|
||||||
|
fi
|
||||||
|
if [ -z "$existingRelayUsers" ]
|
||||||
|
then
|
||||||
|
existingRelayUsers="*"
|
||||||
|
ynh_app_setting_set --app=$app --key=existingRelayUsers --value=$existingRelayUsers
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# If db_name doesn't exist, create it
|
|
||||||
#if [ -z "$mautrix_whatsapp_db_name" ]; then
|
|
||||||
# mautrix_whatsapp_db_name=$(ynh_sanitize_dbid --db_name=$app)
|
|
||||||
# ynh_app_setting_set --app=$app --key=db_name --value=$mautrix_whatsapp_db_name
|
|
||||||
#fi
|
|
||||||
|
|
||||||
# If final_path doesn't exist, create it
|
|
||||||
#if [ -z "$final_path" ]; then
|
|
||||||
# final_path=/opt/yunohost/$app
|
|
||||||
# ynh_app_setting_set --app=$app --key=final_path --value=$final_path
|
|
||||||
#fi
|
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
# CREATE DEDICATED USER
|
# CREATE DEDICATED USER
|
||||||
|
|
Loading…
Add table
Reference in a new issue