and an acceptance test
[puppet-modules/puppetlabs-apt.git] / manifests / unattended_upgrades.pp
1 # Class: apt::unattended_upgrades
2 #
3 # This class manages the unattended-upgrades package and related configuration
4 # files for ubuntu
5 #
6 # origins are the repositories to automatically upgrade included packages
7 # blacklist is a list of packages to not automatically upgrade
8 # update is how often to run "apt-get update" in days
9 # download is how often to run "apt-get upgrade --download-only" in days
10 # upgrade is how often to upgrade packages included in the origins list in days
11 # autoclean is how often to run "apt-get autoclean" in days
12 #
13 # information on the other options can be found in the 50unattended-upgrades
14 # file and in /etc/cron.daily/apt
15 #
16 class apt::unattended_upgrades (
17   $origins             = $::apt::params::origins,
18   $blacklist           = [],
19   $update              = '1',
20   $download            = '1',
21   $upgrade             = '1',
22   $autoclean           = '7',
23   $auto_fix            = true,
24   $minimal_steps       = false,
25   $install_on_shutdown = false,
26   $mail_to             = 'NONE',
27   $mail_only_on_error  = false,
28   $remove_unused       = true,
29   $auto_reboot         = false,
30   $dl_limit            = 'NONE',
31   $randomsleep         = undef,
32   $enable              = '1',
33   $backup_interval     = '0',
34   $backup_level        = '3',
35   $max_age             = '0',
36   $min_age             = '0',
37   $max_size            = '0',
38   $download_delta      = '0',
39   $verbose             = '0',
40 ) inherits ::apt::params {
41
42   validate_bool(
43     $auto_fix,
44     $minimal_steps,
45     $install_on_shutdown,
46     $mail_only_on_error,
47     $remove_unused,
48     $auto_reboot
49   )
50   validate_array($origins)
51
52   if $randomsleep {
53     unless is_numeric($randomsleep) {
54       fail('randomsleep must be numeric')
55     }
56   }
57
58   package { 'unattended-upgrades':
59     ensure => present,
60   }
61
62   file { '/etc/apt/apt.conf.d/50unattended-upgrades':
63     ensure  => file,
64     owner   => 'root',
65     group   => 'root',
66     mode    => '0644',
67     content => template('apt/_header.erb', 'apt/50unattended-upgrades.erb'),
68     require => Package['unattended-upgrades'],
69   }
70
71   file { '/etc/apt/apt.conf.d/10periodic':
72     ensure  => file,
73     owner   => 'root',
74     group   => 'root',
75     mode    => '0644',
76     content => template('apt/_header.erb', 'apt/10periodic.erb'),
77     require => Package['unattended-upgrades'],
78   }
79 }