All-
We have several modules that have defines within them that the style guide (sections 11.1 & 11.4) and puppet-lint suggest should be in their own file. I'm working on fixing them and have a question about how things should be refactored. A stripped down example: The node: node 'foo.bar.edu' { include oracledb::instantclient } file modules/oracledb/manifests/instantclient.pp: class oracledb::instantclient($version='11.1') { include ldconfig # other non-relevant stuff here ldconfig::config { 'oracle-instantclient': content => template('oracledb/instantclient.ld.conf.erb'), } } file modules/ldconfig/manifests/init.pp: class ldconfig { exec { '/sbin/ldconfig': refreshonly => true, alias => 'ldconfig', } define config($content) { file { "/etc/ld.so.conf.d/${name}.conf": ensure => file, owner => 'root', group => 'root', mode => '0644', content => $content, notify => Exec['ldconfig'], } } } Note the define for config() within the init.pp for ldconfig. That's now out of favor. Moving that define into it's own file in modules/ldconfig/manifests/config.pp is straightforward, but it leaves me with questions about where the exec should be. - if I add a "requires => Class['ldconfig']" to the file within the config() define, I now have a circular dependency that puppet errors on. - if I don't include the "requires => Class['ldconfig']" but I'm careful to keep the "include ldconfig" in every class that also uses ldconfig::config, things "work", but that seems like the wrong way to do it, as it only works if I do both things, because of the implicit dependency on the exec. - I've tried moving the exec inside the define, like this: file modules/ldconfig/manifests/config.pp: define ldconfig::config($content) { exec { '/sbin/ldconfig': refreshonly => true, alias => 'ldconfig', } file { "/etc/ld.so.conf.d/${name}.conf": ensure => file, owner => 'root', group => 'root', mode => '0644', content => $content, notify => Exec['ldconfig'], } } but that results in duplicate definitions of the exec: err: Could not retrieve catalog from remote server: Error 400 on SERVER: Duplicate declaration: Exec[/sbin/ldconfig] is already declared in file /etc/puppet/modules/ldconfig/manifests/config.pp at line 6; cannot redeclare at /etc/puppet/modules/ldconfig/manifests/config.pp:6 on node foo.bar.edu - I've considered giving the exec an alias that is unique per define, e.g. something like exec { '/sbin/ldconfig': refreshonly => true, alias => "ldconfig-${name}", } and then doing a 'notify => Exec["ldconfig-${name}"]', but that too seems pretty hackish, though it may be my fall-back position if someone doesn't have a more elegant way to handle this. Any thoughts on how this should be re-organized? 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.