Add rebuild support to os_server_actions (#4289)

Fixes #2714
This commit is contained in:
Ricardo Carrillo Cruz 2016-11-03 02:21:41 +01:00 committed by Matt Clay
parent c9960c00dc
commit 33d7745794

View file

@ -35,6 +35,7 @@ author: "Jesse Keating (@j2sol)"
description: description:
- Perform server actions on an existing compute instance from OpenStack. - Perform server actions on an existing compute instance from OpenStack.
This module does not return any data other than changed true/false. This module does not return any data other than changed true/false.
When I(action) is 'rebuild', then I(image) parameter is required.
options: options:
server: server:
description: description:
@ -55,8 +56,14 @@ options:
description: description:
- Perform the given action. The lock and unlock actions always return - Perform the given action. The lock and unlock actions always return
changed as the servers API does not provide lock status. changed as the servers API does not provide lock status.
choices: [stop, start, pause, unpause, lock, unlock, suspend, resume] choices: [stop, start, pause, unpause, lock, unlock, suspend, resume,
rebuild]
default: present default: present
image:
description:
- Image the server should be rebuilt with
default: null
version_added: "2.3"
requirements: requirements:
- "python >= 2.6" - "python >= 2.6"
- "shade" - "shade"
@ -82,7 +89,8 @@ _action_map = {'stop': 'SHUTOFF',
'lock': 'ACTIVE', # API doesn't show lock/unlock status 'lock': 'ACTIVE', # API doesn't show lock/unlock status
'unlock': 'ACTIVE', 'unlock': 'ACTIVE',
'suspend': 'SUSPENDED', 'suspend': 'SUSPENDED',
'resume': 'ACTIVE',} 'resume': 'ACTIVE',
'rebuild': 'ACTIVE'}
_admin_actions = ['pause', 'unpause', 'suspend', 'resume', 'lock', 'unlock'] _admin_actions = ['pause', 'unpause', 'suspend', 'resume', 'lock', 'unlock']
@ -113,11 +121,15 @@ def main():
argument_spec = openstack_full_argument_spec( argument_spec = openstack_full_argument_spec(
server=dict(required=True), server=dict(required=True),
action=dict(required=True, choices=['stop', 'start', 'pause', 'unpause', action=dict(required=True, choices=['stop', 'start', 'pause', 'unpause',
'lock', 'unlock', 'suspend', 'resume']), 'lock', 'unlock', 'suspend', 'resume',
'rebuild']),
image=dict(required=False),
) )
module_kwargs = openstack_module_kwargs() module_kwargs = openstack_module_kwargs()
module = AnsibleModule(argument_spec, supports_check_mode=True, **module_kwargs) module = AnsibleModule(argument_spec, supports_check_mode=True,
required_if=[('action', 'rebuild', ['image'])],
**module_kwargs)
if not HAS_SHADE: if not HAS_SHADE:
module.fail_json(msg='shade is required for this module') module.fail_json(msg='shade is required for this module')
@ -125,6 +137,7 @@ def main():
action = module.params['action'] action = module.params['action']
wait = module.params['wait'] wait = module.params['wait']
timeout = module.params['timeout'] timeout = module.params['timeout']
image = module.params['image']
try: try:
if action in _admin_actions: if action in _admin_actions:
@ -203,6 +216,18 @@ def main():
_wait(timeout, cloud, server, action) _wait(timeout, cloud, server, action)
module.exit_json(changed=True) module.exit_json(changed=True)
elif action == 'rebuild':
image = cloud.get_image(image)
if image is None:
module.fail_json(msg="Image does not exist")
# rebuild doesn't set a state, just do it
cloud.nova_client.servers.rebuild(server=server.id, image=image.id)
if wait:
_wait(timeout, cloud, server, action)
module.exit_json(changed=True)
except shade.OpenStackCloudException as e: except shade.OpenStackCloudException as e:
module.fail_json(msg=str(e), extra_data=e.extra_data) module.fail_json(msg=str(e), extra_data=e.extra_data)