http-client: Add #:verify-certificate? to 'http-fetch'.

* guix/http-client.scm (http-fetch): Add #:verify-certificate? parameter
and pass it to 'open-connection-for-uri'.
This commit is contained in:
Ludovic Courtès 2016-11-12 12:53:45 +01:00
parent eda2ad5cd1
commit 17cff9c662
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5

View file

@ -223,7 +223,7 @@ (define (read-header-line port)
'shutdown (const #f))
(define* (http-fetch uri #:key port (text? #f) (buffered? #t)
keep-alive?)
keep-alive? (verify-certificate? #t))
"Return an input port containing the data at URI, and the expected number of
bytes available or #f. If TEXT? is true, the data at URI is considered to be
textual. Follow any HTTP redirection. When BUFFERED? is #f, return an
@ -231,11 +231,15 @@ (define* (http-fetch uri #:key port (text? #f) (buffered? #t)
true, send a 'Connection: keep-alive' HTTP header, in which case PORT may be
reused for future HTTP requests.
When VERIFY-CERTIFICATE? is true, verify HTTPS server certificates.
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-for-uri uri)))
(let ((port (or port (open-connection-for-uri uri
#:verify-certificate?
verify-certificate?)))
(auth-header (match (uri-userinfo uri)
((? string? str)
(list (cons 'Authorization