331 lines
10 KiB
Bash
Executable File
331 lines
10 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
#Ki: François
|
|
#Kan: 2021
|
|
#Koi: gestion dockers
|
|
|
|
#15/01/2025: Dernière modif by fab: ne pas redémarrer Traefik en cas de créaio d'orga
|
|
|
|
|
|
# En cas d'absence de postfix, il faut lancer :
|
|
# docker network create postfix_mailNet
|
|
|
|
# démare/arrête un compose
|
|
# sauvegarde la base de données d'un compose
|
|
# met à jours les paramètres de configuration du mandataire (proxy)
|
|
|
|
KAZ_ROOT=$(cd "$(dirname $0)/.."; pwd)
|
|
. "${KAZ_ROOT}/bin/.commonFunctions.sh"
|
|
setKazVars
|
|
|
|
cd "${KAZ_BIN_DIR}"
|
|
PATH_SAUVE="/home/sauve/"
|
|
export SIMU=""
|
|
|
|
declare -a availableComposesNoNeedMail availableMailComposes availableComposesNeedMail availableProxyComposes availableOrga
|
|
availableComposesNoNeedMail=($(getList "${KAZ_CONF_DIR}/container-withoutMail.list"))
|
|
availableMailComposes=($(getList "${KAZ_CONF_DIR}/container-mail.list"))
|
|
availableComposesNeedMail=($(getList "${KAZ_CONF_DIR}/container-withMail.list"))
|
|
availableProxyComposes=($(getList "${KAZ_CONF_DIR}/container-proxy.list"))
|
|
availableOrga=($(getList "${KAZ_CONF_DIR}/container-orga.list"))
|
|
availableComposesNeedMail+=( "${availableOrga[@]}" )
|
|
|
|
knownedComposes+=( ${availableMailComposes[@]} )
|
|
knownedComposes+=( ${availableProxyComposes[@]} )
|
|
knownedComposes+=( ${availableComposesNoNeedMail[@]} )
|
|
knownedComposes+=( ${availableComposesNeedMail[@]} )
|
|
|
|
usage () {
|
|
echo "Usage: $0 [-n] {status|start|stop|save} [compose]..."
|
|
echo " -n : simulation"
|
|
echo " status : docker-compose status (default all compose available)"
|
|
echo " start : start composes (default all compose validate)"
|
|
echo " stop : stop composes (default all compose enable)"
|
|
echo " save : save all known database"
|
|
echo " [compose] : in ${knownedComposes[@]}"
|
|
exit 1
|
|
}
|
|
|
|
doCompose () {
|
|
# $1 dans ("up -d" "down")
|
|
# $2 nom du répertoire du compose
|
|
echo "compose: $1 $2"
|
|
${SIMU} cd "${KAZ_COMP_DIR}/$2"
|
|
if [ ! -h .env ] ; then
|
|
echo "create .env in $2"
|
|
${SIMU} ln -fs ../../config/dockers.env .env
|
|
fi
|
|
${SIMU} docker-compose $1
|
|
|
|
if [ "$2" = "cachet" ] && [ "$1" != "down" ]; then
|
|
NEW_KEY=$(cd "${KAZ_COMP_DIR}/$2" ; docker-compose logs | grep APP_KEY=base64: | sed "s/^.*'APP_KEY=\(base64:[^']*\)'.*$/\1/" | tail -1)
|
|
if [ -n "${NEW_KEY}" ]; then
|
|
printKazMsg "cachet key change"
|
|
# change key
|
|
${SIMU} sed -i \
|
|
-e 's%^\(\s*cachet_APP_KEY=\).*$%\1"'"${NEW_KEY}"'"%' \
|
|
"${KAZ_KEY_DIR}/SetAllPass.sh"
|
|
${SIMU} "${KAZ_BIN_DIR}/secretGen.sh"
|
|
# restart
|
|
${SIMU} docker-compose $1
|
|
fi
|
|
fi
|
|
}
|
|
|
|
doComposes () {
|
|
# $1 dans ("up -d" "down")
|
|
# $2+ nom des répertoires des composes
|
|
cmd=$1
|
|
shift
|
|
for compose in $@ ; do
|
|
doCompose "${cmd}" ${compose}
|
|
done
|
|
}
|
|
|
|
updateProxy () {
|
|
# $1 dans ("on" "off")
|
|
# $2 nom des répertoires des composes
|
|
cmd=$1
|
|
shift
|
|
echo "update proxy ${cmd}: $@"
|
|
date=$(date "+%x %X")
|
|
for compose in $@ ; do
|
|
composeFlag=${compose//-/_}
|
|
entry="proxy_${composeFlag}="
|
|
newline="${entry}${cmd} # update by $(basename $0) at ${date}"
|
|
if ! grep -q "proxy_${composeFlag}=" "${DOCKERS_ENV}" 2> /dev/null ; then
|
|
if [[ -n "${SIMU}" ]] ; then
|
|
echo "${newline} >> ${DOCKERS_ENV}"
|
|
else
|
|
echo "${newline}" >> "${DOCKERS_ENV}"
|
|
fi
|
|
else
|
|
${SIMU} sed -i \
|
|
-e "s|${entry}.*|${newline}|g" \
|
|
"${DOCKERS_ENV}"
|
|
fi
|
|
done
|
|
for item in "${availableProxyComposes[@]}"; do
|
|
${SIMU} ${KAZ_COMP_DIR}/${item}/proxy-gen.sh
|
|
done
|
|
}
|
|
|
|
saveDB () {
|
|
#attention, soucis avec l'option "-ti" qui ne semble pas rendre la main avec docker exec
|
|
|
|
containerName=$1
|
|
userName=$2
|
|
userPass=$3
|
|
dbName=$4
|
|
backName=$5
|
|
#on utilise mysqldump (v=10.5) et mariadb-dump (v>=11.4) pour être certain d'avoir un dump. L'une des 2 lignes fera une erreur
|
|
if [[ -n "${SIMU}" ]] ; then
|
|
${SIMU} "docker exec ${containerName} mysqldump --user=${userName} --password=${userPass} ${dbName} | gzip > $PATH_SAUVE${backName}.sql.gz"
|
|
${SIMU} "docker exec ${containerName} mariadb-dump --user=${userName} --password=${userPass} ${dbName} | gzip > $PATH_SAUVE${backName}.sql.gz"
|
|
else
|
|
docker exec ${containerName} mysqldump --user=${userName} --password=${userPass} ${dbName} | gzip > $PATH_SAUVE${backName}.sql.gz
|
|
docker exec ${containerName} mariadb-dump --user=${userName} --password=${userPass} ${dbName} | gzip > $PATH_SAUVE${backName}.sql.gz
|
|
fi
|
|
}
|
|
|
|
declare -a enableComposesNoNeedMail enableMailComposes enableComposesNeedMail enableProxyComposes
|
|
|
|
enableComposesNoNeedMail=()
|
|
enableMailComposes=()
|
|
enableComposesNeedMail=()
|
|
enableProxyComposes=()
|
|
|
|
startComposes () {
|
|
./kazDockerNet.sh add ${enableComposesNoNeedMail[@]} ${enableProxyComposes[@]} ${enableMailComposes[@]} ${enableComposesNeedMail[@]}
|
|
[ ${#enableComposesNeedMail[@]} -ne 0 ] && [[ ! "${enableMailComposes[@]}" =~ "postfix" ]] && ./kazDockerNet.sh add postfix
|
|
[[ "${enableComposesNeedMail[@]}" =~ "paheko" ]] && ${SIMU} ${KAZ_COMP_DIR}/paheko/paheko-gen.sh
|
|
doComposes "up -d" ${enableComposesNoNeedMail[@]}
|
|
doComposes "up -d" ${enableMailComposes[@]}
|
|
doComposes "up -d" ${enableComposesNeedMail[@]}
|
|
updateProxy "on" ${enableComposesNoNeedMail[@]} ${enableComposesNeedMail[@]}
|
|
#fab le 15/01/25: on ne redémarre plus le proxy avec container.sh
|
|
#doComposes "up -d" ${enableProxyComposes[@]}
|
|
for item in "${enableProxyComposes[@]}"; do
|
|
[[ -x "${KAZ_COMP_DIR}/${item}/reload.sh" ]] && ${SIMU} "${KAZ_COMP_DIR}/${item}/reload.sh"
|
|
done
|
|
if grep -q "^.s*proxy_web.s*=.s*on" "${DOCKERS_ENV}" 2> /dev/null ; then
|
|
${SIMU} ${KAZ_COMP_DIR}/web/web-gen.sh
|
|
fi
|
|
}
|
|
|
|
stopComposes () {
|
|
updateProxy "off" ${enableComposesNoNeedMail[@]} ${enableComposesNeedMail[@]}
|
|
doComposes "down" ${enableProxyComposes[@]}
|
|
doComposes "down" ${enableComposesNeedMail[@]}
|
|
doComposes "down" ${enableMailComposes[@]}
|
|
doComposes "down" ${enableComposesNoNeedMail[@]}
|
|
if grep -q "^.s*proxy_web.s*=.s*on" "${DOCKERS_ENV}" 2> /dev/null ; then
|
|
${SIMU} ${KAZ_COMP_DIR}/web/web-gen.sh
|
|
fi
|
|
}
|
|
|
|
statusComposes () {
|
|
${KAZ_ROOT}/bin/kazList.sh compose status ${enableMailComposes[@]} ${enableProxyComposes[@]} ${enableComposesNoNeedMail[@]} ${enableComposesNeedMail[@]}
|
|
}
|
|
|
|
saveComposes () {
|
|
. "${DOCKERS_ENV}"
|
|
. "${KAZ_ROOT}/secret/SetAllPass.sh"
|
|
|
|
savedComposes+=( ${enableMailComposes[@]} )
|
|
savedComposes+=( ${enableProxyComposes[@]} )
|
|
savedComposes+=( ${enableComposesNoNeedMail[@]} )
|
|
savedComposes+=( ${enableComposesNeedMail[@]} )
|
|
|
|
for compose in ${savedComposes[@]}
|
|
do
|
|
case "${compose}" in
|
|
jirafeau)
|
|
# rien à faire (fichiers)
|
|
;;
|
|
ethercalc)
|
|
#inutile car le backup de /var/lib/docker/volumes/ethercalc_calcDB/_data/dump.rdb est suffisant
|
|
;;
|
|
#grav)
|
|
# ???
|
|
#;;
|
|
#postfix)
|
|
sympa)
|
|
echo "save sympa"
|
|
saveDB ${sympaDBName} "${sympa_MYSQL_USER}" "${sympa_MYSQL_PASSWORD}" "${sympa_MYSQL_DATABASE}" sympa
|
|
;;
|
|
web)
|
|
# rien à faire (fichiers)
|
|
;;
|
|
etherpad)
|
|
echo "save pad"
|
|
saveDB ${etherpadDBName} "${etherpad_MYSQL_USER}" "${etherpad_MYSQL_PASSWORD}" "${etherpad_MYSQL_DATABASE}" etherpad
|
|
;;
|
|
framadate)
|
|
echo "save date"
|
|
saveDB ${framadateDBName} "${framadate_MYSQL_USER}" "${framadate_MYSQL_PASSWORD}" "${framadate_MYSQL_DATABASE}" framadate
|
|
;;
|
|
cloud)
|
|
echo "save cloud"
|
|
saveDB ${nextcloudDBName} "${nextcloud_MYSQL_USER}" "${nextcloud_MYSQL_PASSWORD}" "${nextcloud_MYSQL_DATABASE}" nextcloud
|
|
;;
|
|
paheko)
|
|
# rien à faire (fichiers)
|
|
;;
|
|
mattermost)
|
|
echo "save mattermost"
|
|
saveDB ${mattermostDBName} "${mattermost_MYSQL_USER}" "${mattermost_MYSQL_PASSWORD}" "${mattermost_MYSQL_DATABASE}" mattermost
|
|
;;
|
|
dokuwiki)
|
|
# rien à faire (fichiers)
|
|
;;
|
|
*-orga)
|
|
ORGA=${compose%-orga}
|
|
echo "save ${ORGA}"
|
|
if grep -q "cloud:" "${KAZ_COMP_DIR}/${compose}/docker-compose.yml" 2> /dev/null ; then
|
|
echo " => cloud"
|
|
saveDB "${ORGA}-DB" "${nextcloud_MYSQL_USER}" "${nextcloud_MYSQL_PASSWORD}" "${nextcloud_MYSQL_DATABASE}" "${ORGA}-cloud"
|
|
fi
|
|
if grep -q "agora:" "${KAZ_COMP_DIR}/${compose}/docker-compose.yml" 2> /dev/null ; then
|
|
echo " => mattermost"
|
|
saveDB "${ORGA}-DB" "${mattermost_MYSQL_USER}" "${mattermost_MYSQL_PASSWORD}" "${mattermost_MYSQL_DATABASE}" "${ORGA}-mattermost"
|
|
fi
|
|
if grep -q "wordpress:" "${KAZ_COMP_DIR}/${compose}/docker-compose.yml" 2> /dev/null ; then
|
|
echo " => wordpress"
|
|
saveDB "${ORGA}-DB" "${wp_MYSQL_USER}" "${wp_MYSQL_PASSWORD}" "${wp_MYSQL_DATABASE}" "${ORGA}-wordpress"
|
|
fi
|
|
;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
if [ "$#" -eq 0 ] ; then
|
|
usage
|
|
fi
|
|
|
|
if [ "$1" == "-h" ] ; then
|
|
usage
|
|
shift
|
|
fi
|
|
|
|
if [ "$1" == "-n" ] ; then
|
|
export SIMU=echo
|
|
shift
|
|
fi
|
|
|
|
DCK_CMD=""
|
|
SAVE_CMD=""
|
|
case "$1" in
|
|
start)
|
|
DCK_CMD="startComposes"
|
|
shift
|
|
;;
|
|
|
|
stop)
|
|
DCK_CMD="stopComposes"
|
|
shift
|
|
;;
|
|
|
|
save)
|
|
SAVE_CMD="saveComposes"
|
|
shift
|
|
;;
|
|
|
|
status)
|
|
DCK_CMD="statusComposes"
|
|
shift
|
|
;;
|
|
*)
|
|
usage
|
|
;;
|
|
esac
|
|
|
|
if [ $# -eq 0 ] ; then
|
|
enableComposesNoNeedMail=("${availableComposesNoNeedMail[@]}")
|
|
enableMailComposes=("${availableMailComposes[@]}")
|
|
enableComposesNeedMail=("${availableComposesNeedMail[@]}")
|
|
enableProxyComposes=("${availableProxyComposes[@]}")
|
|
else
|
|
if [ "${DCK_CMD}" = "startComposes" ] ; then
|
|
enableProxyComposes=("${availableProxyComposes[@]}")
|
|
fi
|
|
fi
|
|
|
|
for compose in $*
|
|
do
|
|
compose=${compose%/}
|
|
if [[ ! " ${knownedComposes[@]} " =~ " ${compose} " ]]; then
|
|
declare -a subst
|
|
subst=()
|
|
for item in "${knownedComposes[@]}"; do
|
|
[[ "${item}" =~ "${compose}" ]] && subst+=(${item})
|
|
done
|
|
if [ "${subst}" = "" ] ; then
|
|
echo
|
|
echo "Unknown compose: ${RED}${BOLD}${compose}${NC} not in ${YELLOW}${BOLD}${knownedComposes[*]}${NC}"
|
|
echo
|
|
exit 1
|
|
else
|
|
echo "substitute compose: ${YELLOW}${BOLD}${compose} => ${subst[@]}${NC}"
|
|
fi
|
|
fi
|
|
for item in "${availableMailComposes[@]}"; do
|
|
[[ "${item}" =~ "${compose}" ]] && enableMailComposes+=("${item}")
|
|
done
|
|
for item in "${availableProxyComposes[@]}"; do
|
|
[[ "${item}" =~ "${compose}" ]] && enableProxyComposes=("${item}")
|
|
done
|
|
for item in "${availableComposesNoNeedMail[@]}"; do
|
|
[[ "${item}" =~ "${compose}" ]] && enableComposesNoNeedMail+=("${item}")
|
|
done
|
|
for item in "${availableComposesNeedMail[@]}"; do
|
|
[[ "${item}" =~ "${compose}" ]] && enableComposesNeedMail+=("${item}")
|
|
done
|
|
done
|
|
|
|
[[ ! -z "${DCK_CMD}" ]] && "${DCK_CMD}" && exit 0
|
|
|
|
[[ ! -z "${SAVE_CMD}" ]] && "${SAVE_CMD}" && exit 0
|
|
|
|
exit 1
|