source: postlfs/security/gnutls.xml@ 14d673a2

10.0 10.1 11.0 11.1 11.2 11.3 12.0 12.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 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 14d673a2 was 14d673a2, checked in by Krejzi <krejzi@…>, 6 years ago

Rethink last commit

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

  • Property mode set to 100644
File size: 12.7 KB
RevLine 
[d5404360]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
[fa30d84]7 <!ENTITY gnutls-download-http "&gnupg-http;/gnutls/v3.6/gnutls-&gnutls-version;.tar.xz">
[14d673a2]8 <!-- Something is wrong with ftp server and it confuses curl when currency runs it -->
9 <!-- <!ENTITY gnutls-download-ftp "&gnupg-ftp;/gnutls/v3.6/gnutls-&gnutls-version;.tar.xz"> -->
10 <!ENTITY gnutls-download-ftp " ">
[b04efb5d]11 <!ENTITY gnutls-md5sum "4b65ae3ffef59f3eeed51a6166ff12b3">
[fa30d84]12 <!ENTITY gnutls-size "7.7 MB">
[b04efb5d]13 <!ENTITY gnutls-buildsize "150 MB (add 68 MB for tests)">
14 <!ENTITY gnutls-time "0.6 SBU (using parallelism=4; add 5.6 SBU for tests)">
[d5404360]15]>
16
17<sect1 id="gnutls" xreflabel="GnuTLS-&gnutls-version;">
18 <?dbhtml filename="gnutls.html"?>
19
20 <sect1info>
21 <othername>$LastChangedBy$</othername>
22 <date>$Date$</date>
23 </sect1info>
24
25 <title>GnuTLS-&gnutls-version;</title>
26
27 <indexterm zone="gnutls">
28 <primary sortas="a-GnuTLS">GnuTLS</primary>
29 </indexterm>
30
31 <sect2 role="package">
32 <title>Introduction to GnuTLS</title>
33
[3ee626e]34 <para>
35 The <application>GnuTLS</application> package contains libraries and
36 userspace tools which provide a secure layer over a reliable transport
37 layer. Currently the <application>GnuTLS</application> library implements
38 the proposed standards by the IETF's TLS working group. Quoting from the
39 TLS protocol specification:
40 </para>
41
42 <para>
43 <quote>The TLS protocol provides communications privacy over the
44 Internet. The protocol allows client/server applications to communicate in
45 a way that is designed to prevent eavesdropping, tampering, or message
46 forgery.</quote>
47 </para>
48
49 <para>
[6c6990c]50 <application>GnuTLS</application> provides support for TLS 1.2, TLS 1.1,
[8b830d32]51 TLS 1.0, and SSL 3.0 protocols, TLS extensions, including server name and max
[3ee626e]52 record size. Additionally, the library supports authentication using the
53 SRP protocol, X.509 certificates and OpenPGP keys, along with support for
54 the TLS Pre-Shared-Keys (PSK) extension, the Inner Application (TLS/IA)
55 extension and X.509 and OpenPGP certificate handling.
56 </para>
[d5404360]57
[5ae3416]58 &lfs81_checked;
[214718a]59
[d5404360]60 <bridgehead renderas="sect3">Package Information</bridgehead>
61 <itemizedlist spacing="compact">
[546b042]62 <listitem>
[3ee626e]63 <para>
64 Download (HTTP): <ulink url="&gnutls-download-http;"/>
65 </para>
[546b042]66 </listitem>
[d5404360]67 <listitem>
[3ee626e]68 <para>
69 Download (FTP): <ulink url="&gnutls-download-ftp;"/>
70 </para>
[d5404360]71 </listitem>
72 <listitem>
[3ee626e]73 <para>
74 Download MD5 sum: &gnutls-md5sum;
75 </para>
[d5404360]76 </listitem>
77 <listitem>
[3ee626e]78 <para>
79 Download size: &gnutls-size;
80 </para>
[d5404360]81 </listitem>
82 <listitem>
[3ee626e]83 <para>
84 Estimated disk space required: &gnutls-buildsize;
85 </para>
[d5404360]86 </listitem>
87 <listitem>
[3ee626e]88 <para>
89 Estimated build time: &gnutls-time;
90 </para>
[d5404360]91 </listitem>
92 </itemizedlist>
93
94 <bridgehead renderas="sect3">GnuTLS Dependencies</bridgehead>
95
96 <bridgehead renderas="sect4">Required</bridgehead>
[3ee626e]97 <para role="required">
98 <xref linkend="nettle"/>
99 </para>
[d5404360]100
[5eaf9af8]101 <bridgehead renderas="sect4">Recommended</bridgehead>
102 <para role="recommended">
[74239ce]103 <xref linkend="cacerts"/>,
[c805117a]104 <xref linkend="libunistring"/>,
105 <xref linkend="libtasn1"/>, and
[74239ce]106 <xref linkend="p11-kit"/>
[5eaf9af8]107 </para>
108
[d5404360]109 <bridgehead renderas="sect4">Optional</bridgehead>
[0c6c35d]110 <para role="optional">
[b9abcb5]111 <xref linkend="doxygen"/>,
[0c6c35d]112 <xref linkend="gtk-doc"/>,
[c202a254]113 <xref linkend="guile"/>,
[4412abb2]114 <xref linkend="libidn"/> or
[531f138]115 <xref linkend="libidn2"/>
[dd7d9b0]116 <xref linkend="net-tools"/> (used during the test suite),
[b9abcb5]117 <xref linkend="texlive"/> or <xref linkend="tl-installer"/>,
[6c6990c]118 <xref linkend="unbound"/> (to build the DANE library),
[ffa3d4e]119 <xref linkend="valgrind"/> (used during the test suite),
[8dfc5c3]120 <ulink url="&gnu-http;/autogen/">autogen</ulink>,
[4412abb2]121 <ulink url="https://cmocka.org/">cmocka</ulink> and
122 <ulink url="http://ftp.debian.org/debian/pool/main/d/datefudge/">datefudge</ulink> (used during the test suite if the DANE library is built), and
[8dfc5c3]123 <ulink url="&sourceforge-dl;/trousers/">Trousers</ulink> (Trusted Platform Module support)
[3ee626e]124 </para>
[d5404360]125
[d224244f]126 <note><para>
[3ee626e]127 Note that if you do not install <xref linkend="libtasn1"/>, an older
128 version shipped in the <application>GnuTLS</application> tarball will be
129 used instead.
[d224244f]130 </para></note>
[38b68055]131
[d5404360]132 <para condition="html" role="usernotes">User Notes:
[5eaf9af8]133 <ulink url="&blfs-wiki;/gnutls"/>
134 </para>
[d5404360]135 </sect2>
136
137 <sect2 role="installation">
138 <title>Installation of GnuTLS</title>
139
[3ee626e]140 <para>
141 Install <application>GnuTLS</application> by running the
142 following commands:
143 </para>
[d5404360]144
[1c8a066f]145<screen><userinput>./configure --prefix=/usr \
[1ac799b]146 --with-default-trust-store-pkcs11="pkcs11:" &amp;&amp;
[d5404360]147make</userinput></screen>
148
[3ee626e]149 <para>
[3990b6ae]150 To test the results, issue: <command>make check</command>. If a prior
[29f710e]151 version of <application>GnuTLS</application> (or the same version but
[f586237]152 without all of the recommended dependencies) has been installed, some
[29f710e]153 tests may fail. If <filename>/usr/lib/libgnutls.so</filename> and the
154 target of that symlink are moved or renamed so that they cannot be found,
155 all tests should pass and the install procedure will restore
156 <filename>libgnutls.so</filename> and the versioned library it points to.
[3ee626e]157 </para>
[d5404360]158
[3ee626e]159 <para>
160 Now, as the <systemitem class="username">root</systemitem>
161 user:
162 </para>
[d5404360]163
[73d97caf]164<screen role="root"><userinput>make install</userinput></screen>
[d5404360]165
[3ee626e]166 <para>
[dd3d87b]167 If you passed <option>--enable-gtk-doc</option> to the
168 <command>configure</command> script, the API will automatically be
169 installed. Otherwise, if desired, you can still install the API
[b9abcb5]170 documentation to the <filename
171 class="directory">/usr/share/gtk-doc/html/gnutls</filename> directory
[dd3d87b]172 using the following command as the <systemitem
173 class="username">root</systemitem> user:
[3ee626e]174 </para>
[2e81579]175
176<screen role="root"><userinput>make -C doc/reference install-data-local</userinput></screen>
177
[d5404360]178 </sect2>
179
[d309b21]180 <sect2 role="commands">
181 <title>Command Explanations</title>
182
[4c39aff]183 <para>
[1ac799b]184 <parameter>--with-default-trust-store-pkcs11="pkcs11:"</parameter>: This
185 switch tells gnutls to use the PKCS #11 trust store as the default trust.
186 Omit this switch if <xref linkend="p11-kit"/> is not installed.
187 </para>
188
189 <para>
190 <option>--with-default-trust-store-file=/etc/ssl/ca-bundle.crt</option>:
[4c39aff]191 This switch tells <command>configure</command> where to find the
[1ac799b]192 legacy CA certificate bundle and to use it instead of PKCS #11 module
193 by default. Use this if <xref linkend="p11-kit"/> is not installed.
[4c39aff]194 </para>
195
[e05cd03f]196 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
[5eaf9af8]197 href="../../xincludes/gtk-doc-rebuild.xml"/>
[d309b21]198
[b9abcb5]199 <para>
200 <option>--enable-openssl-compatibility</option>:
[74239ce]201 Use this switch if you wish to build the OpenSSL compatibility library.
202 </para>
203
204 <para>
205 <option>--without-p11-kit</option>: use this switch if you have not
206 installed <application>p11-kit</application>.
[b9abcb5]207 </para>
208
[c805117a]209 <para>
210 <option>--with-included-unistring</option>: uses the bundled version of
211 libunistring, instead of the system one. Use this switch if you have not
212 installed <xref linkend="libunistring"/>.
213 </para>
214
[d309b21]215 </sect2>
216
[d5404360]217 <sect2 role="content">
218 <title>Contents</title>
219
220 <segmentedlist>
221 <segtitle>Installed Programs</segtitle>
222 <segtitle>Installed Libraries</segtitle>
[32dfb13c]223 <segtitle>Installed Directories</segtitle>
[d5404360]224
225 <seglistitem>
[3ee626e]226 <seg>
[495703a]227 certtool, danetool, gnutls-cli, gnutls-cli-debug,
[c202a254]228 gnutls-serv, ocsptool, p11tool, psktool, and srptool
[3ee626e]229 </seg>
230 <seg>
[ac55e029]231 libgnutls.so, libgnutls-dane.so, libgnutlsxx.so,
[fa30d84]232 libgnutls-openssl.so (optional), and
233 /usr/lib/guile/2.2/guile-gnutls-v-2.so
[3ee626e]234 </seg>
235 <seg>
[fa30d84]236 /usr/{include,share/gtk-doc/html,share/guile/site/2.2}/gnutls
[3ee626e]237 </seg>
[d5404360]238 </seglistitem>
239 </segmentedlist>
240
241 <variablelist>
242 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
243 <?dbfo list-presentation="list"?>
244 <?dbhtml list-presentation="table"?>
245
246 <varlistentry id="certtool">
247 <term><command>certtool</command></term>
248 <listitem>
[3ee626e]249 <para>
250 is used to generate X.509 certificates, certificate requests,
251 and private keys.
252 </para>
[d5404360]253 <indexterm zone="gnutls certtool">
254 <primary sortas="b-certtool">certtool</primary>
255 </indexterm>
256 </listitem>
257 </varlistentry>
[a5c54e0]258
[4c39aff]259 <varlistentry id="danetool">
260 <term><command>danetool</command></term>
261 <listitem>
262 <para>
263 is a tool used to generate and check DNS resource records
264 for the DANE protocol.
265 </para>
266 <indexterm zone="gnutls danetool">
267 <primary sortas="b-danetool">danetool</primary>
268 </indexterm>
269 </listitem>
270 </varlistentry>
271
[d5404360]272 <varlistentry id="gnutls-cli">
273 <term><command>gnutls-cli</command></term>
274 <listitem>
[3ee626e]275 <para>
276 is a simple client program to set up a TLS connection to some
277 other computer.
278 </para>
[d5404360]279 <indexterm zone="gnutls gnutls-cli">
280 <primary sortas="b-gnutls-cli">gnutls-cli</primary>
281 </indexterm>
282 </listitem>
283 </varlistentry>
284
285 <varlistentry id="gnutls-cli-debug">
286 <term><command>gnutls-cli-debug</command></term>
287 <listitem>
[3ee626e]288 <para>
289 is a simple client program to set up a TLS connection to some
290 other computer and produces very verbose progress results.
291 </para>
[d5404360]292 <indexterm zone="gnutls gnutls-cli-debug">
293 <primary sortas="b-gnutls-cli-debug">gnutls-cli-debug</primary>
294 </indexterm>
295 </listitem>
296 </varlistentry>
297
298 <varlistentry id="gnutls-serv">
299 <term><command>gnutls-serv</command></term>
300 <listitem>
[3ee626e]301 <para>
302 is a simple server program that listens to incoming TLS
303 connections.
304 </para>
[d5404360]305 <indexterm zone="gnutls gnutls-serv">
306 <primary sortas="b-gnutls-serv">gnutls-serv</primary>
307 </indexterm>
308 </listitem>
309 </varlistentry>
310
[546b042]311 <varlistentry id="ocsptool">
312 <term><command>ocsptool</command></term>
313 <listitem>
[3ee626e]314 <para>
[0d7900a]315 is a program that can parse and print information about OCSP
[3ee626e]316 requests/responses, generate requests and verify responses.
317 </para>
[546b042]318 <indexterm zone="gnutls ocsptool">
319 <primary sortas="b-ocsptool">ocsptool</primary>
320 </indexterm>
321 </listitem>
322 </varlistentry>
323
324 <varlistentry id="p11tool">
325 <term><command>p11tool</command></term>
326 <listitem>
[3ee626e]327 <para>
328 is a program that allows handling data from PKCS #11 smart cards
329 and security modules.
330 </para>
[546b042]331 <indexterm zone="gnutls p11tool">
332 <primary sortas="b-p11tool">p11tool</primary>
333 </indexterm>
334 </listitem>
335 </varlistentry>
336
[d5404360]337 <varlistentry id="psktool">
338 <term><command>psktool</command></term>
339 <listitem>
[3ee626e]340 <para>
341 is a simple program that generates random keys for use with TLS-PSK.
342 </para>
[d5404360]343 <indexterm zone="gnutls psktool">
344 <primary sortas="b-psktool">psktool</primary>
345 </indexterm>
346 </listitem>
347 </varlistentry>
348
349 <varlistentry id="srptool">
350 <term><command>srptool</command></term>
351 <listitem>
[3ee626e]352 <para>
353 is a simple program that emulates the programs in the Stanford
354 SRP (Secure Remote Password) libraries using GnuTLS.
355 </para>
[d5404360]356 <indexterm zone="gnutls srptool">
357 <primary sortas="b-srptool">srptool</primary>
358 </indexterm>
359 </listitem>
360 </varlistentry>
361
362 <varlistentry id="libgnutls">
[73d97caf]363 <term><filename class="libraryfile">libgnutls.so</filename></term>
[d5404360]364 <listitem>
[3ee626e]365 <para>
366 contains the core API functions and X.509 certificate API functions.
367 </para>
[d5404360]368 <indexterm zone="gnutls libgnutls">
[5eaf9af8]369 <primary sortas="c-libgnutls">libgnutls.so</primary>
[d5404360]370 </indexterm>
371 </listitem>
372 </varlistentry>
373
374 </variablelist>
375
376 </sect2>
377
378</sect1>
Note: See TracBrowser for help on using the repository browser.