source: networking/netlibs/curl.xml@ 038b4c75

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.1 8.0 8.1 8.2 8.3 8.4 9.0 9.1 basic bdubbs/svn elogind kea ken/TL2024 ken/inkscape-core-mods ken/tuningfonts lazarus lxqt nosym perl-modules plabs/newcss plabs/python-mods python3.11 qt5new rahul/power-profiles-daemon renodr/vulkan-addition trunk upgradedb xry111/intltool xry111/llvm18 xry111/soup3 xry111/test-20220226 xry111/xf86-video-removal
Last change on this file since 038b4c75 was 038b4c75, checked in by DJ Lucas <dj@…>, 7 years ago

Remove mk-ca-bundle.pl and use ca-path instead of ca-bundle for curl.

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@18010 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 9.3 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY curl-download-http "https://curl.haxx.se/download/curl-&curl-version;.tar.lzma">
8 <!ENTITY curl-download-ftp " ">
9 <!ENTITY curl-md5sum "0f876ef6d5776d96b08510461d57db1b">
10 <!ENTITY curl-size "2.0 MB">
11 <!ENTITY curl-buildsize "55 MB (additional 9 MB for tests)">
12 <!ENTITY curl-time "0.4 SBU (additional 9.9 SBU for tests)">
13]>
14
15<sect1 id="curl" xreflabel="cURL-&curl-version;">
16 <?dbhtml filename="curl.html"?>
17
18 <sect1info>
19 <othername>$LastChangedBy$</othername>
20 <date>$Date$</date>
21 </sect1info>
22
23 <title>cURL-&curl-version;</title>
24
25 <indexterm zone="curl">
26 <primary sortas="a-cURL">cURL</primary>
27 </indexterm>
28
29 <sect2 role="package">
30 <title>Introduction to cURL</title>
31
32 <para>
33 The <application>cURL</application> package contains an utility
34 and a library used for transferring files with URL syntax to any of
35 the following protocols: FTP, FTPS, HTTP, HTTPS, SCP, SFTP, TFTP,
36 TELNET, DICT, LDAP, LDAPS and FILE. Its ability to both download
37 and upload files can be incorporated into other programs to support
38 functions like streaming media.
39 </para>
40
41 &lfs7a_checked;
42
43 <bridgehead renderas="sect3">Package Information</bridgehead>
44 <itemizedlist spacing="compact">
45 <listitem>
46 <para>
47 Download (HTTP): <ulink url="&curl-download-http;"/>
48 </para>
49 </listitem>
50 <listitem>
51 <para>
52 Download (FTP): <ulink url="&curl-download-ftp;"/>
53 </para>
54 </listitem>
55 <listitem>
56 <para>
57 Download MD5 sum: &curl-md5sum;
58 </para>
59 </listitem>
60 <listitem>
61 <para>
62 Download size: &curl-size;
63 </para>
64 </listitem>
65 <listitem>
66 <para>
67 Estimated disk space required: &curl-buildsize;
68 </para>
69 </listitem>
70 <listitem>
71 <para>
72 Estimated build time: &curl-time;
73 </para>
74 </listitem>
75 </itemizedlist>
76
77 <bridgehead renderas="sect3">cURL Dependencies</bridgehead>
78
79 <bridgehead renderas="sect4">Recommended</bridgehead>
80 <para role="recommended">
81 <xref linkend="cacerts"/> (runtime) and
82 <xref linkend="openssl"/> or <xref linkend="gnutls"/>
83 </para>
84
85 <bridgehead renderas="sect4">Optional</bridgehead>
86 <para role="optional">
87 <xref linkend="libidn"/>,
88 <xref linkend="mitkrb"/>,
89 <xref linkend="nghttp2"/>,
90 <xref linkend="openldap"/>,
91 <xref linkend="samba"/>,
92 <ulink url="http://daniel.haxx.se/projects/c-ares/">c-ares</ulink>,
93 <ulink url="https://launchpad.net/libmetalink/">libmetalink</ulink>,
94 <ulink url="https://github.com/rockdaboot/libpsl">libpsl</ulink>,
95 <ulink url="http://rtmpdump.mplayerhq.hu/">librtmp</ulink>,
96 <ulink url="http://www.libssh2.org">libssh2</ulink>,
97 <ulink url="https://tls.mbed.org/">mbed TLS (formerly known as
98 PolarSSL)</ulink>, and
99 <ulink url="http://spnego.sourceforge.net/">
100 SPNEGO</ulink>
101 </para>
102
103 <bridgehead renderas="sect4">Optional for Running the Test Suite</bridgehead>
104 <para role="optional">
105 <xref linkend="stunnel"/> (for the HTTPS and FTPS tests) and
106 <xref linkend="valgrind"/>
107 </para>
108
109 <para condition="html" role="usernotes">User Notes:
110 <ulink url="&blfs-wiki;/curl"/>
111 </para>
112 </sect2>
113
114 <sect2 role="installation">
115 <title>Installation of cURL</title>
116
117 <para>
118 Install <application>cURL</application> by running the following
119 commands:
120 </para>
121
122<screen><userinput>./configure --prefix=/usr \
123 --disable-static \
124 --enable-threaded-resolver \
125 --with-ca-path=/etc/ssl/certs &amp;&amp;
126make</userinput></screen>
127
128<!-- <para>
129 Running the test suite is optional. About 2% of the tests fail. Increase
130 in test time by each failed test is about 10%. Tests SBU above was
131 obtained disabling failing tests, with:
132 </para>
133
134<screen><userinput>cat &gt;&gt; tests/data/DISABLED &lt;&lt; "EOF"
135<literal>564
136700
137701
138703
139706
140707
141708
142709
143710
144711
145712</literal>
146EOF</userinput></screen>
147
148I had the following fail:
149 300 301 303 304 306 309 310 311 312 325
150 400 401 403 406 407 408 409 560 1112 2034
1512035 2037 2038 2041 2042
152
153 - Bruce 20151016
154
155Tests may be using capabilites removed from recent ssh due to
156security issues.
157
158
159 <para>
160 and running <command>make test</command>.
161 </para>-->
162
163 <para>
164 To run the test suite, issue: <command>make test</command>. <!-- Two tests,
165 1139 and 1140, may fail. Works fine for me. Douglas 20160720 --><!-- Some
166 tests (up to 2%) may fail due to timing issues, kernel configuration,
167 or other issues.-->
168 </para>
169
170 <para>
171 Now, as the <systemitem class="username">root</systemitem>
172 user:
173 </para>
174
175<screen role="root"><userinput>make install &amp;&amp;
176
177rm -rf docs/examples/.deps &amp;&amp;
178
179find docs \( -name Makefile\* \
180 -o -name \*.1 \
181 -o -name \*.3 \) \
182 -exec rm {} \; &amp;&amp;
183install -v -d -m755 /usr/share/doc/curl-&curl-version; &amp;&amp;
184cp -v -R docs/* /usr/share/doc/curl-&curl-version;</userinput></screen>
185
186 <para>
187 Simple tests to the new installed <command>curl</command>:
188 <command>curl --trace-ascii debugdump.txt http://www.example.com/</command>
189 and
190 <command>curl --trace-ascii d.txt --trace-time http://example.com/</command>.
191 Inspect the locally created trace files <filename>debugdump.txt</filename>
192 and <filename>d.txt</filename>, which contain version downloaded
193 files information, etc. One file has the time for each action logged.
194 </para>
195 </sect2>
196
197 <sect2 role="commands">
198 <title>Command Explanations</title>
199
200 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
201 href="../../xincludes/static-libraries.xml"/>
202
203 <para>
204 <parameter>--enable-threaded-resolver</parameter>: This switch enables
205 <application>cURL</application>'s builtin threaded DNS resolver.
206 </para>
207
208 <para>
209 <parameter>--with-ca-path=/etc/ssl/certs</parameter>: This
210 switch sets the location of the BLFS <xref linkend="cacerts"/>.
211 </para>
212
213 <para>
214 <option>--with-gssapi</option>: This parameter adds
215 <application>Kerberos 5</application> support to
216 <filename class="libraryfile">libcurl</filename>.
217 </para>
218
219 <para>
220 <option>--without-ssl --with-gnutls</option>: Use to
221 build with <application>GnuTLS</application> support
222 instead of <application>OpenSSL</application> for SSL/TLS.
223 </para>
224
225 <para>
226 <option>--with-ca-bunlde=/etc/ssl/ca-bundle.crt</option>: Use
227 this switch instead of <parameter>--with-ca-path</parameter> if
228 building with <application>GnuTLS</application> support
229 instead of <application>OpenSSL</application> for SSL/TLS.
230 </para>
231
232 <para>
233 <command>find docs ... -exec rm {} \;</command>: This command removes
234 <filename>Makefiles</filename> and man files from the documentation
235 directory that would otherwise be installed by the commands that follow.
236 </para>
237
238 </sect2>
239
240 <sect2 role="content">
241 <title>Contents</title>
242
243 <segmentedlist>
244 <segtitle>Installed Programs</segtitle>
245 <segtitle>Installed Library</segtitle>
246 <segtitle>Installed Directories</segtitle>
247
248 <seglistitem>
249 <seg>
250 curl, and curl-config
251 </seg>
252 <seg>
253 libcurl.so
254 </seg>
255 <seg>
256 /usr/include/curl and
257 /usr/share/doc/curl-&curl-version;
258 </seg>
259 </seglistitem>
260 </segmentedlist>
261
262 <variablelist>
263 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
264 <?dbfo list-presentation="list"?>
265 <?dbhtml list-presentation="table"?>
266
267 <varlistentry id="curl-prog">
268 <term><command>curl</command></term>
269 <listitem>
270 <para>
271 is a command line tool for transferring files with URL syntax.
272 </para>
273 <indexterm zone="curl curl-prog">
274 <primary sortas="b-curl">curl</primary>
275 </indexterm>
276 </listitem>
277 </varlistentry>
278
279 <varlistentry id="curl-config">
280 <term><command>curl-config</command></term>
281 <listitem>
282 <para>
283 prints information about the last compile, like libraries
284 linked to and prefix setting.
285 </para>
286 <indexterm zone="curl curl-config">
287 <primary sortas="b-curl-config">curl-config</primary>
288 </indexterm>
289 </listitem>
290 </varlistentry>
291
292 <varlistentry id="libcurl">
293 <term><filename class="libraryfile">libcurl.so</filename></term>
294 <listitem>
295 <para>
296 provides the API functions required by
297 <command>curl</command> and other programs.
298 </para>
299 <indexterm zone="curl libcurl">
300 <primary sortas="c-libcurl">libcurl.so</primary>
301 </indexterm>
302 </listitem>
303 </varlistentry>
304
305 </variablelist>
306
307 </sect2>
308
309</sect1>
Note: See TracBrowser for help on using the repository browser.