110 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			3.9 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
 | |
| 
 | |
| function display_help() {
 | |
|     uecho "$scriptname: Se connecter sur un site FTP authentifié
 | |
| Ce script nécessite ncftp. Il est conçu pour faciliter l'accès à des sites FTP
 | |
| s'il est requis d'y accéder par un proxy FTP pour les connexion authentifiées.
 | |
| 
 | |
| USAGE
 | |
|     $scriptname [options] host login password [path]
 | |
| 
 | |
| OPTIONS
 | |
|     -p, --proxy
 | |
|     -n, --noproxy
 | |
|         Forcer l'utilisation, resp. ne pas utiliser, le proxy FTP (i.e. faire la
 | |
|         connexion directement)
 | |
|     -l, --lftp
 | |
|         Se connecter avec lftp au lieu de ncftp. Le fonctionnement n'est pas
 | |
|         garanti si l'on utilise un proxy FTP.
 | |
|     -o OPTION
 | |
|         Ajouter une option à la commande lancée. Si l'option prend un argument,
 | |
|         il faut doubler l'option -o, e.g.
 | |
|             $scriptname -l -o -e -o 'mirror remote local' host login pass
 | |
|         Dans cet exemple, l'option -e de lftp est utilisée pour faire un miroir
 | |
|         local du répertoire remote.
 | |
|     --tls
 | |
|         Indiquer que la connexion se fera en TLS. Implique --lftp puisque ncftp
 | |
|         ne le supporte pas.
 | |
|     --verify-certificate
 | |
|         Avec la connexion --tls, forcer la vérification du certificat, qui est
 | |
|         désactivée par défaut.
 | |
|     --sftp
 | |
|         Indiquer que la connexion se fait via SFTP. Implique --lftp --noproxy
 | |
| 
 | |
| note: A cause d'une limitation de lftp, ce n'est pas possible de se connecter
 | |
| automatiquement avec lftp si le mot de passe contient une virgule. A cause de la
 | |
| façon dont le proxy ftp est configuré, il n'est pas possible de se connecter
 | |
| avec un mot de passe qui contient le caractère @"
 | |
| }
 | |
| 
 | |
| function hostkeyfailed_apropos() {
 | |
|     eecho "\
 | |
| ------------------------------------------------------------------------------------
 | |
| Si le message 'Host key verification failed' apparait, lancer la commande suivante:
 | |
|     ssh -o StrictHostKeyChecking=no -o BatchMode=yes $1
 | |
| ------------------------------------------------------------------------------------"
 | |
| }
 | |
| 
 | |
| AUTHFTP_PROXY_DISABLED=1 # par défaut, ne pas utiliser le proxy
 | |
| set_defaults proxy
 | |
| set_defaults authftp
 | |
| 
 | |
| noproxy="$AUTHFTP_PROXY_DISABLED"
 | |
| lftp=
 | |
| options=()
 | |
| tls=
 | |
| verify_certificate=no
 | |
| sftp=
 | |
| parse_opts "${PRETTYOPTS[@]}" \
 | |
|     --help '$exit_with display_help' \
 | |
|     -p,--proxy noproxy= \
 | |
|     -n,--noproxy noproxy=1 \
 | |
|     -l,--lftp lftp=1 \
 | |
|     -o:,--option: options \
 | |
|     --tls tls=1 \
 | |
|     --verify-certificate verify_certificate=yes \
 | |
|     --sftp sftp=1 \
 | |
|     @ args -- "$@" && set -- "${args[@]}" || die "$args"
 | |
| 
 | |
| [ -n "$noproxy" -o -n "$AUTHFTP_PROXY_HOST" ] || die "AUTHFTP_PROXY_HOST doit être défini"
 | |
| 
 | |
| my_login="$PROXY_LOGIN"
 | |
| my_password="$PROXY_PASSWORD"
 | |
| 
 | |
| read_value -i "Entrez le nom de l'hôte" host "$1"
 | |
| read_value -i "Entrez l'identifiant de connexion" login "$2"
 | |
| read_value -i "Entrez le mot de passe" password "$3"
 | |
| read_value -i "Entrez le chemin" path "$4" N
 | |
| 
 | |
| [ -n "$tls" -o -n "$sftp" ] && lftp=1
 | |
| [ -n "$sftp" ] && noproxy=1
 | |
| 
 | |
| if [ -n "$lftp" ]; then
 | |
|     if [ -n "$noproxy" ]; then
 | |
|         export LFTP_PASSWORD="$password"
 | |
|         if [ -n "$sftp" ]; then
 | |
|             url="sftp://$host/$path"
 | |
|             hostkeyfailed_apropos "$login@$host"
 | |
|         else
 | |
|             url="ftp://$host/$path"
 | |
|         fi
 | |
|         exec lftp "${options[@]}" -e "\
 | |
| set ssl:verify-certificate $verify_certificate
 | |
| open -u $login --env-password $url"
 | |
|     else
 | |
|         export LFTP_PASSWORD="${password}@${my_password}"
 | |
|         url="ftp://$AUTHFTP_PROXY_HOST/$path"
 | |
|         exec lftp "${options[@]}" -e "\
 | |
| set ssl:verify-certificate $verify_certificate
 | |
| open -u ${login}@${my_login}@${host} --env-password $url"
 | |
|     fi
 | |
| else
 | |
|     if [ -n "$noproxy" ]; then
 | |
|         exec ncftp -u "$login" -p "$password" "${options[@]}" "ftp://$host/$path"
 | |
|     else
 | |
|         exec ncftp -u "${login}@${my_login}@${host}" -p "${password}@${my_password}" "${options[@]}" "ftp://$AUTHFTP_PROXY_HOST/$path"
 | |
|     fi
 | |
| fi
 |