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