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 [email protected].
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.