#!/bin/bash
# -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
source "$(dirname -- "$0")/lib/ulib/auto" || exit 1

[ -n "$COMPOSE_V1" ] && DOCKER_COMPOSE=(docker-compose) || DOCKER_COMPOSE=(docker compose)

function display_help() {
    uecho "$scriptname: se connecter à la base MySQL

USAGE
    $scriptname [DATABASE]
    $scriptname -d [-uUSER [-pPASSWORD]] DATABASES... >backup.sql
    $scriptname -c [-uUSER [-pPASSWORD]] <backup.sql

OPTIONS
    --compose-v1
        Forcer l'utilisation de docker-compose v1
    -h, -s, --service SERVICE
        Spécifier le nom du service. La valeur par défaut est db
    -i, --ipnum IPNUM
        Si le service est dans plusieurs réseaux, sélectionner le numéro du
        réseau à attaquer en commençant à 1 (la liste sera affichée si cette
        option n'est pas spécifiée)
    -c, --mysql-cmd
        Lancer 'mysql -hSERVICE_IP' avec les arguments supplémentaires fournis
        sur la ligne de commande
    -d, --mysqldump-cmd
        Lancer 'mysqldump --databases --add-drop-database -hSERVICE_IP' avec
        les arguments supplémentaires fournis sur la ligne de commande
    -k, --klean
        Lancer la commande 'klean' dans le container spécifié (supprime toutes
        les données et relance le container)
    -u, --user USER
    -p, --password PASSWORD
        Paramètres supplémentaires utilisés uniquement avec les options -c et -d"
}

service=db
ipnum=
mysql_cmd=
mysqldump_cmd=
klean=
user=
password=
args=(
    --help '$exit_with display_help'
    --compose-v1 '$DOCKER_COMPOSE=(docker-compose)'
    -h:,-s:,--service: service=
    -i:,--ipnum: ipnum=
    -c,--mysql-cmd mysql_cmd=1
    -d,--mysqldump-cmd mysqldump_cmd=1
    -k,--klean klean=1
    -u:,--user: user=
    -p:,--password: password=
)
parse_args "$@"; set -- "${args[@]}"

[ -n "$service" ] || die "Vous devez spécifier le nom du service"

found=
first=1
while true; do
    if [ -f composer.json ]; then
        found=1
        break
    fi
    first=
    cd ..
    if [ "$(pwd)" == "$HOME" ]; then
        die "Cette commande ne peut être lancée que depuis un projet Composer"
    fi
done
if [ -z "$first" ]; then
    enote "Le répertoire du projet est $(ppath . ~)"
fi

###

function die_not_found() { die "$service: service introuvable. vérifiez que le projet est actuellement up"; }
setx cid="${DOCKER_COMPOSE[@]}" ps -q "$service" 2>/dev/null || die_not_found
[ -n "$cid" ] || die_not_found
edebug "$service id: $cid"

function die_not_found() { die "$service: $cid: ip introuvable"; }
setx ip=docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}},{{end}}' "$cid" || die_not_found
[ -n "$ip" ] || die_not_found
ipdesc="${ip%,}"
if [ -z "$ipnum" ] && [[ "$ipdesc" == *,* ]]; then
    enote "Le service est accessible sur plusieurs adresses ip: $ipdesc"
    enote "Pensez à spécifier l'option -i pour désigner l'adresse à utiliser (-i1 pour la première, -i2 pour la seconde, etc.)"
fi
if [ -n "$ipnum" ]; then
    let ipnum=ipnum-1
    while [ $ipnum -gt 0 ]; do
        ip="${ip#*,}"
        let ipnum=ipnum-1
    done
fi
ip="${ip%%,*}"
[ -n "$ip" ] || die_not_found
edebug "$service ip: $ip"

if [ -n "$mysql_cmd" ]; then
    mysql -h"$ip" ${user:+-u"$user"} ${password:+-p"$password"} "$@"

elif [ -n "$mysqldump_cmd" ]; then
    mysqldump --databases --add-drop-database -h"$ip" ${user:+-u"$user"} ${password:+-p"$password"} "$@"

elif [ -n "$klean" ]; then
    estep "klean"
    docker exec "$cid" klean
    estep "wait 10sec..."
    sleep 10
    estep "start"
    "${DOCKER_COMPOSE[@]}" start "$service"

else
    [ -f bin/conndev.php ] || die "Impossible de trouver le script compagnon conndev.php"

    mysql_cmd="$(php bin/conndev.php "$ip" "$@")"
    edebug "mysql_cmd: $mysql_cmd"

    eval "$mysql_cmd"
fi