From 88c5d84d7226daee2c4b27c5c1037303b5c372d1 Mon Sep 17 00:00:00 2001 From: pascalheraud Date: Tue, 8 Dec 2015 00:20:18 +0100 Subject: [PATCH] Fixed the module to be compliant with pep8 --- .../cloud/ovh/ovh_ip_loadbalancing_backend.py | 244 +++++++++++------- 1 file changed, 154 insertions(+), 90 deletions(-) diff --git a/lib/ansible/modules/extras/cloud/ovh/ovh_ip_loadbalancing_backend.py b/lib/ansible/modules/extras/cloud/ovh/ovh_ip_loadbalancing_backend.py index f2dcc1d76a..e3b80617b7 100644 --- a/lib/ansible/modules/extras/cloud/ovh/ovh_ip_loadbalancing_backend.py +++ b/lib/ansible/modules/extras/cloud/ovh/ovh_ip_loadbalancing_backend.py @@ -1,5 +1,16 @@ #!/usr/bin/env python # -*- coding: utf-8 -*- +import sys +try: + import ovh + import ovh.exceptions + HAS_OVH = True +except ImportError: + HAS_OVH = False + +# import module snippets +from ansible.module_utils.basic import * +# and APIError from ovh api from ovh.exceptions import APIError DOCUMENTATION = ''' @@ -11,8 +22,10 @@ description: version_added: "2.0" author: Pascal HERAUD @pascalheraud notes: - - Uses the python OVH Api U(https://github.com/ovh/python-ovh). You have to create an application (a key and secret) with a consummer key as described into U(https://eu.api.ovh.com/g934.first_step_with_api) -requirements: + - Uses the python OVH Api U(https://github.com/ovh/python-ovh). \ + You have to create an application (a key and secret) with a consummer \ + key as described into U(https://eu.api.ovh.com/g934.first_step_with_api) +requirements: - ovh > 0.3.5 options: name: @@ -28,7 +41,8 @@ options: default: present choices: ['present', 'absent'] description: - - Determines wether the backend is to be created/modified or deleted + - Determines wether the backend is to be created/modified \ + or deleted probe: required: false default: none @@ -59,33 +73,32 @@ options: timeout: required: false type: "int" - default: "120 - descriptin: - - The timeout in seconds used to wait for a task to be completed. Default is 120 seconds. - + default: 120 + description: + - The timeout in seconds used to wait for a task to be \ + completed. Default is 120 seconds. + ''' EXAMPLES = ''' # Adds or modify a backend to a loadbalancing -- ovh_ip_loadbalancing name=ip-1.1.1.1 ip=212.1.1.1 state=present probe=none weight=8 endpoint=ovh-eu application_key=yourkey application_secret=yoursecret consumer_key=yourconsumerkey +- ovh_ip_loadbalancing name=ip-1.1.1.1 ip=212.1.1.1 state=present \ +probe=none weight=8 \ +endpoint=ovh-eu application_key=yourkey \ +application_secret=yoursecret consumer_key=yourconsumerkey # Removes a backend from a loadbalancing -- ovh_ip_loadbalancing name=ip-1.1.1.1 ip=212.1.1.1 state=absent endpoint=ovh-eu application_key=yourkey application_secret=yoursecret consumer_key=yourconsumerkey +- ovh_ip_loadbalancing name=ip-1.1.1.1 ip=212.1.1.1 state=absent \ +endpoint=ovh-eu application_key=yourkey \ +application_secret=yoursecret consumer_key=yourconsumerkey ''' -import sys -try: - import ovh - import ovh.exceptions - HAS_OVH = True -except ImportError: - HAS_OVH = False def getOvhClient(ansibleModule): - endpoint = ansibleModule.params.get('endpoint') - application_key = ansibleModule.params.get('application_key') - application_secret = ansibleModule.params.get('application_secret') - consumer_key = ansibleModule.params.get('consumer_key') + endpoint = ansibleModule.params.get('endpoint') + application_key = ansibleModule.params.get('application_key') + application_secret = ansibleModule.params.get('application_secret') + consumer_key = ansibleModule.params.get('consumer_key') return ovh.Client( endpoint=endpoint, @@ -94,128 +107,179 @@ def getOvhClient(ansibleModule): consumer_key=consumer_key ) + def waitForNoTask(client, name, timeout): - currentTimeout = timeout; - while len(client.get('/ip/loadBalancing/{}/task'.format(name)))>0: + currentTimeout = timeout + while len(client.get('/ip/loadBalancing/{}/task'.format(name))) > 0: time.sleep(1) # Delay for 1 sec - currentTimeout-=1 + currentTimeout -= 1 if currentTimeout < 0: return False return True - + + def main(): module = AnsibleModule( - argument_spec = dict( - name = dict(required=True), - backend = dict(required=True), - weight = dict(default='8', type='int'), - probe = dict(default='none', choices =['none', 'http', 'icmp' , 'oco']), - state = dict(default='present', choices=['present', 'absent']), - endpoint = dict(required=True), - application_key = dict(required=True), - application_secret = dict(required=True), - consumer_key = dict(required=True), - timeout = dict(default=120, type='int') + argument_spec=dict( + name=dict(required=True), + backend=dict(required=True), + weight=dict(default='8', type='int'), + probe=dict(default='none', + choices=['none', 'http', 'icmp', 'oco']), + state=dict(default='present', choices=['present', 'absent']), + endpoint=dict(required=True), + application_key=dict(required=True), + application_secret=dict(required=True), + consumer_key=dict(required=True), + timeout=dict(default=120, type='int') ) ) - + if not HAS_OVH: - module.fail_json(msg='ovh-api python module is required to run this module ') + module.fail_json(msg='ovh-api python module\ + is required to run this module ') # Get parameters - name = module.params.get('name') - state = module.params.get('state') - backend = module.params.get('backend') - weight = long(module.params.get('weight')) - probe = module.params.get('probe') + name = module.params.get('name') + state = module.params.get('state') + backend = module.params.get('backend') + weight = long(module.params.get('weight')) + probe = module.params.get('probe') timeout = module.params.get('timeout') # Connect to OVH API client = getOvhClient(module) # Check that the load balancing exists - try : + try: loadBalancings = client.get('/ip/loadBalancing') except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for getting the list of loadBalancing, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) - - if not name in loadBalancings: + module.fail_json( + msg='Unable to call OVH api for getting the list of loadBalancing, \ + check application key, secret, consumerkey and parameters. \ + Error returned by OVH api was : {}'.format(apiError)) + + if name not in loadBalancings: module.fail_json(msg='IP LoadBalancing {} does not exist'.format(name)) # Check that no task is pending before going on - try : - if not waitForNoTask(client, name, timeout): - module.fail_json(msg='Timeout of {} seconds while waiting for no pending tasks before executing the module '.format(timeout)) + try: + if not waitForNoTask(client, name, timeout): + module.fail_json( + msg='Timeout of {} seconds while waiting for no pending \ + tasks before executing the module '.format(timeout)) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for getting the list of pending tasks of the loadBalancing, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) + module.fail_json( + msg='Unable to call OVH api for getting the list of pending tasks \ + of the loadBalancing, check application key, secret, consumerkey \ + and parameters. Error returned by OVH api was : {}\ + '.format(apiError)) - try : + try: backends = client.get('/ip/loadBalancing/{}/backend'.format(name)) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for getting the list of backends of the loadBalancing, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) - + module.fail_json( + msg='Unable to call OVH api for getting the list of backends \ + of the loadBalancing, check application key, secret, consumerkey \ + and parameters. Error returned by OVH api was : {}\ + '.format(apiError)) + backendExists = backend in backends moduleChanged = False - if state=="absent" : - if backendExists : + if state == "absent": + if backendExists: # Remove backend - try : - client.delete('/ip/loadBalancing/{}/backend/{}'.format(name, backend)) - if not waitForNoTask(client, name, timeout): - module.fail_json(msg='Timeout of {} seconds while waiting for completion of removing backend task'.format(timeout)) + try: + client.delete( + '/ip/loadBalancing/{}/backend/{}'.format(name, backend)) + if not waitForNoTask(client, name, timeout): + module.fail_json( + msg='Timeout of {} seconds while waiting for completion \ + of removing backend task'.format(timeout)) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for deleting the backend, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) + module.fail_json( + msg='Unable to call OVH api for deleting the backend, \ + check application key, secret, consumerkey and \ + parameters. Error returned by OVH api was : {}\ + '.format(apiError)) moduleChanged = True - else : - if backendExists : + else: + if backendExists: # Get properties - try : - backendProperties = client.get('/ip/loadBalancing/{}/backend/{}'.format(name, backend)) + try: + backendProperties = client.get( + '/ip/loadBalancing/{}/backend/{}'.format(name, backend)) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for getting the backend properties, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) - + module.fail_json( + msg='Unable to call OVH api for getting the backend properties, \ + check application key, secret, consumerkey and \ + parameters. Error returned by OVH api was : {}\ + '.format(apiError)) + if (backendProperties['weight'] != weight): # Change weight - try : - client.post('/ip/loadBalancing/{}/backend/{}/setWeight'.format(name, backend), weight=weight) - if not waitForNoTask(client, name, timeout): - module.fail_json(msg='Timeout of {} seconds while waiting for completion of setWeight to backend task'.format(timeout)) + try: + client.post( + '/ip/loadBalancing/{}/backend/{}/setWeight\ + '.format(name, backend), weight=weight) + if not waitForNoTask(client, name, timeout): + module.fail_json( + msg='Timeout of {} seconds while waiting for completion \ + of setWeight to backend task'.format(timeout)) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for updating the weight of the backend, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) + module.fail_json( + msg='Unable to call OVH api for updating the weight of the \ + backend, check application key, secret, consumerkey \ + and parameters. Error returned by OVH api was : {}\ + '.format(apiError)) moduleChanged = True - + if (backendProperties['probe'] != probe): # Change probe backendProperties['probe'] = probe - try: - client.put('/ip/loadBalancing/{}/backend/{}'.format(name, backend), probe=probe ) - if not waitForNoTask(client, name, timeout): - module.fail_json(msg='Timeout of {} seconds while waiting for completion of setProbe to backend task'.format(timeout)) + try: + client.put( + '/ip/loadBalancing/{}/backend/{}\ + '.format(name, backend), probe=probe) + if not waitForNoTask(client, name, timeout): + module.fail_json( + msg='Timeout of {} seconds while waiting for completion of \ + setProbe to backend task'.format(timeout)) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for updating the propbe of the backend, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) + module.fail_json( + msg='Unable to call OVH api for updating the propbe of \ + the backend, check application key, secret, \ + consumerkey and parameters. Error returned by OVH api \ + was : {}\ + '.format(apiError)) moduleChanged = True - - else : + + else: # Creates backend try: try: - client.post('/ip/loadBalancing/{}/backend'.format(name), ipBackend=backend, probe=probe, weight=weight) + client.post('/ip/loadBalancing/{}/backend'.format(name), + ipBackend=backend, probe=probe, weight=weight) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for creating the backend, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) - - if not waitForNoTask(client, name, timeout): - module.fail_json(msg='Timeout of {} seconds while waiting for completion of backend creation task'.format(timeout)) + module.fail_json( + msg='Unable to call OVH api for creating the backend, check \ + application key, secret, consumerkey and parameters. \ + Error returned by OVH api was : {}'.format(apiError)) + + if not waitForNoTask(client, name, timeout): + module.fail_json( + msg='Timeout of {} seconds while waiting for completion of \ + backend creation task'.format(timeout)) except APIError as apiError: - module.fail_json(msg='Unable to call OVH api for creating the backend, check application key, secret, consumerkey and parameters. Error returned by OVH api was : {}'.format(apiError)) + module.fail_json( + msg='Unable to call OVH api for creating the backend, check \ + application key, secret, consumerkey and parameters. \ + Error returned by OVH api was : {}'.format(apiError)) moduleChanged = True - + module.exit_json(changed=moduleChanged) # We should never reach here module.fail_json(msg='Internal ovh_ip_loadbalancing_backend module error') - -# import module snippets -from ansible.module_utils.basic import * - main()