Merge pull request #31 from pdxcat/fix_release_parameter_test
[puppet-modules/puppetlabs-apt.git] / manifests / ppa.pp
index 75f0a69574368316f4540567d00b92383645391b..712f425f49b5b50c3de6f74fb639b8088af41ef3 100644 (file)
@@ -1,13 +1,36 @@
 # ppa.pp
 
 define apt::ppa(
-       
+  $release = $lsbdistcodename
 ) {
-       include apt
-       
-       exec { "/usr/bin/add-apt-repository ${name}":
-               require => Package["python-software-properties"],
-               # TODO: unless => 'check'
-       }
+
+  Class['apt'] -> Apt::Ppa[$title]
+
+  include apt::params
+
+  if ! $release {
+    fail("lsbdistcodename fact not available: release parameter required")
+  }
+
+  exec { "apt-update-${name}":
+    command     => "/usr/bin/aptitude update",
+    refreshonly => true,
+  }
+
+  $filename_without_slashes = regsubst($name,'/','-','G')
+  $filename_without_ppa     = regsubst($filename_without_slashes, '^ppa:','','G')
+  $sources_list_d_filename   = "${filename_without_ppa}-${release}.list"
+
+  exec { "add-apt-repository-${name}":
+    command => "/usr/bin/add-apt-repository ${name}",
+    notify  => Exec["apt-update-${name}"],
+    creates => "${apt::params::sources_list_d}/${sources_list_d_filename}",
+  }
+
+  file { "${apt::params::sources_list_d}/${sources_list_d_filename}":
+    ensure  => file,
+    require => Exec["add-apt-repository-${name}"];
+  }
+
 }