2015-08-24 19:58:42 +02:00
|
|
|
#!/usr/bin/python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
# (c) 2015, Joseph Callen <jcallen () csc.com>
|
|
|
|
#
|
|
|
|
# This file is part of Ansible
|
|
|
|
#
|
|
|
|
# Ansible is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# Ansible is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
DOCUMENTATION = '''
|
|
|
|
---
|
|
|
|
module: vmware_portgroup
|
|
|
|
short_description: Create a VMware portgroup
|
|
|
|
description:
|
|
|
|
- Create a VMware portgroup
|
|
|
|
version_added: 2.0
|
|
|
|
author: "Joseph Callen (@jcpowermac), Russell Teague (@mtnbikenc)"
|
|
|
|
notes:
|
|
|
|
- Tested on vSphere 5.5
|
|
|
|
requirements:
|
|
|
|
- "python >= 2.6"
|
|
|
|
- PyVmomi
|
|
|
|
options:
|
|
|
|
switch_name:
|
|
|
|
description:
|
|
|
|
- vSwitch to modify
|
|
|
|
required: True
|
|
|
|
portgroup_name:
|
|
|
|
description:
|
|
|
|
- Portgroup name to add
|
|
|
|
required: True
|
|
|
|
vlan_id:
|
|
|
|
description:
|
|
|
|
- VLAN ID to assign to portgroup
|
|
|
|
required: True
|
2016-07-03 10:49:42 +02:00
|
|
|
network_policy:
|
|
|
|
description:
|
|
|
|
- Network policy specifies layer 2 security settings for a
|
|
|
|
portgroup such as promiscuous mode, where guest adapter listens
|
|
|
|
to all the packets, MAC address changes and forged transmits.
|
|
|
|
Settings are promiscuous_mode, forged_transmits, mac_changes
|
|
|
|
required: False
|
|
|
|
version_added: "2.2"
|
2016-01-12 18:00:22 +01:00
|
|
|
extends_documentation_fragment: vmware.documentation
|
2015-08-24 19:58:42 +02:00
|
|
|
'''
|
|
|
|
|
|
|
|
EXAMPLES = '''
|
|
|
|
Example from Ansible playbook
|
|
|
|
|
|
|
|
- name: Add Management Network VM Portgroup
|
|
|
|
local_action:
|
|
|
|
module: vmware_portgroup
|
|
|
|
hostname: esxi_hostname
|
|
|
|
username: esxi_username
|
|
|
|
password: esxi_password
|
|
|
|
switch_name: vswitch_name
|
|
|
|
portgroup_name: portgroup_name
|
|
|
|
vlan_id: vlan_id
|
2016-07-03 10:49:42 +02:00
|
|
|
|
|
|
|
- name: Add Portgroup with Promiscuous Mode Enabled
|
|
|
|
local_action:
|
|
|
|
module: vmware_portgroup
|
|
|
|
hostname: esxi_hostname
|
|
|
|
username: esxi_username
|
|
|
|
password: esxi_password
|
|
|
|
switch_name: vswitch_name
|
|
|
|
portgroup_name: portgroup_name
|
|
|
|
network_policy:
|
|
|
|
promiscuous_mode: True
|
2015-08-24 19:58:42 +02:00
|
|
|
'''
|
|
|
|
|
|
|
|
try:
|
|
|
|
from pyVmomi import vim, vmodl
|
|
|
|
HAS_PYVMOMI = True
|
|
|
|
except ImportError:
|
|
|
|
HAS_PYVMOMI = False
|
|
|
|
|
|
|
|
|
2016-07-03 10:49:42 +02:00
|
|
|
def create_network_policy(promiscuous_mode, forged_transmits, mac_changes):
|
|
|
|
|
|
|
|
security_policy = vim.host.NetworkPolicy.SecurityPolicy()
|
|
|
|
if promiscuous_mode:
|
|
|
|
security_policy.allowPromiscuous = promiscuous_mode
|
|
|
|
if forged_transmits:
|
|
|
|
security_policy.forgedTransmits = forged_transmits
|
|
|
|
if mac_changes:
|
|
|
|
security_policy.macChanges = mac_changes
|
|
|
|
network_policy = vim.host.NetworkPolicy(security=security_policy)
|
|
|
|
return network_policy
|
|
|
|
|
|
|
|
|
|
|
|
def create_port_group(host_system, portgroup_name, vlan_id, vswitch_name, network_policy):
|
2015-08-24 19:58:42 +02:00
|
|
|
|
|
|
|
config = vim.host.NetworkConfig()
|
|
|
|
config.portgroup = [vim.host.PortGroup.Config()]
|
|
|
|
config.portgroup[0].changeOperation = "add"
|
|
|
|
config.portgroup[0].spec = vim.host.PortGroup.Specification()
|
|
|
|
config.portgroup[0].spec.name = portgroup_name
|
|
|
|
config.portgroup[0].spec.vlanId = vlan_id
|
|
|
|
config.portgroup[0].spec.vswitchName = vswitch_name
|
2016-07-03 10:49:42 +02:00
|
|
|
config.portgroup[0].spec.policy = network_policy
|
2015-08-24 19:58:42 +02:00
|
|
|
|
|
|
|
host_network_config_result = host_system.configManager.networkSystem.UpdateNetworkConfig(config, "modify")
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
|
|
|
|
argument_spec = vmware_argument_spec()
|
|
|
|
argument_spec.update(dict(portgroup_name=dict(required=True, type='str'),
|
|
|
|
switch_name=dict(required=True, type='str'),
|
2016-07-03 10:49:42 +02:00
|
|
|
vlan_id=dict(required=True, type='int'),
|
|
|
|
network_policy=dict(required=False, type='dict', default={})))
|
2015-08-24 19:58:42 +02:00
|
|
|
|
|
|
|
module = AnsibleModule(argument_spec=argument_spec, supports_check_mode=False)
|
|
|
|
|
|
|
|
if not HAS_PYVMOMI:
|
|
|
|
module.fail_json(msg='pyvmomi is required for this module')
|
|
|
|
|
|
|
|
portgroup_name = module.params['portgroup_name']
|
|
|
|
switch_name = module.params['switch_name']
|
|
|
|
vlan_id = module.params['vlan_id']
|
2016-07-03 10:49:42 +02:00
|
|
|
promiscuous_mode = module.params['network_policy'].get('promiscuous_mode', None)
|
|
|
|
forged_transmits = module.params['network_policy'].get('forged_transmits', None)
|
|
|
|
mac_changes = module.params['network_policy'].get('mac_changes', None)
|
2015-08-24 19:58:42 +02:00
|
|
|
|
|
|
|
try:
|
|
|
|
content = connect_to_api(module)
|
|
|
|
host = get_all_objs(content, [vim.HostSystem])
|
|
|
|
if not host:
|
|
|
|
raise SystemExit("Unable to locate Physical Host.")
|
|
|
|
host_system = host.keys()[0]
|
|
|
|
|
2016-03-18 01:00:00 +01:00
|
|
|
if find_host_portgroup_by_name(host_system, portgroup_name):
|
|
|
|
module.exit_json(changed=False)
|
|
|
|
|
2016-07-03 10:49:42 +02:00
|
|
|
network_policy = create_network_policy(promiscuous_mode, forged_transmits, mac_changes)
|
|
|
|
changed = create_port_group(host_system, portgroup_name, vlan_id, switch_name, network_policy)
|
2015-08-24 19:58:42 +02:00
|
|
|
|
|
|
|
module.exit_json(changed=changed)
|
|
|
|
except vmodl.RuntimeFault as runtime_fault:
|
|
|
|
module.fail_json(msg=runtime_fault.msg)
|
|
|
|
except vmodl.MethodFault as method_fault:
|
|
|
|
module.fail_json(msg=method_fault.msg)
|
|
|
|
except Exception as e:
|
|
|
|
module.fail_json(msg=str(e))
|
|
|
|
|
|
|
|
from ansible.module_utils.vmware import *
|
|
|
|
from ansible.module_utils.basic import *
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|