2010-04-27 22:38:28 +02:00
|
|
|
# pin.pp
|
|
|
|
# pin a release in apt, useful for unstable repositories
|
|
|
|
|
|
|
|
define apt::pin(
|
2013-06-18 11:31:38 +02:00
|
|
|
$ensure = present,
|
2014-03-28 08:49:18 +01:00
|
|
|
$explanation = "${caller_module_name}: ${name}",
|
2013-06-18 11:31:38 +02:00
|
|
|
$order = '',
|
|
|
|
$packages = '*',
|
|
|
|
$priority = 0,
|
|
|
|
$release = '', # a=
|
|
|
|
$origin = '',
|
|
|
|
$version = '',
|
|
|
|
$codename = '', # n=
|
|
|
|
$release_version = '', # v=
|
|
|
|
$component = '', # c=
|
|
|
|
$originator = '', # o=
|
2013-06-18 15:14:00 +02:00
|
|
|
$label = '' # l=
|
2010-04-27 22:38:28 +02:00
|
|
|
) {
|
2011-05-30 19:18:13 +02:00
|
|
|
include apt::params
|
2010-04-27 22:38:28 +02:00
|
|
|
|
2012-04-11 23:54:13 +02:00
|
|
|
$preferences_d = $apt::params::preferences_d
|
|
|
|
|
2012-08-21 23:14:54 +02:00
|
|
|
if $order != '' and !is_integer($order) {
|
|
|
|
fail('Only integers are allowed in the apt::pin order param')
|
|
|
|
}
|
|
|
|
|
2013-06-18 15:14:00 +02:00
|
|
|
$pin_release_array = [
|
2013-06-18 11:31:38 +02:00
|
|
|
$release,
|
|
|
|
$codename,
|
|
|
|
$release_version,
|
|
|
|
$component,
|
|
|
|
$originator,
|
2013-09-04 23:32:42 +02:00
|
|
|
$label]
|
2013-06-18 15:14:00 +02:00
|
|
|
$pin_release = join($pin_release_array, '')
|
2013-06-18 11:31:38 +02:00
|
|
|
|
|
|
|
# Read the manpage 'apt_preferences(5)', especially the chapter
|
2014-08-01 00:11:57 +02:00
|
|
|
# 'The Effect of APT Preferences' to understand the following logic
|
2013-06-18 11:31:38 +02:00
|
|
|
# and the difference between specific and general form
|
2014-02-14 16:13:14 +01:00
|
|
|
if is_array($packages) {
|
|
|
|
$packages_string = join($packages, ' ')
|
|
|
|
} else {
|
|
|
|
$packages_string = $packages
|
|
|
|
}
|
|
|
|
|
|
|
|
if $packages_string != '*' { # specific form
|
2013-06-18 11:31:38 +02:00
|
|
|
if ( $pin_release != '' and ( $origin != '' or $version != '' )) or
|
|
|
|
( $version != '' and ( $pin_release != '' or $origin != '' )) {
|
|
|
|
fail('parameters release, origin, and version are mutually exclusive')
|
|
|
|
}
|
|
|
|
} else { # general form
|
|
|
|
if $version != '' {
|
|
|
|
fail('parameter version cannot be used in general form')
|
|
|
|
}
|
2014-08-01 00:11:57 +02:00
|
|
|
if ( $pin_release != '' and $origin != '' ) {
|
|
|
|
fail('parameters release and origin are mutually exclusive')
|
2013-06-18 11:31:38 +02:00
|
|
|
}
|
2012-05-21 23:19:18 +02:00
|
|
|
}
|
|
|
|
|
2014-03-05 16:12:04 +01:00
|
|
|
|
|
|
|
# According to man 5 apt_preferences:
|
|
|
|
# The files have either no or "pref" as filename extension
|
|
|
|
# and only contain alphanumeric, hyphen (-), underscore (_) and period
|
|
|
|
# (.) characters. Otherwise APT will print a notice that it has ignored a
|
|
|
|
# file, unless that file matches a pattern in the
|
|
|
|
# Dir::Ignore-Files-Silently configuration list - in which case it will
|
|
|
|
# be silently ignored.
|
|
|
|
$file_name = regsubst($title, '[^0-9a-z\-_\.]', '_', 'IG')
|
|
|
|
|
2014-05-19 07:33:06 +02:00
|
|
|
$path = $order ? {
|
|
|
|
'' => "${preferences_d}/${file_name}.pref",
|
|
|
|
default => "${preferences_d}/${order}-${file_name}.pref",
|
|
|
|
}
|
2014-03-05 16:12:04 +01:00
|
|
|
file { "${file_name}.pref":
|
2012-05-04 01:59:13 +02:00
|
|
|
ensure => $ensure,
|
2012-08-21 23:14:54 +02:00
|
|
|
path => $path,
|
2012-03-21 14:20:13 +01:00
|
|
|
owner => root,
|
|
|
|
group => root,
|
|
|
|
mode => '0644',
|
2012-08-21 22:55:24 +02:00
|
|
|
content => template('apt/pin.pref.erb'),
|
2011-05-30 19:24:06 +02:00
|
|
|
}
|
2010-04-27 22:38:28 +02:00
|
|
|
}
|