I've been using this, which works pretty well for a template selector: file { "foo": content => inline_template( file( "/literal/path/to/template/on/puppetmaster/$hostname.erb", "/literal/path/to/template/on/puppetmaster/$devicename.erb", "/literal/path/to/template/on/puppetmaster/$clientname.erb", "/literal/path/to/template/on/puppetmaster/motd.erb" )), ... }
On May 2, 2012, at 8:00 PM, Tim Mooney wrote: > > All- > > We're using puppet 2.7.11. > > Our custom firewall module currently builds the RHEL > /etc/sysconfig/iptables (and ip6tables) from multiple fragments using > concat::fragment. > > The base part of the firewall is constructed like this: > > class firewall { > include concat::setup > > $firewall_config = '/etc/sysconfig/iptables' > > concat::fragment { "firewall-base": > target => "$firewall_config", > source => [ > "puppet:///modules/firewall/firewall-base.$fqdn", > "puppet:///modules/firewall/firewall-base" > ], > order => '01', > } > > concat::fragment {"firewall-end": > target => "$firewall_config", > content => "COMMIT\n", > order => '99', > } > } > > > As you can see, we use source to look for a per-box custom firewall base > first, and then fall back to a stock firewall-base file fragment. > > I want to modify this config so that the fall-back fragment comes from > a template, rather than a file fragment. The problem is that it appears > I can't do this: > > concat::fragment { "firewall-base": > target => "$firewall_config", > source => [ > "puppet:///modules/firewall/firewall-base.$fqdn", > template('firewall/firewall-base.erb'), > ], > order => '01', > } > > When I try that, I get: > > $sudo puppet agent --test --noop > info: Retrieving plugin > info: Loading facts in /var/lib/puppet/lib/facter/ipmi_product.rb > info: Loading facts in /var/lib/puppet/lib/facter/biosversion.rb > info: Loading facts in /var/lib/puppet/lib/facter/net_info.rb > info: Loading facts in /var/lib/puppet/lib/facter/facter_dot_d.rb > info: Loading facts in /var/lib/puppet/lib/facter/net_location.rb > info: Loading facts in /var/lib/puppet/lib/facter/pacemaker.rb > info: Loading facts in /var/lib/puppet/lib/facter/root_home.rb > info: Caching catalog for host.nodak.edu > err: Failed to apply catalog: Parameter source failed: Could not understand > source # > > > and then it spits out the file template. > > Is there an easy way to mix, in one fragment, a source and a template, > as I'm trying to do? > > It occurs to me that I could just "pretend" that all of our per-host > firewall-base.$fqdn files are instead templates, even if there's no > actual templating going on, and use something like: > > concat::fragment { "firewall-base": > target => "$firewall_config", > content => [ > template("firewall/firewall-base.$fqdn.erb"), > template('firewall/firewall-base.erb'), > ], > order => '01', > } > > But that seems kind of hackish. Can anyone suggest a more elegant method, > or some syntax that I'm missing? > > Thanks, > > Tim > -- > Tim Mooney tim.moo...@ndsu.edu > Enterprise Computing & Infrastructure 701-231-1076 (Voice) > Room 242-J6, IACC Building 701-231-8541 (Fax) > North Dakota State University, Fargo, ND 58105-5164 > > -- > 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. > Wolf Noble Senior UNIX Systems administrator Datapipe Managed IT Services Tel: 201.792.1918 x2910 ________________________________ This message may contain confidential or privileged information. If you are not the intended recipient, please advise us immediately and delete this message. See http://www.datapipe.com/legal/email_disclaimer/ for further information on confidentiality and the risks of non-secure electronic communication. If you cannot access these links, please notify us by reply message and we will send the contents to you. -- 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.