(#14657) Fix filename when there is a period in the PPA
[puppet-modules/puppetlabs-apt.git] / manifests / ppa.pp
1 # ppa.pp
2
3 define apt::ppa(
4   $release = $::lsbdistcodename
5 ) {
6   include apt::params
7   include apt::update
8
9   $sources_list_d = $apt::params::sources_list_d
10
11   if ! $release {
12     fail('lsbdistcodename fact not available: release parameter required')
13   }
14
15   $filename_without_slashes = regsubst($name, '/', '-', G)
16   $filename_without_dots    = regsubst($filename_without_slashes, '\.', '_', G)
17   $filename_without_ppa     = regsubst($filename_without_dots, '^ppa:', '', G)
18   $sources_list_d_filename  = "${filename_without_ppa}-${release}.list"
19
20   if ! defined(Package['python-software-properties']) {
21     package { 'python-software-properties': }
22   }
23
24   exec { "add-apt-repository-${name}":
25     command => "/usr/bin/add-apt-repository ${name}",
26     creates => "${sources_list_d}/${sources_list_d_filename}",
27     require => [ File[$sources_list_d],
28                  Package['python-software-properties'] ],
29     notify  => Exec['apt_update'],
30   }
31
32   file { "${sources_list_d}/${sources_list_d_filename}":
33     ensure  => file,
34     require => Exec["add-apt-repository-${name}"],
35   }
36
37   # Need anchor to provide containment for dependencies.
38   anchor { "apt::ppa::${name}":
39     require => Class['apt::update'],
40   }
41 }
42