mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	* utilities: Clean up parameter types and add seealso * Add inventory modules * Add more references, clarify with-loops
		
			
				
	
	
		
			98 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/python
 | |
| # -*- coding: utf-8 -*-
 | |
| # Copyright: Ansible Project
 | |
| # 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'''
 | |
| ---
 | |
| author: Ansible Core Team (@ansible)
 | |
| module: import_role
 | |
| short_description: Import a role into a play
 | |
| description:
 | |
|   - Much like the C(roles:) keyword, this task loads a role, but it allows you to control it when the role tasks run in
 | |
|     between other tasks of the play.
 | |
|   - Most keywords, loops and conditionals will only be applied to the imported tasks, not to this statement itself. If
 | |
|     you want the opposite behavior, use M(include_role) instead.
 | |
| version_added: '2.4'
 | |
| options:
 | |
|   name:
 | |
|     description:
 | |
|       - The name of the role to be executed.
 | |
|     type: str
 | |
|     required: true
 | |
|   tasks_from:
 | |
|     description:
 | |
|       - File to load from a role's C(tasks/) directory.
 | |
|     type: str
 | |
|     default: main
 | |
|   vars_from:
 | |
|     description:
 | |
|       - File to load from a role's C(vars/) directory.
 | |
|     type: str
 | |
|     default: main
 | |
|   defaults_from:
 | |
|     description:
 | |
|       - File to load from a role's C(defaults/) directory.
 | |
|     type: str
 | |
|     default: main
 | |
|   allow_duplicates:
 | |
|     description:
 | |
|       - Overrides the role's metadata setting to allow using a role more than once with the same parameters.
 | |
|     type: bool
 | |
|     default: yes
 | |
|   handlers_from:
 | |
|     description:
 | |
|       - File to load from a role's C(handlers/) directory.
 | |
|     type: str
 | |
|     default: main
 | |
|     version_added: '2.8'
 | |
| notes:
 | |
|   - Handlers are made available to the whole play.
 | |
|   - Since Ansible 2.7 variables defined in C(vars) and C(defaults) for the role are exposed at playbook parsing time.
 | |
|     Due to this, these variables will be accessible to roles and tasks executed before the location of the
 | |
|     M(import_role) task.
 | |
|   - Unlike M(include_role) variable exposure is not configurable, and will always be exposed.
 | |
| seealso:
 | |
| - module: import_playbook
 | |
| - module: import_tasks
 | |
| - module: include_role
 | |
| - module: include_tasks
 | |
| - ref: playbooks_reuse_includes
 | |
|   description: More information related to including and importing playbooks, roles and tasks.
 | |
| '''
 | |
| 
 | |
| EXAMPLES = r'''
 | |
| - hosts: all
 | |
|   tasks:
 | |
|     - import_role:
 | |
|         name: myrole
 | |
| 
 | |
|     - name: Run tasks/other.yaml instead of 'main'
 | |
|       import_role:
 | |
|         name: myrole
 | |
|         tasks_from: other
 | |
| 
 | |
|     - name: Pass variables to role
 | |
|       import_role:
 | |
|         name: myrole
 | |
|       vars:
 | |
|         rolevar1: value from task
 | |
| 
 | |
|     - name: Apply condition to each task in role
 | |
|       import_role:
 | |
|         name: myrole
 | |
|       when: not idontwanttorun
 | |
| '''
 | |
| 
 | |
| RETURN = r'''
 | |
| # This module does not return anything except tasks to execute.
 | |
| '''
 |