mirror of
https://github.com/YunoHost-Apps/galene_ynh.git
synced 2024-09-03 18:36:31 +02:00
146 lines
6.8 KiB
Bash
146 lines
6.8 KiB
Bash
#!/bin/bash
|
|
|
|
source _common.sh
|
|
source /usr/share/yunohost/helpers
|
|
|
|
#=================================================
|
|
# LOAD SETTINGS
|
|
#=================================================
|
|
|
|
password=$(ynh_app_setting_get --key=password)
|
|
|
|
#=================================================
|
|
# STOP SYSTEMD SERVICE
|
|
#=================================================
|
|
ynh_script_progression "Stopping $app's systemd service..."
|
|
|
|
ynh_systemctl --service=$app --action="stop" --log_path="systemd"
|
|
ynh_systemctl --service=${app}_ldap --action="stop" --log_path="systemd"
|
|
|
|
#=================================================
|
|
# ENSURE DOWNWARD COMPATIBILITY
|
|
#=================================================
|
|
ynh_script_progression "Ensuring downward compatibility..."
|
|
|
|
# For version 0.6~ynh1 and before
|
|
if [[ ! -d "$install_dir/live" ]]
|
|
then
|
|
tempdir="$(mktemp -d)"
|
|
mv $install_dir $tempdir
|
|
mkdir -p "$install_dir/live"
|
|
mv $tempdir/$app/galene "$install_dir/live/"
|
|
mv $tempdir/$app/data/ "$install_dir/live/"
|
|
mv $tempdir/$app/static/ "$install_dir/live/"
|
|
ynh_safe_rm "$tempdir"
|
|
fi
|
|
|
|
#=================================================
|
|
# DOWNLOAD, CHECK AND UNPACK SOURCE
|
|
#=================================================
|
|
ynh_script_progression "Upgrading source files..."
|
|
|
|
ynh_setup_source --dest_dir="$install_dir/build" --full_replace
|
|
ynh_setup_source --dest_dir="$install_dir/build_ldap" --source_id="ldap" --full_replace
|
|
|
|
mkdir -p "$install_dir/live/data"
|
|
mkdir -p "$install_dir/live_ldap/data"
|
|
|
|
ynh_safe_rm "$install_dir/live/static/"
|
|
cp -r "$install_dir/build/static/" "$install_dir/live/"
|
|
ynh_replace --match="<div class=\"galene-header\">Galène</div>" --replace="<div class=\"galene-header\" onclick=\"location.href=window.location.origin\" style=\"cursor:pointer\">Galène</div>" --file="$install_dir/live/static/galene.html"
|
|
|
|
#REMOVEME? Assuming the install dir is setup using ynh_setup_source, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chmod -R o-rwx "$install_dir"
|
|
#REMOVEME? Assuming the install dir is setup using ynh_setup_source, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chown -R $app:www-data "$install_dir"
|
|
#=================================================
|
|
# BUILD APP
|
|
#=================================================
|
|
ynh_script_progression "Building app..."
|
|
|
|
ynh_go_install
|
|
|
|
pushd $install_dir/build/galene-password-generator/
|
|
ynh_hide_warnings ynh_exec_as_app CGO_ENABLED=0 go build -o $install_dir/
|
|
popd
|
|
pushd $install_dir/build/
|
|
ynh_hide_warnings ynh_exec_as_app CGO_ENABLED=0 go build -ldflags='-s -w' -o $install_dir/live/
|
|
popd
|
|
pushd $install_dir/build_ldap/
|
|
ynh_hide_warnings ynh_exec_as_app CGO_ENABLED=0 go build -ldflags='-s -w' -o $install_dir/live_ldap/
|
|
popd
|
|
|
|
ynh_go_remove
|
|
ynh_safe_rm "$install_dir/build/"
|
|
ynh_safe_rm "$install_dir/build_ldap/"
|
|
ynh_safe_rm "$install_dir/.cache/"
|
|
ynh_safe_rm "$install_dir/go/"
|
|
ynh_safe_rm "$install_dir/.go-version"
|
|
|
|
chmod +x "$install_dir/galene-password-generator"
|
|
|
|
#=================================================
|
|
# UPDATE A CONFIG FILE
|
|
#=================================================
|
|
ynh_script_progression "Updating configuration..."
|
|
|
|
# If password_hash doesn't exist, create it
|
|
# FIXMEhelpers2.1: maybe replace with: ynh_app_setting_set_default --key=password_hash --value=$(echo $($install_dir/galene-password-generator $password))
|
|
if [ -z "${password_hash:-}" ]; then
|
|
password_hash=$(echo $($install_dir/galene-password-generator $password))
|
|
ynh_app_setting_set --key=password_hash --value="$password_hash"
|
|
fi
|
|
# Configure Galène
|
|
ynh_config_add --template="config.json" --destination="$install_dir/live/data/config.json"
|
|
#REMOVEME? Assuming the file is setup using ynh_config_add, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chmod 400 "$install_dir/live/data/config.json"
|
|
#REMOVEME? Assuming the file is setup using ynh_config_add, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chown $app:$app "$install_dir/live/data/config.json"
|
|
|
|
# Configure Galène LDAP
|
|
# If key doesn't exist, create it
|
|
# FIXMEhelpers2.1: maybe replace with: ynh_app_setting_set_default --key=key --value=$(jose jwk gen -i '{"kty":"oct","alg":"HS256"}')
|
|
if [ -z "${key:-}" ]; then
|
|
key=$(jose jwk gen -i '{"kty":"oct","alg":"HS256"}')
|
|
ynh_app_setting_set --key=key --value=$key
|
|
fi
|
|
ynh_config_add --template="galene-ldap.json" --destination="$install_dir/live_ldap/data/galene-ldap.json"
|
|
chmod 400 "$install_dir/live_ldap/data/galene-ldap.json"
|
|
chown $app:$app "$install_dir/live_ldap/data/galene-ldap.json"
|
|
|
|
# Create a group name config
|
|
ynh_config_add --template="groupname.json" --destination="$data_dir/groups/$group_name.json"
|
|
#REMOVEME? Assuming the file is setup using ynh_config_add, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chmod 400 "$data_dir/groups/$group_name.json"
|
|
#REMOVEME? Assuming the file is setup using ynh_config_add, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chown $app:$app "$data_dir/groups/$group_name.json"
|
|
|
|
# Create a group name authenticated on LDAP
|
|
ynh_config_add --template="groupname-ldap.json" --destination="$data_dir/groups/YunoHost_Users.json"
|
|
#REMOVEME? Assuming the file is setup using ynh_config_add, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chmod 400 "$data_dir/groups/YunoHost_Users.json"
|
|
#REMOVEME? Assuming the file is setup using ynh_config_add, the proper chmod/chowns are now already applied and it shouldn't be necessary to tweak perms | chown $app:$app "$data_dir/groups/YunoHost_Users.json"
|
|
|
|
#=================================================
|
|
# REAPPLY SYSTEM CONFIGURATIONS
|
|
#=================================================
|
|
ynh_script_progression "Upgrading system configurations related to $app..."
|
|
|
|
public_ip4="$(curl -s ip.yunohost.org)" || true
|
|
|
|
# Create a dedicated NGINX config
|
|
ynh_config_add_nginx
|
|
|
|
# Create a dedicated systemd config
|
|
ynh_config_add_systemd
|
|
ynh_config_add_systemd --service=${app}_ldap --template="ldap.service"
|
|
|
|
yunohost service add $app --description="Videoconferencing server" --needs_exposed_ports="$port_turn"
|
|
yunohost service add ${app}_ldap --description="LDAP integration for the videoconferencing server"
|
|
|
|
#=================================================
|
|
# START SYSTEMD SERVICE
|
|
#=================================================
|
|
ynh_script_progression "Starting $app's systemd service..."
|
|
|
|
ynh_systemctl --service=$app --action="start" --log_path="systemd"
|
|
ynh_systemctl --service=${app}_ldap --action="start" --log_path="systemd"
|
|
|
|
#=================================================
|
|
# END OF SCRIPT
|
|
#=================================================
|
|
|
|
ynh_script_progression "Upgrade of $app completed"
|