catalystwan 0.41.2__py3-none-any.whl → 0.41.2.dev1__py3-none-any.whl
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.
- catalystwan/__init__.py +3 -2
- catalystwan/api/administration.py +13 -2
- catalystwan/api/api_container.py +4 -1
- catalystwan/api/builders/__init__.py +14 -0
- catalystwan/api/builders/feature_profiles/__init__.py +0 -0
- catalystwan/api/builders/feature_profiles/application_priority.py +58 -0
- catalystwan/api/builders/feature_profiles/builder_factory.py +59 -0
- catalystwan/api/builders/feature_profiles/cli.py +76 -0
- catalystwan/api/builders/feature_profiles/mixins.py +44 -0
- catalystwan/api/builders/feature_profiles/other.py +79 -0
- catalystwan/api/builders/feature_profiles/report.py +155 -0
- catalystwan/api/builders/feature_profiles/service.py +248 -0
- catalystwan/api/builders/feature_profiles/system.py +80 -0
- catalystwan/api/builders/feature_profiles/transport.py +256 -0
- catalystwan/api/builders/feature_profiles/uc_voice.py +287 -0
- catalystwan/api/config_group_api.py +41 -16
- catalystwan/api/configuration_groups/parcel.py +100 -30
- catalystwan/api/feature_profile_api.py +2021 -242
- catalystwan/api/policy_api.py +470 -116
- catalystwan/api/template_api.py +113 -44
- catalystwan/api/templates/README.md +61 -47
- catalystwan/api/templates/cli_template.py +17 -7
- catalystwan/api/templates/device_template/device_template.py +127 -32
- catalystwan/api/templates/feature_template.py +3 -3
- catalystwan/api/templates/models/aaa_model.py +387 -0
- catalystwan/api/templates/models/cisco_aaa_model.py +289 -42
- catalystwan/api/templates/models/cisco_banner_model.py +11 -2
- catalystwan/api/templates/models/cisco_bfd_model.py +31 -36
- catalystwan/api/templates/models/cisco_bgp_model.py +382 -131
- catalystwan/api/templates/models/cisco_logging_model.py +80 -43
- catalystwan/api/templates/models/cisco_ntp_model.py +34 -15
- catalystwan/api/templates/models/cisco_omp_model.py +70 -60
- catalystwan/api/templates/models/cisco_ospf.py +143 -74
- catalystwan/api/templates/models/cisco_ospfv3.py +217 -95
- catalystwan/api/templates/models/cisco_secure_internet_gateway.py +304 -142
- catalystwan/api/templates/models/cisco_snmp_model.py +66 -52
- catalystwan/api/templates/models/cisco_system.py +238 -129
- catalystwan/api/templates/models/cisco_vpn_interface_model.py +632 -275
- catalystwan/api/templates/models/cisco_vpn_model.py +433 -270
- catalystwan/api/templates/models/cli_template.py +3 -2
- catalystwan/api/templates/models/omp_vsmart_model.py +46 -10
- catalystwan/api/templates/models/security_vsmart_model.py +11 -8
- catalystwan/api/templates/models/supported.py +10 -4
- catalystwan/api/templates/models/system_vsmart_model.py +164 -27
- catalystwan/api/templates/models/vpn_vsmart_interface_model.py +198 -0
- catalystwan/api/templates/models/vpn_vsmart_model.py +124 -0
- catalystwan/apigw_auth.py +6 -2
- catalystwan/dataclasses.py +2 -53
- catalystwan/endpoints/__init__.py +41 -41
- catalystwan/endpoints/certificate_management_device.py +4 -0
- catalystwan/endpoints/cluster_management.py +27 -7
- catalystwan/endpoints/configuration/feature_profile/sdwan/application_priority.py +107 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/cli.py +60 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/dns_security.py +83 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/embedded_security.py +88 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/other.py +62 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/policy_object.py +35 -12
- catalystwan/endpoints/configuration/feature_profile/sdwan/service.py +154 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/sig_security.py +88 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/system.py +164 -11
- catalystwan/endpoints/configuration/feature_profile/sdwan/topology.py +93 -0
- catalystwan/endpoints/configuration/feature_profile/sdwan/transport.py +144 -26
- catalystwan/endpoints/configuration/feature_profile/sdwan/uc_voice.py +77 -0
- catalystwan/endpoints/configuration/network_hierarchy.py +32 -0
- catalystwan/endpoints/configuration/policy/abstractions.py +49 -0
- catalystwan/endpoints/configuration/policy/definition/access_control_list.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/access_control_list_ipv6.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/aip.py +52 -0
- catalystwan/endpoints/configuration/policy/definition/amp.py +52 -0
- catalystwan/endpoints/configuration/policy/definition/app_route.py +50 -0
- catalystwan/endpoints/configuration/policy/definition/cflowd.py +46 -0
- catalystwan/endpoints/configuration/policy/definition/control.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/device_access.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/device_access_ipv6.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/dial_peer.py +57 -0
- catalystwan/endpoints/configuration/policy/definition/dns_security.py +50 -0
- catalystwan/endpoints/configuration/policy/definition/fxo_port.py +57 -0
- catalystwan/endpoints/configuration/policy/definition/fxs_did_port.py +57 -0
- catalystwan/endpoints/configuration/policy/definition/fxs_port.py +57 -0
- catalystwan/endpoints/configuration/policy/definition/hub_and_spoke.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/intrusion_prevention.py +52 -0
- catalystwan/endpoints/configuration/policy/definition/mesh.py +2 -11
- catalystwan/endpoints/configuration/policy/definition/pri_isdn_port.py +57 -0
- catalystwan/endpoints/configuration/policy/definition/qos_map.py +2 -11
- catalystwan/endpoints/configuration/policy/definition/rewrite.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/route_policy.py +50 -0
- catalystwan/endpoints/configuration/policy/definition/rule_set.py +2 -11
- catalystwan/endpoints/configuration/policy/definition/security_group.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/srst_phone_profile.py +59 -0
- catalystwan/endpoints/configuration/policy/definition/ssl_decryption.py +50 -0
- catalystwan/endpoints/configuration/policy/definition/ssl_decryption_utd_profile.py +52 -0
- catalystwan/endpoints/configuration/policy/definition/traffic_data.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/url_filtering.py +50 -0
- catalystwan/endpoints/configuration/policy/definition/vpn_membership.py +6 -11
- catalystwan/endpoints/configuration/policy/definition/vpn_qos_map.py +50 -0
- catalystwan/endpoints/configuration/policy/definition/zone_based_firewall.py +6 -11
- catalystwan/endpoints/configuration/policy/list/app.py +3 -16
- catalystwan/endpoints/configuration/policy/list/app_probe.py +6 -15
- catalystwan/endpoints/configuration/policy/list/as_path.py +3 -16
- catalystwan/endpoints/configuration/policy/list/class_map.py +3 -16
- catalystwan/endpoints/configuration/policy/list/color.py +3 -16
- catalystwan/endpoints/configuration/policy/list/community.py +3 -16
- catalystwan/endpoints/configuration/policy/list/data_ipv6_prefix.py +6 -15
- catalystwan/endpoints/configuration/policy/list/data_prefix.py +3 -16
- catalystwan/endpoints/configuration/policy/list/expanded_community.py +6 -15
- catalystwan/endpoints/configuration/policy/list/extended_community.py +52 -0
- catalystwan/endpoints/configuration/policy/list/fax_protocol.py +48 -0
- catalystwan/endpoints/configuration/policy/list/fqdn.py +3 -16
- catalystwan/endpoints/configuration/policy/list/geo_location.py +3 -16
- catalystwan/endpoints/configuration/policy/list/identity.py +48 -0
- catalystwan/endpoints/configuration/policy/list/ips_signature.py +6 -15
- catalystwan/endpoints/configuration/policy/list/ipv6_prefix.py +3 -16
- catalystwan/endpoints/configuration/policy/list/local_app.py +3 -16
- catalystwan/endpoints/configuration/policy/list/local_domain.py +3 -16
- catalystwan/endpoints/configuration/policy/list/media_profile.py +52 -0
- catalystwan/endpoints/configuration/policy/list/mirror.py +3 -16
- catalystwan/endpoints/configuration/policy/list/modem_pass_through.py +52 -0
- catalystwan/endpoints/configuration/policy/list/policer.py +3 -16
- catalystwan/endpoints/configuration/policy/list/port.py +3 -16
- catalystwan/endpoints/configuration/policy/list/preferred_color_group.py +6 -15
- catalystwan/endpoints/configuration/policy/list/prefix.py +4 -16
- catalystwan/endpoints/configuration/policy/list/protocol_name.py +6 -15
- catalystwan/endpoints/configuration/policy/list/region.py +2 -10
- catalystwan/endpoints/configuration/policy/list/scalable_group_tag.py +52 -0
- catalystwan/endpoints/configuration/policy/list/site.py +3 -16
- catalystwan/endpoints/configuration/policy/list/sla.py +3 -16
- catalystwan/endpoints/configuration/policy/list/supervisory_disconnect.py +52 -0
- catalystwan/endpoints/configuration/policy/list/threat_grid_api_key.py +52 -0
- catalystwan/endpoints/configuration/policy/list/tloc.py +3 -16
- catalystwan/endpoints/configuration/policy/list/translation_profile.py +52 -0
- catalystwan/endpoints/configuration/policy/list/translation_rules.py +52 -0
- catalystwan/endpoints/configuration/policy/list/trunkgroup.py +48 -0
- catalystwan/endpoints/configuration/policy/list/umbrella_data.py +52 -0
- catalystwan/endpoints/configuration/policy/list/url_allow_list.py +3 -16
- catalystwan/endpoints/configuration/policy/list/url_block_list.py +3 -16
- catalystwan/endpoints/configuration/policy/list/vpn.py +3 -16
- catalystwan/endpoints/configuration/policy/list/zone.py +3 -16
- catalystwan/endpoints/configuration/policy/security_template.py +2 -3
- catalystwan/endpoints/configuration/policy/voice_template.py +39 -0
- catalystwan/endpoints/configuration/policy_group.py +30 -0
- catalystwan/endpoints/configuration/software_actions.py +2 -4
- catalystwan/endpoints/configuration/topology_group.py +51 -0
- catalystwan/endpoints/configuration_dashboard_status.py +2 -2
- catalystwan/endpoints/configuration_device_template.py +15 -1
- catalystwan/endpoints/configuration_feature_profile.py +8 -11
- catalystwan/endpoints/configuration_general_template.py +31 -0
- catalystwan/endpoints/configuration_group.py +28 -5
- catalystwan/endpoints/configuration_settings.py +90 -1
- catalystwan/endpoints/configuration_template_master.py +48 -0
- catalystwan/endpoints/endpoints_container.py +79 -19
- catalystwan/endpoints/real_time_monitoring/reboot_history.py +1 -3
- catalystwan/endpoints/tenant_migration.py +2 -0
- catalystwan/exceptions.py +17 -0
- catalystwan/integration_tests/base.py +81 -0
- catalystwan/integration_tests/feature_profile/sdwan/__init__.py +0 -0
- catalystwan/integration_tests/feature_profile/sdwan/policy/__init__.py +0 -0
- catalystwan/integration_tests/feature_profile/sdwan/policy/base.py +33 -0
- catalystwan/integration_tests/feature_profile/sdwan/policy/test_extended_community.py +33 -0
- catalystwan/integration_tests/feature_profile/sdwan/policy/test_security_app_list.py +32 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_application_priority.py +433 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_cli.py +54 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_dns_security.py +106 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_other.py +49 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_service.py +1078 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_sig_security.py +322 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_ssl_decryption.py +85 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_system.py +368 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_tracker.py +127 -0
- catalystwan/integration_tests/feature_profile/sdwan/test_transport.py +1698 -0
- catalystwan/integration_tests/feature_profile/sdwan/topology/test_topology.py +93 -0
- catalystwan/integration_tests/profile_builder/__init__.py +0 -0
- catalystwan/integration_tests/profile_builder/test_pb_service.py +197 -0
- catalystwan/integration_tests/profile_builder/test_pb_transport.py +226 -0
- catalystwan/integration_tests/profile_builder/test_pb_uc_voice.py +277 -0
- catalystwan/integration_tests/test_data/__init__.py +117 -0
- catalystwan/integration_tests/test_find_template_values.py +7 -18
- catalystwan/integration_tests/test_network_hierarchy.py +82 -0
- catalystwan/integration_tests/test_settings.py +30 -0
- catalystwan/models/common.py +1898 -2
- catalystwan/models/configuration/common.py +1 -0
- catalystwan/models/configuration/feature_profile/common.py +634 -149
- catalystwan/models/configuration/feature_profile/parcel.py +238 -0
- catalystwan/models/configuration/feature_profile/sdwan/acl/__init__.py +13 -0
- catalystwan/models/configuration/feature_profile/sdwan/acl/ipv4acl.py +298 -0
- catalystwan/models/configuration/feature_profile/sdwan/acl/ipv6acl.py +344 -0
- catalystwan/models/configuration/feature_profile/sdwan/application_priority/__init__.py +218 -0
- catalystwan/models/configuration/feature_profile/sdwan/application_priority/cloud_probe.py +61 -0
- catalystwan/models/configuration/feature_profile/sdwan/application_priority/policy_settings.py +31 -0
- catalystwan/models/configuration/feature_profile/sdwan/application_priority/qos_policy.py +102 -0
- catalystwan/models/configuration/feature_profile/sdwan/application_priority/traffic_policy.py +1057 -0
- catalystwan/models/configuration/feature_profile/sdwan/cli/__init__.py +23 -0
- catalystwan/models/configuration/feature_profile/sdwan/cli/config.py +18 -0
- catalystwan/models/configuration/feature_profile/sdwan/cli/full_config.py +15 -0
- catalystwan/models/configuration/feature_profile/sdwan/dns_security/__init__.py +13 -0
- catalystwan/models/configuration/feature_profile/sdwan/dns_security/dns.py +110 -0
- catalystwan/models/configuration/feature_profile/sdwan/embedded_security/__init__.py +23 -0
- catalystwan/models/configuration/feature_profile/sdwan/embedded_security/ngfirewall.py +493 -0
- catalystwan/models/configuration/feature_profile/sdwan/embedded_security/policy.py +171 -0
- catalystwan/models/configuration/feature_profile/sdwan/other/__init__.py +25 -0
- catalystwan/models/configuration/feature_profile/sdwan/other/cybervision.py +44 -0
- catalystwan/models/configuration/feature_profile/sdwan/other/thousandeyes.py +147 -0
- catalystwan/models/configuration/feature_profile/sdwan/other/ucse.py +110 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/__init__.py +62 -48
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/app_probe.py +34 -20
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/application_list.py +8 -6
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/as_path.py +22 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/color_list.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/data_prefix.py +13 -4
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/expanded_community_list.py +9 -7
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/extended_community.py +34 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/fowarding_class.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/ipv4_network_object.py +15 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/ipv4_service_object.py +254 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/ipv6_data_prefix.py +11 -9
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/ipv6_prefix_list.py +25 -10
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/mirror.py +27 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/network_object_group.py +15 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/object_group.py +15 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/{policier.py → policer.py} +12 -10
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/prefered_group_color.py +29 -10
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/prefix_list.py +23 -8
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/service_object_group.py +21 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/sla_class.py +12 -31
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/standard_community.py +16 -10
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/policy/tloc_list.py +8 -7
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/aip.py +64 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/amp.py +79 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/application_list.py +8 -6
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/data_prefix.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/fqdn.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/geolocation_list.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/identity.py +30 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/intrusion_prevention.py +58 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/ips_signature.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/local_domain.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/object_group.py +72 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/protocol_list.py +7 -5
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/rule_set.py +137 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/scalable_group_tag.py +26 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/security_port.py +21 -11
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/ssl_decryption.py +126 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/ssl_decryption_profile.py +165 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/url.py +15 -10
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/url_filtering.py +148 -0
- catalystwan/models/configuration/feature_profile/sdwan/policy_object/security/zone.py +14 -18
- catalystwan/models/configuration/feature_profile/sdwan/routing/__init__.py +26 -0
- catalystwan/models/configuration/feature_profile/sdwan/routing/bgp.py +609 -0
- catalystwan/models/configuration/feature_profile/sdwan/{service → routing}/ospf.py +55 -47
- catalystwan/models/configuration/feature_profile/sdwan/{service → routing}/ospfv3.py +74 -72
- catalystwan/models/configuration/feature_profile/sdwan/service/__init__.py +91 -0
- catalystwan/models/configuration/feature_profile/sdwan/service/appqoe.py +76 -41
- catalystwan/models/configuration/feature_profile/sdwan/service/dhcp_server.py +107 -64
- catalystwan/models/configuration/feature_profile/sdwan/service/dual_router_ha.py +26 -0
- catalystwan/models/configuration/feature_profile/sdwan/service/eigrp.py +39 -42
- catalystwan/models/configuration/feature_profile/sdwan/service/lan/common.py +7 -88
- catalystwan/models/configuration/feature_profile/sdwan/service/lan/ethernet.py +231 -155
- catalystwan/models/configuration/feature_profile/sdwan/service/lan/gre.py +38 -108
- catalystwan/models/configuration/feature_profile/sdwan/service/lan/ipsec.py +77 -84
- catalystwan/models/configuration/feature_profile/sdwan/service/lan/multilink.py +101 -0
- catalystwan/models/configuration/feature_profile/sdwan/service/lan/svi.py +62 -56
- catalystwan/models/configuration/feature_profile/sdwan/service/lan/vpn.py +111 -120
- catalystwan/models/configuration/feature_profile/sdwan/service/multicast.py +56 -57
- catalystwan/models/configuration/feature_profile/sdwan/service/object_tracker.py +15 -21
- catalystwan/models/configuration/feature_profile/sdwan/service/route_policy.py +358 -110
- catalystwan/models/configuration/feature_profile/sdwan/service/service_chain.py +38 -0
- catalystwan/models/configuration/feature_profile/sdwan/service/service_insertion_attachment.py +17 -25
- catalystwan/models/configuration/feature_profile/sdwan/service/switchport.py +50 -58
- catalystwan/models/configuration/feature_profile/sdwan/service/tracker.py +12 -21
- catalystwan/models/configuration/feature_profile/sdwan/service/wireless_lan.py +27 -31
- catalystwan/models/configuration/feature_profile/sdwan/sig_security/__init__.py +19 -0
- catalystwan/models/configuration/feature_profile/sdwan/sig_security/sig_security.py +379 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/__init__.py +59 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/aaa.py +58 -10
- catalystwan/models/configuration/feature_profile/sdwan/system/banner.py +30 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/basic.py +290 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/bfd.py +69 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/device_access.py +157 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/device_access_ipv6.py +157 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/global_parcel.py +163 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/logging_parcel.py +162 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/mrf.py +75 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/ntp.py +103 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/omp.py +120 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/security.py +179 -0
- catalystwan/models/configuration/feature_profile/sdwan/system/snmp.py +173 -0
- catalystwan/models/configuration/feature_profile/sdwan/topology/__init__.py +29 -0
- catalystwan/models/configuration/feature_profile/sdwan/topology/custom_control.py +425 -0
- catalystwan/models/configuration/feature_profile/sdwan/topology/hubspoke.py +60 -0
- catalystwan/models/configuration/feature_profile/sdwan/topology/mesh.py +23 -0
- catalystwan/models/configuration/feature_profile/sdwan/trackers/__init__.py +36 -0
- catalystwan/models/configuration/feature_profile/sdwan/trackers/tracker.py +96 -0
- catalystwan/models/configuration/feature_profile/sdwan/trackers/tracker_group.py +63 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/__init__.py +93 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/cellular_controller.py +26 -23
- catalystwan/models/configuration/feature_profile/sdwan/transport/cellular_profile.py +71 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/gps.py +37 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/management/ethernet.py +121 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/t1e1controller.py +124 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/vpn.py +285 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/wan/interface/cellular.py +173 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/wan/interface/ethernet.py +389 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/wan/interface/gre.py +46 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/wan/interface/ipsec.py +137 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/wan/interface/multilink.py +219 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/wan/interface/protocol_over.py +405 -0
- catalystwan/models/configuration/feature_profile/sdwan/transport/wan/interface/t1e1serial.py +195 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/__init__.py +62 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/analog_interface.py +436 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/call_routing.py +179 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/digital_interface.py +380 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/dsp_farm.py +193 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/media_profile.py +17 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/server_group.py +51 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/srst.py +86 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/supervisory_disconnect.py +69 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/translation_profile.py +42 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/translation_rule.py +31 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/trunk_group.py +26 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/voice_global.py +57 -0
- catalystwan/models/configuration/feature_profile/sdwan/uc_voice/voice_tenant.py +40 -0
- catalystwan/models/configuration/network_hierarchy/__init__.py +22 -0
- catalystwan/models/configuration/network_hierarchy/cflowd.py +120 -0
- catalystwan/models/configuration/network_hierarchy/node.py +88 -0
- catalystwan/models/configuration/policy_group.py +74 -0
- catalystwan/models/configuration/profile_type.py +1 -6
- catalystwan/models/configuration/topology_group.py +52 -0
- catalystwan/models/policy/__init__.py +275 -69
- catalystwan/models/policy/centralized.py +26 -29
- catalystwan/models/policy/{definitions → definition}/access_control_list.py +47 -17
- catalystwan/models/policy/{definitions → definition}/access_control_list_ipv6.py +42 -18
- catalystwan/models/policy/definition/aip.py +60 -0
- catalystwan/models/policy/definition/amp.py +65 -0
- catalystwan/models/policy/definition/app_route.py +246 -0
- catalystwan/models/policy/definition/cflowd.py +95 -0
- catalystwan/models/policy/{definitions → definition}/control.py +48 -25
- catalystwan/models/policy/{definitions → definition}/device_access.py +22 -11
- catalystwan/models/policy/{definitions → definition}/device_access_ipv6.py +20 -11
- catalystwan/models/policy/definition/dial_peer.py +60 -0
- catalystwan/models/policy/definition/dns_security.py +130 -0
- catalystwan/models/policy/definition/fxo_port.py +63 -0
- catalystwan/models/policy/definition/fxs_did_port.py +58 -0
- catalystwan/models/policy/definition/fxs_port.py +56 -0
- catalystwan/models/policy/{definitions → definition}/hub_and_spoke.py +18 -4
- catalystwan/models/policy/definition/intrusion_prevention.py +55 -0
- catalystwan/models/policy/{definitions → definition}/mesh.py +13 -1
- catalystwan/models/policy/definition/pri_isdn_port.py +48 -0
- catalystwan/models/policy/{definitions → definition}/qos_map.py +39 -32
- catalystwan/models/policy/{definitions → definition}/rewrite.py +12 -2
- catalystwan/models/policy/definition/route_policy.py +187 -0
- catalystwan/models/policy/{definitions → definition}/rule_set.py +66 -48
- catalystwan/models/policy/{definitions → definition}/security_group.py +38 -14
- catalystwan/models/policy/definition/srst_phone_profile.py +37 -0
- catalystwan/models/policy/definition/ssl_decryption.py +209 -0
- catalystwan/models/policy/definition/ssl_decryption_utd_profile.py +87 -0
- catalystwan/models/policy/{definitions → definition}/traffic_data.py +184 -61
- catalystwan/models/policy/definition/url_filtering.py +70 -0
- catalystwan/models/policy/{definitions → definition}/vpn_membership.py +13 -1
- catalystwan/models/policy/definition/vpn_qos_map.py +46 -0
- catalystwan/models/policy/{definitions → definition}/zone_based_firewall.py +93 -32
- catalystwan/models/policy/list/app.py +44 -0
- catalystwan/models/policy/list/app_probe.py +42 -0
- catalystwan/models/policy/list/as_path.py +30 -0
- catalystwan/models/policy/list/class_map.py +30 -0
- catalystwan/models/policy/list/color.py +28 -0
- catalystwan/models/policy/list/communities.py +83 -0
- catalystwan/models/policy/list/data_ipv6_prefix.py +30 -0
- catalystwan/models/policy/list/data_prefix.py +30 -0
- catalystwan/models/policy/list/fax_protocol.py +45 -0
- catalystwan/models/policy/list/fqdn.py +24 -0
- catalystwan/models/policy/list/geo_location.py +33 -0
- catalystwan/models/policy/list/identity.py +29 -0
- catalystwan/models/policy/list/ips_signature.py +27 -0
- catalystwan/models/policy/list/ipv6_prefix.py +33 -0
- catalystwan/models/policy/list/local_app.py +45 -0
- catalystwan/models/policy/list/local_domain.py +36 -0
- catalystwan/models/policy/list/media_profile.py +44 -0
- catalystwan/models/policy/list/mirror.py +27 -0
- catalystwan/models/policy/list/modem_pass_through.py +27 -0
- catalystwan/models/policy/list/policer.py +39 -0
- catalystwan/models/policy/list/port.py +33 -0
- catalystwan/models/policy/list/preferred_color_group.py +82 -0
- catalystwan/models/policy/list/prefix.py +33 -0
- catalystwan/models/policy/list/protocol_name.py +26 -0
- catalystwan/models/policy/list/region.py +45 -0
- catalystwan/models/policy/list/scalable_group_tag.py +30 -0
- catalystwan/models/policy/list/site.py +34 -0
- catalystwan/models/policy/list/sla.py +77 -0
- catalystwan/models/policy/list/supervisory_disconnect.py +62 -0
- catalystwan/models/policy/list/threat_grid_api_key.py +32 -0
- catalystwan/models/policy/list/tloc.py +32 -0
- catalystwan/models/policy/list/translation_profile.py +32 -0
- catalystwan/models/policy/list/translation_rules.py +29 -0
- catalystwan/models/policy/list/trunkgroup.py +56 -0
- catalystwan/models/policy/list/umbrella_data.py +30 -0
- catalystwan/models/policy/list/url.py +39 -0
- catalystwan/models/policy/list/vpn.py +40 -0
- catalystwan/models/policy/list/zone.py +46 -0
- catalystwan/models/policy/localized.py +34 -16
- catalystwan/models/policy/policy.py +13 -9
- catalystwan/models/policy/policy_definition.py +673 -173
- catalystwan/models/policy/policy_list.py +38 -27
- catalystwan/models/policy/security.py +145 -46
- catalystwan/models/policy/voice.py +77 -0
- catalystwan/models/settings.py +41 -0
- catalystwan/models/templates.py +79 -0
- catalystwan/response.py +6 -2
- catalystwan/session.py +1 -1
- catalystwan/tests/builders/test_report.py +60 -0
- catalystwan/tests/builders/uc_voice.py +85 -0
- catalystwan/tests/models/__init__.py +0 -0
- catalystwan/tests/models/test_digital_interface.py +56 -0
- catalystwan/tests/templates/definitions/aaa_basic.json +96 -0
- catalystwan/tests/templates/definitions/aaa_complex.json +464 -0
- catalystwan/tests/templates/definitions/{iuo.json → cisco_aaa.json} +44 -15
- catalystwan/tests/templates/definitions/cisco_aaa_complex.json +361 -0
- catalystwan/tests/templates/definitions/cisco_logging_complex.json +268 -0
- catalystwan/tests/templates/definitions/cisco_ntp_complex.json +143 -0
- catalystwan/tests/templates/definitions/cisco_omp_complex.json +175 -0
- catalystwan/tests/templates/definitions/cisco_ospf_complex.json +302 -0
- catalystwan/tests/templates/definitions/cisco_sig.json +405 -0
- catalystwan/tests/templates/definitions/cisco_snmp_complex.json +258 -0
- catalystwan/tests/templates/definitions/cisco_system_complex.json +502 -0
- catalystwan/tests/templates/definitions/{Basic_Cisco_VPN_Model.json → cisco_vpn_basic.json} +2 -2
- catalystwan/tests/templates/definitions/{complex_cisco_vpn.json → cisco_vpn_complex.json} +27 -12
- catalystwan/tests/templates/definitions/cisco_vpn_interface_complex.json +821 -0
- catalystwan/tests/templates/definitions/omp_vsmart_1.json +26 -0
- catalystwan/tests/templates/definitions/{omp_2.json → omp_vsmart_2.json} +16 -2
- catalystwan/tests/templates/definitions/{omp_3.json → omp_vsmart_3.json} +16 -2
- catalystwan/tests/templates/definitions/omp_vsmart_complex.json +73 -0
- catalystwan/tests/templates/definitions/security_vsmart_complex.json +24 -0
- catalystwan/tests/templates/definitions/system_vsmart_complex.json +193 -0
- catalystwan/tests/templates/definitions/vpn_vsmart_basic.json +17 -0
- catalystwan/tests/templates/definitions/vpn_vsmart_complex.json +179 -0
- catalystwan/tests/templates/definitions/vpn_vsmart_interface_basic.json +42 -0
- catalystwan/tests/templates/definitions/vpn_vsmart_interface_complex.json +208 -0
- catalystwan/tests/templates/models/__init__.py +46 -13
- catalystwan/tests/templates/models/aaa.py +106 -0
- catalystwan/tests/templates/models/cisco_aaa.py +81 -48
- catalystwan/tests/templates/models/cisco_banner.py +2 -2
- catalystwan/tests/templates/models/cisco_bfd.py +4 -6
- catalystwan/tests/templates/models/cisco_logging.py +65 -0
- catalystwan/tests/templates/models/cisco_ntp.py +17 -0
- catalystwan/tests/templates/models/cisco_omp.py +37 -0
- catalystwan/tests/templates/models/cisco_ospf.py +60 -0
- catalystwan/tests/templates/models/cisco_secure_internet_gateway.py +95 -0
- catalystwan/tests/templates/models/cisco_snmp.py +40 -0
- catalystwan/tests/templates/models/cisco_system.py +108 -3
- catalystwan/tests/templates/models/cisco_vpn.py +42 -72
- catalystwan/tests/templates/models/cisco_vpn_interface.py +200 -0
- catalystwan/tests/templates/models/omp_vsmart.py +28 -8
- catalystwan/tests/templates/models/security_vsmart.py +11 -0
- catalystwan/tests/templates/models/system_vsmart.py +37 -0
- catalystwan/tests/templates/models/vpn_vsmart.py +32 -0
- catalystwan/tests/templates/models/vpn_vsmart_interface.py +54 -0
- catalystwan/tests/templates/schemas/aaa.json +1096 -0
- catalystwan/tests/templates/schemas/cedge_aaa.json +1 -1
- catalystwan/tests/templates/schemas/cisco_logging.json +577 -0
- catalystwan/tests/templates/schemas/cisco_ntp.json +265 -0
- catalystwan/tests/templates/schemas/cisco_omp.json +479 -0
- catalystwan/tests/templates/schemas/cisco_ospf.json +908 -0
- catalystwan/tests/templates/schemas/cisco_secure_internet_gateway.json +1520 -0
- catalystwan/tests/templates/schemas/cisco_snmp.json +561 -0
- catalystwan/tests/templates/schemas/cisco_system.json +242 -0
- catalystwan/tests/templates/schemas/cisco_vpn.json +53 -1
- catalystwan/tests/templates/schemas/cisco_vpn_interface.json +3348 -0
- catalystwan/tests/templates/schemas/omp-vsmart.json +20 -0
- catalystwan/tests/templates/schemas/security-vsmart.json +58 -0
- catalystwan/tests/templates/schemas/system-vsmart.json +2585 -0
- catalystwan/tests/templates/schemas/vpn-vsmart-interface.json +859 -0
- catalystwan/tests/templates/schemas/vpn-vsmart.json +445 -0
- catalystwan/tests/templates/test_chose_model.py +6 -10
- catalystwan/tests/templates/test_deserialize_model.py +4 -4
- catalystwan/tests/templates/test_find_template_values.py +229 -0
- catalystwan/tests/templates/test_find_template_values_2.py +193 -0
- catalystwan/tests/templates/test_serialize_model.py +1 -2
- catalystwan/tests/test_cli_template.py +8 -9
- catalystwan/tests/test_endpoints.py +42 -11
- catalystwan/tests/test_feature_profile_api.py +282 -0
- catalystwan/tests/test_models_common.py +53 -0
- catalystwan/tests/test_templates.py +16 -19
- catalystwan/utils/feature_template/find_template_values.py +17 -4
- catalystwan/utils/model.py +45 -0
- catalystwan/utils/persona.py +5 -0
- catalystwan/utils/type_check.py +22 -0
- catalystwan/workflows/backup_restore_device_templates.py +467 -0
- catalystwan/workflows/tenant_migration.py +1 -1
- {catalystwan-0.41.2.dist-info → catalystwan-0.41.2.dev1.dist-info}/METADATA +20 -1
- catalystwan-0.41.2.dev1.dist-info/RECORD +636 -0
- catalystwan/ENDPOINTS.md +0 -611
- catalystwan/api/configuration_groups/parcels/cellular_controller.py +0 -33
- catalystwan/api/templates/device_template/device_template_payload.json.j2 +0 -19
- catalystwan/models/configuration/config_migration.py +0 -36
- catalystwan/models/configuration/feature_profile/sdwan/management/vpn.py +0 -26
- catalystwan/models/configuration/feature_profile/sdwan/service/acl.py +0 -409
- catalystwan/models/configuration/feature_profile/sdwan/service/bgp.py +0 -288
- catalystwan/models/policy/lists.py +0 -330
- catalystwan/models/policy/lists_entries.py +0 -444
- catalystwan/tests/templates/definitions/complex_aaa.json +0 -277
- catalystwan/tests/templates/definitions/omp_1.json +0 -11
- catalystwan/utils/timezone.py +0 -422
- catalystwan-0.41.2.dist-info/RECORD +0 -353
- /catalystwan/tests/templates/definitions/{banner_1.json → cisco_banner.json} +0 -0
- {catalystwan-0.41.2.dist-info → catalystwan-0.41.2.dev1.dist-info}/LICENSE +0 -0
- {catalystwan-0.41.2.dist-info → catalystwan-0.41.2.dev1.dist-info}/WHEEL +0 -0
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
# Copyright 2023 Cisco Systems, Inc. and its affiliates
|
|
2
2
|
|
|
3
3
|
import ipaddress
|
|
4
|
-
from enum import Enum
|
|
5
4
|
from pathlib import Path
|
|
6
|
-
from typing import ClassVar, List, Optional
|
|
5
|
+
from typing import ClassVar, List, Literal, Optional
|
|
7
6
|
|
|
8
7
|
from pydantic import ConfigDict, Field
|
|
9
8
|
|
|
10
9
|
from catalystwan.api.templates.bool_str import BoolStr
|
|
11
10
|
from catalystwan.api.templates.feature_template import FeatureTemplate, FeatureTemplateValidator
|
|
11
|
+
from catalystwan.models.common import Protocol, StaticNatDirection, TLOCColor
|
|
12
12
|
|
|
13
13
|
DEFAULT_STATIC_NAT64_SOURCE_VPN_ID = 0
|
|
14
14
|
DEFAULT_STATIC_NAT_SOURCE_VPN_ID = 0
|
|
@@ -22,443 +22,800 @@ DEFAULT_IPV6_VRRP_PRIORITY = 100
|
|
|
22
22
|
DEFAULT_IPV6_VRRP_TIMER = 1000
|
|
23
23
|
|
|
24
24
|
|
|
25
|
-
|
|
26
|
-
|
|
25
|
+
Direction = Literal["in", "out"]
|
|
26
|
+
NatChoice = Literal["Interface", "Pool", "Loopback"]
|
|
27
|
+
CoreRegion = Literal["core", "core-shared"]
|
|
28
|
+
SecondaryRegion = Literal["off", "secondary-only", "secondary-shared"]
|
|
29
|
+
Encap = Literal["gre", "ipsec"]
|
|
30
|
+
Mode = Literal["hub", "spoke"]
|
|
31
|
+
Carrier = Literal[
|
|
32
|
+
"default", "carrier1", "carrier2", "carrier3", "carrier4", "carrier5", "carrier6", "carrier7", "carrier8"
|
|
33
|
+
]
|
|
34
|
+
MediaType = Literal["auto-select", "rj45", "sfp"]
|
|
35
|
+
Speed = Literal["10", "100", "1000", "2500", "10000"]
|
|
36
|
+
Duplex = Literal["full", "half", "auto"]
|
|
37
|
+
TrackAction = Literal["Decrement", "Shutdown"]
|
|
27
38
|
|
|
28
39
|
|
|
29
|
-
class
|
|
30
|
-
address: Optional[ipaddress.
|
|
40
|
+
class SecondaryIPv4Address(FeatureTemplateValidator):
|
|
41
|
+
address: Optional[ipaddress.IPv4Interface] = Field(
|
|
42
|
+
default=None, description="IPv4 address with CIDR notation for the secondary interface."
|
|
43
|
+
)
|
|
31
44
|
|
|
32
45
|
|
|
33
|
-
class
|
|
34
|
-
|
|
35
|
-
|
|
46
|
+
class SecondaryIPv6Address(FeatureTemplateValidator):
|
|
47
|
+
address: Optional[ipaddress.IPv6Interface] = Field(
|
|
48
|
+
default=None, description="IPv6 address with CIDR notation for the secondary interface."
|
|
49
|
+
)
|
|
36
50
|
|
|
37
51
|
|
|
38
52
|
class AccessList(FeatureTemplateValidator):
|
|
39
|
-
direction: Direction
|
|
40
|
-
acl_name: str = Field(
|
|
41
|
-
|
|
53
|
+
direction: Direction = Field(..., description="Direction of the traffic flow for applying the ACL ('in' or 'out').")
|
|
54
|
+
acl_name: str = Field(
|
|
55
|
+
..., json_schema_extra={"vmanage_key": "acl-name"}, description="Name of the access control list."
|
|
56
|
+
)
|
|
57
|
+
model_config: ClassVar[ConfigDict] = ConfigDict(populate_by_name=True)
|
|
42
58
|
|
|
43
59
|
|
|
44
60
|
class DhcpHelperV6(FeatureTemplateValidator):
|
|
45
|
-
address: ipaddress.IPv6Address
|
|
46
|
-
vpn: Optional[int] = None
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
class NatChoice(str, Enum):
|
|
50
|
-
INTERFACE = "Interface"
|
|
51
|
-
POOL = "Pool"
|
|
52
|
-
LOOPBACK = "Loopback"
|
|
61
|
+
address: ipaddress.IPv6Address = Field(..., description="IPv6 address of the DHCP server or relay.")
|
|
62
|
+
vpn: Optional[int] = Field(default=None, description="Optional VPN ID where the DHCP helper is configured.")
|
|
53
63
|
|
|
54
64
|
|
|
55
65
|
class StaticNat66(FeatureTemplateValidator):
|
|
56
|
-
source_prefix: ipaddress.IPv6Interface = Field(
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
66
|
+
source_prefix: ipaddress.IPv6Interface = Field(
|
|
67
|
+
...,
|
|
68
|
+
json_schema_extra={"vmanage_key": "source-prefix"},
|
|
69
|
+
description="IPv6 network prefix that is to be translated.",
|
|
70
|
+
)
|
|
71
|
+
translated_source_prefix: str = Field(
|
|
72
|
+
...,
|
|
73
|
+
json_schema_extra={"vmanage_key": "translated-source-prefix"},
|
|
74
|
+
description="IPv6 network prefix to which the source prefix is translated.",
|
|
75
|
+
)
|
|
76
|
+
source_vpn_id: int = Field(
|
|
77
|
+
default=DEFAULT_STATIC_NAT64_SOURCE_VPN_ID,
|
|
78
|
+
json_schema_extra={"vmanage_key": "source-vpn-id"},
|
|
79
|
+
description="VPN ID associated with the source network prefix.",
|
|
80
|
+
)
|
|
81
|
+
model_config: ClassVar[ConfigDict] = ConfigDict(populate_by_name=True)
|
|
65
82
|
|
|
66
83
|
|
|
67
84
|
class Static(FeatureTemplateValidator):
|
|
68
|
-
source_ip: ipaddress.IPv4Address = Field(
|
|
69
|
-
|
|
85
|
+
source_ip: ipaddress.IPv4Address = Field(
|
|
86
|
+
..., json_schema_extra={"vmanage_key": "source-ip"}, description="IPv4 address of the source IP for static NAT."
|
|
87
|
+
)
|
|
88
|
+
translate_ip: ipaddress.IPv4Address = Field(
|
|
89
|
+
...,
|
|
90
|
+
json_schema_extra={"vmanage_key": "translate-ip"},
|
|
91
|
+
description="IPv4 address used for translation in static NAT.",
|
|
92
|
+
)
|
|
70
93
|
static_nat_direction: StaticNatDirection = Field(
|
|
71
|
-
|
|
94
|
+
default="inside",
|
|
95
|
+
json_schema_extra={"vmanage_key": "static-nat-direction"},
|
|
96
|
+
description="Direction of static NAT mapping ('inside' or 'outside').",
|
|
72
97
|
)
|
|
73
|
-
source_vpn: int = Field(
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
UDP = "udp"
|
|
98
|
+
source_vpn: int = Field(
|
|
99
|
+
default=DEFAULT_STATIC_NAT_SOURCE_VPN_ID,
|
|
100
|
+
json_schema_extra={"vmanage_key": "source-vpn"},
|
|
101
|
+
description="VPN ID associated with the source IP for static NAT.",
|
|
102
|
+
)
|
|
103
|
+
model_config: ClassVar[ConfigDict] = ConfigDict(populate_by_name=True)
|
|
80
104
|
|
|
81
105
|
|
|
82
106
|
class StaticPortForward(FeatureTemplateValidator):
|
|
83
|
-
source_ip: ipaddress.IPv4Address = Field(
|
|
84
|
-
|
|
107
|
+
source_ip: ipaddress.IPv4Address = Field(
|
|
108
|
+
...,
|
|
109
|
+
json_schema_extra={"vmanage_key": "source-ip"},
|
|
110
|
+
description="IPv4 address of the source IP for port forwarding.",
|
|
111
|
+
)
|
|
112
|
+
translate_ip: ipaddress.IPv4Address = Field(
|
|
113
|
+
...,
|
|
114
|
+
json_schema_extra={"vmanage_key": "translate-ip"},
|
|
115
|
+
description="IPv4 address used for translation in port forwarding.",
|
|
116
|
+
)
|
|
85
117
|
static_nat_direction: StaticNatDirection = Field(
|
|
86
|
-
|
|
118
|
+
default="inside",
|
|
119
|
+
json_schema_extra={"vmanage_key": "static-nat-direction"},
|
|
120
|
+
description="Direction of port forwarding mapping ('inside' or 'outside').",
|
|
121
|
+
)
|
|
122
|
+
source_port: int = Field(
|
|
123
|
+
default=DEFAULT_STATIC_PORT_FORWARD_SOURCE_PORT,
|
|
124
|
+
json_schema_extra={"vmanage_key": "source-port"},
|
|
125
|
+
description="Source port number for port forwarding.",
|
|
87
126
|
)
|
|
88
|
-
source_port: int = Field(DEFAULT_STATIC_PORT_FORWARD_SOURCE_PORT, json_schema_extra={"vmanage_key": "source-port"})
|
|
89
127
|
translate_port: int = Field(
|
|
90
|
-
DEFAULT_STATIC_PORT_FORWARD_TRANSLATE_PORT,
|
|
128
|
+
default=DEFAULT_STATIC_PORT_FORWARD_TRANSLATE_PORT,
|
|
129
|
+
json_schema_extra={"vmanage_key": "translate-port"},
|
|
130
|
+
description="Translated port number for port forwarding.",
|
|
91
131
|
)
|
|
92
|
-
proto:
|
|
93
|
-
source_vpn: int = Field(
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
CORE_SHARED = "core-shared"
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
class SecondaryRegion(str, Enum):
|
|
103
|
-
OFF = "off"
|
|
104
|
-
SECONDARY_ONLY = "secondary-only"
|
|
105
|
-
SECONDARY_SHARED = "secondary-shared"
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
class Encap(str, Enum):
|
|
109
|
-
GRE = "gre"
|
|
110
|
-
IPSEC = "ipsec"
|
|
132
|
+
proto: Protocol = Field(..., description="Protocol used for port forwarding (TCP/UDP).")
|
|
133
|
+
source_vpn: int = Field(
|
|
134
|
+
default=DEFAULT_STATIC_PORT_FORWARD_SOURCE_VPN,
|
|
135
|
+
json_schema_extra={"vmanage_key": "source-vpn"},
|
|
136
|
+
description="VPN ID associated with the source IP for port forwarding.",
|
|
137
|
+
)
|
|
138
|
+
model_config: ClassVar[ConfigDict] = ConfigDict(populate_by_name=True)
|
|
111
139
|
|
|
112
140
|
|
|
113
141
|
class Encapsulation(FeatureTemplateValidator):
|
|
114
|
-
encap: Encap
|
|
115
|
-
preference: Optional[int] =
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
class Value(str, Enum):
|
|
125
|
-
DEFAULT = "default"
|
|
126
|
-
MPLS = "mpls"
|
|
127
|
-
METRO_ETHERNET = "metro-ethernet"
|
|
128
|
-
BIZ_INTERNET = "biz-internet"
|
|
129
|
-
PUBLIC_INTERNET = "public-internet"
|
|
130
|
-
LTE = "lte"
|
|
131
|
-
THREEG = "3g"
|
|
132
|
-
RED = "red"
|
|
133
|
-
GREEN = "green"
|
|
134
|
-
BLUE = "blue"
|
|
135
|
-
GOLD = "gold"
|
|
136
|
-
SILVER = "silver"
|
|
137
|
-
BRONZE = "bronze"
|
|
138
|
-
CUSTOM1 = "custom1"
|
|
139
|
-
CUSTOM2 = "custom2"
|
|
140
|
-
CUSTOM3 = "custom3"
|
|
141
|
-
PRIVATE1 = "private1"
|
|
142
|
-
PRIVATE2 = "private2"
|
|
143
|
-
PRIVATE3 = "private3"
|
|
144
|
-
PRIVATE4 = "private4"
|
|
145
|
-
PRIVATE5 = "private5"
|
|
146
|
-
PRIVATE6 = "private6"
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
class Carrier(str, Enum):
|
|
150
|
-
DEFAULT = "default"
|
|
151
|
-
CARRIER1 = "carrier1"
|
|
152
|
-
CARRIER2 = "carrier2"
|
|
153
|
-
CARRIER3 = "carrier3"
|
|
154
|
-
CARRIER4 = "carrier4"
|
|
155
|
-
CARRIER5 = "carrier5"
|
|
156
|
-
CARRIER6 = "carrier6"
|
|
157
|
-
CARRIER7 = "carrier7"
|
|
158
|
-
CARRIER8 = "carrier8"
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
class MediaType(str, Enum):
|
|
162
|
-
AUTO_SELECT = "auto-select"
|
|
163
|
-
RJ45 = "rj45"
|
|
164
|
-
SFP = "sfp"
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
class Speed(str, Enum):
|
|
168
|
-
TEN = "10"
|
|
169
|
-
HUNDRED = "100"
|
|
170
|
-
THOUSAND = "1000"
|
|
171
|
-
TWOANDAHALFTHOUSAND = "2500"
|
|
172
|
-
TENTHOUSAND = "10000"
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
class Duplex(str, Enum):
|
|
176
|
-
FULL = "full"
|
|
177
|
-
HALF = "half"
|
|
178
|
-
AUTO = "auto"
|
|
142
|
+
encap: Encap = Field(..., description="Type of encapsulation used for the VPN tunnel (GRE/IPsec).")
|
|
143
|
+
preference: Optional[int] = Field(
|
|
144
|
+
default=None, description="Preference value for the encapsulation type (lower values have higher priority)."
|
|
145
|
+
)
|
|
146
|
+
weight: int = Field(
|
|
147
|
+
default=DEFAULT_ENCAPSULATION_WEIGHT,
|
|
148
|
+
description="Weight for the encapsulation type used in load balancing decisions.",
|
|
149
|
+
)
|
|
179
150
|
|
|
180
151
|
|
|
181
152
|
class Ip(FeatureTemplateValidator):
|
|
182
|
-
addr: ipaddress.IPv4Address
|
|
183
|
-
mac: str
|
|
153
|
+
addr: ipaddress.IPv4Address = Field(..., description="IPv4 address for the interface.")
|
|
154
|
+
mac: str = Field(..., description="MAC address associated with the IPv4 address.")
|
|
184
155
|
|
|
185
156
|
|
|
186
157
|
class Ipv4Secondary(FeatureTemplateValidator):
|
|
187
|
-
address: ipaddress.IPv4Address
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
class TrackAction(str, Enum):
|
|
191
|
-
DECREMENT = "Decrement"
|
|
192
|
-
SHUTDOWN = "Shutdown"
|
|
158
|
+
address: ipaddress.IPv4Address = Field(..., description="IPv4 address for the secondary interface.")
|
|
193
159
|
|
|
194
160
|
|
|
195
161
|
class TrackingObject(FeatureTemplateValidator):
|
|
196
|
-
name: int
|
|
197
|
-
track_action: TrackAction = Field(
|
|
198
|
-
|
|
199
|
-
|
|
162
|
+
name: int = Field(..., description="Unique identifier for the tracking object.")
|
|
163
|
+
track_action: TrackAction = Field(
|
|
164
|
+
default="Decrement",
|
|
165
|
+
json_schema_extra={"vmanage_key": "track-action"},
|
|
166
|
+
description="Action to take when the tracked object state changes (e.g., decrement priority or shutdown).",
|
|
167
|
+
)
|
|
168
|
+
decrement: int = Field(
|
|
169
|
+
..., description="Value by which to decrement the VRRP priority when the tracked object is down."
|
|
170
|
+
)
|
|
171
|
+
model_config: ClassVar[ConfigDict] = ConfigDict(populate_by_name=True)
|
|
200
172
|
|
|
201
173
|
|
|
202
174
|
class Vrrp(FeatureTemplateValidator):
|
|
203
|
-
grp_id: int = Field(json_schema_extra={"vmanage_key": "grp-id"})
|
|
204
|
-
priority: int =
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
175
|
+
grp_id: int = Field(..., json_schema_extra={"vmanage_key": "grp-id"}, description="VRRP group ID.")
|
|
176
|
+
priority: int = Field(
|
|
177
|
+
default=DEFAULT_VRRP_PRIORITY, description="Priority value for the VRRP group (higher values take precedence)."
|
|
178
|
+
)
|
|
179
|
+
timer: int = Field(default=DEFAULT_VRRP_TIMER, description="VRRP advertisement interval timer in milliseconds.")
|
|
180
|
+
track_omp: BoolStr = Field(
|
|
181
|
+
default=False,
|
|
182
|
+
json_schema_extra={"vmanage_key": "track-omp"},
|
|
183
|
+
description="Flag to track Overlay Management Protocol (OMP) session state.",
|
|
184
|
+
)
|
|
185
|
+
track_prefix_list: Optional[str] = Field(
|
|
186
|
+
default=None,
|
|
187
|
+
json_schema_extra={"vmanage_key": "track-prefix-list"},
|
|
188
|
+
description="Name of the prefix-list used for tracking specific routes.",
|
|
189
|
+
)
|
|
208
190
|
address: Optional[ipaddress.IPv4Address] = Field(
|
|
209
|
-
default=None,
|
|
191
|
+
default=None,
|
|
192
|
+
json_schema_extra={"data_path": ["ipv4"], "vmanage_key": "address"},
|
|
193
|
+
description="Virtual IP address used by the VRRP group.",
|
|
210
194
|
)
|
|
211
195
|
ipv4_secondary: Optional[List[Ipv4Secondary]] = Field(
|
|
212
|
-
default=None,
|
|
196
|
+
default=None,
|
|
197
|
+
json_schema_extra={"vmanage_key": "ipv4-secondary"},
|
|
198
|
+
description="List of secondary IPv4 addresses for the VRRP group.",
|
|
199
|
+
)
|
|
200
|
+
tloc_change_pref: BoolStr = Field(
|
|
201
|
+
default=False,
|
|
202
|
+
json_schema_extra={"vmanage_key": "tloc-change-pref"},
|
|
203
|
+
description="Flag to change preference based on TLOC status.",
|
|
213
204
|
)
|
|
214
|
-
|
|
215
|
-
value: int
|
|
205
|
+
value: int = Field(..., description="VRRP value to determine the primary node for the VRRP group.")
|
|
216
206
|
tracking_object: Optional[List[TrackingObject]] = Field(
|
|
217
|
-
default=None,
|
|
207
|
+
default=None,
|
|
208
|
+
json_schema_extra={"vmanage_key": "tracking-object"},
|
|
209
|
+
description="List of tracking objects associated with the VRRP configuration.",
|
|
218
210
|
)
|
|
219
|
-
model_config = ConfigDict(populate_by_name=True)
|
|
211
|
+
model_config: ClassVar[ConfigDict] = ConfigDict(populate_by_name=True)
|
|
220
212
|
|
|
221
213
|
|
|
222
214
|
class Ipv6(FeatureTemplateValidator):
|
|
223
|
-
ipv6_link_local: ipaddress.IPv6Address = Field(
|
|
224
|
-
|
|
215
|
+
ipv6_link_local: ipaddress.IPv6Address = Field(
|
|
216
|
+
...,
|
|
217
|
+
json_schema_extra={"vmanage_key": "ipv6-link-local"},
|
|
218
|
+
description="IPv6 link-local address for the interface.",
|
|
219
|
+
)
|
|
220
|
+
prefix: Optional[ipaddress.IPv6Interface] = Field(
|
|
221
|
+
default=None, description="Optional IPv6 prefix for the interface, with CIDR notation."
|
|
222
|
+
)
|
|
225
223
|
model_config = ConfigDict(populate_by_name=True)
|
|
226
224
|
|
|
227
225
|
|
|
228
226
|
class Ipv6Vrrp(FeatureTemplateValidator):
|
|
229
|
-
grp_id: int = Field(json_schema_extra={"vmanage_key": "grp-id"})
|
|
230
|
-
priority: int =
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
227
|
+
grp_id: int = Field(..., json_schema_extra={"vmanage_key": "grp-id"}, description="IPv6 VRRP group ID.")
|
|
228
|
+
priority: int = Field(
|
|
229
|
+
default=DEFAULT_IPV6_VRRP_PRIORITY,
|
|
230
|
+
description="Priority value for the IPv6 VRRP group (higher values take precedence).",
|
|
231
|
+
)
|
|
232
|
+
timer: int = Field(
|
|
233
|
+
default=DEFAULT_IPV6_VRRP_TIMER, description="IPv6 VRRP advertisement interval timer in milliseconds."
|
|
234
|
+
)
|
|
235
|
+
track_omp: BoolStr = Field(
|
|
236
|
+
default=False,
|
|
237
|
+
json_schema_extra={"vmanage_key": "track-omp"},
|
|
238
|
+
description="Flag to track Overlay Management Protocol (OMP) session state for IPv6.",
|
|
239
|
+
)
|
|
240
|
+
track_prefix_list: Optional[str] = Field(
|
|
241
|
+
default=None,
|
|
242
|
+
json_schema_extra={"vmanage_key": "track-prefix-list"},
|
|
243
|
+
description="Name of the IPv6 prefix-list used for tracking specific routes.",
|
|
244
|
+
)
|
|
245
|
+
ipv6: Optional[List[Ipv6]] = Field(
|
|
246
|
+
default=None, description="List of IPv6 configurations associated with the VRRP group."
|
|
247
|
+
)
|
|
235
248
|
model_config = ConfigDict(populate_by_name=True)
|
|
236
249
|
|
|
237
250
|
|
|
238
251
|
class CiscoVpnInterfaceModel(FeatureTemplate):
|
|
239
252
|
model_config = ConfigDict(arbitrary_types_allowed=True, populate_by_name=True)
|
|
253
|
+
_docs_description: str = "Cisco VPN Interface Feature Template configuration"
|
|
240
254
|
|
|
241
|
-
if_name: Optional[str] = Field(
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
255
|
+
if_name: Optional[str] = Field(
|
|
256
|
+
default=None, description="The name of the interface.", json_schema_extra={"vmanage_key": "if-name"}
|
|
257
|
+
)
|
|
258
|
+
interface_description: Optional[str] = Field(
|
|
259
|
+
default=None, description="A description for the interface.", json_schema_extra={"vmanage_key": "description"}
|
|
260
|
+
)
|
|
261
|
+
poe: Optional[BoolStr] = Field(
|
|
262
|
+
default=None,
|
|
263
|
+
description="Power over Ethernet setting for the interface. True if enabled, False otherwise.",
|
|
264
|
+
)
|
|
265
|
+
ipv4_address: Optional[str] = Field(
|
|
266
|
+
default=None,
|
|
267
|
+
description="The primary IPv4 address assigned to the interface.",
|
|
268
|
+
json_schema_extra={"data_path": ["ip"], "vmanage_key": "address"},
|
|
269
|
+
)
|
|
245
270
|
secondary_ipv4_address: Optional[List[SecondaryIPv4Address]] = Field(
|
|
246
|
-
default=None,
|
|
271
|
+
default=None,
|
|
272
|
+
description="A list of secondary IPv4 addresses assigned to the interface.",
|
|
273
|
+
json_schema_extra={"data_path": ["ip"], "vmanage_key": "secondary-address"},
|
|
247
274
|
)
|
|
248
275
|
dhcp_ipv4_client: Optional[BoolStr] = Field(
|
|
249
|
-
default=None,
|
|
276
|
+
default=None,
|
|
277
|
+
description=(
|
|
278
|
+
"Whether DHCP client is enabled on the interface for IPv4 addressing. True if enabled, False otherwise."
|
|
279
|
+
),
|
|
280
|
+
json_schema_extra={"data_path": ["ip"], "vmanage_key": "dhcp-client"},
|
|
281
|
+
)
|
|
282
|
+
dhcp_distance: Optional[int] = Field(
|
|
283
|
+
default=None,
|
|
284
|
+
description="Administrative distance for DHCP routes on the interface.",
|
|
285
|
+
json_schema_extra={"vmanage_key": "dhcp-distance"},
|
|
250
286
|
)
|
|
251
|
-
dhcp_distance: Optional[int] = Field(default=None, json_schema_extra={"vmanage_key": "dhcp-distance"})
|
|
252
287
|
ipv6_address: Optional[ipaddress.IPv6Interface] = Field(
|
|
253
|
-
default=None,
|
|
288
|
+
default=None,
|
|
289
|
+
description="The primary IPv6 address assigned to the interface.",
|
|
290
|
+
json_schema_extra={"data_path": ["ipv6"], "vmanage_key": "address"},
|
|
254
291
|
)
|
|
255
292
|
dhcp_ipv6_client: Optional[BoolStr] = Field(
|
|
256
|
-
default=None,
|
|
293
|
+
default=None,
|
|
294
|
+
description=(
|
|
295
|
+
"Whether DHCP client is enabled on the interface for IPv6 addressing. True if enabled, False otherwise."
|
|
296
|
+
),
|
|
297
|
+
json_schema_extra={"data_path": ["ipv6"], "vmanage_key": "dhcp-client"},
|
|
257
298
|
)
|
|
258
299
|
secondary_ipv6_address: Optional[List[SecondaryIPv6Address]] = Field(
|
|
259
|
-
default=None,
|
|
300
|
+
default=None,
|
|
301
|
+
description="A list of secondary IPv6 addresses assigned to the interface.",
|
|
302
|
+
json_schema_extra={"data_path": ["ipv6"], "vmanage_key": "secondary-address"},
|
|
303
|
+
)
|
|
304
|
+
access_list_ipv4: Optional[List[AccessList]] = Field(
|
|
305
|
+
default=None,
|
|
306
|
+
description="A list of IPv4 access control lists (ACLs) applied to the interface.",
|
|
307
|
+
json_schema_extra={"vmanage_key": "access-list"},
|
|
260
308
|
)
|
|
261
|
-
access_list_ipv4: Optional[List[AccessList]] = Field(default=None, json_schema_extra={"vmanage_key": "access-list"})
|
|
262
309
|
dhcp_helper: Optional[List[ipaddress.IPv4Address]] = Field(
|
|
263
|
-
default=None,
|
|
310
|
+
default=None,
|
|
311
|
+
description="A list of DHCP helper addresses configured on the interface.",
|
|
312
|
+
json_schema_extra={"vmanage_key": "dhcp-helper"},
|
|
264
313
|
)
|
|
265
314
|
dhcp_helper_v6: Optional[List[DhcpHelperV6]] = Field(
|
|
266
|
-
default=None,
|
|
315
|
+
default=None,
|
|
316
|
+
description="A list of DHCPv6 helper configurations applied to the interface.",
|
|
317
|
+
json_schema_extra={"vmanage_key": "dhcp-helper-v6"},
|
|
318
|
+
)
|
|
319
|
+
tracker: Optional[List[str]] = Field(
|
|
320
|
+
default=None,
|
|
321
|
+
description="A list of tracker identifiers associated with the interface.",
|
|
267
322
|
)
|
|
268
|
-
tracker: Optional[List[str]] = None
|
|
269
323
|
auto_bandwidth_detect: Optional[BoolStr] = Field(
|
|
270
|
-
default=None,
|
|
324
|
+
default=None,
|
|
325
|
+
description=(
|
|
326
|
+
"Whether automatic bandwidth detection is enabled on the interface. True if enabled, False otherwise."
|
|
327
|
+
),
|
|
328
|
+
json_schema_extra={"vmanage_key": "auto-bandwidth-detect"},
|
|
271
329
|
)
|
|
272
330
|
iperf_server: Optional[ipaddress.IPv4Address] = Field(
|
|
273
|
-
default=None,
|
|
331
|
+
default=None,
|
|
332
|
+
description="The IP address of the iPerf server used for performance testing from this interface.",
|
|
333
|
+
json_schema_extra={"vmanage_key": "iperf-server"},
|
|
334
|
+
)
|
|
335
|
+
nat: Optional[BoolStr] = Field(
|
|
336
|
+
default=None,
|
|
337
|
+
description="Indicates whether Network Address Translation (NAT) is enabled on the interface.",
|
|
338
|
+
)
|
|
339
|
+
nat_choice: Optional[NatChoice] = Field(
|
|
340
|
+
default=None,
|
|
341
|
+
description="The type of NAT configured on the interface, if applicable.",
|
|
342
|
+
json_schema_extra={"vmanage_key": "nat-choice"},
|
|
343
|
+
)
|
|
344
|
+
udp_timeout: Optional[int] = Field(
|
|
345
|
+
default=None,
|
|
346
|
+
description="The timeout value in seconds for UDP connections through the NAT on this interface.",
|
|
347
|
+
json_schema_extra={"vmanage_key": "udp-timeout"},
|
|
348
|
+
)
|
|
349
|
+
tcp_timeout: Optional[int] = Field(
|
|
350
|
+
default=None,
|
|
351
|
+
description="The timeout value in seconds for TCP connections through the NAT on this interface.",
|
|
352
|
+
json_schema_extra={"vmanage_key": "tcp-timeout"},
|
|
274
353
|
)
|
|
275
|
-
nat: Optional[BoolStr] = None
|
|
276
|
-
nat_choice: Optional[NatChoice] = Field(default=None, json_schema_extra={"vmanage_key": "nat-choice"})
|
|
277
|
-
udp_timeout: Optional[int] = Field(default=None, json_schema_extra={"vmanage_key": "udp-timeout"})
|
|
278
|
-
tcp_timeout: Optional[int] = Field(default=None, json_schema_extra={"vmanage_key": "tcp-timeout"})
|
|
279
354
|
nat_range_start: Optional[ipaddress.IPv4Address] = Field(
|
|
280
|
-
default=None,
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
355
|
+
default=None,
|
|
356
|
+
description="The starting IP address in the range used for NAT on this interface.",
|
|
357
|
+
json_schema_extra={"vmanage_key": "range-start"},
|
|
358
|
+
)
|
|
359
|
+
nat_range_end: Optional[ipaddress.IPv4Address] = Field(
|
|
360
|
+
default=None,
|
|
361
|
+
description="The ending IP address in the range used for NAT on this interface.",
|
|
362
|
+
json_schema_extra={"vmanage_key": "range-end"},
|
|
363
|
+
)
|
|
364
|
+
overload: Optional[BoolStr] = Field(
|
|
365
|
+
default=None,
|
|
366
|
+
description="Indicates if NAT overload (PAT - Port Address Translation) is enabled.",
|
|
367
|
+
)
|
|
368
|
+
loopback_interface: Optional[str] = Field(
|
|
369
|
+
default=None,
|
|
370
|
+
description="The associated loopback interface, if any, for the VPN interface.",
|
|
371
|
+
json_schema_extra={"vmanage_key": "loopback-interface"},
|
|
372
|
+
)
|
|
373
|
+
prefix_length: Optional[int] = Field(
|
|
374
|
+
default=None,
|
|
375
|
+
description="The prefix length for the interface's IP address, indicating the size of the subnet.",
|
|
376
|
+
json_schema_extra={"vmanage_key": "prefix-length"},
|
|
377
|
+
)
|
|
378
|
+
enable: Optional[BoolStr] = Field(
|
|
379
|
+
default=None,
|
|
380
|
+
description="Indicates whether the interface is enabled or disabled.",
|
|
381
|
+
)
|
|
382
|
+
nat64: Optional[BoolStr] = Field(
|
|
383
|
+
default=None,
|
|
384
|
+
description=(
|
|
385
|
+
"Indicates whether NAT64 is enabled on the interface, "
|
|
386
|
+
"allowing IPv6 addresses to communicate with IPv4 services."
|
|
387
|
+
),
|
|
388
|
+
)
|
|
389
|
+
nat66: Optional[BoolStr] = Field(
|
|
390
|
+
default=None,
|
|
391
|
+
description=(
|
|
392
|
+
"Indicates whether NAT66 is enabled on the interface, translating IPv6 addresses into IPv6 addresses."
|
|
393
|
+
),
|
|
394
|
+
)
|
|
395
|
+
static_nat66: Optional[List[StaticNat66]] = Field(
|
|
396
|
+
default=None,
|
|
397
|
+
description="List of static NAT66 entries for translating IPv6 addresses into other IPv6 addresses.",
|
|
398
|
+
json_schema_extra={"vmanage_key": "static-nat66"},
|
|
399
|
+
)
|
|
400
|
+
|
|
290
401
|
static: Optional[List[Static]] = Field(
|
|
291
|
-
default=None,
|
|
402
|
+
default=None,
|
|
403
|
+
description="List of static NAT entries for configuring one-to-one address mappings.",
|
|
404
|
+
json_schema_extra={"data_path": ["nat"], "vmanage_key": "static"},
|
|
292
405
|
)
|
|
293
406
|
static_port_forward: Optional[List[StaticPortForward]] = Field(
|
|
294
|
-
default=None,
|
|
407
|
+
default=None,
|
|
408
|
+
description="List of static port forwarding entries for the interface.",
|
|
409
|
+
json_schema_extra={"vmanage_key": "static-port-forward"},
|
|
410
|
+
)
|
|
411
|
+
enable_core_region: Optional[BoolStr] = Field(
|
|
412
|
+
default=None,
|
|
413
|
+
description="Indicates if the interface is part of the core network region for centralized services.",
|
|
414
|
+
json_schema_extra={"vmanage_key": "enable-core-region"},
|
|
415
|
+
)
|
|
416
|
+
core_region: Optional[CoreRegion] = Field(
|
|
417
|
+
default=None,
|
|
418
|
+
json_schema_extra={"vmanage_key": "core-region"},
|
|
419
|
+
description="Configuration details for the core region.",
|
|
295
420
|
)
|
|
296
|
-
enable_core_region: Optional[BoolStr] = Field(default=None, json_schema_extra={"vmanage_key": "enable-core-region"})
|
|
297
|
-
core_region: Optional[CoreRegion] = Field(default=None, json_schema_extra={"vmanage_key": "core-region"})
|
|
298
421
|
secondary_region: Optional[SecondaryRegion] = Field(
|
|
299
|
-
default=None,
|
|
422
|
+
default=None,
|
|
423
|
+
json_schema_extra={"vmanage_key": "secondary-region"},
|
|
424
|
+
description="Configuration details for a secondary region.",
|
|
300
425
|
)
|
|
301
426
|
tloc_encapsulation: Optional[List[Encapsulation]] = Field(
|
|
302
|
-
default=None,
|
|
427
|
+
default=None,
|
|
428
|
+
json_schema_extra={"vmanage_key": "encapsulation", "data_path": ["tunnel-interface"]},
|
|
429
|
+
description="Transport Location (TLOC) encapsulation settings.",
|
|
430
|
+
)
|
|
431
|
+
border: Optional[BoolStr] = Field(
|
|
432
|
+
default=None,
|
|
433
|
+
json_schema_extra={"data_path": ["tunnel-interface"]},
|
|
434
|
+
description="Defines if the interface is at the border of a network segment.",
|
|
435
|
+
)
|
|
436
|
+
per_tunnel_qos: Optional[BoolStr] = Field(
|
|
437
|
+
default=None,
|
|
438
|
+
json_schema_extra={"vmanage_key": "per-tunnel-qos"},
|
|
439
|
+
description="Enable or disable per-tunnel Quality of Service (QoS).",
|
|
303
440
|
)
|
|
304
|
-
border: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface"]})
|
|
305
|
-
per_tunnel_qos: Optional[BoolStr] = Field(default=None, json_schema_extra={"vmanage_key": "per-tunnel-qos"})
|
|
306
441
|
per_tunnel_qos_aggregator: Optional[BoolStr] = Field(
|
|
307
|
-
default=None,
|
|
442
|
+
default=None,
|
|
443
|
+
json_schema_extra={"vmanage_key": "per-tunnel-qos-aggregator"},
|
|
444
|
+
description="Enable or disable per-tunnel QoS aggregator.",
|
|
445
|
+
)
|
|
446
|
+
mode: Optional[Mode] = Field(default=None, description="Defines the operating mode for the interface.")
|
|
447
|
+
tunnels_bandwidth: Optional[int] = Field(
|
|
448
|
+
default=None,
|
|
449
|
+
json_schema_extra={"vmanage_key": "tunnels-bandwidth"},
|
|
450
|
+
description="Specifies the total bandwidth available across all tunnels.",
|
|
451
|
+
)
|
|
452
|
+
group: Optional[List[int]] = Field(
|
|
453
|
+
default=None,
|
|
454
|
+
json_schema_extra={"data_path": ["tunnel-interface"]},
|
|
455
|
+
description="Identifies the group or groups the interface belongs to.",
|
|
456
|
+
)
|
|
457
|
+
value: Optional[TLOCColor] = Field(
|
|
458
|
+
default=None,
|
|
459
|
+
json_schema_extra={"data_path": ["tunnel-interface", "color"]},
|
|
460
|
+
description=(
|
|
461
|
+
"The value field often corresponds to a specific attribute or setting, such as color in this context."
|
|
462
|
+
),
|
|
308
463
|
)
|
|
309
|
-
mode: Optional[Mode] = None
|
|
310
|
-
tunnels_bandwidth: Optional[int] = Field(default=None, json_schema_extra={"vmanage_key": "tunnels-bandwidth"})
|
|
311
|
-
group: Optional[List[int]] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface"]})
|
|
312
|
-
value: Optional[Value] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface", "color"]})
|
|
313
464
|
max_control_connections: Optional[int] = Field(
|
|
314
|
-
default=None,
|
|
465
|
+
default=None,
|
|
466
|
+
json_schema_extra={"vmanage_key": "max-control-connections", "data_path": ["tunnel-interface"]},
|
|
467
|
+
description="Maximum number of control connections that can be established on the interface.",
|
|
315
468
|
)
|
|
316
469
|
control_connections: Optional[BoolStr] = Field(
|
|
317
|
-
default=None,
|
|
470
|
+
default=None,
|
|
471
|
+
json_schema_extra={"vmanage_key": "control-connections", "data_path": ["tunnel-interface"]},
|
|
472
|
+
description="Enables or disables control connections on the interface.",
|
|
318
473
|
)
|
|
319
474
|
vbond_as_stun_server: Optional[BoolStr] = Field(
|
|
320
|
-
default=None,
|
|
475
|
+
default=None,
|
|
476
|
+
json_schema_extra={"vmanage_key": "vbond-as-stun-server", "data_path": ["tunnel-interface"]},
|
|
477
|
+
description="Configures the vBond orchestrator to act as a STUN server for the interface.",
|
|
321
478
|
)
|
|
322
479
|
exclude_controller_group_list: Optional[List[int]] = Field(
|
|
323
480
|
default=None,
|
|
324
481
|
json_schema_extra={"vmanage_key": "exclude-controller-group-list", "data_path": ["tunnel-interface"]},
|
|
482
|
+
description="List of controller groups to exclude from connections.",
|
|
325
483
|
)
|
|
326
484
|
vmanage_connection_preference: Optional[int] = Field(
|
|
327
485
|
default=None,
|
|
328
486
|
json_schema_extra={"vmanage_key": "vmanage-connection-preference", "data_path": ["tunnel-interface"]},
|
|
487
|
+
description="Preference value for establishing vManage connections.",
|
|
329
488
|
)
|
|
330
489
|
port_hop: Optional[BoolStr] = Field(
|
|
331
|
-
default=None,
|
|
490
|
+
default=None,
|
|
491
|
+
json_schema_extra={"vmanage_key": "port-hop", "data_path": ["tunnel-interface"]},
|
|
492
|
+
description="Enables or disables port hopping for the interface to evade port blocking.",
|
|
493
|
+
)
|
|
494
|
+
restrict: Optional[BoolStr] = Field(
|
|
495
|
+
default=None,
|
|
496
|
+
json_schema_extra={"data_path": ["tunnel-interface", "color"]},
|
|
497
|
+
description="Indicates whether the interface color is restricted for use.",
|
|
332
498
|
)
|
|
333
|
-
restrict: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface", "color"]})
|
|
334
499
|
dst_ip: Optional[ipaddress.IPv4Address] = Field(
|
|
335
500
|
default=None,
|
|
336
501
|
json_schema_extra={"vmanage_key": "dst-ip", "data_path": ["tunnel-interface", "tloc-extension-gre-to"]},
|
|
502
|
+
description="Destination IP address for GRE (Generic Routing Encapsulation) tunnel extension.",
|
|
503
|
+
)
|
|
504
|
+
carrier: Optional[Carrier] = Field(
|
|
505
|
+
default=None,
|
|
506
|
+
json_schema_extra={"data_path": ["tunnel-interface"]},
|
|
507
|
+
description="Specifies the carrier information for the tunnel interface.",
|
|
337
508
|
)
|
|
338
|
-
carrier: Optional[Carrier] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface"]})
|
|
339
509
|
nat_refresh_interval: Optional[int] = Field(
|
|
340
|
-
default=None,
|
|
510
|
+
default=None,
|
|
511
|
+
json_schema_extra={"vmanage_key": "nat-refresh-interval", "data_path": ["tunnel-interface"]},
|
|
512
|
+
description="Interval in seconds to refresh NAT (Network Address Translation) mappings.",
|
|
341
513
|
)
|
|
342
514
|
hello_interval: Optional[int] = Field(
|
|
343
|
-
default=None,
|
|
515
|
+
default=None,
|
|
516
|
+
json_schema_extra={"vmanage_key": "hello-interval", "data_path": ["tunnel-interface"]},
|
|
517
|
+
description="Time interval in seconds between successive hello packets sent over the tunnel interface.",
|
|
344
518
|
)
|
|
345
519
|
hello_tolerance: Optional[int] = Field(
|
|
346
|
-
default=None,
|
|
520
|
+
default=None,
|
|
521
|
+
json_schema_extra={"vmanage_key": "hello-tolerance", "data_path": ["tunnel-interface"]},
|
|
522
|
+
description="Time in seconds to wait before declaring a neighbor down due to missing hello packets.",
|
|
523
|
+
)
|
|
524
|
+
bind: Optional[str] = Field(
|
|
525
|
+
default=None,
|
|
526
|
+
json_schema_extra={"data_path": ["tunnel-interface"]},
|
|
527
|
+
description="Interface or IP address to which the tunnel interface is bound.",
|
|
347
528
|
)
|
|
348
|
-
bind: Optional[str] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface"]})
|
|
349
529
|
last_resort_circuit: Optional[BoolStr] = Field(
|
|
350
|
-
default=None,
|
|
530
|
+
default=None,
|
|
531
|
+
json_schema_extra={"vmanage_key": "last-resort-circuit", "data_path": ["tunnel-interface"]},
|
|
532
|
+
description="Marks the interface as a last resort circuit for traffic to fall back to.",
|
|
351
533
|
)
|
|
352
534
|
low_bandwidth_link: Optional[BoolStr] = Field(
|
|
353
|
-
default=None,
|
|
535
|
+
default=None,
|
|
536
|
+
json_schema_extra={"vmanage_key": "low-bandwidth-link", "data_path": ["tunnel-interface"]},
|
|
537
|
+
description="Indicates if the link is considered a low bandwidth link.",
|
|
354
538
|
)
|
|
355
539
|
tunnel_tcp_mss_adjust: Optional[int] = Field(
|
|
356
|
-
default=None,
|
|
540
|
+
default=None,
|
|
541
|
+
json_schema_extra={"vmanage_key": "tunnel-tcp-mss-adjust", "data_path": ["tunnel-interface"]},
|
|
542
|
+
description="Adjusts the Maximum Segment Size (MSS) value for TCP connections over the tunnel.",
|
|
357
543
|
)
|
|
358
544
|
clear_dont_fragment: Optional[BoolStr] = Field(
|
|
359
|
-
default=None,
|
|
545
|
+
default=None,
|
|
546
|
+
json_schema_extra={"vmanage_key": "clear-dont-fragment", "data_path": ["tunnel-interface"]},
|
|
547
|
+
description="Enables or disables the clearing of the 'Don't Fragment' (DF) bit in the IP header.",
|
|
360
548
|
)
|
|
361
549
|
propagate_sgt: Optional[BoolStr] = Field(
|
|
362
|
-
default=None,
|
|
550
|
+
default=None,
|
|
551
|
+
json_schema_extra={"data_path": ["tunnel-interface"], "vmanage_key": "propagate-sgt"},
|
|
552
|
+
description="Enables or disables the propagation of Security Group Tags (SGTs) across the tunnel interface.",
|
|
363
553
|
)
|
|
364
554
|
network_broadcast: Optional[BoolStr] = Field(
|
|
365
|
-
default=None,
|
|
555
|
+
default=None,
|
|
556
|
+
json_schema_extra={"vmanage_key": "network-broadcast", "data_path": ["tunnel-interface"]},
|
|
557
|
+
description="Allows or disallows network broadcast traffic through the tunnel interface.",
|
|
558
|
+
)
|
|
559
|
+
all: Optional[BoolStr] = Field(
|
|
560
|
+
default=None,
|
|
561
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
562
|
+
description="Permits or denies all services through the tunnel interface.",
|
|
563
|
+
)
|
|
564
|
+
bgp: Optional[BoolStr] = Field(
|
|
565
|
+
default=None,
|
|
566
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
567
|
+
description="Allows or disallows Border Gateway Protocol (BGP) traffic through the tunnel interface.",
|
|
366
568
|
)
|
|
367
|
-
all: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]})
|
|
368
|
-
bgp: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]})
|
|
369
569
|
dhcp: Optional[BoolStr] = Field(
|
|
370
|
-
default=None,
|
|
570
|
+
default=None,
|
|
571
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
572
|
+
description="Enables or disables Dynamic Host Configuration Protocol (DHCP) on the tunnel interface.",
|
|
573
|
+
)
|
|
574
|
+
dns: Optional[BoolStr] = Field(
|
|
575
|
+
default=None,
|
|
576
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
577
|
+
description="Allows or disallows Domain Name System (DNS) queries through the tunnel interface.",
|
|
371
578
|
)
|
|
372
|
-
dns: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]})
|
|
373
579
|
icmp: Optional[BoolStr] = Field(
|
|
374
|
-
default=None,
|
|
580
|
+
default=None,
|
|
581
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
582
|
+
description=(
|
|
583
|
+
"Enables or disables Internet Control Message Protocol (ICMP) "
|
|
584
|
+
"for ping and traceroute through the tunnel interface."
|
|
585
|
+
),
|
|
375
586
|
)
|
|
376
587
|
sshd: Optional[BoolStr] = Field(
|
|
377
|
-
default=None,
|
|
588
|
+
default=None,
|
|
589
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
590
|
+
description="Allows or disallows Secure Shell (SSH) daemon access through the tunnel interface.",
|
|
378
591
|
)
|
|
379
592
|
netconf: Optional[BoolStr] = Field(
|
|
380
|
-
default=None,
|
|
593
|
+
default=None,
|
|
594
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
595
|
+
description="Enables or disables NETCONF protocol support on the tunnel interface.",
|
|
596
|
+
)
|
|
597
|
+
ntp: Optional[BoolStr] = Field(
|
|
598
|
+
default=None,
|
|
599
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
600
|
+
description="Allows or disallows Network Time Protocol (NTP) synchronization through the tunnel interface.",
|
|
381
601
|
)
|
|
382
|
-
ntp: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]})
|
|
383
602
|
ospf: Optional[BoolStr] = Field(
|
|
384
|
-
default=None,
|
|
603
|
+
default=None,
|
|
604
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
605
|
+
description=(
|
|
606
|
+
"Permits or denies Open Shortest Path First (OSPF) routing protocol traffic through the tunnel interface."
|
|
607
|
+
),
|
|
385
608
|
)
|
|
386
609
|
stun: Optional[BoolStr] = Field(
|
|
387
|
-
default=None,
|
|
610
|
+
default=None,
|
|
611
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
612
|
+
description="Enables or disables Session Traversal Utilities for NAT (STUN) on the tunnel interface.",
|
|
388
613
|
)
|
|
389
614
|
snmp: Optional[BoolStr] = Field(
|
|
390
|
-
default=None,
|
|
615
|
+
default=None,
|
|
616
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
617
|
+
description="Allows or disallows Simple Network Management Protocol (SNMP) through the tunnel interface.",
|
|
391
618
|
)
|
|
392
619
|
https: Optional[BoolStr] = Field(
|
|
393
|
-
default=None,
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
620
|
+
default=None,
|
|
621
|
+
json_schema_extra={"data_path": ["tunnel-interface", "allow-service"]},
|
|
622
|
+
description="Permits or denies HTTPS traffic through the tunnel interface.",
|
|
623
|
+
)
|
|
624
|
+
media_type: Optional[MediaType] = Field(
|
|
625
|
+
default=None,
|
|
626
|
+
json_schema_extra={"vmanage_key": "media-type"},
|
|
627
|
+
description="Specifies the media type used by the interface, such as copper or fiber.",
|
|
628
|
+
)
|
|
629
|
+
intrf_mtu: Optional[int] = Field(
|
|
630
|
+
default=None,
|
|
631
|
+
json_schema_extra={"vmanage_key": "intrf-mtu"},
|
|
632
|
+
description="Sets the Maximum Transmission Unit (MTU) size for the interface.",
|
|
633
|
+
)
|
|
634
|
+
mtu: Optional[int] = Field(default=None, description="Specifies the MTU size for the tunnel or logical interface.")
|
|
635
|
+
tcp_mss_adjust: Optional[int] = Field(
|
|
636
|
+
default=None,
|
|
637
|
+
json_schema_extra={"vmanage_key": "tcp-mss-adjust"},
|
|
638
|
+
description="Adjusts the TCP Maximum Segment Size (MSS) value for connections over the interface.",
|
|
639
|
+
)
|
|
640
|
+
tloc_extension: Optional[str] = Field(
|
|
641
|
+
default=None,
|
|
642
|
+
json_schema_extra={"vmanage_key": "tloc-extension"},
|
|
643
|
+
description="Defines the Transport Location (TLOC) extension for the interface.",
|
|
644
|
+
)
|
|
645
|
+
load_interval: Optional[int] = Field(
|
|
646
|
+
default=None,
|
|
647
|
+
json_schema_extra={"vmanage_key": "load-interval"},
|
|
648
|
+
description="Sets the time interval in seconds for calculating interface load statistics.",
|
|
649
|
+
)
|
|
401
650
|
src_ip: Optional[ipaddress.IPv4Address] = Field(
|
|
402
|
-
default=None,
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
651
|
+
default=None,
|
|
652
|
+
json_schema_extra={"vmanage_key": "src-ip", "data_path": ["tloc-extension-gre-from"]},
|
|
653
|
+
description="Source IP address for GRE tunnel extension.",
|
|
654
|
+
)
|
|
655
|
+
xconnect: Optional[str] = Field(
|
|
656
|
+
default=None,
|
|
657
|
+
json_schema_extra={"data_path": ["tloc-extension-gre-from"]},
|
|
658
|
+
description="Cross-connect identifier for the GRE tunnel extension.",
|
|
659
|
+
)
|
|
660
|
+
mac_address: Optional[str] = Field(
|
|
661
|
+
default=None,
|
|
662
|
+
json_schema_extra={"vmanage_key": "mac-address"},
|
|
663
|
+
description="Specifies the MAC address for the interface.",
|
|
664
|
+
)
|
|
665
|
+
speed: Optional[Speed] = Field(
|
|
666
|
+
default=None, description="Defines the speed of the interface, such as 10Mbps, 100Mbps, or 1Gbps."
|
|
667
|
+
)
|
|
668
|
+
duplex: Optional[Duplex] = Field(
|
|
669
|
+
default=None, description="Sets the duplex mode for the interface, such as full or half duplex."
|
|
670
|
+
)
|
|
671
|
+
shutdown: Optional[BoolStr] = Field(default=False, description="Enables or disables (shuts down) the interface.")
|
|
672
|
+
arp_timeout: Optional[int] = Field(
|
|
673
|
+
default=None,
|
|
674
|
+
json_schema_extra={"vmanage_key": "arp-timeout"},
|
|
675
|
+
description="Time in seconds before an ARP cache entry is timed out.",
|
|
676
|
+
)
|
|
677
|
+
autonegotiate: Optional[BoolStr] = Field(
|
|
678
|
+
default=None, description="Enables or disables autonegotiation of speed and duplex settings on the interface."
|
|
679
|
+
)
|
|
411
680
|
ip_directed_broadcast: Optional[BoolStr] = Field(
|
|
412
|
-
default=None,
|
|
681
|
+
default=None,
|
|
682
|
+
json_schema_extra={"vmanage_key": "ip-directed-broadcast"},
|
|
683
|
+
description="Allows or disallows IP directed broadcasts on the interface.",
|
|
413
684
|
)
|
|
414
685
|
icmp_redirect_disable: Optional[BoolStr] = Field(
|
|
415
|
-
default=None,
|
|
686
|
+
default=None,
|
|
687
|
+
json_schema_extra={"vmanage_key": "icmp-redirect-disable"},
|
|
688
|
+
description="Enables or disables ICMP redirect messages on the interface.",
|
|
689
|
+
)
|
|
690
|
+
qos_adaptive: Optional[BoolStr] = Field(
|
|
691
|
+
default=None,
|
|
692
|
+
json_schema_extra={"vmanage_key": "qos-adaptive"},
|
|
693
|
+
description="Activates or deactivates adaptive QoS on the interface.",
|
|
694
|
+
)
|
|
695
|
+
period: Optional[int] = Field(
|
|
696
|
+
default=None,
|
|
697
|
+
json_schema_extra={"data_path": ["qos-adaptive"]},
|
|
698
|
+
description="Time period in seconds for measuring and adapting QoS settings.",
|
|
416
699
|
)
|
|
417
|
-
qos_adaptive: Optional[BoolStr] = Field(default=None, json_schema_extra={"vmanage_key": "qos-adaptive"})
|
|
418
|
-
period: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["qos-adaptive"]})
|
|
419
700
|
bandwidth_down: Optional[int] = Field(
|
|
420
|
-
default=None,
|
|
701
|
+
default=None,
|
|
702
|
+
json_schema_extra={"vmanage_key": "bandwidth-down", "data_path": ["qos-adaptive", "downstream"]},
|
|
703
|
+
description="Specifies the downstream bandwidth in Kbps for adaptive QoS calculations.",
|
|
704
|
+
)
|
|
705
|
+
dmin: Optional[int] = Field(
|
|
706
|
+
default=None,
|
|
707
|
+
json_schema_extra={"data_path": ["qos-adaptive", "downstream", "range"]},
|
|
708
|
+
description="Specifies the minimum downstream bandwidth in Kbps for adaptive QoS.",
|
|
709
|
+
)
|
|
710
|
+
dmax: Optional[int] = Field(
|
|
711
|
+
default=None,
|
|
712
|
+
json_schema_extra={"data_path": ["qos-adaptive", "downstream", "range"]},
|
|
713
|
+
description="Specifies the maximum downstream bandwidth in Kbps for adaptive QoS.",
|
|
421
714
|
)
|
|
422
|
-
dmin: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["qos-adaptive", "downstream", "range"]})
|
|
423
|
-
dmax: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["qos-adaptive", "downstream", "range"]})
|
|
424
715
|
bandwidth_up: Optional[int] = Field(
|
|
425
|
-
default=None,
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
716
|
+
default=None,
|
|
717
|
+
json_schema_extra={"vmanage_key": "bandwidth-up", "data_path": ["qos-adaptive", "upstream"]},
|
|
718
|
+
description="Specifies the upstream bandwidth in Kbps for adaptive QoS calculations.",
|
|
719
|
+
)
|
|
720
|
+
umin: Optional[int] = Field(
|
|
721
|
+
default=None,
|
|
722
|
+
json_schema_extra={"data_path": ["qos-adaptive", "upstream", "range"]},
|
|
723
|
+
description="Specifies the minimum upstream bandwidth in Kbps for adaptive QoS.",
|
|
724
|
+
)
|
|
725
|
+
umax: Optional[int] = Field(
|
|
726
|
+
default=None,
|
|
727
|
+
json_schema_extra={"data_path": ["qos-adaptive", "upstream", "range"]},
|
|
728
|
+
description="Specifies the maximum upstream bandwidth in Kbps for adaptive QoS.",
|
|
729
|
+
)
|
|
730
|
+
shaping_rate: Optional[int] = Field(
|
|
731
|
+
default=None,
|
|
732
|
+
json_schema_extra={"vmanage_key": "shaping-rate"},
|
|
733
|
+
description="Defines the traffic shaping rate for the interface.",
|
|
734
|
+
)
|
|
735
|
+
qos_map: Optional[str] = Field(
|
|
736
|
+
default=None,
|
|
737
|
+
json_schema_extra={"vmanage_key": "qos-map"},
|
|
738
|
+
description="Associates a QoS map with the interface for traffic classification and prioritization.",
|
|
739
|
+
)
|
|
740
|
+
qos_map_vpn: Optional[str] = Field(
|
|
741
|
+
default=None,
|
|
742
|
+
json_schema_extra={"vmanage_key": "qos-map-vpn"},
|
|
743
|
+
description="Associates a QoS map with a VPN for traffic classification and prioritization within the VPN.",
|
|
744
|
+
)
|
|
745
|
+
service_provider: Optional[str] = Field(
|
|
746
|
+
default=None,
|
|
747
|
+
json_schema_extra={"vmanage_key": "service-provider"},
|
|
748
|
+
description="Identifies the service provider associated with the interface.",
|
|
749
|
+
)
|
|
750
|
+
bandwidth_upstream: Optional[int] = Field(
|
|
751
|
+
default=None,
|
|
752
|
+
json_schema_extra={"vmanage_key": "bandwidth-upstream"},
|
|
753
|
+
description="Specifies the upstream bandwidth in Kbps available on the interface.",
|
|
754
|
+
)
|
|
755
|
+
bandwidth_downstream: Optional[int] = Field(
|
|
756
|
+
default=None,
|
|
757
|
+
json_schema_extra={"vmanage_key": "bandwidth-downstream"},
|
|
758
|
+
description="Specifies the downstream bandwidth in Kbps available on the interface.",
|
|
759
|
+
)
|
|
435
760
|
block_non_source_ip: Optional[BoolStr] = Field(
|
|
436
|
-
default=None,
|
|
761
|
+
default=None,
|
|
762
|
+
json_schema_extra={"vmanage_key": "block-non-source-ip"},
|
|
763
|
+
description="Enables or disables blocking of traffic with non-matching source IP addresses.",
|
|
437
764
|
)
|
|
438
765
|
rule_name: Optional[str] = Field(
|
|
439
|
-
default=None,
|
|
766
|
+
default=None,
|
|
767
|
+
json_schema_extra={"vmanage_key": "rule-name", "data_path": ["rewrite-rule"]},
|
|
768
|
+
description="Specifies the name of the rewrite rule applied to the interface.",
|
|
440
769
|
)
|
|
441
770
|
access_list_ipv6: Optional[List[AccessList]] = Field(
|
|
442
|
-
default=None,
|
|
771
|
+
default=None,
|
|
772
|
+
json_schema_extra={"data_path": ["ipv6"], "vmanage_key": "access-list"},
|
|
773
|
+
description="Defines a list of access control entries for IPv6 traffic filtering.",
|
|
774
|
+
)
|
|
775
|
+
ip: Optional[List[Ip]] = Field(
|
|
776
|
+
default=None,
|
|
777
|
+
json_schema_extra={"data_path": ["arp"]},
|
|
778
|
+
description="A list of IP configurations for Address Resolution Protocol (ARP) settings.",
|
|
779
|
+
)
|
|
780
|
+
vrrp: Optional[List[Vrrp]] = Field(
|
|
781
|
+
default=None,
|
|
782
|
+
json_schema_extra={"vmanage_key": "vrrp"},
|
|
783
|
+
description="A list of Virtual Router Redundancy Protocol (VRRP) configurations for IPv4.",
|
|
784
|
+
)
|
|
785
|
+
ipv6_vrrp: Optional[List[Ipv6Vrrp]] = Field(
|
|
786
|
+
default=None,
|
|
787
|
+
json_schema_extra={"vmanage_key": "ipv6-vrrp"},
|
|
788
|
+
description="A list of Virtual Router Redundancy Protocol (VRRP) configurations for IPv6.",
|
|
443
789
|
)
|
|
444
|
-
ip: Optional[List[Ip]] = Field(default=None, json_schema_extra={"data_path": ["arp"]})
|
|
445
|
-
vrrp: Optional[List[Vrrp]] = Field(default=None, json_schema_extra={"vmanage_key": "vrrp"})
|
|
446
|
-
ipv6_vrrp: Optional[List[Ipv6Vrrp]] = Field(default=None, json_schema_extra={"vmanage_key": "ipv6-vrrp"})
|
|
447
790
|
enable_sgt_propagation: Optional[BoolStr] = Field(
|
|
448
|
-
default=None,
|
|
791
|
+
default=None,
|
|
792
|
+
json_schema_extra={"data_path": ["trustsec", "propagate"], "vmanage_key": "sgt"},
|
|
793
|
+
description="Enables or disables Security Group Tag (SGT) propagation.",
|
|
449
794
|
)
|
|
450
795
|
security_group_tag: Optional[int] = Field(
|
|
451
|
-
default=None,
|
|
796
|
+
default=None,
|
|
797
|
+
json_schema_extra={"data_path": ["trustsec", "static"], "vmanage_key": "sgt"},
|
|
798
|
+
description="Specifies a static Security Group Tag (SGT) for the interface.",
|
|
799
|
+
)
|
|
800
|
+
trusted: Optional[BoolStr] = Field(
|
|
801
|
+
default=None,
|
|
802
|
+
json_schema_extra={"data_path": ["trustsec", "static"]},
|
|
803
|
+
description="Marks the interface as trusted or untrusted for TrustSec.",
|
|
452
804
|
)
|
|
453
|
-
trusted: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["trustsec", "static"]})
|
|
454
805
|
enable_sgt_authorization_and_forwarding: Optional[BoolStr] = Field(
|
|
455
|
-
default=None,
|
|
806
|
+
default=None,
|
|
807
|
+
json_schema_extra={"data_path": ["trustsec"], "vmanage_key": "enable"},
|
|
808
|
+
description="Enables or disables Security Group Tag (SGT) authorization and forwarding.",
|
|
456
809
|
)
|
|
457
810
|
enable_sgt_enforcement: Optional[BoolStr] = Field(
|
|
458
|
-
default=None,
|
|
811
|
+
default=None,
|
|
812
|
+
json_schema_extra={"data_path": ["trustsec", "enforcement"], "vmanage_key": "enable"},
|
|
813
|
+
description="Activates or deactivates Security Group Tag (SGT) enforcement.",
|
|
459
814
|
)
|
|
460
815
|
enforcement_sgt: Optional[int] = Field(
|
|
461
|
-
default=None,
|
|
816
|
+
default=None,
|
|
817
|
+
json_schema_extra={"data_path": ["trustsec", "enforcement"], "vmanage_key": "sgt"},
|
|
818
|
+
description="Specifies the Security Group Tag (SGT) to be enforced on the interface.",
|
|
462
819
|
)
|
|
463
820
|
|
|
464
821
|
payload_path: ClassVar[Path] = Path(__file__).parent / "DEPRECATED"
|