mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	
		
			Some checks are pending
		
		
	
	EOL CI / EOL Sanity (Ⓐ2.17) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.10) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.12) (push) Waiting to run
				
			EOL CI / EOL Units (Ⓐ2.17+py3.7) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+alpine319+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+fedora39+py:azp/posix/3/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/1/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/2/) (push) Waiting to run
				
			EOL CI / EOL I (Ⓐ2.17+ubuntu2004+py:azp/posix/3/) (push) Waiting to run
				
			nox / Run extra sanity tests (push) Waiting to run
				
			* Adjust all __future__ imports: for i in $(grep -REl "__future__.*absolute_import" plugins/ tests/); do sed -e 's/from __future__ import .*/from __future__ import annotations/g' -i $i; done * Remove all UTF-8 encoding specifications for Python source files: for i in $(grep -REl '[-][*]- coding: utf-8 -[*]-' plugins/ tests/); do sed -e '/^# -\*- coding: utf-8 -\*-/d' -i $i; done * Remove __metaclass__ = type: for i in $(grep -REl '__metaclass__ = type' plugins/ tests/); do sed -e '/^__metaclass__ = type/d' -i $i; done
		
			
				
	
	
		
			97 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 
 | |
| # Copyright (c) 2017-present Alibaba Group Holding Limited. He Guimin <heguimin36@163.com>
 | |
| # GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
 | |
| # SPDX-License-Identifier: GPL-3.0-or-later
 | |
| 
 | |
| from __future__ import annotations
 | |
| 
 | |
| 
 | |
| class ModuleDocFragment(object):
 | |
| 
 | |
|     # Alicloud only documentation fragment
 | |
|     DOCUMENTATION = r"""
 | |
| options:
 | |
|   alicloud_access_key:
 | |
|     description:
 | |
|       - Alibaba Cloud access key. If not set then the value of environment variable E(ALICLOUD_ACCESS_KEY), E(ALICLOUD_ACCESS_KEY_ID)
 | |
|         is used instead.
 | |
|     aliases: ['access_key_id', 'access_key']
 | |
|     type: str
 | |
|   alicloud_secret_key:
 | |
|     description:
 | |
|       - Alibaba Cloud secret key. If not set then the value of environment variable E(ALICLOUD_SECRET_KEY), E(ALICLOUD_SECRET_ACCESS_KEY)
 | |
|         is used instead.
 | |
|     aliases: ['secret_access_key', 'secret_key']
 | |
|     type: str
 | |
|   alicloud_region:
 | |
|     description:
 | |
|       - The Alibaba Cloud region to use. If not specified then the value of environment variable E(ALICLOUD_REGION), E(ALICLOUD_REGION_ID)
 | |
|         is used instead.
 | |
|     aliases: ['region', 'region_id']
 | |
|     required: true
 | |
|     type: str
 | |
|   alicloud_security_token:
 | |
|     description:
 | |
|       - The Alibaba Cloud security token. If not specified then the value of environment variable E(ALICLOUD_SECURITY_TOKEN)
 | |
|         is used instead.
 | |
|     aliases: ['security_token']
 | |
|     type: str
 | |
|   alicloud_assume_role:
 | |
|     description:
 | |
|       - If provided with a role ARN, Ansible attempts to assume this role using the supplied credentials.
 | |
|       - The nested assume_role block supports C(alicloud_assume_role_arn), C(alicloud_assume_role_session_name), C(alicloud_assume_role_session_expiration)
 | |
|         and C(alicloud_assume_role_policy).
 | |
|     type: dict
 | |
|     aliases: ['assume_role']
 | |
|   alicloud_assume_role_arn:
 | |
|     description:
 | |
|       - The Alibaba Cloud C(role_arn). The ARN of the role to assume. If ARN is set to an empty string, it does not perform
 | |
|         role switching. It supports environment variable E(ALICLOUD_ASSUME_ROLE_ARN). Ansible executes with provided credentials.
 | |
|     aliases: ['assume_role_arn']
 | |
|     type: str
 | |
|   alicloud_assume_role_session_name:
 | |
|     description:
 | |
|       - The Alibaba Cloud session_name. The session name to use when assuming the role. If omitted, 'ansible' is passed to
 | |
|         the AssumeRole call as session name. It supports environment variable E(ALICLOUD_ASSUME_ROLE_SESSION_NAME).
 | |
|     aliases: ['assume_role_session_name']
 | |
|     type: str
 | |
|   alicloud_assume_role_session_expiration:
 | |
|     description:
 | |
|       - The Alibaba Cloud C(session_expiration). The time after which the established session for assuming role expires. Valid
 | |
|         value range 900-3600 seconds. Default to 3600 (in this case Alicloud use own default value). It supports environment
 | |
|         variable E(ALICLOUD_ASSUME_ROLE_SESSION_EXPIRATION).
 | |
|     aliases: ['assume_role_session_expiration']
 | |
|     type: int
 | |
|   ecs_role_name:
 | |
|     description:
 | |
|       - The RAM Role Name attached on a ECS instance for API operations. You can retrieve this from the 'Access Control' section
 | |
|         of the Alibaba Cloud console.
 | |
|       - If you are running Ansible from an ECS instance with RAM Instance using RAM Role, Ansible just accesses the metadata
 | |
|         U(http://100.100.100.200/latest/meta-data/ram/security-credentials/<ecs_role_name>) to obtain the STS credential.
 | |
|         This is a preferred approach over any other when running in ECS as you can avoid hard coding credentials. Instead
 | |
|         these are leased on-the-fly by Ansible which reduces the chance of leakage.
 | |
|     aliases: ['role_name']
 | |
|     type: str
 | |
|   profile:
 | |
|     description:
 | |
|       - This is the Alicloud profile name as set in the shared credentials file. It can also be sourced from the E(ALICLOUD_PROFILE)
 | |
|         environment variable.
 | |
|     type: str
 | |
|   shared_credentials_file:
 | |
|     description:
 | |
|       - This is the path to the shared credentials file. It can also be sourced from the E(ALICLOUD_SHARED_CREDENTIALS_FILE)
 | |
|         environment variable.
 | |
|       - If this is not set and a profile is specified, C(~/.aliyun/config.json) is used.
 | |
|     type: str
 | |
| author:
 | |
|   - "He Guimin (@xiaozhu36)"
 | |
| requirements:
 | |
|   - "Python >= 3.6"
 | |
| notes:
 | |
|   - If parameters are not set within the module, the following environment variables can be used in decreasing order of precedence
 | |
|     E(ALICLOUD_ACCESS_KEY) or E(ALICLOUD_ACCESS_KEY_ID), E(ALICLOUD_SECRET_KEY) or E(ALICLOUD_SECRET_ACCESS_KEY), E(ALICLOUD_REGION)
 | |
|     or E(ALICLOUD_REGION_ID), E(ALICLOUD_SECURITY_TOKEN), E(ALICLOUD_ECS_ROLE_NAME), E(ALICLOUD_SHARED_CREDENTIALS_FILE),
 | |
|     E(ALICLOUD_PROFILE), E(ALICLOUD_ASSUME_ROLE_ARN), E(ALICLOUD_ASSUME_ROLE_SESSION_NAME), E(ALICLOUD_ASSUME_ROLE_SESSION_EXPIRATION).
 | |
|   - E(ALICLOUD_REGION) or E(ALICLOUD_REGION_ID) can be typically be used to specify the Alicloud region, when required, but
 | |
|     this can also be configured in the footmark config file.
 | |
| """
 |