VMware: Refactor vmware_dvs_portgroup (#35193)

Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
Abhijeet Kasurde 2018-01-22 23:45:18 +05:30 committed by ansibot
commit b24d502682

View file

@ -1,7 +1,7 @@
#!/usr/bin/python #!/usr/bin/python
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# Copyright: (c) 2015, Joseph Callen <jcallen () csc.com>
# (c) 2015, Joseph Callen <jcallen () csc.com> # Copyright: (c) 2017-18 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
# #
@ -9,9 +9,11 @@ from __future__ import absolute_import, division, print_function
__metaclass__ = type __metaclass__ = type
ANSIBLE_METADATA = {'metadata_version': '1.1', ANSIBLE_METADATA = {
'metadata_version': '1.1',
'status': ['preview'], 'status': ['preview'],
'supported_by': 'community'} 'supported_by': 'community'
}
DOCUMENTATION = ''' DOCUMENTATION = '''
@ -72,7 +74,7 @@ options:
version_added: '2.5' version_added: '2.5'
network_policy: network_policy:
description: description:
- Dict which configures the different security values for portgroup. - Dictionary which configures the different security values for portgroup.
- 'Valid attributes are:' - 'Valid attributes are:'
- '- C(promiscuous) (bool): indicates whether promiscuous mode is allowed. (default: false)' - '- C(promiscuous) (bool): indicates whether promiscuous mode is allowed. (default: false)'
- '- C(forged_transmits) (bool): indicates whether forged transmits are allowed. (default: false)' - '- C(forged_transmits) (bool): indicates whether forged transmits are allowed. (default: false)'
@ -81,7 +83,7 @@ options:
version_added: '2.5' version_added: '2.5'
port_policy: port_policy:
description: description:
- Dict which configures the advanced policy settings for the portgroup. - Dictionary which configures the advanced policy settings for the portgroup.
- 'Valid attributes are:' - 'Valid attributes are:'
- '- C(block_override) (bool): indicates if the block policy can be changed per port. (default: true)' - '- C(block_override) (bool): indicates if the block policy can be changed per port. (default: true)'
- '- C(ipfix_override) (bool): indicates if the ipfix policy can be changed per port. (default: false)' - '- C(ipfix_override) (bool): indicates if the ipfix policy can be changed per port. (default: false)'
@ -172,18 +174,17 @@ EXAMPLES = '''
try: try:
from pyVmomi import vim, vmodl from pyVmomi import vim, vmodl
HAS_PYVMOMI = True except ImportError as e:
except ImportError: pass
HAS_PYVMOMI = False
from ansible.module_utils.basic import AnsibleModule from ansible.module_utils.basic import AnsibleModule
from ansible.module_utils.vmware import (HAS_PYVMOMI, connect_to_api, find_dvs_by_name, find_dvspg_by_name, from ansible.module_utils.vmware import (PyVmomi, find_dvs_by_name, find_dvspg_by_name,
vmware_argument_spec, wait_for_task) vmware_argument_spec, wait_for_task)
class VMwareDvsPortgroup(object): class VMwareDvsPortgroup(PyVmomi):
def __init__(self, module): def __init__(self, module):
self.module = module super(VMwareDvsPortgroup, self).__init__(module)
self.dvs_portgroup = None self.dvs_portgroup = None
self.switch_name = self.module.params['switch_name'] self.switch_name = self.module.params['switch_name']
self.portgroup_name = self.module.params['portgroup_name'] self.portgroup_name = self.module.params['portgroup_name']
@ -207,10 +208,8 @@ class VMwareDvsPortgroup(object):
self.policy_uplink_teaming_override = self.module.params['port_policy']['uplink_teaming_override'] self.policy_uplink_teaming_override = self.module.params['port_policy']['uplink_teaming_override']
self.policy_vendor_config_override = self.module.params['port_policy']['vendor_config_override'] self.policy_vendor_config_override = self.module.params['port_policy']['vendor_config_override']
self.policy_vlan_override = self.module.params['port_policy']['vlan_override'] self.policy_vlan_override = self.module.params['port_policy']['vlan_override']
self.content = connect_to_api(module)
def process_state(self): def process_state(self):
try:
dvspg_states = { dvspg_states = {
'absent': { 'absent': {
'present': self.state_destroy_dvspg, 'present': self.state_destroy_dvspg,
@ -222,6 +221,7 @@ class VMwareDvsPortgroup(object):
'absent': self.state_create_dvspg, 'absent': self.state_create_dvspg,
} }
} }
try:
dvspg_states[self.state][self.check_dvspg_state()]() dvspg_states[self.state][self.check_dvspg_state()]()
except vmodl.RuntimeFault as runtime_fault: except vmodl.RuntimeFault as runtime_fault:
self.module.fail_json(msg=runtime_fault.msg) self.module.fail_json(msg=runtime_fault.msg)
@ -301,7 +301,7 @@ class VMwareDvsPortgroup(object):
self.dv_switch = find_dvs_by_name(self.content, self.switch_name) self.dv_switch = find_dvs_by_name(self.content, self.switch_name)
if self.dv_switch is None: if self.dv_switch is None:
raise Exception("A distributed virtual switch with name %s does not exist" % self.switch_name) self.module.fail_json(msg="A distributed virtual switch with name %s does not exist" % self.switch_name)
self.dvs_portgroup = find_dvspg_by_name(self.dv_switch, self.portgroup_name) self.dvs_portgroup = find_dvspg_by_name(self.dv_switch, self.portgroup_name)
if self.dvs_portgroup is None: if self.dvs_portgroup is None:
@ -366,10 +366,8 @@ def main():
) )
) )
module = AnsibleModule(argument_spec=argument_spec, supports_check_mode=True) module = AnsibleModule(argument_spec=argument_spec,
supports_check_mode=True)
if not HAS_PYVMOMI:
module.fail_json(msg='pyvmomi is required for this module')
vmware_dvs_portgroup = VMwareDvsPortgroup(module) vmware_dvs_portgroup = VMwareDvsPortgroup(module)
vmware_dvs_portgroup.process_state() vmware_dvs_portgroup.process_state()