Nevermind... under control - thanks for the fish Craig
On Jun 24, 2011, at 9:26 AM, Craig White wrote: > > On Jun 23, 2011, at 6:17 PM, Nigel Kersten wrote: > >> On Thu, Jun 23, 2011 at 4:07 PM, Craig White <craig.wh...@ttiltd.com> wrote: >>> class nginx::install { >>> $prerequisites = [ "build-essential", "libcurl4-openssl-dev", "libssl-dev", >>> "zlib1g-dev" ] >>> case $operatingsystem { >>> centos, redhat: { >>> } >>> debian, ubuntu: { >>> package { $prerequisites : ensure => "installed" : >>> ensure => present { >>> exec { "Installing nginx via passenger": >>> path => "/bin:/usr/bin", >>> environment => "HOME=/root", >>> command => "passenger-install-nginx-module --auto-download >>> --auto", >>> user => "root", >>> group => "root", >>> unless => "ls -l /opt | grep nginx", >>> logoutput => on_failure, >>> } >>> } >>> file {"/etc/init.d/nginx": >>> source => "puppet:///modules/nginx/nginx-initd", >>> owner => root, >>> group => root, >>> mode => 755, >>> require => Class["nginx::install"], >>> notify => Class["nginx::service"], >>> } >>> } >>> } >>> } >>> } >>> >>> The above has a syntax error on line 7 and the catalog won't build but >>> essentially I want to 'ensure' that the pre-requsite packages are installed >>> prior to attempting to execute the command (because if the pre-requisites >>> aren't there, the command will fail). >> >> That definitely won't compile :) >> >> You should be able to just declare the exec and package(s) resources >> separately and define a relationship, like: >> >> exec { "Installing nginx via passenger": >> path => "/bin:/usr/bin", >> environment => "HOME=/root", >> command => "passenger-install-nginx-module --auto-download --auto", >> user => "root", >> group => "root", >> unless => "ls -l /opt | grep nginx", >> logoutput => on_failure, >> require => Package[$prerequisites], >> } >> >> That last line should work for you. Otherwise you could define it the >> opposite way around: >> >> package { $prerequisites: >> ensure => installed, >> before => Exec["Installing nginx via passenger"], >> } >> >> Both those methods should work, but I have a vague memory of the first >> method failing in a point release or two. >> >> What version of Puppet are you running? You may have a much clearer >> way of expressing the conditional you're using than the somewhat messy >> case statement you're using at the moment. > ---- > puppet 2.6.8 > > Your first example would necessitate creating installation class for those > pre-requisite packages which I was hoping to just slide by without doing. In > fact, my way that I did it sort of worked with a little tweaking but it > seemed to try to install nginx before the pre-requisite packages so the first > tine through, it would time out on the command but load the pre-requisite > packages afterwards and then the second time through, it would install via > the command which was messy. > > this is where I am at at the moment... > > class nginx::install { > case $operatingsystem { > centos, redhat: { > } > debian, ubuntu: { > exec { "Installing nginx via passenger": > path => "/bin:/usr/bin", > environment => "HOME=/root", > command => "passenger-install-nginx-module --auto-download > --auto", > user => "root", > group => "root", > unless => "ls -l /opt | grep nginx", > logoutput => on_failure, > require => Class["gems::passenger", "nginx::prerequisites"] > } > } > } > } > > and still the 'require' doesn't seem to be executed prior to evaluating the > 'command' to exec - which still gives me issues. > > Craig > -- 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.