mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	
		
			
				
	
	
		
			142 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/python
 | |
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| # Copyright: (c) 2012, Michael DeHaan <michael.dehaan@gmail.com>, and others
 | |
| # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
 | |
| 
 | |
| from __future__ import absolute_import, division, print_function
 | |
| __metaclass__ = type
 | |
| 
 | |
| ANSIBLE_METADATA = {'metadata_version': '1.1',
 | |
|                     'status': ['stableinterface'],
 | |
|                     'supported_by': 'core'}
 | |
| 
 | |
| DOCUMENTATION = r'''
 | |
| ---
 | |
| module: async_status
 | |
| short_description: Obtain status of asynchronous task
 | |
| description:
 | |
| - This module gets the status of an asynchronous task.
 | |
| - This module is also supported for Windows targets.
 | |
| version_added: "0.5"
 | |
| options:
 | |
|   jid:
 | |
|     description:
 | |
|     - Job or task identifier
 | |
|     type: str
 | |
|     required: true
 | |
|   mode:
 | |
|     description:
 | |
|     - If C(status), obtain the status.
 | |
|     - If C(cleanup), clean up the async job cache (by default in C(~/.ansible_async/)) for the specified job I(jid).
 | |
|     type: str
 | |
|     choices: [ cleanup, status ]
 | |
|     default: status
 | |
| notes:
 | |
| - This module is also supported for Windows targets.
 | |
| seealso:
 | |
| - ref: playbooks_async
 | |
|   description: Detailed information on how to use asynchronous actions and polling.
 | |
| author:
 | |
| - Ansible Core Team
 | |
| - Michael DeHaan
 | |
| '''
 | |
| 
 | |
| EXAMPLES = r'''
 | |
| ---
 | |
| - name: Asynchronous yum task
 | |
|   yum:
 | |
|     name: docker-io
 | |
|     state: present
 | |
|   async: 1000
 | |
|   poll: 0
 | |
|   register: yum_sleeper
 | |
| 
 | |
| - name: Wait for asynchronous job to end
 | |
|   async_status:
 | |
|     jid: '{{ yum_sleeper.ansible_job_id }}'
 | |
|   register: job_result
 | |
|   until: job_result.finished
 | |
|   retries: 30
 | |
| '''
 | |
| 
 | |
| RETURN = r'''
 | |
| ansible_job_id:
 | |
|   description: The asynchronous job id
 | |
|   returned: success
 | |
|   type: str
 | |
|   sample: '360874038559.4169'
 | |
| finished:
 | |
|   description: Whether the asynchronous job has finished (C(1)) or not (C(0))
 | |
|   returned: success
 | |
|   type: int
 | |
|   sample: 1
 | |
| started:
 | |
|   description: Whether the asynchronous job has started (C(1)) or not (C(0))
 | |
|   returned: success
 | |
|   type: int
 | |
|   sample: 1
 | |
| '''
 | |
| 
 | |
| import json
 | |
| import os
 | |
| 
 | |
| from ansible.module_utils.basic import AnsibleModule
 | |
| from ansible.module_utils.six import iteritems
 | |
| from ansible.module_utils._text import to_native
 | |
| 
 | |
| 
 | |
| def main():
 | |
| 
 | |
|     module = AnsibleModule(argument_spec=dict(
 | |
|         jid=dict(type='str', required=True),
 | |
|         mode=dict(type='str', default='status', choices=['cleanup', 'status']),
 | |
|         # passed in from the async_status action plugin
 | |
|         _async_dir=dict(type='path', required=True),
 | |
|     ))
 | |
| 
 | |
|     mode = module.params['mode']
 | |
|     jid = module.params['jid']
 | |
|     async_dir = module.params['_async_dir']
 | |
| 
 | |
|     # setup logging directory
 | |
|     logdir = os.path.expanduser(async_dir)
 | |
|     log_path = os.path.join(logdir, jid)
 | |
| 
 | |
|     if not os.path.exists(log_path):
 | |
|         module.fail_json(msg="could not find job", ansible_job_id=jid, started=1, finished=1)
 | |
| 
 | |
|     if mode == 'cleanup':
 | |
|         os.unlink(log_path)
 | |
|         module.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 = None
 | |
|     try:
 | |
|         with open(log_path) as f:
 | |
|             data = json.loads(f.read())
 | |
|     except Exception:
 | |
|         if not data:
 | |
|             # file not written yet?  That means it is running
 | |
|             module.exit_json(results_file=log_path, ansible_job_id=jid, started=1, finished=0)
 | |
|         else:
 | |
|             module.fail_json(ansible_job_id=jid, results_file=log_path,
 | |
|                              msg="Could not parse job output: %s" % data, started=1, finished=1)
 | |
| 
 | |
|     if 'started' not in data:
 | |
|         data['finished'] = 1
 | |
|         data['ansible_job_id'] = jid
 | |
|     elif 'finished' not in data:
 | |
|         data['finished'] = 0
 | |
| 
 | |
|     # Fix error: TypeError: exit_json() keywords must be strings
 | |
|     data = dict([(to_native(k), v) for k, v in iteritems(data)])
 | |
| 
 | |
|     module.exit_json(**data)
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     main()
 |