mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Added check_mode support to dynamodb_table module.
This commit is contained in:
parent
e93aec0b3a
commit
1bea9a25bb
1 changed files with 28 additions and 23 deletions
|
@ -39,7 +39,7 @@ options:
|
||||||
hash_key_name:
|
hash_key_name:
|
||||||
description:
|
description:
|
||||||
- Name of the hash key.
|
- Name of the hash key.
|
||||||
- Required when state=present.
|
- Required when C(state=present).
|
||||||
required: false
|
required: false
|
||||||
hash_key_type:
|
hash_key_type:
|
||||||
description:
|
description:
|
||||||
|
@ -109,10 +109,10 @@ try:
|
||||||
from boto.dynamodb2.fields import HashKey, RangeKey
|
from boto.dynamodb2.fields import HashKey, RangeKey
|
||||||
from boto.dynamodb2.types import STRING, NUMBER, BINARY
|
from boto.dynamodb2.types import STRING, NUMBER, BINARY
|
||||||
from boto.exception import BotoServerError, JSONResponseError
|
from boto.exception import BotoServerError, JSONResponseError
|
||||||
|
HAS_BOTO = True
|
||||||
|
|
||||||
except ImportError:
|
except ImportError:
|
||||||
print "failed=True msg='boto required for this module'"
|
HAS_BOTO = False
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
|
|
||||||
DYNAMO_TYPE_MAP = {
|
DYNAMO_TYPE_MAP = {
|
||||||
|
@ -132,8 +132,8 @@ def create_or_update_dynamo_table(connection, module):
|
||||||
write_capacity = module.params.get('write_capacity')
|
write_capacity = module.params.get('write_capacity')
|
||||||
|
|
||||||
schema = [
|
schema = [
|
||||||
HashKey(hash_key_name, map_dynamo_type(hash_key_type)),
|
HashKey(hash_key_name, DYNAMO_TYPE_MAP.get(hash_key_type)),
|
||||||
RangeKey(range_key_name, map_dynamo_type(range_key_type))
|
RangeKey(range_key_name, DYNAMO_TYPE_MAP.get(range_key_type))
|
||||||
]
|
]
|
||||||
throughput = {
|
throughput = {
|
||||||
'read': read_capacity,
|
'read': read_capacity,
|
||||||
|
@ -155,13 +155,14 @@ def create_or_update_dynamo_table(connection, module):
|
||||||
table = Table(table_name, connection=connection)
|
table = Table(table_name, connection=connection)
|
||||||
|
|
||||||
if dynamo_table_exists(table):
|
if dynamo_table_exists(table):
|
||||||
changed = update_dynamo_table(table, throughput=throughput)
|
result['changed'] = update_dynamo_table(table, throughput=throughput, check_mode=module.check_mode)
|
||||||
else:
|
else:
|
||||||
Table.create(table_name, connection=connection, schema=schema, throughput=throughput)
|
if not module.check_mode:
|
||||||
changed = True
|
Table.create(table_name, connection=connection, schema=schema, throughput=throughput)
|
||||||
|
result['changed'] = True
|
||||||
|
|
||||||
result['table_status'] = table.describe()['Table']['TableStatus']
|
if not module.check_mode:
|
||||||
result['changed'] = changed
|
result['table_status'] = table.describe()['Table']['TableStatus']
|
||||||
|
|
||||||
except BotoServerError:
|
except BotoServerError:
|
||||||
result['msg'] = 'Failed to create/update dynamo table due to error: ' + traceback.format_exc()
|
result['msg'] = 'Failed to create/update dynamo table due to error: ' + traceback.format_exc()
|
||||||
|
@ -171,7 +172,7 @@ def create_or_update_dynamo_table(connection, module):
|
||||||
|
|
||||||
|
|
||||||
def delete_dynamo_table(connection, module):
|
def delete_dynamo_table(connection, module):
|
||||||
table_name = module.params.get('table_name')
|
table_name = module.params.get('name')
|
||||||
|
|
||||||
result = dict(
|
result = dict(
|
||||||
region=module.params.get('region'),
|
region=module.params.get('region'),
|
||||||
|
@ -179,14 +180,15 @@ def delete_dynamo_table(connection, module):
|
||||||
)
|
)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
changed = False
|
|
||||||
table = Table(table_name, connection=connection)
|
table = Table(table_name, connection=connection)
|
||||||
|
|
||||||
if dynamo_table_exists(table):
|
if dynamo_table_exists(table):
|
||||||
table.delete()
|
if not module.check_mode:
|
||||||
changed = True
|
table.delete()
|
||||||
|
result['changed'] = True
|
||||||
|
|
||||||
result['changed'] = changed
|
else:
|
||||||
|
result['changed'] = False
|
||||||
|
|
||||||
except BotoServerError:
|
except BotoServerError:
|
||||||
result['msg'] = 'Failed to delete dynamo table due to error: ' + traceback.format_exc()
|
result['msg'] = 'Failed to delete dynamo table due to error: ' + traceback.format_exc()
|
||||||
|
@ -207,12 +209,14 @@ def dynamo_table_exists(table):
|
||||||
raise e
|
raise e
|
||||||
|
|
||||||
|
|
||||||
def update_dynamo_table(table, throughput=None):
|
def update_dynamo_table(table, throughput=None, check_mode=False):
|
||||||
table.describe() # populate table details
|
table.describe() # populate table details
|
||||||
|
|
||||||
# AWS complains if the throughput hasn't changed
|
|
||||||
if has_throughput_changed(table, throughput):
|
if has_throughput_changed(table, throughput):
|
||||||
return table.update(throughput=throughput)
|
if not check_mode:
|
||||||
|
return table.update(throughput=throughput)
|
||||||
|
else:
|
||||||
|
return True
|
||||||
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
@ -225,10 +229,6 @@ def has_throughput_changed(table, new_throughput):
|
||||||
new_throughput['write'] != table.throughput['write']
|
new_throughput['write'] != table.throughput['write']
|
||||||
|
|
||||||
|
|
||||||
def map_dynamo_type(dynamo_type):
|
|
||||||
return DYNAMO_TYPE_MAP.get(dynamo_type)
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
argument_spec = ec2_argument_spec()
|
argument_spec = ec2_argument_spec()
|
||||||
argument_spec.update(dict(
|
argument_spec.update(dict(
|
||||||
|
@ -242,7 +242,12 @@ def main():
|
||||||
write_capacity=dict(default=1, type='int'),
|
write_capacity=dict(default=1, type='int'),
|
||||||
))
|
))
|
||||||
|
|
||||||
module = AnsibleModule(argument_spec=argument_spec)
|
module = AnsibleModule(
|
||||||
|
argument_spec=argument_spec,
|
||||||
|
supports_check_mode=True)
|
||||||
|
|
||||||
|
if not HAS_BOTO:
|
||||||
|
module.fail_json(msg='boto required for this module')
|
||||||
|
|
||||||
region, ec2_url, aws_connect_params = get_aws_connection_info(module)
|
region, ec2_url, aws_connect_params = get_aws_connection_info(module)
|
||||||
connection = boto.dynamodb2.connect_to_region(region)
|
connection = boto.dynamodb2.connect_to_region(region)
|
||||||
|
|
Loading…
Reference in a new issue