forked from duosecurity/puppet-duo_unix
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathyum.pp
58 lines (51 loc) · 1.52 KB
/
yum.pp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
# == Class: duo_unix::yum
#
# Provides duo_unix for a yum-based environment (e.g. RHEL/CentOS)
#
# === Authors
#
# Mark Stanislav <[email protected]>
#
class duo_unix::yum {
$repo_uri = 'http://pkg.duosecurity.com'
$package_state = $::duo_unix::package_version
# Map Amazon Linux to RedHat equivalent releases
# Map RedHat 5 to CentOS 5 equivalent releases
if $::operatingsystem == 'Amazon' {
$releasever = $::operatingsystemmajrelease ? {
'2014' => '6Server',
default => undef,
}
$os = $::operatingsystem
} elsif ( $::operatingsystem == 'RedHat' and
versioncmp($::operatingsystemmajrelease,'5') ) {
$os = 'CentOS'
$releasever = '$releasever'
} elsif ( $::operatingsystem == 'OracleLinux' ) {
$os = 'CentOS'
$releasever = '$releasever'
} else {
$os = $::operatingsystem
$releasever = '$releasever'
}
yumrepo { 'duosecurity':
descr => 'Duo Security Repository',
baseurl => "${repo_uri}/${os}/${releasever}/\$basearch",
gpgcheck => '1',
enabled => '1',
require => File['/etc/pki/rpm-gpg/RPM-GPG-KEY-DUO'];
}
if $duo_unix::manage_ssh {
package { 'openssh-server':
ensure => installed;
}
}
package { $duo_unix::duo_package:
ensure => $package_state,
require => [ Yumrepo['duosecurity'], Exec['Duo Security GPG Import'] ];
}
exec { 'Duo Security GPG Import':
command => '/bin/rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-DUO',
unless => '/bin/rpm -qi gpg-pubkey | grep Duo > /dev/null 2>&1'
}
}