Hmm, that's the second time in two weeks someone mentions hiera as a solution for a problem that cannot easily be solved inside puppet, I guess it's time to go check it out :)
On Thu, Dec 22, 2011 at 15:56, jcbollinger <john.bollin...@stjude.org>wrote: > > > On Dec 21, 3:40 pm, Walter Heck <walterh...@gmail.com> wrote: > > Hello, > > > > a related question here on this list sparked me to write this question, > > which has been bugging me for a bit now: > > > > I use the following pattern inside my modules quite abit: > > > > class foo::params{ > > > > $bar = $::foo_bar ? { > > '' => 'somedefaultvalue', > > default => $::foo_bar > > } > > > > } > > > > Then I can refer to the variable from my module by $foo::params::bar, > which > > is quite nice. > > > > The problem is, I want to be able to set the value of $::foo_bar in a > thrid > > module in my services folder, but that is not possible because $::foo_bar > > needs to be top-scope. I don't want to make module foo dirty by adding > > $s_yadda::foo_bar but I don't see a better way, can anyone enlighten me > as > > to how they solve this problem? The only way I can think of is class > > parameters, but that is a lot less clean. > > > > I wish I could write to $::foo_bar from outside the top scope, even > though > > that is kind of dirty too :) . > > > You're exactly right: the behavior you want is dirty, too. Much > dirtier, in fact, than one module directly using class variables of > one of another module's classes. > > Parameterizing foo::params would not be much better, because it would > still leave that class dependent on another module's variables (in > that it needs them to be passed to it as parameters to achieve your > desired result). Parameterizing foo::params would also make it harder > to use, inasmuch as you would need to be much more careful about how > and where it is declared than you otherwise need to be. > > The bottom line is that it doesn't matter how you communicate the > values of one class's variables to another class; any way you do it > produces a dependency of the variable consumer on the variable > provider. > > To avoid such dependencies, you could consider having foo::params use > external data instead of Puppet variables of any scope. Puppet has > long provided the extlookup() function for this purpose, and there is > now hiera as well. You might even find that external data could > *replace* foo::params in some cases rather than merely supporting it. > > > John > > -- > 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. > > -- Walter Heck -- follow @walterheck on twitter to see what I'm up to! -- Check out my new startup: Server Monitoring as a Service @ http://tribily.com Follow @tribily on Twitter and/or 'Like' our Facebook page at http://www.facebook.com/tribily -- 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.