/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 debian/mandos-client.postinst

  • Committer: Teddy Hogeborn
  • Date: 2015-03-10 18:52:09 UTC
  • Revision ID: teddy@recompile.se-20150310185209-lxuovbu09zwyk9bx
Automatically determine the number of DH bits in the TLS handshake.

Instead of using a default value of 1024, check the OpenPGP key and
determine an appropriate number of DH bits to use, (using GnuTLS
functions made for this).  Document this new default behavior.

* plugins.d/mandos-client.c (safe_string): New function.
  (init_gnutls_global): If not specified, determine the number of DH
                        bits to use, based on the OpenPGP key.
* plugins.d/mandos-client.xml (OPTIONS): Document this new default of
                                         the --dh-bits option.

Thanks to Andreas Fischer <af@bantuX.org> for reporting this issue.

Show diffs side-by-side

added added

removed removed

Lines of Context:
63
63
    fi
64
64
}
65
65
 
66
 
create_dh_params(){
67
 
    if [ -r /etc/keys/mandos/dhparams.pem ]; then
68
 
        return 0
69
 
    fi
70
 
    # Create a Diffe-Hellman parameters file
71
 
    DHFILE="`mktemp -t mandos-client-dh-parameters.XXXXXXXXXX.pem`"
72
 
    # First try certtool from GnuTLS
73
 
    if ! certtool --generate-dh-params --sec-param high \
74
 
         --outfile "$DHFILE"; then
75
 
        # Otherwise try OpenSSL
76
 
        if ! openssl genpkey -genparam -algorithm DH -out "$DHFILE" \
77
 
             -pkeyopt dh_paramgen_prime_len:3072; then
78
 
            # None of the commands succeded; give up
79
 
            rm -- "$DHFILE"
80
 
            return 1
81
 
        fi
82
 
    fi
83
 
    sed --in-place --expression='0,/^-----BEGIN DH PARAMETERS-----$/d' \
84
 
        "$DHFILE"
85
 
    sed --in-place --expression='1i-----BEGIN DH PARAMETERS-----' \
86
 
            "$DHFILE"
87
 
    cp --archive "$DHFILE" /etc/keys/mandos/dhparams.pem
88
 
    rm -- "$DHFILE"
89
 
}
90
 
 
91
66
case "$1" in
92
67
    configure)
93
68
        add_mandos_user "$@"
94
69
        create_key "$@"
95
 
        create_dh_params "$@" || :
96
70
        update_initramfs "$@"
97
71
        ;;
98
72
    abort-upgrade|abort-deconfigure|abort-remove)