Skip to content

Commit

Permalink
New modules for RDS clusters management (ansible-collections#687)
Browse files Browse the repository at this point in the history
New modules for RDS clusters management

SUMMARY

Two new modules for RDS clusters management (rds_cluster ans rds_cluster_info)
Took over from: ansible-collections#262
Depends-On: ansible-collections#553
Closes ansible-collections#849
Should also close ansible-collections#191

ISSUE TYPE

New Module Pull Request

Reviewed-by: Mark Woolley <[email protected]>
Reviewed-by: Alina Buzachis <None>
Reviewed-by: Markus Bergholz <[email protected]>

This commit was initially merged in https://github.com/ansible-collections/community.aws
See: ansible-collections/community.aws@3661b1c
  • Loading branch information
alinabuzachis committed Sep 16, 2022
1 parent 4b5902b commit 71a3df6
Show file tree
Hide file tree
Showing 16 changed files with 2,622 additions and 0 deletions.
1,026 changes: 1,026 additions & 0 deletions plugins/modules/rds_cluster.py

Large diffs are not rendered by default.

307 changes: 307 additions & 0 deletions plugins/modules/rds_cluster_info.py
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()
3 changes: 3 additions & 0 deletions tests/integration/targets/rds_cluster/aliases
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
cloud/aws

rds_cluster_info
23 changes: 23 additions & 0 deletions tests/integration/targets/rds_cluster/inventory
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 }}"
11 changes: 11 additions & 0 deletions tests/integration/targets/rds_cluster/main.yml
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
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'
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
---
Loading

0 comments on commit 71a3df6

Please sign in to comment.