mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	Fixes for WinRM/PowerShell support in v2.
- Add support for inserting module args into PowerShell modules. Fixes #11661. - Support Windows paths containing spaces. Applies changes from #10727 to v2. Fixes #9999. Should also fix ansible/ansible-modules-core#944 and ansible/ansible-modules-core#1007. - Change how execution policy is set for running remote scripts. Applies changes from #11092 to v2. Also fixes ansible/ansible-modules-core#1776. - Use codepage 65001 (UTF-8) for WinRM connection instead of default (CP437), convert command to UTF-8 and results from UTF-8. Replaces changes from #10024. Fixes #11198. - Close WinRM connection when task completes. - Use win_stat, win_file and win_copy modules instead of stat, file and copy when called from within other action plugins (only when using WinRM+PowerShell). - Unquote Windows path arguments before passing to win_stat, win_file, win_copy and slurp modules (only when using WinRM/PowerShell). - Check for win_ping module to determine if core modules are missing (only when using WinRM/PowerShell). - Add stdout_lines to result from running low level commands (so stdout_lines is available when using raw/script). - Update copy action plugin to use shell functions for joining paths and checking for trailing slash. - Update fetch action plugin to unquote source path when using Windows paths. - Add win_copy and win_template action plugins that inherit from copy and template. - Support running .bat and .cmd scripts using default system encoding instead of UTF-8. - Always send PowerShell commands as base64-encoded blobs to allow for running simple PowerShell commands via raw. - Support running modules on Windows with interpreters other than PowerShell. - Update integration tests to support above changes and test unicode fixes. - Add test for win_user error from ansible/ansible-modules-core#1241 (fixed by ansible/ansible-modules-core#1774). - Add test for additional win_stat output values (implemented by ansible/ansible-modules-core#1473). - Add test for OS architecture and name from setup.ps1 (implemented by ansible/ansible-modules-core#1100). All WinRM integration tests pass for me with these changes.
This commit is contained in:
		
					parent
					
						
							
								fa8043c0ba
							
						
					
				
			
			
				commit
				
					
						e87cf4a3cc
					
				
			
		
					 25 changed files with 356 additions and 118 deletions
				
			
		|  | @ -37,6 +37,7 @@ REPLACER         = "#<<INCLUDE_ANSIBLE_MODULE_COMMON>>" | |||
| REPLACER_ARGS    = "\"<<INCLUDE_ANSIBLE_MODULE_ARGS>>\"" | ||||
| REPLACER_COMPLEX = "\"<<INCLUDE_ANSIBLE_MODULE_COMPLEX_ARGS>>\"" | ||||
| REPLACER_WINDOWS = "# POWERSHELL_COMMON" | ||||
| REPLACER_WINARGS = "<<INCLUDE_ANSIBLE_MODULE_WINDOWS_ARGS>>" | ||||
| REPLACER_VERSION = "\"<<ANSIBLE_VERSION>>\"" | ||||
| 
 | ||||
| # We could end up writing out parameters with unicode characters so we need to | ||||
|  | @ -65,6 +66,8 @@ def _find_snippet_imports(module_data, module_path, strip_comments): | |||
|     module_style = 'old' | ||||
|     if REPLACER in module_data: | ||||
|         module_style = 'new' | ||||
|     elif REPLACER_WINDOWS in module_data: | ||||
|         module_style = 'new' | ||||
|     elif 'from ansible.module_utils.' in module_data: | ||||
|         module_style = 'new' | ||||
|     elif 'WANT_JSON' in module_data: | ||||
|  | @ -165,6 +168,7 @@ def modify_module(module_path, module_args, task_vars=dict(), strip_comments=Fal | |||
|         # these strings should be part of the 'basic' snippet which is required to be included | ||||
|         module_data = module_data.replace(REPLACER_VERSION, repr(__version__)) | ||||
|         module_data = module_data.replace(REPLACER_COMPLEX, encoded_args) | ||||
|         module_data = module_data.replace(REPLACER_WINARGS, module_args_json.encode('utf-8')) | ||||
| 
 | ||||
|         if module_style == 'new': | ||||
|             facility = C.DEFAULT_SYSLOG_FACILITY | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue