aboutsummaryrefslogtreecommitdiff
path: root/manifests/upgrade_package.pp
diff options
context:
space:
mode:
authorMicah Anderson <micah@riseup.net>2010-09-02 19:12:58 -0400
committerMicah Anderson <micah@riseup.net>2010-09-02 19:12:58 -0400
commita5e4ab40d8e5074c3ef6525358858376c5dbdab7 (patch)
treef3342e4da7e620a7d43564cf7496d666c80b46e6 /manifests/upgrade_package.pp
parent9b916b3224b194c3e6805855b83886eae3e9fd39 (diff)
parentdd36612e50b2c44135fa10fdc3d6120ff2b1220e (diff)
downloadpuppet-apt-a5e4ab40d8e5074c3ef6525358858376c5dbdab7.tar.gz
puppet-apt-a5e4ab40d8e5074c3ef6525358858376c5dbdab7.tar.bz2
Merge remote branch 'immerda/master'
Conflicts: manifests/init.pp
Diffstat (limited to 'manifests/upgrade_package.pp')
-rw-r--r--manifests/upgrade_package.pp19
1 files changed, 19 insertions, 0 deletions
diff --git a/manifests/upgrade_package.pp b/manifests/upgrade_package.pp
new file mode 100644
index 0000000..41d5d52
--- /dev/null
+++ b/manifests/upgrade_package.pp
@@ -0,0 +1,19 @@
+define apt::upgrade_package ($version = "") {
+ case $version {
+ '': {
+ exec { "aptitude -y install $name":
+ onlyif => [ "grep-status -F Status installed -a -P $name -q", "apt-show-versions -u $name | grep -q upgradeable" ],
+ }
+ }
+ 'latest': {
+ exec { "aptitude -y install $name":
+ onlyif => [ "grep-status -F Status installed -a -P $name -q", "apt-show-versions -u $name | grep -q upgradeable" ],
+ }
+ }
+ default: {
+ exec { "aptitude -y install $name=$version":
+ onlyif => [ "grep-status -F Status installed -a -P $name -q", "apt-show-versions -u $name | grep -q upgradeable" ],
+ }
+ }
+ }
+}