mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 13:34:01 -07:00 
			
		
		
		
	* Windows: Add special parameter types Adding explicit parameter types now exposes this information in the module documentation, and proves really helpful. We only do this for non-string types as strings, mostly because strings are implicit. PS We also make copyright statements consistent and use #Requires for explicit library imports * Type "string" must be type "str" * A few more Copyright corrections * More fixes * Don't add file encoding to Powershell files * Don't add missing interfacetypes parameter Otherwise CI demands an incorrect version_added * Small fix
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			PowerShell
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			PowerShell
		
	
	
	
	
	
| #!powershell
 | |
| 
 | |
| # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
 | |
| 
 | |
| #Requires -Module Ansible.ModuleUtils.Legacy
 | |
| 
 | |
| $results = @{changed=$false}
 | |
| 
 | |
| $parsed_args = Parse-Args $args
 | |
| $jid = Get-AnsibleParam $parsed_args "jid" -failifempty $true -resultobj $results
 | |
| $mode = Get-AnsibleParam $parsed_args "mode" -Default "status" -ValidateSet "status","cleanup"
 | |
| $_remote_tmp = Get-AnsibleParam $parsed_args "_ansible_remote_tmp" -type "path" -default $env:TMP
 | |
| 
 | |
| $log_path = [System.IO.Path]::Combine($_remote_tmp, ".ansible_async", $jid)
 | |
| 
 | |
| If(-not $(Test-Path $log_path))
 | |
| {
 | |
|     Fail-Json @{ansible_job_id=$jid; started=1; finished=1} "could not find job"
 | |
| }
 | |
| 
 | |
| If($mode -eq "cleanup") {
 | |
|     Remove-Item $log_path -Recurse
 | |
|     Exit-Json @{ansible_job_id=$jid; erased=$log_path}
 | |
| }
 | |
| 
 | |
| # NOT in cleanup mode, assume regular status mode
 | |
| # no remote kill mode currently exists, but probably should
 | |
| # consider log_path + ".pid" file and also unlink that above
 | |
| 
 | |
| $data = $null
 | |
| Try {
 | |
|     $data_raw = Get-Content $log_path
 | |
| 
 | |
|     # TODO: move this into module_utils/powershell.ps1?
 | |
|     $jss = New-Object System.Web.Script.Serialization.JavaScriptSerializer
 | |
|     $data = $jss.DeserializeObject($data_raw)
 | |
| }
 | |
| Catch {
 | |
|     If(-not $data_raw) {
 | |
|         # file not written yet?  That means it is running
 | |
|         Exit-Json @{results_file=$log_path; ansible_job_id=$jid; started=1; finished=0}
 | |
|     }
 | |
|     Else {
 | |
|         Fail-Json @{ansible_job_id=$jid; results_file=$log_path; started=1; finished=1} "Could not parse job output: $data"
 | |
|     }
 | |
| }
 | |
| 
 | |
| If (-not $data.ContainsKey("started")) {
 | |
|     $data['finished'] = 1
 | |
|     $data['ansible_job_id'] = $jid
 | |
| }
 | |
| ElseIf (-not $data.ContainsKey("finished")) {
 | |
|     $data['finished'] = 0
 | |
| }
 | |
| 
 | |
| Exit-Json $data
 |