nornir-collection 0.0.23__tar.gz → 0.0.25__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/PKG-INFO +3 -2
  2. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/netconf/config_tasks.py +66 -1
  3. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/inventory.py +2 -2
  4. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection.egg-info/PKG-INFO +3 -2
  5. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/setup.py +1 -1
  6. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/LICENSE +0 -0
  7. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/README.md +0 -0
  8. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/__init__.py +0 -0
  9. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/batfish/__init__.py +0 -0
  10. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/batfish/assert_config.py +0 -0
  11. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/batfish/utils.py +0 -0
  12. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/__init__.py +0 -0
  13. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/__init__.py +0 -0
  14. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/cli/__init__.py +0 -0
  15. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/cli/config_tasks.py +0 -0
  16. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/cli/config_workflow.py +0 -0
  17. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/cli/show_tasks.py +0 -0
  18. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/netconf/__init__.py +0 -0
  19. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/netconf/config_workflow.py +0 -0
  20. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/netconf/nr_cfg_iosxe_netconf.py +0 -0
  21. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/netconf/ops_tasks.py +0 -0
  22. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/processor.py +0 -0
  23. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/pyats.py +0 -0
  24. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/restconf/__init__.py +0 -0
  25. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/restconf/cisco_rpc.py +0 -0
  26. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/restconf/config_workflow.py +0 -0
  27. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/restconf/tasks.py +0 -0
  28. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/configuration_management/utils.py +0 -0
  29. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/software_upgrade/__init__.py +0 -0
  30. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/software_upgrade/cisco_software_upgrade.py +0 -0
  31. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/software_upgrade/utils.py +0 -0
  32. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/support_api/__init__.py +0 -0
  33. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/support_api/api_calls.py +0 -0
  34. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/support_api/cisco_maintenance_report.py +0 -0
  35. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/support_api/cisco_support.py +0 -0
  36. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/support_api/reports.py +0 -0
  37. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/cisco/support_api/utils.py +0 -0
  38. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/fortinet/__init__.py +0 -0
  39. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/fortinet/utils.py +0 -0
  40. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/git.py +0 -0
  41. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/__init__.py +0 -0
  42. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/custom_script.py +0 -0
  43. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/set_device_status.py +0 -0
  44. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/sync_datasource.py +0 -0
  45. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/update_cisco_inventory_data.py +0 -0
  46. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/update_cisco_support_plugin_data.py +0 -0
  47. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/update_fortinet_inventory_data.py +0 -0
  48. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/update_prefixes_ip_addresses.py +0 -0
  49. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/update_purestorage_inventory_data.py +0 -0
  50. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/utils.py +0 -0
  51. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/netbox/verify_device_primary_ip.py +0 -0
  52. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/nornir_plugins/__init__.py +0 -0
  53. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/nornir_plugins/inventory/__init__.py +0 -0
  54. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/nornir_plugins/inventory/netbox.py +0 -0
  55. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/nornir_plugins/inventory/staggered_yaml.py +0 -0
  56. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/nornir_plugins/inventory/utils.py +0 -0
  57. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/purestorage/__init__.py +0 -0
  58. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/purestorage/utils.py +0 -0
  59. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection/utils.py +0 -0
  60. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection.egg-info/SOURCES.txt +0 -0
  61. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection.egg-info/dependency_links.txt +0 -0
  62. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection.egg-info/requires.txt +0 -0
  63. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/nornir_collection.egg-info/top_level.txt +0 -0
  64. {nornir_collection-0.0.23 → nornir_collection-0.0.25}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
- Metadata-Version: 2.2
1
+ Metadata-Version: 2.4
2
2
  Name: nornir-collection
3
- Version: 0.0.23
3
+ Version: 0.0.25
4
4
  Summary: Nornir-Collection contains network automation functions and complete IaC workflows with Nornir and other python libraries. It contains Nornir tasks and general functions in Nornir style.
5
5
  Author: Willi Kubny
6
6
  Author-email: willi.kubny@gmail.ch
@@ -47,6 +47,7 @@ Dynamic: author-email
47
47
  Dynamic: classifier
48
48
  Dynamic: description
49
49
  Dynamic: description-content-type
50
+ Dynamic: license-file
50
51
  Dynamic: requires-dist
51
52
  Dynamic: requires-python
52
53
  Dynamic: summary
@@ -360,6 +360,71 @@ def nc_edit_cleanup_svi(task: Task, verbose: bool = False) -> Result:
360
360
  return Result(host=task.host, custom_result=custom_result, failed=task_failed)
361
361
 
362
362
 
363
+ def nc_edit_cleanup_vlan(task: Task, verbose: bool = False) -> Result:
364
+ """
365
+ TBD
366
+ """
367
+ # The custom_result list will be filled with the results
368
+ custom_result = []
369
+
370
+ #### Get all current configured VLANs with RESTCONF #####################################################
371
+
372
+ task_text = "RESTCONF GET VLANs"
373
+
374
+ # Set the RESTCONF port, yang query and url to get all configured SVIs
375
+ yang_query = "Cisco-IOS-XE-native:native/vlan/Cisco-IOS-XE-vlan:vlan-list"
376
+ url = f"https://{task.host.hostname}:443/restconf/data/{yang_query}"
377
+
378
+ # RESTCONF HTTP Get for all SVIs
379
+ response = rc_cisco_get(url=url, auth=(task.host.username, task.host.password), verify=False)
380
+
381
+ # Set the RESTCONF result and return the Nornir result if the RESTCONF response status_code is not 200
382
+ custom_result = set_restconf_result(
383
+ task=Task,
384
+ task_text=task_text,
385
+ yang_query=yang_query,
386
+ response=response,
387
+ custom_result=custom_result,
388
+ verbose=verbose,
389
+ )
390
+
391
+ # Create a list with all current configured VLANs except the default VLAN 1
392
+ current_vlans = [x for x in response["json"]["Cisco-IOS-XE-vlan:vlan-list"] if x["id"] != 1]
393
+
394
+ #### Render NETCONF payload to remove VLANs with Jinja2 #################################################
395
+
396
+ task_text = "Render Jinja2 NETCONF payload"
397
+ # Create a list with all configured VLANs which are not part of the inventory
398
+ remove_vlans = [x for x in current_vlans if x["id"] not in [x["vid"] for x in task.host["cfg_vlans"]]]
399
+
400
+ # If there are no VLANs to remove, return the Nornir result
401
+ if not remove_vlans:
402
+ custom_result.append(
403
+ f"{task_result(text=task_text, changed=False, level_name='INFO', failed=False)}\n"
404
+ + f"'{task_text}' -> NornirResponse <Success: True>\n"
405
+ + "-> No VLANs to remove"
406
+ )
407
+ return Result(host=task.host, custom_result=custom_result, failed=False)
408
+
409
+ # Set the info message for the Nornir result
410
+ info_msg = f"VLANs to remove: {len(remove_vlans)}"
411
+
412
+ # Render the Jinja2 payload template and configure the NETCONF candidate datastore
413
+ custom_result, task_failed = netconf_configure_jinja2_rendered_payload_template(
414
+ task=task,
415
+ j2_task_text=task_text,
416
+ j2_tpl_path="iosxe_netconf/tpl_sys/cleanup/cleanup_vlan.j2",
417
+ custom_result=custom_result,
418
+ task_failed=False,
419
+ info_msg=info_msg,
420
+ verbose=verbose,
421
+ j2_kwargs={"remove_vlans": remove_vlans},
422
+ )
423
+
424
+ # Return the Nornir NETCONF result
425
+ return Result(host=task.host, custom_result=custom_result, failed=task_failed)
426
+
427
+
363
428
  def nc_edit_tpl_config(task: Task, tpl_startswith: str, verbose: bool = False) -> Result:
364
429
  """
365
430
  TBD
@@ -477,7 +542,6 @@ def nc_cfg_cleanup(nr: Nornir, cfg_status: bool = True, verbose: bool = False) -
477
542
  """
478
543
  TBD
479
544
  """
480
-
481
545
  # Return False if cfg_status argument is False
482
546
  if not cfg_status:
483
547
  return False
@@ -485,6 +549,7 @@ def nc_cfg_cleanup(nr: Nornir, cfg_status: bool = True, verbose: bool = False) -
485
549
  tasks = {
486
550
  nc_edit_cleanup_portchannel: "NETCONF portchannel cleanup",
487
551
  nc_edit_cleanup_svi: "NETCONF vlan interface cleanup",
552
+ nc_edit_cleanup_vlan: "NETCONF vlan cleanup",
488
553
  }
489
554
 
490
555
  # Run each task from the Nornir tasks list
@@ -91,8 +91,8 @@ def _load_interface_data(task: Task, all_interfaces: List[Dict], enrich_vlan_dat
91
91
  # Dict keys for comprehension to include only some key-value pairs
92
92
  # fmt: off
93
93
  include_keys = [
94
- "name", "int_template", "description", "type", "lag", "count_ipaddresses",
95
- "count_fhrp_groups", "int_peer_device", "int_config_context", "enabled",
94
+ "name", "int_template", "description", "type", "lag", "mode", "untagged_vlan", "tagged_vlans",
95
+ "count_ipaddresses", "count_fhrp_groups", "int_peer_device", "int_config_context", "enabled",
96
96
  ]
97
97
  # fmt: on
98
98
  # Make some normalization to the device interfaces data with the interface_filter list and others
@@ -1,6 +1,6 @@
1
- Metadata-Version: 2.2
1
+ Metadata-Version: 2.4
2
2
  Name: nornir-collection
3
- Version: 0.0.23
3
+ Version: 0.0.25
4
4
  Summary: Nornir-Collection contains network automation functions and complete IaC workflows with Nornir and other python libraries. It contains Nornir tasks and general functions in Nornir style.
5
5
  Author: Willi Kubny
6
6
  Author-email: willi.kubny@gmail.ch
@@ -47,6 +47,7 @@ Dynamic: author-email
47
47
  Dynamic: classifier
48
48
  Dynamic: description
49
49
  Dynamic: description-content-type
50
+ Dynamic: license-file
50
51
  Dynamic: requires-dist
51
52
  Dynamic: requires-python
52
53
  Dynamic: summary
@@ -11,7 +11,7 @@ with open("requirements.txt", encoding="utf-8") as f:
11
11
 
12
12
  setuptools.setup(
13
13
  name="nornir-collection",
14
- version="0.0.23",
14
+ version="0.0.25",
15
15
  author="Willi Kubny",
16
16
  author_email="willi.kubny@gmail.ch",
17
17
  description="Nornir-Collection contains network automation functions and complete IaC workflows with \