mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 13:34:01 -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
		
			
				
	
	
		
			401 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			401 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/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
 | |
| #
 | |
| #  This file is part of Ansible
 | |
| #
 | |
| # Ansible is free software: you can redistribute it and/or modify
 | |
| # it under the terms of the GNU General Public License as published by
 | |
| # the Free Software Foundation, either version 3 of the License, or
 | |
| # (at your option) any later version.
 | |
| #
 | |
| # Ansible is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 | |
| # GNU General Public License for more details.
 | |
| #
 | |
| # You should have received a copy of the GNU General Public License
 | |
| # along with Ansible. If not, see http://www.gnu.org/licenses/.
 | |
| 
 | |
| from __future__ import annotations
 | |
| 
 | |
| 
 | |
| DOCUMENTATION = r"""
 | |
| module: ali_instance_info
 | |
| short_description: Gather information on instances of Alibaba Cloud ECS
 | |
| description:
 | |
|   - This module fetches data from the Open API in Alicloud. The module must be called from within the ECS instance itself.
 | |
| attributes:
 | |
|   check_mode:
 | |
|     version_added: 3.3.0
 | |
|         # This was backported to 2.5.4 and 1.3.11 as well, since this was a bugfix
 | |
| 
 | |
| options:
 | |
|   name_prefix:
 | |
|     description:
 | |
|       - Use a instance name prefix to filter ECS instances.
 | |
|     type: str
 | |
|     version_added: '0.2.0'
 | |
|   tags:
 | |
|     description:
 | |
|       - A hash/dictionaries of instance tags. C({"key":"value"}).
 | |
|     aliases: ["instance_tags"]
 | |
|     type: dict
 | |
|   filters:
 | |
|     description:
 | |
|       - A dict of filters to apply. Each dict item consists of a filter key and a filter value. The filter keys can be all
 | |
|         of request parameters. See U(https://www.alibabacloud.com/help/doc-detail/25506.htm) for parameter details. Filter
 | |
|         keys can be same as request parameter name or be lower case and use underscore (V("_")) or dash (V("-")) to connect
 | |
|         different words in one parameter. C(InstanceIds) should be a list. C(Tag.n.Key) and C(Tag.n.Value) should be a dict
 | |
|         and using O(tags) instead.
 | |
|     type: dict
 | |
|     version_added: '0.2.0'
 | |
| author:
 | |
|   - "He Guimin (@xiaozhu36)"
 | |
| requirements:
 | |
|   - "Python >= 3.6"
 | |
|   - "footmark >= 1.13.0"
 | |
| extends_documentation_fragment:
 | |
|   - community.general.alicloud
 | |
|   - community.general.attributes
 | |
|   - community.general.attributes.info_module
 | |
| """
 | |
| 
 | |
| EXAMPLES = r"""
 | |
| # Fetch instances details according to setting different filters
 | |
| 
 | |
| - name: Find all instances in the specified region
 | |
|   community.general.ali_instance_info:
 | |
|   register: all_instances
 | |
| 
 | |
| - name: Find all instances based on the specified ids
 | |
|   community.general.ali_instance_info:
 | |
|     instance_ids:
 | |
|       - "i-35b333d9"
 | |
|       - "i-ddav43kd"
 | |
|   register: instances_by_ids
 | |
| 
 | |
| - name: Find all instances based on the specified name_prefix
 | |
|   community.general.ali_instance_info:
 | |
|     name_prefix: "ecs_instance_"
 | |
|   register: instances_by_name_prefix
 | |
| 
 | |
| - name: Find instances based on tags
 | |
|   community.general.ali_instance_info:
 | |
|     tags:
 | |
|       Test: "add"
 | |
| """
 | |
| 
 | |
| RETURN = r"""
 | |
| instances:
 | |
|   description: List of ECS instances.
 | |
|   returned: always
 | |
|   type: complex
 | |
|   contains:
 | |
|     availability_zone:
 | |
|       description: The availability zone of the instance is in.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: cn-beijing-a
 | |
|     block_device_mappings:
 | |
|       description: Any block device mapping entries for the instance.
 | |
|       returned: always
 | |
|       type: complex
 | |
|       contains:
 | |
|         device_name:
 | |
|           description: The device name exposed to the instance (for example, /dev/xvda).
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: /dev/xvda
 | |
|         attach_time:
 | |
|           description: The time stamp when the attachment initiated.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: "2018-06-25T04:08:26Z"
 | |
|         delete_on_termination:
 | |
|           description: Indicates whether the volume is deleted on instance termination.
 | |
|           returned: always
 | |
|           type: bool
 | |
|           sample: true
 | |
|         status:
 | |
|           description: The attachment state.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: in_use
 | |
|         volume_id:
 | |
|           description: The ID of the cloud disk.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: d-2zei53pjsi117y6gf9t6
 | |
|     cpu:
 | |
|       description: The CPU core count of the instance.
 | |
|       returned: always
 | |
|       type: int
 | |
|       sample: 4
 | |
|     creation_time:
 | |
|       description: The time the instance was created.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: "2018-06-25T04:08Z"
 | |
|     description:
 | |
|       description: The instance description.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: "my ansible instance"
 | |
|     eip:
 | |
|       description: The attribution of EIP associated with the instance.
 | |
|       returned: always
 | |
|       type: complex
 | |
|       contains:
 | |
|         allocation_id:
 | |
|           description: The ID of the EIP.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: eip-12345
 | |
|         internet_charge_type:
 | |
|           description: The internet charge type of the EIP.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: "paybybandwidth"
 | |
|         ip_address:
 | |
|           description: EIP address.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: 42.10.2.2
 | |
|     expired_time:
 | |
|       description: The time the instance expires.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: "2099-12-31T15:59Z"
 | |
|     gpu:
 | |
|       description: The attribution of instance GPU.
 | |
|       returned: always
 | |
|       type: complex
 | |
|       contains:
 | |
|         amount:
 | |
|           description: The count of the GPU.
 | |
|           returned: always
 | |
|           type: int
 | |
|           sample: 0
 | |
|         spec:
 | |
|           description: The specification of the GPU.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: ""
 | |
|     host_name:
 | |
|       description: The host name of the instance.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: iZ2zewaoZ
 | |
|     id:
 | |
|       description: Alias of instance_id.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: i-abc12345
 | |
|     instance_id:
 | |
|       description: ECS instance resource ID.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: i-abc12345
 | |
|     image_id:
 | |
|       description: The ID of the image used to launch the instance.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: m-0011223344
 | |
|     inner_ip_address:
 | |
|       description: The inner IPv4 address of the classic instance.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: 10.0.0.2
 | |
|     instance_charge_type:
 | |
|       description: The instance charge type.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: PostPaid
 | |
|     instance_name:
 | |
|       description: The name of the instance.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: my-ecs
 | |
|     instance_type_family:
 | |
|       description: The instance type family of the instance belongs.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: ecs.sn1ne
 | |
|     instance_type:
 | |
|       description: The instance type of the running instance.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: ecs.sn1ne.xlarge
 | |
|     internet_charge_type:
 | |
|       description: The billing method of the network bandwidth.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: PayByBandwidth
 | |
|     internet_max_bandwidth_in:
 | |
|       description: Maximum incoming bandwidth from the internet network.
 | |
|       returned: always
 | |
|       type: int
 | |
|       sample: 200
 | |
|     internet_max_bandwidth_out:
 | |
|       description: Maximum incoming bandwidth from the internet network.
 | |
|       returned: always
 | |
|       type: int
 | |
|       sample: 20
 | |
|     io_optimized:
 | |
|       description: Indicates whether the instance is optimized for EBS I/O.
 | |
|       returned: always
 | |
|       type: bool
 | |
|       sample: false
 | |
|     memory:
 | |
|       description: Memory size of the instance.
 | |
|       returned: always
 | |
|       type: int
 | |
|       sample: 8192
 | |
|     network_interfaces:
 | |
|       description: One or more network interfaces for the instance.
 | |
|       returned: always
 | |
|       type: complex
 | |
|       contains:
 | |
|         mac_address:
 | |
|           description: The MAC address.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: "00:11:22:33:44:55"
 | |
|         network_interface_id:
 | |
|           description: The ID of the network interface.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: eni-01234567
 | |
|         primary_ip_address:
 | |
|           description: The primary IPv4 address of the network interface within the vswitch.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: 10.0.0.1
 | |
|     osname:
 | |
|       description: The operation system name of the instance owned.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: CentOS
 | |
|     ostype:
 | |
|       description: The operation system type of the instance owned.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: linux
 | |
|     private_ip_address:
 | |
|       description: The IPv4 address of the network interface within the subnet.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: 10.0.0.1
 | |
|     public_ip_address:
 | |
|       description: The public IPv4 address assigned to the instance or EIP address.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: 43.0.0.1
 | |
|     resource_group_id:
 | |
|       description: The ID of the resource group to which the instance belongs.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: my-ecs-group
 | |
|     security_groups:
 | |
|       description: One or more security groups for the instance.
 | |
|       returned: always
 | |
|       type: list
 | |
|       elements: dict
 | |
|       contains:
 | |
|         group_id:
 | |
|           description: The ID of the security group.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: sg-0123456
 | |
|         group_name:
 | |
|           description: The name of the security group.
 | |
|           returned: always
 | |
|           type: str
 | |
|           sample: my-security-group
 | |
|     status:
 | |
|       description: The current status of the instance.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: running
 | |
|     tags:
 | |
|       description: Any tags assigned to the instance.
 | |
|       returned: always
 | |
|       type: dict
 | |
|       sample:
 | |
|     vswitch_id:
 | |
|       description: The ID of the vswitch in which the instance is running.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: vsw-dew00abcdef
 | |
|     vpc_id:
 | |
|       description: The ID of the VPC the instance is in.
 | |
|       returned: always
 | |
|       type: str
 | |
|       sample: vpc-0011223344
 | |
| ids:
 | |
|   description: List of ECS instance IDs.
 | |
|   returned: always
 | |
|   type: list
 | |
|   sample: ["i-12345er", "i-3245fs"]
 | |
| """
 | |
| 
 | |
| from ansible.module_utils.basic import AnsibleModule, missing_required_lib
 | |
| from ansible_collections.community.general.plugins.module_utils.alicloud_ecs import (
 | |
|     ecs_argument_spec, ecs_connect, FOOTMARK_IMP_ERR, HAS_FOOTMARK
 | |
| )
 | |
| 
 | |
| 
 | |
| def main():
 | |
|     argument_spec = ecs_argument_spec()
 | |
|     argument_spec.update(dict(
 | |
|         name_prefix=dict(type='str'),
 | |
|         tags=dict(type='dict', aliases=['instance_tags']),
 | |
|         filters=dict(type='dict')
 | |
|     )
 | |
|     )
 | |
|     module = AnsibleModule(
 | |
|         argument_spec=argument_spec,
 | |
|         supports_check_mode=True,
 | |
|     )
 | |
| 
 | |
|     if HAS_FOOTMARK is False:
 | |
|         module.fail_json(msg=missing_required_lib('footmark'), exception=FOOTMARK_IMP_ERR)
 | |
| 
 | |
|     ecs = ecs_connect(module)
 | |
| 
 | |
|     instances = []
 | |
|     instance_ids = []
 | |
|     ids = []
 | |
|     name_prefix = module.params['name_prefix']
 | |
| 
 | |
|     filters = module.params['filters']
 | |
|     if not filters:
 | |
|         filters = {}
 | |
|     for key, value in list(filters.items()):
 | |
|         if key in ["InstanceIds", "instance_ids", "instance-ids"] and isinstance(ids, list):
 | |
|             for id in value:
 | |
|                 if id not in ids:
 | |
|                     ids.append(value)
 | |
|     if ids:
 | |
|         filters['instance_ids'] = ids
 | |
|     if module.params['tags']:
 | |
|         filters['tags'] = module.params['tags']
 | |
| 
 | |
|     for inst in ecs.describe_instances(**filters):
 | |
|         if name_prefix:
 | |
|             if not str(inst.instance_name).startswith(name_prefix):
 | |
|                 continue
 | |
|         volumes = ecs.describe_disks(instance_id=inst.id)
 | |
|         setattr(inst, 'block_device_mappings', volumes)
 | |
|         setattr(inst, 'user_data', inst.describe_user_data())
 | |
|         instances.append(inst.read())
 | |
|         instance_ids.append(inst.id)
 | |
| 
 | |
|     module.exit_json(changed=False, ids=instance_ids, instances=instances)
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     main()
 |