mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-22 18:49:14 -05:00
http-client: Correctly handle redirects when #:keep-alive? #t.
Previously PORT would be closed unconditionally, which broke redirects when #:keep-alive? #t is given. * guix/http-client.scm (http-fetch): Make 'port' a parameter of 'loop'. Upon 3xx responses, do not close PORT is KEEP-ALIVE? is true, but consume RESP's body. Add second argument to 'loop'.
This commit is contained in:
parent
55e8e283ae
commit
8786c2e8d7
1 changed files with 24 additions and 11 deletions
|
@ -100,14 +100,15 @@ (define* (http-fetch uri #:key port (text? #f) (buffered? #t)
|
|||
Write information about redirects to LOG-PORT.
|
||||
|
||||
Raise an '&http-get-error' condition if downloading fails."
|
||||
(let loop ((uri (if (string? uri)
|
||||
(string->uri uri)
|
||||
uri)))
|
||||
(let ((port (or port (open-connection uri
|
||||
#:verify-certificate?
|
||||
verify-certificate?
|
||||
#:timeout timeout)))
|
||||
(headers (match (uri-userinfo uri)
|
||||
(define uri*
|
||||
(if (string? uri) (string->uri uri) uri))
|
||||
|
||||
(let loop ((uri uri*)
|
||||
(port (or port (open-connection uri*
|
||||
#:verify-certificate?
|
||||
verify-certificate?
|
||||
#:timeout timeout))))
|
||||
(let ((headers (match (uri-userinfo uri)
|
||||
((? string? str)
|
||||
(cons (cons 'Authorization
|
||||
(string-append "Basic "
|
||||
|
@ -131,11 +132,23 @@ (define* (http-fetch uri #:key port (text? #f) (buffered? #t)
|
|||
303 ; see other
|
||||
307 ; temporary redirection
|
||||
308) ; permanent redirection
|
||||
(let ((uri (resolve-uri-reference (response-location resp) uri)))
|
||||
(close-port port)
|
||||
(let ((host (uri-host uri))
|
||||
(uri (resolve-uri-reference (response-location resp) uri)))
|
||||
(if keep-alive?
|
||||
(dump-port data (%make-void-port "w0")
|
||||
(response-content-length resp))
|
||||
(close-port port))
|
||||
(format log-port (G_ "following redirection to `~a'...~%")
|
||||
(uri->string uri))
|
||||
(loop uri)))
|
||||
(loop uri
|
||||
(or (and keep-alive?
|
||||
(or (not (uri-host uri))
|
||||
(string=? host (uri-host uri)))
|
||||
port)
|
||||
(open-connection uri*
|
||||
#:verify-certificate?
|
||||
verify-certificate?
|
||||
#:timeout timeout)))))
|
||||
(else
|
||||
(raise (condition (&http-get-error
|
||||
(uri uri)
|
||||
|
|
Loading…
Reference in a new issue