On Wednesday, April 29, 2015 at 9:20:37 AM UTC-5, Jacob W. wrote:
>
> Hi all,
>
> I'm trying to run some scripts provided by Red Hat to test for select 
> security vulnerabilities. They're as-is from Red Hat, excluding a minor 
> modification so I get emailed when it finds a vulnerable system (noted in 
> bold/highlighted). I can run the command from the script and it works fine, 
> and I can run the script by hand and it works fine. However, when I try 
> calling it from Puppet it fails with:
>
> Notice: /Stage[main]/patches_security::test_ghost/Exec[/tmp/ghost-test.sh
> ]/returns: Error: Could not execute posix command: Exec format error - 
> /tmp/ghost-test.sh
> Error: /Stage[main]/patches_security::test_ghost/Exec[/tmp/ghost-test.sh]: 
> Failed to call refresh: /tmp/ghost-test.sh returned 1 instead of one of [0
> ]
> Error: /Stage[main]/patches_security::test_ghost/Exec[/tmp/ghost-test.sh]: 
> /tmp/ghost-test.sh returned 1 instead of one of [0]
>
>

Those messages say that you're getting the 'posix' provider for your Exec 
resource, and they suggest that your script is not recognized as having a 
valid format (per execve(2) and the related exec-family functions).  But 
your script *does* appear to have a valid format, inasmuch as it starts 
with a shebang line that ought to be valid, and execve() handles that.

Usually when a program succeeds when run directly but fails when run from 
Puppet, the problem is related to environment (variables) or security 
context.  The agent does provide a very sparse environment to commands it 
Execs (and in particular, it looks like you may want to check that 
`HOSTNAME` is among them).  If you need additional environment variables 
then you provide them via Exec's 'environment' parameter 
<https://docs.puppetlabs.com/references/3.4.stable/type.html#exec-attribute-environment>
.

The error message does not look like it indicates an environment issue, 
however.  Although you shouldn't need to do so, I'm going to suggest you 
try to invoke bash explicitly:

exec { '/bin/bash /tmp/ghost-test.sh':
# ...

OR

try using the 'shell' provider:

exec { '/tmp/ghost-test.sh':
  provider => 'shell',
  # ...


Please let us know whether one or both of those solves your problem.


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/c137a78d-bb4b-4975-b66d-994d4c637db1%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to