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

example42/puppet-profile

Repository files navigation

Deprecation notice

This module was designed for Puppet versions 2 and 3. It should work also on Puppet 4 but doesn't use any of its features.

The current Puppet 3 compatible codebase is no longer actively maintained by example42.

Still, Pull Requests that fix bugs or introduce backwards compatible features will be accepted.

Puppet module: profile

This is a Puppet module for to manage /etc/profile and /etc/profile.d It provides only package installation and file configuration.

Based on Example42 layouts by Alessandro Franceschi / Lab42

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

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

Released under the terms of Apache 2 License.

This module requires the presence of Example42 Puppi module in your modulepath.

USAGE - Basic management

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

      class { 'profile':
        audit_only => true
      }
    
  • Use custom sources for /etc/profile

      class { 'profile':
        source => [ "puppet:///modules/example42/profile/profile.conf-${hostname}" , "puppet:///modules/example42/profile/profile.conf" ], 
      }
    
  • Place a custom script (using source) in /etc/profile.d/ This creates the (executable) file: /etc/profile.d/java.sh

      profile::script { 'java':
        source => 'puppet:///modules/example42/profile/java.sh',
      }
    
  • Place a custom script (using content) in /etc/profile.d/

      profile::script { 'java':
        content => template('/example42/profile/java.sh'),
      }
    
  • Use custom source directory for the whole /etc/profile.d dir

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

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

      class { 'profile':
        my_class => 'example42::my_profile',
      }
    
  • Remove profile resources (DO NOT DO THAT)

      class { 'profile':
        absent => true
      }
    

Build Status

About

Puppet module to manage /etc/profile and /etc/profile.d

Resources

License

Stars

Watchers

Forks

Packages

No packages published