| This guide contains (at least) inaccurate statements. It's oversimplifying and omitting important things while putting emphasis on some exotic details where defaults would be sane enough. "One key, the public key, can only encrypt data, not decrypt it" - this is cryptographically inaccurate. One should use it that way, though. "Identity is verified by encrypting and decrypting data that both the client and server know". That's not how signing works. The crucial part of the process is to first establish an encrypted channel, then choose something random (not used previously) and finally verify the signature is correct. What exactly would be the data that "both the client and server know"? "If you're sure there is nobody listening between the client you're on and your server, you can use ssh-copy-id to transfer and append the public key". Almost never happens unless you're in the server room, connected point-to-point. But then the remark about someone listening doesn't make sense. And not a single word about verifying server's fingerprint in the whole guide. "Keep in mind doing this means you can't use the key for automation because you'll have no way to send the passphrase in your scripts". Unless you use an ssh-agent. "umask is a Bash built-in which means a user can change their own umask setting". Wrong implication here. umask is a syscall. It doesn't matter what you use to call it. And what if you're using a different shell? Suggesting painful default umask instead of just doing `chmod go-rwx $HOME` and adjusting /etc/adduser.conf is debatable. Making this guide "distribution agnostic" is IMHO futile and there already are some distribution-specific guides like https://debian-handbook.info/. |
CentOS: https://wiki.centos.org/HowTos/OS_Protection (limited)
Debian: https://www.debian.org/doc/manuals/securing-debian-howto/ind... (old)
Fedora: https://docs.fedoraproject.org/en-US/Fedora/19/html/Security... (old)
Mageia: https://wiki.mageia.org/en/Msec (limited)
Oracle Linux: https://docs.oracle.com/cd/E52668_01/E54670/html/index.html
Red Hat: https://access.redhat.com/documentation/en-us/red_hat_enterp...
Slackware: https://docs.slackware.com/howtos:security:start (limited)
SuSE: https://www.suse.com/documentation/sles-15/singlehtml/book_h...
Ubuntu: https://help.ubuntu.com/lts/serverguide/security.html.en (limited)