mirror of
https://github.com/YunoHost-Apps/synapse_ynh.git
synced 2024-09-03 20:26:38 +02:00
101 lines
3 KiB
Bash
101 lines
3 KiB
Bash
#!/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 $APP_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_test_if_first_run
|
|
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 and Install synapse in virtualenv
|
|
setup_dir
|
|
install_source
|
|
set_permission
|
|
|
|
# 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
|
|
ynh_use_logrotate /var/log/turnserver
|
|
|
|
# register yunohost service
|
|
yunohost service add matrix-synapse
|
|
|
|
# Recharge la configuration Nginx
|
|
systemctl restart matrix-synapse.service
|
|
systemctl restart coturn.service
|