mirror of
https://github.com/YunoHost-Apps/flohmarkt_ynh.git
synced 2024-09-03 18:36:30 +02:00
[autopatch] Automatic patch attempt for helpers 2.1
This commit is contained in:
parent
6364e57085
commit
6b27c84674
9 changed files with 247 additions and 233 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -1,2 +1,5 @@
|
||||||
README*
|
README*
|
||||||
scripts/test_local_curl.sh
|
scripts/test_local_curl.sh
|
||||||
|
*~
|
||||||
|
*.sw[op]
|
||||||
|
.DS_Store
|
||||||
|
|
|
@ -26,7 +26,8 @@ code = "https://codeberg.org/flohmarkt/flohmarkt"
|
||||||
# fund = "???"
|
# fund = "???"
|
||||||
|
|
||||||
[integration]
|
[integration]
|
||||||
yunohost = ">= 11.2.11"
|
yunohost = ">= 11.2.18"
|
||||||
|
helpers_version = "2.1"
|
||||||
architectures = "all"
|
architectures = "all"
|
||||||
# https://codeberg.org/ChriChri/flohmarkt_ynh/issues/11
|
# https://codeberg.org/ChriChri/flohmarkt_ynh/issues/11
|
||||||
multi_instance = true
|
multi_instance = true
|
||||||
|
|
|
@ -1,14 +1,13 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
# COMMON VARIABLES
|
# COMMON VARIABLES AND CUSTOM HELPERS
|
||||||
#=================================================
|
#=================================================
|
||||||
|
|
||||||
## new filenames starting 0.00~ynh5
|
## new filenames starting 0.00~ynh5
|
||||||
# make a filename/service name from domain/path
|
# make a filename/service name from domain/path
|
||||||
if [[ "$path" == /* ]]; then
|
if [[ "$path" == /* ]]; then
|
||||||
|
|
||||||
url_path="${path:1}"
|
url_path="${path:1}"
|
||||||
fi
|
fi
|
||||||
if [[ "__${url_path}__" == '____' ]]; then
|
if [[ "__${url_path}__" == '____' ]]; then
|
||||||
|
@ -31,7 +30,7 @@ flohmarkt_urlwatch_dir="${flohmarkt_install}/urlwatch"
|
||||||
flohmarkt_log_dir="/var/log/${app}"
|
flohmarkt_log_dir="/var/log/${app}"
|
||||||
flohmarkt_sym_log_dir="/var/log/${flohmarkt_filename}"
|
flohmarkt_sym_log_dir="/var/log/${flohmarkt_filename}"
|
||||||
# filename for logfiles - ¡ojo! if not ends with .log will be interpreted
|
# filename for logfiles - ¡ojo! if not ends with .log will be interpreted
|
||||||
# as a directory by ynh_use_logrotate
|
# as a directory by ynh_config_add_logrotate
|
||||||
# https://github.com/YunoHost/issues/issues/2383
|
# https://github.com/YunoHost/issues/issues/2383
|
||||||
flohmarkt_logfile="${flohmarkt_log_dir}/app.log"
|
flohmarkt_logfile="${flohmarkt_log_dir}/app.log"
|
||||||
# flohmarkt data_dir
|
# flohmarkt data_dir
|
||||||
|
@ -88,26 +87,32 @@ flohmarkt_old_service="flohmarkt"
|
||||||
# For the previous example, that means that $finalpath will be fill with the value given as argument for this option.
|
# For the previous example, that means that $finalpath will be fill with the value given as argument for this option.
|
||||||
#
|
#
|
||||||
# Also, in the previous example, finalpath has a '=' at the end. That means this option need a value.
|
# Also, in the previous example, finalpath has a '=' at the end. That means this option need a value.
|
||||||
# So, the helper has to be call with --finalpath /final/path, --finalpath=/final/path or -f /final/path,
|
# So, the helper has to be call with --finalpath /final/path, --finalpath=/final/path or -f /final/path,
|
||||||
|
|
||||||
# the variable $finalpath will get the value /final/path
|
# the variable $finalpath will get the value /final/path
|
||||||
# If there's many values for an option, -f /final /path, the value will be separated by a ';' $finalpath=/final;/path
|
# If there's many values for an option, -f /final /path, the value will be separated by a ';' $finalpath=/final;/path
|
||||||
# For an option without value, like --user in the example, the helper can be called only with --user or -u. $user
|
# For an option without value, like --user in the example, the helper can be called only with --user or -u. $user
|
||||||
|
|
||||||
# will then get the value 1.
|
# will then get the value 1.
|
||||||
#
|
#
|
||||||
# To keep a retrocompatibility, a package can still call a helper, using getopts, with positional arguments.
|
# To keep a retrocompatibility, a package can still call a helper, using getopts, with positional arguments.
|
||||||
# The "legacy mode" will manage the positional arguments and fill the variable in the same order than they are given
|
# The "legacy mode" will manage the positional arguments and fill the variable in the same order than they are given
|
||||||
|
|
||||||
# in $args_array. e.g. for `my_helper "val1" val2`, arg1 will be filled with val1, and arg2 with val2.
|
# in $args_array. e.g. for `my_helper "val1" val2`, arg1 will be filled with val1, and arg2 with val2.
|
||||||
|
|
||||||
# Positional parameters (used to be the only way to use ynh_handle_getopts_args once upon a time) can be
|
# Positional parameters (used to be the only way to use ynh_handle_getopts_args once upon a time) can be
|
||||||
|
|
||||||
# used also:
|
# used also:
|
||||||
#
|
#
|
||||||
|
|
||||||
# '--' start processing the rest of the arguments as positional parameters
|
# '--' start processing the rest of the arguments as positional parameters
|
||||||
# $legacy_args The arguments positional parameters will be assign to
|
# $legacy_args The arguments positional parameters will be assign to
|
||||||
# Needs to be composed of array keys of args_array. If a key for a predefined variable
|
# Needs to be composed of array keys of args_array. If a key for a predefined variable
|
||||||
# is used multiple times the assigned values will be concatenated delimited by ';'.
|
# is used multiple times the assigned values will be concatenated delimited by ';'.
|
||||||
# If the long option variable to contain the data is predefined as an array (e.g. using
|
# If the long option variable to contain the data is predefined as an array (e.g. using
|
||||||
# `local -a arg1` then multiple values will be assigned to its cells.
|
# `local -a arg1` then multiple values will be assigned to its cells.
|
||||||
# If the last positional parameter defined in legacy_args is defined as an array all
|
# If the last positional parameter defined in legacy_args is defined as an array all
|
||||||
|
|
||||||
# the leftover positional parameters will be assigned to its cells.
|
# the leftover positional parameters will be assigned to its cells.
|
||||||
# (it is named legacy_args, because the use of positional parameters was about to be
|
# (it is named legacy_args, because the use of positional parameters was about to be
|
||||||
# deprecated before the last re-design of this sub)
|
# deprecated before the last re-design of this sub)
|
||||||
|
@ -118,7 +123,7 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
# Manage arguments only if there's some provided
|
# Manage arguments only if there's some provided
|
||||||
set +o xtrace # set +x
|
set +o xtrace # set +x
|
||||||
if [ $# -eq 0 ]; then
|
if [ $# -eq 0 ]; then
|
||||||
ynh_print_warn --message="ynh_handle_getopts_args called without arguments"
|
ynh_print_warn "ynh_handle_getopts_args called without arguments"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -135,11 +140,13 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
flohmarkt_print_debug "args_array = (${!args_array[@]})"
|
flohmarkt_print_debug "args_array = (${!args_array[@]})"
|
||||||
for option_flag in "${!args_array[@]}"; do
|
for option_flag in "${!args_array[@]}"; do
|
||||||
# TODO refactor: Now I'm not sure anymore this part belongs here. To make the
|
# TODO refactor: Now I'm not sure anymore this part belongs here. To make the
|
||||||
# this all less hard to read and understand I'm thinking at the moment that it
|
# this all less hard to read and understand I'm thinking at the moment that it
|
||||||
|
|
||||||
# would be good to split the different things done here into their own loops:
|
# would be good to split the different things done here into their own loops:
|
||||||
#
|
#
|
||||||
# 1. build the option string $getopts_parameters
|
# 1. build the option string $getopts_parameters
|
||||||
# 2. go through the arguments and add empty arguments where needed to
|
# 2. go through the arguments and add empty arguments where needed to
|
||||||
|
|
||||||
# allow for cases like '--arg= --value' where 'value' is a valid option, too
|
# allow for cases like '--arg= --value' where 'value' is a valid option, too
|
||||||
# 3. replace long option names by short once
|
# 3. replace long option names by short once
|
||||||
# 4. (possibly add empty parameters for '-a -v' in cases where -a expects a value
|
# 4. (possibly add empty parameters for '-a -v' in cases where -a expects a value
|
||||||
|
@ -147,7 +154,8 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
flohmarkt_print_debug "option_flag = $option_flag"
|
flohmarkt_print_debug "option_flag = $option_flag"
|
||||||
# Concatenate each option_flags of the array to build the string of arguments for getopts
|
# Concatenate each option_flags of the array to build the string of arguments for getopts
|
||||||
# Will looks like 'abcd' for -a -b -c -d
|
# Will looks like 'abcd' for -a -b -c -d
|
||||||
# If the value of an option_flag finish by =, it's an option with additionnal values.
|
# If the value of an option_flag finish by =, it's an option with additionnal values.
|
||||||
|
|
||||||
# (e.g. --user bob or -u bob)
|
# (e.g. --user bob or -u bob)
|
||||||
# Check the last character of the value associate to the option_flag
|
# Check the last character of the value associate to the option_flag
|
||||||
flohmarkt_print_debug "compare to '${args_array[$option_flag]: -1}'"
|
flohmarkt_print_debug "compare to '${args_array[$option_flag]: -1}'"
|
||||||
|
@ -174,9 +182,10 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
# but if exists '[v]=value=' this is not the expected behavior:
|
# but if exists '[v]=value=' this is not the expected behavior:
|
||||||
# → then $arg is expected to contain an empty value and '-v' or '--value'
|
# → then $arg is expected to contain an empty value and '-v' or '--value'
|
||||||
# is expected to be interpreted as its own valid argument
|
# is expected to be interpreted as its own valid argument
|
||||||
# (found in use of ynh_replace_string called by ynh_add_config)
|
# (found in use of ynh_replace called by ynh_config_add)
|
||||||
# solution:
|
# solution:
|
||||||
# insert an empty arg into array arguments to be later interpreted by
|
# insert an empty arg into array arguments to be later interpreted by
|
||||||
|
|
||||||
# getopts as the missing value to --arg=
|
# getopts as the missing value to --arg=
|
||||||
if [[ -v arguments[arg+1] ]] && [[ ${arguments[arg]: -1} == '=' ]]; then
|
if [[ -v arguments[arg+1] ]] && [[ ${arguments[arg]: -1} == '=' ]]; then
|
||||||
# arg ends with a '='
|
# arg ends with a '='
|
||||||
|
@ -187,7 +196,8 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
flohmarkt_print_debug "MISSING PARAMETER: this_argument='$this_argument', next_argument='$next_argument'"
|
flohmarkt_print_debug "MISSING PARAMETER: this_argument='$this_argument', next_argument='$next_argument'"
|
||||||
|
|
||||||
# check if next_argument is a value in args_array
|
# check if next_argument is a value in args_array
|
||||||
# → starts with '--' and the rest of the argument excluding optional trailing '='
|
# → starts with '--' and the rest of the argument excluding optional trailing '='
|
||||||
|
|
||||||
# of the string is a value in associative array args_array
|
# of the string is a value in associative array args_array
|
||||||
# → or starts with '-' and the rest of the argument is a valid key in args_array
|
# → or starts with '-' and the rest of the argument is a valid key in args_array
|
||||||
# (long argument could already have been replaced by short version before)
|
# (long argument could already have been replaced by short version before)
|
||||||
|
@ -218,7 +228,7 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
flohmarkt_print_debug "====> end loop: arguments = '${arguments[@]}'"
|
flohmarkt_print_debug "====> end loop: arguments = '${arguments[@]}'"
|
||||||
done
|
done
|
||||||
flohmarkt_print_debug '================= end first loop ================='
|
flohmarkt_print_debug '================= end first loop ================='
|
||||||
|
|
||||||
# Parse the first argument, return the number of arguments to be shifted off the arguments array
|
# Parse the first argument, return the number of arguments to be shifted off the arguments array
|
||||||
# The function call is necessary here to allow `getopts` to use $@
|
# The function call is necessary here to allow `getopts` to use $@
|
||||||
parse_arg() {
|
parse_arg() {
|
||||||
|
@ -231,11 +241,11 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
flohmarkt_print_debug "after getopts - parameter='$parameter', OPTIND='${OPTIND:-none}', OPTARG='${OPTARG:-none}'"
|
flohmarkt_print_debug "after getopts - parameter='$parameter', OPTIND='${OPTIND:-none}', OPTARG='${OPTARG:-none}'"
|
||||||
|
|
||||||
if [ "$parameter" = "?" ]; then
|
if [ "$parameter" = "?" ]; then
|
||||||
ynh_die --message="Invalid argument: -${OPTARG:-}"
|
ynh_die "Invalid argument: -${OPTARG:-}"
|
||||||
flohmarkt_print_debug "Invalid argument: -${OPTARG:-}"
|
flohmarkt_print_debug "Invalid argument: -${OPTARG:-}"
|
||||||
exit 255
|
exit 255
|
||||||
elif [ "$parameter" = ":" ]; then
|
elif [ "$parameter" = ":" ]; then
|
||||||
ynh_die --message="-$OPTARG parameter requires an argument."
|
ynh_die "-$OPTARG parameter requires an argument."
|
||||||
echo "-$OPTARG parameter requires an argument."
|
echo "-$OPTARG parameter requires an argument."
|
||||||
exit 255
|
exit 255
|
||||||
else
|
else
|
||||||
|
@ -268,7 +278,8 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
local positional_count=0 # counter for positional parameters
|
local positional_count=0 # counter for positional parameters
|
||||||
local option_var='' # the variable name to be filled
|
local option_var='' # the variable name to be filled
|
||||||
# Try to use legacy_args as a list of option_flag of the array args_array
|
# Try to use legacy_args as a list of option_flag of the array args_array
|
||||||
# Otherwise, fill it with getopts_parameters to get the option_flag.
|
# Otherwise, fill it with getopts_parameters to get the option_flag.
|
||||||
|
|
||||||
# (But an associative arrays isn't always sorted in the correct order...)
|
# (But an associative arrays isn't always sorted in the correct order...)
|
||||||
# Remove all ':' in getopts_parameters, if used.
|
# Remove all ':' in getopts_parameters, if used.
|
||||||
legacy_args=${legacy_args:-${getopts_parameters//:/}}
|
legacy_args=${legacy_args:-${getopts_parameters//:/}}
|
||||||
|
@ -291,12 +302,15 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
positional_mode=1 # set state to positional parameter mode
|
positional_mode=1 # set state to positional parameter mode
|
||||||
flohmarkt_print_debug "positional parameter, argument='$argument'"
|
flohmarkt_print_debug "positional parameter, argument='$argument'"
|
||||||
|
|
||||||
# Get the option_flag from getopts_parameters by using the option_flag according to the
|
# Get the option_flag from getopts_parameters by using the option_flag according to the
|
||||||
|
|
||||||
# position of the argument.
|
# position of the argument.
|
||||||
option_flag=${legacy_args:$positional_count:1}
|
option_flag=${legacy_args:$positional_count:1}
|
||||||
|
|
||||||
# increment counter for legacy_args if still args left. If no args left check if the
|
# increment counter for legacy_args if still args left. If no args left check if the
|
||||||
# last arg is a predefined array and let it cells be filled. Otherwise complain and
|
|
||||||
|
# last arg is a predefined array and let it cells be filled. Otherwise complain and
|
||||||
|
|
||||||
# return.
|
# return.
|
||||||
flohmarkt_print_debug "positional_counter='$positional_count', max positional_counter='$(( ${#legacy_args} -1 ))'"
|
flohmarkt_print_debug "positional_counter='$positional_count', max positional_counter='$(( ${#legacy_args} -1 ))'"
|
||||||
if [[ $positional_count -le $((${#legacy_args} - 1)) ]]; then
|
if [[ $positional_count -le $((${#legacy_args} - 1)) ]]; then
|
||||||
|
@ -309,11 +323,12 @@ flohmarkt_ynh_handle_getopts_args() {
|
||||||
# Also, remove '=' at the end of the long option
|
# Also, remove '=' at the end of the long option
|
||||||
# The variable name will be stored in 'option_var'
|
# The variable name will be stored in 'option_var'
|
||||||
option_var="${args_array[$option_flag]%=}"
|
option_var="${args_array[$option_flag]%=}"
|
||||||
elif [[ $positional_count -ge $((${#legacy_args} - 1)) ]] &&
|
elif [[ $positional_count -ge $((${#legacy_args} - 1)) ]] &&
|
||||||
|
|
||||||
! declare -p ${option_var} | grep '^declare -a'
|
! declare -p ${option_var} | grep '^declare -a'
|
||||||
then
|
then
|
||||||
# no more legacy_args to fill - legacy behaviour: complain and return
|
# no more legacy_args to fill - legacy behaviour: complain and return
|
||||||
ynh_print_warn --message="Too many arguments ! \"${arguments[$i]}\" will be ignored."
|
ynh_print_warn "Too many arguments ! \"${arguments[$i]}\" will be ignored."
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
flohmarkt_print_debug "array found - keep going"
|
flohmarkt_print_debug "array found - keep going"
|
||||||
|
@ -371,7 +386,7 @@ flohmarkt_ynh_local_curl() {
|
||||||
# Curl abstraction to help with POST requests to local pages (such as installation forms)
|
# Curl abstraction to help with POST requests to local pages (such as installation forms)
|
||||||
#
|
#
|
||||||
# usage: ynh_local_curl [--option [-other_option […]]] "page" "key1=value1" "key2=value2" ...
|
# usage: ynh_local_curl [--option [-other_option […]]] "page" "key1=value1" "key2=value2" ...
|
||||||
# | arg: -l --line_match: check answer against an extended regex
|
# | arg: -l --wait_until: check answer against an extended regex
|
||||||
# | arg: -m --method: request method to use: POST (default), PUT, GET, DELETE
|
# | arg: -m --method: request method to use: POST (default), PUT, GET, DELETE
|
||||||
# | arg: -H --header: add a header to the request (can be used multiple times)
|
# | arg: -H --header: add a header to the request (can be used multiple times)
|
||||||
# | arg: -d --data: data to be PUT or POSTed. Can be used multiple times.
|
# | arg: -d --data: data to be PUT or POSTed. Can be used multiple times.
|
||||||
|
@ -387,7 +402,8 @@ flohmarkt_ynh_local_curl() {
|
||||||
#
|
#
|
||||||
# example: ynh_local_curl "/install.php?installButton" "foo=$var1" "bar=$var2"
|
# example: ynh_local_curl "/install.php?installButton" "foo=$var1" "bar=$var2"
|
||||||
# → will open a POST request to "https://$domain/$path/install.php?installButton" posting "foo=$var1" and "bar=$var2"
|
# → will open a POST request to "https://$domain/$path/install.php?installButton" posting "foo=$var1" and "bar=$var2"
|
||||||
# example: ynh_local_curl -m POST --header "Accept: application/json" \
|
# example: ynh_local_curl -m POST --header "Accept: application/json" \
|
||||||
|
|
||||||
# -H "Content-Type: application/json" \
|
# -H "Content-Type: application/json" \
|
||||||
# --data "{\"members\":{\"names\": [\"${app}\"],\"roles\": [\"editor\"]}}" -l '"ok":true' \
|
# --data "{\"members\":{\"names\": [\"${app}\"],\"roles\": [\"editor\"]}}" -l '"ok":true' \
|
||||||
# "http://localhost:5984/"
|
# "http://localhost:5984/"
|
||||||
|
@ -398,24 +414,27 @@ flohmarkt_ynh_local_curl() {
|
||||||
# For multiple calls, cookies are persisted between each call for the same app.
|
# For multiple calls, cookies are persisted between each call for the same app.
|
||||||
#
|
#
|
||||||
# `$domain` and `$path_url` need to be defined externally if the first form for the 'page' argument is used.
|
# `$domain` and `$path_url` need to be defined externally if the first form for the 'page' argument is used.
|
||||||
#
|
#
|
||||||
# The return code of this function will vary depending of the use of --line_match:
|
|
||||||
#
|
# The return code of this function will vary depending of the use of --wait_until:
|
||||||
# If --line_match has been used the return code will be the one of the grep checking line_match
|
#
|
||||||
|
|
||||||
|
# If --wait_until has been used the return code will be the one of the grep checking line_match
|
||||||
# against the output of curl. The output of curl will not be returned.
|
# against the output of curl. The output of curl will not be returned.
|
||||||
#
|
#
|
||||||
# If --line_match has not been provided the return code will be the one of the curl command and
|
# If --wait_until has not been provided the return code will be the one of the curl command and
|
||||||
# the output of curl will be echoed.
|
# the output of curl will be echoed.
|
||||||
#
|
#
|
||||||
# Requires YunoHost version 2.6.4 or higher.
|
# Requires YunoHost version 2.6.4 or higher.
|
||||||
|
|
||||||
# Declare an array to define the options of this helper.a
|
# Declare an array to define the options of this helper.a
|
||||||
local -A supported_methods=( [PUT]=1 [POST]=1 [GET]=1 [DELETE]=1 )
|
local -A supported_methods=( [PUT]=1 [POST]=1 [GET]=1 [DELETE]=1 )
|
||||||
local legacy_args=Ld
|
#REMOVEME? local legacy_args=Ld
|
||||||
local -A args_array=( [l]=line_match= [m]=method= [H]=header= [n]=no_sleep [L]=location= [d]=data= [u]=user= [p]=password= [s]=seperator= )
|
local -A args_array=( [l]=line_match= [m]=method= [H]=header= [n]=no_sleep [L]=location= [d]=data= [u]=user= [p]=password= [s]=seperator= )
|
||||||
local line_match
|
local line_match
|
||||||
local method
|
local method
|
||||||
local -a header
|
local -a header
|
||||||
|
|
||||||
local no_sleep
|
local no_sleep
|
||||||
local location
|
local location
|
||||||
local user
|
local user
|
||||||
|
@ -428,7 +447,7 @@ flohmarkt_ynh_local_curl() {
|
||||||
|
|
||||||
# make sure method is a supported one
|
# make sure method is a supported one
|
||||||
if ! [[ -v supported_methods[$method] ]]; then
|
if ! [[ -v supported_methods[$method] ]]; then
|
||||||
ynh_die --message="method $method not supported by flohmarkt_ynh_local_curl"
|
ynh_die "method $method not supported by flohmarkt_ynh_local_curl"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# linter doesn't want that the internal function is used anymore
|
# linter doesn't want that the internal function is used anymore
|
||||||
|
@ -487,11 +506,12 @@ flohmarkt_ynh_local_curl() {
|
||||||
seq=$(( $seq + 1 ))
|
seq=$(( $seq + 1 ))
|
||||||
done
|
done
|
||||||
|
|
||||||
# build --user for curl
|
# build --user for curl
|
||||||
|
|
||||||
if [[ -n "$user" ]] && [[ -n "$password" ]]; then
|
if [[ -n "$user" ]] && [[ -n "$password" ]]; then
|
||||||
curl_opt_args+=('--user' "$user:$password")
|
curl_opt_args+=('--user' "$user:$password")
|
||||||
elif [[ -n "$user" ]] && [[ -z "$password" ]]; then
|
elif [[ -n "$user" ]] && [[ -z "$password" ]]; then
|
||||||
ynh_die --message="user provided via '-u/--user' needs password specified via '-p/--password'"
|
ynh_die "user provided via '-u/--user' needs password specified via '-p/--password'"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
flohmarkt_print_debug "long string curl_opt_args='${curl_opt_args[@]}'"
|
flohmarkt_print_debug "long string curl_opt_args='${curl_opt_args[@]}'"
|
||||||
|
@ -533,14 +553,14 @@ flohmarkt_ynh_local_curl() {
|
||||||
--resolve "$domain:443:127.0.0.1" "${curl_opt_args[@]}" "$full_page_url" )
|
--resolve "$domain:443:127.0.0.1" "${curl_opt_args[@]}" "$full_page_url" )
|
||||||
local curl_error=$?
|
local curl_error=$?
|
||||||
flohmarkt_print_debug "curl_result='$curl_result' ($curl_error)"
|
flohmarkt_print_debug "curl_result='$curl_result' ($curl_error)"
|
||||||
|
|
||||||
# check result agains --line_match if provided
|
# check result agains --wait_until if provided
|
||||||
if [[ -v line_match ]] && [[ -n $line_match ]]; then
|
if [[ -v line_match ]] && [[ -n $line_match ]]; then
|
||||||
printf '%s' "$curl_result" | grep "$line_match" > /dev/null
|
printf '%s' "$curl_result" | grep "$line_match" > /dev/null
|
||||||
# will return the error code of the above grep
|
# will return the error code of the above grep
|
||||||
curl_error=$?
|
curl_error=$?
|
||||||
else
|
else
|
||||||
# no --line_match, return curls error code and output
|
# no --wait_until, return curls error code and output
|
||||||
echo $curl_result
|
echo $curl_result
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -551,10 +571,6 @@ flohmarkt_ynh_local_curl() {
|
||||||
return $curl_error
|
return $curl_error
|
||||||
}
|
}
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# PERSONAL HELPERS
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
# debug output for flohmarkt_ynh_handle_getopts_args and flohmarkt_ynh_local_curl
|
# debug output for flohmarkt_ynh_handle_getopts_args and flohmarkt_ynh_local_curl
|
||||||
# otherwise not needed TODO delete after development of the two is done
|
# otherwise not needed TODO delete after development of the two is done
|
||||||
flohmarkt_debug=0
|
flohmarkt_debug=0
|
||||||
|
@ -581,28 +597,28 @@ flohmarkt_ynh_set_permission() {
|
||||||
|
|
||||||
# start flohmarkt service
|
# start flohmarkt service
|
||||||
flohmarkt_ynh_start_service() {
|
flohmarkt_ynh_start_service() {
|
||||||
ynh_systemd_action --service_name=$flohmarkt_filename --action="start" \
|
ynh_systemctl --service=$flohmarkt_filename --action="start" \
|
||||||
--line_match='INFO: *Application startup complete.' --log_path="$flohmarkt_logfile" \
|
--wait_until='INFO: *Application startup complete.' --log_path="$flohmarkt_logfile" \
|
||||||
--timeout=30
|
--timeout=30
|
||||||
}
|
}
|
||||||
|
|
||||||
# stop flohmarkt service
|
# stop flohmarkt service
|
||||||
flohmarkt_ynh_stop_service() {
|
flohmarkt_ynh_stop_service() {
|
||||||
ynh_systemd_action --service_name=$flohmarkt_filename --action="stop"
|
ynh_systemctl --service=$flohmarkt_filename --action="stop"
|
||||||
}
|
}
|
||||||
|
|
||||||
# start couchdb and wait for success
|
# start couchdb and wait for success
|
||||||
flohmarkt_ynh_start_couchdb() {
|
flohmarkt_ynh_start_couchdb() {
|
||||||
ynh_systemd_action --service_name=couchdb --action="start" --timeout=30 \
|
ynh_systemctl --service=couchdb --action="start" --timeout=30 \
|
||||||
--log_path="/var/log/couchdb/couchdb.log" \
|
--log_path="/var/log/couchdb/couchdb.log" \
|
||||||
--line_match='Apache CouchDB has started on http://127.0.0.1'
|
--wait_until='Apache CouchDB has started on http://127.0.0.1'
|
||||||
}
|
}
|
||||||
|
|
||||||
# stop couchdb
|
# stop couchdb
|
||||||
flohmarkt_ynh_stop_couchdb() {
|
flohmarkt_ynh_stop_couchdb() {
|
||||||
ynh_systemd_action --service_name=couchdb --action="stop" --timeout=30 \
|
ynh_systemctl --service=couchdb --action="stop" --timeout=30 \
|
||||||
--log_path="/var/log/couchdb/couchdb.log" \
|
--log_path="/var/log/couchdb/couchdb.log" \
|
||||||
--line_match='SIGTERM received - shutting down'
|
--wait_until='SIGTERM received - shutting down'
|
||||||
}
|
}
|
||||||
|
|
||||||
# install or upgrade couchdb
|
# install or upgrade couchdb
|
||||||
|
@ -618,7 +634,7 @@ flohmarkt_ynh_up_inst_couchdb() {
|
||||||
couchdb couchdb/adminpass_again password $password_couchdb_admin
|
couchdb couchdb/adminpass_again password $password_couchdb_admin
|
||||||
couchdb couchdb/adminpass_again seen true" | debconf-set-selections
|
couchdb couchdb/adminpass_again seen true" | debconf-set-selections
|
||||||
DEBIAN_FRONTEND=noninteractive # apt-get install -y --force-yes couchdb
|
DEBIAN_FRONTEND=noninteractive # apt-get install -y --force-yes couchdb
|
||||||
ynh_install_extra_app_dependencies \
|
ynh_apt_install_dependencies_from_extra_repository \
|
||||||
--repo="deb https://apache.jfrog.io/artifactory/couchdb-deb/ $(lsb_release -c -s) main" \
|
--repo="deb https://apache.jfrog.io/artifactory/couchdb-deb/ $(lsb_release -c -s) main" \
|
||||||
--key="https://couchdb.apache.org/repo/keys.asc" \
|
--key="https://couchdb.apache.org/repo/keys.asc" \
|
||||||
--package="couchdb"
|
--package="couchdb"
|
||||||
|
@ -659,7 +675,7 @@ flohmarkt_ynh_delete_couchdb_user() {
|
||||||
flohmarkt_ynh_local_curl -n -m DELETE -u admin -p ${password_couchdb_admin} -l '"ok":true' \
|
flohmarkt_ynh_local_curl -n -m DELETE -u admin -p ${password_couchdb_admin} -l '"ok":true' \
|
||||||
"http://127.0.0.1:5984/_users/org.couchdb.user%3A${app}?rev=${couchdb_user_revision}"
|
"http://127.0.0.1:5984/_users/org.couchdb.user%3A${app}?rev=${couchdb_user_revision}"
|
||||||
else
|
else
|
||||||
ynh_die --message "couchdb_user_revision is empty (${couchdb_user_revision})"
|
ynh_die "couchdb_user_revision is empty (${couchdb_user_revision})"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -669,7 +685,7 @@ flohmarkt_ynh_create_couchdb_user() {
|
||||||
-d '{' \
|
-d '{' \
|
||||||
-d "\"name\": \"${app}\", \"password\": \"${password_couchdb_flohmarkt}\"," \
|
-d "\"name\": \"${app}\", \"password\": \"${password_couchdb_flohmarkt}\"," \
|
||||||
-d '"roles": [], "type": "user"}' \
|
-d '"roles": [], "type": "user"}' \
|
||||||
--line_match='"ok":true' \
|
--wait_until='"ok":true' \
|
||||||
"http://127.0.0.1:5984/_users/org.couchdb.user:${app}"
|
"http://127.0.0.1:5984/_users/org.couchdb.user:${app}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -677,7 +693,7 @@ flohmarkt_ynh_couchdb_user_permissions() {
|
||||||
flohmarkt_ynh_local_curl -n -m PUT -u admin -p "$password_couchdb_admin" \
|
flohmarkt_ynh_local_curl -n -m PUT -u admin -p "$password_couchdb_admin" \
|
||||||
-H "Accept: application/json" -H "Content-Type: application/json" \
|
-H "Accept: application/json" -H "Content-Type: application/json" \
|
||||||
-d "{\"members\":{\"names\": [\"${app}\"],\"roles\": [\"editor\"]}}" \
|
-d "{\"members\":{\"names\": [\"${app}\"],\"roles\": [\"editor\"]}}" \
|
||||||
--line_match='"ok":true' \
|
--wait_until='"ok":true' \
|
||||||
"http://127.0.0.1:5984/${app}/_security"
|
"http://127.0.0.1:5984/${app}/_security"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -692,18 +708,18 @@ flohmarkt_ynh_exists_couchdb_db() {
|
||||||
}
|
}
|
||||||
|
|
||||||
flohmarkt_ynh_delete_couchdb_db() {
|
flohmarkt_ynh_delete_couchdb_db() {
|
||||||
local legacy_args='n'
|
#REMOVEME? local legacy_args='n'
|
||||||
local -A args_array=( [n]=name= )
|
local -A args_array=( [n]=name= )
|
||||||
flohmarkt_ynh_handle_getopts_args "$@"
|
flohmarkt_ynh_handle_getopts_args "$@"
|
||||||
local name=${name:-${app}}
|
local name=${name:-${app}}
|
||||||
|
|
||||||
flohmarkt_ynh_local_curl -n -m DELETE -u admin -p "$password_couchdb_admin" \
|
flohmarkt_ynh_local_curl -n -m DELETE -u admin -p "$password_couchdb_admin" \
|
||||||
--line_match='"ok":true' "http://127.0.0.1:5984/${name}"
|
--wait_until='"ok":true' "http://127.0.0.1:5984/${name}"
|
||||||
}
|
}
|
||||||
|
|
||||||
# replicate couchdb to a new database
|
# replicate couchdb to a new database
|
||||||
flohmarkt_ynh_copy_couchdb() {
|
flohmarkt_ynh_copy_couchdb() {
|
||||||
local legacy_args='on'
|
#REMOVEME? local legacy_args='on'
|
||||||
local -A args_array=( [o]=old_name= [n]=new_name= )
|
local -A args_array=( [o]=old_name= [n]=new_name= )
|
||||||
local new_name
|
local new_name
|
||||||
local old_name
|
local old_name
|
||||||
|
@ -714,12 +730,12 @@ flohmarkt_ynh_copy_couchdb() {
|
||||||
-H "Accept: application/json" -H "Content-Type: application/json" \
|
-H "Accept: application/json" -H "Content-Type: application/json" \
|
||||||
-d '{ "create_target":true,"source" : "' -d"${old_name}" -d'",' \
|
-d '{ "create_target":true,"source" : "' -d"${old_name}" -d'",' \
|
||||||
-d '"target":"' -d "${new_name}" -d'"}' --seperator=none \
|
-d '"target":"' -d "${new_name}" -d'"}' --seperator=none \
|
||||||
--line_match='"ok":true' "http://127.0.0.1:5984/_replicate"
|
--wait_until='"ok":true' "http://127.0.0.1:5984/_replicate"
|
||||||
}
|
}
|
||||||
|
|
||||||
# copy couchdb to new name and delete source
|
# copy couchdb to new name and delete source
|
||||||
flohmarkt_ynh_rename_couchdb() {
|
flohmarkt_ynh_rename_couchdb() {
|
||||||
local legacy_args='on'
|
#REMOVEME? local legacy_args='on'
|
||||||
local -A args_array=( [o]=old_name= [n]=new_name= )
|
local -A args_array=( [o]=old_name= [n]=new_name= )
|
||||||
local new_name
|
local new_name
|
||||||
local old_name
|
local old_name
|
||||||
|
@ -733,9 +749,9 @@ flohmarkt_ynh_rename_couchdb() {
|
||||||
flohmarkt_ynh_backup_old_couchdb() {
|
flohmarkt_ynh_backup_old_couchdb() {
|
||||||
flohmarkt_couchdb_rename_to="${app}_$(date '+%Y-%m-%d_%H-%M-%S_%N')"
|
flohmarkt_couchdb_rename_to="${app}_$(date '+%Y-%m-%d_%H-%M-%S_%N')"
|
||||||
if flohmarkt_ynh_rename_couchdb "${app}" "${flohmarkt_couchdb_rename_to}"; then
|
if flohmarkt_ynh_rename_couchdb "${app}" "${flohmarkt_couchdb_rename_to}"; then
|
||||||
ynh_print_warn --message="renamed existing database ${app} to ${flohmarkt_couchdb_rename_to}"
|
ynh_print_warn "renamed existing database ${app} to ${flohmarkt_couchdb_rename_to}"
|
||||||
else
|
else
|
||||||
ynh_die --message="could not rename existing couchdb database and cannot overwrite it"
|
ynh_die "could not rename existing couchdb database and cannot overwrite it"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -751,13 +767,12 @@ flohmarkt_ynh_create_venv() {
|
||||||
}
|
}
|
||||||
|
|
||||||
flohmarkt_ynh_venv_upgrade() {
|
flohmarkt_ynh_venv_upgrade() {
|
||||||
ynh_print_warn --message="flohmarkt_ynh_venv_upgrade: I'll sit here and do nothing without @grindholds confirmation"
|
ynh_print_warn "flohmarkt_ynh_venv_upgrade: I'll sit here and do nothing without @grindholds confirmation"
|
||||||
return
|
return
|
||||||
(
|
(
|
||||||
$flohmarkt_venv_dir/bin/python3 -m venv --upgrade-deps
|
$flohmarkt_venv_dir/bin/python3 -m venv --upgrade-deps
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# install requirements.txt in venv
|
# install requirements.txt in venv
|
||||||
flohmarkt_ynh_venv_requirements() {
|
flohmarkt_ynh_venv_requirements() {
|
||||||
|
@ -774,31 +789,34 @@ flohmarkt_ynh_venv_requirements() {
|
||||||
flohmarkt_ynh_urlwatch_cron() {
|
flohmarkt_ynh_urlwatch_cron() {
|
||||||
mkdir -m 750 -p "${flohmarkt_urlwatch_dir}"
|
mkdir -m 750 -p "${flohmarkt_urlwatch_dir}"
|
||||||
chown ${app}:root "${flohmarkt_urlwatch_dir}"
|
chown ${app}:root "${flohmarkt_urlwatch_dir}"
|
||||||
ynh_add_config --template="../conf/urlwatch_config.yaml" \
|
ynh_config_add --template="urlwatch_config.yaml" \
|
||||||
--destination="${flohmarkt_urlwatch_dir}/config.yaml"
|
--destination="${flohmarkt_urlwatch_dir}/config.yaml"
|
||||||
ynh_add_config --template="../conf/urlwatch_urls.yaml" \
|
ynh_config_add --template="urlwatch_urls.yaml" \
|
||||||
--destination="${flohmarkt_urlwatch_dir}/urls.yaml"
|
--destination="${flohmarkt_urlwatch_dir}/urls.yaml"
|
||||||
ynh_add_config --template="../conf/urlwatch.cron" \
|
ynh_config_add --template="urlwatch.cron" \
|
||||||
--destination="${flohmarkt_cron_job}"
|
--destination="${flohmarkt_cron_job}"
|
||||||
chown root:root "${flohmarkt_cron_job}"
|
chown root:root "${flohmarkt_cron_job}"
|
||||||
chmod 755 "${flohmarkt_cron_job}"
|
chmod 755 "${flohmarkt_cron_job}"
|
||||||
# run urlwatch once to initialize if cache file does not exist,
|
# run urlwatch once to initialize if cache file does not exist,
|
||||||
|
|
||||||
# but if sending email fails (like on CI) just warn. We do not want
|
# but if sending email fails (like on CI) just warn. We do not want
|
||||||
# to show the output that might contain passwords
|
# to show the output that might contain passwords
|
||||||
if ! [[ -s ${flohmarkt_urlwatch_dir}/cache.file ]] &&
|
if ! [[ -s ${flohmarkt_urlwatch_dir}/cache.file ]] &&
|
||||||
! ynh_exec_fully_quiet sudo -u ${app} urlwatch \
|
! sudo -u ${app} urlwatch \
|
||||||
--config=${flohmarkt_urlwatch_dir}/config.yaml \
|
--config=${flohmarkt_urlwatch_dir}/config.yaml \
|
||||||
--urls=${flohmarkt_urlwatch_dir}/urls.yaml \
|
--urls=${flohmarkt_urlwatch_dir}/urls.yaml \
|
||||||
--cache=${flohmarkt_urlwatch_dir}/cache.file
|
--cache=${flohmarkt_urlwatch_dir}/cache.file
|
||||||
|
|
||||||
then
|
then
|
||||||
ynh_print_warn --message="initial call to urlwatch failed"
|
ynh_print_warn "initial call to urlwatch failed"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
flohmarkt_initialized() {
|
flohmarkt_initialized() {
|
||||||
flohmarkt_ynh_local_curl -n -m GET -u admin -p "$password_couchdb_admin" \
|
flohmarkt_ynh_local_curl -n -m GET -u admin -p "$password_couchdb_admin" \
|
||||||
-l '"initialized":true' \
|
-l '"initialized":true' \
|
||||||
"http://127.0.0.1:5984/${app}/instance_settings"
|
"http://127.0.0.1:5984/${app}/instance_settings"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
flohmarkt_ynh_get_initialization_key() {
|
flohmarkt_ynh_get_initialization_key() {
|
||||||
|
@ -817,39 +835,31 @@ flohmarkt_ynh_upgrade_path_ynh5() {
|
||||||
# yunohost seems to move the venv dir automatically, but this
|
# yunohost seems to move the venv dir automatically, but this
|
||||||
# doesn't work, because the paths inside the venv are not adjusted
|
# doesn't work, because the paths inside the venv are not adjusted
|
||||||
# delete the old, not working venv and create a new one:
|
# delete the old, not working venv and create a new one:
|
||||||
ynh_secure_remove --file="$flohmarkt_venv_dir"
|
ynh_safe_rm "$flohmarkt_venv_dir"
|
||||||
flohmarkt_ynh_create_venv
|
flohmarkt_ynh_create_venv
|
||||||
flohmarkt_ynh_venv_requirements
|
flohmarkt_ynh_venv_requirements
|
||||||
# remove old $install_dir
|
# remove old $install_dir
|
||||||
ynh_secure_remove --file="$flohmarkt_old_install"
|
ynh_safe_rm "$flohmarkt_old_install"
|
||||||
|
|
||||||
# move logfile directory
|
# move logfile directory
|
||||||
mkdir -p "$flohmarkt_log_dir"
|
mkdir -p "$flohmarkt_log_dir"
|
||||||
|
|
||||||
# remove systemd.service - will be generated newly by upgrade
|
# remove systemd.service - will be generated newly by upgrade
|
||||||
# ynh_remove_systemd_config --service="$flohmarkt_old_service"
|
# ynh_config_remove_systemd"$flohmarkt_old_service"
|
||||||
ynh_systemd_action --action=stop --service_name="$flohmarkt_old_service"
|
ynh_systemctl --action=stop --service="$flohmarkt_old_service"
|
||||||
ynh_systemd_action --action=disable --service_name="$flohmarkt_old_service"
|
ynh_systemctl --action=disable --service="$flohmarkt_old_service"
|
||||||
ynh_secure_remove --file="/etc/systemd/system/multi-user.target.wants/flohmarkt.service"
|
ynh_safe_rm "/etc/systemd/system/multi-user.target.wants/flohmarkt.service"
|
||||||
ynh_secure_remove --file="/etc/systemd/system/flohmarkt.service"
|
ynh_safe_rm "/etc/systemd/system/flohmarkt.service"
|
||||||
# funktioniert nicht? issue?
|
# funktioniert nicht? issue?
|
||||||
#ynh_systemd_action --action=daemon-reload
|
#ynh_systemctl --action=daemon-reload
|
||||||
# DEBUG + systemctl daemon-reload flohmarkt
|
# DEBUG + systemctl daemon-reload flohmarkt
|
||||||
# WARNING Too many arguments.
|
# WARNING Too many arguments.
|
||||||
systemctl daemon-reload
|
systemctl daemon-reload
|
||||||
# unit flohmarkt is automatically appended and therefor this fails:
|
# unit flohmarkt is automatically appended and therefor this fails:
|
||||||
#ynh_systemd_action --action=reset-failed
|
#ynh_systemctl --action=reset-failed
|
||||||
systemctl reset-failed
|
systemctl reset-failed
|
||||||
|
|
||||||
# create symlinks
|
# create symlinks
|
||||||
ln -s "$flohmarkt_install" "$flohmarkt_sym_install"
|
ln -s "$flohmarkt_install" "$flohmarkt_sym_install"
|
||||||
ln -s "$flohmarkt_data_dir" "$flohmarkt_sym_data_dir"
|
ln -s "$flohmarkt_data_dir" "$flohmarkt_sym_data_dir"
|
||||||
}
|
}
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# EXPERIMENTAL HELPERS
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# FUTURE OFFICIAL HELPERS
|
|
||||||
#=================================================
|
|
||||||
|
|
|
@ -3,37 +3,40 @@
|
||||||
source ../settings/scripts/_common.sh
|
source ../settings/scripts/_common.sh
|
||||||
source /usr/share/yunohost/helpers
|
source /usr/share/yunohost/helpers
|
||||||
|
|
||||||
ynh_print_info --message="Declaring files to be backed up..."
|
ynh_print_info "Declaring files to be backed up..."
|
||||||
ynh_backup --src_path="$flohmarkt_install"
|
ynh_backup "$flohmarkt_install"
|
||||||
ynh_backup --src_path="/etc/nginx/conf.d/$domain.d/$app.conf"
|
ynh_backup "/etc/nginx/conf.d/$domain.d/$app.conf"
|
||||||
ynh_backup --src_path="/etc/fail2ban/jail.d/$app.conf"
|
ynh_backup "/etc/fail2ban/jail.d/$app.conf"
|
||||||
ynh_backup --src_path="/etc/fail2ban/filter.d/$app.conf"
|
ynh_backup "/etc/fail2ban/filter.d/$app.conf"
|
||||||
ynh_backup --src_path="/etc/logrotate.d/$app"
|
ynh_backup "/etc/logrotate.d/$app"
|
||||||
ynh_backup --src_path="/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
ynh_backup "/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
||||||
ynh_backup --src_path="/etc/systemd/system/$flohmarkt_filename.service"
|
ynh_backup "/etc/systemd/system/$flohmarkt_filename.service"
|
||||||
ynh_backup --src_path="${flohmarkt_cron_job}"
|
ynh_backup "${flohmarkt_cron_job}"
|
||||||
ynh_backup --src_path="${flohmarkt_log_dir}"
|
ynh_backup "${flohmarkt_log_dir}"
|
||||||
|
|
||||||
# for the following backups we'll want to stop flohmarkt and couchdb
|
# for the following backups we'll want to stop flohmarkt and couchdb
|
||||||
# to guarentee a consistant state
|
# to guarentee a consistant state
|
||||||
ynh_print_info --message="Stopping flohmarkt to backup data..."
|
ynh_print_info "Stopping flohmarkt to backup data..."
|
||||||
flohmarkt_ynh_stop_service
|
flohmarkt_ynh_stop_service
|
||||||
|
|
||||||
# https://codeberg.org/ChriChri/flohmarkt_ynh/issues/24
|
# https://codeberg.org/ChriChri/flohmarkt_ynh/issues/24
|
||||||
# since this might be re-installed as a dependency during 'remove' and
|
# since this might be re-installed as a dependency during 'remove' and
|
||||||
|
|
||||||
# 'install' anew (like after a failed upgrade) we do not want to use
|
# 'install' anew (like after a failed upgrade) we do not want to use
|
||||||
# --is_big even thought the directories might be big because:
|
# even thought the directories might be big because:
|
||||||
# "don't want that your package does backup that part during ynh_backup_before_upgrade"
|
# "don't want that your package does backup that part during ynh_backup_before_upgrade"
|
||||||
# https://yunohost.org/en/packaging_apps_scripts_helpers#ynh-backup
|
# https://yunohost.org/en/packaging_apps_scripts_helpers#ynh-backup
|
||||||
#
|
#
|
||||||
# if this becomes a pain we'll need to stop deleting this directories on 'remove'
|
|
||||||
# ynh_backup --src_path="$data_dir" --is_big
|
|
||||||
ynh_backup --src_path="$flohmarkt_data_dir"
|
|
||||||
|
|
||||||
ynh_print_info --message="Dumping couchdb..."
|
# if this becomes a pain we'll need to stop deleting this directories on 'remove'
|
||||||
|
# ynh_backup "$data_dir"
|
||||||
|
|
||||||
|
ynh_backup "$flohmarkt_data_dir"
|
||||||
|
|
||||||
|
ynh_print_info "Dumping couchdb..."
|
||||||
flohmarkt_ynh_dump_couchdb
|
flohmarkt_ynh_dump_couchdb
|
||||||
|
|
||||||
ynh_print_info --message="Starting flohmarkt..."
|
ynh_print_info "Starting flohmarkt..."
|
||||||
flohmarkt_ynh_start_service
|
flohmarkt_ynh_start_service
|
||||||
|
|
||||||
ynh_print_info --message="Backup script completed for $app."
|
ynh_print_info "Backup script completed for $app."
|
||||||
|
|
|
@ -3,15 +3,17 @@
|
||||||
source /etc/yunohost/apps/$app/scripts/_common.sh
|
source /etc/yunohost/apps/$app/scripts/_common.sh
|
||||||
source /usr/share/yunohost/helpers
|
source /usr/share/yunohost/helpers
|
||||||
|
|
||||||
ynh_abort_if_errors
|
#REMOVEME? ynh_abort_if_errors
|
||||||
|
|
||||||
# my code starts here:
|
# my code starts here:
|
||||||
|
|
||||||
get__flohmarkt_initial_setup_url(){
|
get__flohmarkt_initial_setup_url(){
|
||||||
local init_key="$(flohmarkt_ynh_get_initialization_key)"
|
local init_key="$(flohmarkt_ynh_get_initialization_key)"
|
||||||
# TODO: wenn leer, dann etwas anderes zurückgeben
|
# TODO: wenn leer, dann etwas anderes zurückgeben
|
||||||
if ! [[ -v init_key ]] ||
|
if ! [[ -v init_key ]] ||
|
||||||
[[ "${init_key}" == 'null' ]] ||
|
|
||||||
|
[[ "${init_key}" == 'null' ]] ||
|
||||||
|
|
||||||
[[ -z "${init_key}" ]]
|
[[ -z "${init_key}" ]]
|
||||||
then
|
then
|
||||||
if flohmarkt_initialized; then
|
if flohmarkt_initialized; then
|
||||||
|
|
|
@ -12,7 +12,7 @@ source /usr/share/yunohost/helpers
|
||||||
if [[ -e /opt/couchdb ]] || pgrep epmd > /dev/null || pgrep beam.smp || dpkg-query -W couchdb > /dev/null 2>&1 \
|
if [[ -e /opt/couchdb ]] || pgrep epmd > /dev/null || pgrep beam.smp || dpkg-query -W couchdb > /dev/null 2>&1 \
|
||||||
&& ! [[ -e /opt/couchdb/etc/local.d/05-flohmarkt.ini ]];
|
&& ! [[ -e /opt/couchdb/etc/local.d/05-flohmarkt.ini ]];
|
||||||
then
|
then
|
||||||
ynh_die --message="CouchDB already installed on this host - will not proceed."
|
ynh_die "CouchDB already installed on this host - will not proceed."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -21,17 +21,17 @@ fi
|
||||||
# → there's no way to get the admin password later if sometimes in the future deleting
|
# → there's no way to get the admin password later if sometimes in the future deleting
|
||||||
# the app will delete its specific database only (instead of the whole couchdb server as
|
# the app will delete its specific database only (instead of the whole couchdb server as
|
||||||
# of now in the earliest versions of the integration).
|
# of now in the earliest versions of the integration).
|
||||||
ynh_app_setting_set --app=$app --key=password_couchdb_admin --value="$password_couchdb_admin"
|
ynh_app_setting_set --key=password_couchdb_admin --value="$password_couchdb_admin"
|
||||||
|
|
||||||
# get port, admin_pw for already installed couchdb
|
# get port, admin_pw for already installed couchdb
|
||||||
# skip the installation steps below
|
# skip the installation steps below
|
||||||
ynh_script_progression --message="Installing CouchDB..." --weight=60
|
ynh_script_progression "Installing CouchDB..."
|
||||||
|
|
||||||
# A CouchDB node has an Erlang magic cookie value set at startup.
|
# A CouchDB node has an Erlang magic cookie value set at startup.
|
||||||
# This value must match for all nodes in the cluster. If they do not match,
|
# This value must match for all nodes in the cluster. If they do not match,
|
||||||
# attempts to connect the node to the cluster will be rejected.
|
# attempts to connect the node to the cluster will be rejected.
|
||||||
couchdb_magic_cookie=$(ynh_string_random --length=23 --filter='A-Za-z0-9_')
|
couchdb_magic_cookie=$(ynh_string_random --length=23 --filter='A-Za-z0-9_')
|
||||||
ynh_app_setting_set --app=$app --key=couchdb_magic_cookie --value="$couchdb_magic_cookie"
|
ynh_app_setting_set --key=couchdb_magic_cookie --value="$couchdb_magic_cookie"
|
||||||
|
|
||||||
# update couchdb dpkg
|
# update couchdb dpkg
|
||||||
flohmarkt_ynh_up_inst_couchdb
|
flohmarkt_ynh_up_inst_couchdb
|
||||||
|
@ -40,24 +40,24 @@ flohmarkt_ynh_up_inst_couchdb
|
||||||
flohmarkt_ynh_stop_couchdb
|
flohmarkt_ynh_stop_couchdb
|
||||||
|
|
||||||
# add couchdb configuration
|
# add couchdb configuration
|
||||||
ynh_script_progression --message="Adding a configuration file..." --weight=2
|
ynh_script_progression "Adding $app's configuration..."
|
||||||
# customize couchdb config
|
# customize couchdb config
|
||||||
ynh_add_config --template="../conf/05-flohmarkt.ini" --destination="/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
ynh_config_add --template="05-flohmarkt.ini" --destination="/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
||||||
chown root:couchdb /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
chown root:couchdb /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
||||||
chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
||||||
|
|
||||||
# restart couchdb to pick up changes
|
# restart couchdb to pick up changes
|
||||||
ynh_script_progression --message="Starting CouchDB..." --weight=2
|
ynh_script_progression "Starting CouchDB..."
|
||||||
flohmarkt_ynh_start_couchdb
|
flohmarkt_ynh_start_couchdb
|
||||||
|
|
||||||
# get flohmarkt
|
# get flohmarkt
|
||||||
# suspecting that this deletes all other sources for YNH_APP_ID
|
# suspecting that this deletes all other sources for YNH_APP_ID
|
||||||
ynh_script_progression --message="Downloading flohmarkt..." --weight=2
|
ynh_script_progression "Downloading flohmarkt..."
|
||||||
ynh_setup_source --dest_dir="$flohmarkt_app_dir"
|
ynh_setup_source --dest_dir="$flohmarkt_app_dir"
|
||||||
|
|
||||||
# setup python environment for flohmarkt
|
# setup python environment for flohmarkt
|
||||||
ynh_script_progression --message="Creating python venv..." --weight=2
|
ynh_script_progression "Creating python venv..."
|
||||||
ynh_secure_remove "$flohmarkt_venv_dir"
|
ynh_safe_rm "$flohmarkt_venv_dir"
|
||||||
flohmarkt_ynh_create_venv
|
flohmarkt_ynh_create_venv
|
||||||
flohmarkt_ynh_venv_upgrade
|
flohmarkt_ynh_venv_upgrade
|
||||||
flohmarkt_ynh_venv_requirements
|
flohmarkt_ynh_venv_requirements
|
||||||
|
@ -65,65 +65,65 @@ flohmarkt_ynh_venv_requirements
|
||||||
# JwtSecret
|
# JwtSecret
|
||||||
# workaround for https://github.com/YunoHost/issues/issues/2379
|
# workaround for https://github.com/YunoHost/issues/issues/2379
|
||||||
jwtsecret=$(ynh_string_random -l 200 -f 'a-zA-Z0-9/+'; ynh_string_random -l 142 -f 'a-zA-Z0-9/+'; echo -n '==')
|
jwtsecret=$(ynh_string_random -l 200 -f 'a-zA-Z0-9/+'; ynh_string_random -l 142 -f 'a-zA-Z0-9/+'; echo -n '==')
|
||||||
ynh_app_setting_set --app=$app --key=jwtsecret --value="$jwtsecret"
|
ynh_app_setting_set --key=jwtsecret --value="$jwtsecret"
|
||||||
|
|
||||||
password_couchdb_flohmarkt=$(ynh_string_random --length=31 --filter='A-Za-z0-9_.:,')
|
password_couchdb_flohmarkt=$(ynh_string_random --length=31 --filter='A-Za-z0-9_.:,')
|
||||||
ynh_app_setting_set --app=$app --key=password_couchdb_flohmarkt --value="$password_couchdb_flohmarkt"
|
ynh_app_setting_set --key=password_couchdb_flohmarkt --value="$password_couchdb_flohmarkt"
|
||||||
|
|
||||||
# generate flohmarkt.conf
|
# generate flohmarkt.conf
|
||||||
ynh_script_progression --message="Adding flohmarkt.conf configuration..." --weight=2
|
ynh_script_progression "Adding flohmarkt.conf configuration..."
|
||||||
ynh_add_config --template="../conf/flohmarkt.conf" --destination="$flohmarkt_app_dir/flohmarkt.conf"
|
ynh_config_add --template="flohmarkt.conf" --destination="$flohmarkt_app_dir/flohmarkt.conf"
|
||||||
|
|
||||||
# setup couchdb
|
# setup couchdb
|
||||||
ynh_script_progression --message="Setup couchdb database and user for flohmarkt..." --weight=2
|
ynh_script_progression "Setup couchdb database and user for flohmarkt..."
|
||||||
flohmarkt_ynh_initialize_couchdb
|
flohmarkt_ynh_initialize_couchdb
|
||||||
|
|
||||||
# SETUP LOGROTATE
|
# SETUP LOGROTATE
|
||||||
ynh_script_progression --message="Configuring log rotation..." --weight=2
|
ynh_script_progression "Configuring log rotation..."
|
||||||
# Use logrotate to manage application logfile(s)
|
# Use logrotate to manage application logfile(s)
|
||||||
ynh_use_logrotate --logfile=$flohmarkt_logfile
|
ynh_config_add_logrotate $flohmarkt_logfile
|
||||||
|
|
||||||
# NGINX CONFIGURATION
|
# NGINX CONFIGURATION
|
||||||
ynh_script_progression --message="Configuring NGINX web server..." --weight=3
|
ynh_script_progression "Configuring NGINX web server..."
|
||||||
# Create a dedicated NGINX config
|
# Create a dedicated NGINX config
|
||||||
ynh_add_nginx_config
|
ynh_config_add_nginx
|
||||||
|
|
||||||
# systemd.service
|
# systemd.service
|
||||||
ynh_script_progression --message="Configuring a systemd service..." --weight=1
|
ynh_script_progression "Configuring $app's systemd service..."
|
||||||
# Create a dedicated systemd config
|
# Create a dedicated systemd config
|
||||||
ynh_add_systemd_config --service=$flohmarkt_filename
|
ynh_config_add_systemd --service=$flohmarkt_filename
|
||||||
# integrate into yunohost
|
# integrate into yunohost
|
||||||
ynh_script_progression --message="Integrating service in YunoHost..." --weight=1
|
ynh_script_progression "Integrating service in YunoHost..."
|
||||||
yunohost service add $flohmarkt_filename --description="A decentral federated small advertisement platform" --log="$flohmarkt_logfile"
|
yunohost service add $flohmarkt_filename --description="A decentral federated small advertisement platform" --log="$flohmarkt_logfile"
|
||||||
|
|
||||||
# logfile contains possibly the secret setup URL
|
# logfile contains possibly the secret setup URL
|
||||||
ynh_script_progression --message="Setting permissions on logfile..." --weight=2
|
ynh_script_progression "Setting permissions on logfile..."
|
||||||
mkdir -m755 -p "$flohmarkt_log_dir"
|
mkdir -m755 -p "$flohmarkt_log_dir"
|
||||||
touch "$flohmarkt_logfile"
|
touch "$flohmarkt_logfile"
|
||||||
chown root:$app "$flohmarkt_logfile"
|
chown root:$app "$flohmarkt_logfile"
|
||||||
chmod 660 "$flohmarkt_logfile"
|
chmod 660 "$flohmarkt_logfile"
|
||||||
|
|
||||||
# set file permissions for install dir
|
# set file permissions for install dir
|
||||||
ynh_script_progression --message="Setting permissions on install directory..." --weight=2
|
ynh_script_progression "Setting permissions on install directory..."
|
||||||
flohmarkt_ynh_set_permission
|
flohmarkt_ynh_set_permission
|
||||||
|
|
||||||
# SETUP FAIL2BAN
|
# SETUP FAIL2BAN
|
||||||
ynh_script_progression --message="Configuring Fail2Ban..." --weight=3
|
ynh_script_progression "Configuring Fail2Ban..."
|
||||||
ynh_add_fail2ban_config --logpath="$flohmarkt_logfile" --failregex='INFO: +<HOST>:\d+ - "POST /token HTTP/\d+\.\d+" 403 Forbidden' --max_retry=5
|
ynh_config_add_fail2ban --logpath="$flohmarkt_logfile" --failregex='INFO: +<HOST>:\d+ - "POST /token HTTP/\d+\.\d+" 403 Forbidden'
|
||||||
|
|
||||||
# symlink data_dir and install_dir to make it easier to find the
|
# symlink data_dir and install_dir to make it easier to find the
|
||||||
# files for a certain domain/path
|
# files for a certain domain/path
|
||||||
ynh_script_progression --message="Creating symlinks..." --weight=1
|
ynh_script_progression "Creating symlinks..."
|
||||||
flohmarkt_ynh_create_symlinks
|
flohmarkt_ynh_create_symlinks
|
||||||
|
|
||||||
# start service
|
# start service
|
||||||
ynh_script_progression --message="Debug before starting flohmarkt..." --weight=1
|
ynh_script_progression "Debug before starting flohmarkt..."
|
||||||
ls -l $flohmarkt_logfile /bin/bash /usr/bin/bash || true
|
ls -l $flohmarkt_logfile /bin/bash /usr/bin/bash || true
|
||||||
ynh_script_progression --message="Starting flohmarkt..." --weight=10
|
ynh_script_progression "Starting flohmarkt..."
|
||||||
flohmarkt_ynh_start_service
|
flohmarkt_ynh_start_service
|
||||||
|
|
||||||
# integrate urlwatch
|
# integrate urlwatch
|
||||||
ynh_script_progression --message="Configure urlwatch and its cron job..." --weight=1
|
ynh_script_progression "Configure urlwatch and its cron job..."
|
||||||
flohmarkt_ynh_urlwatch_cron
|
flohmarkt_ynh_urlwatch_cron
|
||||||
|
|
||||||
ynh_script_progression --message="Installation of $id completed" --last
|
ynh_script_progression "Installation of $id completed"
|
||||||
|
|
|
@ -1,11 +1,5 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# GENERIC START
|
|
||||||
#=================================================
|
|
||||||
# IMPORT GENERIC HELPERS
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
source _common.sh
|
source _common.sh
|
||||||
source /usr/share/yunohost/helpers
|
source /usr/share/yunohost/helpers
|
||||||
|
|
||||||
|
@ -14,53 +8,54 @@ source /usr/share/yunohost/helpers
|
||||||
#=================================================
|
#=================================================
|
||||||
# REMOVE SERVICE INTEGRATION IN YUNOHOST
|
# REMOVE SERVICE INTEGRATION IN YUNOHOST
|
||||||
#=================================================
|
#=================================================
|
||||||
ynh_script_progression --message="Removing system configurations related to $app..." --weight=5
|
ynh_script_progression "Removing system configurations related to $app..."
|
||||||
|
|
||||||
# Stop flohmarkt service
|
# Stop flohmarkt service
|
||||||
ynh_script_progression --message="Stopping $app..." --weight=2
|
ynh_script_progression "Stopping $app..."
|
||||||
yunohost service stop $flohmarkt_filename
|
yunohost service stop $flohmarkt_filename
|
||||||
|
|
||||||
# Remove the service from the list of services known by YunoHost (added from `yunohost service add`)
|
# Remove the service from the list of services known by YunoHost (added from `yunohost service add`)
|
||||||
if ynh_exec_warn_less yunohost service status $flohmarkt_filename >/dev/null; then
|
if ynh_hide_warnings yunohost service status $flohmarkt_filename >/dev/null; then
|
||||||
ynh_script_progression --message="Removing $app service integration..." --weight=2
|
ynh_script_progression "Removing $app service integration..."
|
||||||
ynh_remove_systemd_config --service=$flohmarkt_filename
|
ynh_config_remove_systemd$flohmarkt_filename
|
||||||
yunohost service remove $flohmarkt_filename
|
yunohost service remove $flohmarkt_filename
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# remove DB user for this instance - a new install will create a new user and permissions
|
# remove DB user for this instance - a new install will create a new user and permissions
|
||||||
ynh_script_progression --message="Removing couchdb user..." --weight=2
|
ynh_script_progression "Removing couchdb user..."
|
||||||
flohmarkt_ynh_delete_couchdb_user
|
flohmarkt_ynh_delete_couchdb_user
|
||||||
|
|
||||||
if [[ $YNH_APP_PURGE -eq 1 ]]; then
|
if [[ $YNH_APP_PURGE -eq 1 ]]; then
|
||||||
ynh_script_progression --message="Purging couchdb database ..." --weight=2
|
ynh_script_progression "Purging couchdb database ..."
|
||||||
# remove DB
|
# remove DB
|
||||||
flohmarkt_ynh_delete_couchdb_db
|
flohmarkt_ynh_delete_couchdb_db
|
||||||
# remove logfiles directory
|
# remove logfiles directory
|
||||||
ynh_script_progression --message="Purging logfiles..." --weight=2
|
ynh_script_progression "Purging logfiles..."
|
||||||
ynh_secure_remove --file="${flohmarkt_log_dir}"
|
ynh_safe_rm "${flohmarkt_log_dir}"
|
||||||
else
|
else
|
||||||
ynh_script_progression --message="Purge not selected - not deleting couchdb and logfiles..." --weight=1
|
ynh_script_progression "Purge not selected - not deleting couchdb and logfiles..."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Remove the app-specific logrotate config
|
# Remove the app-specific logrotate config
|
||||||
ynh_script_progression --message="Removing logrotate configuration..." --weight=2
|
ynh_script_progression "Removing logrotate configuration..."
|
||||||
ynh_remove_logrotate
|
ynh_config_remove_logrotate
|
||||||
|
|
||||||
# Remove the dedicated NGINX config
|
# Remove the dedicated NGINX config
|
||||||
ynh_script_progression --message="Removing nginx configuration..." --weight=2
|
ynh_script_progression "Removing nginx configuration..."
|
||||||
ynh_remove_nginx_config
|
ynh_config_remove_nginx
|
||||||
|
|
||||||
# Remove the dedicated Fail2Ban config
|
# Remove the dedicated Fail2Ban config
|
||||||
ynh_script_progression --message="Removing fail2ban configuration..." --weight=2
|
ynh_script_progression "Removing fail2ban configuration..."
|
||||||
ynh_remove_fail2ban_config
|
ynh_config_remove_fail2ban
|
||||||
|
|
||||||
# remove systemd service
|
# remove systemd service
|
||||||
ynh_script_progression --message="Removing systemd.service directory..." --weight=2
|
ynh_script_progression "Removing systemd.service directory..."
|
||||||
ynh_remove_systemd_config
|
ynh_config_remove_systemd
|
||||||
|
|
||||||
# remove symlinks
|
# remove symlinks
|
||||||
ynh_script_progression --message="Removing symlinks..." --weight=2
|
ynh_script_progression "Removing symlinks..."
|
||||||
# no ynh_secure_remove:
|
# no ynh_safe_rm :
|
||||||
|
|
||||||
# https://codeberg.org/flohmarkt/flohmarkt_ynh/issues/52
|
# https://codeberg.org/flohmarkt/flohmarkt_ynh/issues/52
|
||||||
rm "$flohmarkt_sym_install" || true
|
rm "$flohmarkt_sym_install" || true
|
||||||
rm "$flohmarkt_sym_data_dir" || true
|
rm "$flohmarkt_sym_data_dir" || true
|
||||||
|
@ -70,4 +65,4 @@ rm "$flohmarkt_sym_log_dir" || true
|
||||||
# END OF SCRIPT
|
# END OF SCRIPT
|
||||||
#=================================================
|
#=================================================
|
||||||
|
|
||||||
ynh_script_progression --message="Removal of $app completed" --last
|
ynh_script_progression "Removal of $app completed"
|
||||||
|
|
|
@ -4,42 +4,43 @@ source ../settings/scripts/_common.sh
|
||||||
source /usr/share/yunohost/helpers
|
source /usr/share/yunohost/helpers
|
||||||
|
|
||||||
# reinstall couchdb
|
# reinstall couchdb
|
||||||
ynh_script_progression --message="Reinstalling couchdb..." --weight=40
|
ynh_script_progression "Reinstalling couchdb..."
|
||||||
flohmarkt_ynh_up_inst_couchdb
|
flohmarkt_ynh_up_inst_couchdb
|
||||||
|
|
||||||
# add couchdb configuration
|
# add couchdb configuration
|
||||||
if ! [[ -e /opt/couchdb/etc/local.d/05-flohmarkt.ini ]]; then
|
if ! [[ -e /opt/couchdb/etc/local.d/05-flohmarkt.ini ]]; then
|
||||||
ynh_script_progression --message="Adding a configuration file..." --weight=2
|
ynh_script_progression "Adding $app's configuration..."
|
||||||
|
|
||||||
flohmarkt_ynh_stop_couchdb
|
flohmarkt_ynh_stop_couchdb
|
||||||
|
|
||||||
ynh_restore_file --origin_path="/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
ynh_restore "/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
||||||
chown root:couchdb /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
chown root:couchdb /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
||||||
chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
||||||
|
|
||||||
ynh_script_progression --message="Starting couchdb..." --weight=4
|
ynh_script_progression "Starting couchdb..."
|
||||||
flohmarkt_ynh_start_couchdb
|
flohmarkt_ynh_start_couchdb
|
||||||
else
|
else
|
||||||
ynh_script_progression --message="CouchDB configuration file already exists." --weight=1
|
ynh_script_progression "CouchDB configuration file already exists."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# if exists rename existing couchdb
|
# if exists rename existing couchdb
|
||||||
ynh_script_progression --message="Check if old database exists..." --weight=1
|
ynh_script_progression "Check if old database exists..."
|
||||||
if flohmarkt_ynh_exists_couchdb_db; then
|
if flohmarkt_ynh_exists_couchdb_db; then
|
||||||
|
|
||||||
flohmarkt_ynh_backup_old_couchdb
|
flohmarkt_ynh_backup_old_couchdb
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# restore couchdb from json
|
# restore couchdb from json
|
||||||
ynh_script_progression --message="Importing couchdb from json backup..." --weight=8
|
ynh_script_progression "Importing couchdb from json backup..."
|
||||||
flohmarkt_ynh_restore_couchdb
|
flohmarkt_ynh_restore_couchdb
|
||||||
|
|
||||||
# RESTORE THE APP MAIN DIR
|
# RESTORE THE APP MAIN DIR
|
||||||
ynh_script_progression --message="Restoring the app main directory..." --weight=10
|
ynh_script_progression "Restoring the app main directory..."
|
||||||
ynh_restore_file --origin_path="$flohmarkt_install"
|
ynh_restore "$flohmarkt_install"
|
||||||
|
|
||||||
# RESTORE THE DATA DIRECTORY
|
# RESTORE THE DATA DIRECTORY
|
||||||
ynh_script_progression --message="Restoring the data directory..." --weight=1
|
ynh_script_progression "Restoring the data directory..."
|
||||||
ynh_restore_file --origin_path="$flohmarkt_data_dir" --not_mandatory
|
ynh_restore "$flohmarkt_data_dir" || true
|
||||||
mkdir -p $data_dir
|
mkdir -p $data_dir
|
||||||
|
|
||||||
# restore logfiles
|
# restore logfiles
|
||||||
|
@ -48,44 +49,44 @@ mkdir -p $data_dir
|
||||||
# directory and file so that the systemd.service can redirect STDOUT to the file.
|
# directory and file so that the systemd.service can redirect STDOUT to the file.
|
||||||
# If the logfile(or maybe just -directory?) is missing the service will not start
|
# If the logfile(or maybe just -directory?) is missing the service will not start
|
||||||
# on a fresh install, because directory and/or file do not exist.
|
# on a fresh install, because directory and/or file do not exist.
|
||||||
ynh_script_progression --message="Restoring log directory and logfiles..." --weight=1
|
ynh_script_progression "Restoring log directory and logfiles..."
|
||||||
ynh_restore_file --origin_path="$flohmarkt_log_dir" --not_mandatory
|
ynh_restore "$flohmarkt_log_dir" || true
|
||||||
mkdir -p -m755 "$flohmarkt_log_dir"
|
mkdir -p -m755 "$flohmarkt_log_dir"
|
||||||
touch "$flohmarkt_logfile"
|
touch "$flohmarkt_logfile"
|
||||||
# logfile contains possibly the secret setup URL
|
# logfile contains possibly the secret setup URL
|
||||||
chmod 640 "$flohmarkt_logfile"
|
chmod 640 "$flohmarkt_logfile"
|
||||||
|
|
||||||
# RESTORE FAIL2BAN CONFIGURATION
|
# RESTORE FAIL2BAN CONFIGURATION
|
||||||
ynh_script_progression --message="Restoring the Fail2Ban configuration..." --weight=2
|
ynh_script_progression "Restoring the Fail2Ban configuration..."
|
||||||
ynh_restore_file --origin_path="/etc/fail2ban/jail.d/$app.conf"
|
ynh_restore "/etc/fail2ban/jail.d/$app.conf"
|
||||||
ynh_restore_file --origin_path="/etc/fail2ban/filter.d/$app.conf"
|
ynh_restore "/etc/fail2ban/filter.d/$app.conf"
|
||||||
ynh_systemd_action --action=restart --service_name=fail2ban
|
ynh_systemctl --action=restart --service=fail2ban
|
||||||
|
|
||||||
# RESTORE THE NGINX CONFIGURATION
|
# RESTORE THE NGINX CONFIGURATION
|
||||||
ynh_script_progression --message="Restoring the NGINX web server configuration..." --weight=1
|
ynh_script_progression "Restoring the NGINX web server configuration..."
|
||||||
ynh_restore_file --origin_path="/etc/nginx/conf.d/$domain.d/$app.conf"
|
ynh_restore "/etc/nginx/conf.d/$domain.d/$app.conf"
|
||||||
|
|
||||||
# RESTORE THE LOGROTATE CONFIGURATION
|
# RESTORE THE LOGROTATE CONFIGURATION
|
||||||
ynh_script_progression --message="Restoring the logrotate configuration..." --weight=1
|
ynh_script_progression "Restoring the logrotate configuration..."
|
||||||
ynh_restore_file --origin_path="/etc/logrotate.d/$app"
|
ynh_restore "/etc/logrotate.d/$app"
|
||||||
|
|
||||||
# restore flohmarkt systemd service and integrate service into yunohost
|
# restore flohmarkt systemd service and integrate service into yunohost
|
||||||
ynh_script_progression --message="Restoring flohmarkt.service and integrating service into YunoHost..." --weight=1
|
ynh_script_progression "Restoring flohmarkt.service and integrating service into YunoHost..."
|
||||||
ynh_restore_file --origin_path="/etc/systemd/system/$flohmarkt_filename.service"
|
ynh_restore "/etc/systemd/system/$flohmarkt_filename.service"
|
||||||
ynh_systemd_action --action=enable --service_name=$flohmarkt_filename
|
ynh_systemctl --action=enable --service=$flohmarkt_filename
|
||||||
yunohost service add $flohmarkt_filename --description="A decentral federated small advertisement platform" --log="$flohmarkt_logfile"
|
yunohost service add $flohmarkt_filename --description="A decentral federated small advertisement platform" --log="$flohmarkt_logfile"
|
||||||
flohmarkt_ynh_start_service
|
flohmarkt_ynh_start_service
|
||||||
|
|
||||||
# RELOAD NGINX
|
# RELOAD NGINX
|
||||||
ynh_script_progression --message="Reloading NGINX web server..." --weight=1
|
ynh_script_progression "Reloading NGINX web server..."
|
||||||
ynh_systemd_action --service_name=nginx --action=reload
|
ynh_systemctl --service=nginx --action=reload
|
||||||
|
|
||||||
# create symlinks
|
# create symlinks
|
||||||
ynh_script_progression --message="Creating symlinks..." --weight=1
|
ynh_script_progression "Creating symlinks..."
|
||||||
flohmarkt_ynh_create_symlinks
|
flohmarkt_ynh_create_symlinks
|
||||||
|
|
||||||
# restore cronjob file for urlwatch
|
# restore cronjob file for urlwatch
|
||||||
ynh_script_progression --message="Restoring cronjob for urlwatch..." --weight=1
|
ynh_script_progression "Restoring cronjob for urlwatch..."
|
||||||
ynh_restore_file --origin_path="${flohmarkt_cron_job}"
|
ynh_restore "${flohmarkt_cron_job}"
|
||||||
|
|
||||||
ynh_script_progression --message="Restoration completed for $app" --last
|
ynh_script_progression "Restoration completed for $app"
|
||||||
|
|
|
@ -7,9 +7,8 @@ source /usr/share/yunohost/helpers
|
||||||
# UPGRADE_APP if the upstream app version has changed
|
# UPGRADE_APP if the upstream app version has changed
|
||||||
# DOWNGRADE
|
# DOWNGRADE
|
||||||
# UPGRADE_SAME
|
# UPGRADE_SAME
|
||||||
upgrade_type=$(ynh_check_app_version_changed)
|
|
||||||
|
|
||||||
ynh_script_progression --message="Stopping flohmarkt and CouchDB..." --weight=5
|
ynh_script_progression "Stopping flohmarkt and CouchDB..."
|
||||||
# stop flohmarkt
|
# stop flohmarkt
|
||||||
flohmarkt_ynh_stop_service
|
flohmarkt_ynh_stop_service
|
||||||
# stop couchdb
|
# stop couchdb
|
||||||
|
@ -18,76 +17,76 @@ flohmarkt_ynh_stop_couchdb
|
||||||
# Upgrade ynh4 → ynh5, change of paths and filenames
|
# Upgrade ynh4 → ynh5, change of paths and filenames
|
||||||
# https://matrix.to/#/!PauySEslPVuJCJCwlZ:matrix.org/$auU_rSL6MACt9wkyFGlCQbO8ivFlU0ztYW74TimZdcM?via=matrix.org&via=aria-net.org&via=sans-nuage.fr
|
# https://matrix.to/#/!PauySEslPVuJCJCwlZ:matrix.org/$auU_rSL6MACt9wkyFGlCQbO8ivFlU0ztYW74TimZdcM?via=matrix.org&via=aria-net.org&via=sans-nuage.fr
|
||||||
# and follow-ups
|
# and follow-ups
|
||||||
if ynh_compare_current_package_version --comparison lt --version 0.0~ynh5 &&
|
if ynh_app_upgrading_from_version_before 0.0~ynh5 &&
|
||||||
( [[ "$upgrade_type" == UPGRADE_PACKAGE ]] || [[ "$upgrade_type" == UPGRADE_APP ]] )
|
( [[ "$upgrade_type" == UPGRADE_PACKAGE ]] || [[ "$upgrade_type" == UPGRADE_APP ]] )
|
||||||
then
|
then
|
||||||
flohmarkt_ynh_upgrade_path_ynh5
|
flohmarkt_ynh_upgrade_path_ynh5
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# upgrade couchdb
|
# upgrade couchdb
|
||||||
ynh_script_progression --message="Upgrading CouchDB..." --weight=50
|
ynh_script_progression "Upgrading CouchDB..."
|
||||||
flohmarkt_ynh_up_inst_couchdb
|
flohmarkt_ynh_up_inst_couchdb
|
||||||
|
|
||||||
# stop couchdb
|
# stop couchdb
|
||||||
ynh_script_progression --message="Stop couchdb before updating configuration file..." --weight=1
|
ynh_script_progression "Stop couchdb before updating configuration file..."
|
||||||
flohmarkt_ynh_stop_couchdb
|
flohmarkt_ynh_stop_couchdb
|
||||||
|
|
||||||
# upgrade couchdb config
|
# upgrade couchdb config
|
||||||
ynh_script_progression --message="Updating couchdb configuration file..." --weight=1
|
ynh_script_progression "Updating couchdb configuration file..."
|
||||||
ynh_add_config --template="../conf/05-flohmarkt.ini" --destination="/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
ynh_config_add --template="05-flohmarkt.ini" --destination="/opt/couchdb/etc/local.d/05-flohmarkt.ini"
|
||||||
chown root:couchdb /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
chown root:couchdb /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
||||||
chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
chmod 640 /opt/couchdb/etc/local.d/05-flohmarkt.ini
|
||||||
|
|
||||||
# start couchdb
|
# start couchdb
|
||||||
ynh_script_progression --message="Starting couchdb..." --weight=1
|
ynh_script_progression "Starting couchdb..."
|
||||||
flohmarkt_ynh_start_couchdb
|
flohmarkt_ynh_start_couchdb
|
||||||
|
|
||||||
# install upgrade for flohmarkt
|
# install upgrade for flohmarkt
|
||||||
ynh_script_progression --message="Upgrading flohmarkt..." --weight=4
|
ynh_script_progression "Upgrading flohmarkt..."
|
||||||
ynh_setup_source --dest_dir="$flohmarkt_app_dir/"
|
ynh_setup_source --dest_dir="$flohmarkt_app_dir/"
|
||||||
|
|
||||||
ynh_script_progression --message="Upgrading flohmarkt python dependencies..." --weight=6
|
ynh_script_progression "Upgrading flohmarkt python dependencies..."
|
||||||
# upgrade python environment / install new dependencies
|
# upgrade python environment / install new dependencies
|
||||||
flohmarkt_ynh_venv_upgrade
|
flohmarkt_ynh_venv_upgrade
|
||||||
flohmarkt_ynh_venv_requirements
|
flohmarkt_ynh_venv_requirements
|
||||||
|
|
||||||
# upgrade flohmarkt.conf
|
# upgrade flohmarkt.conf
|
||||||
ynh_script_progression --message="Upgrading flohmarkt configuration..." --weight=1
|
ynh_script_progression "Upgrading flohmarkt configuration..."
|
||||||
ynh_add_config --template="../conf/flohmarkt.conf" --destination="$flohmarkt_app_dir/flohmarkt.conf"
|
ynh_config_add --template="flohmarkt.conf" --destination="$flohmarkt_app_dir/flohmarkt.conf"
|
||||||
|
|
||||||
ynh_script_progression --message="Upgrading flohmarkt couchdb..." --weight=10
|
ynh_script_progression "Upgrading flohmarkt couchdb..."
|
||||||
flohmarkt_ynh_initialize_couchdb
|
flohmarkt_ynh_initialize_couchdb
|
||||||
|
|
||||||
# set file permissions for install dir
|
# set file permissions for install dir
|
||||||
flohmarkt_ynh_set_permission
|
flohmarkt_ynh_set_permission
|
||||||
|
|
||||||
# systemd service upgrade
|
# systemd service upgrade
|
||||||
ynh_script_progression --message="Upgrading flohmarkt systemd service..." --weight=1
|
ynh_script_progression "Upgrading flohmarkt systemd service..."
|
||||||
ynh_add_systemd_config --service=$flohmarkt_filename
|
ynh_config_add_systemd --service=$flohmarkt_filename
|
||||||
# INTEGRATE SERVICE IN YUNOHOST
|
# INTEGRATE SERVICE IN YUNOHOST
|
||||||
ynh_script_progression --message="Integrating service in YunoHost..." --weight=2
|
ynh_script_progression "Integrating service in YunoHost..."
|
||||||
yunohost service add $flohmarkt_filename --description="A decentral federated small advertisement platform" --log="$flohmarkt_logfile"
|
yunohost service add $flohmarkt_filename --description="A decentral federated small advertisement platform" --log="$flohmarkt_logfile"
|
||||||
|
|
||||||
# upgrade logrotate
|
# upgrade logrotate
|
||||||
ynh_script_progression --message="Upgrading logrotate configuration..." --weight=1
|
ynh_script_progression "Upgrading logrotate configuration..."
|
||||||
# Use logrotate to manage app-specific logfile(s)
|
# Use logrotate to manage app-specific logfile(s)
|
||||||
ynh_use_logrotate --non-append
|
ynh_config_add_logrotate
|
||||||
|
|
||||||
# upgrade nginx configuration
|
# upgrade nginx configuration
|
||||||
ynh_script_progression --message="Upgrading NGINX web server configuration..." --weight=2
|
ynh_script_progression "Upgrading NGINX web server configuration..."
|
||||||
ynh_add_nginx_config
|
ynh_config_add_nginx
|
||||||
|
|
||||||
# UPGRADE FAIL2BAN
|
# UPGRADE FAIL2BAN
|
||||||
ynh_script_progression --message="Reconfiguring Fail2Ban..." --weight=3
|
ynh_script_progression "Reconfiguring Fail2Ban..."
|
||||||
ynh_add_fail2ban_config --logpath="$flohmarkt_logfile" --failregex='INFO: +<HOST>:\d+ - "POST /token HTTP/\d+\.\d+" 403 Forbidden' --max_retry=5
|
ynh_config_add_fail2ban --logpath="$flohmarkt_logfile" --failregex='INFO: +<HOST>:\d+ - "POST /token HTTP/\d+\.\d+" 403 Forbidden'
|
||||||
|
|
||||||
# start flohmarkt
|
# start flohmarkt
|
||||||
ynh_script_progression --message="Starting flohmarkt..." --weight=3
|
ynh_script_progression "Starting flohmarkt..."
|
||||||
flohmarkt_ynh_start_service
|
flohmarkt_ynh_start_service
|
||||||
|
|
||||||
# check if admin_mail is already set and if not use a default
|
# check if admin_mail is already set and if not use a default
|
||||||
if ! [[ -v admin_mail ]] || [[ -z "${admin_mail}" ]]; then
|
if ! [[ -v admin_mail ]] || [[ -z "${admin_mail}" ]]; then
|
||||||
ynh_print_warn --message="new setting admin_mail - trying to set a default"
|
ynh_print_warn "new setting admin_mail - trying to set a default"
|
||||||
# try to read admin email address from flohmarkt installation
|
# try to read admin email address from flohmarkt installation
|
||||||
admin_mail=$( flohmarkt_ynh_local_curl -n -m POST -u admin -p "$password_couchdb_admin" \
|
admin_mail=$( flohmarkt_ynh_local_curl -n -m POST -u admin -p "$password_couchdb_admin" \
|
||||||
-H "Accept: application/json" -H "Content-Type: application/json" -s none \
|
-H "Accept: application/json" -H "Content-Type: application/json" -s none \
|
||||||
|
@ -99,12 +98,12 @@ if ! [[ -v admin_mail ]] || [[ -z "${admin_mail}" ]]; then
|
||||||
# use yunohost admin group
|
# use yunohost admin group
|
||||||
admin_mail="admin@$(yunohost domain main-domain | cut -d' ' -f2)"
|
admin_mail="admin@$(yunohost domain main-domain | cut -d' ' -f2)"
|
||||||
fi
|
fi
|
||||||
ynh_print_warn --message="using ${admin_mail} for new setting admin_mail"
|
ynh_print_warn "using ${admin_mail} for new setting admin_mail"
|
||||||
ynh_app_setting_set --app=$app --key=admin_mail --value="${admin_mail}"
|
ynh_app_setting_set --key=admin_mail --value="${admin_mail}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# upgrade urlwatch configuration
|
# upgrade urlwatch configuration
|
||||||
ynh_script_progression --message="Upgrade urlwatch configuration..." --weight=1
|
ynh_script_progression "Upgrade urlwatch configuration..."
|
||||||
flohmarkt_ynh_urlwatch_cron
|
flohmarkt_ynh_urlwatch_cron
|
||||||
|
|
||||||
ynh_script_progression --message="Upgrade of $app completed" --last
|
ynh_script_progression "Upgrade of $app completed"
|
||||||
|
|
Loading…
Reference in a new issue