#!/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