init.pp 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. # apt.pp - common components and defaults for handling apt
  2. # Copyright (C) 2008 Micah Anerson <micah@riseup.net>
  3. # Copyright (C) 2007 David Schmitt <david@schmitt.edv-bus.at>
  4. # See LICENSE for the full license granted to you.
  5. class apt(
  6. $use_lts = $apt::params::use_lts,
  7. $use_volatile = $apt::params::use_volatile,
  8. $use_backports = $apt::params::use_backports,
  9. $include_src = $apt::params::include_src,
  10. $use_next_release = $apt::params::use_next_release,
  11. $debian_url = $apt::params::debian_url,
  12. $security_url = $apt::params::security_url,
  13. $backports_url = $apt::params::backports_url,
  14. $lts_url = $apt::params::lts_url,
  15. $volatile_url = $apt::params::volatile_url,
  16. $ubuntu_url = $apt::params::ubuntu_url,
  17. $repos = $apt::params::repos,
  18. $custom_preferences = $apt::params::custom_preferences,
  19. $custom_sources_list = '',
  20. $disable_update = $apt::params::disable_update,
  21. $custom_key_dir = $apt::params::custom_key_dir
  22. ) inherits apt::params {
  23. case $::operatingsystem {
  24. 'debian': {
  25. $real_repos = $repos ? {
  26. 'auto' => 'main contrib non-free',
  27. default => $repos,
  28. }
  29. }
  30. 'ubuntu': {
  31. $real_repos = $repos ? {
  32. 'auto' => 'main restricted universe multiverse',
  33. default => $repos,
  34. }
  35. }
  36. }
  37. package { 'apt':
  38. ensure => installed,
  39. require => undef,
  40. }
  41. $sources_content = $custom_sources_list ? {
  42. '' => template( "apt/${::operatingsystem}/sources.list.erb"),
  43. default => $custom_sources_list
  44. }
  45. file {
  46. # include main and security
  47. # additional sources should be included via the apt::sources_list define
  48. '/etc/apt/sources.list':
  49. content => $sources_content,
  50. notify => Exec['refresh_apt'],
  51. owner => root,
  52. group => 0,
  53. mode => '0644';
  54. }
  55. apt_conf { '02show_upgraded':
  56. source => [ "puppet:///modules/site_apt/${::fqdn}/02show_upgraded",
  57. 'puppet:///modules/site_apt/02show_upgraded',
  58. 'puppet:///modules/apt/02show_upgraded' ]
  59. }
  60. if ( $::virtual == 'vserver' ) {
  61. apt_conf { '03clean_vserver':
  62. source => [ "puppet:///modules/site_apt/${::fqdn}/03clean_vserver",
  63. 'puppet:///modules/site_apt/03clean_vserver',
  64. 'puppet:///modules/apt/03clean_vserver' ],
  65. alias => '03clean';
  66. }
  67. }
  68. else {
  69. apt_conf { '03clean':
  70. source => [ "puppet:///modules/site_apt/${::fqdn}/03clean",
  71. 'puppet:///modules/site_apt/03clean',
  72. 'puppet:///modules/apt/03clean' ]
  73. }
  74. }
  75. case $custom_preferences {
  76. false: {
  77. include apt::preferences::absent
  78. }
  79. default: {
  80. # When squeeze becomes the stable branch, transform this file's header
  81. # into a preferences.d file
  82. include apt::preferences
  83. }
  84. }
  85. include apt::dot_d_directories
  86. ## This package should really always be current
  87. package { 'debian-archive-keyring': ensure => latest }
  88. # backports uses the normal archive key now
  89. package { 'debian-backports-keyring': ensure => absent }
  90. if ($use_backports and !($::debian_release in ['testing', 'unstable', 'experimental'])) {
  91. apt::sources_list {
  92. 'backports':
  93. content => "deb $backports_url ${::debian_codename}-backports ${apt::real_repos}",
  94. }
  95. if $include_src {
  96. apt::sources_list {
  97. 'backports-src':
  98. content => "deb-src $backports_url ${::debian_codename}-backports ${apt::real_repos}",
  99. }
  100. }
  101. }
  102. include common::moduledir
  103. common::module_dir { 'apt': }
  104. $apt_base_dir = "${common::moduledir::module_dir_path}/apt"
  105. if $custom_key_dir {
  106. file { "${apt_base_dir}/keys.d":
  107. source => $custom_key_dir,
  108. recurse => true,
  109. owner => root,
  110. group => root,
  111. mode => '0755',
  112. }
  113. exec { 'custom_keys':
  114. command => "find ${apt_base_dir}/keys.d -type f -exec apt-key add '{}' \\;",
  115. subscribe => File["${apt_base_dir}/keys.d"],
  116. refreshonly => true,
  117. notify => Exec[refresh_apt]
  118. }
  119. if $custom_preferences != false {
  120. Exec['custom_keys'] {
  121. before => File['apt_config']
  122. }
  123. }
  124. }
  125. # workaround for preseeded_package component
  126. file { [ '/var/cache', '/var/cache/local', '/var/cache/local/preseeding' ]: ensure => directory }
  127. }