2018-02-25 21:45:24 +01:00
#!/bin/bash
#=================================================
# GENERIC START
#=================================================
# IMPORT GENERIC HELPERS
source /usr/share/yunohost/helpers
# Exit if an error occurs during the execution of the script
ynh_abort_if_errors
# Load common variables and helpers
source ./experimental_helper.sh
source ./_common.sh
# Retrieve app settings
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Loading installation settings..."
2019-06-09 21:05:14 +02:00
domain=$(ynh_app_setting_get --app $app --key domain)
path_url=$(ynh_normalize_url_path $(ynh_app_setting_get --app $app --key path))
dbpass=$(ynh_app_setting_get --app $app --key mysqlpwd)
admin=$(ynh_app_setting_get --app $app --key adminusername)
key=$(ynh_app_setting_get --app $app --key secret_key)
is_public=$(ynh_app_setting_get --app $app --key is_public)
port=$(ynh_app_setting_get --app $app --key web_port)
upstream_version=$(ynh_app_setting_get --app $app --key upstream_version)
2018-02-25 21:45:24 +01:00
# Backup the current version of the app
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Backing up the app before upgrading (may take a while)..." --weight=10
2018-02-25 21:45:24 +01:00
ynh_backup_before_upgrade
ynh_clean_setup () {
ynh_restore_upgradebackup
}
# Stop service
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Stoping services..."
2018-02-25 21:45:24 +01:00
systemctl stop "$app".service
#=================================================
2019-02-15 11:33:29 +01:00
# MIGRATION FROM GOGS
2018-02-25 21:45:24 +01:00
#=================================================
2019-02-15 11:33:29 +01:00
[[ $YNH_APP_ID == "gogs" ]] \
&& [[ "$(cat "/opt/$app/templates/.VERSION")" != 0.11.79.1211 ]] \
2019-08-01 14:01:59 +02:00
&& ynh_die --message "It look like that you have an old gogs install. You need first upgrade gogs instance (id : $gogs_migrate_id) and after migrate to gitea."
2019-02-15 11:33:29 +01:00
ynh_handle_app_migration gogs gogs_migrations
if [[ $migration_process -eq 1 ]]; then
# Reload variables
dbname=$app
dbuser=$app
final_path="/opt/$app"
DATADIR="/home/$app"
REPO_PATH="$DATADIR/repositories"
DATA_PATH="$DATADIR/data"
2019-03-02 00:00:55 +01:00
# Replace the user
ynh_system_user_delete $old_app
test getent passwd "$app" &>/dev/null || \
useradd -d "$DATADIR" --system --user-group "$app" --shell /bin/bash || \
2019-08-01 14:01:59 +02:00
ynh_die --message "Unable to create $app system account"
2019-03-02 00:00:55 +01:00
2019-02-15 11:33:29 +01:00
# Clean old binary
2019-06-09 21:05:14 +02:00
ynh_secure_remove --file=$final_path/gogs
ynh_secure_remove --file=$final_path/custom/conf/auth.d
2019-02-15 11:33:29 +01:00
# Restore authentication from SQL database
2019-09-10 21:26:06 +02:00
ynh_replace_string --match_string __ADMIN__ --replace_string "$admin" --target_file ../conf/login_source.sql
ynh_replace_string --match_string __APP__ --replace_string "$app" --target_file ../conf/login_source.sql
2019-02-15 11:33:29 +01:00
ynh_mysql_connect_as "$dbuser" "$dbpass" "$dbname" < ../conf/login_source.sql
2019-03-02 00:16:46 +01:00
# Fix hooks
if [[ -e $REPO_PATH ]];then
ls $REPO_PATH/*/*.git/hooks/pre-receive | while read p; do
2019-06-09 21:05:14 +02:00
ynh_secure_remove --file=$p
2019-03-02 00:16:46 +01:00
done
ls $REPO_PATH/*/*.git/hooks/post-receive | while read p; do
2019-06-09 21:05:14 +02:00
ynh_secure_remove --file=$p
2019-03-02 00:16:46 +01:00
done
fi
2019-02-15 11:33:29 +01:00
upstream_version="0.0.1"
2018-02-25 21:45:24 +01:00
fi
#=================================================
# STANDARD UPGRADE STEPS
#=================================================
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Configuring application..."
2018-02-25 21:45:24 +01:00
# Clean template to fix issue : https://github.com/gogits/gogs/issues/4585
2019-06-09 21:05:14 +02:00
ynh_secure_remove --file="/opt/$app/templates"
2018-02-25 21:45:24 +01:00
2018-06-15 22:08:34 +02:00
# Configure gitea with app.ini file
config_gitea
2018-02-25 21:45:24 +01:00
# Configure init script
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Updating systemd units..."
2018-02-25 21:45:24 +01:00
ynh_add_systemd_config
# Modify Nginx configuration file and copy it to Nginx conf directory
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Configuring nginx..." --weight=1
2018-02-25 21:45:24 +01:00
config_nginx
2019-02-15 11:33:29 +01:00
#=================================================
# DB migration
#=================================================
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Upgrading database and sources..." --weight=6
2019-05-07 10:56:04 +02:00
# Before the version 1.7 the upstream version was not stored
# The way to find the version for the install < 1.7 is to parse the binary file to find which version is installed
if [ -z ${upstream_version:-} ]; then
for version in "0.0." "1.0." "1.1." "1.2." "1.3." "1.4." "1.5." "1.6." "1.7."; do
if strings $final_path/gitea | grep -P "^${version//./\\.}\d"; then
upstream_version="${version}0"
break
fi
done
fi
2019-02-15 11:33:29 +01:00
restart_gitea() {
# Set permissions
set_permission
ynh_systemd_action -l "Serving \[::\]:$port with pid" -p "systemd"
# Leave the time to update the database schema
sleep 5
systemctl stop $app
}
case $upstream_version in
2019-05-07 10:56:04 +02:00
"0.0."* )
2019-02-15 11:33:29 +01:00
ynh_setup_source $final_path source/${architecture}_1.0
set_permission
systemctl start $app
sleep 20
systemctl stop $app
;&
"1.0."* )
ynh_setup_source $final_path source/${architecture}_1.1
restart_gitea
;&
"1.1."* )
ynh_setup_source $final_path source/${architecture}_1.2
restart_gitea
;&
"1.2."* )
ynh_setup_source $final_path source/${architecture}_1.3
restart_gitea
;&
"1.3."* )
ynh_setup_source $final_path source/${architecture}_1.4
restart_gitea
;&
"1.4."* )
ynh_setup_source $final_path source/${architecture}_1.5
restart_gitea
;&
"1.5."* )
ynh_setup_source $final_path source/${architecture}_1.6
restart_gitea
;&
2019-05-05 12:02:02 +02:00
"1.6."* )
ynh_setup_source $final_path source/${architecture}_1.7
restart_gitea
;&
2019-08-01 14:17:11 +02:00
"1.7."* )
ynh_setup_source $final_path source/${architecture}_1.8
restart_gitea
;&
2019-02-15 11:33:29 +01:00
esac
2019-08-01 15:06:08 +02:00
# Install gitea source
2019-02-15 11:33:29 +01:00
ynh_setup_source $final_path source/$architecture
2019-02-03 15:05:38 +01:00
# SETUP FAIL2BAN
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Configuring fail2ban..."
2019-09-07 11:05:06 +02:00
ynh_add_fail2ban_config --logpath "/var/log/$app/gitea.log" --failregex ".*Failed authentication attempt for .* from <HOST>" --max_retry 5
2019-02-03 15:05:38 +01:00
2018-02-25 21:45:24 +01:00
#=================================================
# GENERIC FINALIZATION
#=================================================
# Set permissions
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Protecting directory"
2018-02-25 21:45:24 +01:00
set_permission
2019-02-15 11:33:29 +01:00
# Save Version
2019-06-09 21:05:14 +02:00
ynh_app_setting_set --app $app --key upstream_version --value $(ynh_app_upstream_version)
2019-02-15 11:33:29 +01:00
2019-02-14 09:51:19 +01:00
# Unprotect root from SSO if public
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Configuring permissions..."
2019-02-14 09:51:19 +01:00
set_access_settings
2018-02-25 21:45:24 +01:00
# Reload services
2019-09-10 22:43:45 +02:00
ynh_script_progression --message="Starting gitea services..." --weight=3
2019-08-05 22:58:17 +02:00
ynh_systemd_action -l "Serving \[::\]:$port with pid" -p "/var/log/$app/gitea.log" -t 10
2019-02-16 13:43:04 +01:00
sleep 1
2019-02-16 12:59:32 +01:00
# Store the checksum with the 'INTERNAL_TOKEN' value.
# Should be removed when the issue https://github.com/go-gitea/gitea/issues/3246 is fixed
2019-06-09 21:05:14 +02:00
ynh_store_file_checksum --file "$final_path/custom/conf/app.ini"
2019-02-15 11:33:29 +01:00
#=================================================
# FINISH MIGRATION PROCESS
#=================================================
if [[ $migration_process -eq 1 ]]; then
echo "gogs has been successfully migrated to Gitea! \
A last scheduled operation will run in a couple of minutes to finish the \
migration in YunoHost side. Do not proceed any application operation while \
you don't see Gogs as installed." >&2
# Execute a post migration script after the end of this upgrade.
# Mainly for some cleaning
script_post_migration=gogs_post_migration.sh
2019-09-10 21:26:06 +02:00
ynh_replace_string --match_string __OLD_APP__ --replace_string "$old_app" --target_file ../conf/$script_post_migration
ynh_replace_string --match_string __NEW_APP__ --replace_string "$app" --target_file ../conf/$script_post_migration
2019-02-15 11:33:29 +01:00
cp ../conf/$script_post_migration /tmp
chmod +x /tmp/$script_post_migration
(cd /tmp; echo "/tmp/$script_post_migration > /tmp/$script_post_migration.log 2>&1" | at now + 2 minutes)
fi