This project is based on OpenSSH-hardening advice offered by stribika. The general idea is to throw a wrench into the works of illegal mass surveillance. This is accomplished by:
- Enforcing forward secrecy on the key exchange.
- Dropping weak and/or tainted key algorithms (re: Anything with "DSA" in the name) in favor of 4096-bit RSA keys and ED25519.
- Disable the use of weak and broken ciphers.
- Sane settings related to message authentication codes.
DISCLAIMER: If the NSA or equivalent SIGINT agency is after you, this script won't prevent you from getting owned by other means, and it should not be assumed that this will even make your ssh sessions bullet-proof. This script is just a way to help others spit in the face of passive surveillance against ssh connections. Consider yourself warned.
If you want to take it a step further, you could install Tor and configure it so that you can connect to ssh over an authenticated hidden service. The reason for using an authenticated hidden service is so the HS descriptor can't be readily harvested by bad actors and researchers. Then, set your sshd's bind address to 127.0.0.1. From there, you would connect via ssh over your new .onion address. It beats moving the ssh port in terms of security through obscurity.
KNOWN ISSUE: The client set-up this script provides is still (As of July 28th, 2015) too hardcore for github.com. I had to comment out the KexAlgorithms line in /etc/ssh/ssh_config in order to push to github with ssh.
To use this repository, OpenSSH 6.5 or higher is required. This scripts works on the following platforms:
- Debian Wheezy & Jessie (With ssh from wheezy-backports for Wheezy)
- Ubuntu 14.04 & 15.04
- CentOS 7
- Alpine Linux 3.3.1
- Mac OS X Yosemite Niresh with Homebrew's openssh
- FreeBSD 10 & 11
- OpenBSD 5.7
- NetBSD 7.0 RC 1
- Solaris 11.2 with CSWOpenSSH and 11.3 with OpenSSH from the package manager
INSTALLATION INSTRUCTIONS
If you're stuck using an older version of OpenSSH, I really can't help you. Here are the commands you'll want to run:
git clone https://github.com/NSAKEY/happy-dance.git
cd happy-dance
./happy-dance.sh
If you can't install git for some reason, these commands will also work:
wget https://github.com/NSAKEY/happy-dance/archive/master.zip
unzip master.zip
cd happy-dance-master
./happy-dance.sh
Credit goes to stribika for writing Secure Secure Shell. Source: https://stribika.github.io/2015/01/04/secure-secure-shell.html