define apt::source(
$location = '',
- $release = 'karmic',
+ $release = $lsbdistcodename,
$repos = 'main',
$include_src = true,
$required_packages = false,
$key = false,
$key_server = 'keyserver.ubuntu.com',
- $pin = false,
- $key_content = false
+ $key_content = false,
+ $key_source = false,
+ $pin = false
) {
include apt::params
+ if $release == undef {
+ fail('lsbdistcodename fact not available: release parameter required')
+ }
file { "${name}.list":
- name => "${apt::params::root}/sources.list.d/${name}.list",
- ensure => file,
- owner => root,
- group => root,
- mode => 644,
- content => template("apt/source.list.erb"),
+ ensure => file,
+ path => "${apt::params::root}/sources.list.d/${name}.list",
+ owner => root,
+ group => root,
+ mode => '0644',
+ content => template("${module_name}/source.list.erb"),
}
if $pin != false {
- apt::pin { "${release}": priority => "${pin}" } -> File["${name}.list"]
+ apt::pin { $release:
+ priority => $pin,
+ before => File["${name}.list"]
+ }
}
exec { "${name} apt update":
- command => "${apt::params::provider} update",
- subscribe => File["${name}.list"],
+ command => "${apt::params::provider} update",
+ subscribe => File["${name}.list"],
refreshonly => true,
}
if $required_packages != false {
- exec { "${apt::params::provider} -y install ${required_packages}":
- subscribe => File["${name}.list"],
+ exec { "Required packages: '${required_packages}' for ${name}":
+ command => "${apt::params::provider} -y install ${required_packages}",
+ subscribe => File["${name}.list"],
refreshonly => true,
}
}
if $key != false {
- if $key_content {
- exec { "Add key: ${key} from content":
- command => "/bin/echo '${key_content}' | /usr/bin/apt-key add -",
- unless => "/usr/bin/apt-key list | /bin/grep '${key}'",
- before => File["${name}.list"],
- }
- } else {
- exec { "/usr/bin/apt-key adv --keyserver ${key_server} --recv-keys ${key}":
- unless => "/usr/bin/apt-key list | /bin/grep ${key}",
- before => File["${name}.list"],
- }
+ apt::key { "Add key: ${key} from Apt::Source ${title}":
+ ensure => present,
+ key => $key,
+ key_server => $key_server,
+ key_content => $key_content,
+ key_source => $key_source,
+ before => File["${name}.list"],
}
}
}