100 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			3.4 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/ulib" || exit 1
 | 
						|
urequire DEFAULTS
 | 
						|
 | 
						|
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 @"
 | 
						|
}
 | 
						|
 | 
						|
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
 | 
						|
        if [ -n "$sftp" ]; then
 | 
						|
            url="sftp://$host/$path"
 | 
						|
        else
 | 
						|
            url="ftp://$host/$path"
 | 
						|
        fi
 | 
						|
        exec lftp "${options[@]}" -e "\
 | 
						|
set ssl:verify-certificate $verify_certificate
 | 
						|
open -u $login,$password $url"
 | 
						|
    else
 | 
						|
        url="ftp://$AUTHFTP_PROXY_HOST/$path"
 | 
						|
        exec lftp "${options[@]}" -e "\
 | 
						|
set ssl:verify-certificate $verify_certificate
 | 
						|
open -u ${login}@${my_login}@${host},${password}@${my_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
 |