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,258 +1,509 @@
|
|
|
1
1
|
# Copyright 2023 Cisco Systems, Inc. and its affiliates
|
|
2
2
|
|
|
3
|
-
from enum import Enum
|
|
4
3
|
from pathlib import Path
|
|
5
|
-
from typing import ClassVar, List, Optional
|
|
4
|
+
from typing import ClassVar, List, Literal, Optional
|
|
6
5
|
|
|
7
6
|
from pydantic import ConfigDict, Field
|
|
8
7
|
|
|
9
8
|
from catalystwan.api.templates.bool_str import BoolStr
|
|
10
9
|
from catalystwan.api.templates.feature_template import FeatureTemplate, FeatureTemplateValidator
|
|
11
10
|
|
|
11
|
+
NeighborFamilyType = Literal["ipv4-unicast", "vpnv4-unicast", "vpnv6-unicast"]
|
|
12
|
+
Direction = Literal["in", "out"]
|
|
13
|
+
Protocol = Literal["static", "connected", "ospf", "ospfv3", "omp", "eigrp", "nat"]
|
|
14
|
+
AddressFamilyType = Literal["ipv4-unicast"]
|
|
15
|
+
IPv6NeighborFamilyType = Literal["ipv6-unicast"]
|
|
16
|
+
|
|
12
17
|
|
|
13
18
|
class Export(FeatureTemplateValidator):
|
|
14
|
-
asn_ip: str = Field(
|
|
19
|
+
asn_ip: str = Field(
|
|
20
|
+
description="The ASN or IP address to be used as the export route target.",
|
|
21
|
+
json_schema_extra={"vmanage_key": "asn-ip"},
|
|
22
|
+
)
|
|
15
23
|
model_config = ConfigDict(populate_by_name=True)
|
|
16
24
|
|
|
17
25
|
|
|
18
26
|
class Import(FeatureTemplateValidator):
|
|
19
|
-
asn_ip: str = Field(
|
|
27
|
+
asn_ip: str = Field(
|
|
28
|
+
description="The ASN or IP address to be used as the import route target.",
|
|
29
|
+
json_schema_extra={"vmanage_key": "asn-ip"},
|
|
30
|
+
)
|
|
20
31
|
model_config = ConfigDict(populate_by_name=True)
|
|
21
32
|
|
|
22
33
|
|
|
23
34
|
class RouteTargetIpv4(FeatureTemplateValidator):
|
|
24
|
-
vpn_id: int = Field(
|
|
25
|
-
|
|
26
|
-
|
|
35
|
+
vpn_id: int = Field(
|
|
36
|
+
description="VPN identifier associated with the IPv4 route target.", json_schema_extra={"vmanage_key": "vpn-id"}
|
|
37
|
+
)
|
|
38
|
+
export: List[Export] = Field(description="List of export route targets.")
|
|
39
|
+
import_: List[Import] = Field(
|
|
40
|
+
description="List of import route targets.", json_schema_extra={"vmanage_key": "import"}
|
|
41
|
+
)
|
|
27
42
|
model_config = ConfigDict(populate_by_name=True)
|
|
28
43
|
|
|
29
44
|
|
|
30
45
|
class RouteTargetIpv6(FeatureTemplateValidator):
|
|
31
|
-
vpn_id: int = Field(
|
|
32
|
-
|
|
33
|
-
|
|
46
|
+
vpn_id: int = Field(
|
|
47
|
+
description="VPN identifier associated with the IPv6 route target.", json_schema_extra={"vmanage_key": "vpn-id"}
|
|
48
|
+
)
|
|
49
|
+
export: List[Export] = Field(description="List of export route targets.")
|
|
50
|
+
import_: List[Import] = Field(
|
|
51
|
+
description="List of import route targets.", json_schema_extra={"vmanage_key": "import"}
|
|
52
|
+
)
|
|
34
53
|
model_config = ConfigDict(populate_by_name=True)
|
|
35
54
|
|
|
36
55
|
|
|
37
56
|
class MplsInterface(FeatureTemplateValidator):
|
|
38
|
-
if_name: Optional[str] = Field(
|
|
57
|
+
if_name: Optional[str] = Field(
|
|
58
|
+
default=None, description="Name of the MPLS interface.", json_schema_extra={"vmanage_key": "if-name"}
|
|
59
|
+
)
|
|
39
60
|
model_config = ConfigDict(populate_by_name=True)
|
|
40
61
|
|
|
41
62
|
|
|
42
|
-
class AddressFamilyType(str, Enum):
|
|
43
|
-
IPV4_UNICAST = "ipv4-unicast"
|
|
44
|
-
|
|
45
|
-
|
|
46
63
|
class AggregateAddress(FeatureTemplateValidator):
|
|
47
|
-
prefix: str
|
|
48
|
-
as_set: Optional[BoolStr] = Field(
|
|
49
|
-
|
|
64
|
+
prefix: str = Field(description="IP prefix to be aggregated.")
|
|
65
|
+
as_set: Optional[BoolStr] = Field(
|
|
66
|
+
default=None,
|
|
67
|
+
description="Include AS_SET information in the aggregate route.",
|
|
68
|
+
json_schema_extra={"vmanage_key": "as-set"},
|
|
69
|
+
)
|
|
70
|
+
summary_only: Optional[BoolStr] = Field(
|
|
71
|
+
default=None,
|
|
72
|
+
description="Advertise only the summary route, not more specific routes.",
|
|
73
|
+
json_schema_extra={"vmanage_key": "summary-only"},
|
|
74
|
+
)
|
|
50
75
|
model_config = ConfigDict(populate_by_name=True)
|
|
51
76
|
|
|
52
77
|
|
|
53
78
|
class Ipv6AggregateAddress(FeatureTemplateValidator):
|
|
54
|
-
prefix: str
|
|
55
|
-
as_set: Optional[bool] = Field(
|
|
56
|
-
|
|
79
|
+
prefix: str = Field(description="IPv6 prefix to be aggregated.")
|
|
80
|
+
as_set: Optional[bool] = Field(
|
|
81
|
+
default=False,
|
|
82
|
+
description="Include AS_SET information in the aggregate IPv6 route.",
|
|
83
|
+
json_schema_extra={"vmanage_key": "as-set"},
|
|
84
|
+
)
|
|
85
|
+
summary_only: Optional[bool] = Field(
|
|
86
|
+
default=False,
|
|
87
|
+
description="Advertise only the summary IPv6 route, not more specific routes.",
|
|
88
|
+
json_schema_extra={"vmanage_key": "summary-only"},
|
|
89
|
+
)
|
|
57
90
|
model_config = ConfigDict(populate_by_name=True)
|
|
58
91
|
|
|
59
92
|
|
|
60
93
|
class Network(FeatureTemplateValidator):
|
|
61
|
-
prefix: str
|
|
94
|
+
prefix: str = Field(description="IP network prefix to be advertised.")
|
|
62
95
|
|
|
63
96
|
|
|
64
97
|
class Ipv6Network(FeatureTemplateValidator):
|
|
65
|
-
prefix: str
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
class Protocol(str, Enum):
|
|
69
|
-
STATIC = "static"
|
|
70
|
-
CONNECTED = "connected"
|
|
71
|
-
OSPF = "ospf"
|
|
72
|
-
OSPFV3 = "ospfv3"
|
|
73
|
-
OMP = "omp"
|
|
74
|
-
EIGRP = "eigrp"
|
|
75
|
-
NAT = "nat"
|
|
98
|
+
prefix: str = Field(description="IPv6 network prefix to be advertised.")
|
|
76
99
|
|
|
77
100
|
|
|
78
101
|
class Redistribute(FeatureTemplateValidator):
|
|
79
|
-
protocol: Protocol
|
|
80
|
-
route_policy: Optional[str] = Field(
|
|
102
|
+
protocol: Protocol = Field(description="Routing protocol from which routes are to be redistributed.")
|
|
103
|
+
route_policy: Optional[str] = Field(
|
|
104
|
+
default=None,
|
|
105
|
+
description="Name of the route policy to be applied during redistribution.",
|
|
106
|
+
json_schema_extra={"vmanage_key": "route-policy"},
|
|
107
|
+
)
|
|
81
108
|
model_config = ConfigDict(populate_by_name=True)
|
|
82
109
|
|
|
83
110
|
|
|
84
111
|
class AddressFamily(FeatureTemplateValidator):
|
|
85
|
-
family_type: AddressFamilyType = Field(
|
|
112
|
+
family_type: AddressFamilyType = Field(
|
|
113
|
+
description="Type of address family for BGP (e.g., IPv4 unicast).",
|
|
114
|
+
json_schema_extra={"vmanage_key": "family-type"},
|
|
115
|
+
)
|
|
86
116
|
aggregate_address: Optional[List[AggregateAddress]] = Field(
|
|
87
|
-
default=None,
|
|
117
|
+
default=None,
|
|
118
|
+
description="List of aggregate address configurations.",
|
|
119
|
+
json_schema_extra={"vmanage_key": "aggregate-address"},
|
|
88
120
|
)
|
|
89
121
|
ipv6_aggregate_address: Optional[List[Ipv6AggregateAddress]] = Field(
|
|
90
|
-
default=None,
|
|
122
|
+
default=None,
|
|
123
|
+
description="List of IPv6 aggregate address configurations.",
|
|
124
|
+
json_schema_extra={"vmanage_key": "ipv6-aggregate-address"},
|
|
125
|
+
)
|
|
126
|
+
network: Optional[List[Network]] = Field(default=None, description="List of networks to be advertised by BGP.")
|
|
127
|
+
ipv6_network: Optional[List[Ipv6Network]] = Field(
|
|
128
|
+
default=None,
|
|
129
|
+
description="List of IPv6 networks to be advertised by BGP.",
|
|
130
|
+
json_schema_extra={"vmanage_key": "ipv6-network"},
|
|
131
|
+
)
|
|
132
|
+
paths: Optional[int] = Field(
|
|
133
|
+
default=None,
|
|
134
|
+
description="Maximum number of equal-cost paths for load sharing.",
|
|
135
|
+
json_schema_extra={"data_path": ["maximum-paths"]},
|
|
136
|
+
)
|
|
137
|
+
originate: Optional[BoolStr] = Field(
|
|
138
|
+
default=None,
|
|
139
|
+
description="Whether to originate default route.",
|
|
140
|
+
json_schema_extra={"data_path": ["default-information"]},
|
|
91
141
|
)
|
|
92
|
-
network: Optional[List[Network]] = None
|
|
93
|
-
ipv6_network: Optional[List[Ipv6Network]] = Field(default=None, json_schema_extra={"vmanage_key": "ipv6-network"})
|
|
94
|
-
paths: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["maximum-paths"]})
|
|
95
|
-
originate: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["default-information"]})
|
|
96
142
|
policy_name: Optional[str] = Field(
|
|
97
|
-
default=None,
|
|
143
|
+
default=None,
|
|
144
|
+
description="Name of the policy to apply to the address family.",
|
|
145
|
+
json_schema_extra={"data_path": ["table-map"], "vmanage_key": "name"},
|
|
146
|
+
)
|
|
147
|
+
filter: Optional[BoolStr] = Field(
|
|
148
|
+
default=None,
|
|
149
|
+
description="Whether to filter routes according to the policy.",
|
|
150
|
+
json_schema_extra={"data_path": ["table-map"]},
|
|
151
|
+
)
|
|
152
|
+
redistribute: Optional[List[Redistribute]] = Field(
|
|
153
|
+
default=None, description="List of routing protocols and their respective redistribution configurations."
|
|
98
154
|
)
|
|
99
|
-
filter: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["table-map"]})
|
|
100
|
-
redistribute: Optional[List[Redistribute]] = None
|
|
101
155
|
model_config = ConfigDict(populate_by_name=True)
|
|
102
156
|
|
|
103
157
|
|
|
104
|
-
class NeighborFamilyType(str, Enum):
|
|
105
|
-
IPV4_UNICAST = "ipv4-unicast"
|
|
106
|
-
VPNV4_UNICAST = "vpnv4-unicast"
|
|
107
|
-
VPNV6_UNICAST = "vpnv6-unicast"
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
class Direction(str, Enum):
|
|
111
|
-
IN = "in"
|
|
112
|
-
OUT = "out"
|
|
113
|
-
|
|
114
|
-
|
|
115
158
|
class RoutePolicy(FeatureTemplateValidator):
|
|
116
|
-
direction: Direction
|
|
117
|
-
|
|
159
|
+
direction: Direction = Field(
|
|
160
|
+
description="Direction in which the route policy is to be applied (inbound or outbound)."
|
|
161
|
+
)
|
|
162
|
+
pol_name: str = Field(description="Name of the route policy.", json_schema_extra={"vmanage_key": "pol-name"})
|
|
118
163
|
model_config = ConfigDict(populate_by_name=True)
|
|
119
164
|
|
|
120
165
|
|
|
121
166
|
class NeighborAddressFamily(FeatureTemplateValidator):
|
|
122
|
-
|
|
167
|
+
"""Configuration for a BGP neighbor's address family settings."""
|
|
168
|
+
|
|
169
|
+
family_type: NeighborFamilyType = Field(
|
|
170
|
+
description="The address family type associated with this neighbor (e.g., ipv4-unicast, vpnv4-unicast).",
|
|
171
|
+
json_schema_extra={"vmanage_key": "family-type"},
|
|
172
|
+
)
|
|
123
173
|
prefix_num: Optional[int] = Field(
|
|
124
|
-
default=None,
|
|
174
|
+
default=None,
|
|
175
|
+
description="The maximum number of prefixes that can be received from a neighbor before taking action.",
|
|
176
|
+
json_schema_extra={"data_path": ["maximum-prefixes"], "vmanage_key": "prefix-num"},
|
|
177
|
+
)
|
|
178
|
+
threshold: Optional[int] = Field(
|
|
179
|
+
default=None,
|
|
180
|
+
description=(
|
|
181
|
+
"The threshold percentage of maximum prefixes "
|
|
182
|
+
"after which a warning is issued or further action is taken."
|
|
183
|
+
),
|
|
184
|
+
json_schema_extra={"data_path": ["maximum-prefixes"]},
|
|
185
|
+
)
|
|
186
|
+
restart: Optional[int] = Field(
|
|
187
|
+
default=None,
|
|
188
|
+
description=(
|
|
189
|
+
"The time in minutes to wait before re-establishing BGP peering"
|
|
190
|
+
"after a maximum prefix limit has been exceeded."
|
|
191
|
+
),
|
|
192
|
+
json_schema_extra={"data_path": ["maximum-prefixes"]},
|
|
125
193
|
)
|
|
126
|
-
threshold: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["maximum-prefixes"]})
|
|
127
|
-
restart: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["maximum-prefixes"]})
|
|
128
194
|
warning_only: Optional[bool] = Field(
|
|
129
|
-
default=None,
|
|
195
|
+
default=None,
|
|
196
|
+
description=(
|
|
197
|
+
"Indicates whether only a warning message should be issued when the maximum prefix limit is exceeded,"
|
|
198
|
+
" without dropping the BGP session."
|
|
199
|
+
),
|
|
200
|
+
json_schema_extra={"data_path": ["maximum-prefixes"], "vmanage_key": "warning-only"},
|
|
201
|
+
)
|
|
202
|
+
route_policy: Optional[List[RoutePolicy]] = Field(
|
|
203
|
+
default=None,
|
|
204
|
+
description="A list of route policies applied to incoming or outgoing routes for this address family.",
|
|
205
|
+
json_schema_extra={"vmanage_key": "route-policy"},
|
|
130
206
|
)
|
|
131
|
-
route_policy: Optional[List[RoutePolicy]] = Field(default=None, json_schema_extra={"vmanage_key": "route-policy"})
|
|
132
207
|
model_config = ConfigDict(populate_by_name=True)
|
|
133
208
|
|
|
134
209
|
|
|
135
210
|
class Neighbor(FeatureTemplateValidator):
|
|
136
|
-
address: str
|
|
137
|
-
description: Optional[str] = None
|
|
138
|
-
shutdown: Optional[BoolStr] =
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
211
|
+
address: str = Field(description="IP address of the BGP neighbor.")
|
|
212
|
+
description: Optional[str] = Field(default=None, description="A textual description of the BGP neighbor.")
|
|
213
|
+
shutdown: Optional[BoolStr] = Field(
|
|
214
|
+
default=None, description="Indicates whether the BGP neighbor is administratively shut down."
|
|
215
|
+
)
|
|
216
|
+
remote_as: int = Field(
|
|
217
|
+
description="The Autonomous System (AS) number of the BGP neighbor.",
|
|
218
|
+
json_schema_extra={"vmanage_key": "remote-as"},
|
|
219
|
+
)
|
|
220
|
+
keepalive: Optional[int] = Field(
|
|
221
|
+
default=None,
|
|
222
|
+
description="Keepalive interval for the BGP neighbor in seconds.",
|
|
223
|
+
json_schema_extra={"data_path": ["timers"]},
|
|
224
|
+
)
|
|
225
|
+
holdtime: Optional[int] = Field(
|
|
226
|
+
default=None,
|
|
227
|
+
description="Hold time interval for the BGP neighbor in seconds.",
|
|
228
|
+
json_schema_extra={"data_path": ["timers"]},
|
|
229
|
+
)
|
|
142
230
|
if_name: Optional[str] = Field(
|
|
143
|
-
default=None,
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
231
|
+
default=None,
|
|
232
|
+
description="Interface name to use as the source address for BGP packets.",
|
|
233
|
+
json_schema_extra={"data_path": ["update-source"], "vmanage_key": "if-name"},
|
|
234
|
+
)
|
|
235
|
+
next_hop_self: Optional[BoolStr] = Field(
|
|
236
|
+
default=None,
|
|
237
|
+
description="Whether the BGP neighbor should use its own address as the next hop.",
|
|
238
|
+
json_schema_extra={"vmanage_key": "next-hop-self"},
|
|
239
|
+
)
|
|
240
|
+
send_community: Optional[BoolStr] = Field(
|
|
241
|
+
default=None,
|
|
242
|
+
description="Whether to send standard community attributes to this neighbor.",
|
|
243
|
+
json_schema_extra={"vmanage_key": "send-community"},
|
|
244
|
+
)
|
|
245
|
+
send_ext_community: Optional[BoolStr] = Field(
|
|
246
|
+
default=None,
|
|
247
|
+
description="Whether to send extended community attributes to this neighbor.",
|
|
248
|
+
json_schema_extra={"vmanage_key": "send-ext-community"},
|
|
249
|
+
)
|
|
250
|
+
ebgp_multihop: Optional[int] = Field(
|
|
251
|
+
default=None,
|
|
252
|
+
description="The maximum number of hops allowed for eBGP sessions with this neighbor.",
|
|
253
|
+
json_schema_extra={"vmanage_key": "ebgp-multihop"},
|
|
254
|
+
)
|
|
255
|
+
password: Optional[str] = Field(default=None, description="Password for BGP authentication with the neighbor.")
|
|
256
|
+
send_label: Optional[BoolStr] = Field(
|
|
257
|
+
default=None,
|
|
258
|
+
description="Whether to send MPLS labels for routes to this neighbor.",
|
|
259
|
+
json_schema_extra={"vmanage_key": "send-label"},
|
|
260
|
+
)
|
|
151
261
|
send_label_explicit: Optional[BoolStr] = Field(
|
|
152
|
-
default=None,
|
|
262
|
+
default=None,
|
|
263
|
+
description="Whether to send MPLS labels explicitly for routes to this neighbor.",
|
|
264
|
+
json_schema_extra={"vmanage_key": "send-label-explicit"},
|
|
265
|
+
)
|
|
266
|
+
as_override: Optional[BoolStr] = Field(
|
|
267
|
+
default=None,
|
|
268
|
+
description="Whether to override the AS number in the AS_PATH for routes to this neighbor.",
|
|
269
|
+
json_schema_extra={"vmanage_key": "as-override"},
|
|
153
270
|
)
|
|
154
|
-
as_override: Optional[BoolStr] = Field(default=None, json_schema_extra={"vmanage_key": "as-override"})
|
|
155
271
|
as_number: Optional[int] = Field(
|
|
156
|
-
default=None,
|
|
272
|
+
default=None,
|
|
273
|
+
description="The number of occurrences of the local AS number allowed in the AS_PATH before it is ignored.",
|
|
274
|
+
json_schema_extra={"data_path": ["allowas-in"], "vmanage_key": "as-number"},
|
|
157
275
|
)
|
|
158
276
|
address_family: Optional[List[NeighborAddressFamily]] = Field(
|
|
159
|
-
default=None,
|
|
277
|
+
default=None,
|
|
278
|
+
description="List of address family configurations for the BGP neighbor.",
|
|
279
|
+
json_schema_extra={"vmanage_key": "address-family"},
|
|
160
280
|
)
|
|
161
281
|
model_config = ConfigDict(populate_by_name=True)
|
|
162
282
|
|
|
163
283
|
|
|
164
|
-
class IPv6NeighborFamilyType(str, Enum):
|
|
165
|
-
IPV6_UNICAST = "ipv6-unicast"
|
|
166
|
-
|
|
167
|
-
|
|
168
284
|
class IPv6NeighborAddressFamily(FeatureTemplateValidator):
|
|
169
|
-
family_type: IPv6NeighborFamilyType = Field(
|
|
285
|
+
family_type: IPv6NeighborFamilyType = Field(
|
|
286
|
+
description="The IPv6 address family type associated with this neighbor (e.g., ipv6-unicast).",
|
|
287
|
+
json_schema_extra={"vmanage_key": "family-type"},
|
|
288
|
+
)
|
|
170
289
|
prefix_num: Optional[int] = Field(
|
|
171
|
-
0,
|
|
290
|
+
default=0,
|
|
291
|
+
description=("The maximum number of IPv6 prefixes that can be received from a neighbor before taking action."),
|
|
292
|
+
json_schema_extra={"data_path": ["maximum-prefixes"], "vmanage_key": "prefix-num"},
|
|
293
|
+
)
|
|
294
|
+
threshold: Optional[int] = Field(
|
|
295
|
+
default=None,
|
|
296
|
+
description=(
|
|
297
|
+
"The threshold percentage of maximum IPv6 prefixes"
|
|
298
|
+
" after which a warning is issued or further action is taken."
|
|
299
|
+
),
|
|
300
|
+
json_schema_extra={"data_path": ["maximum-prefixes"]},
|
|
301
|
+
)
|
|
302
|
+
restart: Optional[int] = Field(
|
|
303
|
+
default=None,
|
|
304
|
+
description=(
|
|
305
|
+
"The time in minutes to wait before re-establishing BGP peering "
|
|
306
|
+
"after an IPv6 maximum prefix limit has been exceeded."
|
|
307
|
+
),
|
|
308
|
+
json_schema_extra={"data_path": ["maximum-prefixes"]},
|
|
172
309
|
)
|
|
173
|
-
threshold: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["maximum-prefixes"]})
|
|
174
|
-
restart: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["maximum-prefixes"]})
|
|
175
310
|
warning_only: Optional[bool] = Field(
|
|
176
|
-
False,
|
|
311
|
+
default=False,
|
|
312
|
+
description=(
|
|
313
|
+
"Indicates whether only a warning message should be issued "
|
|
314
|
+
"when the IPv6 maximum prefix limit is exceeded, without dropping the BGP session."
|
|
315
|
+
),
|
|
316
|
+
json_schema_extra={"data_path": ["maximum-prefixes"], "vmanage_key": "warning-only"},
|
|
317
|
+
)
|
|
318
|
+
route_policy: Optional[List[RoutePolicy]] = Field(
|
|
319
|
+
default=None,
|
|
320
|
+
description="A list of route policies applied to incoming or outgoing routes for this IPv6 address family.",
|
|
321
|
+
json_schema_extra={"vmanage_key": "route-policy"},
|
|
177
322
|
)
|
|
178
|
-
route_policy: Optional[List[RoutePolicy]] = Field(default=None, json_schema_extra={"vmanage_key": "route-policy"})
|
|
179
323
|
model_config = ConfigDict(populate_by_name=True)
|
|
180
324
|
|
|
181
325
|
|
|
182
326
|
class Ipv6Neighbor(FeatureTemplateValidator):
|
|
183
|
-
address: str
|
|
184
|
-
description: Optional[str] = None
|
|
185
|
-
shutdown: Optional[BoolStr] =
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
327
|
+
address: str = Field(description="IPv6 address of the BGP neighbor.")
|
|
328
|
+
description: Optional[str] = Field(default=None, description="A textual description of the BGP neighbor.")
|
|
329
|
+
shutdown: Optional[BoolStr] = Field(
|
|
330
|
+
default=None, description="Indicates whether the BGP neighbor is administratively shut down."
|
|
331
|
+
)
|
|
332
|
+
remote_as: Optional[int] = Field(
|
|
333
|
+
default=None,
|
|
334
|
+
description="The Autonomous System (AS) number of the BGP neighbor.",
|
|
335
|
+
json_schema_extra={"vmanage_key": "remote-as"},
|
|
336
|
+
)
|
|
337
|
+
keepalive: Optional[int] = Field(
|
|
338
|
+
default=None,
|
|
339
|
+
description="Keepalive interval for the BGP neighbor in seconds.",
|
|
340
|
+
json_schema_extra={"data_path": ["timers"]},
|
|
341
|
+
)
|
|
342
|
+
holdtime: Optional[int] = Field(
|
|
343
|
+
default=None,
|
|
344
|
+
description="Hold time interval for the BGP neighbor in seconds.",
|
|
345
|
+
json_schema_extra={"data_path": ["timers"]},
|
|
346
|
+
)
|
|
189
347
|
if_name: Optional[str] = Field(
|
|
190
|
-
default=None,
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
348
|
+
default=None,
|
|
349
|
+
description="Interface name to use as the source address for BGP packets.",
|
|
350
|
+
json_schema_extra={"data_path": ["update-source"], "vmanage_key": "if-name"},
|
|
351
|
+
)
|
|
352
|
+
next_hop_self: Optional[BoolStr] = Field(
|
|
353
|
+
default=False,
|
|
354
|
+
description="Whether the BGP neighbor should use its own address as the next hop.",
|
|
355
|
+
json_schema_extra={"vmanage_key": "next-hop-self"},
|
|
356
|
+
)
|
|
357
|
+
send_community: Optional[BoolStr] = Field(
|
|
358
|
+
default=True,
|
|
359
|
+
description="Whether to send standard community attributes to this neighbor.",
|
|
360
|
+
json_schema_extra={"vmanage_key": "send-community"},
|
|
361
|
+
)
|
|
362
|
+
send_ext_community: Optional[BoolStr] = Field(
|
|
363
|
+
default=True,
|
|
364
|
+
description="Whether to send extended community attributes to this neighbor.",
|
|
365
|
+
json_schema_extra={"vmanage_key": "send-ext-community"},
|
|
366
|
+
)
|
|
367
|
+
ebgp_multihop: Optional[int] = Field(
|
|
368
|
+
default=1,
|
|
369
|
+
description="The maximum number of hops allowed for eBGP sessions with this neighbor.",
|
|
370
|
+
json_schema_extra={"vmanage_key": "ebgp-multihop"},
|
|
371
|
+
)
|
|
372
|
+
password: Optional[str] = Field(default=None, description="Password for BGP authentication with the neighbor.")
|
|
373
|
+
send_label: Optional[BoolStr] = Field(
|
|
374
|
+
default=False,
|
|
375
|
+
description="Whether to send MPLS labels for routes to this neighbor.",
|
|
376
|
+
json_schema_extra={"vmanage_key": "send-label"},
|
|
377
|
+
)
|
|
198
378
|
send_label_explicit: Optional[BoolStr] = Field(
|
|
199
|
-
default=False,
|
|
379
|
+
default=False,
|
|
380
|
+
description="Whether to send MPLS labels explicitly for routes to this neighbor.",
|
|
381
|
+
json_schema_extra={"vmanage_key": "send-label-explicit"},
|
|
382
|
+
)
|
|
383
|
+
as_override: Optional[BoolStr] = Field(
|
|
384
|
+
default=False,
|
|
385
|
+
description="Whether to override the AS number in the AS_PATH for routes to this neighbor.",
|
|
386
|
+
json_schema_extra={"vmanage_key": "as-override"},
|
|
200
387
|
)
|
|
201
|
-
as_override: Optional[BoolStr] = Field(default=False, json_schema_extra={"vmanage_key": "as-override"})
|
|
202
388
|
as_number: Optional[int] = Field(
|
|
203
|
-
default=None,
|
|
389
|
+
default=None,
|
|
390
|
+
description="The number of occurrences of the local AS number allowed in the AS_PATH before it is ignored.",
|
|
391
|
+
json_schema_extra={"data_path": ["allowas-in"], "vmanage_key": "as-number"},
|
|
204
392
|
)
|
|
205
393
|
address_family: Optional[List[IPv6NeighborAddressFamily]] = Field(
|
|
206
|
-
default=None,
|
|
394
|
+
default=None,
|
|
395
|
+
description="List of IPv6 address family configurations for the BGP neighbor.",
|
|
396
|
+
json_schema_extra={"vmanage_key": "address-family"},
|
|
207
397
|
)
|
|
208
398
|
model_config = ConfigDict(populate_by_name=True)
|
|
209
399
|
|
|
210
400
|
|
|
211
401
|
class CiscoBGPModel(FeatureTemplate):
|
|
212
402
|
model_config = ConfigDict(arbitrary_types_allowed=True, populate_by_name=True)
|
|
403
|
+
_docs_description: str = "Cisco Border Gateway Protocol (BGP) configuration"
|
|
213
404
|
|
|
214
|
-
as_num: Optional[str] = Field(
|
|
215
|
-
|
|
216
|
-
|
|
405
|
+
as_num: Optional[str] = Field(
|
|
406
|
+
default=None,
|
|
407
|
+
description="Autonomous System number for the BGP process.",
|
|
408
|
+
json_schema_extra={"data_path": ["bgp"], "vmanage_key": "as-num"},
|
|
409
|
+
)
|
|
410
|
+
shutdown: Optional[BoolStr] = Field(
|
|
411
|
+
default=None,
|
|
412
|
+
description="Indicates whether the BGP process is administratively shut down.",
|
|
413
|
+
json_schema_extra={"data_path": ["bgp"]},
|
|
414
|
+
)
|
|
415
|
+
router_id: Optional[str] = Field(
|
|
416
|
+
default=None,
|
|
417
|
+
description="Router identifier for the BGP process.",
|
|
418
|
+
json_schema_extra={"data_path": ["bgp"], "vmanage_key": "router-id"},
|
|
419
|
+
)
|
|
217
420
|
propagate_aspath: Optional[bool] = Field(
|
|
218
|
-
default=None,
|
|
421
|
+
default=None,
|
|
422
|
+
description="Option to enable or disable AS path propagation.",
|
|
423
|
+
json_schema_extra={"data_path": ["bgp"], "vmanage_key": "propagate-aspath"},
|
|
219
424
|
)
|
|
220
425
|
propagate_community: Optional[bool] = Field(
|
|
221
|
-
default=None,
|
|
426
|
+
default=None,
|
|
427
|
+
description="Option to enable or disable community attribute propagation.",
|
|
428
|
+
json_schema_extra={"data_path": ["bgp"], "vmanage_key": "propagate-community"},
|
|
222
429
|
)
|
|
223
430
|
route_target_ipv4: List[RouteTargetIpv4] = Field(
|
|
224
|
-
|
|
431
|
+
default=[],
|
|
432
|
+
description="List of IPv4 route targets for BGP VPNs.",
|
|
433
|
+
json_schema_extra={"data_path": ["bgp", "target"], "vmanage_key": "route-target-ipv4"},
|
|
225
434
|
)
|
|
226
435
|
route_target_ipv6: List[RouteTargetIpv6] = Field(
|
|
227
|
-
|
|
436
|
+
default=[],
|
|
437
|
+
description="List of IPv6 route targets for BGP VPNs.",
|
|
438
|
+
json_schema_extra={"data_path": ["bgp", "target"], "vmanage_key": "route-target-ipv6"},
|
|
228
439
|
)
|
|
229
440
|
mpls_interface: Optional[List[MplsInterface]] = Field(
|
|
230
|
-
default=None,
|
|
441
|
+
default=None,
|
|
442
|
+
description="List of MPLS interfaces associated with the BGP process.",
|
|
443
|
+
json_schema_extra={"data_path": ["bgp"], "vmanage_key": "mpls-interface"},
|
|
444
|
+
)
|
|
445
|
+
external: Optional[int] = Field(
|
|
446
|
+
default=None,
|
|
447
|
+
description="Administrative distance for external BGP routes.",
|
|
448
|
+
json_schema_extra={"data_path": ["bgp", "distance"]},
|
|
449
|
+
)
|
|
450
|
+
internal: Optional[int] = Field(
|
|
451
|
+
default=None,
|
|
452
|
+
description="Administrative distance for internal BGP routes.",
|
|
453
|
+
json_schema_extra={"data_path": ["bgp", "distance"]},
|
|
454
|
+
)
|
|
455
|
+
local: Optional[int] = Field(
|
|
456
|
+
default=None,
|
|
457
|
+
description="Administrative distance for local BGP routes.",
|
|
458
|
+
json_schema_extra={"data_path": ["bgp", "distance"]},
|
|
459
|
+
)
|
|
460
|
+
keepalive: Optional[int] = Field(
|
|
461
|
+
default=None,
|
|
462
|
+
description="Keepalive interval for BGP sessions in seconds.",
|
|
463
|
+
json_schema_extra={"data_path": ["bgp", "timers"]},
|
|
464
|
+
)
|
|
465
|
+
holdtime: Optional[int] = Field(
|
|
466
|
+
default=None,
|
|
467
|
+
description="Hold time interval for BGP sessions in seconds.",
|
|
468
|
+
json_schema_extra={"data_path": ["bgp", "timers"]},
|
|
231
469
|
)
|
|
232
|
-
external: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["bgp", "distance"]})
|
|
233
|
-
internal: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["bgp", "distance"]})
|
|
234
|
-
local: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["bgp", "distance"]})
|
|
235
|
-
keepalive: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["bgp", "timers"]})
|
|
236
|
-
holdtime: Optional[int] = Field(default=None, json_schema_extra={"data_path": ["bgp", "timers"]})
|
|
237
470
|
always_compare: Optional[bool] = Field(
|
|
238
|
-
default=None,
|
|
471
|
+
default=None,
|
|
472
|
+
description="Always compare MED for paths from neighbors in different ASes.",
|
|
473
|
+
json_schema_extra={"data_path": ["bgp", "best-path", "med"], "vmanage_key": "always-compare"},
|
|
474
|
+
)
|
|
475
|
+
deterministic: Optional[BoolStr] = Field(
|
|
476
|
+
default=None,
|
|
477
|
+
description="Deterministic comparison of MED for paths from different neighbors.",
|
|
478
|
+
json_schema_extra={"data_path": ["bgp", "best-path", "med"]},
|
|
239
479
|
)
|
|
240
|
-
deterministic: Optional[BoolStr] = Field(default=None, json_schema_extra={"data_path": ["bgp", "best-path", "med"]})
|
|
241
480
|
missing_as_worst: Optional[BoolStr] = Field(
|
|
242
|
-
default=None,
|
|
481
|
+
default=None,
|
|
482
|
+
description="Treat missing AS as worst path.",
|
|
483
|
+
json_schema_extra={"data_path": ["bgp", "best-path", "med"], "vmanage_key": "missing-as-worst"},
|
|
243
484
|
)
|
|
244
485
|
compare_router_id: Optional[BoolStr] = Field(
|
|
245
|
-
default=None,
|
|
486
|
+
default=None,
|
|
487
|
+
description="Compare router ID for identical EBGP paths.",
|
|
488
|
+
json_schema_extra={"data_path": ["bgp", "best-path"], "vmanage_key": "compare-router-id"},
|
|
246
489
|
)
|
|
247
490
|
multipath_relax: Optional[BoolStr] = Field(
|
|
248
|
-
default=None,
|
|
491
|
+
default=None,
|
|
492
|
+
description="Option to enable or disable relaxation of the BGP multipath selection criteria.",
|
|
493
|
+
json_schema_extra={"data_path": ["bgp", "best-path", "as-path"], "vmanage_key": "multipath-relax"},
|
|
249
494
|
)
|
|
250
495
|
address_family: Optional[List[AddressFamily]] = Field(
|
|
251
|
-
default=None,
|
|
496
|
+
default=None,
|
|
497
|
+
description="List of address family configurations for the BGP process.",
|
|
498
|
+
json_schema_extra={"data_path": ["bgp"], "vmanage_key": "address-family"},
|
|
499
|
+
)
|
|
500
|
+
neighbor: Optional[List[Neighbor]] = Field(
|
|
501
|
+
default=None, description="List of IPv4 BGP neighbor configurations.", json_schema_extra={"data_path": ["bgp"]}
|
|
252
502
|
)
|
|
253
|
-
neighbor: Optional[List[Neighbor]] = Field(default=None, json_schema_extra={"data_path": ["bgp"]})
|
|
254
503
|
ipv6_neighbor: Optional[List[Ipv6Neighbor]] = Field(
|
|
255
|
-
default=None,
|
|
504
|
+
default=None,
|
|
505
|
+
description="List of IPv6 BGP neighbor configurations.",
|
|
506
|
+
json_schema_extra={"data_path": ["bgp"], "vmanage_key": "ipv6-neighbor"},
|
|
256
507
|
)
|
|
257
508
|
|
|
258
509
|
payload_path: ClassVar[Path] = Path(__file__).parent / "DEPRECATED"
|