Code Review
/
puppet-modules
/
puppetlabs-apt.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
review
|
tree
raw
|
inline
| side by side
(MODULES-4098) Sync the rest of the files
[puppet-modules/puppetlabs-apt.git]
/
manifests
/
init.pp
diff --git
a/manifests/init.pp
b/manifests/init.pp
index 453df3171f3e0191cf4ff9018229a6297f85582e..5664edeed5220192b10bc1b0974e8ab98f557d78 100644
(file)
--- a/
manifests/init.pp
+++ b/
manifests/init.pp
@@
-1,11
+1,16
@@
+# == Class: apt
#
#
-class apt(
+# Manage APT (Advanced Packaging Tool)
+#
+class apt (
+ $confs = {},
$update = {},
$purge = {},
$proxy = {},
$sources = {},
$keys = {},
$ppas = {},
$update = {},
$purge = {},
$proxy = {},
$sources = {},
$keys = {},
$ppas = {},
+ $pins = {},
$settings = {},
) inherits ::apt::params {
$settings = {},
) inherits ::apt::params {
@@
-26,7
+31,7
@@
class apt(
}
$_update = merge($::apt::update_defaults, $update)
}
$_update = merge($::apt::update_defaults, $update)
- include apt::update
+ include
::
apt::update
validate_hash($purge)
if $purge['sources.list'] {
validate_hash($purge)
if $purge['sources.list'] {
@@
-45,6
+50,9
@@
class apt(
$_purge = merge($::apt::purge_defaults, $purge)
validate_hash($proxy)
$_purge = merge($::apt::purge_defaults, $purge)
validate_hash($proxy)
+ if $proxy['ensure'] {
+ validate_re($proxy['ensure'], ['file', 'present', 'absent'])
+ }
if $proxy['host'] {
validate_string($proxy['host'])
}
if $proxy['host'] {
validate_string($proxy['host'])
}
@@
-59,26
+67,29
@@
class apt(
$_proxy = merge($apt::proxy_defaults, $proxy)
$_proxy = merge($apt::proxy_defaults, $proxy)
+ validate_hash($confs)
validate_hash($sources)
validate_hash($keys)
validate_hash($settings)
validate_hash($ppas)
validate_hash($sources)
validate_hash($keys)
validate_hash($settings)
validate_hash($ppas)
+ validate_hash($pins)
- if $proxy['host'] {
+ if $
_proxy['ensure'] == 'absent' or $_
proxy['host'] {
apt::setting { 'conf-proxy':
apt::setting { 'conf-proxy':
+ ensure => $_proxy['ensure'],
priority => '01',
priority => '01',
- content => template('apt/_header.erb', 'apt/proxy.erb'),
+ content => template('apt/_
conf_
header.erb', 'apt/proxy.erb'),
}
}
$sources_list_content = $_purge['sources.list'] ? {
}
}
$sources_list_content = $_purge['sources.list'] ? {
-
false => undef
,
-
true => "# Repos managed by puppet.\n"
,
+
true => "# Repos managed by puppet.\n"
,
+
default => undef
,
}
$preferences_ensure = $_purge['preferences'] ? {
}
$preferences_ensure = $_purge['preferences'] ? {
-
false => file
,
-
true => absent
,
+
true => absent
,
+
default => file
,
}
if $_update['frequency'] == 'always' {
}
if $_update['frequency'] == 'always' {
@@
-89,7
+100,7
@@
class apt(
apt::setting { 'conf-update-stamp':
priority => 15,
apt::setting { 'conf-update-stamp':
priority => 15,
- content => template('apt/_header.erb', 'apt/15update-stamp.erb'),
+ content => template('apt/_
conf_
header.erb', 'apt/15update-stamp.erb'),
}
file { 'sources.list':
}
file { 'sources.list':
@@
-99,7
+110,7
@@
class apt(
group => root,
mode => '0644',
content => $sources_list_content,
group => root,
mode => '0644',
content => $sources_list_content,
- notify =>
Exec['apt_
update'],
+ notify =>
Class['apt::
update'],
}
file { 'sources.list.d':
}
file { 'sources.list.d':
@@
-110,7
+121,7
@@
class apt(
mode => '0644',
purge => $_purge['sources.list.d'],
recurse => $_purge['sources.list.d'],
mode => '0644',
purge => $_purge['sources.list.d'],
recurse => $_purge['sources.list.d'],
- notify =>
Exec['apt_
update'],
+ notify =>
Class['apt::
update'],
}
file { 'preferences':
}
file { 'preferences':
@@
-119,7
+130,7
@@
class apt(
owner => root,
group => root,
mode => '0644',
owner => root,
group => root,
mode => '0644',
- notify =>
Exec['apt_
update'],
+ notify =>
Class['apt::
update'],
}
file { 'preferences.d':
}
file { 'preferences.d':
@@
-130,14
+141,12
@@
class apt(
mode => '0644',
purge => $_purge['preferences.d'],
recurse => $_purge['preferences.d'],
mode => '0644',
purge => $_purge['preferences.d'],
recurse => $_purge['preferences.d'],
- notify =>
Exec['apt_
update'],
+ notify =>
Class['apt::
update'],
}
}
- # Need anchor to provide containment for dependencies.
- anchor { 'apt::update':
- require => Class['apt::update'],
+ if $confs {
+ create_resources('apt::conf', $confs)
}
}
-
# manage sources if present
if $sources {
create_resources('apt::source', $sources)
# manage sources if present
if $sources {
create_resources('apt::source', $sources)
@@
-154,4
+163,9
@@
class apt(
if $settings {
create_resources('apt::setting', $settings)
}
if $settings {
create_resources('apt::setting', $settings)
}
+
+ # manage pins if present
+ if $pins {
+ create_resources('apt::pin', $pins)
+ }
}
}