1 ;;; GNU Guix --- Functional package management for GNU
2 ;;; Copyright © 2013, 2014, 2015 Andreas Enge <andreas@enge.fr>
3 ;;; Copyright © 2015 Mark H Weaver <mhw@netris.org>
4 ;;; Copyright © 2015 Tomáš Čech <sleep_walker@suse.cz>
5 ;;; Copyright © 2015, 2020 Ludovic Courtès <ludo@gnu.org>
6 ;;; Copyright © 2016, 2017, 2019 Leo Famulari <leo@famulari.name>
7 ;;; Copyright © 2017, 2019, 2020 Marius Bakke <mbakke@fastmail.com>
8 ;;; Copyright © 2017 Efraim Flashner <efraim@flashner.co.il>
9 ;;; Copyright © 2017, 2018 Tobias Geerinckx-Rice <me@tobias.gr>
10 ;;; Copyright © 2018 Roel Janssen <roel@gnu.org>
11 ;;; Copyright © 2019 Ricardo Wurmus <rekado@elephly.net>
12 ;;; Copyright © 2020 Jakub Kądziołka <kuba@kadziolka.net>
13 ;;; Copyright © 2020 Dale Mellor <guix-devel-0brg6b@rdmp.org>
15 ;;; This file is part of GNU Guix.
17 ;;; GNU Guix is free software; you can redistribute it and/or modify it
18 ;;; under the terms of the GNU General Public License as published by
19 ;;; the Free Software Foundation; either version 3 of the License, or (at
20 ;;; your option) any later version.
22 ;;; GNU Guix is distributed in the hope that it will be useful, but
23 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
24 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25 ;;; GNU General Public License for more details.
27 ;;; You should have received a copy of the GNU General Public License
28 ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
30 (define-module (gnu packages curl)
31 #:use-module ((guix licenses) #:prefix license:)
32 #:use-module (guix packages)
33 #:use-module (guix download)
34 #:use-module (guix git-download)
35 #:use-module (guix utils)
36 #:use-module (guix build-system cmake)
37 #:use-module (guix build-system gnu)
38 #:use-module (guix build-system go)
39 #:use-module (gnu packages)
40 #:use-module (gnu packages compression)
41 #:use-module (gnu packages golang)
42 #:use-module (gnu packages guile)
43 #:use-module (gnu packages kerberos)
44 #:use-module (gnu packages libidn)
45 #:use-module (gnu packages openldap)
46 #:use-module (gnu packages perl)
47 #:use-module (gnu packages pkg-config)
48 #:use-module (gnu packages python)
49 #:use-module (gnu packages tls)
50 #:use-module (gnu packages web)
51 #:use-module (srfi srfi-1))
59 (uri (string-append "https://curl.haxx.se/download/curl-"
63 "12w7gskrglg6qrmp822j37fmbr0icrcxv7rib1fy5xiw80n5z7cr"))
64 (patches (search-patches "curl-use-ssl-cert-env.patch"))))
65 (build-system gnu-build-system)
67 "doc")) ;1.2 MiB of man3 pages
68 (inputs `(("gnutls" ,gnutls)
70 ("openldap" ,openldap)
71 ("mit-krb5" ,mit-krb5)
72 ("nghttp2" ,nghttp2 "lib")
76 ("pkg-config" ,pkg-config)
77 ("python" ,python-wrapper)))
79 ;; These variables are introduced by curl-use-ssl-cert-env.patch.
80 (list (search-path-specification
81 (variable "SSL_CERT_DIR")
82 (separator #f) ;single entry
83 (files '("etc/ssl/certs")))
84 (search-path-specification
85 (variable "SSL_CERT_FILE")
87 (separator #f) ;single entry
88 (files '("etc/ssl/certs/ca-certificates.crt")))
89 ;; Note: This search path is respected by the `curl` command-line
90 ;; tool only. Patching libcurl to read it too would bring no
91 ;; advantages and require maintaining a more complex patch.
92 (search-path-specification
93 (variable "CURL_CA_BUNDLE")
95 (separator #f) ;single entry
96 (files '("etc/ssl/certs/ca-certificates.crt")))))
98 `(#:disallowed-references ("doc")
99 #:configure-flags (list "--with-gnutls"
100 (string-append "--with-gssapi="
101 (assoc-ref %build-inputs "mit-krb5"))
104 (modify-phases %standard-phases
105 (add-after 'unpack 'do-not-record-configure-flags
107 ;; Do not save the configure options to avoid unnecessary references.
108 (substitute* "curl-config.in"
109 (("@CONFIGURE_OPTIONS@")
110 "\"not available\""))
113 'install 'move-man3-pages
114 (lambda* (#:key outputs #:allow-other-keys)
115 ;; Move section 3 man pages to "doc".
116 (let ((out (assoc-ref outputs "out"))
117 (doc (assoc-ref outputs "doc")))
118 (mkdir-p (string-append doc "/share/man"))
119 (rename-file (string-append out "/share/man/man3")
120 (string-append doc "/share/man/man3"))
125 (substitute* "tests/runtests.pl"
126 (("/bin/sh") (which "sh")))
128 ;; The top-level "make check" does "make -C tests quiet-test", which
129 ;; is too quiet. Use the "test" target instead, which is more
131 (invoke "make" "-C" "tests" "test"))))))
132 (synopsis "Command line tool for transferring data with URL syntax")
134 "curl is a command line tool for transferring data with URL syntax,
135 supporting DICT, FILE, FTP, FTPS, Gopher, HTTP, HTTPS, IMAP, IMAPS, LDAP,
136 LDAPS, POP3, POP3S, RTMP, RTSP, SCP, SFTP, SMTP, SMTPS, Telnet and TFTP.
137 curl supports SSL certificates, HTTP POST, HTTP PUT, FTP uploading, HTTP
138 form based upload, proxies, cookies, file transfer resume, user+password
139 authentication (Basic, Digest, NTLM, Negotiate, kerberos...), proxy
140 tunneling, and so on.")
141 (license (license:non-copyleft "file://COPYING"
142 "See COPYING in the distribution."))
143 (home-page "https://curl.haxx.se/")))
145 ;; This package exists mainly to bootstrap CMake. It must not depend on
146 ;; anything that uses cmake-build-system.
147 (define-public curl-minimal
151 (name "curl-minimal")
152 (inputs (alist-delete "openldap" (package-inputs curl))))))
161 (url "https://gitlab.com/davidjpeacock/kurly.git")
162 (commit (string-append "v" version))))
163 (file-name (git-file-name name version))
166 "003jv2k45hg2svhjpy5253ccd250vi2r17x2zhm51iw54kgwxipm"))))
167 (build-system go-build-system)
169 `(#:import-path "gitlab.com/davidjpeacock/kurly"
172 (modify-phases %standard-phases
173 (add-after 'install 'install-documentation
174 (lambda* (#:key import-path outputs #:allow-other-keys)
175 (let* ((source (string-append "src/" import-path))
176 (out (assoc-ref outputs "out"))
177 (doc (string-append out "/share/doc/" ,name "-" ,version))
178 (man (string-append out "/share/man/man1")))
179 (with-directory-excursion source
180 (install-file "README.md" doc)
182 (copy-file "doc/kurly.man"
183 (string-append man "/kurly.1")))
186 `(("go-github-com-alsm-ioprogress" ,go-github-com-alsm-ioprogress)
187 ("go-github-com-aki237-nscjar" ,go-github-com-aki237-nscjar)
188 ("go-github-com-urfave-cli" ,go-github-com-urfave-cli)))
189 (synopsis "Command-line HTTP client")
190 (description "kurly is an alternative to the @code{curl} program written in
191 Go. kurly is designed to operate in a similar manner to curl, with select
192 features. Notably, kurly is not aiming for feature parity, but common flags and
193 mechanisms particularly within the HTTP(S) realm are to be expected. kurly does
194 not offer a replacement for libcurl.")
195 (home-page "https://gitlab.com/davidjpeacock/kurly")
196 (license license:asl2.0)))
198 (define-public guile-curl
204 (uri (string-append "http://www.lonelycactus.com/tarball/"
205 "guile_curl-" version ".tar.gz"))
208 "1pxdhnk288ky6gkpad8i60m0p6404rdvls43lr1b5d3csrklyc70"))))
209 (build-system gnu-build-system)
211 `(#:configure-flags (list (string-append
212 "--with-guilesitedir="
213 (assoc-ref %outputs "out")
214 "/share/guile/site/2.2")
216 "-with-guileextensiondir="
217 (assoc-ref %outputs "out")
218 "/lib/guile/2.2/extensions"))
220 (modify-phases %standard-phases
221 (add-after 'install 'patch-extension-path
222 (lambda* (#:key outputs #:allow-other-keys)
223 (let* ((out (assoc-ref outputs "out"))
224 (curl.scm (string-append
225 out "/share/guile/site/2.2/curl.scm"))
226 (curl.go (string-append
227 out "/lib/guile/2.2/site-ccache/curl.go"))
228 (ext (string-append out "/lib/guile/2.2/"
229 "extensions/libguile-curl")))
230 (substitute* curl.scm (("libguile-curl") ext))
231 ;; The build system does not actually compile the Scheme module.
232 ;; So we can compile it and put it in the right place in one go.
233 (invoke "guild" "compile" curl.scm "-o" curl.go)))))))
234 (native-inputs `(("pkg-config" ,pkg-config)))
237 ("guile" ,guile-2.2)))
238 (home-page "http://www.lonelycactus.com/guile-curl.html")
239 (synopsis "Curl bindings for Guile")
240 (description "@code{guile-curl} is a project that has procedures that allow
241 Guile to do client-side URL transfers, like requesting documents from HTTP or
242 FTP servers. It is based on the curl library.")
243 (license license:gpl3+)))
245 (define-public curlpp
253 (url "https://github.com/jpbarrette/curlpp")
254 (commit (string-append "v" version))))
256 (base32 "1b0ylnnrhdax4kwjq64r1fk0i24n5ss6zfzf4hxwgslny01xiwrk"))
257 (file-name (git-file-name name version))))
258 (build-system cmake-build-system)
259 ;; There are no build tests to be had.
262 ;; The installed version needs the header files from the C library.
265 (synopsis "C++ wrapper around libcURL")
267 "This package provides a free and easy-to-use client-side C++ URL
268 transfer library, supporting FTP, FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT,
269 FILE and LDAP; in particular it supports HTTPS certificates, HTTP POST, HTTP
270 PUT, FTP uploading, kerberos, HTTP form based upload, proxies, cookies,
271 user+password authentication, file transfer resume, http proxy tunneling and
273 (home-page "http://www.curlpp.org")
274 (license license:expat)))