124
147
  <refsect1 id="description">
 
125
148
    <title>DESCRIPTION</title>
 
127
 
      <command>&COMMANDNAME;</command> is a client program that
 
128
 
      communicates with <citerefentry><refentrytitle
 
129
 
      >mandos</refentrytitle><manvolnum>8</manvolnum></citerefentry>
 
130
 
      to get a password.  It uses IPv6 link-local addresses to get
 
131
 
      network connectivity, Zeroconf to find the server, and TLS with
 
132
 
      an OpenPGP key to ensure authenticity and confidentiality.  It
 
133
 
      keeps running, trying all servers on the network, until it
 
134
 
      receives a satisfactory reply.
 
137
 
      This program is not meant to be run directly; it is really meant
 
138
 
      to run as a plugin of the <application>Mandos</application>
 
139
 
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
 
140
 
      <manvolnum>8mandos</manvolnum></citerefentry>, which runs in the
 
141
 
      initial <acronym>RAM</acronym> disk environment because it is
 
142
 
      specified as a <quote>keyscript</quote> in the <citerefentry>
 
143
 
      <refentrytitle>crypttab</refentrytitle><manvolnum>5</manvolnum>
 
144
 
      </citerefentry> file.
 
148
 
  <refsect1 id="purpose">
 
149
 
    <title>PURPOSE</title>
 
151
 
      The purpose of this is to enable <emphasis>remote and unattended
 
152
 
      rebooting</emphasis> of client host computer with an
 
153
 
      <emphasis>encrypted root file system</emphasis>.  See <xref
 
154
 
      linkend="overview"/> for details.
 
 
150
      <command>&COMMANDNAME;</command> is a mandos plugin that works
 
 
151
      like a client program that through avahi detects mandos servers,
 
 
152
      sets up a gnutls connect and request a encrypted password. Any
 
 
153
      passwords given is automaticly decrypted and passed to
 
158
158
  <refsect1 id="options">
 
159
159
    <title>OPTIONS</title>
 
161
 
      This program is commonly not invoked from the command line; it
 
162
 
      is normally started by the <application>Mandos</application>
 
163
 
      plugin runner, see <citerefentry><refentrytitle
 
164
 
      >plugin-runner</refentrytitle><manvolnum>8mandos</manvolnum>
 
165
 
      </citerefentry>.  Any command line options this program accepts
 
166
 
      are therefore normally provided by the plugin runner, and not
 
 
161
      Commonly not invoked as command lines but from configuration
 
 
162
      file of plugin runner.
 
172
 
        <term><option>--connect=<replaceable
 
173
 
        >ADDRESS</replaceable><literal>:</literal><replaceable
 
174
 
        >PORT</replaceable></option></term>
 
176
 
        <replaceable>ADDRESS</replaceable><literal>:</literal
 
177
 
        ><replaceable>PORT</replaceable></option></term>
 
180
 
            Do not use Zeroconf to locate servers.  Connect directly
 
181
 
            to only one specified <application>Mandos</application>
 
182
 
            server.  Note that an IPv6 address has colon characters in
 
183
 
            it, so the <emphasis>last</emphasis> colon character is
 
184
 
            assumed to separate the address from the port number.
 
187
 
            This option is normally only useful for testing and
 
194
 
        <term><option>--keydir=<replaceable
 
195
 
        >DIRECTORY</replaceable></option></term>
 
197
 
        <replaceable>DIRECTORY</replaceable></option></term>
 
200
 
            Directory to read the OpenPGP key files
 
201
 
            <filename>pubkey.txt</filename> and
 
202
 
            <filename>seckey.txt</filename> from.  The default is
 
203
 
            <filename>/conf/conf.d/mandos</filename> (in the initial
 
204
 
            <acronym>RAM</acronym> disk environment).
 
210
 
        <term><option>--interface=
 
211
 
        <replaceable>NAME</replaceable></option></term>
 
213
 
        <replaceable>NAME</replaceable></option></term>
 
216
 
            Network interface that will be brought up and scanned for
 
217
 
            Mandos servers to connect to.  The default it
 
218
 
            <quote><literal>eth0</literal></quote>.
 
224
 
        <term><option>--pubkey=<replaceable
 
225
 
        >FILE</replaceable></option></term>
 
227
 
        <replaceable>FILE</replaceable></option></term>
 
230
 
            OpenPGP public key file base name.  This will be combined
 
231
 
            with the directory from the <option>--keydir</option>
 
232
 
            option to form an absolute file name.  The default name is
 
233
 
            <quote><literal>pubkey.txt</literal></quote>.
 
239
 
        <term><option>--seckey=<replaceable
 
240
 
        >FILE</replaceable></option></term>
 
242
 
        <replaceable>FILE</replaceable></option></term>
 
245
 
            OpenPGP secret key file base name.  This will be combined
 
246
 
            with the directory from the <option>--keydir</option>
 
247
 
            option to form an absolute file name.  The default name is
 
248
 
            <quote><literal>seckey.txt</literal></quote>.
 
254
 
        <term><option>--priority=<replaceable
 
255
 
        >STRING</replaceable></option></term>
 
257
 
          <xi:include href="../mandos-options.xml"
 
258
 
                      xpointer="priority"/>
 
263
 
        <term><option>--dh-bits=<replaceable
 
264
 
        >BITS</replaceable></option></term>
 
267
 
            Sets the number of bits to use for the prime number in the
 
268
 
            TLS Diffie-Hellman key exchange.  Default is 1024.
 
274
 
        <term><option>--debug</option></term>
 
277
 
            Enable debug mode.  This will enable a lot of output to
 
278
 
            standard error about what the program is doing.  The
 
279
 
            program will still perform all other functions normally.
 
282
 
            It will also enable debug mode in the Avahi and GnuTLS
 
283
 
            libraries, making them print large amounts of debugging
 
290
 
        <term><option>--help</option></term>
 
291
 
        <term><option>-?</option></term>
 
294
 
            Gives a help message about options and their meanings.
 
300
 
        <term><option>--usage</option></term>
 
303
 
            Gives a short usage message.
 
309
 
        <term><option>--version</option></term>
 
310
 
        <term><option>-V</option></term>
 
313
 
            Prints the program version.
 
 
167
        <term><literal>-c</literal>, <literal>--connect=<replaceable>
 
 
168
        IP</replaceable></literal></term>
 
 
171
            Connect directly to a specified mandos server
 
 
177
        <term><literal>-d</literal>, <literal>--keydir=<replaceable>
 
 
178
        KEYDIR</replaceable></literal></term>
 
 
181
            Directory where the openpgp keyring is
 
 
187
        <term><literal>-i</literal>, <literal>--interface=
 
 
188
        <replaceable>INTERFACE</replaceable></literal></term>
 
 
191
            Interface that Avahi will conntect through
 
 
197
        <term><literal>-p</literal>, <literal>--pubkey=<replaceable>
 
 
198
        PUBKEY</replaceable></literal></term>
 
 
201
            Public openpgp key for gnutls authentication
 
 
207
        <term><literal>-s</literal>, <literal>--seckey=<replaceable>
 
 
208
        SECKEY</replaceable></literal></term>
 
 
211
            Secret openpgp key for gnutls authentication
 
 
217
        <term><literal>--priority=<replaceable>PRIORITY</replaceable>
 
 
227
        <term><literal>--dh-bits=<replaceable>BITS</replaceable>
 
 
231
            dh-bits to use in gnutls communication
 
 
237
        <term><literal>--debug</literal></term>
 
 
246
        <term><literal>-?</literal>, <literal>--help</literal></term>
 
 
255
        <term><literal>--usage</literal></term>
 
 
258
            Gives a short usage message
 
 
264
        <term><literal>-V</literal>, <literal>--version</literal></term>
 
 
267
            Prints the program version
 
320
 
  <refsect1 id="overview">
 
321
 
    <title>OVERVIEW</title>
 
322
 
    <xi:include href="../overview.xml"/>
 
324
 
      This program is the client part.  It is a plugin started by
 
325
 
      <citerefentry><refentrytitle>plugin-runner</refentrytitle>
 
326
 
      <manvolnum>8mandos</manvolnum></citerefentry> which will run in
 
327
 
      an initial <acronym>RAM</acronym> disk environment.
 
330
 
      This program could, theoretically, be used as a keyscript in
 
331
 
      <filename>/etc/crypttab</filename>, but it would then be
 
332
 
      impossible to enter the encrypted root disk password at the
 
333
 
      console, since this program does not read from the console at
 
334
 
      all.  This is why a separate plugin does that, which will be run
 
335
 
      in parallell to this one.
 
339
274
  <refsect1 id="exit_status">
 
340
275
    <title>EXIT STATUS</title>
 
342
 
      This program will exit with a successful (zero) exit status if a
 
343
 
      server could be found and the password received from it could be
 
344
 
      successfully decrypted and output on standard output.  The
 
345
 
      program will exit with a non-zero exit status only if a critical
 
346
 
      error occurs.  Otherwise, it will forever connect to new
 
347
 
      <application>Mandosservers</application> servers as they appear,
 
348
 
      trying to get a decryptable password.
 
352
280
  <refsect1 id="environment">
 
353
281
    <title>ENVIRONMENT</title>
 
355
 
      This program does not use any environment variables, not even
 
356
 
      the ones provided by <citerefentry><refentrytitle
 
357
 
      >cryptsetup</refentrytitle><manvolnum>8</manvolnum>
 
362
286
  <refsect1 id="file">
 
363
287
    <title>FILES</title>