#!/bin/bash # Source YunoHost helpers source /usr/share/yunohost/helpers source ./psql.sh # Stop script if errors ynh_abort_if_errors # Import common cmd source ./_common.sh # Retrieve arguments domain=$YNH_APP_ARG_DOMAIN is_public=$YNH_APP_ARG_IS_PUBLIC path="/_matrix" final_path="/opt/yunohost/matrix-synapse" # Check domain/path availability test $(ynh_webpath_available $domain $path) == 'True' || ynh_die "$domain$path is not available, please use an other domain." # Check Final Path availability test ! -e "$final_path" || ynh_die "This path already contains a folder" # Ouvre le port dans le firewall synapse_tls_port=$(ynh_find_port 8448) synapse_port=$(ynh_find_port 8008) turnserver_tls_port=$(ynh_find_port 5349) yunohost firewall allow --no-upnp TCP $synapse_tls_port > /dev/null 2>&1 yunohost firewall allow --no-upnp Both $turnserver_tls_port > /dev/null 2>&1 # Make dh cert for synapse if it not exist test ! -e /etc/yunohost/certs/$domain/dh.pem && openssl dhparam -out /etc/yunohost/certs/$domain/dh.pem 2048 > /dev/null # Find password for turnserver and database turnserver_pwd=$(ynh_string_random 30) synapse_db_pwd=$(ynh_string_random 30) # Enregistre les infos dans la config YunoHost ynh_app_setting_set $app special_domain $domain ynh_app_setting_set $app special_path $path ynh_app_setting_set $app final_path $final_path ynh_app_setting_set $app synapse_version $synapse_version ynh_app_setting_set $app synapse_db_pwd $synapse_db_pwd ynh_app_setting_set $app is_public $is_public ynh_app_setting_set $app synapse_port $synapse_port ynh_app_setting_set $app synapse_tls_port $synapse_tls_port ynh_app_setting_set $app turnserver_tls_port $turnserver_tls_port ynh_app_setting_set $app turnserver_pwd $turnserver_pwd # Install all dependances install_dependances # Create user ynh_system_user_create $synapse_user /var/lib/matrix-synapse # Create postgresql database ynh_psql_create_user $synapse_db_user $synapse_db_pwd ynh_psql_execute_as_root \ "CREATE DATABASE $synapse_db_name ENCODING 'UTF8' LC_COLLATE='C' LC_CTYPE='C' template=template0 OWNER $synapse_db_user;" # Create directory Install synapse in virtualenv install_from_source # Open access to server without a button the home cp ../conf/add_sso_conf.py $final_path cp ../conf/remove_sso_conf.py $final_path python $final_path/add_sso_conf.py # Create systemd service cp ../conf/default_matrix-synapse /etc/default/matrix-synapse cp ../conf/matrix-synapse.service /etc/systemd/system/ systemctl daemon-reload systemctl enable matrix-synapse.service # Config nginx config_nginx # Configure Synapse config_synapse # Configure Coturn config_coturn # Configure access for certificates set_certificat_access # Configuration de logrotate ynh_use_logrotate /var/log/matrix-synapse/ # register yunohost service yunohost service add matrix-synapse # Recharge la configuration Nginx systemctl restart matrix-synapse.service systemctl restart coturn.service