ftp-client: Try all the addresses returned by `getaddrinfo'.

* guix/ftp-client.scm (ftp-open): Upon connection failure, try the other
  addresses returned by `getaddrinfo'.
This commit is contained in:
Ludovic Courtès 2012-10-13 21:18:16 +02:00
parent 568717fd90
commit 4004f95379

View file

@ -81,24 +81,40 @@ (define (%ftp-login user pass port)
(else (throw 'ftp-error port command code message)))))) (else (throw 'ftp-error port command code message))))))
(define (ftp-open host) (define (ftp-open host)
"Open an FTP connection to HOST, and return it."
(catch 'getaddrinfo-error (catch 'getaddrinfo-error
(lambda () (lambda ()
(let* ((ai (car (getaddrinfo host "ftp"))) (define addresses
(s (socket (addrinfo:fam ai) (addrinfo:socktype ai) (getaddrinfo host "ftp"))
(addrinfo:protocol ai))))
(connect s (addrinfo:addr ai)) (let loop ((addresses addresses))
(setvbuf s _IOLBF) (let* ((ai (car addresses))
(let-values (((code message) (%ftp-listen s))) (s (socket (addrinfo:fam ai) (addrinfo:socktype ai)
(if (eqv? code 220) (addrinfo:protocol ai))))
(begin
;(%ftp-command "OPTS UTF8 ON" 200 s) (catch 'system-error
(%ftp-login "anonymous" "ludo@example.com" s) (lambda ()
(%make-ftp-connection s ai)) (connect s (addrinfo:addr ai))
(begin (setvbuf s _IOLBF)
(format (current-error-port) "FTP to `~a' failed: ~A: ~A~%" (let-values (((code message) (%ftp-listen s)))
host code message) (if (eqv? code 220)
(close s) (begin
#f))))) ;;(%ftp-command "OPTS UTF8 ON" 200 s)
(%ftp-login "anonymous" "guix@example.com" s)
(%make-ftp-connection s ai))
(begin
(format (current-error-port)
"FTP to `~a' failed: ~A: ~A~%"
host code message)
(close s)
#f))))
(lambda args
;; Connection failed, so try one of the other addresses.
(close s)
(if (null? addresses)
(apply throw args)
(loop (cdr addresses))))))))
(lambda (key errcode) (lambda (key errcode)
(format (current-error-port) "failed to resolve `~a': ~a~%" (format (current-error-port) "failed to resolve `~a': ~a~%"
host (gai-strerror errcode)) host (gai-strerror errcode))