Remove deprecated get_exception API
Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
parent
caefe31125
commit
6bd0fbb63c
42 changed files with 284 additions and 409 deletions
lib/ansible/modules
files
network
aos
eos
fortios
junos
panos
_panos_nat_policy.py_panos_security_policy.pypanos_cert_gen_ssh.pypanos_import.pypanos_interface.pypanos_mgtconfig.pypanos_nat_rule.pypanos_object.pypanos_pg.pypanos_sag.pypanos_security_rule.py
vyos
packaging/os
storage/netapp
netapp_e_host.pynetapp_e_lun_mapping.pynetapp_e_snapshot_group.pynetapp_e_snapshot_images.pynetapp_e_snapshot_volume.pynetapp_e_storage_system.pynetapp_e_storagepool.pynetapp_e_volume.pynetapp_e_volume_copy.pysf_volume_manager.py
system
web_infrastructure
|
@ -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()
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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']
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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__':
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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")
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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']
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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':
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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")
|
||||||
|
|
|
@ -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:
|
||||||
|
|
|
@ -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:
|
||||||
|
|
|
@ -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.")
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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__':
|
||||||
|
|
|
@ -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)),
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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")
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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))
|
||||||
|
|
|
@ -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()
|
||||||
|
|
Loading…
Reference in a new issue