2014-01-25 19:08:04 +01:00
# Puppet SSH Module
2014-01-25 13:23:27 +01:00
2014-01-26 15:33:18 +01:00
[![Build Status ](https://travis-ci.org/duritong/puppet-sshd.png?branch=master )](https://travis-ci.org/duritong/puppet-sshd)
2011-02-19 20:12:04 +01:00
This puppet module manages OpenSSH configuration and services.
2014-01-25 13:30:49 +01:00
**!! Upgrade Notice (01/2013) !!**
2013-01-09 00:01:15 +01:00
This module now uses parameterized classes, where it used global variables
2014-01-25 13:23:27 +01:00
before. So please whatch out before pulling, you need to change the
2013-01-09 00:01:15 +01:00
class declarations in your manifest !
2014-01-25 13:23:27 +01:00
### Dependencies
2011-02-19 20:12:04 +01:00
This module requires puppet => 2.6, and the following modules are required
pre-dependencies:
2010-10-04 22:03:49 +02:00
2014-01-26 09:36:35 +01:00
- [puppetlabs/stdlib ](https://github.com/puppetlabs/puppetlabs-stdlib ) >= 2.x
2011-02-19 20:12:04 +01:00
2014-01-25 13:23:27 +01:00
## OpenSSH Server
2011-02-19 20:12:04 +01:00
On a node where you wish to have an openssh server installed, you should
2014-01-25 13:23:27 +01:00
include
```puppet
class { 'sshd': }
```
2014-01-25 19:08:04 +01:00
on that node. If you need to configure any aspects of sshd_config, set the variables before the include. Or you can adjust many parameters:
```puppet
class { 'sshd':
ports => [ 20002 ],
permit_root_login => 'no',
}
```
See Configurable Variables below for what you can set.
2011-02-19 20:12:04 +01:00
2014-01-25 13:23:27 +01:00
### Nagios
2011-02-19 20:12:04 +01:00
To have nagios checks setup automatically for sshd services, simply set
2014-01-25 13:23:27 +01:00
`manage_nagios` to `true` for that class. If you want to disable ssh
2011-02-19 20:12:04 +01:00
nagios checking for a particular node (such as when ssh is firewalled), then you
2014-01-25 13:23:27 +01:00
can set the class parameter `nagios_check_ssh` to `false` and that node will not be
monitored.
2011-02-19 20:12:04 +01:00
2014-01-25 13:30:49 +01:00
Nagios will automatically check the ports defined in `ports` , and the
hostname specified by `nagios_check_ssh_hostname` .
2011-02-19 20:12:04 +01:00
NOTE: this requires that you are using the shared-nagios puppet module which
2014-01-25 13:23:27 +01:00
supports the nagios native types via `nagios::service` :
2015-02-20 23:24:12 +01:00
https://gitlab.com/shared-puppet-modules-group/sshd
2011-02-19 20:12:04 +01:00
2014-01-25 13:23:27 +01:00
### Firewall
2011-02-19 20:12:04 +01:00
If you wish to have firewall rules setup automatically for you, using shorewall,
2014-01-25 13:30:49 +01:00
you will need to set: `use_shorewall => true` . The `ports` that you have
2011-02-19 20:12:04 +01:00
specified will automatically be used.
NOTE: This requires that you are using the shared-shorewall puppet module:
git://labs.riseup.net/shared-shorewall
2014-01-25 13:23:27 +01:00
### Configurable variables
2011-02-19 20:12:04 +01:00
Configuration of sshd is strict, and may not fit all needs, however there are a
number of variables that you can consider configuring. The defaults are set to
2014-01-25 13:23:27 +01:00
the distribution shipped sshd_config file defaults.
2011-02-19 20:12:04 +01:00
To set any of these variables, simply set them as variables in your manifests,
before the class is included, for example:
2014-01-25 13:23:27 +01:00
```puppet
class {'sshd':
listen_address => ['10.0.0.1', '192.168.0.1'],
use_pam => yes
}
```
2011-02-19 20:12:04 +01:00
If you need to install a version of the ssh daemon or client package other than
2014-01-25 13:23:27 +01:00
the default one that would be installed by `ensure => installed` , then you can
2011-02-19 20:12:04 +01:00
set the following variables:
2014-01-25 13:23:27 +01:00
```puppet
class {'sshd':
ensure_version => "1:5.2p2-6"
}
```
2011-02-19 20:12:04 +01:00
The following is a list of the currently available variables:
2014-01-25 13:23:27 +01:00
- `listen_address`
specify the addresses sshd should listen on set this to `['10.0.0.1', '192.168.0.1']` to have it listen on both addresses, or leave it unset to listen on all Default: empty -> results in listening on `0.0.0.0`
- `allowed_users`
list of usernames separated by spaces. set this for example to `"foobar
root"` to ensure that only user foobar and root might login. Default: empty
2011-02-19 20:12:04 +01:00
-> no restriction is set
2014-01-25 13:23:27 +01:00
- `allowed_groups`
list of groups separated by spaces. set this for example to `"wheel sftponly"`
2011-02-19 20:12:04 +01:00
to ensure that only users in the groups wheel and sftponly might login.
Default: empty -> no restriction is set Note: This is set after
2014-01-25 13:23:27 +01:00
`allowed_users` , take care of the behaviour if you use these 2 options
2011-02-19 20:12:04 +01:00
together.
2014-01-25 13:30:49 +01:00
- `use_pam` if you want to use pam or not for authenticaton. Values:
- `no` (default)
- `yes`
- `permit_root_login` If you want to allow root logins or not. Valid values:
- `yes`
- `no`
- `without-password` (default)
- `forced-commands-only`
2014-01-25 13:23:27 +01:00
- `password_authentication`
2014-01-25 13:41:08 +01:00
If you want to enable password authentication or not. Valid values:
- `yes`
- `no` (default)
2014-01-25 13:23:27 +01:00
- `kerberos_authentication`
2011-02-19 20:12:04 +01:00
If you want the password that is provided by the user to be validated
through the Kerberos KDC. To use this option the server needs a Kerberos
servtab which allows the verification of the KDC's identity. Valid values:
2014-01-25 13:41:08 +01:00
- `yes`
- `no` (default)
- `kerberos_orlocalpasswd` If password authentication through Kerberos fails, then the password will be validated via any additional local mechanism. Valid values:
- `yes` (default)
- `no`
- `kerberos_ticketcleanup` Destroy the user's ticket cache file on logout? Valid values:
- `yes` (default)
- `no`
- `gssapi_authentication` Authenticate users based on GSSAPI? Valid values:
- `yes`
- `no` (default)
- `gssapi_cleanupcredentials` Destroy user's credential cache on logout? Valid values:
- `yes` (default)
- `no`
- `challenge_response_authentication` If you want to enable ChallengeResponseAuthentication or not When disabled, s/key passwords are disabled. Valid values:
- `yes`
- `no` (default)
- `tcp_forwarding` If you want to enable TcpForwarding. Valid values:
- `yes`
- `no` (default)
- `x11_forwarding` If you want to enable x11 forwarding. Valid values:
- `yes`
- `no` (default)
- `agent_forwarding` If you want to allow ssh-agent forwarding. Valid values:
- `yes`
- `no` (default)
- `pubkey_authentication` If you want to enable public key authentication. Valid values:
- `yes` (default)
- `no`
- `rsa_authentication` If you want to enable RSA Authentication. Valid values:
- `yes`
- `no` (default)
2014-01-25 13:23:27 +01:00
- `rhosts_rsa_authentication`
2014-01-25 13:41:08 +01:00
If you want to enable rhosts RSA Authentication. Valid values:
- `yes`
- `no` (default)
- `hostbased_authentication` If you want to enable `HostbasedAuthentication` . Valid values:
- `yes`
- `no` (default)
- `strict_modes` If you want to set `StrictModes` (check file modes/ownership before accepting login). Valid values:
- `yes` (default)
- `no`
2014-01-25 13:23:27 +01:00
- `permit_empty_passwords`
If you want enable PermitEmptyPasswords to allow empty passwords. Valid
2014-01-25 13:41:08 +01:00
Values:
- `yes`
- `no` (default)
- `ports` If you want to specify a list of ports other than the default `22` ; Default: `[22]`
2014-01-25 13:23:27 +01:00
- `authorized_keys_file`
2011-02-19 20:12:04 +01:00
Set this to the location of the AuthorizedKeysFile
2014-01-25 13:23:27 +01:00
(e.g. `/etc/ssh/authorized_keys/%u` ). Default: `AuthorizedKeysFile
%h/.ssh/authorized_keys`
- `hardened_ssl`
2011-03-06 09:10:44 +01:00
Use only strong SSL ciphers and MAC.
2014-01-25 13:41:08 +01:00
Values:
- `no` (default)
- `yes`
2014-01-25 13:23:27 +01:00
- `print_motd`
2011-07-17 06:28:54 +02:00
Show the Message of the day when a user logs in.
2014-01-25 13:23:27 +01:00
- `sftp_subsystem`
2011-02-19 20:12:04 +01:00
Set a different sftp-subystem than the default one. Might be interesting for
sftponly usage. Default: empty -> no change of the default
2014-01-25 13:23:27 +01:00
- `head_additional_options`
2011-02-19 20:12:04 +01:00
Set this to any additional sshd_options which aren't listed above. Anything
set here will be added to the beginning of the sshd_config file. This option
might be useful to define complicated Match Blocks. This string is going to
be included, like it is defined. So take care! Default: empty -> not added.
2014-01-25 13:41:08 +01:00
- `tail_additional_options` Set this to any additional sshd_options which aren't listed above. Anything set here will be added to the end of the sshd_config file. This option might be useful to define complicated Match Blocks. This string is going to be included, like it is defined. So take care! Default: empty -> not added.
- `shared_ip` Whether the server uses a shared network IP address. If it does, then we don't want it to export an rsa key for its IP address. Values:
- `no` (default)
- `yes`
2011-07-17 06:38:25 +02:00
2011-02-19 20:12:04 +01:00
2014-01-25 13:23:27 +01:00
### Defines and functions
2011-02-19 20:18:02 +01:00
2014-01-25 13:23:27 +01:00
Deploy authorized_keys file with the define `authorized_key` .
2011-02-19 20:18:02 +01:00
Generate a public/private keypair with the ssh_keygen function. For example, the
following will generate ssh keys and put the different parts of the key into
variables:
2014-01-25 13:23:27 +01:00
```puppet
2012-06-05 23:46:39 +02:00
$ssh_keys = ssh_keygen("${$ssh_key_basepath}/backup/keys/${::fqdn}/${backup_host}")
2011-02-19 20:18:02 +01:00
$public_key = split($ssh_keys[1],' ')
$sshkey_type => $public_key[0]
$sshkey => $public_key[1]
2014-01-25 13:23:27 +01:00
```
## Client
On a node where you wish to have the ssh client managed, you can do:
```puppet
class{'sshd::client':
}
```
2011-02-19 20:12:04 +01:00
2014-01-25 13:23:27 +01:00
in the node definition. This will install the appropriate package.
2011-02-19 20:12:04 +01:00
2014-01-25 13:23:27 +01:00
## License
2011-02-19 20:12:04 +01:00
2014-01-25 13:30:49 +01:00
- Copyright 2008-2011, Riseup Labs micah@riseup.net
- Copyright 2008, admin(at)immerda.ch
- Copyright 2008, Puzzle ITC GmbH
- Marcel Härry haerry+puppet(at)puzzle.ch
- Simon Josi josi+puppet(at)puzzle.ch
2011-02-19 20:12:04 +01:00
2014-01-25 13:23:27 +01:00
This program is free software; you can redistribute
it and/or modify it under the terms of the GNU
General Public License version 3 as published by
the Free Software Foundation.
2011-02-19 20:12:04 +01:00