Skip to content
This repository has been archived by the owner on Jun 11, 2019. It is now read-only.

example42/puppet-yum

Repository files navigation

Puppet module: yum

This is a Puppet module that manages Yum repositories for Centos RedHat and Scientific Linux

Made by Alessandro Franceschi / Lab42

Inspired by the Yum Immerda module: https://git.puppet.immerda.ch

Official site: http://www.example42.com

Official git repository: http://github.com/example42/puppet-yum

Released under the terms of Apache 2 License.

This module requires functions provided by the Example42 Puppi module.

USAGE

  • Just leave the default options: Automatic detection of Operating System (RedHat, Centos, Scientific supported) Epel repo installation, keeping of local yum files, automatic updates disabled.

      class { 'yum':
      }
    
  • Enable automatic updates via cron (updatesd is supported only on 5)

      class { 'yum':
        update => 'cron',
      }
    
  • Purge local /etc/yum.repos.d/ and enforce its contents only via a custom source

      class { 'yum':
        source_repo_dir => 'puppet:///modules/example42/yum/conf/',
        clean_repos     => true,
      }
    
  • Enable EPEL and PuppetLabs repos

      class { 'yum':
        extrarepo => [ 'epel' , 'puppetlabs' ],
      }
    
  • Do not include any extra repo (By default EPEL is added)

      class { 'yum':
        extrarepo => '' ,
      }
    
  • Automatically copy in /etc/pki/rpm-gpg all the rpm-gpg keys known by the yum module (this was the "old" and intrusive behaviour, now each rpm-gpg key may be individually provided by the yum::manages_repos' gpgkey_source parameter)

      class { 'yum':
        install_all_keys => true ,
      }
    
  • Include a selected extra repo

      include yum::repo::puppetlabs
    

USAGE - Overrides and Customizations

  • Enable auditing without without making changes on existing yum configuration files

      class { 'yum':
        audit_only => true
      }
    
  • Use custom sources for main config file

      class { 'yum':
        source => [ "puppet:///modules/lab42/yum/yum.conf-${hostname}" , "puppet:///modules/lab42/yum/yum.conf" ],
      }
    
  • Use custom source directory for the whole configuration dir

      class { 'yum':
        source_dir       => 'puppet:///modules/lab42/yum/conf/',
        source_dir_purge => false, # Set to true to purge any existing file not present in $source_dir
      }
    
  • Use custom template for main config file. Note that template and source arguments are alternative.

      class { 'yum':
        template => 'example42/yum/yum.conf.erb',
      }
    
  • Automatically include a custom subclass

      class { 'yum':
        my_class => 'yum::example42',
      }
    

USAGE - Example42 extensions management

  • Activate puppi (recommended, but disabled by default)

      class { 'yum':
        puppi    => true,
      }
    
  • Activate puppi and use a custom puppi_helper template (to be provided separately with a puppi::helper define ) to customize the output of puppi commands

      class { 'yum':
        puppi        => true,
        puppi_helper => 'myhelper',
      }
    

OPERATING SYSTEMS SUPPORT

REDHAT 7 - BETA

REDHAT 6 - Full

REDHAT 5 - Full

REDHAT 4 - Partial

CENTOS 6 - Full

CENTOS 5 - Full

CENTOS 4 - Partial

SCIENTIFIC 6 - Full

SCIENTIFIC 5 - Full

AMAZON LINUX 3 (Sigh) - Partial

Build Status