2009-09-29 19:53:04 +02:00
|
|
|
# wrapper to have some defaults.
|
|
|
|
define sshd::ssh_authorized_key(
|
2009-12-18 18:36:05 +01:00
|
|
|
$ensure = 'present',
|
2009-09-29 19:53:04 +02:00
|
|
|
$type = 'ssh-dss',
|
2009-12-18 19:06:43 +01:00
|
|
|
$key = 'absent',
|
2011-01-20 08:25:32 +01:00
|
|
|
$user = '',
|
2009-12-10 23:15:07 +01:00
|
|
|
$target = undef,
|
2009-09-29 19:53:04 +02:00
|
|
|
$options = 'absent'
|
|
|
|
){
|
|
|
|
|
2009-12-18 19:06:43 +01:00
|
|
|
if ($ensure=='present') and ($key=='absent') {
|
|
|
|
fail("You have to set \$key for Sshd::Ssh_authorized_key[${name}]!")
|
|
|
|
}
|
|
|
|
|
2009-12-10 23:15:07 +01:00
|
|
|
$real_user = $user ? {
|
|
|
|
false => $name,
|
2009-12-10 23:34:57 +01:00
|
|
|
'' => $name,
|
2009-12-10 23:15:07 +01:00
|
|
|
default => $user,
|
|
|
|
}
|
|
|
|
|
|
|
|
case $target {
|
2009-12-10 23:34:57 +01:00
|
|
|
undef,'': {
|
|
|
|
case $real_user {
|
2009-12-10 23:15:07 +01:00
|
|
|
'root': { $real_target = '/root/.ssh/authorized_keys' }
|
2011-01-20 02:45:59 +01:00
|
|
|
default: { $real_target = "/home/${real_user}/.ssh/authorized_keys" }
|
2009-12-10 23:15:07 +01:00
|
|
|
}
|
2009-09-29 19:53:04 +02:00
|
|
|
}
|
2009-12-10 23:15:07 +01:00
|
|
|
default: {
|
|
|
|
$real_target = $target
|
2009-09-29 19:53:04 +02:00
|
|
|
}
|
2009-12-10 23:15:07 +01:00
|
|
|
}
|
|
|
|
ssh_authorized_key{$name:
|
2009-12-18 18:36:05 +01:00
|
|
|
ensure => $ensure,
|
2009-12-10 23:15:07 +01:00
|
|
|
type => $type,
|
|
|
|
key => $key,
|
|
|
|
user => $real_user,
|
|
|
|
target => $real_target,
|
|
|
|
}
|
2009-09-29 19:53:04 +02:00
|
|
|
|
2009-12-10 23:15:07 +01:00
|
|
|
case $options {
|
|
|
|
'absent': { info("not setting any option for ssh_authorized_key: $name") }
|
|
|
|
default: {
|
|
|
|
Ssh_authorized_key[$name]{
|
|
|
|
options => $options,
|
|
|
|
}
|
2009-09-29 19:53:04 +02:00
|
|
|
}
|
2009-12-10 23:15:07 +01:00
|
|
|
}
|
2009-09-29 19:53:04 +02:00
|
|
|
}
|