This is -exactly- what I've wanted in my modules since I heard of
Hiera and I am strongly supporting this proposal.  I'll be
experimenting with your gem.  I can't give this enough support as this
is what I wanted since Hiera began.  It'll make supporting multiple
distros/operating systems much easier for modules on the forge.

On Sun, Sep 30, 2012 at 5:37 AM, R.I.Pienaar <r...@devco.net> wrote:
> hello,
>
> Till now hiera-puppet was the only way I know that allowed hiera data to
> be loaded from inside a module.
>
> The problem with this was that it was still subject to the site specific
> hierarchy which means a module author had a pretty hard time to store
> his data in a proper way in his module thus perpetuating the use of the
> params classes pattern.
>
> Now that Puppet 3 is out and it's gem extensible I can finally try some
> ideas I had but put off implementing because it was too hard to install
> and distribute these extensions.
>
> I propose extending the module layout with a data/ directory that can go
> into each module and in this data directory would live a hiera config
> file (optionally) and module specific data:
>
>    your_module
>    ├── data
>    │   ├── hiera.json
>    │   └── osfamily
>    │       ├── Debian.json
>    │       └── RedHat.json
>    └── manifests
>        └── init.pp
>
> Here the data/hiera.json is optional and specifies a hierarchy that the
> module author chooses and is unique to the specific backend.
>
> The default contents would be this is the file is absent:
>
>    {"hierarchy": ["osfamily/%{osfamily}", "common"]}
>
> But a module author can pick anything there, should even be able to rely
> on facts that is shipped with the module in its lib dir since that'll
> get pluginsynced out before compile time:
>
> Now given the data files for Redhat:
>
>    {"apache::package" : "httpd"}
>
> ...and Debian:
>
>    {"apache::package" : "apache2"}
>
> And your main hiera site config being something like:
>
>    :backends: - json
>               - module_json
>
> You should be able to just write module code like this:
>
>    class apache($package="apache") {
>       package{$package: ensure => present}
>    }
>
> If no data is specified in the site hiera backends then this will use
> the in-module hierarchy and data and just do the right thing on RedHat
> and Debian systems but as always the site can still override the data
> using hard coding, site specific data, ENCs etc.
>
> So the important thing here is the module author has control over the
> hierarchy that gets used when the data in his module gets loaded. The
> site can has its own hierarchy policy but this backend will only use
> the hierarchy that is recorded in the module by its author.
>
> If you want to play with this idea on your Puppet 3 install just do 'gem
> install hiera-module-json'
>
> So I am looking for feedback from the community on this pattern, will it
> solve the problem of author-supplied module data better than we have
> today? I've heard this problem brought up quite a lot so keen to hear
> feedback.
>
> I'd imagine eventually a backend like this might be a hard-coded backend
> shipped with puppet and always there as the lowest priority backend
> below any that the site might specify in their site wide hiera config so
> everyone can rely on this being there and with the new lookup helpers
> this should also be backward compatible - old Puppets or ones who
> specifically disable the hiera indirector will just not have data and
> will need to supply it some other way.
>
> ---
> R.I.Pienaar
>
> --
> You received this message because you are subscribed to the Google Groups 
> "Puppet Users" group.
> To post to this group, send email to puppet-users@googlegroups.com.
> To unsubscribe from this group, send email to 
> puppet-users+unsubscr...@googlegroups.com.
> For more options, visit this group at 
> http://groups.google.com/group/puppet-users?hl=en.
>

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To post to this group, send email to puppet-users@googlegroups.com.
To unsubscribe from this group, send email to 
puppet-users+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/puppet-users?hl=en.

Reply via email to