From bb2f047c9c45d011361d253d4444b2fd1ebd3612 Mon Sep 17 00:00:00 2001 From: "James E. Blair" Date: Mon, 18 Jul 2011 17:33:29 +0000 Subject: [PATCH] Add puppet module for ssh that installs an sshd_config that only allows login via keys. --- manifests/server.pp | 1 + modules/ssh/files/sshd_config | 86 +++++++++++++++++++++++++++++++++++ modules/ssh/manifests/init.pp | 19 ++++++++ 3 files changed, 106 insertions(+) create mode 100644 modules/ssh/files/sshd_config create mode 100644 modules/ssh/manifests/init.pp diff --git a/manifests/server.pp b/manifests/server.pp index 00e2e6e10f..8c2442a76b 100644 --- a/manifests/server.pp +++ b/manifests/server.pp @@ -2,6 +2,7 @@ import "openstack_admins_users" node default { include openstack_admins_users + include ssh package { "python-software-properties": ensure => latest diff --git a/modules/ssh/files/sshd_config b/modules/ssh/files/sshd_config new file mode 100644 index 0000000000..bb7429ad7c --- /dev/null +++ b/modules/ssh/files/sshd_config @@ -0,0 +1,86 @@ +# Package generated configuration file +# See the sshd_config(5) manpage for details + +# What ports, IPs and protocols we listen for +Port 22 +# Use these options to restrict which interfaces/protocols sshd will bind to +#ListenAddress :: +#ListenAddress 0.0.0.0 +Protocol 2 +# HostKeys for protocol version 2 +HostKey /etc/ssh/ssh_host_rsa_key +HostKey /etc/ssh/ssh_host_dsa_key +#Privilege Separation is turned on for security +UsePrivilegeSeparation yes + +# Lifetime and size of ephemeral version 1 server key +KeyRegenerationInterval 3600 +ServerKeyBits 768 + +# Logging +SyslogFacility AUTH +LogLevel INFO + +# Authentication: +LoginGraceTime 120 +PermitRootLogin no +StrictModes yes + +RSAAuthentication yes +PubkeyAuthentication yes +#AuthorizedKeysFile %h/.ssh/authorized_keys + +# Don't read the user's ~/.rhosts and ~/.shosts files +IgnoreRhosts yes +# For this to work you will also need host keys in /etc/ssh_known_hosts +RhostsRSAAuthentication no +# similar for protocol version 2 +HostbasedAuthentication no +# Uncomment if you don't trust ~/.ssh/known_hosts for RhostsRSAAuthentication +#IgnoreUserKnownHosts yes + +# To enable empty passwords, change to yes (NOT RECOMMENDED) +PermitEmptyPasswords no + +# Change to yes to enable challenge-response passwords (beware issues with +# some PAM modules and threads) +ChallengeResponseAuthentication no + +# Change to no to disable tunnelled clear text passwords +PasswordAuthentication no + +# Kerberos options +#KerberosAuthentication no +#KerberosGetAFSToken no +#KerberosOrLocalPasswd yes +#KerberosTicketCleanup yes + +# GSSAPI options +#GSSAPIAuthentication no +#GSSAPICleanupCredentials yes + +X11Forwarding yes +X11DisplayOffset 10 +PrintMotd no +PrintLastLog yes +TCPKeepAlive yes +#UseLogin no + +#MaxStartups 10:30:60 +#Banner /etc/issue.net + +# Allow client to pass locale environment variables +AcceptEnv LANG LC_* + +Subsystem sftp /usr/lib/openssh/sftp-server + +# Set this to 'yes' to enable PAM authentication, account processing, +# and session processing. If this is enabled, PAM authentication will +# be allowed through the ChallengeResponseAuthentication and +# PasswordAuthentication. Depending on your PAM configuration, +# PAM authentication via ChallengeResponseAuthentication may bypass +# the setting of "PermitRootLogin without-password". +# If you just want the PAM account and session checks to run without +# PAM authentication, then enable this but set PasswordAuthentication +# and ChallengeResponseAuthentication to 'no'. +UsePAM yes diff --git a/modules/ssh/manifests/init.pp b/modules/ssh/manifests/init.pp new file mode 100644 index 0000000000..1e6cbe74e5 --- /dev/null +++ b/modules/ssh/manifests/init.pp @@ -0,0 +1,19 @@ +class ssh { + package { openssh-server: ensure => latest } + service { ssh: + ensure => running, + hasrestart => true, + subscribe => File["/etc/ssh/sshd_config"], + } + file { "/etc/ssh/sshd_config": + owner => 'root', + group => 'root', + mode => 444, + ensure => 'present', + source => [ + "puppet:///modules/ssh/sshd_config.$operatingsystem", + "puppet:///modules/ssh/sshd_config" + ], + replace => 'true', + } +}