/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 mandos-keygen.xml

  • Committer: Teddy Hogeborn
  • Date: 2008-08-31 13:55:04 UTC
  • Revision ID: teddy@fukt.bsnet.se-20080831135504-2ka1cccglsghslxy
* plugin-runner.xml (/refentry/refentryinfo/copyright): Split
                                                        copyright
                                                        holders.
* plugins.d/password-request.xml (/refentry/refentryinfo/copyright):
                                 Split copyright holders.

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">
4
5
<!ENTITY COMMANDNAME "mandos-keygen">
5
 
<!ENTITY TIMESTAMP "2019-07-18">
6
 
<!ENTITY % common SYSTEM "common.ent">
7
 
%common;
 
6
<!ENTITY TIMESTAMP "2008-08-31">
8
7
]>
9
8
 
10
9
<refentry xmlns:xi="http://www.w3.org/2001/XInclude">
12
11
    <title>Mandos Manual</title>
13
12
    <!-- NWalsh’s docbook scripts use this to generate the footer: -->
14
13
    <productname>Mandos</productname>
15
 
    <productnumber>&version;</productnumber>
 
14
    <productnumber>&VERSION;</productnumber>
16
15
    <date>&TIMESTAMP;</date>
17
16
    <authorgroup>
18
17
      <author>
19
18
        <firstname>Björn</firstname>
20
19
        <surname>Påhlsson</surname>
21
20
        <address>
22
 
          <email>belorn@recompile.se</email>
 
21
          <email>belorn@fukt.bsnet.se</email>
23
22
        </address>
24
23
      </author>
25
24
      <author>
26
25
        <firstname>Teddy</firstname>
27
26
        <surname>Hogeborn</surname>
28
27
        <address>
29
 
          <email>teddy@recompile.se</email>
 
28
          <email>teddy@fukt.bsnet.se</email>
30
29
        </address>
31
30
      </author>
32
31
    </authorgroup>
33
32
    <copyright>
34
33
      <year>2008</year>
35
 
      <year>2009</year>
36
 
      <year>2010</year>
37
 
      <year>2011</year>
38
 
      <year>2012</year>
39
 
      <year>2013</year>
40
 
      <year>2014</year>
41
 
      <year>2015</year>
42
 
      <year>2016</year>
43
 
      <year>2017</year>
44
 
      <year>2018</year>
45
 
      <year>2019</year>
46
34
      <holder>Teddy Hogeborn</holder>
47
35
      <holder>Björn Påhlsson</holder>
48
36
    </copyright>
49
 
    <xi:include href="legalnotice.xml"/>
 
37
    <legalnotice>
 
38
      <para>
 
39
        This manual page is free software: you can redistribute it
 
40
        and/or modify it under the terms of the GNU General Public
 
41
        License as published by the Free Software Foundation,
 
42
        either version 3 of the License, or (at your option) any
 
43
        later version.
 
44
      </para>
 
45
 
 
46
      <para>
 
47
        This manual page is distributed in the hope that it will
 
48
        be useful, but WITHOUT ANY WARRANTY; without even the
 
49
        implied warranty of MERCHANTABILITY or FITNESS FOR A
 
50
        PARTICULAR PURPOSE.  See the GNU General Public License
 
51
        for more details.
 
52
      </para>
 
53
 
 
54
      <para>
 
55
        You should have received a copy of the GNU General Public
 
56
        License along with this program; If not, see
 
57
        <ulink url="http://www.gnu.org/licenses/"/>.
 
58
      </para>
 
59
    </legalnotice>
50
60
  </refentryinfo>
51
 
  
 
61
 
52
62
  <refmeta>
53
63
    <refentrytitle>&COMMANDNAME;</refentrytitle>
54
64
    <manvolnum>8</manvolnum>
60
70
      Generate key and password for Mandos client and server.
61
71
    </refpurpose>
62
72
  </refnamediv>
63
 
  
 
73
 
64
74
  <refsynopsisdiv>
65
75
    <cmdsynopsis>
66
76
      <command>&COMMANDNAME;</command>
127
137
        <replaceable>TIME</replaceable></option></arg>
128
138
      </group>
129
139
      <sbr/>
130
 
      <group>
131
 
        <arg choice="plain"><option>--tls-keytype
132
 
        <replaceable>KEYTYPE</replaceable></option></arg>
133
 
        <arg choice="plain"><option>-T
134
 
        <replaceable>KEYTYPE</replaceable></option></arg>
135
 
      </group>
136
 
      <sbr/>
137
 
      <group>
138
 
        <arg choice="plain"><option>--force</option></arg>
139
 
        <arg choice="plain"><option>-f</option></arg>
140
 
      </group>
 
140
      <arg><option>--force</option></arg>
141
141
    </cmdsynopsis>
142
142
    <cmdsynopsis>
143
143
      <command>&COMMANDNAME;</command>
144
144
      <group choice="req">
145
145
        <arg choice="plain"><option>--password</option></arg>
146
146
        <arg choice="plain"><option>-p</option></arg>
147
 
        <arg choice="plain"><option>--passfile
148
 
        <replaceable>FILE</replaceable></option></arg>
149
 
        <arg choice="plain"><option>-F</option>
150
 
        <replaceable>FILE</replaceable></arg>
151
147
      </group>
152
148
      <sbr/>
153
149
      <group>
163
159
        <arg choice="plain"><option>-n
164
160
        <replaceable>NAME</replaceable></option></arg>
165
161
      </group>
166
 
      <group>
167
 
        <arg choice="plain"><option>--no-ssh</option></arg>
168
 
        <arg choice="plain"><option>-S</option></arg>
169
 
      </group>
170
162
    </cmdsynopsis>
171
163
    <cmdsynopsis>
172
164
      <command>&COMMANDNAME;</command>
188
180
    <title>DESCRIPTION</title>
189
181
    <para>
190
182
      <command>&COMMANDNAME;</command> is a program to generate the
191
 
      TLS and OpenPGP keys used by
192
 
      <citerefentry><refentrytitle>mandos-client</refentrytitle>
193
 
      <manvolnum>8mandos</manvolnum></citerefentry>.  The keys are
194
 
      normally written to /etc/keys/mandos for later installation into
195
 
      the initrd image, but this, and most other things, can be
196
 
      changed with command line options.
 
183
      OpenPGP key used by
 
184
      <citerefentry><refentrytitle>password-request</refentrytitle>
 
185
      <manvolnum>8mandos</manvolnum></citerefentry>.  The key is
 
186
      normally written to /etc/mandos for later installation into the
 
187
      initrd image, but this, and most other things, can be changed
 
188
      with command line options.
197
189
    </para>
198
190
    <para>
199
191
      This program can also be used with the
200
 
      <option>--password</option> or <option>--passfile</option>
201
 
      options to generate a ready-made section for
202
 
      <filename>clients.conf</filename> (see
 
192
      <option>--password</option> option to generate a ready-made
 
193
      section for <filename>clients.conf</filename> (see
203
194
      <citerefentry><refentrytitle>mandos-clients.conf</refentrytitle>
204
195
      <manvolnum>5</manvolnum></citerefentry>).
205
196
    </para>
228
219
          </para>
229
220
        </listitem>
230
221
      </varlistentry>
231
 
      
 
222
 
232
223
      <varlistentry>
233
224
        <term><option>--dir
234
225
        <replaceable>DIRECTORY</replaceable></option></term>
236
227
        <replaceable>DIRECTORY</replaceable></option></term>
237
228
        <listitem>
238
229
          <para>
239
 
            Target directory for key files.  Default is <filename
240
 
            class="directory">/etc/keys/mandos</filename>.
 
230
            Target directory for key files.  Default is
 
231
            <filename>/etc/mandos</filename>.
241
232
          </para>
242
233
        </listitem>
243
234
      </varlistentry>
244
 
      
 
235
 
245
236
      <varlistentry>
246
237
        <term><option>--type
247
238
        <replaceable>TYPE</replaceable></option></term>
249
240
        <replaceable>TYPE</replaceable></option></term>
250
241
        <listitem>
251
242
          <para>
252
 
            OpenPGP key type.  Default is <quote>RSA</quote>.
 
243
            Key type.  Default is <quote>DSA</quote>.
253
244
          </para>
254
245
        </listitem>
255
246
      </varlistentry>
256
 
      
 
247
 
257
248
      <varlistentry>
258
249
        <term><option>--length
259
250
        <replaceable>BITS</replaceable></option></term>
261
252
        <replaceable>BITS</replaceable></option></term>
262
253
        <listitem>
263
254
          <para>
264
 
            OpenPGP key length in bits.  Default is 4096.
 
255
            Key length in bits.  Default is 2048.
265
256
          </para>
266
257
        </listitem>
267
258
      </varlistentry>
268
 
      
 
259
 
269
260
      <varlistentry>
270
261
        <term><option>--subtype
271
262
        <replaceable>KEYTYPE</replaceable></option></term>
273
264
        <replaceable>KEYTYPE</replaceable></option></term>
274
265
        <listitem>
275
266
          <para>
276
 
            OpenPGP subkey type.  Default is <quote>RSA</quote>
 
267
            Subkey type.  Default is <quote>ELG-E</quote> (Elgamal
 
268
            encryption-only).
277
269
          </para>
278
270
        </listitem>
279
271
      </varlistentry>
280
 
      
 
272
 
281
273
      <varlistentry>
282
274
        <term><option>--sublength
283
275
        <replaceable>BITS</replaceable></option></term>
285
277
        <replaceable>BITS</replaceable></option></term>
286
278
        <listitem>
287
279
          <para>
288
 
            OpenPGP subkey length in bits.  Default is 4096.
 
280
            Subkey length in bits.  Default is 2048.
289
281
          </para>
290
282
        </listitem>
291
283
      </varlistentry>
292
 
      
 
284
 
293
285
      <varlistentry>
294
286
        <term><option>--email
295
287
        <replaceable>ADDRESS</replaceable></option></term>
301
293
          </para>
302
294
        </listitem>
303
295
      </varlistentry>
304
 
      
 
296
 
305
297
      <varlistentry>
306
298
        <term><option>--comment
307
299
        <replaceable>TEXT</replaceable></option></term>
309
301
        <replaceable>TEXT</replaceable></option></term>
310
302
        <listitem>
311
303
          <para>
312
 
            Comment field for key.  Default is empty.
 
304
            Comment field for key.  The default value is
 
305
            <quote><literal>Mandos client key</literal></quote>.
313
306
          </para>
314
307
        </listitem>
315
308
      </varlistentry>
316
 
      
 
309
 
317
310
      <varlistentry>
318
311
        <term><option>--expire
319
312
        <replaceable>TIME</replaceable></option></term>
327
320
          </para>
328
321
        </listitem>
329
322
      </varlistentry>
330
 
      
331
 
      <varlistentry>
332
 
        <term><option>--tls-keytype
333
 
        <replaceable>KEYTYPE</replaceable></option></term>
334
 
        <term><option>-T
335
 
        <replaceable>KEYTYPE</replaceable></option></term>
336
 
        <listitem>
337
 
          <para>
338
 
            TLS key type.  Default is <quote>ed25519</quote>
339
 
          </para>
340
 
        </listitem>
341
 
      </varlistentry>
342
 
      
 
323
 
343
324
      <varlistentry>
344
325
        <term><option>--force</option></term>
345
326
        <term><option>-f</option></term>
355
336
        <listitem>
356
337
          <para>
357
338
            Prompt for a password and encrypt it with the key already
358
 
            present in either <filename>/etc/keys/mandos</filename> or
359
 
            the directory specified with the <option>--dir</option>
 
339
            present in either <filename>/etc/mandos</filename> or the
 
340
            directory specified with the <option>--dir</option>
360
341
            option.  Outputs, on standard output, a section suitable
361
342
            for inclusion in <citerefentry><refentrytitle
362
343
            >mandos-clients.conf</refentrytitle><manvolnum
363
344
            >8</manvolnum></citerefentry>.  The host name or the name
364
345
            specified with the <option>--name</option> option is used
365
346
            for the section header.  All other options are ignored,
366
 
            and no key is created.  Note: white space is stripped from
367
 
            the beginning and from the end of the password; See <xref
368
 
            linkend="bugs"/>.
369
 
          </para>
370
 
        </listitem>
371
 
      </varlistentry>
372
 
      <varlistentry>
373
 
        <term><option>--passfile
374
 
        <replaceable>FILE</replaceable></option></term>
375
 
        <term><option>-F
376
 
        <replaceable>FILE</replaceable></option></term>
377
 
        <listitem>
378
 
          <para>
379
 
            The same as <option>--password</option>, but read from
380
 
            <replaceable>FILE</replaceable>, not the terminal, and
381
 
            white space is not stripped from the password in any way.
382
 
          </para>
383
 
        </listitem>
384
 
      </varlistentry>
385
 
      <varlistentry>
386
 
        <term><option>--no-ssh</option></term>
387
 
        <term><option>-S</option></term>
388
 
        <listitem>
389
 
          <para>
390
 
            When <option>--password</option> or
391
 
            <option>--passfile</option> is given, this option will
392
 
            prevent <command>&COMMANDNAME;</command> from calling
393
 
            <command>ssh-keyscan</command> to get an SSH fingerprint
394
 
            for this host and, if successful, output suitable config
395
 
            options to use this fingerprint as a
396
 
            <option>checker</option> option in the output.  This is
397
 
            otherwise the default behavior.
 
347
            and no key is created.
398
348
          </para>
399
349
        </listitem>
400
350
      </varlistentry>
401
351
    </variablelist>
402
352
  </refsect1>
403
 
  
 
353
 
404
354
  <refsect1 id="overview">
405
355
    <title>OVERVIEW</title>
406
356
    <xi:include href="overview.xml"/>
407
357
    <para>
408
 
      This program is a small utility to generate new TLS and OpenPGP
409
 
      keys for new Mandos clients, and to generate sections for
410
 
      inclusion in <filename>clients.conf</filename> on the server.
 
358
      This program is a small utility to generate new OpenPGP keys for
 
359
      new Mandos clients, and to generate sections for inclusion in
 
360
      <filename>clients.conf</filename> on the server.
411
361
    </para>
412
362
  </refsect1>
413
 
  
 
363
 
414
364
  <refsect1 id="exit_status">
415
365
    <title>EXIT STATUS</title>
416
366
    <para>
436
386
    </variablelist>
437
387
  </refsect1>
438
388
  
439
 
  <refsect1 id="files">
 
389
  <refsect1 id="file">
440
390
    <title>FILES</title>
441
391
    <para>
442
392
      Use the <option>--dir</option> option to change where
445
395
    </para>
446
396
    <variablelist>
447
397
      <varlistentry>
448
 
        <term><filename>/etc/keys/mandos/seckey.txt</filename></term>
 
398
        <term><filename>/etc/mandos/seckey.txt</filename></term>
449
399
        <listitem>
450
400
          <para>
451
401
            OpenPGP secret key file which will be created or
454
404
        </listitem>
455
405
      </varlistentry>
456
406
      <varlistentry>
457
 
        <term><filename>/etc/keys/mandos/pubkey.txt</filename></term>
 
407
        <term><filename>/etc/mandos/pubkey.txt</filename></term>
458
408
        <listitem>
459
409
          <para>
460
410
            OpenPGP public key file which will be created or
463
413
        </listitem>
464
414
      </varlistentry>
465
415
      <varlistentry>
466
 
        <term><filename>/etc/keys/mandos/tls-privkey.pem</filename></term>
467
 
        <listitem>
468
 
          <para>
469
 
            Private key file which will be created or overwritten.
470
 
          </para>
471
 
        </listitem>
472
 
      </varlistentry>
473
 
      <varlistentry>
474
 
        <term><filename>/etc/keys/mandos/tls-pubkey.pem</filename></term>
475
 
        <listitem>
476
 
          <para>
477
 
            Public key file which will be created or overwritten.
478
 
          </para>
479
 
        </listitem>
480
 
      </varlistentry>
481
 
      <varlistentry>
482
 
        <term><filename class="directory">/tmp</filename></term>
 
416
        <term><filename>/tmp</filename></term>
483
417
        <listitem>
484
418
          <para>
485
419
            Temporary files will be written here if
489
423
      </varlistentry>
490
424
    </variablelist>
491
425
  </refsect1>
492
 
  
 
426
 
493
427
  <refsect1 id="bugs">
494
428
    <title>BUGS</title>
495
429
    <para>
496
 
      The <option>--password</option>/<option>-p</option> option
497
 
      strips white space from the start and from the end of the
498
 
      password before using it.  If this is a problem, use the
499
 
      <option>--passfile</option> option instead, which does not do
500
 
      this.
 
430
      None are known at this time.
501
431
    </para>
502
 
    <xi:include href="bugs.xml"/>
503
432
  </refsect1>
504
 
  
 
433
 
505
434
  <refsect1 id="example">
506
435
    <title>EXAMPLE</title>
507
436
    <informalexample>
526
455
    </informalexample>
527
456
    <informalexample>
528
457
      <para>
529
 
        Prompt for a password, encrypt it with the keys in <filename
530
 
        class="directory">/etc/keys/mandos</filename> and output a
531
 
        section suitable for <filename>clients.conf</filename>.
 
458
        Prompt for a password, encrypt it with the key in
 
459
        <filename>/etc/mandos</filename> and output a section suitable
 
460
        for <filename>clients.conf</filename>.
532
461
      </para>
533
462
      <para>
534
463
        <userinput>&COMMANDNAME; --password</userinput>
536
465
    </informalexample>
537
466
    <informalexample>
538
467
      <para>
539
 
        Prompt for a password, encrypt it with the keys in the
 
468
        Prompt for a password, encrypt it with the key in the
540
469
        <filename>client-key</filename> directory and output a section
541
470
        suitable for <filename>clients.conf</filename>.
542
471
      </para>
548
477
      </para>
549
478
    </informalexample>
550
479
  </refsect1>
551
 
  
 
480
 
552
481
  <refsect1 id="security">
553
482
    <title>SECURITY</title>
554
483
    <para>
563
492
      <manvolnum>8</manvolnum></citerefentry>.
564
493
    </para>
565
494
  </refsect1>
566
 
  
 
495
 
567
496
  <refsect1 id="see_also">
568
497
    <title>SEE ALSO</title>
569
498
    <para>
570
 
      <citerefentry><refentrytitle>intro</refentrytitle>
571
 
      <manvolnum>8mandos</manvolnum></citerefentry>,
572
499
      <citerefentry><refentrytitle>gpg</refentrytitle>
573
500
      <manvolnum>1</manvolnum></citerefentry>,
574
501
      <citerefentry><refentrytitle>mandos-clients.conf</refentrytitle>
575
502
      <manvolnum>5</manvolnum></citerefentry>,
576
503
      <citerefentry><refentrytitle>mandos</refentrytitle>
577
504
      <manvolnum>8</manvolnum></citerefentry>,
578
 
      <citerefentry><refentrytitle>mandos-client</refentrytitle>
579
 
      <manvolnum>8mandos</manvolnum></citerefentry>,
580
 
      <citerefentry><refentrytitle>ssh-keyscan</refentrytitle>
581
 
      <manvolnum>1</manvolnum></citerefentry>
 
505
      <citerefentry><refentrytitle>password-request</refentrytitle>
 
506
      <manvolnum>8mandos</manvolnum></citerefentry>
582
507
    </para>
583
508
  </refsect1>
584
509