Fix old-style (non-python) module support
This commit is contained in:
parent
e40e08d799
commit
30d481ac57
2 changed files with 18 additions and 9 deletions
|
@ -22,12 +22,13 @@ __metaclass__ = type
|
||||||
import base64
|
import base64
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
|
import pipes
|
||||||
import random
|
import random
|
||||||
import stat
|
import stat
|
||||||
import tempfile
|
import tempfile
|
||||||
import time
|
import time
|
||||||
|
|
||||||
from six import string_types
|
from six import string_types, iteritems
|
||||||
from six.moves import StringIO
|
from six.moves import StringIO
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
|
@ -362,17 +363,26 @@ class ActionBase:
|
||||||
|
|
||||||
# a remote tmp path may be necessary and not already created
|
# a remote tmp path may be necessary and not already created
|
||||||
remote_module_path = None
|
remote_module_path = None
|
||||||
|
args_file_path = None
|
||||||
if not tmp and self._late_needs_tmp_path(tmp, module_style):
|
if not tmp and self._late_needs_tmp_path(tmp, module_style):
|
||||||
tmp = self._make_tmp_path()
|
tmp = self._make_tmp_path()
|
||||||
|
|
||||||
if tmp:
|
if tmp:
|
||||||
remote_module_path = self._connection._shell.join_path(tmp, module_name)
|
remote_module_path = self._connection._shell.join_path(tmp, module_name)
|
||||||
|
if module_style == 'old':
|
||||||
|
# we'll also need a temp file to hold our module arguments
|
||||||
|
args_file_path = self._connection._shell.join_path(tmp, 'args')
|
||||||
|
|
||||||
# FIXME: async stuff here?
|
if remote_module_path or module_style != 'new':
|
||||||
#if (module_style != 'new' or async_jid is not None or not self._connection._has_pipelining or not self._play_context.pipelining or C.DEFAULT_KEEP_REMOTE_FILES):
|
|
||||||
if remote_module_path:
|
|
||||||
self._display.debug("transferring module to remote")
|
self._display.debug("transferring module to remote")
|
||||||
self._transfer_data(remote_module_path, module_data)
|
self._transfer_data(remote_module_path, module_data)
|
||||||
|
if module_style == 'old':
|
||||||
|
# we need to dump the module args to a k=v string in a file on
|
||||||
|
# the remote system, which can be read and parsed by the module
|
||||||
|
args_data = ""
|
||||||
|
for k,v in iteritems(module_args):
|
||||||
|
args_data += '%s="%s" ' % (k, pipes.quote(v))
|
||||||
|
self._transfer_data(args_file_path, args_data)
|
||||||
self._display.debug("done transferring module to remote")
|
self._display.debug("done transferring module to remote")
|
||||||
|
|
||||||
environment_string = self._compute_environment_string()
|
environment_string = self._compute_environment_string()
|
||||||
|
@ -384,9 +394,6 @@ class ActionBase:
|
||||||
cmd = ""
|
cmd = ""
|
||||||
in_data = None
|
in_data = None
|
||||||
|
|
||||||
# FIXME: all of the old-module style and async stuff has been removed from here, and
|
|
||||||
# might need to be re-added (unless we decide to drop support for old-style modules
|
|
||||||
# at this point and rework things to support non-python modules specifically)
|
|
||||||
if self._connection.has_pipelining and self._play_context.pipelining and not C.DEFAULT_KEEP_REMOTE_FILES:
|
if self._connection.has_pipelining and self._play_context.pipelining and not C.DEFAULT_KEEP_REMOTE_FILES:
|
||||||
in_data = module_data
|
in_data = module_data
|
||||||
else:
|
else:
|
||||||
|
@ -399,7 +406,7 @@ class ActionBase:
|
||||||
# not sudoing or sudoing to root, so can cleanup files in the same step
|
# not sudoing or sudoing to root, so can cleanup files in the same step
|
||||||
rm_tmp = tmp
|
rm_tmp = tmp
|
||||||
|
|
||||||
cmd = self._connection._shell.build_module_command(environment_string, shebang, cmd, rm_tmp)
|
cmd = self._connection._shell.build_module_command(environment_string, shebang, cmd, arg_path=args_file_path, rm_tmp=rm_tmp)
|
||||||
cmd = cmd.strip()
|
cmd = cmd.strip()
|
||||||
|
|
||||||
sudoable = True
|
sudoable = True
|
||||||
|
|
|
@ -134,12 +134,14 @@ class ShellModule(object):
|
||||||
cmd = "%s; %s || (echo \'0 \'%s)" % (test, cmd, shell_escaped_path)
|
cmd = "%s; %s || (echo \'0 \'%s)" % (test, cmd, shell_escaped_path)
|
||||||
return cmd
|
return cmd
|
||||||
|
|
||||||
def build_module_command(self, env_string, shebang, cmd, rm_tmp=None):
|
def build_module_command(self, env_string, shebang, cmd, arg_path=None, rm_tmp=None):
|
||||||
# don't quote the cmd if it's an empty string, because this will
|
# don't quote the cmd if it's an empty string, because this will
|
||||||
# break pipelining mode
|
# break pipelining mode
|
||||||
if cmd.strip() != '':
|
if cmd.strip() != '':
|
||||||
cmd = pipes.quote(cmd)
|
cmd = pipes.quote(cmd)
|
||||||
cmd_parts = [env_string.strip(), shebang.replace("#!", "").strip(), cmd]
|
cmd_parts = [env_string.strip(), shebang.replace("#!", "").strip(), cmd]
|
||||||
|
if arg_path is not None:
|
||||||
|
cmd_parts.append(arg_path)
|
||||||
new_cmd = " ".join(cmd_parts)
|
new_cmd = " ".join(cmd_parts)
|
||||||
if rm_tmp:
|
if rm_tmp:
|
||||||
new_cmd = '%s; rm -rf "%s" %s' % (new_cmd, rm_tmp, self._SHELL_REDIRECT_ALLNULL)
|
new_cmd = '%s; rm -rf "%s" %s' % (new_cmd, rm_tmp, self._SHELL_REDIRECT_ALLNULL)
|
||||||
|
|
Loading…
Reference in a new issue