2018-04-17 00:02:25 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
2019-04-03 14:35:09 +02:00
|
|
|
#=================================================
|
|
|
|
# COMMON VARIABLES
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
# dependencies used by the app
|
|
|
|
pkg_dependencies="build-essential curl ffmpeg \
|
|
|
|
libjpeg-dev libmagic-dev libpq-dev postgresql postgresql-contrib python3-dev virtualenv \
|
|
|
|
redis-server libldap2-dev libsasl2-dev \
|
|
|
|
`# add arm support` \
|
|
|
|
zlib1g-dev libffi-dev libssl-dev"
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# PERSONAL HELPERS
|
|
|
|
#=================================================
|
|
|
|
|
2019-02-17 08:06:04 +01:00
|
|
|
# funkwhale needs edits to the domain config file
|
|
|
|
# this function removes funkwhale specifics
|
|
|
|
funkwhale_nginx_domain_cleaning() {
|
|
|
|
local line
|
|
|
|
local tempFile
|
|
|
|
local nginxConf
|
|
|
|
|
|
|
|
nginxConf="/etc/nginx/conf.d/$domain.conf"
|
|
|
|
tempFile="$nginxConf.temp"
|
|
|
|
|
|
|
|
line=$(sed -n '/server /=' "$nginxConf" | head -n 1)
|
|
|
|
|
|
|
|
tail -n +"$line" "$nginxConf" > "$tempFile"
|
|
|
|
mv "$tempFile" "$nginxConf"
|
|
|
|
}
|
|
|
|
|
|
|
|
# funkwhale needs edits to the domain config file
|
|
|
|
# this function adds funkwhale specifics
|
|
|
|
funkwhale_nginx_domain_configure() {
|
|
|
|
local tempFile
|
|
|
|
local nginxConf
|
|
|
|
|
|
|
|
nginxConf="/etc/nginx/conf.d/$domain.conf"
|
|
|
|
tempFile="$nginxConf.temp"
|
|
|
|
|
|
|
|
echo "
|
|
|
|
# required for websocket support
|
|
|
|
map \$http_upgrade \$connection_upgrade {
|
|
|
|
default upgrade;
|
|
|
|
'' close;
|
|
|
|
}
|
|
|
|
" | cat - "$nginxConf" > "$tempFile"
|
|
|
|
mv "$tempFile" "$nginxConf"
|
|
|
|
}
|
|
|
|
|
2019-04-03 14:35:09 +02:00
|
|
|
#=================================================
|
|
|
|
# EXPERIMENTAL HELPERS
|
|
|
|
#=================================================
|
|
|
|
|
2018-05-12 23:57:20 +02:00
|
|
|
#=================================================
|
|
|
|
#
|
|
|
|
# Redis HELPERS
|
|
|
|
#
|
|
|
|
# Point of contact : Jean-Baptiste Holcroft <jean-baptiste@holcroft.fr>
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
# get the first available redis database
|
2018-04-17 00:02:25 +02:00
|
|
|
#
|
2018-05-12 23:57:20 +02:00
|
|
|
# usage: ynh_redis_get_free_db
|
|
|
|
# | returns: the database number to use
|
|
|
|
ynh_redis_get_free_db() {
|
2018-05-20 19:58:33 +02:00
|
|
|
local result max db
|
2018-05-12 23:57:20 +02:00
|
|
|
result=$(redis-cli INFO keyspace)
|
|
|
|
|
2018-05-20 19:58:33 +02:00
|
|
|
# get the num
|
|
|
|
max=$(cat /etc/redis/redis.conf | grep ^databases | grep -Eow "[0-9]+")
|
|
|
|
|
2018-05-12 23:57:20 +02:00
|
|
|
db=0
|
|
|
|
# default Debian setting is 15 databases
|
2018-05-20 19:58:33 +02:00
|
|
|
for i in $(seq 0 "$max")
|
2018-05-12 23:57:20 +02:00
|
|
|
do
|
|
|
|
if ! echo "$result" | grep -q "db$i"
|
|
|
|
then
|
|
|
|
db=$i
|
|
|
|
break 1
|
|
|
|
fi
|
2018-06-03 15:44:13 +02:00
|
|
|
db=-1
|
2018-05-12 23:57:20 +02:00
|
|
|
done
|
2018-04-17 00:02:25 +02:00
|
|
|
|
2018-05-20 19:58:33 +02:00
|
|
|
test "$db" -eq -1 && ynh_die "No available Redis databases..."
|
|
|
|
|
2018-05-12 23:57:20 +02:00
|
|
|
echo "$db"
|
2018-04-17 00:02:25 +02:00
|
|
|
}
|
|
|
|
|
2018-05-12 23:57:20 +02:00
|
|
|
# Create a master password and set up global settings
|
|
|
|
# Please always call this script in install and restore scripts
|
|
|
|
#
|
|
|
|
# usage: ynh_redis_remove_db database
|
|
|
|
# | arg: database - the database to erase
|
|
|
|
ynh_redis_remove_db() {
|
|
|
|
local db=$1
|
|
|
|
redis-cli -n "$db" flushall
|
|
|
|
}
|
2018-04-17 00:02:25 +02:00
|
|
|
|
|
|
|
# Send an email to inform the administrator
|
|
|
|
#
|
|
|
|
# usage: ynh_send_readme_to_admin app_message [recipients]
|
|
|
|
# | arg: app_message - The message to send to the administrator.
|
|
|
|
# | arg: recipients - The recipients of this email. Use spaces to separate multiples recipients. - default: root
|
|
|
|
# example: "root admin@domain"
|
|
|
|
# If you give the name of a YunoHost user, ynh_send_readme_to_admin will find its email adress for you
|
|
|
|
# example: "root admin@domain user1 user2"
|
|
|
|
ynh_send_readme_to_admin() {
|
2018-07-10 23:54:58 +02:00
|
|
|
local app_message="${1:-...No specific information...}"
|
2018-04-17 00:02:25 +02:00
|
|
|
local recipients="${2:-root}"
|
|
|
|
|
|
|
|
# Retrieve the email of users
|
|
|
|
find_mails () {
|
|
|
|
local list_mails="$1"
|
|
|
|
local mail
|
|
|
|
local recipients=" "
|
|
|
|
# Read each mail in argument
|
|
|
|
for mail in $list_mails
|
|
|
|
do
|
|
|
|
# Keep root or a real email address as it is
|
|
|
|
if [ "$mail" = "root" ] || echo "$mail" | grep --quiet "@"
|
|
|
|
then
|
|
|
|
recipients="$recipients $mail"
|
|
|
|
else
|
|
|
|
# But replace an user name without a domain after by its email
|
|
|
|
if mail=$(ynh_user_get_info "$mail" "mail" 2> /dev/null)
|
|
|
|
then
|
|
|
|
recipients="$recipients $mail"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
echo "$recipients"
|
|
|
|
}
|
|
|
|
recipients=$(find_mails "$recipients")
|
|
|
|
|
|
|
|
local mail_subject="☁️🆈🅽🅷☁️: \`$app\` was just installed!"
|
|
|
|
|
|
|
|
local mail_message="This is an automated message from your beloved YunoHost server.
|
2018-07-10 23:54:58 +02:00
|
|
|
|
|
|
|
Specific information for the application $app.
|
|
|
|
|
2018-04-17 00:02:25 +02:00
|
|
|
$app_message
|
2018-07-10 23:54:58 +02:00
|
|
|
|
2018-04-17 00:02:25 +02:00
|
|
|
---
|
|
|
|
Automatic diagnosis data from YunoHost
|
2018-07-10 23:54:58 +02:00
|
|
|
|
2018-04-17 00:02:25 +02:00
|
|
|
$(yunohost tools diagnosis | grep -B 100 "services:" | sed '/services:/d')"
|
|
|
|
|
2018-07-10 23:54:58 +02:00
|
|
|
# Define binary to use for mail command
|
|
|
|
if [ -e /usr/bin/bsd-mailx ]
|
|
|
|
then
|
|
|
|
local mail_bin=/usr/bin/bsd-mailx
|
|
|
|
else
|
|
|
|
local mail_bin=/usr/bin/mail.mailutils
|
|
|
|
fi
|
|
|
|
|
2018-04-17 00:02:25 +02:00
|
|
|
# Send the email to the recipients
|
2018-07-10 23:54:58 +02:00
|
|
|
echo "$mail_message" | $mail_bin -a "Content-Type: text/plain; charset=UTF-8" -s "$mail_subject" "$recipients"
|
2018-04-17 00:02:25 +02:00
|
|
|
}
|
2018-07-10 23:54:58 +02:00
|
|
|
|
2018-11-25 21:54:18 +01:00
|
|
|
#=================================================
|
|
|
|
# fail2ban helpers
|
|
|
|
# taken from https://github.com/YunoHost-Apps/shaarli_ynh
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
# Create a dedicated fail2ban config (jail and filter conf files)
|
|
|
|
#
|
|
|
|
# usage: ynh_add_fail2ban_config log_file filter [max_retry [ports]]
|
|
|
|
# | arg: log_file - Log file to be checked by fail2ban
|
|
|
|
# | arg: failregex - Failregex to be looked for by fail2ban
|
|
|
|
# | arg: max_retry - Maximum number of retries allowed before banning IP address - default: 3
|
|
|
|
# | arg: ports - Ports blocked for a banned IP address - default: http,https
|
|
|
|
ynh_add_fail2ban_config () {
|
|
|
|
local logpath
|
|
|
|
local failregex
|
|
|
|
local max_retry
|
|
|
|
local ports
|
|
|
|
|
|
|
|
logpath=$1
|
|
|
|
failregex=$2
|
|
|
|
max_retry=${3:-3}
|
|
|
|
ports=${4:-http,https}
|
|
|
|
|
|
|
|
test -n "$logpath" || ynh_die "ynh_add_fail2ban_config expects a logfile path as first argument and received nothing."
|
|
|
|
test -n "$failregex" || ynh_die "ynh_add_fail2ban_config expects a failure regex as second argument and received nothing."
|
|
|
|
|
|
|
|
finalfail2banjailconf="/etc/fail2ban/jail.d/$app.conf"
|
|
|
|
finalfail2banfilterconf="/etc/fail2ban/filter.d/$app.conf"
|
|
|
|
ynh_backup_if_checksum_is_different "$finalfail2banjailconf" 1
|
|
|
|
ynh_backup_if_checksum_is_different "$finalfail2banfilterconf" 1
|
|
|
|
|
|
|
|
sudo tee "$finalfail2banjailconf" <<EOF
|
|
|
|
[$app]
|
|
|
|
enabled = true
|
|
|
|
port = $ports
|
|
|
|
filter = $app
|
|
|
|
logpath = $logpath
|
|
|
|
maxretry = $max_retry
|
|
|
|
EOF
|
|
|
|
|
|
|
|
sudo tee "$finalfail2banfilterconf" <<EOF
|
|
|
|
[INCLUDES]
|
|
|
|
before = common.conf
|
|
|
|
[Definition]
|
|
|
|
failregex = $failregex
|
|
|
|
ignoreregex =
|
|
|
|
EOF
|
|
|
|
|
|
|
|
ynh_store_file_checksum "$finalfail2banjailconf"
|
|
|
|
ynh_store_file_checksum "$finalfail2banfilterconf"
|
|
|
|
|
|
|
|
systemctl restart fail2ban
|
|
|
|
local fail2ban_error="$(journalctl -u fail2ban | tail -n50 | grep "WARNING.*$app.*")"
|
|
|
|
if [ -n "$fail2ban_error" ]
|
|
|
|
then
|
|
|
|
echo "[ERR] Fail2ban failed to load the jail for $app" >&2
|
|
|
|
echo "WARNING${fail2ban_error#*WARNING}" >&2
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# Remove the dedicated fail2ban config (jail and filter conf files)
|
|
|
|
#
|
|
|
|
# usage: ynh_remove_fail2ban_config
|
|
|
|
ynh_remove_fail2ban_config () {
|
|
|
|
ynh_secure_remove "/etc/fail2ban/jail.d/$app.conf"
|
|
|
|
ynh_secure_remove "/etc/fail2ban/filter.d/$app.conf"
|
|
|
|
systemctl reload fail2ban
|
2019-04-03 14:35:09 +02:00
|
|
|
}
|