mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-10 02:30:58 +01:00
80 lines
3.2 KiB
Markdown
80 lines
3.2 KiB
Markdown
|
|
Compilation instructions
|
|
========================
|
|
|
|
The precompiled versions here are from OpenSSL 1.0.2 and
|
|
they are a fork of OpenSSL from Peter Mosmans,
|
|
just to get chacha20+poly1305 support (thx!). The one from
|
|
the official git repo didn't work for me work correctly,
|
|
it's also likely they'll disappear shortly
|
|
(https://www.mail-archive.com/openssl-dev@openssl.org/msg34756.html).
|
|
|
|
$ git clone https://github.com/PeterMosmans/openssl
|
|
$ cd openssl
|
|
|
|
|
|
General instructions
|
|
--------------------
|
|
|
|
* 64 bit version was compiled under Opensuse 12.3
|
|
* 32 bit version was compiled under Ubuntu 12.04 LTS
|
|
|
|
In addition to the binaries statically linked binaries I provide -- except a few
|
|
libs which are nowadays sometimes hard to statically link in -- I compiled a set of
|
|
dynamic binaries. The catch here are the Kerberos libs: No Linux
|
|
distributor privides static libs. As of now I feel too lazy to compile
|
|
MIT or KTH from scratch to get statitic libs.
|
|
|
|
So for the kerberos binaries I provide (openssl??-1.0.2pm-krb5*) you need a whopping bunch of
|
|
kerberos libraries which you maybe need to install (libgssapi_krb5, libkrb5, libcom_err,
|
|
libk5crypto, libkrb5support, libkeyutils). For the 'static' binaries kerberos is not compiled in, so that's is not needed.
|
|
|
|
|
|
If you want to compile OpenSSL yourself, here are the instructions:
|
|
|
|
1.) apply experimental-features.patch (otherwise you miss the experimental features)
|
|
|
|
2.) apply openssl-telnet-starttls.patch and openssl-xmpp-starttls-fix.patch
|
|
(provided by Stefan Zehl, thx!).
|
|
|
|
3.) configure the damned thing. Options I used:
|
|
|
|
* for 64Bit:
|
|
./config --prefix=/usr/ --openssldir=/etc/ssl enable-zlib enable-ssl2 enable-rc5 enable-rc2 enable-GOST enable-cms enable-md2 enable-mdc2 enable-ec enable-ec2m enable-ecdh enable-ecdsa enable-seed enable-camellia enable-idea enable-rfc3779 enable-ec_nistp_64_gcc_128 --with-krb5-flavor=MIT experimental-jpake
|
|
|
|
* for 32 Bit:
|
|
./config --prefix=/usr/ --openssldir=/etc/ssl enable-zlib enable-ssl2 enable-rc5 enable-rc2 enable-GOST enable-cms enable-md2 enable-mdc2 enable-ec enable-ec2m enable-ecdh enable-ecdsa enable-seed enable-camellia enable-idea enable-rfc3779 no-ec_nistp_64_gcc_128 --with-krb5-flavor=MIT experimental-jpake
|
|
|
|
Don't use -DTEMP_GOST_TLS, it breaks things!
|
|
|
|
If you don't have / don't want Kerberos libraries and devel rpms/debs, omit "--with-krb5-flavor=MIT".
|
|
If you have other Kerberos flavors you need to figure out by yourself.
|
|
|
|
For real GOST cipher [1] support you need to built static libs as the crypto
|
|
engine is a shared lib (additional options: "shared -fPIC -DOPENSSL_PIC"). I didn't
|
|
do that yet. If you aiming at this you rather should compile everything with another prefix
|
|
as you don't want your openssl binary to end up loading system libraries like libssl or
|
|
libcrypto. Alternatively you can hack the Makefile and include those
|
|
libs which you compiled statically as ".a".
|
|
|
|
4.)
|
|
make depend
|
|
|
|
5.)
|
|
make
|
|
|
|
6.)
|
|
make report (check whether it runs ok)
|
|
|
|
7.) "openssl ciphers -V ALL:COMPLEMENTOFALL | wc -l" lists for me w/ kerberos and w/o GOST cipher engine
|
|
167 ciphers as opposed to 111/109 from Ubuntu or Opensuse.
|
|
|
|
|
|
**Never use these binaries for anything else then for testing**
|
|
|
|
|
|
Enjoy! Dirk
|
|
|
|
|
|
[1] https://en.wikipedia.org/wiki/GOST_%28block_cipher%29
|