41 lines
1.1 KiB
Puppet
41 lines
1.1 KiB
Puppet
# The base class to setup the common things.
|
|
# This is a private class and will always be used
|
|
# throught the sshd class itself.
|
|
class sshd::base {
|
|
|
|
$sshd_config_content = $::operatingsystem ? {
|
|
'CentOS' => template("sshd/sshd_config/${::operatingsystem}_${::operatingsystemmajrelease}.erb"),
|
|
default => $::lsbdistcodename ? {
|
|
'' => template("sshd/sshd_config/${::operatingsystem}.erb"),
|
|
default => template("sshd/sshd_config/${::operatingsystem}_${::lsbdistcodename}.erb")
|
|
}
|
|
}
|
|
|
|
file { 'sshd_config':
|
|
ensure => present,
|
|
path => '/etc/ssh/sshd_config',
|
|
content => $sshd_config_content,
|
|
notify => Service[sshd],
|
|
owner => root,
|
|
group => 0,
|
|
mode => '0600';
|
|
}
|
|
|
|
# Now add the key, if we've got one
|
|
case $::sshrsakey {
|
|
'': { info("no sshrsakey on ${::fqdn}") }
|
|
default: {
|
|
# only export sshkey when storedconfigs is enabled
|
|
if $::sshd::use_storedconfigs {
|
|
include ::sshd::sshkey
|
|
}
|
|
}
|
|
}
|
|
service{'sshd':
|
|
ensure => running,
|
|
name => 'sshd',
|
|
enable => true,
|
|
hasstatus => true,
|
|
require => File[sshd_config],
|
|
}
|
|
}
|