Return resource objects from OpenStack modules

It's not uncommon for people to want to do additional things after
creating a module. Also, add a note about it to the dev notes.
This commit is contained in:
Monty Taylor 2015-06-17 05:24:08 -04:00 committed by Matt Clay
parent 89f95471f8
commit b955b2f5c8
7 changed files with 30 additions and 22 deletions

View file

@ -21,6 +21,13 @@ Naming
* If the module is one that a cloud admin and a cloud consumer could both use, * If the module is one that a cloud admin and a cloud consumer could both use,
the cloud consumer rules apply. the cloud consumer rules apply.
Interface
---------
* If the resource being managed has an id, it should be returned.
* If the resource being managed has an associated object more complex than
an id, it should also be returned.
Interoperability Interoperability
---------------- ----------------

View file

@ -148,7 +148,7 @@ def main():
if module.params['state'] == 'present': if module.params['state'] == 'present':
if not image: if not image:
result = cloud.create_image( image = cloud.create_image(
name=module.params['name'], name=module.params['name'],
filename=module.params['filename'], filename=module.params['filename'],
disk_format=module.params['disk_format'], disk_format=module.params['disk_format'],
@ -158,26 +158,26 @@ def main():
) )
changed = True changed = True
if not module.params['wait']: if not module.params['wait']:
module.exit_json(changed=changed, result=result) module.exit_json(changed=changed, image=image, id=image.id)
image = cloud.get_image(name_or_id=result['id'])
cloud.update_image_properties( cloud.update_image_properties(
image=image, image=image,
kernel=module.params['kernel'], kernel=module.params['kernel'],
ramdisk=module.params['ramdisk'], ramdisk=module.params['ramdisk'],
**module.params['properties']) **module.params['properties'])
image = cloud.get_image(name_or_id=image.id)
module.exit_json(changed=changed, image=image, id=image.id)
elif module.params['state'] == 'absent': elif module.params['state'] == 'absent':
if not image: if not image:
module.exit_json(changed=False, result="success") changed = False
else: else:
cloud.delete_image( cloud.delete_image(
name_or_id=module.params['name'], name_or_id=module.params['name'],
wait=module.params['wait'], wait=module.params['wait'],
timeout=module.params['timeout']) timeout=module.params['timeout'])
changed = True changed = True
module.exit_json(changed=changed)
module.exit_json(changed=changed, id=image.id, result="success")
except shade.OpenStackCloudException as e: except shade.OpenStackCloudException as e:
module.fail_json(msg=e.message, extra_data=e.extra_data) module.fail_json(msg=e.message, extra_data=e.extra_data)

View file

@ -88,16 +88,14 @@ def main():
if state == 'present': if state == 'present':
if not net: if not net:
net = cloud.create_network(name, shared, admin_state_up) net = cloud.create_network(name, shared, admin_state_up)
module.exit_json(changed=True, result="Created", id=net['id']) module.exit_json(changed=False, network=net, id=net['id'])
else:
module.exit_json(changed=False, result="Success", id=net['id'])
elif state == 'absent': elif state == 'absent':
if not net: if not net:
module.exit_json(changed=False, result="Success") module.exit_json(changed=False)
else: else:
cloud.delete_network(name) cloud.delete_network(name)
module.exit_json(changed=True, result="Deleted") module.exit_json(changed=True)
except shade.OpenStackCloudException as e: except shade.OpenStackCloudException as e:
module.fail_json(msg=e.message) module.fail_json(msg=e.message)

View file

@ -115,7 +115,7 @@ def main():
changed = process_object(cloud, **module.params) changed = process_object(cloud, **module.params)
module.exit_json(changed=changed, result="success") module.exit_json(changed=changed)
except shade.OpenStackCloudException as e: except shade.OpenStackCloudException as e:
module.fail_json(msg=e.message) module.fail_json(msg=e.message)

View file

@ -241,7 +241,8 @@ EXAMPLES = '''
def _exit_hostvars(module, cloud, server, changed=True): def _exit_hostvars(module, cloud, server, changed=True):
hostvars = meta.get_hostvars_from_server(cloud, server) hostvars = meta.get_hostvars_from_server(cloud, server)
module.exit_json(changed=changed, id=server.id, openstack=hostvars) module.exit_json(
changed=changed, server=server, id=server.id, openstack=hostvars)
def _network_args(module, cloud): def _network_args(module, cloud):

View file

@ -227,7 +227,7 @@ def main():
dns_nameservers=dns, dns_nameservers=dns,
allocation_pools=pool, allocation_pools=pool,
host_routes=host_routes) host_routes=host_routes)
module.exit_json(changed=True, result="created") changed = True
else: else:
if _needs_update(subnet, module): if _needs_update(subnet, module):
cloud.update_subnet(subnet['id'], cloud.update_subnet(subnet['id'],
@ -237,16 +237,18 @@ def main():
dns_nameservers=dns, dns_nameservers=dns,
allocation_pools=pool, allocation_pools=pool,
host_routes=host_routes) host_routes=host_routes)
module.exit_json(changed=True, result="updated") changed = True
else: else:
module.exit_json(changed=False, result="success") changed = False
module.exit_json(changed=changed)
elif state == 'absent': elif state == 'absent':
if not subnet: if not subnet:
module.exit_json(changed=False, result="success") changed = False
else: else:
changed = True
cloud.delete_subnet(subnet_name) cloud.delete_subnet(subnet_name)
module.exit_json(changed=True, result="deleted") module.exit_json(changed=changed)
except shade.OpenStackCloudException as e: except shade.OpenStackCloudException as e:
module.fail_json(msg=e.message) module.fail_json(msg=e.message)

View file

@ -89,7 +89,7 @@ EXAMPLES = '''
def _present_volume(module, cloud): def _present_volume(module, cloud):
if cloud.volume_exists(module.params['display_name']): if cloud.volume_exists(module.params['display_name']):
v = cloud.get_volume(module.params['display_name']) v = cloud.get_volume(module.params['display_name'])
module.exit_json(changed=False, id=v['id']) module.exit_json(changed=False, id=v['id'], volume=v)
volume_args = dict( volume_args = dict(
size=module.params['size'], size=module.params['size'],
@ -106,7 +106,7 @@ def _present_volume(module, cloud):
volume = cloud.create_volume( volume = cloud.create_volume(
wait=module.params['wait'], timeout=module.params['timeout'], wait=module.params['wait'], timeout=module.params['timeout'],
**volume_args) **volume_args)
module.exit_json(changed=True, id=volume['id']) module.exit_json(changed=True, id=volume['id'], volume=volume)
def _absent_volume(module, cloud): def _absent_volume(module, cloud):
@ -116,8 +116,8 @@ def _absent_volume(module, cloud):
wait=module.params['wait'], wait=module.params['wait'],
timeout=module.params['timeout']) timeout=module.params['timeout'])
except shade.OpenStackCloudTimeout: except shade.OpenStackCloudTimeout:
module.exit_json(changed=False, result="Volume deletion timed-out") module.exit_json(changed=False)
module.exit_json(changed=True, result='Volume Deleted') module.exit_json(changed=True)
def main(): def main():