mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Added support for instance types.
Added type and version parameters to be passed to rax_cdb module so users can create Percona and MariaDB instance types.
This commit is contained in:
parent
d38cd4896d
commit
bb6762dffd
1 changed files with 25 additions and 6 deletions
|
@ -38,6 +38,14 @@ options:
|
||||||
description:
|
description:
|
||||||
- Volume size of the database 1-150GB
|
- Volume size of the database 1-150GB
|
||||||
default: 2
|
default: 2
|
||||||
|
type:
|
||||||
|
description:
|
||||||
|
- type of instance (i.e. MySQL, MariaDB, Percona)
|
||||||
|
default: MySQL
|
||||||
|
version:
|
||||||
|
description:
|
||||||
|
- version of database (MySQL supports 5.1 and 5.6, MariaDB supports 10, Percona supports 5.6)
|
||||||
|
choices: ['5.1', '5.6', '10']
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- Indicate desired state of the resource
|
- Indicate desired state of the resource
|
||||||
|
@ -68,6 +76,8 @@ EXAMPLES = '''
|
||||||
name: db-server1
|
name: db-server1
|
||||||
flavor: 1
|
flavor: 1
|
||||||
volume: 2
|
volume: 2
|
||||||
|
type: MySQL
|
||||||
|
version: 5.6
|
||||||
wait: yes
|
wait: yes
|
||||||
state: present
|
state: present
|
||||||
register: rax_db_server
|
register: rax_db_server
|
||||||
|
@ -91,10 +101,12 @@ def find_instance(name):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
def save_instance(module, name, flavor, volume, wait, wait_timeout):
|
def save_instance(module, name, flavor, volume, type, version, wait,
|
||||||
|
wait_timeout):
|
||||||
|
|
||||||
for arg, value in dict(name=name, flavor=flavor,
|
for arg, value in dict(name=name, flavor=flavor,
|
||||||
volume=volume).iteritems():
|
volume=volume, type=type, version=version
|
||||||
|
).iteritems():
|
||||||
if not value:
|
if not value:
|
||||||
module.fail_json(msg='%s is required for the "rax_cdb"'
|
module.fail_json(msg='%s is required for the "rax_cdb"'
|
||||||
' module' % arg)
|
' module' % arg)
|
||||||
|
@ -118,7 +130,8 @@ def save_instance(module, name, flavor, volume, wait, wait_timeout):
|
||||||
if not instance:
|
if not instance:
|
||||||
action = 'create'
|
action = 'create'
|
||||||
try:
|
try:
|
||||||
instance = cdb.create(name=name, flavor=flavor, volume=volume)
|
instance = cdb.create(name=name, flavor=flavor, volume=volume,
|
||||||
|
type=type, version=version)
|
||||||
except Exception, e:
|
except Exception, e:
|
||||||
module.fail_json(msg='%s' % e.message)
|
module.fail_json(msg='%s' % e.message)
|
||||||
else:
|
else:
|
||||||
|
@ -189,11 +202,13 @@ def delete_instance(module, name, wait, wait_timeout):
|
||||||
cdb=rax_to_dict(instance))
|
cdb=rax_to_dict(instance))
|
||||||
|
|
||||||
|
|
||||||
def rax_cdb(module, state, name, flavor, volume, wait, wait_timeout):
|
def rax_cdb(module, state, name, flavor, volume, type, version, wait,
|
||||||
|
wait_timeout):
|
||||||
|
|
||||||
# act on the state
|
# act on the state
|
||||||
if state == 'present':
|
if state == 'present':
|
||||||
save_instance(module, name, flavor, volume, wait, wait_timeout)
|
save_instance(module, name, flavor, volume, type, version, wait,
|
||||||
|
wait_timeout)
|
||||||
elif state == 'absent':
|
elif state == 'absent':
|
||||||
delete_instance(module, name, wait, wait_timeout)
|
delete_instance(module, name, wait, wait_timeout)
|
||||||
|
|
||||||
|
@ -205,6 +220,8 @@ def main():
|
||||||
name=dict(type='str', required=True),
|
name=dict(type='str', required=True),
|
||||||
flavor=dict(type='int', default=1),
|
flavor=dict(type='int', default=1),
|
||||||
volume=dict(type='int', default=2),
|
volume=dict(type='int', default=2),
|
||||||
|
type=dict(type='str', default='MySQL'),
|
||||||
|
version=dict(type='str', default='5.6'),
|
||||||
state=dict(default='present', choices=['present', 'absent']),
|
state=dict(default='present', choices=['present', 'absent']),
|
||||||
wait=dict(type='bool', default=False),
|
wait=dict(type='bool', default=False),
|
||||||
wait_timeout=dict(type='int', default=300),
|
wait_timeout=dict(type='int', default=300),
|
||||||
|
@ -222,12 +239,14 @@ def main():
|
||||||
name = module.params.get('name')
|
name = module.params.get('name')
|
||||||
flavor = module.params.get('flavor')
|
flavor = module.params.get('flavor')
|
||||||
volume = module.params.get('volume')
|
volume = module.params.get('volume')
|
||||||
|
type = module.params.get('type')
|
||||||
|
version = module.params.get('version')
|
||||||
state = module.params.get('state')
|
state = module.params.get('state')
|
||||||
wait = module.params.get('wait')
|
wait = module.params.get('wait')
|
||||||
wait_timeout = module.params.get('wait_timeout')
|
wait_timeout = module.params.get('wait_timeout')
|
||||||
|
|
||||||
setup_rax_module(module, pyrax)
|
setup_rax_module(module, pyrax)
|
||||||
rax_cdb(module, state, name, flavor, volume, wait, wait_timeout)
|
rax_cdb(module, state, name, flavor, volume, type, version, wait, wait_timeout)
|
||||||
|
|
||||||
|
|
||||||
# import module snippets
|
# import module snippets
|
||||||
|
|
Loading…
Reference in a new issue