From 7e8cc65829854f72d1165f7e346c909d490386a8 Mon Sep 17 00:00:00 2001 From: Chris Church Date: Tue, 17 Jun 2014 23:26:36 -0500 Subject: [PATCH] Refactor common args used for building PowerShell commands. --- lib/ansible/runner/connection_plugins/winrm.py | 2 +- lib/ansible/runner/shell_plugins/powershell.py | 11 ++++++++--- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/lib/ansible/runner/connection_plugins/winrm.py b/lib/ansible/runner/connection_plugins/winrm.py index 5b6a0190857..7300b182b61 100644 --- a/lib/ansible/runner/connection_plugins/winrm.py +++ b/lib/ansible/runner/connection_plugins/winrm.py @@ -127,7 +127,7 @@ class Connection(object): vvvv("WINRM PARTS %r" % cmd_parts, host=self.host) # For script/raw support. if cmd_parts and cmd_parts[0].lower().endswith('.ps1'): - script = 'PowerShell -NoProfile -NonInteractive -ExecutionPolicy Unrestricted -File ' + ' '.join(['"%s"' % x for x in cmd_parts]) + script = powershell._build_file_cmd(cmd_parts) cmd_parts = powershell._encode_script(script, as_list=True) try: result = self._winrm_exec(cmd_parts[0], cmd_parts[1:]) diff --git a/lib/ansible/runner/shell_plugins/powershell.py b/lib/ansible/runner/shell_plugins/powershell.py index 75f1a20478a..1d6c74b5879 100644 --- a/lib/ansible/runner/shell_plugins/powershell.py +++ b/lib/ansible/runner/shell_plugins/powershell.py @@ -22,6 +22,8 @@ import random import shlex import time +_common_args = ['PowerShell', '-NoProfile', '-NonInteractive'] + def _escape(value, include_vars=False): '''Return value escaped for use in PowerShell command.''' # http://www.techotopia.com/index.php/Windows_PowerShell_1.0_String_Quoting_and_Escape_Sequences @@ -39,11 +41,15 @@ def _escape(value, include_vars=False): def _encode_script(script, as_list=False): '''Convert a PowerShell script to a single base64-encoded command.''' encoded_script = base64.b64encode(script.encode('utf-16-le')) - cmd_parts = ['PowerShell', '-NoProfile', '-NonInteractive', '-EncodedCommand', encoded_script] + cmd_parts = _common_args + ['-EncodedCommand', encoded_script] if as_list: return cmd_parts return ' '.join(cmd_parts) +def _build_file_cmd(cmd_parts): + '''Build command line to run a file, given list of file name plus args.''' + return ' '.join(_common_args + ['-ExecutionPolicy', 'Unrestricted', '-File'] + ['"%s"' % x for x in cmd_parts]) + class ShellModule(object): def env_prefix(self, **kwargs): @@ -75,8 +81,7 @@ class ShellModule(object): cmd_parts = shlex.split(cmd, posix=False) if not cmd_parts[0].lower().endswith('.ps1'): cmd_parts[0] = '%s.ps1' % cmd_parts[0] - cmd_parts = ['PowerShell', '-NoProfile', '-NonInteractive', '-ExecutionPolicy', 'Unrestricted', '-File'] + ['"%s"' % x for x in cmd_parts] - script = ' '.join(cmd_parts) + script = _build_file_cmd(cmd_parts) if rm_tmp: rm_tmp = _escape(rm_tmp) script = '%s; Remove-Item "%s" -Force -Recurse;' % (script, rm_tmp)