No description
Find a file
2013-12-04 20:40:05 -08:00
files remove dead files 2013-11-01 18:32:02 -07:00
lib/facter convert from 4 space to 2 space indent 2013-11-03 11:02:00 -07:00
manifests allow source param to concat::fragment to be a string or an Array 2013-11-12 23:20:48 -07:00
spec add system tests for replacing symlinks and directories 2013-11-18 14:58:46 -07:00
tests Cleaning up linting error with ensure param 2013-12-04 20:40:05 -08:00
.fixtures.yml validate define concat params + split warn param 2013-10-23 10:48:34 -07:00
.gitattributes Added .gitattributes to maintain line endings for .sh files 2013-10-19 22:30:44 +01:00
.gitignore Updated .gitignore for spec generated files 2013-10-02 13:53:00 +01:00
.nodeset.yml Add rspec-system tests. 2013-08-08 08:44:31 -07:00
.travis.yml update travis matrix 2013-11-12 05:19:08 -07:00
CHANGELOG Release 1.0.0. 2013-08-09 10:42:02 -07:00
Gemfile Ensure that ::setup runs before ::fragment in all cases. 2013-09-24 17:12:27 -04:00
LICENSE add files needed for the module forge 2012-04-30 10:45:08 +01:00
Modulefile validate define concat params + split warn param 2013-10-23 10:48:34 -07:00
Rakefile fix or suppress all lint warnings 2013-11-01 18:52:59 -07:00
README.md Improve formatting of code example 2013-12-02 21:32:32 -05:00

What is it?

Build Status

A Puppet module that can construct files from fragments.

Please see the comments in the various .pp files for details as well as posts on my blog at http://www.devco.net/

Released under the Apache 2.0 licence

Usage:

If you wanted a /etc/motd file that listed all the major modules on the machine. And that would be maintained automatically even if you just remove the include lines for other modules you could use code like below, a sample /etc/motd would be:

Puppet modules on this server:

    -- Apache
    -- MySQL

Local sysadmins can also append to the file by just editing /etc/motd.local their changes will be incorporated into the puppet managed motd.

# class to setup basic motd, include on all nodes
class motd {
  $motd = '/etc/motd'

  concat { $motd:
    owner => 'root',
    group => 'root',
    mode  => '0644'
  }

  concat::fragment{ 'motd_header':
    target  => $motd,
    content => "\nPuppet modules on this server:\n\n",
    order   => '01'
  }

  # local users on the machine can append to motd by just creating
  # /etc/motd.local
  concat::fragment{ 'motd_local':
    target => $motd,
    source => '/etc/motd.local',
    order  => '15'
  }
}

# used by other modules to register themselves in the motd
define motd::register($content="", $order=10) {
  if $content == "" {
    $body = $name
  } else {
    $body = $content
  }

  concat::fragment{ "motd_fragment_$name":
    target  => '/etc/motd',
    content => "    -- $body\n"
  }
}

# a sample apache module
class apache {
  include apache::install, apache::config, apache::service

  motd::register{ 'Apache': }
}

Detailed documentation of the class options can be found in the manifest files.

Known Issues:

  • Since puppet-concat now relies on a fact for the concat directory, you will need to set up pluginsync = true on both the master and client node's '/etc/puppet/puppet.conf' for at least the first run. You have this issue if puppet fails to run on the client and you have a message similar to "err: Failed to apply catalog: Parameter path failed: File paths must be fully qualified, not 'undef' at [...]/concat/manifests/setup.pp:44".

Contributors:

Paul Elliot

  • Provided 0.24.8 support, shell warnings and empty file creation support.

Chad Netzer

  • Various patches to improve safety of file operations
  • Symlink support

David Schmitt

  • Patch to remove hard coded paths relying on OS path
  • Patch to use file{} to copy the resulting file to the final destination. This means Puppet client will show diffs and that hopefully we can change file ownerships now

Peter Meier

  • Basedir as a fact
  • Unprivileged user support

Sharif Nassar

  • Solaris/Nexenta support
  • Better error reporting

Christian G. Warden

  • Style improvements

Reid Vandewiele

  • Support non GNU systems by default

Erik Dalén

  • Style improvements

Gildas Le Nadan

  • Documentation improvements

Paul Belanger

  • Testing improvements and Travis support

Branan Purvine-Riley

  • Support Puppet Module Tool better

Dustin J. Mitchell

  • Always include setup when using the concat define

Andreas Jaggi

  • Puppet Lint support

Jan Vansteenkiste

  • Configurable paths

Joshua Hoblitt

  • Remove requirement to manually include concat::setup in the manifest
  • Style improvements
  • Parameter validation / refactor parameter handling
  • Test coverage

Contact:

puppet-users@ mailing list.