module-apt/manifests/init.pp

134 lines
3.9 KiB
ObjectPascal
Raw Normal View History

# apt.pp - common components and defaults for handling apt
# Copyright (C) 2008 Micah Anerson <micah@riseup.net>
# Copyright (C) 2007 David Schmitt <david@schmitt.edv-bus.at>
# See LICENSE for the full license granted to you.
2012-06-06 02:31:15 +02:00
class apt(
$codename = '',
2012-06-14 15:07:29 +02:00
$use_volatile = false,
$include_src = false,
$use_next_release = false,
$debian_url = 'http://cdn.debian.net/debian/',
$security_url = 'http://security.debian.org/',
$backports_url = 'http://backports.debian.org/debian-backports/',
$volatile_url = 'http://volatile.debian.org/debian-volatile/',
$ubuntu_url = 'http://archive.ubuntu.com/ubuntu',
$repos = 'auto',
$custom_preferences = ''
){
2012-06-06 02:31:15 +02:00
case $::operatingsystem {
2010-10-17 02:01:48 +02:00
'debian': {
2012-06-06 02:31:15 +02:00
$real_repos = $repos ? {
'auto' => 'main contrib non-free',
default => $repos,
2010-10-17 02:01:48 +02:00
}
}
'ubuntu': {
2012-06-06 02:31:15 +02:00
$real_repos = $repos ? {
2010-10-17 02:01:48 +02:00
'' => 'main restricted universe multiverse',
2012-06-06 02:31:15 +02:00
default => $repos,
2010-10-17 02:01:48 +02:00
}
}
}
2010-10-06 12:09:38 +02:00
package { apt:
ensure => installed,
require => undef,
}
include lsb
# init $release, $next_release, $codename, $next_codename, $release_version
case $codename {
'': {
$codename = $::lsbdistcodename
2012-06-06 02:31:15 +02:00
$release = $::lsbdistrelease
}
default: {
$release = debian_release($codename)
}
}
$release_version = debian_release_version($codename)
$next_codename = debian_nextcodename($codename)
$next_release = debian_nextrelease($release)
2012-06-18 16:41:04 +02:00
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 ? {
2012-06-06 02:31:15 +02:00
'' => template( "apt/${::operatingsystem}/sources.list.erb"),
default => $custom_sources_list
},
require => Package['lsb'],
notify => Exec['refresh_apt'],
2012-06-18 16:41:04 +02:00
owner => root, group => 0, mode => 0644;
}
apt_conf { "02show_upgraded":
2012-06-06 02:31:15 +02:00
source => [ "puppet:///modules/site_apt/${::fqdn}/02show_upgraded",
"puppet:///modules/site_apt/02show_upgraded",
2010-12-07 19:18:41 +01:00
"puppet:///modules/apt/02show_upgraded" ]
}
2012-06-06 02:31:15 +02:00
if ( $::virtual == "vserver" ) {
apt_conf { "03clean_vserver":
2012-06-06 02:31:15 +02:00
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":
2012-06-06 02:31:15 +02:00
source => [ "puppet:///modules/site_apt/${::fqdn}/03clean",
"puppet:///modules/site_apt/03clean",
2010-12-07 19:18:41 +01:00
"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
}
}
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 }
}