/mandos/release

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/release

« back to all changes in this revision

Viewing changes to plugins.d/mandos-client.xml

* mandos: Tolerate restarting Avahi servers.  Also Changed to new
          "except x as y" exception syntax.
  (AvahiService.entry_group_state_changed_match): New; contains the
                                                  SignalMatch object.
  (AvahiService.remove): Really remove the group and the signal
                         connection, if any.
  (AvahiService.add): Always create a new group and signal connection.
  (AvahiService.cleanup): Changed to simply call remove().
  (AvahiService.server_state_changed): Handle and log more bad states.
  (AvahiService.activate): Set "follow_name_owner_changes=True" on the
                           Avahi Server proxy object.
  (ClientDBus.checked_ok): Do not return anything.
  (ClientDBus.CheckedOK): Do not return anything, as documented.
* mandos-monitor: Call D-Bus methods asynchronously.

Show diffs side-by-side

added added

removed removed

Lines of Context:
2
2
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3
3
        "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4
4
<!ENTITY COMMANDNAME "mandos-client">
5
 
<!ENTITY TIMESTAMP "2011-11-27">
 
5
<!ENTITY TIMESTAMP "2010-09-26">
6
6
<!ENTITY % common SYSTEM "../common.ent">
7
7
%common;
8
8
]>
19
19
        <firstname>Björn</firstname>
20
20
        <surname>Påhlsson</surname>
21
21
        <address>
22
 
          <email>belorn@recompile.se</email>
 
22
          <email>belorn@fukt.bsnet.se</email>
23
23
        </address>
24
24
      </author>
25
25
      <author>
26
26
        <firstname>Teddy</firstname>
27
27
        <surname>Hogeborn</surname>
28
28
        <address>
29
 
          <email>teddy@recompile.se</email>
 
29
          <email>teddy@fukt.bsnet.se</email>
30
30
        </address>
31
31
      </author>
32
32
    </authorgroup>
33
33
    <copyright>
34
34
      <year>2008</year>
35
35
      <year>2009</year>
36
 
      <year>2011</year>
37
36
      <holder>Teddy Hogeborn</holder>
38
37
      <holder>Björn Påhlsson</holder>
39
38
    </copyright>
98
97
      </arg>
99
98
      <sbr/>
100
99
      <arg>
101
 
        <option>--retry <replaceable>SECONDS</replaceable></option>
102
 
      </arg>
103
 
      <sbr/>
104
 
      <arg>
105
 
        <option>--network-hook-dir
106
 
        <replaceable>DIR</replaceable></option>
107
 
      </arg>
108
 
      <sbr/>
109
 
      <arg>
110
100
        <option>--debug</option>
111
101
      </arg>
112
102
    </cmdsynopsis>
143
133
      using TLS with an OpenPGP key to ensure authenticity and
144
134
      confidentiality.  This client program keeps running, trying all
145
135
      servers on the network, until it receives a satisfactory reply
146
 
      or a TERM signal.  After all servers have been tried, all
147
 
      servers are periodically retried.  If no servers are found it
148
 
      will wait indefinitely for new servers to appear.
149
 
    </para>
150
 
    <para>
151
 
      The network interface is selected like this: If an interface is
152
 
      specified using the <option>--interface</option> option, that
153
 
      interface is used.  Otherwise, <command>&COMMANDNAME;</command>
154
 
      will choose any interface that is up and running and is not a
155
 
      loopback interface, is not a point-to-point interface, is
156
 
      capable of broadcasting and does not have the NOARP flag (see
157
 
      <citerefentry><refentrytitle>netdevice</refentrytitle>
158
 
      <manvolnum>7</manvolnum></citerefentry>).  (If the
159
 
      <option>--connect</option> option is used, point-to-point
160
 
      interfaces and non-broadcast interfaces are accepted.)  If no
161
 
      acceptable interfaces are found, re-run the check but without
162
 
      the <quote>up and running</quote> requirement, and manually take
163
 
      the selected interface up (and later take it down on program
164
 
      exit).
165
 
    </para>
166
 
    <para>
167
 
      Before a network interface is selected, all <quote>network
168
 
      hooks</quote> are run; see <xref linkend="network-hooks"/>.
 
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.
169
139
    </para>
170
140
    <para>
171
141
      This program is not meant to be run directly; it is really meant
248
218
            can not be a pseudo-interface such as <quote>br0</quote>
249
219
            or <quote>tun0</quote>; such interfaces will not exist
250
220
            until much later in the boot process, and can not be used
251
 
            by this program, unless created by a <quote>network
252
 
            hook</quote> — see <xref linkend="network-hooks"/>.
 
221
            by this program.
253
222
          </para>
254
223
          <para>
255
224
            <replaceable>NAME</replaceable> can be the string
324
293
          </para>
325
294
        </listitem>
326
295
      </varlistentry>
327
 
 
328
 
      <varlistentry>
329
 
        <term><option>--retry=<replaceable
330
 
        >SECONDS</replaceable></option></term>
331
 
        <listitem>
332
 
          <para>
333
 
            All Mandos servers are tried repeatedly until a password
334
 
            is received.  This value specifies, in seconds, how long
335
 
            between each successive try <emphasis>for the same
336
 
            server</emphasis>.  The default is 10 seconds.
337
 
          </para>
338
 
        </listitem>
339
 
      </varlistentry>
340
 
 
341
 
      <varlistentry>
342
 
        <term><option>--network-hook-dir=<replaceable
343
 
        >DIR</replaceable></option></term>
344
 
        <listitem>
345
 
          <para>
346
 
            Network hook directory.  The default directory is
347
 
            <quote><filename class="directory"
348
 
            >/lib/mandos/network-hooks.d</filename></quote>.
349
 
          </para>
350
 
        </listitem>
351
 
      </varlistentry>
352
296
      
353
297
      <varlistentry>
354
298
        <term><option>--debug</option></term>
415
359
      <refentrytitle>plugin-runner</refentrytitle>
416
360
      <manvolnum>8mandos</manvolnum></citerefentry>) is used to run
417
361
      both this program and others in in parallel,
418
 
      <emphasis>one</emphasis> of which (<citerefentry>
419
 
      <refentrytitle>password-prompt</refentrytitle>
420
 
      <manvolnum>8mandos</manvolnum></citerefentry>) will prompt for
421
 
      passwords on the system console.
 
362
      <emphasis>one</emphasis> of which will prompt for passwords on
 
363
      the system console.
422
364
    </para>
423
365
  </refsect1>
424
366
  
429
371
      server could be found and the password received from it could be
430
372
      successfully decrypted and output on standard output.  The
431
373
      program will exit with a non-zero exit status only if a critical
432
 
      error occurs.  Otherwise, it will forever connect to any
433
 
      discovered <application>Mandos</application> servers, trying to
434
 
      get a decryptable password and print it.
 
374
      error occurs.  Otherwise, it will forever connect to new
 
375
      <application>Mandos</application> servers as they appear, trying
 
376
      to get a decryptable password and print it.
435
377
    </para>
436
378
  </refsect1>
437
379
  
445
387
    </para>
446
388
  </refsect1>
447
389
  
448
 
  <refsect1 id="network-hooks">
449
 
    <title>NETWORK HOOKS</title>
450
 
    <para>
451
 
      If a network interface like a bridge or tunnel is required to
452
 
      find a Mandos server, this requires the interface to be up and
453
 
      running before <command>&COMMANDNAME;</command> starts looking
454
 
      for Mandos servers.  This can be accomplished by creating a
455
 
      <quote>network hook</quote> program, and placing it in a special
456
 
      directory.
457
 
    </para>
458
 
    <para>
459
 
      Before the network is used (and again before program exit), any
460
 
      runnable programs found in the network hook directory are run
461
 
      with the argument <quote><literal>start</literal></quote> or
462
 
      <quote><literal>stop</literal></quote>.  This should bring up or
463
 
      down, respectively, any network interface which
464
 
      <command>&COMMANDNAME;</command> should use.
465
 
    </para>
466
 
    <refsect2 id="hook-requirements">
467
 
      <title>REQUIREMENTS</title>
468
 
      <para>
469
 
        A network hook must be an executable file, and its name must
470
 
        consist entirely of upper and lower case letters, digits,
471
 
        underscores, and hyphens.
472
 
      </para>
473
 
      <para>
474
 
        A network hook will receive one argument, which can be one of
475
 
        the following:
476
 
      </para>
477
 
      <variablelist>
478
 
        <varlistentry>
479
 
          <term><literal>start</literal></term>
480
 
          <listitem>
481
 
            <para>
482
 
              This should make the network hook create (if necessary)
483
 
              and bring up a network interface.
484
 
            </para>
485
 
          </listitem>
486
 
        </varlistentry>
487
 
        <varlistentry>
488
 
          <term><literal>stop</literal></term>
489
 
          <listitem>
490
 
            <para>
491
 
              This should make the network hook take down a network
492
 
              interface, and delete it if it did not exist previously.
493
 
            </para>
494
 
          </listitem>
495
 
        </varlistentry>
496
 
        <varlistentry>
497
 
          <term><literal>files</literal></term>
498
 
          <listitem>
499
 
            <para>
500
 
              This should make the network hook print, <emphasis>on
501
 
              separate lines</emphasis>, all the files needed for it
502
 
              to run.  (These files will be copied into the initial
503
 
              RAM filesystem.)  Intended use is for a network hook
504
 
              which is a shell script to print its needed binaries.
505
 
            </para>
506
 
            <para>
507
 
              It is not necessary to print any non-executable files
508
 
              already in the network hook directory, these will be
509
 
              copied implicitly if they otherwise satisfy the name
510
 
              requirement.
511
 
            </para>
512
 
          </listitem>
513
 
        </varlistentry>
514
 
      </variablelist>
515
 
      <para>
516
 
        The network hook will be provided with a number of environment
517
 
        variables:
518
 
      </para>
519
 
      <variablelist>
520
 
        <varlistentry>
521
 
          <term><envar>MANDOSNETHOOKDIR</envar></term>
522
 
          <listitem>
523
 
            <para>
524
 
              The network hook directory, specified to
525
 
              <command>&COMMANDNAME;</command> by the
526
 
              <option>--network-hook-dir</option> option.  Note: this
527
 
              should <emphasis>always</emphasis> be used by the
528
 
              network hook to refer to itself or any files it may
529
 
              require.
530
 
            </para>
531
 
          </listitem>
532
 
        </varlistentry>
533
 
        <varlistentry>
534
 
          <term><envar>DEVICE</envar></term>
535
 
          <listitem>
536
 
            <para>
537
 
              The network interface, as specified to
538
 
              <command>&COMMANDNAME;</command> by the
539
 
              <option>--interface</option> option.  If this is not the
540
 
              interface a hook will bring up, there is no reason for a
541
 
              hook to continue.
542
 
            </para>
543
 
          </listitem>
544
 
        </varlistentry>
545
 
        <varlistentry>
546
 
          <term><envar>MODE</envar></term>
547
 
          <listitem>
548
 
            <para>
549
 
              This will be the same as the first argument;
550
 
              i.e. <quote><literal>start</literal></quote>,
551
 
              <quote><literal>stop</literal></quote>, or
552
 
              <quote><literal>files</literal></quote>.
553
 
            </para>
554
 
          </listitem>
555
 
        </varlistentry>
556
 
        <varlistentry>
557
 
          <term><envar>VERBOSITY</envar></term>
558
 
          <listitem>
559
 
            <para>
560
 
              This will be the <quote><literal>1</literal></quote> if
561
 
              the <option>--debug</option> option is passed to
562
 
              <command>&COMMANDNAME;</command>, otherwise
563
 
              <quote><literal>0</literal></quote>.
564
 
            </para>
565
 
          </listitem>
566
 
        </varlistentry>
567
 
        <varlistentry>
568
 
          <term><envar>DELAY</envar></term>
569
 
          <listitem>
570
 
            <para>
571
 
              This will be the same as the <option>--delay</option>
572
 
              option passed to <command>&COMMANDNAME;</command>.
573
 
            </para>
574
 
          </listitem>
575
 
        </varlistentry>
576
 
      </variablelist>
577
 
      <para>
578
 
        A hook may not read from standard input, and should be
579
 
        restrictive in printing to standard output or standard error
580
 
        unless <varname>VERBOSITY</varname> is
581
 
        <quote><literal>1</literal></quote>.
582
 
      </para>
583
 
    </refsect2>
584
 
  </refsect1>
585
 
  
586
390
  <refsect1 id="files">
587
391
    <title>FILES</title>
588
392
    <variablelist>
600
404
          </para>
601
405
        </listitem>
602
406
      </varlistentry>
603
 
      <varlistentry>
604
 
        <term><filename
605
 
        class="directory">/lib/mandos/network-hooks.d</filename></term>
606
 
        <listitem>
607
 
          <para>
608
 
            Directory where network hooks are located.  Change this
609
 
            with the <option>--network-hook-dir</option> option.  See
610
 
            <xref linkend="network-hooks"/>.
611
 
          </para>
612
 
        </listitem>
613
 
      </varlistentry>
614
407
    </variablelist>
615
408
  </refsect1>
616
409
  
725
518
  <refsect1 id="see_also">
726
519
    <title>SEE ALSO</title>
727
520
    <para>
728
 
      <citerefentry><refentrytitle>intro</refentrytitle>
729
 
      <manvolnum>8mandos</manvolnum></citerefentry>,
730
521
      <citerefentry><refentrytitle>cryptsetup</refentrytitle>
731
522
      <manvolnum>8</manvolnum></citerefentry>,
732
523
      <citerefentry><refentrytitle>crypttab</refentrytitle>