On Wednesday, August 20, 2014 6:04:56 AM UTC-5, Vincent Miszczak wrote: > > Hello, > > I have a define like this : > > define application::install($root,$url,$user="root") > { > include git > #Puppet wants a command to start with /something... > $cmd="/bin/echo 1&&{ cd $root||mkdir $root&&cd $root ; }&&git clone -b > prod $url ." > $unless="/bin/ls -alh $root |grep '.git'" > > > exec{"$cmd": > command=>$cmd, > unless=>$unless, > user=>$user, > require=>Package["git"] > } > } > > > being called with a class : > > class applications($apps) > { > create_resources(application::install,$apps) > } > > > and > $apps = { > test => { > url=> "https://mygitrepos/myapp.git", > root=> "/opt/apps/myapp", > user=>"root", > require=>Class[myclass], > } > } > > > class "myclass" is included by some other module > > I get : > > Error: Could not retrieve catalog from remote server: Error 400 on SERVER: > Invalid relationship: Application::Install[test] { require => > Class[myclass] }, because Class[myclass] doesn't seem to be in the catalog > > but the class *is* really included. > > For instance, if I do not require in $apps but require in the exec{}, it > will work just fine. Ofc I won't do this because I need things to be > dynamic. > > Expected behavior is it should work, unless I missed something. > > Any help welcome. > >
I'm a bit surprised to hear that doesn't work when the hash passed to create_resources() is initialized via a literal, as you show. If that's how you plan to do it, though, then you could instead establish the relationship separately by use of the chain operator: Class['myclass'] -> Application::Install['test'] That's not really what I'd call "dynamic", however, so I suspect what you're really trying to do is express that hash in hiera data. Indeed that *won't* work, at least not with the default back-end (YAML), because YAML has no mechanism for expressing Puppet resource references. The value "Class[myclass]" is just a string in YAML. You could work around such a problem by expressing required class names in your data rather than class references (and then applying the chain operator appropriately in your defined type). John -- 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 view this discussion on the web visit https://groups.google.com/d/msgid/puppet-users/0888eb96-13d1-41fb-8cd4-565de784c670%40googlegroups.com. For more options, visit https://groups.google.com/d/optout.