# apt.pp - common components and defaults for handling apt # Copyright (C) 2008 Micah Anerson # Copyright (C) 2007 David Schmitt # See LICENSE for the full license granted to you. class apt { $use_volatile = $apt_volatile_enabled ? { '' => false, default => $apt_volatile_enabled, } $include_src = $apt_include_src ? { '' => false, default => $apt_include_src, } $use_next_release = $apt_use_next_release ? { '' => false, default => $apt_use_next_release, } $debian_url = $apt_debian_url ? { '' => 'http://http.debian.net/debian/', default => "${apt_debian_url}", } $security_url = $apt_security_url ? { '' => 'http://security.debian.org/', default => "${apt_security_url}", } $backports_url = $apt_backports_url ? { '' => 'http://backports.debian.org/debian-backports/', default => "${apt_backports_url}", } $volatile_url = $apt_volatile_url ? { '' => 'http://volatile.debian.org/debian-volatile/', default => "${apt_volatile_url}", } $ubuntu_url = $apt_ubuntu_url ? { '' => 'http://archive.ubuntu.com/ubuntu', default => "${apt_ubuntu_url}", } $disable_update = $apt_disable_update ? { '' => false, default => $apt_disable_update } case $operatingsystem { 'debian': { $repos = $apt_repos ? { '' => 'main contrib non-free', default => "${apt_repos}", } } 'ubuntu': { $repos = $apt_repos ? { '' => 'main restricted universe multiverse', default => "${apt_repos}", } } } package { apt: ensure => installed, require => undef, } include lsb # init $release, $next_release, $codename, $next_codename, $release_version case $lsbdistcodename { '': { $codename = $lsbdistcodename $release = $lsbdistrelease } 'n/a': { fail("Unknown lsbdistcodename reported by facter: '$lsbdistcodename', please fix this by setting this variable in your manifest.") } default: { $codename = $lsbdistcodename $release = debian_release($codename) } } $release_version = debian_release_version($codename) $next_codename = debian_nextcodename($codename) $next_release = debian_nextrelease($release) config_file { # include main, security and backports # additional sources should be included via the apt::sources_list define "/etc/apt/sources.list": content => $custom_sources_list ? { '' => template( "apt/$operatingsystem/sources.list.erb"), default => $custom_sources_list }, require => Package['lsb'], notify => Exec['refresh_apt'], } apt_conf { "02show_upgraded": source => [ "puppet:///modules/site_apt/${fqdn}/02show_upgraded", "puppet:///modules/site_apt/02show_upgraded", "puppet:///modules/apt/02show_upgraded" ] } if ( $virtual == "vserver" ) { apt_conf { "03clean_vserver": source => [ "puppet:///modules/site_apt/${fqdn}/03clean_vserver", "puppet:///modules/site_apt/03clean_vserver", "puppet:///modules/apt/03clean_vserver" ], alias => "03clean"; } } else { apt_conf { "03clean": source => [ "puppet:///modules/site_apt/${fqdn}/03clean", "puppet:///modules/site_apt/03clean", "puppet:///modules/apt/03clean" ] } } case $custom_preferences { false: { include apt::preferences::absent } default: { # When squeeze becomes the stable branch, transform this file's header # into a preferences.d file include apt::preferences } } # backward compatibility: upgrade from previous versions of this module. file { [ "/etc/apt/apt.conf.d/from_puppet", "/etc/apt/apt.conf.d/99from_puppet" ]: ensure => 'absent', require => [ Apt_conf['02show_upgraded'], Apt_conf['03clean'] ]; } include apt::dot_d_directories ## This package should really always be current package { "debian-archive-keyring": ensure => latest } # backports uses the normal archive key now package { "debian-backports-keyring": ensure => absent } include common::moduledir $apt_base_dir = "${common::moduledir::module_dir_path}/apt" modules_dir { apt: } if $custom_key_dir { file { "${apt_base_dir}/keys.d": source => "$custom_key_dir", recurse => true, mode => 0755, owner => root, group => root, } exec { "custom_keys": command => "find ${apt_base_dir}/keys.d -type f -exec apt-key add '{}' \\; && /usr/bin/apt-get update", subscribe => File["${apt_base_dir}/keys.d"], refreshonly => true, } if $custom_preferences != false { Exec["custom_keys"] { before => Concat[apt_config], } } } # workaround for preseeded_package component file { [ "/var/cache", "/var/cache/local", "/var/cache/local/preseeding" ]: ensure => directory } }