/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">
444 by Teddy Hogeborn
Update copyright year to "2010" wherever appropriate.
5
<!ENTITY TIMESTAMP "2010-09-26">
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>
24.1.124 by Björn Påhlsson
Added lower kernel loglevel to reduce clutter on system console.
96
	<option>--delay <replaceable>SECONDS</replaceable></option>
97
      </arg>
98
      <sbr/>
99
      <arg>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
100
	<option>--debug</option>
101
      </arg>
102
    </cmdsynopsis>
103
    <cmdsynopsis>
104
      <command>&COMMANDNAME;</command>
105
      <group choice="req">
129 by Teddy Hogeborn
* mandos-clients.conf.xml: Changed all single quotes to double quotes
106
	<arg choice="plain"><option>--help</option></arg>
107
	<arg choice="plain"><option>-?</option></arg>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
108
      </group>
109
    </cmdsynopsis>
110
    <cmdsynopsis>
111
      <command>&COMMANDNAME;</command>
129 by Teddy Hogeborn
* mandos-clients.conf.xml: Changed all single quotes to double quotes
112
      <arg choice="plain"><option>--usage</option></arg>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
113
    </cmdsynopsis>
114
    <cmdsynopsis>
115
      <command>&COMMANDNAME;</command>
116
      <group choice="req">
129 by Teddy Hogeborn
* mandos-clients.conf.xml: Changed all single quotes to double quotes
117
	<arg choice="plain"><option>--version</option></arg>
118
	<arg choice="plain"><option>-V</option></arg>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
119
      </group>
120
    </cmdsynopsis>
24.1.23 by Björn Påhlsson
Added manual pages for:
121
  </refsynopsisdiv>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
122
  
24.1.23 by Björn Påhlsson
Added manual pages for:
123
  <refsect1 id="description">
124
    <title>DESCRIPTION</title>
125
    <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
126
      <command>&COMMANDNAME;</command> is a client program that
127
      communicates with <citerefentry><refentrytitle
128
      >mandos</refentrytitle><manvolnum>8</manvolnum></citerefentry>
285 by Teddy Hogeborn
* plugins.d/mandos-client.c (main): Use remove() instead of unlink(),
129
      to get a password.  In slightly more detail, this client program
130
      brings up a network interface, uses the interface’s IPv6
131
      link-local address to get network connectivity, uses Zeroconf to
132
      find servers on the local network, and communicates with servers
133
      using TLS with an OpenPGP key to ensure authenticity and
134
      confidentiality.  This client program keeps running, trying all
135
      servers on the network, until it receives a satisfactory reply
136
      or a TERM signal is received.  If no servers are found, or after
137
      all servers have been tried, it waits indefinitely for new
138
      servers to appear.
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
139
    </para>
140
    <para>
141
      This program is not meant to be run directly; it is really meant
142
      to run as a plugin of the <application>Mandos</application>
143
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
144
      <manvolnum>8mandos</manvolnum></citerefentry>, which runs in the
145
      initial <acronym>RAM</acronym> disk environment because it is
146
      specified as a <quote>keyscript</quote> in the <citerefentry>
147
      <refentrytitle>crypttab</refentrytitle><manvolnum>5</manvolnum>
148
      </citerefentry> file.
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
149
    </para>
150
  </refsect1>
151
  
152
  <refsect1 id="purpose">
153
    <title>PURPOSE</title>
154
    <para>
155
      The purpose of this is to enable <emphasis>remote and unattended
156
      rebooting</emphasis> of client host computer with an
157
      <emphasis>encrypted root file system</emphasis>.  See <xref
158
      linkend="overview"/> for details.
159
    </para>
160
  </refsect1>
161
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
162
  <refsect1 id="options">
163
    <title>OPTIONS</title>
164
    <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
165
      This program is commonly not invoked from the command line; it
166
      is normally started by the <application>Mandos</application>
167
      plugin runner, see <citerefentry><refentrytitle
168
      >plugin-runner</refentrytitle><manvolnum>8mandos</manvolnum>
169
      </citerefentry>.  Any command line options this program accepts
170
      are therefore normally provided by the plugin runner, and not
171
      directly.
24.1.55 by Björn Påhlsson
updated some partial manual pages
172
    </para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
173
    
24.1.23 by Björn Påhlsson
Added manual pages for:
174
    <variablelist>
175
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
176
	<term><option>--connect=<replaceable
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
177
	>ADDRESS</replaceable><literal>:</literal><replaceable
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
178
	>PORT</replaceable></option></term>
179
	<term><option>-c
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
180
	<replaceable>ADDRESS</replaceable><literal>:</literal
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
181
	><replaceable>PORT</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
182
	<listitem>
183
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
184
	    Do not use Zeroconf to locate servers.  Connect directly
185
	    to only one specified <application>Mandos</application>
186
	    server.  Note that an IPv6 address has colon characters in
187
	    it, so the <emphasis>last</emphasis> colon character is
188
	    assumed to separate the address from the port number.
189
	  </para>
190
	  <para>
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
191
	    This option is normally only useful for testing and
192
	    debugging.
24.1.23 by Björn Påhlsson
Added manual pages for:
193
	  </para>
194
	</listitem>
195
      </varlistentry>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
196
      
24.1.23 by Björn Påhlsson
Added manual pages for:
197
      <varlistentry>
304 by Teddy Hogeborn
Four new interrelated features:
198
	<term><option>--interface=<replaceable
199
	>NAME</replaceable></option></term>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
200
	<term><option>-i
201
	<replaceable>NAME</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
202
	<listitem>
203
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
204
	    Network interface that will be brought up and scanned for
237.2.33 by teddy at bsnet
* plugins.d/mandos-client.c: An empty interface name now means to
205
	    Mandos servers to connect to.  The default is the empty
206
	    string, which will automatically choose an appropriate
207
	    interface.
24.1.23 by Björn Påhlsson
Added manual pages for:
208
	  </para>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
209
	  <para>
210
	    If the <option>--connect</option> option is used, this
211
	    specifies the interface to use to connect to the address
212
	    given.
213
	  </para>
285 by Teddy Hogeborn
* plugins.d/mandos-client.c (main): Use remove() instead of unlink(),
214
	  <para>
215
	    Note that since this program will normally run in the
216
	    initial RAM disk environment, the interface must be an
217
	    interface which exists at that stage.  Thus, the interface
218
	    can not be a pseudo-interface such as <quote>br0</quote>
219
	    or <quote>tun0</quote>; such interfaces will not exist
220
	    until much later in the boot process, and can not be used
221
	    by this program.
222
	  </para>
304 by Teddy Hogeborn
Four new interrelated features:
223
	  <para>
237.2.33 by teddy at bsnet
* plugins.d/mandos-client.c: An empty interface name now means to
224
	    <replaceable>NAME</replaceable> can be the string
225
	    <quote><literal>none</literal></quote>; this will not use
226
	    any specific interface, and will not bring up an interface
227
	    on startup.  This is not recommended, and only meant for
228
	    advanced users.
304 by Teddy Hogeborn
Four new interrelated features:
229
	  </para>
24.1.23 by Björn Påhlsson
Added manual pages for:
230
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
231
      </varlistentry>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
232
      
24.1.23 by Björn Påhlsson
Added manual pages for:
233
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
234
	<term><option>--pubkey=<replaceable
235
	>FILE</replaceable></option></term>
236
	<term><option>-p
237
	<replaceable>FILE</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
238
	<listitem>
239
	  <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
240
	    OpenPGP public key file name.  The default name is
241
	    <quote><filename>/conf/conf.d/mandos/pubkey.txt</filename
242
	    ></quote>.
24.1.23 by Björn Påhlsson
Added manual pages for:
243
	  </para>
244
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
245
      </varlistentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
246
      
24.1.23 by Björn Påhlsson
Added manual pages for:
247
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
248
	<term><option>--seckey=<replaceable
249
	>FILE</replaceable></option></term>
250
	<term><option>-s
251
	<replaceable>FILE</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
252
	<listitem>
253
	  <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
254
	    OpenPGP secret key file name.  The default name is
255
	    <quote><filename>/conf/conf.d/mandos/seckey.txt</filename
256
	    ></quote>.
24.1.23 by Björn Påhlsson
Added manual pages for:
257
	  </para>
258
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
259
      </varlistentry>
24.1.23 by Björn Påhlsson
Added manual pages for:
260
      
261
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
262
	<term><option>--priority=<replaceable
263
	>STRING</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
264
	<listitem>
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
265
	  <xi:include href="../mandos-options.xml"
266
		      xpointer="priority"/>
24.1.23 by Björn Påhlsson
Added manual pages for:
267
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
268
      </varlistentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
269
      
24.1.23 by Björn Påhlsson
Added manual pages for:
270
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
271
	<term><option>--dh-bits=<replaceable
272
	>BITS</replaceable></option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
273
	<listitem>
274
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
275
	    Sets the number of bits to use for the prime number in the
276
	    TLS Diffie-Hellman key exchange.  Default is 1024.
24.1.23 by Björn Påhlsson
Added manual pages for:
277
	  </para>
278
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
279
      </varlistentry>
24.1.124 by Björn Påhlsson
Added lower kernel loglevel to reduce clutter on system console.
280
281
      <varlistentry>
282
	<term><option>--delay=<replaceable
283
	>SECONDS</replaceable></option></term>
284
	<listitem>
285
	  <para>
286
	    After bringing the network interface up, the program waits
287
	    for the interface to arrive in a <quote>running</quote>
288
	    state before proceeding.  During this time, the kernel log
289
	    level will be lowered to reduce clutter on the system
290
	    console, alleviating any other plugins which might be
291
	    using the system console.  This option sets the upper
292
	    limit of seconds to wait.  The default is 2.5 seconds.
293
	  </para>
294
	</listitem>
295
      </varlistentry>
24.1.23 by Björn Påhlsson
Added manual pages for:
296
      
297
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
298
	<term><option>--debug</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
299
	<listitem>
300
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
301
	    Enable debug mode.  This will enable a lot of output to
302
	    standard error about what the program is doing.  The
303
	    program will still perform all other functions normally.
304
	  </para>
305
	  <para>
306
	    It will also enable debug mode in the Avahi and GnuTLS
307
	    libraries, making them print large amounts of debugging
308
	    output.
24.1.23 by Björn Påhlsson
Added manual pages for:
309
	  </para>
310
	</listitem>
311
      </varlistentry>
312
      
313
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
314
	<term><option>--help</option></term>
315
	<term><option>-?</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
316
	<listitem>
317
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
318
	    Gives a help message about options and their meanings.
24.1.23 by Björn Påhlsson
Added manual pages for:
319
	  </para>
320
	</listitem>
321
      </varlistentry>
322
      
323
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
324
	<term><option>--usage</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
325
	<listitem>
326
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
327
	    Gives a short usage message.
24.1.23 by Björn Påhlsson
Added manual pages for:
328
	  </para>
329
	</listitem>
330
      </varlistentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
331
      
24.1.23 by Björn Påhlsson
Added manual pages for:
332
      <varlistentry>
127 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Make replaceables match
333
	<term><option>--version</option></term>
334
	<term><option>-V</option></term>
24.1.23 by Björn Påhlsson
Added manual pages for:
335
	<listitem>
336
	  <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
337
	    Prints the program version.
24.1.23 by Björn Påhlsson
Added manual pages for:
338
	  </para>
339
	</listitem>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
340
      </varlistentry>
24.1.23 by Björn Påhlsson
Added manual pages for:
341
    </variablelist>
342
  </refsect1>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
343
  
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
344
  <refsect1 id="overview">
345
    <title>OVERVIEW</title>
346
    <xi:include href="../overview.xml"/>
347
    <para>
348
      This program is the client part.  It is a plugin started by
349
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
350
      <manvolnum>8mandos</manvolnum></citerefentry> which will run in
351
      an initial <acronym>RAM</acronym> disk environment.
352
    </para>
353
    <para>
354
      This program could, theoretically, be used as a keyscript in
355
      <filename>/etc/crypttab</filename>, but it would then be
144 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Improved wording.
356
      impossible to enter a password for the encrypted root disk at
357
      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
358
      at all.  This is why a separate plugin runner (<citerefentry>
359
      <refentrytitle>plugin-runner</refentrytitle>
360
      <manvolnum>8mandos</manvolnum></citerefentry>) is used to run
361
      both this program and others in in parallel,
362
      <emphasis>one</emphasis> of which will prompt for passwords on
363
      the system console.
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
364
    </para>
365
  </refsect1>
366
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
367
  <refsect1 id="exit_status">
368
    <title>EXIT STATUS</title>
369
    <para>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
370
      This program will exit with a successful (zero) exit status if a
371
      server could be found and the password received from it could be
372
      successfully decrypted and output on standard output.  The
373
      program will exit with a non-zero exit status only if a critical
374
      error occurs.  Otherwise, it will forever connect to new
144 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Improved wording.
375
      <application>Mandos</application> servers as they appear, trying
172 by Teddy Hogeborn
* plugins.d/mandos-client.xml (NAME, OVERVIEW, EXIT STATUS): Improved
376
      to get a decryptable password and print it.
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
377
    </para>
378
  </refsect1>
379
  
143 by Teddy Hogeborn
* Makefile (mandos.8): Add dependency on "overview.xml" and
380
  <refsect1 id="environment">
381
    <title>ENVIRONMENT</title>
382
    <para>
383
      This program does not use any environment variables, not even
384
      the ones provided by <citerefentry><refentrytitle
385
      >cryptsetup</refentrytitle><manvolnum>8</manvolnum>
386
    </citerefentry>.
387
    </para>
388
  </refsect1>
142 by Teddy Hogeborn
* plugins.d/password-request.c (main): Change default GnuTLS priority
389
  
224 by Teddy Hogeborn
* mandos-keygen.xml (FILES): Fixed id to be "files", not "file".
390
  <refsect1 id="files">
24.1.55 by Björn Påhlsson
updated some partial manual pages
391
    <title>FILES</title>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
392
    <variablelist>
393
      <varlistentry>
394
	<term><filename>/conf/conf.d/mandos/pubkey.txt</filename
395
	></term>
396
	<term><filename>/conf/conf.d/mandos/seckey.txt</filename
397
	></term>
398
	<listitem>
399
	  <para>
400
	    OpenPGP public and private key files, in <quote>ASCII
401
	    Armor</quote> format.  These are the default file names,
402
	    they can be changed with the <option>--pubkey</option> and
403
	    <option>--seckey</option> options.
404
	  </para>
405
	</listitem>
406
      </varlistentry>
407
    </variablelist>
118 by Teddy Hogeborn
* mandos-keygen.xml (SYNOPSIS): Fixed tags. Unify short and long
408
  </refsect1>
24.1.55 by Björn Påhlsson
updated some partial manual pages
409
  
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
410
<!--   <refsect1 id="bugs"> -->
411
<!--     <title>BUGS</title> -->
412
<!--     <para> -->
413
<!--     </para> -->
414
<!--   </refsect1> -->
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
415
  
87 by Teddy Hogeborn
* Makefile: Bug fix: fixed creation of man pages in "plugins.d".
416
  <refsect1 id="example">
417
    <title>EXAMPLE</title>
24.1.55 by Björn Påhlsson
updated some partial manual pages
418
    <para>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
419
      Note that normally, command line options will not be given
420
      directly, but via options for the Mandos <citerefentry
421
      ><refentrytitle>plugin-runner</refentrytitle>
422
      <manvolnum>8mandos</manvolnum></citerefentry>.
24.1.55 by Björn Påhlsson
updated some partial manual pages
423
    </para>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
424
    <informalexample>
425
      <para>
426
	Normal invocation needs no options, if the network interface
427
	is <quote>eth0</quote>:
428
      </para>
429
      <para>
430
	<userinput>&COMMANDNAME;</userinput>
431
      </para>
432
    </informalexample>
433
    <informalexample>
434
      <para>
158 by Teddy Hogeborn
* plugins.d/password-request.xml (EXAMPLE): Improved wording.
435
	Search for Mandos servers (and connect to them) using another
436
	interface:
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
437
      </para>
438
      <para>
439
	<!-- do not wrap this line -->
440
	<userinput>&COMMANDNAME; --interface eth1</userinput>
441
      </para>
442
    </informalexample>
443
    <informalexample>
444
      <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
445
	Run in debug mode, and use a custom key:
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
446
      </para>
447
      <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
448
449
<!-- do not wrap this line -->
450
<userinput>&COMMANDNAME; --debug --pubkey keydir/pubkey.txt --seckey keydir/seckey.txt</userinput>
451
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
452
      </para>
453
    </informalexample>
454
    <informalexample>
455
      <para>
151 by Teddy Hogeborn
* plugins.d/password-request.xml (SYNOPSYS): Removed "--keydir".
456
	Run in debug mode, with a custom key, and do not use Zeroconf
304 by Teddy Hogeborn
Four new interrelated features:
457
	to locate a server; connect directly to the IPv6 link-local
458
	address <quote><systemitem class="ipaddress"
459
	>fe80::aede:48ff:fe71:f6f2</systemitem></quote>, port 4711,
460
	using interface eth2:
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
461
      </para>
462
      <para>
463
464
<!-- do not wrap this line -->
304 by Teddy Hogeborn
Four new interrelated features:
465
<userinput>&COMMANDNAME; --debug --pubkey keydir/pubkey.txt --seckey keydir/seckey.txt --connect fe80::aede:48ff:fe71:f6f2:4711 --interface eth2</userinput>
146 by Teddy Hogeborn
* plugins.d/password-request.xml (OPTIONS): Improved wording.
466
467
      </para>
468
    </informalexample>
24.1.55 by Björn Påhlsson
updated some partial manual pages
469
  </refsect1>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
470
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
471
  <refsect1 id="security">
472
    <title>SECURITY</title>
473
    <para>
147 by Teddy Hogeborn
* plugins.d/password-request.c (init_gnutls_global): Improved wording
474
      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
475
      original (and presumably non-privileged) user and group after
476
      bringing up the network interface.
147 by Teddy Hogeborn
* plugins.d/password-request.c (init_gnutls_global): Improved wording
477
    </para>
478
    <para>
479
      To use this program for its intended purpose (see <xref
480
      linkend="purpose"/>), the password for the root file system will
481
      have to be given out to be stored in a server computer, after
482
      having been encrypted using an OpenPGP key.  This encrypted data
483
      which will be stored in a server can only be decrypted by the
484
      OpenPGP key, and the data will only be given out to those
485
      clients who can prove they actually have that key.  This key,
486
      however, is stored unencrypted on the client side in its initial
487
      <acronym>RAM</acronym> disk image file system.  This is normally
488
      readable by all, but this is normally fixed during installation
489
      of this program; file permissions are set so that no-one is able
490
      to read that file.
491
    </para>
492
    <para>
493
      The only remaining weak point is that someone with physical
494
      access to the client hard drive might turn off the client
495
      computer, read the OpenPGP keys directly from the hard drive,
216 by Teddy Hogeborn
* Makefile: Add HTML rules for manual pages.
496
      and communicate with the server.  To safeguard against this, the
497
      server is supposed to notice the client disappearing and stop
498
      giving out the encrypted data.  Therefore, it is important to
499
      set the timeout and checker interval values tightly on the
500
      server.  See <citerefentry><refentrytitle
147 by Teddy Hogeborn
* plugins.d/password-request.c (init_gnutls_global): Improved wording
501
      >mandos</refentrytitle><manvolnum>8</manvolnum></citerefentry>.
502
    </para>
503
    <para>
148 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Refer to
504
      It will also help if the checker program on the server is
505
      configured to request something from the client which can not be
506
      spoofed by someone else on the network, unlike unencrypted
507
      <acronym>ICMP</acronym> echo (<quote>ping</quote>) replies.
508
    </para>
509
    <para>
510
      <emphasis>Note</emphasis>: This makes it completely insecure to
511
      have <application >Mandos</application> clients which dual-boot
512
      to another operating system which is <emphasis>not</emphasis>
513
      trusted to keep the initial <acronym>RAM</acronym> disk image
514
      confidential.
24.1.55 by Björn Påhlsson
updated some partial manual pages
515
    </para>
516
  </refsect1>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
517
  
24.1.55 by Björn Påhlsson
updated some partial manual pages
518
  <refsect1 id="see_also">
519
    <title>SEE ALSO</title>
114 by Teddy Hogeborn
* mandos-clients.conf.xml (SEE ALSO): Alphabetized, as per
520
    <para>
148 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Refer to
521
      <citerefentry><refentrytitle>cryptsetup</refentrytitle>
522
      <manvolnum>8</manvolnum></citerefentry>,
523
      <citerefentry><refentrytitle>crypttab</refentrytitle>
524
      <manvolnum>5</manvolnum></citerefentry>,
114 by Teddy Hogeborn
* mandos-clients.conf.xml (SEE ALSO): Alphabetized, as per
525
      <citerefentry><refentrytitle>mandos</refentrytitle>
526
      <manvolnum>8</manvolnum></citerefentry>,
527
      <citerefentry><refentrytitle>password-prompt</refentrytitle>
528
      <manvolnum>8mandos</manvolnum></citerefentry>,
529
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
530
      <manvolnum>8mandos</manvolnum></citerefentry>
531
    </para>
148 by Teddy Hogeborn
* plugins.d/password-request.xml (OVERVIEW): Refer to
532
    <variablelist>
533
      <varlistentry>
534
	<term>
535
	  <ulink url="http://www.zeroconf.org/">Zeroconf</ulink>
536
	</term>
537
	<listitem>
538
	  <para>
539
	    Zeroconf is the network protocol standard used for finding
540
	    Mandos servers on the local network.
541
	  </para>
542
	</listitem>
543
      </varlistentry>
544
      <varlistentry>
545
	<term>
546
	  <ulink url="http://www.avahi.org/">Avahi</ulink>
547
	</term>
548
      <listitem>
549
	<para>
550
	  Avahi is the library this program calls to find Zeroconf
551
	  services.
552
	</para>
553
      </listitem>
554
      </varlistentry>
555
      <varlistentry>
556
	<term>
557
	  <ulink url="http://www.gnu.org/software/gnutls/"
558
	  >GnuTLS</ulink>
559
	</term>
560
      <listitem>
561
	<para>
562
	  GnuTLS is the library this client uses to implement TLS for
563
	  communicating securely with the server, and at the same time
564
	  send the public OpenPGP key to the server.
565
	</para>
566
      </listitem>
567
      </varlistentry>
568
      <varlistentry>
569
	<term>
570
	  <ulink url="http://www.gnupg.org/related_software/gpgme/"
571
		 >GPGME</ulink>
572
	</term>
573
	<listitem>
574
	  <para>
575
	    GPGME is the library used to decrypt the OpenPGP data sent
576
	    by the server.
577
	  </para>
578
	</listitem>
579
      </varlistentry>
580
      <varlistentry>
581
	<term>
582
	  RFC 4291: <citetitle>IP Version 6 Addressing
583
	  Architecture</citetitle>
584
	</term>
585
	<listitem>
586
	  <variablelist>
587
	    <varlistentry>
588
	      <term>Section 2.2: <citetitle>Text Representation of
589
	      Addresses</citetitle></term>
590
	      <listitem><para/></listitem>
591
	    </varlistentry>
592
	    <varlistentry>
593
	      <term>Section 2.5.5.2: <citetitle>IPv4-Mapped IPv6
594
	      Address</citetitle></term>
595
	      <listitem><para/></listitem>
596
	    </varlistentry>
597
	    <varlistentry>
598
	    <term>Section 2.5.6, <citetitle>Link-Local IPv6 Unicast
599
	    Addresses</citetitle></term>
600
	    <listitem>
601
	      <para>
602
		This client uses IPv6 link-local addresses, which are
603
		immediately usable since a link-local addresses is
604
		automatically assigned to a network interfaces when it
605
		is brought up.
606
	      </para>
607
	    </listitem>
608
	    </varlistentry>
609
	  </variablelist>
610
	</listitem>
611
      </varlistentry>
612
      <varlistentry>
613
	<term>
614
	  RFC 4346: <citetitle>The Transport Layer Security (TLS)
615
	  Protocol Version 1.1</citetitle>
616
	</term>
617
      <listitem>
618
	<para>
619
	  TLS 1.1 is the protocol implemented by GnuTLS.
620
	</para>
621
      </listitem>
622
      </varlistentry>
623
      <varlistentry>
624
	<term>
625
	  RFC 4880: <citetitle>OpenPGP Message Format</citetitle>
626
	</term>
627
      <listitem>
628
	<para>
629
	  The data received from the server is binary encrypted
630
	  OpenPGP data.
631
	</para>
632
      </listitem>
633
      </varlistentry>
634
      <varlistentry>
635
	<term>
636
	  RFC 5081: <citetitle>Using OpenPGP Keys for Transport Layer
637
	  Security</citetitle>
638
	</term>
639
      <listitem>
640
	<para>
641
	  This is implemented by GnuTLS and used by this program so
642
	  that OpenPGP keys can be used.
643
	</para>
644
      </listitem>
645
      </varlistentry>
646
    </variablelist>
81 by Teddy Hogeborn
* Makefile (GNUTLS_CFLAGS, GNUTLS_LIBS, AVAHI_CFLAGS, AVAHI_LIBS,
647
  </refsect1>
24.1.23 by Björn Påhlsson
Added manual pages for:
648
</refentry>
182 by Teddy Hogeborn
* Makefile (install): Use "install-client-nokey".
649
111 by Teddy Hogeborn
* mandos-clients.conf.xml (ENTITY TIMESTAMP): New. Automatically
650
<!-- Local Variables: -->
651
<!-- time-stamp-start: "<!ENTITY TIMESTAMP [\"']" -->
652
<!-- time-stamp-end: "[\"']>" -->
653
<!-- time-stamp-format: "%:y-%02m-%02d" -->
654
<!-- End: -->