Remove deprecated get_exception API

Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
Abhijeet Kasurde 2017-12-26 08:33:21 +05:30 committed by Brian Coca
parent caefe31125
commit 6bd0fbb63c
42 changed files with 284 additions and 409 deletions

View file

@ -130,7 +130,7 @@ acl:
import os import os
from ansible.module_utils.basic import AnsibleModule, get_platform from ansible.module_utils.basic import AnsibleModule, get_platform
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
def split_entry(entry): def split_entry(entry):
@ -225,9 +225,8 @@ def run_acl(module, cmd, check_rc=True):
try: try:
(rc, out, err) = module.run_command(' '.join(cmd), check_rc=check_rc) (rc, out, err) = module.run_command(' '.join(cmd), check_rc=check_rc)
except Exception: except Exception as e:
e = get_exception() module.fail_json(msg=to_native(e))
module.fail_json(msg=e.strerror)
lines = [] lines = []
for l in out.splitlines(): for l in out.splitlines():
@ -355,5 +354,6 @@ def main():
module.exit_json(changed=changed, msg=msg, acl=acl) module.exit_json(changed=changed, msg=msg, acl=acl)
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -77,7 +77,7 @@ import re
# import module snippets # import module snippets
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
def get_xattr_keys(module, path, follow): def get_xattr_keys(module, path, follow):
@ -134,9 +134,8 @@ def _run_xattr(module, cmd, check_rc=True):
try: try:
(rc, out, err) = module.run_command(' '.join(cmd), check_rc=check_rc) (rc, out, err) = module.run_command(' '.join(cmd), check_rc=check_rc)
except Exception: except Exception as e:
e = get_exception() module.fail_json(msg="%s!" % to_native(e))
module.fail_json(msg="%s!" % e.strerror)
# result = {'raw': out} # result = {'raw': out}
result = {} result = {}
@ -210,5 +209,6 @@ def main():
module.exit_json(changed=changed, msg=msg, xattr=res) module.exit_json(changed=changed, msg=msg, xattr=res)
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -134,7 +134,6 @@ build_errors:
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.network.aos.aos import get_aos_session, check_aos_version, find_collection_item from ansible.module_utils.network.aos.aos import get_aos_session, check_aos_version, find_collection_item
from ansible.module_utils.pycompat24 import get_exception
def create_blueprint(module, aos, name): def create_blueprint(module, aos, name):
@ -149,8 +148,7 @@ def create_blueprint(module, aos, name):
blueprint = aos.Blueprints[name] blueprint = aos.Blueprints[name]
blueprint.create(template_id, reference_arch=margs['reference_arch']) blueprint.create(template_id, reference_arch=margs['reference_arch'])
except: except Exception as exc:
exc = get_exception()
msg = "Unable to create blueprint: %s" % exc.message msg = "Unable to create blueprint: %s" % exc.message
if 'UNPROCESSABLE ENTITY' in exc.message: if 'UNPROCESSABLE ENTITY' in exc.message:
msg += ' (likely missing dependencies)' msg += ' (likely missing dependencies)'
@ -170,8 +168,7 @@ def ensure_absent(module, aos, blueprint):
if not module.check_mode: if not module.check_mode:
try: try:
blueprint.delete() blueprint.delete()
except: except Exception as exc:
exc = get_exception()
module.fail_json(msg='Unable to delete blueprint, %s' % exc.message) module.fail_json(msg='Unable to delete blueprint, %s' % exc.message)
module.exit_json(changed=True, module.exit_json(changed=True,
@ -294,5 +291,6 @@ def main():
aos_blueprint(module) aos_blueprint(module)
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -163,7 +163,7 @@ import json
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.network.aos.aos import get_aos_session, find_collection_item, check_aos_version from ansible.module_utils.network.aos.aos import get_aos_session, find_collection_item, check_aos_version
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
try: try:
import yaml import yaml
@ -238,10 +238,9 @@ def blueprint_param_present(module, aos, blueprint, param, param_value):
if not module.check_mode: if not module.check_mode:
try: try:
param.value = param_value param.value = param_value
except: except Exception as exc:
exc = get_exception() module.fail_json(msg='unable to write to param %s: %s' %
module.fail_json(msg='unable to write to param %s: %r' % (margs['name'], to_native(exc)))
(margs['name'], exc))
module.exit_json(changed=True, module.exit_json(changed=True,
blueprint=blueprint.name, blueprint=blueprint.name,
@ -265,9 +264,8 @@ def blueprint_param_absent(module, aos, blueprint, param, param_value):
if not module.check_mode: if not module.check_mode:
try: try:
param.value = {} param.value = {}
except: except Exception as exc:
exc = get_exception() module.fail_json(msg='Unable to write to param %s: %s' % (margs['name'], to_native(exc)))
module.fail_json(msg='Unable to write to param %s: %r' % (margs['name'], exc))
module.exit_json(changed=True, module.exit_json(changed=True,
blueprint=blueprint.name, blueprint=blueprint.name,

View file

@ -84,8 +84,8 @@ EXAMPLES = '''
import json import json
from ansible.module_utils.pycompat24 import get_exception
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils._text import to_native
from ansible.module_utils.network.aos.aos import get_aos_session, find_collection_item, do_load_resource, check_aos_version, content_to_dict from ansible.module_utils.network.aos.aos import get_aos_session, find_collection_item, do_load_resource, check_aos_version, content_to_dict
@ -103,9 +103,8 @@ def ensure_present(module, aos, blueprint, virtnet):
if not module.check_mode: if not module.check_mode:
try: try:
virtnet.create(module.params['content']) virtnet.create(module.params['content'])
except: except Exception as e:
e = get_exception() module.fail_json(msg="unable to create virtual-network : %s" % to_native(e))
module.fail_json(msg="unable to create virtual-network : %r" % e)
module.exit_json(changed=True, module.exit_json(changed=True,
blueprint=blueprint.name, blueprint=blueprint.name,
@ -120,9 +119,8 @@ def ensure_absent(module, aos, blueprint, virtnet):
if not module.check_mode: if not module.check_mode:
try: try:
virtnet.delete() virtnet.delete()
except: except Exception as e:
e = get_exception() module.fail_json(msg="unable to delete virtual-network %s : %s" % (virtnet.name, to_native(e)))
module.fail_json(msg="unable to delete virtual-network %s : %r" % (virtnet.name, e))
module.exit_json(changed=True, module.exit_json(changed=True,
blueprint=blueprint.name) blueprint=blueprint.name)
@ -214,5 +212,6 @@ def main():
blueprint_virtnet(module) blueprint_virtnet(module)
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -137,7 +137,7 @@ failed_conditions:
import time import time
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.six import string_types from ansible.module_utils.six import string_types
from ansible.module_utils.network.common.parsing import Conditional from ansible.module_utils.network.common.parsing import Conditional
from ansible.module_utils.network.common.utils import ComplexList from ansible.module_utils.network.common.utils import ComplexList
@ -216,9 +216,8 @@ def main():
try: try:
conditionals = [Conditional(c) for c in wait_for] conditionals = [Conditional(c) for c in wait_for]
except AttributeError: except AttributeError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=str(exc))
retries = module.params['retries'] retries = module.params['retries']
interval = module.params['interval'] interval = module.params['interval']

View file

@ -110,7 +110,6 @@ from ansible.module_utils.network.fortios.fortios import fortios_argument_spec,
from ansible.module_utils.network.fortios.fortios import backup, AnsibleFortios from ansible.module_utils.network.fortios.fortios import backup, AnsibleFortios
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
# check for netaddr lib # check for netaddr lib
@ -287,5 +286,6 @@ def main():
# Apply changes (check mode is managed directly by the fortigate object) # Apply changes (check mode is managed directly by the fortigate object)
fortigate.apply_changes() fortigate.apply_changes()
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -81,7 +81,7 @@ from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.network.common.netconf import exec_rpc from ansible.module_utils.network.common.netconf import exec_rpc
from ansible.module_utils.network.junos.junos import junos_argument_spec, get_param from ansible.module_utils.network.junos.junos import junos_argument_spec, get_param
from ansible.module_utils.network.junos.junos import get_configuration, get_connection from ansible.module_utils.network.junos.junos import get_configuration, get_connection
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.six import iteritems from ansible.module_utils.six import iteritems
@ -263,9 +263,8 @@ class Facts(FactsBase):
device = Device(host, **kwargs) device = Device(host, **kwargs)
device.open() device.open()
device.timeout = get_param(module, 'timeout') or 10 device.timeout = get_param(module, 'timeout') or 10
except ConnectError: except ConnectError as exc:
exc = get_exception() module.fail_json('unable to connect to %s: %s' % (host, to_native(exc)))
module.fail_json('unable to connect to %s: %s' % (host, str(exc)))
return device return device
@ -286,6 +285,7 @@ class Facts(FactsBase):
return facts return facts
FACT_SUBSETS = dict( FACT_SUBSETS = dict(
default=Default, default=Default,
hardware=Hardware, hardware=Hardware,

View file

@ -103,7 +103,7 @@ EXAMPLES = """
""" """
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.network.junos.junos import junos_argument_spec, get_param from ansible.module_utils.network.junos.junos import junos_argument_spec, get_param
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
try: try:
from jnpr.junos import Device from jnpr.junos import Device
@ -134,9 +134,8 @@ def connect(module):
device = Device(host, **kwargs) device = Device(host, **kwargs)
device.open() device.open()
device.timeout = get_param(module, 'timeout') or 10 device.timeout = get_param(module, 'timeout') or 10
except ConnectError: except ConnectError as exc:
exc = get_exception() module.fail_json(msg='unable to connect to %s: %s' % (host, to_native(exc)))
module.fail_json(msg='unable to connect to %s: %s' % (host, str(exc)))
return device return device

View file

@ -150,7 +150,7 @@ RETURN = '''
''' '''
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
import pan.xapi import pan.xapi
@ -345,9 +345,8 @@ def main():
module.exit_json(changed=changed, msg="okey dokey") module.exit_json(changed=changed, msg="okey dokey")
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
if __name__ == '__main__': if __name__ == '__main__':

View file

@ -260,7 +260,7 @@ RETURN = '''
''' '''
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
import pan.xapi import pan.xapi
@ -508,9 +508,8 @@ def main():
module.fail_json(msg='Rule with the same name but different objects exists.') module.fail_json(msg='Rule with the same name but different objects exists.')
try: try:
changed = add_security_rule(device, sec_rule, rule_exist) changed = add_security_rule(device, sec_rule, rule_exist)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
if changed and commit: if changed and commit:
result = _commit(device, devicegroup) result = _commit(device, devicegroup)

View file

@ -91,7 +91,7 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
import time import time
try: try:
@ -193,11 +193,11 @@ def main():
cert_friendly_name, cert_friendly_name,
signed_by, signed_by,
rsa_nbits) rsa_nbits)
except Exception: except Exception as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=True, msg="okey dokey") module.exit_json(changed=True, msg="okey dokey")
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -83,7 +83,7 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
import os.path import os.path
import xml.etree import xml.etree
@ -183,9 +183,8 @@ def main():
try: try:
changed, filename = import_file(xapi, module, ip_address, file_, category) changed, filename = import_file(xapi, module, ip_address, file_, category)
except Exception: except Exception as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
# cleanup and delete file if local # cleanup and delete file if local
if url is not None: if url is not None:
@ -193,5 +192,6 @@ def main():
module.exit_json(changed=changed, filename=filename, msg="okey dokey") module.exit_json(changed=changed, filename=filename, msg="okey dokey")
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -83,8 +83,7 @@ RETURN = '''
''' '''
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
import pan.xapi import pan.xapi
@ -171,14 +170,14 @@ def main():
try: try:
changed = add_dhcp_if(xapi, if_name, zone_name, create_default_route) changed = add_dhcp_if(xapi, if_name, zone_name, create_default_route)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
if changed and commit: if changed and commit:
xapi.commit(cmd="<commit></commit>", sync=True, interval=1) xapi.commit(cmd="<commit></commit>", sync=True, interval=1)
module.exit_json(changed=changed, msg="okey dokey") module.exit_json(changed=changed, msg="okey dokey")
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -91,7 +91,7 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
import pan.xapi import pan.xapi
@ -196,11 +196,11 @@ def main():
if changed and commit: if changed and commit:
xapi.commit(cmd="<commit></commit>", sync=True, interval=1) xapi.commit(cmd="<commit></commit>", sync=True, interval=1)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg="okey dokey") module.exit_json(changed=changed, msg="okey dokey")
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -149,7 +149,7 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
# import pydevd # import pydevd
# pydevd.settrace('localhost', port=60374, stdoutToServer=True, stderrToServer=True) # pydevd.settrace('localhost', port=60374, stdoutToServer=True, stderrToServer=True)
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
import pan.xapi import pan.xapi
@ -374,9 +374,8 @@ def main():
match.delete() match.delete()
if commit: if commit:
device.commit(sync=True) device.commit(sync=True)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=True, msg='Rule \'%s\' successfully deleted.' % rule_name) module.exit_json(changed=True, msg='Rule \'%s\' successfully deleted.' % rule_name)
else: else:
@ -417,9 +416,8 @@ def main():
changed = add_rule(rulebase, new_rule) changed = add_rule(rulebase, new_rule)
if changed and commit: if changed and commit:
device.commit(sync=True) device.commit(sync=True)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg='Rule \'%s\' successfully added.' % rule_name) module.exit_json(changed=changed, msg='Rule \'%s\' successfully added.' % rule_name)
elif operation == 'update': elif operation == 'update':
# Search for the rule. Update if found. # Search for the rule. Update if found.
@ -450,9 +448,8 @@ def main():
changed = update_rule(rulebase, new_rule) changed = update_rule(rulebase, new_rule)
if changed and commit: if changed and commit:
device.commit(sync=True) device.commit(sync=True)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg='Rule \'%s\' successfully updated.' % rule_name) module.exit_json(changed=changed, msg='Rule \'%s\' successfully updated.' % rule_name)
else: else:
module.fail_json(msg='Rule \'%s\' does not exist. Use operation: \'add\' to add it.' % rule_name) module.fail_json(msg='Rule \'%s\' does not exist. Use operation: \'add\' to add it.' % rule_name)

View file

@ -167,7 +167,7 @@ RETURN = '''
''' '''
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
import pan.xapi import pan.xapi
@ -392,9 +392,8 @@ def main():
if match: if match:
try: try:
match.delete() match.delete()
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=True, msg='Object \'%s\' successfully deleted' % obj_name) module.exit_json(changed=True, msg='Object \'%s\' successfully deleted' % obj_name)
else: else:
@ -424,9 +423,8 @@ def main():
color=color color=color
) )
changed = add_object(device, dev_group, new_object) changed = add_object(device, dev_group, new_object)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg='Object \'%s\' successfully added' % obj_name) module.exit_json(changed=changed, msg='Object \'%s\' successfully added' % obj_name)
elif operation == "update": elif operation == "update":
# Search for the object. Update if found. # Search for the object. Update if found.
@ -451,9 +449,8 @@ def main():
color=color color=color
) )
changed = add_object(device, dev_group, new_object) changed = add_object(device, dev_group, new_object)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg='Object \'%s\' successfully updated.' % obj_name) module.exit_json(changed=changed, msg='Object \'%s\' successfully updated.' % obj_name)
else: else:
module.fail_json(msg='Object \'%s\' does not exist. Use operation: \'add\' to add it.' % obj_name) module.fail_json(msg='Object \'%s\' does not exist. Use operation: \'add\' to add it.' % obj_name)

View file

@ -111,7 +111,7 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
@ -214,9 +214,8 @@ def main():
if changed and commit: if changed and commit:
xapi.commit(cmd="<commit></commit>", sync=True, interval=1) xapi.commit(cmd="<commit></commit>", sync=True, interval=1)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg="okey dokey") module.exit_json(changed=changed, msg="okey dokey")

View file

@ -107,7 +107,8 @@ ANSIBLE_METADATA = {'metadata_version': '1.1',
'status': ['preview'], 'status': ['preview'],
'supported_by': 'community'} 'supported_by': 'community'}
from ansible.module_utils.basic import AnsibleModule, get_exception from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils._text import to_native
try: try:
from pandevice import base from pandevice import base
@ -183,8 +184,7 @@ def add_address_group(device, dev_group, ag_object):
exc = None exc = None
try: try:
ag_object.create() ag_object.create()
except Exception: except Exception as exc:
exc = get_exception()
return False, exc return False, exc
return True, exc return True, exc
@ -204,8 +204,7 @@ def delete_address_group(device, dev_group, obj_name):
if static_obj: if static_obj:
try: try:
static_obj.delete() static_obj.delete()
except Exception: except Exception as exc:
exc = get_exception()
return False, exc return False, exc
return True, None return True, None
else: else:
@ -263,9 +262,8 @@ def main():
if result and commit: if result and commit:
try: try:
device.commit(sync=True) device.commit(sync=True)
except Exception: except Exception as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
elif operation == 'delete': elif operation == 'delete':
obj_name = module.params.get('sag_name', None) obj_name = module.params.get('sag_name', None)

View file

@ -236,7 +236,7 @@ RETURN = '''
''' '''
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.basic import get_exception from ansible.module_utils._text import to_native
try: try:
import pan.xapi import pan.xapi
@ -479,9 +479,8 @@ def main():
try: try:
if commit: if commit:
match.delete() match.delete()
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=True, msg='Rule \'%s\' successfully deleted' % rule_name) module.exit_json(changed=True, msg='Rule \'%s\' successfully deleted' % rule_name)
else: else:
@ -525,9 +524,8 @@ def main():
changed = add_rule(rulebase, new_rule) changed = add_rule(rulebase, new_rule)
if changed and commit: if changed and commit:
device.commit(sync=True) device.commit(sync=True)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg='Rule \'%s\' successfully added' % rule_name) module.exit_json(changed=changed, msg='Rule \'%s\' successfully added' % rule_name)
elif operation == 'update': elif operation == 'update':
# Search for the rule. Update if found. # Search for the rule. Update if found.
@ -563,9 +561,8 @@ def main():
changed = update_rule(rulebase, new_rule) changed = update_rule(rulebase, new_rule)
if changed and commit: if changed and commit:
device.commit(sync=True) device.commit(sync=True)
except PanXapiError: except PanXapiError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=exc.message)
module.exit_json(changed=changed, msg='Rule \'%s\' successfully updated' % rule_name) module.exit_json(changed=changed, msg='Rule \'%s\' successfully updated' % rule_name)
else: else:
module.fail_json(msg='Rule \'%s\' does not exist. Use operation: \'add\' to add it.' % rule_name) module.fail_json(msg='Rule \'%s\' does not exist. Use operation: \'add\' to add it.' % rule_name)

View file

@ -144,7 +144,7 @@ warnings:
import time import time
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.network.common.parsing import Conditional from ansible.module_utils.network.common.parsing import Conditional
from ansible.module_utils.network.common.utils import ComplexList from ansible.module_utils.network.common.utils import ComplexList
from ansible.module_utils.six import string_types from ansible.module_utils.six import string_types
@ -200,9 +200,8 @@ def main():
wait_for = module.params['wait_for'] or list() wait_for = module.params['wait_for'] or list()
try: try:
conditionals = [Conditional(c) for c in wait_for] conditionals = [Conditional(c) for c in wait_for]
except AttributeError: except AttributeError as exc:
exc = get_exception() module.fail_json(msg=to_native(exc))
module.fail_json(msg=str(exc))
retries = module.params['retries'] retries = module.params['retries']
interval = module.params['interval'] interval = module.params['interval']

View file

@ -252,7 +252,6 @@ import sys
import time import time
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
from ansible.module_utils._text import to_bytes, to_native from ansible.module_utils._text import to_bytes, to_native
from ansible.module_utils.urls import fetch_url from ansible.module_utils.urls import fetch_url
@ -588,9 +587,8 @@ def install_deb(m, debs, cache, force, install_recommends, allow_unauthenticated
# to install so they're all done in one shot # to install so they're all done in one shot
deps_to_install.extend(pkg.missing_deps) deps_to_install.extend(pkg.missing_deps)
except Exception: except Exception as e:
e = get_exception() m.fail_json(msg="Unable to install package: %s" % to_native(e))
m.fail_json(msg="Unable to install package: %s" % str(e))
# and add this deb to the list of packages to install # and add this deb to the list of packages to install
pkgs_to_install.append(deb_file) pkgs_to_install.append(deb_file)
@ -805,9 +803,8 @@ def download(module, deb):
f.write(data) f.write(data)
f.close() f.close()
deb = package deb = package
except Exception: except Exception as e:
e = get_exception() module.fail_json(msg="Failure downloading %s, %s" % (deb, to_native(e)))
module.fail_json(msg="Failure downloading %s, %s" % (deb, e))
return deb return deb
@ -843,8 +840,7 @@ def get_cache(module):
cache = None cache = None
try: try:
cache = apt.Cache() cache = apt.Cache()
except SystemError: except SystemError as e:
e = get_exception()
if '/var/lib/apt/lists/' in str(e).lower(): if '/var/lib/apt/lists/' in str(e).lower():
# update cache until files are fixed or retries exceeded # update cache until files are fixed or retries exceeded
retries = 0 retries = 0

View file

@ -107,7 +107,11 @@ import os
import re import re
import sys import sys
import tempfile import tempfile
import json
# import module snippets
from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.urls import fetch_url
from ansible.module_utils._text import to_native
try: try:
import apt import apt
import apt_pkg import apt_pkg
@ -292,9 +296,8 @@ class SourcesList(object):
try: try:
f.write(line) f.write(line)
except IOError: except IOError as err:
err = get_exception() self.module.fail_json(msg="Failed to write to file %s: %s" % (tmp_path, to_native(err)))
self.module.fail_json(msg="Failed to write to file %s: %s" % (tmp_path, unicode(err)))
self.module.atomic_move(tmp_path, filename) self.module.atomic_move(tmp_path, filename)
# allow the user to override the default mode # allow the user to override the default mode
@ -510,9 +513,8 @@ def main():
sourceslist.add_source(repo) sourceslist.add_source(repo)
elif state == 'absent': elif state == 'absent':
sourceslist.remove_source(repo) sourceslist.remove_source(repo)
except InvalidSource: except InvalidSource as err:
err = get_exception() module.fail_json(msg='Invalid repository string: %s' % to_native(err))
module.fail_json(msg='Invalid repository string: %s' % unicode(err))
sources_after = sourceslist.dump() sources_after = sourceslist.dump()
changed = sources_before != sources_after changed = sources_before != sources_after
@ -533,15 +535,11 @@ def main():
if update_cache: if update_cache:
cache = apt.Cache() cache = apt.Cache()
cache.update() cache.update()
except OSError: except OSError as err:
err = get_exception() module.fail_json(msg=to_native(err))
module.fail_json(msg=unicode(err))
module.exit_json(changed=changed, repo=repo, state=state, diff=diff) module.exit_json(changed=changed, repo=repo, state=state, diff=diff)
# import module snippets
from ansible.module_utils.basic import *
from ansible.module_utils.urls import *
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -448,7 +448,7 @@ state:
import os import os
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.six.moves import configparser from ansible.module_utils.six.moves import configparser
@ -566,32 +566,29 @@ class YumRepo(object):
# Write data into the file # Write data into the file
try: try:
fd = open(self.params['dest'], 'w') fd = open(self.params['dest'], 'w')
except IOError: except IOError as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot open repo file %s." % self.params['dest'], msg="Cannot open repo file %s." % self.params['dest'],
details=str(e)) details=to_native(e))
self.repofile.write(fd) self.repofile.write(fd)
try: try:
fd.close() fd.close()
except IOError: except IOError as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot write repo file %s." % self.params['dest'], msg="Cannot write repo file %s." % self.params['dest'],
details=str(e)) details=to_native(e))
else: else:
# Remove the file if there are not repos # Remove the file if there are not repos
try: try:
os.remove(self.params['dest']) os.remove(self.params['dest'])
except OSError: except OSError as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg=( msg=(
"Cannot remove empty repo file %s." % "Cannot remove empty repo file %s." %
self.params['dest']), self.params['dest']),
details=str(e)) details=to_native(e))
def remove(self): def remove(self):
# Remove section if exists # Remove section if exists

View file

@ -66,7 +66,7 @@ import json
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.netapp import request, eseries_host_argument_spec from ansible.module_utils.netapp import request, eseries_host_argument_spec
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
HEADERS = { HEADERS = {
"Content-Type": "application/json", "Content-Type": "application/json",
@ -110,10 +110,9 @@ class Host(object):
try: try:
(rc, host_types) = request(self.url + 'storage-systems/%s/host-types' % self.ssid, url_password=self.pwd, (rc, host_types) = request(self.url + 'storage-systems/%s/host-types' % self.ssid, url_password=self.pwd,
url_username=self.user, validate_certs=self.certs, headers=HEADERS) url_username=self.user, validate_certs=self.certs, headers=HEADERS)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to get host types. Array Id [%s]. Error [%s]." % (self.ssid, str(err))) msg="Failed to get host types. Array Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
try: try:
match = filter(lambda host_type: host_type['index'] == self.host_type_index, host_types)[0] match = filter(lambda host_type: host_type['index'] == self.host_type_index, host_types)[0]
@ -129,10 +128,9 @@ class Host(object):
url_password=self.pwd, url_username=self.user, url_password=self.pwd, url_username=self.user,
validate_certs=self.certs, validate_certs=self.certs,
headers=HEADERS) headers=HEADERS)
except: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to get unassociated host ports. Array Id [%s]. Error [%s]." % (self.ssid, str(err))) msg="Failed to get unassociated host ports. Array Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
if len(self.available_ports) > 0 and len(self.ports) <= len(self.available_ports): if len(self.available_ports) > 0 and len(self.ports) <= len(self.available_ports):
for port in self.ports: for port in self.ports:
@ -159,10 +157,9 @@ class Host(object):
(rc, all_groups) = request(self.url + 'storage-systems/%s/host-groups' % self.ssid, (rc, all_groups) = request(self.url + 'storage-systems/%s/host-groups' % self.ssid,
url_password=self.pwd, url_password=self.pwd,
url_username=self.user, validate_certs=self.certs, headers=HEADERS) url_username=self.user, validate_certs=self.certs, headers=HEADERS)
except: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to get host groups. Array Id [%s]. Error [%s]." % (self.ssid, str(err))) msg="Failed to get host groups. Array Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
try: try:
group_obj = filter(lambda group: group['name'] == self.group, all_groups)[0] group_obj = filter(lambda group: group['name'] == self.group, all_groups)[0]
@ -178,10 +175,9 @@ class Host(object):
try: try:
(rc, all_hosts) = request(self.url + 'storage-systems/%s/hosts' % self.ssid, url_password=self.pwd, (rc, all_hosts) = request(self.url + 'storage-systems/%s/hosts' % self.ssid, url_password=self.pwd,
url_username=self.user, validate_certs=self.certs, headers=HEADERS) url_username=self.user, validate_certs=self.certs, headers=HEADERS)
except: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to determine host existence. Array Id [%s]. Error [%s]." % (self.ssid, str(err))) msg="Failed to determine host existence. Array Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
self.all_hosts = all_hosts self.all_hosts = all_hosts
try: # Try to grab the host object try: # Try to grab the host object
@ -260,11 +256,10 @@ class Host(object):
self.url + 'storage-systems/%s/hosts/%s' % (self.ssid, self.host_obj['id']), self.url + 'storage-systems/%s/hosts/%s' % (self.ssid, self.host_obj['id']),
url_username=self.user, url_password=self.pwd, headers=HEADERS, url_username=self.user, url_password=self.pwd, headers=HEADERS,
validate_certs=self.certs, method='POST', data=json.dumps(self.post_body)) validate_certs=self.certs, method='POST', data=json.dumps(self.post_body))
except: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to reassign host port. Host Id [%s]. Array Id [%s]. Error [%s]." % ( msg="Failed to reassign host port. Host Id [%s]. Array Id [%s]. Error [%s]." % (
self.host_obj['id'], self.ssid, str(err))) self.host_obj['id'], self.ssid, to_native(err)))
def update_host(self): def update_host(self):
if self.ports: if self.ports:
@ -285,9 +280,8 @@ class Host(object):
(rc, self.host_obj) = request(self.url + 'storage-systems/%s/hosts/%s' % (self.ssid, self.host_obj['id']), (rc, self.host_obj) = request(self.url + 'storage-systems/%s/hosts/%s' % (self.ssid, self.host_obj['id']),
url_username=self.user, url_password=self.pwd, headers=HEADERS, url_username=self.user, url_password=self.pwd, headers=HEADERS,
validate_certs=self.certs, method='POST', data=json.dumps(self.post_body)) validate_certs=self.certs, method='POST', data=json.dumps(self.post_body))
except: except Exception as err:
err = get_exception() self.module.fail_json(msg="Failed to update host. Array Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
self.module.fail_json(msg="Failed to update host. Array Id [%s]. Error [%s]." % (self.ssid, str(err)))
self.module.exit_json(changed=True, **self.host_obj) self.module.exit_json(changed=True, **self.host_obj)
@ -311,10 +305,9 @@ class Host(object):
(rc, create_resp) = request(self.url + "storage-systems/%s/hosts" % self.ssid, method='POST', (rc, create_resp) = request(self.url + "storage-systems/%s/hosts" % self.ssid, method='POST',
url_username=self.user, url_password=self.pwd, validate_certs=self.certs, url_username=self.user, url_password=self.pwd, validate_certs=self.certs,
data=json.dumps(post_body), headers=HEADERS) data=json.dumps(post_body), headers=HEADERS)
except: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to create host. Array Id [%s]. Error [%s]." % (self.ssid, str(err))) msg="Failed to create host. Array Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
else: else:
self.module.exit_json(changed=False, self.module.exit_json(changed=False,
msg="Host already exists. Id [%s]. Host [%s]." % (self.ssid, self.name)) msg="Host already exists. Id [%s]. Host [%s]." % (self.ssid, self.name))
@ -331,12 +324,11 @@ class Host(object):
(rc, resp) = request(self.url + "storage-systems/%s/hosts/%s" % (self.ssid, self.host_obj['id']), (rc, resp) = request(self.url + "storage-systems/%s/hosts/%s" % (self.ssid, self.host_obj['id']),
method='DELETE', method='DELETE',
url_username=self.user, url_password=self.pwd, validate_certs=self.certs) url_username=self.user, url_password=self.pwd, validate_certs=self.certs)
except: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to remote host. Host[%s]. Array Id [%s]. Error [%s]." % (self.host_obj['id'], msg="Failed to remote host. Host[%s]. Array Id [%s]. Error [%s]." % (self.host_obj['id'],
self.ssid, self.ssid,
str(err))) to_native(err)))
def apply(self): def apply(self):
if self.state == 'present': if self.state == 'present':

View file

@ -78,7 +78,7 @@ import json
from ansible.module_utils.api import basic_auth_argument_spec from ansible.module_utils.api import basic_auth_argument_spec
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.netapp import request, eseries_host_argument_spec from ansible.module_utils.netapp import request, eseries_host_argument_spec
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
HEADERS = { HEADERS = {
"Content-Type": "application/json", "Content-Type": "application/json",
@ -94,9 +94,8 @@ def get_host_and_group_map(module, ssid, api_url, user, pwd, validate_certs):
try: try:
hg_rc, hg_data = request(groups_url, headers=HEADERS, url_username=user, url_password=pwd, hg_rc, hg_data = request(groups_url, headers=HEADERS, url_username=user, url_password=pwd,
validate_certs=validate_certs) validate_certs=validate_certs)
except: except Exception as err:
err = get_exception() module.fail_json(msg="Failed to get host groups. Id [%s]. Error [%s]" % (ssid, to_native(err)))
module.fail_json(msg="Failed to get host groups. Id [%s]. Error [%s]" % (ssid, str(err)))
for group in hg_data: for group in hg_data:
mapping['group'][group['name']] = group['id'] mapping['group'][group['name']] = group['id']
@ -106,9 +105,8 @@ def get_host_and_group_map(module, ssid, api_url, user, pwd, validate_certs):
try: try:
h_rc, h_data = request(hosts_url, headers=HEADERS, url_username=user, url_password=pwd, h_rc, h_data = request(hosts_url, headers=HEADERS, url_username=user, url_password=pwd,
validate_certs=validate_certs) validate_certs=validate_certs)
except: except Exception as err:
err = get_exception() module.fail_json(msg="Failed to get hosts. Id [%s]. Error [%s]" % (ssid, to_native(err)))
module.fail_json(msg="Failed to get hosts. Id [%s]. Error [%s]" % (ssid, str(err)))
for host in h_data: for host in h_data:
mapping['host'][host['name']] = host['id'] mapping['host'][host['name']] = host['id']
@ -150,10 +148,9 @@ def get_volumes(module, ssid, api_url, user, pwd, mappable, validate_certs):
url = api_url + volumes url = api_url + volumes
try: try:
rc, data = request(url, url_username=user, url_password=pwd, validate_certs=validate_certs) rc, data = request(url, url_username=user, url_password=pwd, validate_certs=validate_certs)
except Exception: except Exception as err:
err = get_exception()
module.fail_json( module.fail_json(
msg="Failed to mappable objects. Type[%s. Id [%s]. Error [%s]." % (mappable, ssid, str(err))) msg="Failed to mappable objects. Type[%s. Id [%s]. Error [%s]." % (mappable, ssid, to_native(err)))
return data return data

View file

@ -136,7 +136,7 @@ import json
from ansible.module_utils.api import basic_auth_argument_spec from ansible.module_utils.api import basic_auth_argument_spec
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.urls import open_url from ansible.module_utils.urls import open_url
from ansible.module_utils.six.moves.urllib.error import HTTPError from ansible.module_utils.six.moves.urllib.error import HTTPError
@ -149,8 +149,7 @@ def request(url, data=None, headers=None, method='GET', use_proxy=True,
force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs, force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs,
url_username=url_username, url_password=url_password, http_agent=http_agent, url_username=url_username, url_password=url_password, http_agent=http_agent,
force_basic_auth=force_basic_auth) force_basic_auth=force_basic_auth)
except HTTPError: except HTTPError as err:
err = get_exception()
r = err.fp r = err.fp
try: try:
@ -223,10 +222,9 @@ class SnapshotGroup(object):
url = self.url + pools url = self.url + pools
try: try:
(rc, data) = request(url, headers=HEADERS, url_username=self.user, url_password=self.pwd) (rc, data) = request(url, headers=HEADERS, url_username=self.user, url_password=self.pwd)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Snapshot group module - Failed to fetch storage pools. " + self.module.fail_json(msg="Snapshot group module - Failed to fetch storage pools. " +
"Id [%s]. Error [%s]." % (self.ssid, str(err))) "Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
for pool in data: for pool in data:
if pool['name'] == self.storage_pool_name: if pool['name'] == self.storage_pool_name:
@ -242,10 +240,9 @@ class SnapshotGroup(object):
try: try:
rc, data = request(url, headers=HEADERS, url_username=self.user, url_password=self.pwd, rc, data = request(url, headers=HEADERS, url_username=self.user, url_password=self.pwd,
validate_certs=self.certs) validate_certs=self.certs)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Snapshot group module - Failed to fetch volumes. " + self.module.fail_json(msg="Snapshot group module - Failed to fetch volumes. " +
"Id [%s]. Error [%s]." % (self.ssid, str(err))) "Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
qty = 0 qty = 0
for volume in data: for volume in data:
if volume['name'] == self.base_volume_name: if volume['name'] == self.base_volume_name:
@ -269,10 +266,9 @@ class SnapshotGroup(object):
try: try:
rc, data = request(url, headers=HEADERS, url_username=self.user, url_password=self.pwd, rc, data = request(url, headers=HEADERS, url_username=self.user, url_password=self.pwd,
validate_certs=self.certs) validate_certs=self.certs)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Failed to fetch snapshot groups. " + self.module.fail_json(msg="Failed to fetch snapshot groups. " +
"Id [%s]. Error [%s]." % (self.ssid, str(err))) "Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
for ssg in data: for ssg in data:
if ssg['name'] == self.name: if ssg['name'] == self.name:
self.ssg_data = ssg self.ssg_data = ssg
@ -305,12 +301,11 @@ class SnapshotGroup(object):
try: try:
rc, self.ssg_data = request(url, data=json.dumps(self.post_data), method='POST', headers=HEADERS, rc, self.ssg_data = request(url, data=json.dumps(self.post_data), method='POST', headers=HEADERS,
url_username=self.user, url_password=self.pwd, validate_certs=self.certs) url_username=self.user, url_password=self.pwd, validate_certs=self.certs)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Failed to create snapshot group. " + self.module.fail_json(msg="Failed to create snapshot group. " +
"Snapshot group [%s]. Id [%s]. Error [%s]." % (self.name, "Snapshot group [%s]. Id [%s]. Error [%s]." % (self.name,
self.ssid, self.ssid,
str(err))) to_native(err)))
if not self.snapshot_group_id: if not self.snapshot_group_id:
self.snapshot_group_id = self.ssg_data['id'] self.snapshot_group_id = self.ssg_data['id']
@ -332,12 +327,11 @@ class SnapshotGroup(object):
try: try:
rc, self.ssg_data = request(url, data=json.dumps(self.post_data), method='POST', headers=HEADERS, rc, self.ssg_data = request(url, data=json.dumps(self.post_data), method='POST', headers=HEADERS,
url_username=self.user, url_password=self.pwd, validate_certs=self.certs) url_username=self.user, url_password=self.pwd, validate_certs=self.certs)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Failed to update snapshot group. " + self.module.fail_json(msg="Failed to update snapshot group. " +
"Snapshot group [%s]. Id [%s]. Error [%s]." % (self.name, "Snapshot group [%s]. Id [%s]. Error [%s]." % (self.name,
self.ssid, self.ssid,
str(err))) to_native(err)))
def apply(self): def apply(self):
if self.state == 'absent': if self.state == 'absent':
@ -347,12 +341,11 @@ class SnapshotGroup(object):
self.url + 'storage-systems/%s/snapshot-groups/%s' % (self.ssid, self.snapshot_group_id), self.url + 'storage-systems/%s/snapshot-groups/%s' % (self.ssid, self.snapshot_group_id),
method='DELETE', headers=HEADERS, url_password=self.pwd, url_username=self.user, method='DELETE', headers=HEADERS, url_password=self.pwd, url_username=self.user,
validate_certs=self.certs) validate_certs=self.certs)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Failed to delete snapshot group. " + self.module.fail_json(msg="Failed to delete snapshot group. " +
"Snapshot group [%s]. Id [%s]. Error [%s]." % (self.name, "Snapshot group [%s]. Id [%s]. Error [%s]." % (self.name,
self.ssid, self.ssid,
str(err))) to_native(err)))
self.module.exit_json(changed=True, msg="Snapshot group removed", **self.ssg_data) self.module.exit_json(changed=True, msg="Snapshot group removed", **self.ssg_data)
else: else:
self.module.exit_json(changed=False, msg="Snapshot group absent") self.module.exit_json(changed=False, msg="Snapshot group absent")

View file

@ -84,7 +84,7 @@ import json
from ansible.module_utils.api import basic_auth_argument_spec from ansible.module_utils.api import basic_auth_argument_spec
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.urls import open_url from ansible.module_utils.urls import open_url
from ansible.module_utils.six.moves.urllib.error import HTTPError from ansible.module_utils.six.moves.urllib.error import HTTPError
@ -97,8 +97,7 @@ def request(url, data=None, headers=None, method='GET', use_proxy=True,
force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs, force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs,
url_username=url_username, url_password=url_password, http_agent=http_agent, url_username=url_username, url_password=url_password, http_agent=http_agent,
force_basic_auth=force_basic_auth) force_basic_auth=force_basic_auth)
except HTTPError: except HTTPError as err:
err = get_exception()
r = err.fp r = err.fp
try: try:
@ -145,10 +144,9 @@ def oldest_image(module, ssid, api_url, api_pwd, api_usr, name):
try: try:
(ret, images) = request(url, url_username=api_usr, url_password=api_pwd, headers=HEADERS, (ret, images) = request(url, url_username=api_usr, url_password=api_pwd, headers=HEADERS,
validate_certs=module.params['validate_certs']) validate_certs=module.params['validate_certs'])
except: except Exception as err:
err = get_exception()
module.fail_json(msg="Failed to get snapshot images for group. Group [%s]. Id [%s]. Error [%s]" % module.fail_json(msg="Failed to get snapshot images for group. Group [%s]. Id [%s]. Error [%s]" %
(name, ssid, str(err))) (name, ssid, to_native(err)))
if not images: if not images:
module.exit_json(msg="There are no snapshot images to remove. Group [%s]. Id [%s]." % (name, ssid)) module.exit_json(msg="There are no snapshot images to remove. Group [%s]. Id [%s]." % (name, ssid))
@ -188,8 +186,7 @@ def delete_image(module, ssid, api_url, pwd, user, snapshot_group):
try: try:
(ret, image_data) = request(url, method='DELETE', url_username=user, url_password=pwd, headers=HEADERS, (ret, image_data) = request(url, method='DELETE', url_username=user, url_password=pwd, headers=HEADERS,
validate_certs=module.params['validate_certs']) validate_certs=module.params['validate_certs'])
except Exception: except Exception as e:
e = get_exception()
image_data = (e[0], e[1]) image_data = (e[0], e[1])
if ret == 204: if ret == 204:

View file

@ -111,7 +111,6 @@ import json
from ansible.module_utils.api import basic_auth_argument_spec from ansible.module_utils.api import basic_auth_argument_spec
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
from ansible.module_utils.urls import open_url from ansible.module_utils.urls import open_url
from ansible.module_utils.six.moves.urllib.error import HTTPError from ansible.module_utils.six.moves.urllib.error import HTTPError
@ -124,8 +123,7 @@ def request(url, data=None, headers=None, method='GET', use_proxy=True,
force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs, force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs,
url_username=url_username, url_password=url_password, http_agent=http_agent, url_username=url_username, url_password=url_password, http_agent=http_agent,
force_basic_auth=force_basic_auth) force_basic_auth=force_basic_auth)
except HTTPError: except HTTPError as err:
err = get_exception()
r = err.fp r = err.fp
try: try:

View file

@ -101,7 +101,7 @@ from time import sleep
from ansible.module_utils.api import basic_auth_argument_spec from ansible.module_utils.api import basic_auth_argument_spec
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.urls import open_url from ansible.module_utils.urls import open_url
from ansible.module_utils.six.moves.urllib.error import HTTPError from ansible.module_utils.six.moves.urllib.error import HTTPError
@ -114,8 +114,7 @@ def request(url, data=None, headers=None, method='GET', use_proxy=True,
force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs, force=force, last_mod_time=last_mod_time, timeout=timeout, validate_certs=validate_certs,
url_username=url_username, url_password=url_password, http_agent=http_agent, url_username=url_username, url_password=url_password, http_agent=http_agent,
force_basic_auth=force_basic_auth) force_basic_auth=force_basic_auth)
except HTTPError: except HTTPError as err:
err = get_exception()
r = err.fp r = err.fp
try: try:
@ -208,9 +207,8 @@ def main():
(rc, resp) = request(api_url + "/storage-systems/%s" % ssid, headers=dict(Accept="application/json"), (rc, resp) = request(api_url + "/storage-systems/%s" % ssid, headers=dict(Accept="application/json"),
url_username=api_usr, url_password=api_pwd, validate_certs=validate_certs, url_username=api_usr, url_password=api_pwd, validate_certs=validate_certs,
ignore_errors=True) ignore_errors=True)
except: except Exception as err:
err = get_exception() module.fail_json(msg="Error accessing storage-system with id [%s]. Error [%s]" % (ssid, to_native(err)))
module.fail_json(msg="Error accessing storage-system with id [%s]. Error [%s]" % (ssid, str(err)))
array_exists = True array_exists = True
array_detail = resp array_detail = resp
@ -260,10 +258,9 @@ def main():
try: try:
(rc, resp) = do_post(ssid, api_url, post_headers, api_usr, api_pwd, validate_certs, request_data, (rc, resp) = do_post(ssid, api_url, post_headers, api_usr, api_pwd, validate_certs, request_data,
array_status_timeout_sec) array_status_timeout_sec)
except: except Exception as err:
err = get_exception()
module.fail_json(msg="Failed to add storage system. Id[%s]. Request body [%s]. Error[%s]." % module.fail_json(msg="Failed to add storage system. Id[%s]. Request body [%s]. Error[%s]." %
(ssid, request_data, str(err))) (ssid, request_data, to_native(err)))
else: # array exists, modify... else: # array exists, modify...
post_headers = dict(Accept="application/json") post_headers = dict(Accept="application/json")
@ -278,10 +275,9 @@ def main():
try: try:
(rc, resp) = do_post(ssid, api_url, post_headers, api_usr, api_pwd, validate_certs, post_body, (rc, resp) = do_post(ssid, api_url, post_headers, api_usr, api_pwd, validate_certs, post_body,
array_status_timeout_sec) array_status_timeout_sec)
except: except Exception as err:
err = get_exception()
module.fail_json(msg="Failed to update storage system. Id[%s]. Request body [%s]. Error[%s]." % module.fail_json(msg="Failed to update storage system. Id[%s]. Request body [%s]. Error[%s]." %
(ssid, post_body, str(err))) (ssid, post_body, to_native(err)))
elif state == 'absent': elif state == 'absent':
# delete the array # delete the array
@ -289,9 +285,8 @@ def main():
(rc, resp) = request(api_url + "/storage-systems/%s" % ssid, method='DELETE', (rc, resp) = request(api_url + "/storage-systems/%s" % ssid, method='DELETE',
url_username=api_usr, url_username=api_usr,
url_password=api_pwd, validate_certs=validate_certs) url_password=api_pwd, validate_certs=validate_certs)
except: except Exception as err:
err = get_exception() module.fail_json(msg="Failed to remove storage array. Id[%s]. Error[%s]." % (ssid, to_native(err)))
module.fail_json(msg="Failed to remove storage array. Id[%s]. Error[%s]." % (ssid, str(err)))
if rc == 422: if rc == 422:
module.exit_json(changed=changed, msg="Storage system was not presnt.") module.exit_json(changed=changed, msg="Storage system was not presnt.")

View file

@ -109,7 +109,7 @@ from traceback import format_exc
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.netapp import request, eseries_host_argument_spec from ansible.module_utils.netapp import request, eseries_host_argument_spec
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
def select(predicate, iterable): def select(predicate, iterable):
@ -380,17 +380,15 @@ class NetAppESeriesStoragePool(object):
(rc, resp) = request(self.api_url + "/storage-systems/%s/storage-pools" % (self.ssid), (rc, resp) = request(self.api_url + "/storage-systems/%s/storage-pools" % (self.ssid),
headers=dict(Accept="application/json"), url_username=self.api_usr, headers=dict(Accept="application/json"), url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs) url_password=self.api_pwd, validate_certs=self.validate_certs)
except Exception: except Exception as err:
err = get_exception()
rc = err.args[0] rc = err.args[0]
if rc == 404 and self.state == 'absent': if rc == 404 and self.state == 'absent':
self.module.exit_json( self.module.exit_json(
msg="Storage pool [%s] did not exist." % (self.name)) msg="Storage pool [%s] did not exist." % (self.name))
else: else:
err = get_exception()
self.module.exit_json( self.module.exit_json(
msg="Failed to get storage pools. Array id [%s]. Error[%s]. State[%s]. RC[%s]." % msg="Failed to get storage pools. Array id [%s]. Error[%s]. State[%s]. RC[%s]." %
(self.ssid, str(err), self.state, rc)) (self.ssid, to_native(err), self.state, rc))
self.debug("searching for storage pool '%s'", storage_pool_name) self.debug("searching for storage pool '%s'", storage_pool_name)
@ -435,10 +433,9 @@ class NetAppESeriesStoragePool(object):
(rc, drives_resp) = request(self.api_url + "/storage-systems/%s/drives" % (self.ssid), method='GET', (rc, drives_resp) = request(self.api_url + "/storage-systems/%s/drives" % (self.ssid), method='GET',
url_username=self.api_usr, url_password=self.api_pwd, url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs) validate_certs=self.validate_certs)
except: except Exception as err:
err = get_exception()
self.module.exit_json( self.module.exit_json(
msg="Failed to fetch disk drives. Array id [%s]. Error[%s]." % (self.ssid, str(err))) msg="Failed to fetch disk drives. Array id [%s]. Error[%s]." % (self.ssid, to_native(err)))
try: try:
candidate_set = self.filter_drives(drives_resp, candidate_set = self.filter_drives(drives_resp,
@ -451,10 +448,9 @@ class NetAppESeriesStoragePool(object):
interface_type=self.criteria_drive_interface_type, interface_type=self.criteria_drive_interface_type,
fde_required=self.criteria_drive_require_fde fde_required=self.criteria_drive_require_fde
) )
except: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to allocate adequate drive count. Id [%s]. Error [%s]." % (self.ssid, str(err))) msg="Failed to allocate adequate drive count. Id [%s]. Error [%s]." % (self.ssid, to_native(err)))
disk_ids = [d['id'] for d in candidate_set] disk_ids = [d['id'] for d in candidate_set]
@ -478,13 +474,12 @@ class NetAppESeriesStoragePool(object):
url_username=self.api_usr, url_password=self.api_pwd, url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs, validate_certs=self.validate_certs,
timeout=120) timeout=120)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to create storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id, msg="Failed to create storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id,
self.ssid, self.ssid,
str(err))) to_native(err)))
self.pool_detail = self.get_storage_pool(self.name) self.pool_detail = self.get_storage_pool(self.name)
@ -496,13 +491,12 @@ class NetAppESeriesStoragePool(object):
data=json.dumps(secure_pool_data), headers=self.post_headers, method='POST', data=json.dumps(secure_pool_data), headers=self.post_headers, method='POST',
url_username=self.api_usr, url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120, ignore_errors=True) url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120, ignore_errors=True)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to update storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id, msg="Failed to update storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id,
self.ssid, self.ssid,
str(err))) to_native(err)))
@property @property
def needs_raid_level_migration(self): def needs_raid_level_migration(self):
@ -527,12 +521,11 @@ class NetAppESeriesStoragePool(object):
data=json.dumps(sp_raid_migrate_req), headers=self.post_headers, method='POST', data=json.dumps(sp_raid_migrate_req), headers=self.post_headers, method='POST',
url_username=self.api_usr, url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120) url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to change the raid level of storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % ( msg="Failed to change the raid level of storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (
pool_id, self.ssid, str(err))) pool_id, self.ssid, to_native(err)))
@property @property
def sp_drives(self, exclude_hotspares=True): def sp_drives(self, exclude_hotspares=True):
@ -543,11 +536,10 @@ class NetAppESeriesStoragePool(object):
(rc, resp) = request(self.api_url + "/storage-systems/%s/drives" % (self.ssid), method='GET', (rc, resp) = request(self.api_url + "/storage-systems/%s/drives" % (self.ssid), method='GET',
url_username=self.api_usr, url_password=self.api_pwd, url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs) validate_certs=self.validate_certs)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to fetch disk drives. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id, self.ssid, str(err))) msg="Failed to fetch disk drives. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id, self.ssid, to_native(err)))
sp_id = self.pool_detail['id'] sp_id = self.pool_detail['id']
if exclude_hotspares: if exclude_hotspares:
@ -586,12 +578,11 @@ class NetAppESeriesStoragePool(object):
self.pool_detail['id']), self.pool_detail['id']),
method='GET', url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs, method='GET', url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs,
timeout=120) timeout=120)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to fetch candidate drives for storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % ( msg="Failed to fetch candidate drives for storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (
pool_id, self.ssid, str(err))) pool_id, self.ssid, to_native(err)))
current_drive_count = len(self.sp_drives) current_drive_count = len(self.sp_drives)
current_capacity_bytes = int(self.pool_detail['totalRaidedSpace']) # TODO: is this the right attribute to use? current_capacity_bytes = int(self.pool_detail['totalRaidedSpace']) # TODO: is this the right attribute to use?
@ -649,14 +640,12 @@ class NetAppESeriesStoragePool(object):
self.pool_detail['id']), self.pool_detail['id']),
data=json.dumps(sp_expand_req), headers=self.post_headers, method='POST', url_username=self.api_usr, data=json.dumps(sp_expand_req), headers=self.post_headers, method='POST', url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120) url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to add drives to storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id, msg="Failed to add drives to storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id,
self.ssid, self.ssid,
str( to_native(err)))
err)))
# TODO: check response # TODO: check response
# TODO: support blocking wait? # TODO: support blocking wait?
@ -675,12 +664,11 @@ class NetAppESeriesStoragePool(object):
self.pool_detail['id']), self.pool_detail['id']),
data=json.dumps(drive_list), headers=self.post_headers, method='POST', url_username=self.api_usr, data=json.dumps(drive_list), headers=self.post_headers, method='POST', url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120) url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to remove drives from storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % ( msg="Failed to remove drives from storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (
pool_id, self.ssid, str(err))) pool_id, self.ssid, to_native(err)))
def update_reserve_drive_count(self, qty): def update_reserve_drive_count(self, qty):
data = dict(reservedDriveCount=qty) data = dict(reservedDriveCount=qty)
@ -689,14 +677,12 @@ class NetAppESeriesStoragePool(object):
self.api_url + "/storage-systems/%s/storage-pools/%s" % (self.ssid, self.pool_detail['id']), self.api_url + "/storage-systems/%s/storage-pools/%s" % (self.ssid, self.pool_detail['id']),
data=json.dumps(data), headers=self.post_headers, method='POST', url_username=self.api_usr, data=json.dumps(data), headers=self.post_headers, method='POST', url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120) url_password=self.api_pwd, validate_certs=self.validate_certs, timeout=120)
except: except Exception as err:
err = get_exception()
pool_id = self.pool_detail['id'] pool_id = self.pool_detail['id']
self.module.exit_json( self.module.exit_json(
msg="Failed to update reserve drive count. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id, msg="Failed to update reserve drive count. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id,
self.ssid, self.ssid,
str( to_native(err)))
err)))
def apply(self): def apply(self):
changed = False changed = False
@ -777,11 +763,10 @@ class NetAppESeriesStoragePool(object):
data=json.dumps(secure_pool_data), headers=self.post_headers, method='POST', data=json.dumps(secure_pool_data), headers=self.post_headers, method='POST',
url_username=self.api_usr, url_password=self.api_pwd, url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs, timeout=120, ignore_errors=True) validate_certs=self.validate_certs, timeout=120, ignore_errors=True)
except: except Exception as err:
err = get_exception()
self.module.exit_json( self.module.exit_json(
msg="Failed to delete storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % ( msg="Failed to delete storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (
pool_id, self.ssid, str(err))) pool_id, self.ssid, to_native(err)))
if int(retc) == 422: if int(retc) == 422:
self.module.fail_json( self.module.fail_json(
@ -799,12 +784,11 @@ class NetAppESeriesStoragePool(object):
method='DELETE', method='DELETE',
url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs, url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs,
timeout=120) timeout=120)
except: except Exception as err:
err = get_exception()
self.module.exit_json( self.module.exit_json(
msg="Failed to delete storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id, msg="Failed to delete storage pool. Pool id [%s]. Array id [%s]. Error[%s]." % (pool_id,
self.ssid, self.ssid,
str(err))) to_native(err)))
self.module.exit_json(changed=changed, **self.pool_detail) self.module.exit_json(changed=changed, **self.pool_detail)
@ -813,9 +797,8 @@ def main():
sp = NetAppESeriesStoragePool() sp = NetAppESeriesStoragePool()
try: try:
sp.apply() sp.apply()
except Exception: except Exception as e:
e = get_exception() sp.debug("Exception in apply(): \n%s", format_exc())
sp.debug("Exception in apply(): \n%s", format_exc(e))
raise raise

View file

@ -117,7 +117,7 @@ from traceback import format_exc
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.netapp import request, eseries_host_argument_spec from ansible.module_utils.netapp import request, eseries_host_argument_spec
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
HEADERS = { HEADERS = {
"Content-Type": "application/json", "Content-Type": "application/json",
@ -217,21 +217,19 @@ class NetAppESeriesVolume(object):
(rc, volumes) = request(self.api_url + "/storage-systems/%s/volumes" % (self.ssid), (rc, volumes) = request(self.api_url + "/storage-systems/%s/volumes" % (self.ssid),
headers=dict(Accept="application/json"), url_username=self.api_usr, headers=dict(Accept="application/json"), url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs) url_password=self.api_pwd, validate_certs=self.validate_certs)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to obtain list of standard/thick volumes. Array Id [%s]. Error[%s]." % (self.ssid, msg="Failed to obtain list of standard/thick volumes. Array Id [%s]. Error[%s]." % (self.ssid,
str(err))) to_native(err)))
try: try:
self.debug('fetching thin-volumes') self.debug('fetching thin-volumes')
(rc, thinvols) = request(self.api_url + "/storage-systems/%s/thin-volumes" % (self.ssid), (rc, thinvols) = request(self.api_url + "/storage-systems/%s/thin-volumes" % (self.ssid),
headers=dict(Accept="application/json"), url_username=self.api_usr, headers=dict(Accept="application/json"), url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs) url_password=self.api_pwd, validate_certs=self.validate_certs)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to obtain list of thin volumes. Array Id [%s]. Error[%s]." % (self.ssid, str(err))) msg="Failed to obtain list of thin volumes. Array Id [%s]. Error[%s]." % (self.ssid, to_native(err)))
volumes.extend(thinvols) volumes.extend(thinvols)
@ -252,10 +250,9 @@ class NetAppESeriesVolume(object):
(rc, resp) = request(self.api_url + "/storage-systems/%s/storage-pools" % (self.ssid), (rc, resp) = request(self.api_url + "/storage-systems/%s/storage-pools" % (self.ssid),
headers=dict(Accept="application/json"), url_username=self.api_usr, headers=dict(Accept="application/json"), url_username=self.api_usr,
url_password=self.api_pwd, validate_certs=self.validate_certs) url_password=self.api_pwd, validate_certs=self.validate_certs)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to obtain list of storage pools. Array Id [%s]. Error[%s]." % (self.ssid, str(err))) msg="Failed to obtain list of storage pools. Array Id [%s]. Error[%s]." % (self.ssid, to_native(err)))
self.debug("searching for storage pool '%s'", storage_pool_name) self.debug("searching for storage pool '%s'", storage_pool_name)
pool_detail = next(ifilter(lambda a: a['name'] == storage_pool_name, resp), None) pool_detail = next(ifilter(lambda a: a['name'] == storage_pool_name, resp), None)
@ -284,11 +281,10 @@ class NetAppESeriesVolume(object):
url_username=self.api_usr, url_password=self.api_pwd, url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs, validate_certs=self.validate_certs,
timeout=120) timeout=120)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to create volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, self.ssid, msg="Failed to create volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, self.ssid,
str(err))) to_native(err)))
def create_thin_volume(self, pool_id, name, size_unit, size, thin_volume_repo_size, def create_thin_volume(self, pool_id, name, size_unit, size, thin_volume_repo_size,
thin_volume_max_repo_size, data_assurance_enabled): thin_volume_max_repo_size, data_assurance_enabled):
@ -309,12 +305,11 @@ class NetAppESeriesVolume(object):
url_username=self.api_usr, url_password=self.api_pwd, url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs, validate_certs=self.validate_certs,
timeout=120) timeout=120)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to create thin volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, msg="Failed to create thin volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name,
self.ssid, self.ssid,
str(err))) to_native(err)))
def delete_volume(self): def delete_volume(self):
# delete the volume # delete the volume
@ -325,11 +320,10 @@ class NetAppESeriesVolume(object):
self.volume_detail['id']), self.volume_detail['id']),
method='DELETE', url_username=self.api_usr, url_password=self.api_pwd, method='DELETE', url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs, timeout=120) validate_certs=self.validate_certs, timeout=120)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to delete volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, self.ssid, msg="Failed to delete volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, self.ssid,
str(err))) to_native(err)))
@property @property
def volume_resource_name(self): def volume_resource_name(self):
@ -366,12 +360,11 @@ class NetAppESeriesVolume(object):
data=json.dumps(update_volume_req), headers=HEADERS, method='POST', data=json.dumps(update_volume_req), headers=HEADERS, method='POST',
url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs, url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs,
timeout=120) timeout=120)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to update volume properties. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, msg="Failed to update volume properties. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name,
self.ssid, self.ssid,
str(err))) to_native(err)))
@property @property
def volume_needs_expansion(self): def volume_needs_expansion(self):
@ -399,12 +392,11 @@ class NetAppESeriesVolume(object):
data=json.dumps(thin_volume_expand_req), headers=HEADERS, method='POST', data=json.dumps(thin_volume_expand_req), headers=HEADERS, method='POST',
url_username=self.api_usr, url_password=self.api_pwd, url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs, timeout=120) validate_certs=self.validate_certs, timeout=120)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to expand thin volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, msg="Failed to expand thin volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name,
self.ssid, self.ssid,
str(err))) to_native(err)))
# TODO: check return code # TODO: check return code
else: else:
@ -420,12 +412,11 @@ class NetAppESeriesVolume(object):
data=json.dumps(volume_expand_req), headers=HEADERS, method='POST', data=json.dumps(volume_expand_req), headers=HEADERS, method='POST',
url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs, url_username=self.api_usr, url_password=self.api_pwd, validate_certs=self.validate_certs,
timeout=120) timeout=120)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to expand volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name, msg="Failed to expand volume. Volume [%s]. Array Id [%s]. Error[%s]." % (self.name,
self.ssid, self.ssid,
str(err))) to_native(err)))
self.debug('polling for completion...') self.debug('polling for completion...')
@ -436,11 +427,10 @@ class NetAppESeriesVolume(object):
'id']), 'id']),
method='GET', url_username=self.api_usr, url_password=self.api_pwd, method='GET', url_username=self.api_usr, url_password=self.api_pwd,
validate_certs=self.validate_certs) validate_certs=self.validate_certs)
except Exception: except Exception as err:
err = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Failed to get volume expansion progress. Volume [%s]. Array Id [%s]. Error[%s]." % ( msg="Failed to get volume expansion progress. Volume [%s]. Array Id [%s]. Error[%s]." % (
self.name, self.ssid, str(err))) self.name, self.ssid, to_native(err)))
action = resp['action'] action = resp['action']
percent_complete = resp['percentComplete'] percent_complete = resp['percentComplete']
@ -538,10 +528,9 @@ def main():
try: try:
v.apply() v.apply()
except Exception: except Exception as e:
e = get_exception() v.debug("Exception in apply(): \n%s", format_exc())
v.debug("Exception in apply(): \n%s", format_exc(e)) v.module.fail_json(msg="Module failed. Error [%s]." % to_native(e))
v.module.fail_json(msg="Module failed. Error [%s]." % (str(e)))
if __name__ == '__main__': if __name__ == '__main__':

View file

@ -98,7 +98,7 @@ msg:
import json import json
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.netapp import request from ansible.module_utils.netapp import request
HEADERS = { HEADERS = {
@ -284,9 +284,8 @@ def main():
if params['search_volume_id'] is not None: if params['search_volume_id'] is not None:
try: try:
potential_targets, potential_sources = find_valid_copy_pair_targets_and_sources(params) potential_targets, potential_sources = find_valid_copy_pair_targets_and_sources(params)
except: except Exception as e:
e = get_exception() module.fail_json(msg="Failed to find valid copy pair candidates. Error [%s]" % to_native(e))
module.fail_json(msg="Failed to find valid copy pair candidates. Error [%s]" % str(e))
module.exit_json(changed=False, module.exit_json(changed=False,
msg=' Valid source devices found: %s Valid target devices found: %s' % (len(potential_sources), len(potential_targets)), msg=' Valid source devices found: %s Valid target devices found: %s' % (len(potential_sources), len(potential_targets)),

View file

@ -138,7 +138,7 @@ msg:
""" """
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
import ansible.module_utils.netapp as netapp_utils import ansible.module_utils.netapp as netapp_utils
HAS_SF_SDK = netapp_utils.has_sf_sdk() HAS_SF_SDK = netapp_utils.has_sf_sdk()
@ -230,19 +230,17 @@ class SolidFireVolume(object):
qos=self.qos, qos=self.qos,
attributes=self.attributes) attributes=self.attributes)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Error provisioning volume %s of size %s" % (self.name, self.size), self.module.fail_json(msg="Error provisioning volume %s of size %s" % (self.name, self.size),
exception=str(err)) exception=to_native(err))
def delete_volume(self): def delete_volume(self):
try: try:
self.sfe.delete_volume(volume_id=self.volume_id) self.sfe.delete_volume(volume_id=self.volume_id)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Error deleting volume %s" % self.volume_id, self.module.fail_json(msg="Error deleting volume %s" % self.volume_id,
exception=str(err)) exception=to_native(err))
def update_volume(self): def update_volume(self):
try: try:
@ -253,10 +251,9 @@ class SolidFireVolume(object):
total_size=self.size, total_size=self.size,
attributes=self.attributes) attributes=self.attributes)
except: except Exception as err:
err = get_exception()
self.module.fail_json(msg="Error updating volume %s" % self.name, self.module.fail_json(msg="Error updating volume %s" % self.name,
exception=str(err)) exception=to_native(err))
def apply(self): def apply(self):
changed = False changed = False
@ -326,5 +323,6 @@ def main():
v = SolidFireVolume() v = SolidFireVolume()
v.apply() v.apply()
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -81,7 +81,7 @@ import tempfile
import errno import errno
import re import re
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
@ -132,8 +132,7 @@ def enforce_state(module, params):
if replace_or_add or found != (state == "present"): if replace_or_add or found != (state == "present"):
try: try:
inf = open(path, "r") inf = open(path, "r")
except IOError: except IOError as e:
e = get_exception()
if e.errno == errno.ENOENT: if e.errno == errno.ENOENT:
inf = None inf = None
else: else:
@ -150,9 +149,8 @@ def enforce_state(module, params):
outf.write(key) outf.write(key)
outf.flush() outf.flush()
module.atomic_move(outf.name, path) module.atomic_move(outf.name, path)
except (IOError, OSError): except (IOError, OSError) as e:
e = get_exception() module.fail_json(msg="Failed to write to file %s: %s" % (path, to_native(e)))
module.fail_json(msg="Failed to write to file %s: %s" % (path, str(e)))
try: try:
outf.close() outf.close()
@ -185,10 +183,9 @@ def sanity_check(module, host, key, sshkeygen):
outf = tempfile.NamedTemporaryFile(mode='w+') outf = tempfile.NamedTemporaryFile(mode='w+')
outf.write(key) outf.write(key)
outf.flush() outf.flush()
except IOError: except IOError as e:
e = get_exception()
module.fail_json(msg="Failed to write to temporary file %s: %s" % module.fail_json(msg="Failed to write to temporary file %s: %s" %
(outf.name, str(e))) (outf.name, to_native(e)))
sshkeygen_command = [sshkeygen, '-F', host, '-f', outf.name] sshkeygen_command = [sshkeygen, '-F', host, '-f', outf.name]
rc, stdout, stderr = module.run_command(sshkeygen_command, check_rc=True) rc, stdout, stderr = module.run_command(sshkeygen_command, check_rc=True)
@ -299,8 +296,7 @@ def compute_diff(path, found_line, replace_or_add, state, key):
} }
try: try:
inf = open(path, "r") inf = open(path, "r")
except IOError: except IOError as e:
e = get_exception()
if e.errno == errno.ENOENT: if e.errno == errno.ENOENT:
diff['before_header'] = '/dev/null' diff['before_header'] = '/dev/null'
else: else:
@ -331,5 +327,6 @@ def main():
results = enforce_state(module, module.params) results = enforce_state(module, module.params)
module.exit_json(**results) module.exit_json(**results)
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -43,7 +43,6 @@ import re
from subprocess import Popen, PIPE, call from subprocess import Popen, PIPE, call
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
from ansible.module_utils._text import to_native from ansible.module_utils._text import to_native
LOCALE_NORMALIZATION = { LOCALE_NORMALIZATION = {
@ -228,9 +227,8 @@ def main():
apply_change(state, name) apply_change(state, name)
else: else:
apply_change_ubuntu(state, name) apply_change_ubuntu(state, name)
except EnvironmentError: except EnvironmentError as e:
e = get_exception() module.fail_json(msg=to_native(e), exitValue=e.errno)
module.fail_json(msg=e.strerror, exitValue=e.errno)
module.exit_json(name=name, changed=changed, msg="OK") module.exit_json(name=name, changed=changed, msg="OK")

View file

@ -128,7 +128,6 @@ import os
from ansible.module_utils.basic import AnsibleModule, get_platform from ansible.module_utils.basic import AnsibleModule, get_platform
from ansible.module_utils.ismount import ismount from ansible.module_utils.ismount import ismount
from ansible.module_utils.pycompat24 import get_exception
from ansible.module_utils.six import iteritems from ansible.module_utils.six import iteritems
from ansible.module_utils._text import to_native from ansible.module_utils._text import to_native
@ -653,9 +652,8 @@ def main():
if os.path.exists(name): if os.path.exists(name):
try: try:
os.rmdir(name) os.rmdir(name)
except (OSError, IOError): except (OSError, IOError) as e:
e = get_exception() module.fail_json(msg="Error rmdir %s: %s" % (name, to_native(e)))
module.fail_json(msg="Error rmdir %s: %s" % (name, str(e)))
elif state == 'unmounted': elif state == 'unmounted':
if ismount(name) or is_bind_mounted(module, linux_mounts, name): if ismount(name) or is_bind_mounted(module, linux_mounts, name):
if not module.check_mode: if not module.check_mode:
@ -670,10 +668,9 @@ def main():
if not os.path.exists(name) and not module.check_mode: if not os.path.exists(name) and not module.check_mode:
try: try:
os.makedirs(name) os.makedirs(name)
except (OSError, IOError): except (OSError, IOError) as e:
e = get_exception()
module.fail_json( module.fail_json(
msg="Error making dir %s: %s" % (name, str(e))) msg="Error making dir %s: %s" % (name, to_native(e)))
name, changed = set_mount(module, args) name, changed = set_mount(module, args)
res = 0 res = 0

View file

@ -255,7 +255,7 @@ dest:
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception from ansible.module_utils._text import to_native
import os import os
import re import re
import time import time
@ -360,11 +360,10 @@ class PamdService(object):
stringline += '\n' stringline += '\n'
self.load_rules_from_string(stringline.replace("\\\n", "")) self.load_rules_from_string(stringline.replace("\\\n", ""))
except IOError: except IOError as e:
e = get_exception()
self.ansible.fail_json(msg='Unable to open/read PAM module \ self.ansible.fail_json(msg='Unable to open/read PAM module \
file %s with error %s. And line %s' % file %s with error %s. And line %s' %
(self.fname, str(e), stringline)) (self.fname, to_native(e), stringline))
def load_rules_from_string(self, stringvalue): def load_rules_from_string(self, stringvalue):
for line in stringvalue.splitlines(): for line in stringvalue.splitlines():
@ -687,5 +686,6 @@ def main():
module.exit_json(changed=change, ansible_facts=facts) module.exit_json(changed=change, ansible_facts=facts)
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -229,7 +229,6 @@ import time
from ansible.module_utils._text import to_native from ansible.module_utils._text import to_native
from ansible.module_utils.basic import load_platform_subclass, AnsibleModule from ansible.module_utils.basic import load_platform_subclass, AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
try: try:
import spwd import spwd
@ -298,9 +297,8 @@ class User(object):
if module.params['expires']: if module.params['expires']:
try: try:
self.expires = time.gmtime(module.params['expires']) self.expires = time.gmtime(module.params['expires'])
except Exception: except Exception as e:
e = get_exception() module.fail_json(msg="Invalid expires time %s: %s" % (self.expires, to_native(e)))
module.fail_json(msg="Invalid expires time %s: %s" % (self.expires, e))
if module.params['ssh_key_file'] is not None: if module.params['ssh_key_file'] is not None:
self.ssh_file = module.params['ssh_key_file'] self.ssh_file = module.params['ssh_key_file']
@ -637,9 +635,8 @@ class User(object):
try: try:
os.mkdir(ssh_dir, int('0700', 8)) os.mkdir(ssh_dir, int('0700', 8))
os.chown(ssh_dir, info[2], info[3]) os.chown(ssh_dir, info[2], info[3])
except OSError: except OSError as e:
e = get_exception() return (1, '', 'Failed to create %s: %s' % (ssh_dir, to_native(e)))
return (1, '', 'Failed to create %s: %s' % (ssh_dir, str(e)))
if os.path.exists(ssh_key_file): if os.path.exists(ssh_key_file):
return (None, 'Key already exists', '') return (None, 'Key already exists', '')
cmd = [self.module.get_bin_path('ssh-keygen', True)] cmd = [self.module.get_bin_path('ssh-keygen', True)]
@ -709,15 +706,13 @@ class User(object):
if os.path.exists(skeleton): if os.path.exists(skeleton):
try: try:
shutil.copytree(skeleton, path, symlinks=True) shutil.copytree(skeleton, path, symlinks=True)
except OSError: except OSError as e:
e = get_exception() self.module.exit_json(failed=True, msg="%s" % to_native(e))
self.module.exit_json(failed=True, msg="%s" % e)
else: else:
try: try:
os.makedirs(path) os.makedirs(path)
except OSError: except OSError as e:
e = get_exception() self.module.exit_json(failed=True, msg="%s" % to_native(e))
self.module.exit_json(failed=True, msg="%s" % e)
def chown_homedir(self, uid, gid, path): def chown_homedir(self, uid, gid, path):
try: try:
@ -727,9 +722,8 @@ class User(object):
os.chown(os.path.join(root, d), uid, gid) os.chown(os.path.join(root, d), uid, gid)
for f in files: for f in files:
os.chown(os.path.join(root, f), uid, gid) os.chown(os.path.join(root, f), uid, gid)
except OSError: except OSError as e:
e = get_exception() self.module.exit_json(failed=True, msg="%s" % to_native(e))
self.module.exit_json(failed=True, msg="%s" % e)
# =========================================== # ===========================================
@ -1289,9 +1283,8 @@ class SunOS(User):
maxweeks = value.rstrip('\n') maxweeks = value.rstrip('\n')
elif key == "WARNWEEKS": elif key == "WARNWEEKS":
warnweeks = value.rstrip('\n') warnweeks = value.rstrip('\n')
except Exception: except Exception as err:
err = get_exception() self.module.fail_json(msg="failed to read /etc/default/passwd: %s" % to_native(err))
self.module.fail_json(msg="failed to read /etc/default/passwd: %s" % str(err))
return (minweeks, maxweeks, warnweeks) return (minweeks, maxweeks, warnweeks)
@ -1372,9 +1365,8 @@ class SunOS(User):
line = ':'.join(fields) line = ':'.join(fields)
lines.append('%s\n' % line) lines.append('%s\n' % line)
open(self.SHADOWFILE, 'w+').writelines(lines) open(self.SHADOWFILE, 'w+').writelines(lines)
except Exception: except Exception as err:
err = get_exception() self.module.fail_json(msg="failed to update users password: %s" % to_native(err))
self.module.fail_json(msg="failed to update users password: %s" % str(err))
return (rc, out, err) return (rc, out, err)
@ -1468,9 +1460,8 @@ class SunOS(User):
lines.append('%s\n' % line) lines.append('%s\n' % line)
open(self.SHADOWFILE, 'w+').writelines(lines) open(self.SHADOWFILE, 'w+').writelines(lines)
rc = 0 rc = 0
except Exception: except Exception as err:
err = get_exception() self.module.fail_json(msg="failed to update users password: %s" % to_native(err))
self.module.fail_json(msg="failed to update users password: %s" % str(err))
return (rc, out, err) return (rc, out, err)

View file

@ -96,7 +96,8 @@ EXAMPLES = """
import os import os
import tempfile import tempfile
from distutils.version import LooseVersion from distutils.version import LooseVersion
from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils._text import to_native
try: try:
from passlib.apache import HtpasswdFile, htpasswd_context from passlib.apache import HtpasswdFile, htpasswd_context
from passlib.context import CryptContext from passlib.context import CryptContext
@ -262,14 +263,9 @@ def main():
check_file_attrs(module, changed, msg) check_file_attrs(module, changed, msg)
module.exit_json(msg=msg, changed=changed) module.exit_json(msg=msg, changed=changed)
except Exception: except Exception as e:
e = get_exception() module.fail_json(msg=to_native(e))
module.fail_json(msg=str(e))
# import module snippets
from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
if __name__ == '__main__': if __name__ == '__main__':
main() main()

View file

@ -276,7 +276,6 @@ state:
''' '''
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
from ansible.module_utils.six.moves.urllib.parse import urlencode from ansible.module_utils.six.moves.urllib.parse import urlencode
from ansible.module_utils.urls import fetch_url, url_argument_spec from ansible.module_utils.urls import fetch_url, url_argument_spec
from ansible.module_utils._text import to_native from ansible.module_utils._text import to_native
@ -325,8 +324,7 @@ class JenkinsPlugin(object):
# Parse the JSON data # Parse the JSON data
try: try:
json_data = json.loads(to_native(r.read())) json_data = json.loads(to_native(r.read()))
except Exception: except Exception as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot parse %s JSON data." % what, msg="Cannot parse %s JSON data." % what,
details=to_native(e)) details=to_native(e))
@ -350,8 +348,7 @@ class JenkinsPlugin(object):
if info['status'] != 200: if info['status'] != 200:
self.module.fail_json(msg=msg_status, details=info['msg']) self.module.fail_json(msg=msg_status, details=info['msg'])
except Exception: except Exception as e:
e = get_exception()
self.module.fail_json(msg=msg_exception, details=to_native(e)) self.module.fail_json(msg=msg_exception, details=to_native(e))
return response return response
@ -500,11 +497,10 @@ class JenkinsPlugin(object):
try: try:
sha1_old = hashlib.sha1(open(plugin_file, 'rb').read()) sha1_old = hashlib.sha1(open(plugin_file, 'rb').read())
except Exception: except Exception as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot calculate SHA1 of the old plugin.", msg="Cannot calculate SHA1 of the old plugin.",
details=e.message) details=to_native(e))
sha1sum_old = base64.b64encode(sha1_old.digest()) sha1sum_old = base64.b64encode(sha1_old.digest())
@ -567,8 +563,7 @@ class JenkinsPlugin(object):
try: try:
os.close(update_fd) os.close(update_fd)
except IOError: except IOError as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot close the tmp updates file %s." % updates_file, msg="Cannot close the tmp updates file %s." % updates_file,
details=to_native(e)) details=to_native(e))
@ -576,8 +571,7 @@ class JenkinsPlugin(object):
# Open the updates file # Open the updates file
try: try:
f = open(updates_file) f = open(updates_file)
except IOError: except IOError as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot open temporal updates file.", msg="Cannot open temporal updates file.",
details=to_native(e)) details=to_native(e))
@ -588,11 +582,10 @@ class JenkinsPlugin(object):
if i == 1: if i == 1:
try: try:
data = json.loads(line) data = json.loads(line)
except Exception: except Exception as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot load JSON data from the tmp updates file.", msg="Cannot load JSON data from the tmp updates file.",
details=e.message) details=to_native(e))
break break
@ -604,11 +597,10 @@ class JenkinsPlugin(object):
if not os.path.isdir(updates_dir): if not os.path.isdir(updates_dir):
try: try:
os.makedirs(updates_dir, int('0700', 8)) os.makedirs(updates_dir, int('0700', 8))
except OSError: except OSError as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg="Cannot create temporal directory.", msg="Cannot create temporal directory.",
details=e.message) details=to_native(e))
self.module.atomic_move(updates_file, updates_file_orig) self.module.atomic_move(updates_file, updates_file_orig)
@ -639,8 +631,7 @@ class JenkinsPlugin(object):
try: try:
os.close(tmp_f_fd) os.close(tmp_f_fd)
except IOError: except IOError as e:
e = get_exception()
self.module.fail_json( self.module.fail_json(
msg='Cannot close the temporal plugin file %s.' % tmp_f, msg='Cannot close the temporal plugin file %s.' % tmp_f,
details=to_native(e)) details=to_native(e))
@ -766,8 +757,7 @@ def main():
# Convert timeout to float # Convert timeout to float
try: try:
module.params['timeout'] = float(module.params['timeout']) module.params['timeout'] = float(module.params['timeout'])
except ValueError: except ValueError as e:
e = get_exception()
module.fail_json( module.fail_json(
msg='Cannot convert %s to float.' % module.params['timeout'], msg='Cannot convert %s to float.' % module.params['timeout'],
details=to_native(e)) details=to_native(e))

View file

@ -117,7 +117,8 @@ EXAMPLES = '''
RETURN = '''# ''' RETURN = '''# '''
from os import getenv from os import getenv
from os.path import isfile from os.path import isfile
from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils._text import to_native
try: try:
from taiga import TaigaAPI from taiga import TaigaAPI
from taiga.exceptions import TaigaException from taiga.exceptions import TaigaException
@ -235,9 +236,8 @@ def manage_issue(module, taiga_host, project_name, issue_subject, issue_priority
# More than 1 matching issue # More than 1 matching issue
return (False, changed, "More than one issue with subject %s in project %s" % (issue_subject, project_name), {}) return (False, changed, "More than one issue with subject %s in project %s" % (issue_subject, project_name), {})
except TaigaException: except TaigaException as exc:
exc = get_exception() msg = "An exception happened: %s" % to_native(exc)
msg = "An exception happened: %s" % exc
return (False, changed, msg, {}) return (False, changed, msg, {})
@ -307,8 +307,5 @@ def main():
module.fail_json(msg=msg) module.fail_json(msg=msg)
from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.pycompat24 import get_exception
if __name__ == '__main__': if __name__ == '__main__':
main() main()