We have embraced Hiera; we use the YAML configuration system currently and 
on the whole everyone finds it easy to use and intuitive.

However, as our manifests have grown more complex, we have a need to 
"compile" multiple narrowly-focused classes together into different types 
of high-level roles. For example, we might have a "webmail" class that 
pulls together classes for configuring Apache, PHP, etc.  The low-level 
classes look to hiera for various configuration options -- e.g. Apache 
might look to Hiera for values on configuring server tokens or enabling the 
enhanced status or SSL information, PHP might want to check for 
security-related options configured, etc.

Ideally, we would like to expose simple values in the YAML file:

(e.g.)
---
webmail.use_https: true


Which gets translated into various "apache.*" configuration options.  We 
don't want to make operators learn all the small levers that need to be 
tweaked in the individual components in order to make the system function 
together.  

(I apologize if this particular example doesn't make much real-world sense; 
this is somewhat contrived.)

I don't think there's a way to set Hiera options, right?  (I haven't seen 
one; we're on Puppet 2.7.x, so maybe newer Puppet does this differently?) 
 We could maybe use parameterized classes, but we are currently heavily 
reliant on the "singleton" guarantee with multiple includes.

Am curious how/whether others address this problem of abstracting 
configuration and using composition pattern to bring together small classes 
into sophisticated functionality?

Thanks in advance!

Hans

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to puppet-users+unsubscr...@googlegroups.com.
To post to this group, send email to puppet-users@googlegroups.com.
Visit this group at http://groups.google.com/group/puppet-users.
For more options, visit https://groups.google.com/groups/opt_out.

Reply via email to