/mandos/trunk

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

« back to all changes in this revision

Viewing changes to plugin-runner.xml

  • Committer: Teddy Hogeborn
  • Date: 2015-07-12 01:57:54 UTC
  • Revision ID: teddy@recompile.se-20150712015754-1lq7u2ejo7fdyfvi
* debian/mandos.prerm: Don't run init script, use only invoke-rc.d.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
<?xml version="1.0" encoding="UTF-8"?>
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
 
<!ENTITY VERSION "1.0">
5
4
<!ENTITY COMMANDNAME "plugin-runner">
6
 
<!ENTITY TIMESTAMP "2008-09-01">
 
5
<!ENTITY TIMESTAMP "2015-06-28">
 
6
<!ENTITY % common SYSTEM "common.ent">
 
7
%common;
7
8
]>
8
9
 
9
10
<refentry xmlns:xi="http://www.w3.org/2001/XInclude">
11
12
    <title>Mandos Manual</title>
12
13
    <!-- Nwalsh’s docbook scripts use this to generate the footer: -->
13
14
    <productname>Mandos</productname>
14
 
    <productnumber>&VERSION;</productnumber>
 
15
    <productnumber>&version;</productnumber>
15
16
    <date>&TIMESTAMP;</date>
16
17
    <authorgroup>
17
18
      <author>
18
19
        <firstname>Björn</firstname>
19
20
        <surname>Påhlsson</surname>
20
21
        <address>
21
 
          <email>belorn@fukt.bsnet.se</email>
 
22
          <email>belorn@recompile.se</email>
22
23
        </address>
23
24
      </author>
24
25
      <author>
25
26
        <firstname>Teddy</firstname>
26
27
        <surname>Hogeborn</surname>
27
28
        <address>
28
 
          <email>teddy@fukt.bsnet.se</email>
 
29
          <email>teddy@recompile.se</email>
29
30
        </address>
30
31
      </author>
31
32
    </authorgroup>
32
33
    <copyright>
33
34
      <year>2008</year>
 
35
      <year>2009</year>
 
36
      <year>2012</year>
34
37
      <holder>Teddy Hogeborn</holder>
35
38
      <holder>Björn Påhlsson</holder>
36
39
    </copyright>
37
40
    <xi:include href="legalnotice.xml"/>
38
41
  </refentryinfo>
39
 
 
 
42
  
40
43
  <refmeta>
41
44
    <refentrytitle>&COMMANDNAME;</refentrytitle>
42
45
    <manvolnum>8mandos</manvolnum>
45
48
  <refnamediv>
46
49
    <refname><command>&COMMANDNAME;</command></refname>
47
50
    <refpurpose>
48
 
      Run Mandos plugins.  Pass data from first succesful one.
 
51
      Run Mandos plugins, pass data from first to succeed.
49
52
    </refpurpose>
50
53
  </refnamediv>
51
 
 
 
54
  
52
55
  <refsynopsisdiv>
53
56
    <cmdsynopsis>
54
57
      <command>&COMMANDNAME;</command>
55
58
      <group rep="repeat">
56
59
        <arg choice="plain"><option>--global-env=<replaceable
57
 
        >VAR</replaceable><literal>=</literal><replaceable
 
60
        >ENV</replaceable><literal>=</literal><replaceable
58
61
        >value</replaceable></option></arg>
59
 
        <arg choice="plain"><option>-e
60
 
        <replaceable>VAR</replaceable><literal>=</literal><replaceable
 
62
        <arg choice="plain"><option>-G
 
63
        <replaceable>ENV</replaceable><literal>=</literal><replaceable
61
64
        >value</replaceable> </option></arg>
62
65
      </group>
63
66
      <sbr/>
66
69
        >PLUGIN</replaceable><literal>:</literal><replaceable
67
70
        >ENV</replaceable><literal>=</literal><replaceable
68
71
        >value</replaceable></option></arg>
69
 
        <arg choice="plain"><option>-f<replaceable>
 
72
        <arg choice="plain"><option>-E<replaceable>
70
73
        PLUGIN</replaceable><literal>:</literal><replaceable
71
74
        >ENV</replaceable><literal>=</literal><replaceable
72
75
        >value</replaceable> </option></arg>
83
86
        <arg choice="plain"><option>--options-for=<replaceable
84
87
        >PLUGIN</replaceable><literal>:</literal><replaceable
85
88
        >OPTIONS</replaceable></option></arg>
86
 
        <arg choice="plain"><option>-f<replaceable>
 
89
        <arg choice="plain"><option>-o<replaceable>
87
90
        PLUGIN</replaceable><literal>:</literal><replaceable
88
91
        >OPTIONS</replaceable> </option></arg>
89
92
      </group>
95
98
        <replaceable>PLUGIN</replaceable> </option></arg>
96
99
      </group>
97
100
      <sbr/>
 
101
      <group rep="repeat">
 
102
        <arg choice="plain"><option>--enable=<replaceable
 
103
        >PLUGIN</replaceable></option></arg>
 
104
        <arg choice="plain"><option>-e
 
105
        <replaceable>PLUGIN</replaceable> </option></arg>
 
106
      </group>
 
107
      <sbr/>
98
108
      <arg><option>--groupid=<replaceable
99
109
      >ID</replaceable></option></arg>
100
110
      <sbr/>
104
114
      <arg><option>--plugin-dir=<replaceable
105
115
      >DIRECTORY</replaceable></option></arg>
106
116
      <sbr/>
 
117
      <arg><option>--plugin-helper-dir=<replaceable
 
118
      >DIRECTORY</replaceable></option></arg>
 
119
      <sbr/>
 
120
      <arg><option>--config-file=<replaceable
 
121
      >FILE</replaceable></option></arg>
 
122
      <sbr/>
107
123
      <arg><option>--debug</option></arg>
108
124
    </cmdsynopsis>
109
125
    <cmdsynopsis>
130
146
    <title>DESCRIPTION</title>
131
147
    <para>
132
148
      <command>&COMMANDNAME;</command> is a program which is meant to
133
 
      be specified as <quote>keyscript</quote> in <citerefentry>
134
 
      <refentrytitle>crypttab</refentrytitle>
135
 
      <manvolnum>5</manvolnum></citerefentry> for the root disk.  The
136
 
      aim of this program is therefore to output a password, which
137
 
      then <citerefentry><refentrytitle>cryptsetup</refentrytitle>
138
 
      <manvolnum>8</manvolnum></citerefentry> will use to try and
139
 
      unlock the root disk.
 
149
      be specified as a <quote>keyscript</quote> for the root disk in
 
150
      <citerefentry><refentrytitle>crypttab</refentrytitle>
 
151
      <manvolnum>5</manvolnum></citerefentry>.  The aim of this
 
152
      program is therefore to output a password, which then
 
153
      <citerefentry><refentrytitle>cryptsetup</refentrytitle>
 
154
      <manvolnum>8</manvolnum></citerefentry> will use to unlock the
 
155
      root disk.
140
156
    </para>
141
157
    <para>
142
158
      This program is not meant to be invoked directly, but can be in
160
176
    <variablelist>
161
177
      <varlistentry>
162
178
        <term><option>--global-env
163
 
        <replaceable>VAR</replaceable><literal>=</literal><replaceable
 
179
        <replaceable>ENV</replaceable><literal>=</literal><replaceable
164
180
        >value</replaceable></option></term>
165
 
        <term><option>-e
166
 
        <replaceable>VAR</replaceable><literal>=</literal><replaceable
 
181
        <term><option>-G
 
182
        <replaceable>ENV</replaceable><literal>=</literal><replaceable
167
183
        >value</replaceable></option></term>
168
184
        <listitem>
169
185
          <para>
179
195
        <replaceable>PLUGIN</replaceable><literal>:</literal
180
196
        ><replaceable>ENV</replaceable><literal>=</literal
181
197
        ><replaceable>value</replaceable></option></term>
182
 
        <term><option>-f
 
198
        <term><option>-E
183
199
        <replaceable>PLUGIN</replaceable><literal>:</literal
184
200
        ><replaceable>ENV</replaceable><literal>=</literal
185
201
        ><replaceable>value</replaceable></option></term>
205
221
            <replaceable>OPTIONS</replaceable> is a comma separated
206
222
            list of options.  This is not a very useful option, except
207
223
            for specifying the <quote><option>--debug</option></quote>
208
 
            for all plugins.
 
224
            option to all plugins.
209
225
          </para>
210
226
        </listitem>
211
227
      </varlistentry>
231
247
            <option>--bar</option> with the option argument
232
248
            <quote>baz</quote> is either
233
249
            <userinput>--options-for=foo:--bar=baz</userinput> or
234
 
            <userinput>--options-for=foo:--bar,baz</userinput>, but
235
 
            <emphasis>not</emphasis>
236
 
            <userinput>--options-for="foo:--bar baz"</userinput>.
 
250
            <userinput>--options-for=foo:--bar,baz</userinput>.  Using
 
251
            <userinput>--options-for="foo:--bar baz"</userinput>. will
 
252
            <emphasis>not</emphasis> work.
237
253
          </para>
238
254
        </listitem>
239
255
      </varlistentry>
240
 
 
 
256
      
241
257
      <varlistentry>
242
 
        <term><option> --disable
 
258
        <term><option>--disable
243
259
        <replaceable>PLUGIN</replaceable></option></term>
244
260
        <term><option>-d
245
261
        <replaceable>PLUGIN</replaceable></option></term>
248
264
            Disable the plugin named
249
265
            <replaceable>PLUGIN</replaceable>.  The plugin will not be
250
266
            started.
251
 
          </para>       
252
 
        </listitem>
253
 
      </varlistentry>
254
 
 
 
267
          </para>
 
268
        </listitem>
 
269
      </varlistentry>
 
270
      
 
271
      <varlistentry>
 
272
        <term><option>--enable
 
273
        <replaceable>PLUGIN</replaceable></option></term>
 
274
        <term><option>-e
 
275
        <replaceable>PLUGIN</replaceable></option></term>
 
276
        <listitem>
 
277
          <para>
 
278
            Re-enable the plugin named
 
279
            <replaceable>PLUGIN</replaceable>.  This is only useful to
 
280
            undo a previous <option>--disable</option> option, maybe
 
281
            from the configuration file.
 
282
          </para>
 
283
        </listitem>
 
284
      </varlistentry>
 
285
      
255
286
      <varlistentry>
256
287
        <term><option>--groupid
257
288
        <replaceable>ID</replaceable></option></term>
264
295
          </para>
265
296
        </listitem>
266
297
      </varlistentry>
267
 
 
 
298
      
268
299
      <varlistentry>
269
300
        <term><option>--userid
270
301
        <replaceable>ID</replaceable></option></term>
277
308
          </para>
278
309
        </listitem>
279
310
      </varlistentry>
280
 
 
 
311
      
281
312
      <varlistentry>
282
313
        <term><option>--plugin-dir
283
314
        <replaceable>DIRECTORY</replaceable></option></term>
292
323
      </varlistentry>
293
324
      
294
325
      <varlistentry>
 
326
        <term><option>--plugin-helper-dir
 
327
        <replaceable>DIRECTORY</replaceable></option></term>
 
328
        <listitem>
 
329
          <para>
 
330
            Specify a different plugin helper directory.  The default
 
331
            is <filename>/lib/mandos/plugin-helpers</filename>, which
 
332
            will exist in the initial <acronym>RAM</acronym> disk
 
333
            environment.  (This will simply be passed to all plugins
 
334
            via the <envar>MANDOSPLUGINHELPERDIR</envar> environment
 
335
            variable.  See <xref linkend="writing_plugins"/>)
 
336
          </para>
 
337
        </listitem>
 
338
      </varlistentry>
 
339
      
 
340
      <varlistentry>
 
341
        <term><option>--config-file
 
342
        <replaceable>FILE</replaceable></option></term>
 
343
        <listitem>
 
344
          <para>
 
345
            Specify a different file to read additional options from.
 
346
            See <xref linkend="files"/>.  Other command line options
 
347
            will override options specified in the file.
 
348
          </para>
 
349
        </listitem>
 
350
      </varlistentry>
 
351
      
 
352
      <varlistentry>
295
353
        <term><option>--debug</option></term>
296
354
        <listitem>
297
355
          <para>
328
386
          </para>
329
387
        </listitem>
330
388
      </varlistentry>
331
 
 
 
389
      
332
390
      <varlistentry>
333
391
        <term><option>--version</option></term>
334
392
        <term><option>-V</option></term>
340
398
      </varlistentry>
341
399
    </variablelist>
342
400
  </refsect1>
343
 
 
 
401
  
344
402
  <refsect1 id="overview">
345
403
    <title>OVERVIEW</title>
346
404
    <xi:include href="overview.xml"/>
366
424
      code will make this plugin-runner output the password from that
367
425
      plugin, stop any other plugins, and exit.
368
426
    </para>
 
427
    
 
428
    <refsect2 id="writing_plugins">
 
429
      <title>WRITING PLUGINS</title>
 
430
      <para>
 
431
        A plugin is simply a program which prints a password to its
 
432
        standard output and then exits with a successful (zero) exit
 
433
        status.  If the exit status is not zero, any output on
 
434
        standard output will be ignored by the plugin runner.  Any
 
435
        output on its standard error channel will simply be passed to
 
436
        the standard error of the plugin runner, usually the system
 
437
        console.
 
438
      </para>
 
439
      <para>
 
440
        If the password is a single-line, manually entered passprase,
 
441
        a final trailing newline character should
 
442
        <emphasis>not</emphasis> be printed.
 
443
      </para>
 
444
      <para>
 
445
        The plugin will run in the initial RAM disk environment, so
 
446
        care must be taken not to depend on any files or running
 
447
        services not available there.  Any helper executables required
 
448
        by the plugin (which are not in the <envar>PATH</envar>) can
 
449
        be placed in the plugin helper directory, the name of which
 
450
        will be made available to the plugin via the
 
451
        <envar>MANDOSPLUGINHELPERDIR</envar> environment variable.
 
452
      </para>
 
453
      <para>
 
454
        The plugin must exit cleanly and free all allocated resources
 
455
        upon getting the TERM signal, since this is what the plugin
 
456
        runner uses to stop all other plugins when one plugin has
 
457
        output a password and exited cleanly.
 
458
      </para>
 
459
      <para>
 
460
        The plugin must not use resources, like for instance reading
 
461
        from the standard input, without knowing that no other plugin
 
462
        is also using it.
 
463
      </para>
 
464
      <para>
 
465
        It is useful, but not required, for the plugin to take the
 
466
        <option>--debug</option> option.
 
467
      </para>
 
468
    </refsect2>
369
469
  </refsect1>
370
470
  
371
471
  <refsect1 id="fallback">
393
493
  <refsect1 id="environment">
394
494
    <title>ENVIRONMENT</title>
395
495
    <para>
396
 
      
 
496
      This program does not use any environment variables itself, it
 
497
      only passes on its environment to all the plugins.  The
 
498
      environment passed to plugins can be modified using the
 
499
      <option>--global-env</option> and <option>--env-for</option>
 
500
      options.  Also, the <option>--plugin-helper-dir</option> option
 
501
      will affect the environment variable
 
502
      <envar>MANDOSPLUGINHELPERDIR</envar> for the plugins.
397
503
    </para>
398
504
  </refsect1>
399
505
  
400
 
  <refsect1 id="file">
 
506
  <refsect1 id="files">
401
507
    <title>FILES</title>
402
508
    <para>
403
509
      <variablelist>
415
521
              of a line is ignored.
416
522
            </para>
417
523
            <para>
 
524
              This program is meant to run in the initial RAM disk
 
525
              environment, so that is where this file is assumed to
 
526
              exist.  The file does not need to exist in the normal
 
527
              file system.
 
528
            </para>
 
529
            <para>
418
530
              This file will be processed <emphasis>before</emphasis>
419
531
              the normal command line options, so the latter can
420
532
              override the former, if need be.
421
533
            </para>
 
534
            <para>
 
535
              This file name is the default; the file to read for
 
536
              arguments can be changed using the
 
537
              <option>--config-file</option> option.
 
538
            </para>
422
539
          </listitem>
423
540
        </varlistentry>
424
541
      </variablelist>
428
545
  <refsect1 id="bugs">
429
546
    <title>BUGS</title>
430
547
    <para>
431
 
      There is no <option>--enable</option> option to enable disabled
432
 
      plugins.
 
548
      The <option>--config-file</option> option is ignored when
 
549
      specified from within a configuration file.
433
550
    </para>
434
551
  </refsect1>
435
552
  
436
553
  <refsect1 id="examples">
437
554
    <title>EXAMPLE</title>
438
 
    <para>
439
 
    </para>
 
555
    <informalexample>
 
556
      <para>
 
557
        Normal invocation needs no options:
 
558
      </para>
 
559
      <para>
 
560
        <userinput>&COMMANDNAME;</userinput>
 
561
      </para>
 
562
    </informalexample>
 
563
    <informalexample>
 
564
      <para>
 
565
        Run the program, but not the plugins, in debug mode:
 
566
      </para>
 
567
      <para>
 
568
        
 
569
        <!-- do not wrap this line -->
 
570
        <userinput>&COMMANDNAME; --debug</userinput>
 
571
        
 
572
      </para>
 
573
    </informalexample>
 
574
    <informalexample>
 
575
      <para>
 
576
        Run all plugins, but run the <quote>foo</quote> plugin in
 
577
        debug mode:
 
578
      </para>
 
579
      <para>
 
580
        
 
581
        <!-- do not wrap this line -->
 
582
        <userinput>&COMMANDNAME; --options-for=foo:--debug</userinput>
 
583
        
 
584
      </para>
 
585
    </informalexample>
 
586
    <informalexample>
 
587
      <para>
 
588
        Run all plugins, but not the program, in debug mode:
 
589
      </para>
 
590
      <para>
 
591
        
 
592
        <!-- do not wrap this line -->
 
593
        <userinput>&COMMANDNAME; --global-options=--debug</userinput>
 
594
        
 
595
      </para>
 
596
    </informalexample>
 
597
    <informalexample>
 
598
      <para>
 
599
        Read a different configuration file, run plugins from a
 
600
        different directory, specify an alternate plugin helper
 
601
        directory and add two options to the
 
602
        <citerefentry><refentrytitle >mandos-client</refentrytitle>
 
603
        <manvolnum>8mandos</manvolnum></citerefentry> plugin:
 
604
      </para>
 
605
      <para>
 
606
 
 
607
<!-- do not wrap this line -->
 
608
<userinput>cd /etc/keys/mandos; &COMMANDNAME;  --config-file=/etc/mandos/plugin-runner.conf --plugin-dir /usr/lib/x86_64-linux-gnu/mandos/plugins.d --plugin-helper-dir /usr/lib/x86_64-linux-gnu/mandos/plugin-helpers --options-for=mandos-client:--pubkey=pubkey.txt,--seckey=seckey.txt</userinput>
 
609
 
 
610
      </para>
 
611
    </informalexample>
440
612
  </refsect1>
441
 
  
442
613
  <refsect1 id="security">
443
614
    <title>SECURITY</title>
444
615
    <para>
 
616
      This program will, when starting, try to switch to another user.
 
617
      If it is started as root, it will succeed, and will by default
 
618
      switch to user and group 65534, which are assumed to be
 
619
      non-privileged.  This user and group is then what all plugins
 
620
      will be started as.  Therefore, the only way to run a plugin as
 
621
      a privileged user is to have the set-user-ID or set-group-ID bit
 
622
      set on the plugin executable file (see <citerefentry>
 
623
      <refentrytitle>execve</refentrytitle><manvolnum>2</manvolnum>
 
624
      </citerefentry>).
 
625
    </para>
 
626
    <para>
 
627
      If this program is used as a keyscript in <citerefentry
 
628
      ><refentrytitle>crypttab</refentrytitle><manvolnum>5</manvolnum>
 
629
      </citerefentry>, there is a slight risk that if this program
 
630
      fails to work, there might be no way to boot the system except
 
631
      for booting from another media and editing the initial RAM disk
 
632
      image to not run this program.  This is, however, unlikely,
 
633
      since the <citerefentry><refentrytitle
 
634
      >password-prompt</refentrytitle><manvolnum>8mandos</manvolnum>
 
635
      </citerefentry> plugin will read a password from the console in
 
636
      case of failure of the other plugins, and this plugin runner
 
637
      will also, in case of catastrophic failure, itself fall back to
 
638
      asking and outputting a password on the console (see <xref
 
639
      linkend="fallback"/>).
445
640
    </para>
446
641
  </refsect1>
447
642
  
448
643
  <refsect1 id="see_also">
449
644
    <title>SEE ALSO</title>
450
645
    <para>
 
646
      <citerefentry><refentrytitle>intro</refentrytitle>
 
647
      <manvolnum>8mandos</manvolnum></citerefentry>,
451
648
      <citerefentry><refentrytitle>cryptsetup</refentrytitle>
452
649
      <manvolnum>8</manvolnum></citerefentry>,
 
650
      <citerefentry><refentrytitle>crypttab</refentrytitle>
 
651
      <manvolnum>5</manvolnum></citerefentry>,
 
652
      <citerefentry><refentrytitle>execve</refentrytitle>
 
653
      <manvolnum>2</manvolnum></citerefentry>,
453
654
      <citerefentry><refentrytitle>mandos</refentrytitle>
454
655
      <manvolnum>8</manvolnum></citerefentry>,
455
656
      <citerefentry><refentrytitle>password-prompt</refentrytitle>
456
657
      <manvolnum>8mandos</manvolnum></citerefentry>,
457
 
      <citerefentry><refentrytitle>password-request</refentrytitle>
 
658
      <citerefentry><refentrytitle>mandos-client</refentrytitle>
458
659
      <manvolnum>8mandos</manvolnum></citerefentry>
459
660
    </para>
460
661
  </refsect1>