125 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/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
 |