|
|
@ -74,7 +74,6 @@ options:
|
|
|
|
description:
|
|
|
|
description:
|
|
|
|
- Set VLAN mode to classical ethernet or fabricpath.
|
|
|
|
- Set VLAN mode to classical ethernet or fabricpath.
|
|
|
|
This is a valid option for Nexus 5000 and 7000 series.
|
|
|
|
This is a valid option for Nexus 5000 and 7000 series.
|
|
|
|
default: ce
|
|
|
|
|
|
|
|
choices: ['ce','fabricpath']
|
|
|
|
choices: ['ce','fabricpath']
|
|
|
|
version_added: "2.4"
|
|
|
|
version_added: "2.4"
|
|
|
|
aggregate:
|
|
|
|
aggregate:
|
|
|
@ -156,8 +155,10 @@ import time
|
|
|
|
from copy import deepcopy
|
|
|
|
from copy import deepcopy
|
|
|
|
|
|
|
|
|
|
|
|
from ansible.module_utils.network.nxos.nxos import get_config, load_config, run_commands
|
|
|
|
from ansible.module_utils.network.nxos.nxos import get_config, load_config, run_commands
|
|
|
|
from ansible.module_utils.network.nxos.nxos import get_capabilities, nxos_argument_spec
|
|
|
|
from ansible.module_utils.network.nxos.nxos import normalize_interface, nxos_argument_spec
|
|
|
|
from ansible.module_utils.basic import AnsibleModule
|
|
|
|
from ansible.module_utils.basic import AnsibleModule
|
|
|
|
|
|
|
|
from ansible.module_utils.connection import ConnectionError
|
|
|
|
|
|
|
|
from ansible.module_utils.network.common.config import CustomNetworkConfig
|
|
|
|
from ansible.module_utils.network.common.utils import remove_default_spec
|
|
|
|
from ansible.module_utils.network.common.utils import remove_default_spec
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -191,7 +192,7 @@ def is_default_name(obj, vlan_id):
|
|
|
|
return False
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def map_obj_to_commands(updates, module, os_platform):
|
|
|
|
def map_obj_to_commands(updates, module):
|
|
|
|
commands = list()
|
|
|
|
commands = list()
|
|
|
|
purge = module.params['purge']
|
|
|
|
purge = module.params['purge']
|
|
|
|
want, have = updates
|
|
|
|
want, have = updates
|
|
|
@ -201,15 +202,11 @@ def map_obj_to_commands(updates, module, os_platform):
|
|
|
|
name = w['name']
|
|
|
|
name = w['name']
|
|
|
|
interfaces = w.get('interfaces') or []
|
|
|
|
interfaces = w.get('interfaces') or []
|
|
|
|
mapped_vni = w['mapped_vni']
|
|
|
|
mapped_vni = w['mapped_vni']
|
|
|
|
|
|
|
|
mode = w['mode']
|
|
|
|
vlan_state = w['vlan_state']
|
|
|
|
vlan_state = w['vlan_state']
|
|
|
|
admin_state = w['admin_state']
|
|
|
|
admin_state = w['admin_state']
|
|
|
|
state = w['state']
|
|
|
|
state = w['state']
|
|
|
|
del w['state']
|
|
|
|
del w['state']
|
|
|
|
if any(i in os_platform for i in ['5K', '7K']):
|
|
|
|
|
|
|
|
mode = w['mode']
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
w['mode'] = None
|
|
|
|
|
|
|
|
mode = w['mode']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
obj_in_have = search_obj_in_list(vlan_id, have)
|
|
|
|
obj_in_have = search_obj_in_list(vlan_id, have)
|
|
|
|
|
|
|
|
|
|
|
@ -258,7 +255,7 @@ def map_obj_to_commands(updates, module, os_platform):
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
if not is_default_name(obj_in_have, vlan_id):
|
|
|
|
if not is_default_name(obj_in_have, vlan_id):
|
|
|
|
commands.append('no name')
|
|
|
|
commands.append('no name')
|
|
|
|
if key == 'vlan_state':
|
|
|
|
if key == 'vlan_state' and value:
|
|
|
|
commands.append('state {0}'.format(value))
|
|
|
|
commands.append('state {0}'.format(value))
|
|
|
|
if key == 'mapped_vni':
|
|
|
|
if key == 'mapped_vni':
|
|
|
|
if value == 'default':
|
|
|
|
if value == 'default':
|
|
|
@ -271,7 +268,7 @@ def map_obj_to_commands(updates, module, os_platform):
|
|
|
|
commands.append('no shutdown')
|
|
|
|
commands.append('no shutdown')
|
|
|
|
elif value == 'down':
|
|
|
|
elif value == 'down':
|
|
|
|
commands.append('shutdown')
|
|
|
|
commands.append('shutdown')
|
|
|
|
if key == 'mode':
|
|
|
|
if key == 'mode' and value:
|
|
|
|
commands.append('mode {0}'.format(value))
|
|
|
|
commands.append('mode {0}'.format(value))
|
|
|
|
if len(commands) > 1:
|
|
|
|
if len(commands) > 1:
|
|
|
|
commands.append('exit')
|
|
|
|
commands.append('exit')
|
|
|
@ -367,6 +364,13 @@ def vlan_range_commands(module, have):
|
|
|
|
return commands
|
|
|
|
return commands
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def normalize(interfaces):
|
|
|
|
|
|
|
|
normalized = None
|
|
|
|
|
|
|
|
if interfaces:
|
|
|
|
|
|
|
|
normalized = [normalize_interface(i) for i in interfaces]
|
|
|
|
|
|
|
|
return normalized
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def map_params_to_obj(module):
|
|
|
|
def map_params_to_obj(module):
|
|
|
|
obj = []
|
|
|
|
obj = []
|
|
|
|
if module.params['vlan_range']:
|
|
|
|
if module.params['vlan_range']:
|
|
|
@ -382,19 +386,24 @@ def map_params_to_obj(module):
|
|
|
|
d = item.copy()
|
|
|
|
d = item.copy()
|
|
|
|
d['vlan_id'] = str(d['vlan_id'])
|
|
|
|
d['vlan_id'] = str(d['vlan_id'])
|
|
|
|
d['mapped_vni'] = str(d['mapped_vni'])
|
|
|
|
d['mapped_vni'] = str(d['mapped_vni'])
|
|
|
|
|
|
|
|
d['interfaces'] = normalize(d['interfaces'])
|
|
|
|
|
|
|
|
d['associated_interfaces'] = normalize(d['associated_interfaces'])
|
|
|
|
|
|
|
|
|
|
|
|
obj.append(d)
|
|
|
|
obj.append(d)
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
|
|
|
|
interfaces = normalize(module.params['interfaces'])
|
|
|
|
|
|
|
|
associated_interfaces = normalize(module.params['associated_interfaces'])
|
|
|
|
|
|
|
|
|
|
|
|
obj.append({
|
|
|
|
obj.append({
|
|
|
|
'vlan_id': str(module.params['vlan_id']),
|
|
|
|
'vlan_id': str(module.params['vlan_id']),
|
|
|
|
'name': module.params['name'],
|
|
|
|
'name': module.params['name'],
|
|
|
|
'interfaces': module.params['interfaces'],
|
|
|
|
'interfaces': interfaces,
|
|
|
|
'vlan_state': module.params['vlan_state'],
|
|
|
|
'vlan_state': module.params['vlan_state'],
|
|
|
|
'mapped_vni': str(module.params['mapped_vni']),
|
|
|
|
'mapped_vni': str(module.params['mapped_vni']),
|
|
|
|
'state': module.params['state'],
|
|
|
|
'state': module.params['state'],
|
|
|
|
'admin_state': module.params['admin_state'],
|
|
|
|
'admin_state': module.params['admin_state'],
|
|
|
|
'mode': module.params['mode'],
|
|
|
|
'mode': module.params['mode'],
|
|
|
|
'associated_interfaces': module.params['associated_interfaces']
|
|
|
|
'associated_interfaces': associated_interfaces
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
return obj
|
|
|
|
return obj
|
|
|
@ -408,49 +417,23 @@ def parse_admin_state(vlan):
|
|
|
|
return 'down'
|
|
|
|
return 'down'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def parse_mode(os_platform, output, vlan_id):
|
|
|
|
def parse_mode(config):
|
|
|
|
if not any(i in os_platform for i in ['5K', '7K']):
|
|
|
|
mode = None
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
|
|
|
mtus = output['TABLE_mtuinfo']['ROW_mtuinfo']
|
|
|
|
|
|
|
|
except KeyError:
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if mtus:
|
|
|
|
|
|
|
|
if isinstance(mtus, list):
|
|
|
|
|
|
|
|
for mtu in mtus:
|
|
|
|
|
|
|
|
if mtu['vlanshowinfo-vlanid'] == vlan_id:
|
|
|
|
|
|
|
|
mode = mtu.get('vlanshowinfo-vlanmode')
|
|
|
|
|
|
|
|
if mode == 'ce-vlan':
|
|
|
|
|
|
|
|
return 'ce'
|
|
|
|
|
|
|
|
elif mode == 'fabricpath-vlan':
|
|
|
|
|
|
|
|
return 'fabricpath'
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
elif isinstance(mtus, dict):
|
|
|
|
|
|
|
|
if mtus['vlanshowinfo-vlanid'] == vlan_id:
|
|
|
|
|
|
|
|
mode = mtus.get('vlanshowinfo-vlanmode')
|
|
|
|
|
|
|
|
if mode == 'ce-vlan':
|
|
|
|
|
|
|
|
return 'ce'
|
|
|
|
|
|
|
|
elif mode == 'fabricpath-vlan':
|
|
|
|
|
|
|
|
return 'fabricpath'
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else:
|
|
|
|
if config:
|
|
|
|
return None
|
|
|
|
match = re.search(r'mode (\S+)', config)
|
|
|
|
else:
|
|
|
|
if match:
|
|
|
|
return None
|
|
|
|
mode = match.group(1)
|
|
|
|
|
|
|
|
return mode
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def parse_vni(module, vlan_id):
|
|
|
|
def parse_vni(config):
|
|
|
|
vni = None
|
|
|
|
vni = None
|
|
|
|
flags = ['| section vlan.{0}'.format(vlan_id)]
|
|
|
|
|
|
|
|
cfg = get_config(module, flags=flags)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
match = re.search(r'vn-segment (\S+)', cfg, re.M)
|
|
|
|
if config:
|
|
|
|
if match:
|
|
|
|
match = re.search(r'vn-segment (\S+)', config)
|
|
|
|
vni = match.group(1)
|
|
|
|
if match:
|
|
|
|
|
|
|
|
vni = match.group(1)
|
|
|
|
return str(vni)
|
|
|
|
return str(vni)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -482,41 +465,138 @@ def parse_interfaces(module, vlan):
|
|
|
|
return vlan_int
|
|
|
|
return vlan_int
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def parse_vlan_options(module, os_platform, output, vlan):
|
|
|
|
def parse_vlan_config(netcfg, vlan_id):
|
|
|
|
|
|
|
|
parents = ['vlan {0}'.format(vlan_id)]
|
|
|
|
|
|
|
|
config = netcfg.get_section(parents)
|
|
|
|
|
|
|
|
return config
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def parse_vlan_options(module, netcfg, output, vlan):
|
|
|
|
obj = {}
|
|
|
|
obj = {}
|
|
|
|
vlan_id = vlan['vlanshowbr-vlanid-utf']
|
|
|
|
vlan_id = vlan['vlanshowbr-vlanid-utf']
|
|
|
|
|
|
|
|
config = parse_vlan_config(netcfg, vlan_id)
|
|
|
|
|
|
|
|
|
|
|
|
obj['vlan_id'] = str(vlan_id)
|
|
|
|
obj['vlan_id'] = str(vlan_id)
|
|
|
|
obj['name'] = vlan.get('vlanshowbr-vlanname')
|
|
|
|
obj['name'] = vlan.get('vlanshowbr-vlanname')
|
|
|
|
obj['vlan_state'] = vlan.get('vlanshowbr-vlanstate')
|
|
|
|
obj['vlan_state'] = vlan.get('vlanshowbr-vlanstate')
|
|
|
|
obj['admin_state'] = parse_admin_state(vlan)
|
|
|
|
obj['admin_state'] = parse_admin_state(vlan)
|
|
|
|
obj['mode'] = parse_mode(os_platform, output, vlan_id)
|
|
|
|
obj['mode'] = parse_mode(config)
|
|
|
|
obj['mapped_vni'] = parse_vni(module, vlan_id)
|
|
|
|
obj['mapped_vni'] = parse_vni(config)
|
|
|
|
obj['interfaces'] = parse_interfaces(module, vlan)
|
|
|
|
obj['interfaces'] = parse_interfaces(module, vlan)
|
|
|
|
return obj
|
|
|
|
return obj
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def map_config_to_obj(module, os_platform):
|
|
|
|
def parse_vlan_non_structured(module, netcfg, vlans):
|
|
|
|
|
|
|
|
objs = list()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for vlan in vlans:
|
|
|
|
|
|
|
|
vlan_match = re.search(r'(\d+)', vlan, re.M)
|
|
|
|
|
|
|
|
if vlan_match:
|
|
|
|
|
|
|
|
obj = {}
|
|
|
|
|
|
|
|
vlan_id = vlan_match.group(1)
|
|
|
|
|
|
|
|
obj['vlan_id'] = str(vlan_id)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
name_match = re.search(r'{0}\s*(\S+)'.format(vlan_id), vlan, re.M)
|
|
|
|
|
|
|
|
if name_match:
|
|
|
|
|
|
|
|
name = name_match.group(1)
|
|
|
|
|
|
|
|
obj['name'] = name
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
state_match = re.search(r'{0}\s*{1}\s*(\S+)'.format(vlan_id, name), vlan, re.M)
|
|
|
|
|
|
|
|
if state_match:
|
|
|
|
|
|
|
|
vlan_state_match = state_match.group(1)
|
|
|
|
|
|
|
|
if vlan_state_match == 'suspended':
|
|
|
|
|
|
|
|
vlan_state = 'suspend'
|
|
|
|
|
|
|
|
admin_state = 'up'
|
|
|
|
|
|
|
|
elif vlan_state_match == 'sus/lshut':
|
|
|
|
|
|
|
|
vlan_state = 'suspend'
|
|
|
|
|
|
|
|
admin_state = 'down'
|
|
|
|
|
|
|
|
if vlan_state_match == 'active':
|
|
|
|
|
|
|
|
vlan_state = 'active'
|
|
|
|
|
|
|
|
admin_state = 'up'
|
|
|
|
|
|
|
|
if vlan_state_match == 'act/lshut':
|
|
|
|
|
|
|
|
vlan_state = 'active'
|
|
|
|
|
|
|
|
admin_state = 'down'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
obj['vlan_state'] = vlan_state
|
|
|
|
|
|
|
|
obj['admin_state'] = admin_state
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
vlan = ','.join(vlan.splitlines())
|
|
|
|
|
|
|
|
interfaces = list()
|
|
|
|
|
|
|
|
intfs_match = re.search(r'{0}\s*{1}\s*{2}\s*(.*)'.format(vlan_id, name, vlan_state_match),
|
|
|
|
|
|
|
|
vlan, re.M)
|
|
|
|
|
|
|
|
if intfs_match:
|
|
|
|
|
|
|
|
intfs = intfs_match.group(1)
|
|
|
|
|
|
|
|
intfs = intfs.split()
|
|
|
|
|
|
|
|
for i in intfs:
|
|
|
|
|
|
|
|
intf = normalize_interface(i.strip(','))
|
|
|
|
|
|
|
|
interfaces.append(intf)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if interfaces:
|
|
|
|
|
|
|
|
obj['interfaces'] = interfaces
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
obj['interfaces'] = None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
config = parse_vlan_config(netcfg, vlan_id)
|
|
|
|
|
|
|
|
obj['mode'] = parse_mode(config)
|
|
|
|
|
|
|
|
obj['mapped_vni'] = parse_vni(config)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
objs.append(obj)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return objs
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def map_config_to_obj(module):
|
|
|
|
objs = list()
|
|
|
|
objs = list()
|
|
|
|
output = run_commands(module, ['show vlan | json'])[0]
|
|
|
|
output = None
|
|
|
|
try:
|
|
|
|
|
|
|
|
vlans = output['TABLE_vlanbrief']['ROW_vlanbrief']
|
|
|
|
command = ['show vlan brief | json']
|
|
|
|
except KeyError:
|
|
|
|
output = run_commands(module, command, check_rc='retry_json')[0]
|
|
|
|
return objs
|
|
|
|
if output:
|
|
|
|
|
|
|
|
netcfg = CustomNetworkConfig(indent=2,
|
|
|
|
if vlans:
|
|
|
|
contents=get_config(module, flags=['all']))
|
|
|
|
if isinstance(vlans, list):
|
|
|
|
|
|
|
|
for vlan in vlans:
|
|
|
|
if isinstance(output, dict):
|
|
|
|
obj = parse_vlan_options(module, os_platform, output, vlan)
|
|
|
|
vlans = None
|
|
|
|
objs.append(obj)
|
|
|
|
try:
|
|
|
|
|
|
|
|
vlans = output['TABLE_vlanbriefxbrief']['ROW_vlanbriefxbrief']
|
|
|
|
elif isinstance(vlans, dict):
|
|
|
|
except KeyError:
|
|
|
|
obj = parse_vlan_options(module, os_platform, output, vlans)
|
|
|
|
return objs
|
|
|
|
objs.append(obj)
|
|
|
|
|
|
|
|
|
|
|
|
if vlans:
|
|
|
|
|
|
|
|
if isinstance(vlans, list):
|
|
|
|
|
|
|
|
for vlan in vlans:
|
|
|
|
|
|
|
|
obj = parse_vlan_options(module, netcfg, output, vlan)
|
|
|
|
|
|
|
|
objs.append(obj)
|
|
|
|
|
|
|
|
elif isinstance(vlans, dict):
|
|
|
|
|
|
|
|
obj = parse_vlan_options(module, netcfg, output, vlans)
|
|
|
|
|
|
|
|
objs.append(obj)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
vlans = list()
|
|
|
|
|
|
|
|
splitted_line = re.split(r'\n(\d+)|\n{2}', output.strip())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for line in splitted_line:
|
|
|
|
|
|
|
|
if not line:
|
|
|
|
|
|
|
|
continue
|
|
|
|
|
|
|
|
if len(line) > 0:
|
|
|
|
|
|
|
|
line = line.strip()
|
|
|
|
|
|
|
|
if line[0].isdigit():
|
|
|
|
|
|
|
|
match = re.search(r'(\d+)', line, re.M)
|
|
|
|
|
|
|
|
if match:
|
|
|
|
|
|
|
|
v = match.group(1)
|
|
|
|
|
|
|
|
pos1 = splitted_line.index(v)
|
|
|
|
|
|
|
|
pos2 = pos1 + 1
|
|
|
|
|
|
|
|
vlaninfo = ''.join(splitted_line[pos1:pos2 + 1])
|
|
|
|
|
|
|
|
vlans.append(vlaninfo)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if vlans:
|
|
|
|
|
|
|
|
objs = parse_vlan_non_structured(module, netcfg, vlans)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
return objs
|
|
|
|
|
|
|
|
|
|
|
|
return objs
|
|
|
|
return objs
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def check_declarative_intent_params(want, module, os_platform, result):
|
|
|
|
def check_declarative_intent_params(want, module, result):
|
|
|
|
|
|
|
|
|
|
|
|
have = None
|
|
|
|
have = None
|
|
|
|
is_delay = False
|
|
|
|
is_delay = False
|
|
|
@ -530,7 +610,7 @@ def check_declarative_intent_params(want, module, os_platform, result):
|
|
|
|
is_delay = True
|
|
|
|
is_delay = True
|
|
|
|
|
|
|
|
|
|
|
|
if have is None:
|
|
|
|
if have is None:
|
|
|
|
have = map_config_to_obj(module, os_platform)
|
|
|
|
have = map_config_to_obj(module)
|
|
|
|
|
|
|
|
|
|
|
|
for i in w['associated_interfaces']:
|
|
|
|
for i in w['associated_interfaces']:
|
|
|
|
obj_in_have = search_obj_in_list(w['vlan_id'], have)
|
|
|
|
obj_in_have = search_obj_in_list(w['vlan_id'], have)
|
|
|
@ -552,7 +632,7 @@ def main():
|
|
|
|
delay=dict(default=10, type='int'),
|
|
|
|
delay=dict(default=10, type='int'),
|
|
|
|
state=dict(choices=['present', 'absent'], default='present', required=False),
|
|
|
|
state=dict(choices=['present', 'absent'], default='present', required=False),
|
|
|
|
admin_state=dict(choices=['up', 'down'], required=False, default='up'),
|
|
|
|
admin_state=dict(choices=['up', 'down'], required=False, default='up'),
|
|
|
|
mode=dict(choices=['ce', 'fabricpath'], required=False, default='ce'),
|
|
|
|
mode=dict(choices=['ce', 'fabricpath'], required=False),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
aggregate_spec = deepcopy(element_spec)
|
|
|
|
aggregate_spec = deepcopy(element_spec)
|
|
|
@ -579,22 +659,19 @@ def main():
|
|
|
|
mutually_exclusive=mutually_exclusive,
|
|
|
|
mutually_exclusive=mutually_exclusive,
|
|
|
|
supports_check_mode=True)
|
|
|
|
supports_check_mode=True)
|
|
|
|
|
|
|
|
|
|
|
|
info = get_capabilities(module).get('device_info', {})
|
|
|
|
|
|
|
|
os_platform = info.get('network_os_platform', '')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
warnings = list()
|
|
|
|
warnings = list()
|
|
|
|
result = {'changed': False}
|
|
|
|
result = {'changed': False}
|
|
|
|
if warnings:
|
|
|
|
if warnings:
|
|
|
|
result['warnings'] = warnings
|
|
|
|
result['warnings'] = warnings
|
|
|
|
|
|
|
|
|
|
|
|
have = map_config_to_obj(module, os_platform)
|
|
|
|
have = map_config_to_obj(module)
|
|
|
|
want = map_params_to_obj(module)
|
|
|
|
want = map_params_to_obj(module)
|
|
|
|
|
|
|
|
|
|
|
|
if module.params['vlan_range']:
|
|
|
|
if module.params['vlan_range']:
|
|
|
|
commands = vlan_range_commands(module, have)
|
|
|
|
commands = vlan_range_commands(module, have)
|
|
|
|
result['commands'] = commands
|
|
|
|
result['commands'] = commands
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
commands = map_obj_to_commands((want, have), module, os_platform)
|
|
|
|
commands = map_obj_to_commands((want, have), module)
|
|
|
|
result['commands'] = commands
|
|
|
|
result['commands'] = commands
|
|
|
|
|
|
|
|
|
|
|
|
if commands:
|
|
|
|
if commands:
|
|
|
@ -603,7 +680,7 @@ def main():
|
|
|
|
result['changed'] = True
|
|
|
|
result['changed'] = True
|
|
|
|
|
|
|
|
|
|
|
|
if want:
|
|
|
|
if want:
|
|
|
|
check_declarative_intent_params(want, module, os_platform, result)
|
|
|
|
check_declarative_intent_params(want, module, result)
|
|
|
|
|
|
|
|
|
|
|
|
module.exit_json(**result)
|
|
|
|
module.exit_json(**result)
|
|
|
|
|
|
|
|
|
|
|
|