/mandos/trunk

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/trunk
129 by Teddy Hogeborn
* mandos-clients.conf.xml: Changed all single quotes to double quotes
1
<?xml version="1.0" encoding="UTF-8"?>
24.1.23 by Björn Påhlsson
Added manual pages for:
2
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3
	"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
171 by Teddy Hogeborn
Renamed "password-request" to "mandos-client".
4
<!ENTITY COMMANDNAME "mandos-client">
246 by Teddy Hogeborn
* README: Update copyright year; add "2009".
5
<!ENTITY TIMESTAMP "2009-01-04">
217 by Teddy Hogeborn
* .bzrignore: Added "man" directory (created by "make install-html").
6
<!ENTITY % common SYSTEM "../common.ent">
7
%common;
24.1.23 by Björn Påhlsson
Added manual pages for:
8
]>
9
131 by Teddy Hogeborn
* Makefile: Make all DocBook rules include legalnotice.xml as a
10
<refentry xmlns:xi="http://www.w3.org/2001/XInclude">
24.1.23 by Björn Påhlsson
Added manual pages for:
11
  <refentryinfo>
112 by Teddy Hogeborn
* mandos-clients.conf.xml (/refentry/refentryinfo/title): Changed to
12
    <title>Mandos Manual</title>
217 by Teddy Hogeborn
* .bzrignore: Added "man" directory (created by "make install-html").
13
    <!-- NWalsh’s docbook scripts use this to generate the footer: -->
112 by Teddy Hogeborn
* mandos-clients.conf.xml (/refentry/refentryinfo/title): Changed to
14
    <productname>Mandos</productname>
217 by Teddy Hogeborn
* .bzrignore: Added "man" directory (created by "make install-html").
15
    <productnumber>&version;</productnumber>
111 by Teddy Hogeborn
* mandos-clients.conf.xml (ENTITY TIMESTAMP): New. Automatically
16
    <date>&TIMESTAMP;</date>
24.1.23 by Björn Påhlsson
Added manual pages for:
17
    <authorgroup>
18
      <author>
19
	<firstname>Björn</firstname>
20
	<surname>Påhlsson</surname>
21
	<address>
22
	  <email>belorn@fukt.bsnet.se</email>
23
	</address>
24
      </author>
25
      <author>
26
	<firstname>Teddy</firstname>
27
	<surname>Hogeborn</surname>
28
	<address>
29
	  <email>teddy@fukt.bsnet.se</email>
30
	</address>
31
      </author>
32
    </authorgroup>
33
    <copyright>
34
      <year>2008</year>
246 by Teddy Hogeborn
* README: Update copyright year; add "2009".
35
      <year>2009</year>
128 by Teddy Hogeborn
* plugin-runner.xml (/refentry/refentryinfo/copyright): Split
36
      <holder>Teddy Hogeborn</holder>
37
      <holder>Björn Påhlsson</holder>
24.1.23 by Björn Påhlsson
Added manual pages for:
38
    </copyright>
131 by Teddy Hogeborn
* Makefile: Make all DocBook rules include legalnotice.xml as a
39
    <xi:include href="../legalnotice.xml"/>
24.1.23 by Björn Påhlsson
Added manual pages for:
40
  </refentryinfo>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
41
  
24.1.23 by Björn Påhlsson
Added manual pages for:
42
  <refmeta>
43
    <refentrytitle>&COMMANDNAME;</refentrytitle>
44
    <manvolnum>8mandos</manvolnum>
45
  </refmeta>
46
  
47
  <refnamediv>
48
    <refname><command>&COMMANDNAME;</command></refname>
49
    <refpurpose>
172 by Teddy Hogeborn
* plugins.d/mandos-client.xml (NAME, OVERVIEW, EXIT STATUS): Improved
50
      Client for <application>Mandos</application>
24.1.23 by Björn Påhlsson
Added manual pages for:
51
    </refpurpose>
52
  </refnamediv>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
53
  
24.1.23 by Björn Påhlsson
Added manual pages for:
54
  <refsynopsisdiv>
55
    <cmdsynopsis>
56
      <command>&COMMANDNAME;</command>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
57
      <group>
58
	<arg choice="plain"><option>--connect
156 by Teddy Hogeborn
* mandos-clients.conf.xml (OPTIONS): Improved spelling.
59
	<replaceable>ADDRESS</replaceable><literal>:</literal
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
60
	><replaceable>PORT</replaceable></option></arg>
61
	<arg choice="plain"><option>-c
156 by Teddy Hogeborn
* mandos-clients.conf.xml (OPTIONS): Improved spelling.
62
	<replaceable>ADDRESS</replaceable><literal>:</literal
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
63
	><replaceable>PORT</replaceable></option></arg>
64
      </group>
65
      <sbr/>
66
      <group>
67
	<arg choice="plain"><option>--interface
68
	<replaceable>NAME</replaceable></option></arg>
69
	<arg choice="plain"><option>-i
70
	<replaceable>NAME</replaceable></option></arg>
71
      </group>
72
      <sbr/>
73
      <group>
74
	<arg choice="plain"><option>--pubkey
75
	<replaceable>FILE</replaceable></option></arg>
76
	<arg choice="plain"><option>-p
77
	<replaceable>FILE</replaceable></option></arg>
78
      </group>
79
      <sbr/>
80
      <group>
81
	<arg choice="plain"><option>--seckey
82
	<replaceable>FILE</replaceable></option></arg>
83
	<arg choice="plain"><option>-s
84
	<replaceable>FILE</replaceable></option></arg>
85
      </group>
86
      <sbr/>
87
      <arg>
88
	<option>--priority <replaceable>STRING</replaceable></option>
89
      </arg>
90
      <sbr/>
91
      <arg>
92
	<option>--dh-bits <replaceable>BITS</replaceable></option>
93
      </arg>
94
      <sbr/>
95
      <arg>
96
	<option>--debug</option>
97
      </arg>
98
    </cmdsynopsis>
99
    <cmdsynopsis>
100
      <command>&COMMANDNAME;</command>
101
      <group choice="req">
129 by Teddy Hogeborn
* mandos-clients.conf.xml: Changed all single quotes to double quotes
102
	<arg choice="plain"><option>--help</option></arg>
103
	<arg choice="plain"><option>-?</option></arg>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
104
      </group>
105
    </cmdsynopsis>
106
    <cmdsynopsis>
107
      <command>&COMMANDNAME;</command>
129 by Teddy Hogeborn
* mandos-clients.conf.xml: Changed all single quotes to double quotes
108
      <arg choice="plain"><option>--usage</option></arg>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
109
    </cmdsynopsis>
110
    <cmdsynopsis>
111
      <command>&COMMANDNAME;</command>
112
      <group choice="req">
129 by Teddy Hogeborn
* mandos-clients.conf.xml: Changed all single quotes to double quotes
113
	<arg choice="plain"><option>--version</option></arg>
114
	<arg choice="plain"><option>-V</option></arg>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
115
      </group>
116
    </cmdsynopsis>
24.1.23 by Björn Påhlsson
Added manual pages for:
117
  </refsynopsisdiv>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
118
  
24.1.23 by Björn Påhlsson
Added manual pages for:
119
  <refsect1 id="description">
120
    <title>DESCRIPTION</title>
121
    <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
122
      <command>&COMMANDNAME;</command> is a client program that
123
      communicates with <citerefentry><refentrytitle
124
      >mandos</refentrytitle><manvolnum>8</manvolnum></citerefentry>
125
      to get a password.  It uses IPv6 link-local addresses to get
145 by Teddy Hogeborn
* plugins.d/password-request.xml (DESCRIPTION): Improved wording.
126
      network connectivity, Zeroconf to find servers, and TLS with an
127
      OpenPGP key to ensure authenticity and confidentiality.  It
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
128
      keeps running, trying all servers on the network, until it
156 by Teddy Hogeborn
* mandos-clients.conf.xml (OPTIONS): Improved spelling.
129
      receives a satisfactory reply or a TERM signal is received.
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
130
    </para>
131
    <para>
132
      This program is not meant to be run directly; it is really meant
133
      to run as a plugin of the <application>Mandos</application>
134
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
135
      <manvolnum>8mandos</manvolnum></citerefentry>, which runs in the
136
      initial <acronym>RAM</acronym> disk environment because it is
137
      specified as a <quote>keyscript</quote> in the <citerefentry>
138
      <refentrytitle>crypttab</refentrytitle><manvolnum>5</manvolnum>
139
      </citerefentry> file.
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
140
    </para>
141
  </refsect1>
142
  
143
  <refsect1 id="purpose">
144
    <title>PURPOSE</title>
145
    <para>
146
      The purpose of this is to enable <emphasis>remote and unattended
147
      rebooting</emphasis> of client host computer with an
148
      <emphasis>encrypted root file system</emphasis>.  See <xref
149
      linkend="overview"/> for details.
150
    </para>
151
  </refsect1>
152
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
153
  <refsect1 id="options">
154
    <title>OPTIONS</title>
155
    <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
156
      This program is commonly not invoked from the command line; it
157
      is normally started by the <application>Mandos</application>
158
      plugin runner, see <citerefentry><refentrytitle
159
      >plugin-runner</refentrytitle><manvolnum>8mandos</manvolnum>
160
      </citerefentry>.  Any command line options this program accepts
161
      are therefore normally provided by the plugin runner, and not
162
      directly.
24.1.55 by Björn Påhlsson
updated some partial manual pages
163
    </para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
164
    
24.1.23 by Björn Påhlsson
Added manual pages for:
165
    <variablelist>
166
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
167
	<term><option>--connect=<replaceable
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
168
	>ADDRESS</replaceable><literal>:</literal><replaceable
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
169
	>PORT</replaceable></option></term>
170
	<term><option>-c
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
171
	<replaceable>ADDRESS</replaceable><literal>:</literal
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
172
	><replaceable>PORT</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
173
	<listitem>
174
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
175
	    Do not use Zeroconf to locate servers.  Connect directly
176
	    to only one specified <application>Mandos</application>
177
	    server.  Note that an IPv6 address has colon characters in
178
	    it, so the <emphasis>last</emphasis> colon character is
179
	    assumed to separate the address from the port number.
180
	  </para>
181
	  <para>
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
182
	    This option is normally only useful for testing and
183
	    debugging.
24.1.23 by Björn Påhlsson
Added manual pages for:
184
	  </para>
185
	</listitem>
186
      </varlistentry>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
187
      
24.1.23 by Björn Påhlsson
Added manual pages for:
188
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
189
	<term><option>--interface=
190
	<replaceable>NAME</replaceable></option></term>
191
	<term><option>-i
192
	<replaceable>NAME</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
193
	<listitem>
194
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
195
	    Network interface that will be brought up and scanned for
196
	    Mandos servers to connect to.  The default it
197
	    <quote><literal>eth0</literal></quote>.
24.1.23 by Björn Påhlsson
Added manual pages for:
198
	  </para>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
199
	  <para>
200
	    If the <option>--connect</option> option is used, this
201
	    specifies the interface to use to connect to the address
202
	    given.
203
	  </para>
24.1.23 by Björn Påhlsson
Added manual pages for:
204
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
205
      </varlistentry>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
206
      
24.1.23 by Björn Påhlsson
Added manual pages for:
207
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
208
	<term><option>--pubkey=<replaceable
209
	>FILE</replaceable></option></term>
210
	<term><option>-p
211
	<replaceable>FILE</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
212
	<listitem>
213
	  <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
214
	    OpenPGP public key file name.  The default name is
215
	    <quote><filename>/conf/conf.d/mandos/pubkey.txt</filename
216
	    ></quote>.
24.1.23 by Björn Påhlsson
Added manual pages for:
217
	  </para>
218
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
219
      </varlistentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
220
      
24.1.23 by Björn Påhlsson
Added manual pages for:
221
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
222
	<term><option>--seckey=<replaceable
223
	>FILE</replaceable></option></term>
224
	<term><option>-s
225
	<replaceable>FILE</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
226
	<listitem>
227
	  <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
228
	    OpenPGP secret key file name.  The default name is
229
	    <quote><filename>/conf/conf.d/mandos/seckey.txt</filename
230
	    ></quote>.
24.1.23 by Björn Påhlsson
Added manual pages for:
231
	  </para>
232
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
233
      </varlistentry>
24.1.23 by Björn Påhlsson
Added manual pages for:
234
      
235
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
236
	<term><option>--priority=<replaceable
237
	>STRING</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
238
	<listitem>
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
239
	  <xi:include href="../mandos-options.xml"
240
		      xpointer="priority"/>
24.1.23 by Björn Påhlsson
Added manual pages for:
241
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
242
      </varlistentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
243
      
24.1.23 by Björn Påhlsson
Added manual pages for:
244
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
245
	<term><option>--dh-bits=<replaceable
246
	>BITS</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
247
	<listitem>
248
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
249
	    Sets the number of bits to use for the prime number in the
250
	    TLS Diffie-Hellman key exchange.  Default is 1024.
24.1.23 by Björn Påhlsson
Added manual pages for:
251
	  </para>
252
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
253
      </varlistentry>
24.1.23 by Björn Påhlsson
Added manual pages for:
254
      
255
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
256
	<term><option>--debug</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
257
	<listitem>
258
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
259
	    Enable debug mode.  This will enable a lot of output to
260
	    standard error about what the program is doing.  The
261
	    program will still perform all other functions normally.
262
	  </para>
263
	  <para>
264
	    It will also enable debug mode in the Avahi and GnuTLS
265
	    libraries, making them print large amounts of debugging
266
	    output.
24.1.23 by Björn Påhlsson
Added manual pages for:
267
	  </para>
268
	</listitem>
269
      </varlistentry>
270
      
271
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
272
	<term><option>--help</option></term>
273
	<term><option>-?</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
274
	<listitem>
275
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
276
	    Gives a help message about options and their meanings.
24.1.23 by Björn Påhlsson
Added manual pages for:
277
	  </para>
278
	</listitem>
279
      </varlistentry>
280
      
281
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
282
	<term><option>--usage</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
283
	<listitem>
284
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
285
	    Gives a short usage message.
24.1.23 by Björn Påhlsson
Added manual pages for:
286
	  </para>
287
	</listitem>
288
      </varlistentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
289
      
24.1.23 by Björn Påhlsson
Added manual pages for:
290
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
291
	<term><option>--version</option></term>
292
	<term><option>-V</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
293
	<listitem>
294
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
295
	    Prints the program version.
24.1.23 by Björn Påhlsson
Added manual pages for:
296
	  </para>
297
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
298
      </varlistentry>
24.1.23 by Björn Påhlsson
Added manual pages for:
299
    </variablelist>
300
  </refsect1>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
301
  
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
302
  <refsect1 id="overview">
303
    <title>OVERVIEW</title>
304
    <xi:include href="../overview.xml"/>
305
    <para>
306
      This program is the client part.  It is a plugin started by
307
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
308
      <manvolnum>8mandos</manvolnum></citerefentry> which will run in
309
      an initial <acronym>RAM</acronym> disk environment.
310
    </para>
311
    <para>
312
      This program could, theoretically, be used as a keyscript in
313
      <filename>/etc/crypttab</filename>, but it would then be
144 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Improved wording.
314
      impossible to enter a password for the encrypted root disk at
315
      the console, since this program does not read from the console
172 by Teddy Hogeborn
* plugins.d/mandos-client.xml (NAME, OVERVIEW, EXIT STATUS): Improved
316
      at all.  This is why a separate plugin runner (<citerefentry>
317
      <refentrytitle>plugin-runner</refentrytitle>
318
      <manvolnum>8mandos</manvolnum></citerefentry>) is used to run
319
      both this program and others in in parallel,
320
      <emphasis>one</emphasis> of which will prompt for passwords on
321
      the system console.
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
322
    </para>
323
  </refsect1>
324
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
325
  <refsect1 id="exit_status">
326
    <title>EXIT STATUS</title>
327
    <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
328
      This program will exit with a successful (zero) exit status if a
329
      server could be found and the password received from it could be
330
      successfully decrypted and output on standard output.  The
331
      program will exit with a non-zero exit status only if a critical
332
      error occurs.  Otherwise, it will forever connect to new
144 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Improved wording.
333
      <application>Mandos</application> servers as they appear, trying
172 by Teddy Hogeborn
* plugins.d/mandos-client.xml (NAME, OVERVIEW, EXIT STATUS): Improved
334
      to get a decryptable password and print it.
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
335
    </para>
336
  </refsect1>
337
  
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
338
  <refsect1 id="environment">
339
    <title>ENVIRONMENT</title>
340
    <para>
341
      This program does not use any environment variables, not even
342
      the ones provided by <citerefentry><refentrytitle
343
      >cryptsetup</refentrytitle><manvolnum>8</manvolnum>
344
    </citerefentry>.
345
    </para>
346
  </refsect1>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
347
  
224 by Teddy Hogeborn
* mandos-keygen.xml (FILES): Fixed id to be "files", not "file".
348
  <refsect1 id="files">
24.1.55 by Björn Påhlsson
updated some partial manual pages
349
    <title>FILES</title>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
350
    <variablelist>
351
      <varlistentry>
352
	<term><filename>/conf/conf.d/mandos/pubkey.txt</filename
353
	></term>
354
	<term><filename>/conf/conf.d/mandos/seckey.txt</filename
355
	></term>
356
	<listitem>
357
	  <para>
358
	    OpenPGP public and private key files, in <quote>ASCII
359
	    Armor</quote> format.  These are the default file names,
360
	    they can be changed with the <option>--pubkey</option> and
361
	    <option>--seckey</option> options.
362
	  </para>
363
	</listitem>
364
      </varlistentry>
365
    </variablelist>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
366
  </refsect1>
24.1.55 by Björn Påhlsson
updated some partial manual pages
367
  
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
368
<!--   <refsect1 id="bugs"> -->
369
<!--     <title>BUGS</title> -->
370
<!--     <para> -->
371
<!--     </para> -->
372
<!--   </refsect1> -->
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
373
  
87 by Teddy Hogeborn
* Makefile: Bug fix: fixed creation of man pages in "plugins.d".
374
  <refsect1 id="example">
375
    <title>EXAMPLE</title>
24.1.55 by Björn Påhlsson
updated some partial manual pages
376
    <para>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
377
      Note that normally, command line options will not be given
378
      directly, but via options for the Mandos <citerefentry
379
      ><refentrytitle>plugin-runner</refentrytitle>
380
      <manvolnum>8mandos</manvolnum></citerefentry>.
24.1.55 by Björn Påhlsson
updated some partial manual pages
381
    </para>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
382
    <informalexample>
383
      <para>
384
	Normal invocation needs no options, if the network interface
385
	is <quote>eth0</quote>:
386
      </para>
387
      <para>
388
	<userinput>&COMMANDNAME;</userinput>
389
      </para>
390
    </informalexample>
391
    <informalexample>
392
      <para>
158 by Teddy Hogeborn
* plugins.d/password-request.xml (EXAMPLE): Improved wording.
393
	Search for Mandos servers (and connect to them) using another
394
	interface:
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
395
      </para>
396
      <para>
397
	<!-- do not wrap this line -->
398
	<userinput>&COMMANDNAME; --interface eth1</userinput>
399
      </para>
400
    </informalexample>
401
    <informalexample>
402
      <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
403
	Run in debug mode, and use a custom key:
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
404
      </para>
405
      <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
406
407
<!-- do not wrap this line -->
408
<userinput>&COMMANDNAME; --debug --pubkey keydir/pubkey.txt --seckey keydir/seckey.txt</userinput>
409
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
410
      </para>
411
    </informalexample>
412
    <informalexample>
413
      <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
414
	Run in debug mode, with a custom key, and do not use Zeroconf
415
	to locate a server; connect directly to the IPv6 address
416
	<quote><systemitem class="ipaddress"
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
417
	>2001:db8:f983:bd0b:30de:ae4a:71f2:f672</systemitem></quote>,
418
	port 4711, using interface eth2:
419
      </para>
420
      <para>
421
422
<!-- do not wrap this line -->
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
423
<userinput>&COMMANDNAME; --debug --pubkey keydir/pubkey.txt --seckey keydir/seckey.txt --connect 2001:db8:f983:bd0b:30de:ae4a:71f2:f672:4711 --interface eth2</userinput>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
424
425
      </para>
426
    </informalexample>
24.1.55 by Björn Påhlsson
updated some partial manual pages
427
  </refsect1>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
428
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
429
  <refsect1 id="security">
430
    <title>SECURITY</title>
431
    <para>
147 by Teddy Hogeborn
* plugins.d/password-request.c (init_gnutls_global): Improved wording
432
      This program is set-uid to root, but will switch back to the
148 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Refer to
433
      original (and presumably non-privileged) user and group after
434
      bringing up the network interface.
147 by Teddy Hogeborn
* plugins.d/password-request.c (init_gnutls_global): Improved wording
435
    </para>
436
    <para>
437
      To use this program for its intended purpose (see <xref
438
      linkend="purpose"/>), the password for the root file system will
439
      have to be given out to be stored in a server computer, after
440
      having been encrypted using an OpenPGP key.  This encrypted data
441
      which will be stored in a server can only be decrypted by the
442
      OpenPGP key, and the data will only be given out to those
443
      clients who can prove they actually have that key.  This key,
444
      however, is stored unencrypted on the client side in its initial
445
      <acronym>RAM</acronym> disk image file system.  This is normally
446
      readable by all, but this is normally fixed during installation
447
      of this program; file permissions are set so that no-one is able
448
      to read that file.
449
    </para>
450
    <para>
451
      The only remaining weak point is that someone with physical
452
      access to the client hard drive might turn off the client
453
      computer, read the OpenPGP keys directly from the hard drive,
216 by Teddy Hogeborn
* Makefile: Add HTML rules for manual pages.
454
      and communicate with the server.  To safeguard against this, the
455
      server is supposed to notice the client disappearing and stop
456
      giving out the encrypted data.  Therefore, it is important to
457
      set the timeout and checker interval values tightly on the
458
      server.  See <citerefentry><refentrytitle
147 by Teddy Hogeborn
* plugins.d/password-request.c (init_gnutls_global): Improved wording
459
      >mandos</refentrytitle><manvolnum>8</manvolnum></citerefentry>.
460
    </para>
461
    <para>
148 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Refer to
462
      It will also help if the checker program on the server is
463
      configured to request something from the client which can not be
464
      spoofed by someone else on the network, unlike unencrypted
465
      <acronym>ICMP</acronym> echo (<quote>ping</quote>) replies.
466
    </para>
467
    <para>
468
      <emphasis>Note</emphasis>: This makes it completely insecure to
469
      have <application >Mandos</application> clients which dual-boot
470
      to another operating system which is <emphasis>not</emphasis>
471
      trusted to keep the initial <acronym>RAM</acronym> disk image
472
      confidential.
24.1.55 by Björn Påhlsson
updated some partial manual pages
473
    </para>
474
  </refsect1>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
475
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
476
  <refsect1 id="see_also">
477
    <title>SEE ALSO</title>
114 by Teddy Hogeborn
* mandos-clients.conf.xml (SEE ALSO): Alphabetized, as per
478
    <para>
148 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Refer to
479
      <citerefentry><refentrytitle>cryptsetup</refentrytitle>
480
      <manvolnum>8</manvolnum></citerefentry>,
481
      <citerefentry><refentrytitle>crypttab</refentrytitle>
482
      <manvolnum>5</manvolnum></citerefentry>,
114 by Teddy Hogeborn
* mandos-clients.conf.xml (SEE ALSO): Alphabetized, as per
483
      <citerefentry><refentrytitle>mandos</refentrytitle>
484
      <manvolnum>8</manvolnum></citerefentry>,
485
      <citerefentry><refentrytitle>password-prompt</refentrytitle>
486
      <manvolnum>8mandos</manvolnum></citerefentry>,
487
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
488
      <manvolnum>8mandos</manvolnum></citerefentry>
489
    </para>
148 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Refer to
490
    <variablelist>
491
      <varlistentry>
492
	<term>
493
	  <ulink url="http://www.zeroconf.org/">Zeroconf</ulink>
494
	</term>
495
	<listitem>
496
	  <para>
497
	    Zeroconf is the network protocol standard used for finding
498
	    Mandos servers on the local network.
499
	  </para>
500
	</listitem>
501
      </varlistentry>
502
      <varlistentry>
503
	<term>
504
	  <ulink url="http://www.avahi.org/">Avahi</ulink>
505
	</term>
506
      <listitem>
507
	<para>
508
	  Avahi is the library this program calls to find Zeroconf
509
	  services.
510
	</para>
511
      </listitem>
512
      </varlistentry>
513
      <varlistentry>
514
	<term>
515
	  <ulink url="http://www.gnu.org/software/gnutls/"
516
	  >GnuTLS</ulink>
517
	</term>
518
      <listitem>
519
	<para>
520
	  GnuTLS is the library this client uses to implement TLS for
521
	  communicating securely with the server, and at the same time
522
	  send the public OpenPGP key to the server.
523
	</para>
524
      </listitem>
525
      </varlistentry>
526
      <varlistentry>
527
	<term>
528
	  <ulink url="http://www.gnupg.org/related_software/gpgme/"
529
		 >GPGME</ulink>
530
	</term>
531
	<listitem>
532
	  <para>
533
	    GPGME is the library used to decrypt the OpenPGP data sent
534
	    by the server.
535
	  </para>
536
	</listitem>
537
      </varlistentry>
538
      <varlistentry>
539
	<term>
540
	  RFC 4291: <citetitle>IP Version 6 Addressing
541
	  Architecture</citetitle>
542
	</term>
543
	<listitem>
544
	  <variablelist>
545
	    <varlistentry>
546
	      <term>Section 2.2: <citetitle>Text Representation of
547
	      Addresses</citetitle></term>
548
	      <listitem><para/></listitem>
549
	    </varlistentry>
550
	    <varlistentry>
551
	      <term>Section 2.5.5.2: <citetitle>IPv4-Mapped IPv6
552
	      Address</citetitle></term>
553
	      <listitem><para/></listitem>
554
	    </varlistentry>
555
	    <varlistentry>
556
	    <term>Section 2.5.6, <citetitle>Link-Local IPv6 Unicast
557
	    Addresses</citetitle></term>
558
	    <listitem>
559
	      <para>
560
		This client uses IPv6 link-local addresses, which are
561
		immediately usable since a link-local addresses is
562
		automatically assigned to a network interfaces when it
563
		is brought up.
564
	      </para>
565
	    </listitem>
566
	    </varlistentry>
567
	  </variablelist>
568
	</listitem>
569
      </varlistentry>
570
      <varlistentry>
571
	<term>
572
	  RFC 4346: <citetitle>The Transport Layer Security (TLS)
573
	  Protocol Version 1.1</citetitle>
574
	</term>
575
      <listitem>
576
	<para>
577
	  TLS 1.1 is the protocol implemented by GnuTLS.
578
	</para>
579
      </listitem>
580
      </varlistentry>
581
      <varlistentry>
582
	<term>
583
	  RFC 4880: <citetitle>OpenPGP Message Format</citetitle>
584
	</term>
585
      <listitem>
586
	<para>
587
	  The data received from the server is binary encrypted
588
	  OpenPGP data.
589
	</para>
590
      </listitem>
591
      </varlistentry>
592
      <varlistentry>
593
	<term>
594
	  RFC 5081: <citetitle>Using OpenPGP Keys for Transport Layer
595
	  Security</citetitle>
596
	</term>
597
      <listitem>
598
	<para>
599
	  This is implemented by GnuTLS and used by this program so
600
	  that OpenPGP keys can be used.
601
	</para>
602
      </listitem>
603
      </varlistentry>
604
    </variablelist>
81 by Teddy Hogeborn
* Makefile (GNUTLS_CFLAGS, GNUTLS_LIBS, AVAHI_CFLAGS, AVAHI_LIBS,
605
  </refsect1>
24.1.23 by Björn Påhlsson
Added manual pages for:
606
</refentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
607
111 by Teddy Hogeborn
* mandos-clients.conf.xml (ENTITY TIMESTAMP): New. Automatically
608
<!-- Local Variables: -->
609
<!-- time-stamp-start: "<!ENTITY TIMESTAMP [\"']" -->
610
<!-- time-stamp-end: "[\"']>" -->
611
<!-- time-stamp-format: "%:y-%02m-%02d" -->
612
<!-- End: -->