-
Notifications
You must be signed in to change notification settings - Fork 397
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
[PR #687/3661b1ca backport][stable-3] New modules for RDS clusters management This is a backport of PR #687 as merged into main (3661b1c). SUMMARY Two new modules for RDS clusters management (rds_cluster ans rds_cluster_info) Took over from: #262 Depends-On: ansible-collections/amazon.aws#553 Closes #849 Should also close #191 ISSUE TYPE New Module Pull Request Reviewed-by: Markus Bergholz <[email protected]>
- Loading branch information
1 parent
3500c6b
commit fb69830
Showing
17 changed files
with
2,624 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,307 @@ | ||
#!/usr/bin/python | ||
# Copyright (c) 2022 Ansible Project | ||
# Copyright (c) 2022 Alina Buzachis (@alinabuzachis) | ||
# 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 | ||
|
||
|
||
DOCUMENTATION = r''' | ||
module: rds_cluster_info | ||
version_added: 3.2.0 | ||
short_description: Obtain information about one or more RDS clusters | ||
description: | ||
- Obtain information about one or more RDS clusters. | ||
options: | ||
db_cluster_identifier: | ||
description: | ||
- The user-supplied DB cluster identifier. | ||
- If this parameter is specified, information from only the specific DB cluster is returned. | ||
aliases: | ||
- cluster_id | ||
- id | ||
- cluster_name | ||
type: str | ||
filters: | ||
description: | ||
- A filter that specifies one or more DB clusters to describe. | ||
See U(https://docs.aws.amazon.com/AmazonRDS/latest/APIReference/API_DescribeDBClusters.html). | ||
type: dict | ||
author: | ||
- Alina Buzachis (@alinabuzachis) | ||
extends_documentation_fragment: | ||
- amazon.aws.aws | ||
- amazon.aws.ec2 | ||
''' | ||
|
||
EXAMPLES = r''' | ||
- name: Get info of all existing DB clusters | ||
community.aws.rds_cluster_info: | ||
register: _result_cluster_info | ||
- name: Get info on a specific DB cluster | ||
community.aws.rds_cluster_info: | ||
cluster_id: "{{ cluster_id }}" | ||
register: _result_cluster_info | ||
- name: Get info all DB clusters with specific engine | ||
community.aws.rds_cluster_info: | ||
engine: "aurora" | ||
register: _result_cluster_info | ||
''' | ||
|
||
RETURN = r''' | ||
clusters: | ||
description: List of RDS clusters. | ||
returned: always | ||
type: list | ||
contains: | ||
activity_stream_status: | ||
description: The status of the database activity stream. | ||
type: str | ||
sample: stopped | ||
allocated_storage: | ||
description: | ||
- The allocated storage size in gigabytes. Since aurora storage size is not fixed this is | ||
always 1 for aurora database engines. | ||
type: int | ||
sample: 1 | ||
associated_roles: | ||
description: | ||
- A list of dictionaries of the AWS Identity and Access Management (IAM) roles that are associated | ||
with the DB cluster. Each dictionary contains the role_arn and the status of the role. | ||
type: list | ||
sample: [] | ||
availability_zones: | ||
description: The list of availability zones that instances in the DB cluster can be created in. | ||
type: list | ||
sample: | ||
- us-east-1c | ||
- us-east-1a | ||
- us-east-1e | ||
backup_retention_period: | ||
description: The number of days for which automatic DB snapshots are retained. | ||
type: int | ||
sample: 1 | ||
cluster_create_time: | ||
description: The time in UTC when the DB cluster was created. | ||
type: str | ||
sample: '2018-06-29T14:08:58.491000+00:00' | ||
copy_tags_to_snapshot: | ||
description: | ||
- Specifies whether tags are copied from the DB cluster to snapshots of the DB cluster. | ||
type: bool | ||
sample: false | ||
cross_account_clone: | ||
description: | ||
- Specifies whether the DB cluster is a clone of a DB cluster owned by a different Amazon Web Services account. | ||
type: bool | ||
sample: false | ||
db_cluster_arn: | ||
description: The Amazon Resource Name (ARN) for the DB cluster. | ||
type: str | ||
sample: arn:aws:rds:us-east-1:123456789012:cluster:rds-cluster-demo | ||
db_cluster_identifier: | ||
description: The lowercase user-supplied DB cluster identifier. | ||
type: str | ||
sample: rds-cluster-demo | ||
db_cluster_members: | ||
description: | ||
- A list of dictionaries containing information about the instances in the cluster. | ||
Each dictionary contains the I(db_instance_identifier), I(is_cluster_writer) (bool), | ||
I(db_cluster_parameter_group_status), and I(promotion_tier) (int). | ||
type: list | ||
sample: [] | ||
db_cluster_parameter_group: | ||
description: The parameter group associated with the DB cluster. | ||
type: str | ||
sample: default.aurora5.6 | ||
db_cluster_resource_id: | ||
description: The AWS Region-unique, immutable identifier for the DB cluster. | ||
type: str | ||
sample: cluster-D2MEQDN3BQNXDF74K6DQJTHASU | ||
db_subnet_group: | ||
description: The name of the subnet group associated with the DB Cluster. | ||
type: str | ||
sample: default | ||
deletion_protection: | ||
description: | ||
- Indicates if the DB cluster has deletion protection enabled. | ||
The database can't be deleted when deletion protection is enabled. | ||
type: bool | ||
sample: false | ||
domain_memberships: | ||
description: | ||
- The Active Directory Domain membership records associated with the DB cluster. | ||
type: list | ||
sample: [] | ||
earliest_restorable_time: | ||
description: The earliest time to which a database can be restored with point-in-time restore. | ||
type: str | ||
sample: '2018-06-29T14:09:34.797000+00:00' | ||
endpoint: | ||
description: The connection endpoint for the primary instance of the DB cluster. | ||
type: str | ||
sample: rds-cluster-demo.cluster-cvlrtwiennww.us-east-1.rds.amazonaws.com | ||
engine: | ||
description: The database engine of the DB cluster. | ||
type: str | ||
sample: aurora | ||
engine_mode: | ||
description: The DB engine mode of the DB cluster. | ||
type: str | ||
sample: provisioned | ||
engine_version: | ||
description: The database engine version. | ||
type: str | ||
sample: 5.6.10a | ||
hosted_zone_id: | ||
description: The ID that Amazon Route 53 assigns when you create a hosted zone. | ||
type: str | ||
sample: Z2R2ITUGPM61AM | ||
http_endpoint_enabled: | ||
description: | ||
- A value that indicates whether the HTTP endpoint for an Aurora Serverless DB cluster is enabled. | ||
type: bool | ||
sample: false | ||
iam_database_authentication_enabled: | ||
description: Whether IAM accounts may be mapped to database accounts. | ||
type: bool | ||
sample: false | ||
latest_restorable_time: | ||
description: The latest time to which a database can be restored with point-in-time restore. | ||
type: str | ||
sample: '2018-06-29T14:09:34.797000+00:00' | ||
master_username: | ||
description: The master username for the DB cluster. | ||
type: str | ||
sample: username | ||
multi_az: | ||
description: Whether the DB cluster has instances in multiple availability zones. | ||
type: bool | ||
sample: false | ||
port: | ||
description: The port that the database engine is listening on. | ||
type: int | ||
sample: 3306 | ||
preferred_backup_window: | ||
description: The UTC weekly time range during which system maintenance can occur. | ||
type: str | ||
sample: 10:18-10:48 | ||
preferred_maintenance_window: | ||
description: The UTC weekly time range during which system maintenance can occur. | ||
type: str | ||
sample: tue:03:23-tue:03:53 | ||
read_replica_identifiers: | ||
description: A list of read replica ID strings associated with the DB cluster. | ||
type: list | ||
sample: [] | ||
reader_endpoint: | ||
description: The reader endpoint for the DB cluster. | ||
type: str | ||
sample: rds-cluster-demo.cluster-ro-cvlrtwiennww.us-east-1.rds.amazonaws.com | ||
status: | ||
description: The status of the DB cluster. | ||
type: str | ||
sample: available | ||
storage_encrypted: | ||
description: Whether the DB cluster is storage encrypted. | ||
type: bool | ||
sample: false | ||
tag_list: | ||
description: A list of tags consisting of key-value pairs. | ||
type: list | ||
elements: dict | ||
sample: [ | ||
{ | ||
"key": "Created_By", | ||
"value": "Ansible_rds_cluster_integration_test" | ||
} | ||
] | ||
tags: | ||
description: A dictionary of key value pairs. | ||
type: dict | ||
sample: { | ||
"Name": "rds-cluster-demo" | ||
} | ||
vpc_security_groups: | ||
description: A list of the DB cluster's security groups and their status. | ||
type: complex | ||
contains: | ||
status: | ||
description: Status of the security group. | ||
type: str | ||
sample: active | ||
vpc_security_group_id: | ||
description: Security group of the cluster. | ||
type: str | ||
sample: sg-12345678 | ||
''' | ||
|
||
|
||
try: | ||
import botocore | ||
except ImportError: | ||
pass # handled by AnsibleAWSModule | ||
|
||
from ansible_collections.amazon.aws.plugins.module_utils.core import AnsibleAWSModule | ||
from ansible_collections.amazon.aws.plugins.module_utils.core import is_boto3_error_code | ||
from ansible_collections.amazon.aws.plugins.module_utils.ec2 import ansible_dict_to_boto3_filter_list | ||
from ansible_collections.amazon.aws.plugins.module_utils.ec2 import AWSRetry | ||
from ansible_collections.amazon.aws.plugins.module_utils.ec2 import camel_dict_to_snake_dict | ||
from ansible_collections.amazon.aws.plugins.module_utils.rds import get_tags | ||
|
||
|
||
@AWSRetry.jittered_backoff(retries=10) | ||
def _describe_db_clusters(client, **params): | ||
try: | ||
paginator = client.get_paginator('describe_db_clusters') | ||
return paginator.paginate(**params).build_full_result()['DBClusters'] | ||
except is_boto3_error_code('DBClusterNotFoundFault'): | ||
return [] | ||
|
||
|
||
def cluster_info(client, module): | ||
cluster_id = module.params.get('db_cluster_identifier') | ||
filters = module.params.get('filters') | ||
|
||
params = dict() | ||
if cluster_id: | ||
params['DBClusterIdentifier'] = cluster_id | ||
if filters: | ||
params['Filters'] = ansible_dict_to_boto3_filter_list(filters) | ||
|
||
try: | ||
result = _describe_db_clusters(client, **params) | ||
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e: | ||
module.fail_json_aws(e, "Couldn't get RDS cluster information.") | ||
|
||
for cluster in result: | ||
cluster['Tags'] = get_tags(client, module, cluster['DBClusterArn']) | ||
|
||
return dict(changed=False, clusters=[camel_dict_to_snake_dict(cluster, ignore_list=['Tags']) for cluster in result]) | ||
|
||
|
||
def main(): | ||
argument_spec = dict( | ||
db_cluster_identifier=dict(aliases=['cluster_id', 'id', 'cluster_name']), | ||
filters=dict(type='dict'), | ||
) | ||
|
||
module = AnsibleAWSModule( | ||
argument_spec=argument_spec, | ||
supports_check_mode=True, | ||
) | ||
|
||
try: | ||
client = module.client('rds', retry_decorator=AWSRetry.jittered_backoff(retries=10)) | ||
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e: | ||
module.fail_json_aws(e, msg='Failed to connect to AWS.') | ||
|
||
module.exit_json(**cluster_info(client, module)) | ||
|
||
|
||
if __name__ == '__main__': | ||
main() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
cloud/aws | ||
|
||
rds_cluster_info |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
[tests] | ||
# basic rds_cluster cretion tests | ||
create | ||
|
||
# restore cluster tests | ||
restore | ||
|
||
# TODO: Cannot be tested in the CI because: | ||
# An error occurred (InvalidParameterValue) when calling the CreateDBCluster operation: Replication from cluster in same region is not supported | ||
# promote | ||
|
||
# security groups db tests | ||
create_sgs | ||
|
||
# basic modify operations applied on the rds cluster | ||
modify | ||
|
||
# tag rds cluster test | ||
tag | ||
|
||
[all:vars] | ||
ansible_connection=local | ||
ansible_python_interpreter="{{ ansible_playbook_python }}" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
--- | ||
# Beware: most of our tests here are run in parallel. | ||
# To add new tests you'll need to add a new host to the inventory and a matching | ||
# '{{ inventory_hostname }}'.yml file in roles/rds_cluster/tasks/ | ||
|
||
- hosts: all | ||
gather_facts: no | ||
strategy: free | ||
serial: 6 | ||
roles: | ||
- rds_cluster |
36 changes: 36 additions & 0 deletions
36
tests/integration/targets/rds_cluster/roles/rds_cluster/defaults/main.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
--- | ||
# defaults file for rds_cluster | ||
|
||
# Create cluster | ||
cluster_id: "ansible-test-{{ inventory_hostname | replace('_','-') }}{{ tiny_prefix }}" | ||
username: 'testrdsusername' | ||
password: 'test-rds_password' | ||
engine: 'aurora' | ||
port: 3306 | ||
tags_create: | ||
Name: 'ansible-test-cluster-{{ tiny_prefix }}' | ||
Created_By: "Ansible_rds_cluster_integration_test" | ||
|
||
# Modify cluster | ||
new_cluster_id: 'ansible-test-cluster-{{ tiny_prefix }}-new' | ||
new_port: 1155 | ||
new_password: 'test-rds_password-new' | ||
|
||
# Tag cluster | ||
tags_patch: | ||
Name: "{{ tiny_prefix }}-new" | ||
Created_by: Ansible rds_cluster integration tests | ||
|
||
# Create cluster in a VPC | ||
vpc_name: 'ansible-test-vpc-{{ tiny_prefix }}' | ||
vpc_cidr: '10.{{ 256 | random(seed=tiny_prefix) }}.0.0/16' | ||
subnets: | ||
- {'cidr': '10.{{ 256 | random(seed=tiny_prefix) }}.1.0/24', 'zone': '{{ aws_region }}a'} | ||
- {'cidr': '10.{{ 256 | random(seed=tiny_prefix) }}.2.0/24', 'zone': '{{ aws_region }}b'} | ||
- {'cidr': '10.{{ 256 | random(seed=tiny_prefix) }}.3.0/24', 'zone': '{{ aws_region }}c'} | ||
- {'cidr': '10.{{ 256 | random(seed=tiny_prefix) }}.4.0/24', 'zone': '{{ aws_region }}d'} | ||
|
||
security_groups: | ||
- '{{ tiny_prefix }}-sg-1' | ||
- '{{ tiny_prefix }}-sg-2' | ||
- '{{ tiny_prefix }}-sg-3' |
1 change: 1 addition & 0 deletions
1
tests/integration/targets/rds_cluster/roles/rds_cluster/meta/main.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
--- |
Oops, something went wrong.