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
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
# Copyright 2024 Cisco Systems, Inc. and its affiliates
|
|
2
|
+
from __future__ import annotations
|
|
3
|
+
|
|
4
|
+
from typing import Literal, Optional, Union
|
|
5
|
+
|
|
6
|
+
from pydantic import AliasPath, BaseModel, ConfigDict, Field
|
|
7
|
+
|
|
8
|
+
from catalystwan.api.configuration_groups.parcel import Default, Global, Variable, _ParcelBase
|
|
9
|
+
|
|
10
|
+
EtherchannelFlowLoadBalance = Literal[
|
|
11
|
+
"dst-ip",
|
|
12
|
+
"dst-mac",
|
|
13
|
+
"sdwan",
|
|
14
|
+
"src-dst-ip",
|
|
15
|
+
"src-dst-mac",
|
|
16
|
+
"src-dst-mixed-ip-port",
|
|
17
|
+
"src-ip",
|
|
18
|
+
"src-mac",
|
|
19
|
+
]
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class ServicesIp(BaseModel):
|
|
23
|
+
model_config = ConfigDict(
|
|
24
|
+
extra="forbid",
|
|
25
|
+
populate_by_name=True,
|
|
26
|
+
)
|
|
27
|
+
http_server: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
28
|
+
default=Default[bool](value=False),
|
|
29
|
+
serialization_alias="servicesGlobalServicesIpHttpServer",
|
|
30
|
+
validation_alias="servicesGlobalServicesIpHttpServer",
|
|
31
|
+
)
|
|
32
|
+
https_server: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
33
|
+
default=Default[bool](value=False),
|
|
34
|
+
serialization_alias="servicesGlobalServicesIpHttpsServer",
|
|
35
|
+
validation_alias="servicesGlobalServicesIpHttpsServer",
|
|
36
|
+
)
|
|
37
|
+
ftp_passive: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
38
|
+
default=Default[bool](value=False),
|
|
39
|
+
serialization_alias="servicesGlobalServicesIpFtpPassive",
|
|
40
|
+
validation_alias="servicesGlobalServicesIpFtpPassive",
|
|
41
|
+
)
|
|
42
|
+
domain_lookup: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
43
|
+
default=Default[bool](value=False),
|
|
44
|
+
serialization_alias="servicesGlobalServicesIpDomainLookup",
|
|
45
|
+
validation_alias="servicesGlobalServicesIpDomainLookup",
|
|
46
|
+
)
|
|
47
|
+
arp_proxy: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
48
|
+
default=Default[bool](value=False),
|
|
49
|
+
serialization_alias="servicesGlobalServicesIpArpProxy",
|
|
50
|
+
validation_alias="servicesGlobalServicesIpArpProxy",
|
|
51
|
+
)
|
|
52
|
+
rcmd: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
53
|
+
default=Default[bool](value=False),
|
|
54
|
+
serialization_alias="servicesGlobalServicesIpRcmd",
|
|
55
|
+
validation_alias="servicesGlobalServicesIpRcmd",
|
|
56
|
+
)
|
|
57
|
+
line_vty: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
58
|
+
default=Default[bool](value=False),
|
|
59
|
+
serialization_alias="servicesGlobalServicesIpLineVty",
|
|
60
|
+
validation_alias="servicesGlobalServicesIpLineVty",
|
|
61
|
+
)
|
|
62
|
+
cdp: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
63
|
+
default=Default[bool](value=True),
|
|
64
|
+
serialization_alias="servicesGlobalServicesIpCdp",
|
|
65
|
+
validation_alias="servicesGlobalServicesIpCdp",
|
|
66
|
+
)
|
|
67
|
+
lldp: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
68
|
+
default=Default[bool](value=True),
|
|
69
|
+
serialization_alias="servicesGlobalServicesIpLldp",
|
|
70
|
+
validation_alias="servicesGlobalServicesIpLldp",
|
|
71
|
+
)
|
|
72
|
+
source_intrf: Union[Variable, Global[str], Default[None]] = Field(
|
|
73
|
+
default=Default[None](value=None),
|
|
74
|
+
serialization_alias="servicesGlobalServicesIpSourceIntrf",
|
|
75
|
+
validation_alias="servicesGlobalServicesIpSourceIntrf",
|
|
76
|
+
)
|
|
77
|
+
tcp_keepalives_in: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
78
|
+
default=Default[bool](value=True),
|
|
79
|
+
serialization_alias="globalOtherSettingsTcpKeepalivesIn",
|
|
80
|
+
validation_alias="globalOtherSettingsTcpKeepalivesIn",
|
|
81
|
+
)
|
|
82
|
+
keepalives_out: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
83
|
+
default=Default[bool](value=True),
|
|
84
|
+
serialization_alias="globalOtherSettingsTcpKeepalivesOut",
|
|
85
|
+
validation_alias="globalOtherSettingsTcpKeepalivesOut",
|
|
86
|
+
)
|
|
87
|
+
small_servers: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
88
|
+
default=Default[bool](value=False),
|
|
89
|
+
serialization_alias="globalOtherSettingsTcpSmallServers",
|
|
90
|
+
validation_alias="globalOtherSettingsTcpSmallServers",
|
|
91
|
+
)
|
|
92
|
+
udp_small_servers: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
93
|
+
default=Default[bool](value=False),
|
|
94
|
+
serialization_alias="globalOtherSettingsUdpSmallServers",
|
|
95
|
+
validation_alias="globalOtherSettingsUdpSmallServers",
|
|
96
|
+
)
|
|
97
|
+
console_logging: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
98
|
+
default=Default[bool](value=True),
|
|
99
|
+
serialization_alias="globalOtherSettingsConsoleLogging",
|
|
100
|
+
validation_alias="globalOtherSettingsConsoleLogging",
|
|
101
|
+
)
|
|
102
|
+
ip_source_route: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
103
|
+
default=Default[bool](value=False),
|
|
104
|
+
serialization_alias="globalOtherSettingsIPSourceRoute",
|
|
105
|
+
validation_alias="globalOtherSettingsIPSourceRoute",
|
|
106
|
+
)
|
|
107
|
+
vty_line_logging: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
108
|
+
default=Default[bool](value=False),
|
|
109
|
+
serialization_alias="globalOtherSettingsVtyLineLogging",
|
|
110
|
+
validation_alias="globalOtherSettingsVtyLineLogging",
|
|
111
|
+
)
|
|
112
|
+
snmp_ifindex_persist: (Union[Variable, Global[bool], Default[bool]]) = Field(
|
|
113
|
+
default=Default[bool](value=True),
|
|
114
|
+
serialization_alias="globalOtherSettingsSnmpIfindexPersist",
|
|
115
|
+
validation_alias="globalOtherSettingsSnmpIfindexPersist",
|
|
116
|
+
)
|
|
117
|
+
ignore_bootp: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
118
|
+
default=Default[bool](value=True),
|
|
119
|
+
serialization_alias="globalOtherSettingsIgnoreBootp",
|
|
120
|
+
validation_alias="globalOtherSettingsIgnoreBootp",
|
|
121
|
+
)
|
|
122
|
+
nat64_udp_timeout: Union[Variable, Global[int], Default[int]] = Field(
|
|
123
|
+
default=Global[int](value=300),
|
|
124
|
+
serialization_alias="globalSettingsNat64UdpTimeout",
|
|
125
|
+
validation_alias="globalSettingsNat64UdpTimeout",
|
|
126
|
+
)
|
|
127
|
+
nat64_tcp_timeout: Union[Variable, Global[int], Default[int]] = Field(
|
|
128
|
+
default=Global[int](value=3600),
|
|
129
|
+
serialization_alias="globalSettingsNat64TcpTimeout",
|
|
130
|
+
validation_alias="globalSettingsNat64TcpTimeout",
|
|
131
|
+
)
|
|
132
|
+
http_authentication: Union[Variable, Global[str], Default[None]] = Field(
|
|
133
|
+
default=Default[None](value=None),
|
|
134
|
+
serialization_alias="globalSettingsHttpAuthentication",
|
|
135
|
+
validation_alias="globalSettingsHttpAuthentication",
|
|
136
|
+
)
|
|
137
|
+
ssh_version: Union[Variable, Global[str], Default[None]] = Field(
|
|
138
|
+
default=Default[None](value=None),
|
|
139
|
+
serialization_alias="globalSettingsSSHVersion",
|
|
140
|
+
validation_alias="globalSettingsSSHVersion",
|
|
141
|
+
)
|
|
142
|
+
lacp_system_priority: Optional[Union[Variable, Global[int], Default[None]]] = Field(
|
|
143
|
+
default=None, validation_alias="lacpSystemPriority", serialization_alias="lacpSystemPriority"
|
|
144
|
+
)
|
|
145
|
+
|
|
146
|
+
|
|
147
|
+
class ServicesGlobal(BaseModel):
|
|
148
|
+
model_config = ConfigDict(
|
|
149
|
+
extra="forbid",
|
|
150
|
+
populate_by_name=True,
|
|
151
|
+
)
|
|
152
|
+
services_ip: ServicesIp = Field(default_factory=ServicesIp)
|
|
153
|
+
|
|
154
|
+
|
|
155
|
+
class GlobalParcel(_ParcelBase):
|
|
156
|
+
type_: Literal["global"] = Field(default="global", exclude=True)
|
|
157
|
+
model_config = ConfigDict(
|
|
158
|
+
extra="forbid",
|
|
159
|
+
populate_by_name=True,
|
|
160
|
+
)
|
|
161
|
+
services_global: ServicesGlobal = Field(
|
|
162
|
+
default_factory=ServicesGlobal, validation_alias=AliasPath("data", "services_global")
|
|
163
|
+
)
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
# Copyright 2024 Cisco Systems, Inc. and its affiliates
|
|
2
|
+
from typing import List, Literal, Optional, Union
|
|
3
|
+
|
|
4
|
+
from pydantic import AliasPath, BaseModel, ConfigDict, Field
|
|
5
|
+
|
|
6
|
+
from catalystwan.api.configuration_groups.parcel import Default, Global, Variable, _ParcelBase, as_default, as_global
|
|
7
|
+
|
|
8
|
+
Priority = Literal["informational", "debugging", "notice", "warn", "error", "critical", "alert", "emergency"]
|
|
9
|
+
TlsVersion = Literal["TLSv1.1", "TLSv1.2"]
|
|
10
|
+
AuthType = Literal["Server", "Mutual"]
|
|
11
|
+
CypherSuite = Literal[
|
|
12
|
+
"rsa-aes-cbc-sha2",
|
|
13
|
+
"rsa-aes-gcm-sha2",
|
|
14
|
+
"ecdhe-rsa-aes-gcm-sha2",
|
|
15
|
+
"aes-128-cbc-sha",
|
|
16
|
+
"aes-256-cbc-sha",
|
|
17
|
+
"dhe-aes-cbc-sha2",
|
|
18
|
+
"dhe-aes-gcm-sha2",
|
|
19
|
+
"ecdhe-ecdsa-aes-gcm-sha2",
|
|
20
|
+
"ecdhe-rsa-aes-cbc-sha2",
|
|
21
|
+
]
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
class TlsProfile(BaseModel):
|
|
25
|
+
profile: Union[Global[str], Variable]
|
|
26
|
+
version: Union[Global[TlsVersion], Default[TlsVersion], Variable] = Field(
|
|
27
|
+
default=as_default("TLSv1.1", TlsVersion), serialization_alias="tlsVersion", validation_alias="tlsVersion"
|
|
28
|
+
)
|
|
29
|
+
auth_type: Default[AuthType] = Field(
|
|
30
|
+
default=as_default("Server", AuthType), serialization_alias="authType", validation_alias="authType"
|
|
31
|
+
) # Value can't be changed in the UI
|
|
32
|
+
ciphersuite_list: Union[Global[List[CypherSuite]], Default[None], Variable] = Field(
|
|
33
|
+
default=Default[None](value=None), serialization_alias="cipherSuiteList", validation_alias="cipherSuiteList"
|
|
34
|
+
)
|
|
35
|
+
model_config = ConfigDict(populate_by_name=True)
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
class Server(BaseModel):
|
|
39
|
+
name: Union[Global[str], Variable]
|
|
40
|
+
vpn: Union[Global[int], Default[int], Variable] = Field(default=as_default(0))
|
|
41
|
+
source_interface: Union[Global[str], Default[None], Variable] = Field(
|
|
42
|
+
default=Default[None](value=None), serialization_alias="sourceInterface", validation_alias="sourceInterface"
|
|
43
|
+
)
|
|
44
|
+
priority: Union[Global[Priority], Default[Priority], Variable] = Field(
|
|
45
|
+
default=as_default("informational", Priority)
|
|
46
|
+
)
|
|
47
|
+
enable_tls: Union[Global[bool], Default[bool], Variable] = Field(
|
|
48
|
+
default=as_default(False), serialization_alias="tlsEnable", validation_alias="tlsEnable"
|
|
49
|
+
)
|
|
50
|
+
custom_profile: Optional[Union[Global[bool], Default[bool], Variable]] = Field(
|
|
51
|
+
default=None,
|
|
52
|
+
serialization_alias="tlsPropertiesCustomProfile",
|
|
53
|
+
validation_alias="tlsPropertiesCustomProfile",
|
|
54
|
+
)
|
|
55
|
+
profile_properties: Optional[Union[Global[str], Variable]] = Field(
|
|
56
|
+
default=None, serialization_alias="tlsPropertiesProfile", validation_alias="tlsPropertiesProfile"
|
|
57
|
+
)
|
|
58
|
+
model_config = ConfigDict(populate_by_name=True)
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
class File(BaseModel):
|
|
62
|
+
disk_file_size: Optional[Union[Global[int], Default[int], Variable]] = Field(
|
|
63
|
+
default=as_default(10), serialization_alias="diskFileSize", validation_alias="diskFileSize"
|
|
64
|
+
)
|
|
65
|
+
disk_file_rotate: Optional[Union[Global[int], Default[int], Variable]] = Field(
|
|
66
|
+
default=as_default(10), serialization_alias="diskFileRotate", validation_alias="diskFileRotate"
|
|
67
|
+
)
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
class Disk(BaseModel):
|
|
71
|
+
disk_enable: Optional[Global[bool]] = Field(
|
|
72
|
+
default=None, serialization_alias="diskEnable", validation_alias="diskEnable"
|
|
73
|
+
)
|
|
74
|
+
file: File = Field(default_factory=File)
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
class LoggingParcel(_ParcelBase):
|
|
78
|
+
type_: Literal["logging"] = Field(default="logging", exclude=True)
|
|
79
|
+
model_config = ConfigDict(
|
|
80
|
+
extra="forbid",
|
|
81
|
+
populate_by_name=True,
|
|
82
|
+
)
|
|
83
|
+
disk: Disk = Field(default_factory=Disk, validation_alias=AliasPath("data", "disk"))
|
|
84
|
+
tls_profile: Optional[List[TlsProfile]] = Field(default=None, validation_alias=AliasPath("data", "tlsProfile"))
|
|
85
|
+
server: Optional[List[Server]] = Field(default=None, validation_alias=AliasPath("data", "server"))
|
|
86
|
+
ipv6_server: Optional[List[Server]] = Field(default=None, validation_alias=AliasPath("data", "ipv6Server"))
|
|
87
|
+
|
|
88
|
+
def set_disk(self, enable: bool, disk_file_size: int = 10, disk_file_rotate: int = 10):
|
|
89
|
+
self.disk.disk_enable = as_global(enable)
|
|
90
|
+
self.disk.file.disk_file_size = as_global(disk_file_size)
|
|
91
|
+
self.disk.file.disk_file_rotate = as_global(disk_file_rotate)
|
|
92
|
+
|
|
93
|
+
def add_tls_profile(
|
|
94
|
+
self, profile: str, version: TlsVersion = "TLSv1.1", ciphersuite_list: Optional[List[CypherSuite]] = None
|
|
95
|
+
):
|
|
96
|
+
if not self.tls_profile:
|
|
97
|
+
self.tls_profile = []
|
|
98
|
+
self.tls_profile.append(
|
|
99
|
+
TlsProfile(
|
|
100
|
+
profile=as_global(profile),
|
|
101
|
+
version=as_global(version, TlsVersion),
|
|
102
|
+
ciphersuite_list=Global[List[CypherSuite]](value=ciphersuite_list)
|
|
103
|
+
if ciphersuite_list
|
|
104
|
+
else Default[None](value=None),
|
|
105
|
+
)
|
|
106
|
+
)
|
|
107
|
+
|
|
108
|
+
def add_ipv4_server(
|
|
109
|
+
self,
|
|
110
|
+
name: str,
|
|
111
|
+
vpn: int = 0,
|
|
112
|
+
source_interface: Optional[str] = None,
|
|
113
|
+
priority: Priority = "informational",
|
|
114
|
+
enable_tls: bool = False,
|
|
115
|
+
custom_profile: bool = False,
|
|
116
|
+
profile_properties: Optional[str] = None,
|
|
117
|
+
):
|
|
118
|
+
item = self._create_server_item(
|
|
119
|
+
name, vpn, source_interface, priority, enable_tls, custom_profile, profile_properties
|
|
120
|
+
)
|
|
121
|
+
if not self.server:
|
|
122
|
+
self.server = []
|
|
123
|
+
self.server.append(item)
|
|
124
|
+
return item
|
|
125
|
+
|
|
126
|
+
def add_ipv6_server(
|
|
127
|
+
self,
|
|
128
|
+
name: str,
|
|
129
|
+
vpn: int = 0,
|
|
130
|
+
source_interface: Optional[str] = None,
|
|
131
|
+
priority: Priority = "informational",
|
|
132
|
+
enable_tls: bool = False,
|
|
133
|
+
custom_profile: bool = False,
|
|
134
|
+
profile_properties: Optional[str] = None,
|
|
135
|
+
):
|
|
136
|
+
item = self._create_server_item(
|
|
137
|
+
name, vpn, source_interface, priority, enable_tls, custom_profile, profile_properties
|
|
138
|
+
)
|
|
139
|
+
if not self.ipv6_server:
|
|
140
|
+
self.ipv6_server = []
|
|
141
|
+
self.ipv6_server.append(item)
|
|
142
|
+
return item
|
|
143
|
+
|
|
144
|
+
def _create_server_item(
|
|
145
|
+
self,
|
|
146
|
+
name: str,
|
|
147
|
+
vpn: int,
|
|
148
|
+
source_interface: Optional[str] = None,
|
|
149
|
+
priority: Priority = "informational",
|
|
150
|
+
enable_tls: bool = False,
|
|
151
|
+
custom_profile: bool = False,
|
|
152
|
+
profile_properties: Optional[str] = None,
|
|
153
|
+
):
|
|
154
|
+
return Server(
|
|
155
|
+
name=as_global(name),
|
|
156
|
+
vpn=as_global(vpn),
|
|
157
|
+
source_interface=as_global(source_interface) if source_interface else Default[None](value=None),
|
|
158
|
+
priority=as_global(priority, Priority),
|
|
159
|
+
enable_tls=as_global(enable_tls),
|
|
160
|
+
custom_profile=as_global(custom_profile) if custom_profile else None,
|
|
161
|
+
profile_properties=as_global(profile_properties) if profile_properties else None,
|
|
162
|
+
)
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
# Copyright 2024 Cisco Systems, Inc. and its affiliates
|
|
2
|
+
from __future__ import annotations
|
|
3
|
+
|
|
4
|
+
from typing import List, Literal, Optional, Union
|
|
5
|
+
|
|
6
|
+
from pydantic import AliasPath, BaseModel, ConfigDict, Field
|
|
7
|
+
|
|
8
|
+
from catalystwan.api.configuration_groups.parcel import Default, Global, Variable, _ParcelBase, as_default
|
|
9
|
+
|
|
10
|
+
EnableMrfMigration = Literal["enabled", "enabled-from-bgp-core"]
|
|
11
|
+
Role = Literal["edge-router", "border-router"]
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class ManagementRegion(BaseModel):
|
|
15
|
+
model_config = ConfigDict(
|
|
16
|
+
extra="forbid",
|
|
17
|
+
populate_by_name=True,
|
|
18
|
+
)
|
|
19
|
+
vrf_id: Union[Global[int], Default[None], Variable] = Field(
|
|
20
|
+
default=Default[None](value=None),
|
|
21
|
+
serialization_alias="vrfId",
|
|
22
|
+
validation_alias="vrfId",
|
|
23
|
+
description="VRF name for management region",
|
|
24
|
+
)
|
|
25
|
+
gateway_preference: Optional[Union[Global[List[int]], Default[None], Variable]] = Field(
|
|
26
|
+
default=Default[None](value=None),
|
|
27
|
+
serialization_alias="gatewayPreference",
|
|
28
|
+
validation_alias="gatewayPreference",
|
|
29
|
+
description="List of affinity group preferences for VRF",
|
|
30
|
+
)
|
|
31
|
+
management_gateway: Union[Global[bool], Default[bool], Variable] = Field(
|
|
32
|
+
default=as_default(False),
|
|
33
|
+
serialization_alias="managementGateway",
|
|
34
|
+
validation_alias="managementGateway",
|
|
35
|
+
description="Enable management gateway",
|
|
36
|
+
)
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
class MRFParcel(_ParcelBase):
|
|
40
|
+
type_: Literal["mrf"] = Field(default="mrf", exclude=True)
|
|
41
|
+
|
|
42
|
+
model_config = ConfigDict(
|
|
43
|
+
extra="forbid",
|
|
44
|
+
populate_by_name=True,
|
|
45
|
+
)
|
|
46
|
+
secondary_region: Union[Global[int], Variable, Default[None]] = Field(
|
|
47
|
+
default=Default[None](value=None),
|
|
48
|
+
validation_alias=AliasPath("data", "secondaryRegion"),
|
|
49
|
+
description="Set secondary region ID",
|
|
50
|
+
)
|
|
51
|
+
role: Union[Global[Role], Variable, Default[None]] = Field(
|
|
52
|
+
default=Default[None](value=None),
|
|
53
|
+
validation_alias=AliasPath("data", "role"),
|
|
54
|
+
description="Set the role for router",
|
|
55
|
+
)
|
|
56
|
+
enable_mrf_migration: Union[Global[EnableMrfMigration], Default[None]] = Field(
|
|
57
|
+
default=Default[None](value=None),
|
|
58
|
+
validation_alias=AliasPath("data", "enableMrfMigration"),
|
|
59
|
+
description="Enable migration mode to Multi-Region Fabric",
|
|
60
|
+
)
|
|
61
|
+
migration_bgp_community: Optional[Union[Global[int], Default[None]]] = Field(
|
|
62
|
+
default=Default[None](value=None),
|
|
63
|
+
validation_alias=AliasPath("data", "migrationBgpCommunity"),
|
|
64
|
+
description="Set BGP community during migration from BGP-core based network",
|
|
65
|
+
)
|
|
66
|
+
enable_management_region: Union[Global[bool], Default[bool], Variable] = Field(
|
|
67
|
+
default=as_default(False),
|
|
68
|
+
validation_alias=AliasPath("data", "enableManagementRegion"),
|
|
69
|
+
description="Enable management region",
|
|
70
|
+
)
|
|
71
|
+
management_region: ManagementRegion = Field(
|
|
72
|
+
default_factory=ManagementRegion,
|
|
73
|
+
validation_alias=AliasPath("data", "managementRegion"),
|
|
74
|
+
description="Management Region",
|
|
75
|
+
)
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
# Copyright 2024 Cisco Systems, Inc. and its affiliates
|
|
2
|
+
from __future__ import annotations
|
|
3
|
+
|
|
4
|
+
from ipaddress import IPv4Address, IPv6Address
|
|
5
|
+
from typing import List, Literal, Optional, Union
|
|
6
|
+
|
|
7
|
+
from pydantic import AliasPath, BaseModel, ConfigDict, Field
|
|
8
|
+
|
|
9
|
+
from catalystwan.api.configuration_groups.parcel import Default, Global, Variable, _ParcelBase, as_default
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
class ServerItem(BaseModel):
|
|
13
|
+
model_config = ConfigDict(
|
|
14
|
+
extra="forbid",
|
|
15
|
+
populate_by_name=True,
|
|
16
|
+
)
|
|
17
|
+
name: Union[Variable, Global[str], Global[IPv6Address], Global[IPv4Address]] = Field(
|
|
18
|
+
..., description="Set hostname or IP address of server"
|
|
19
|
+
)
|
|
20
|
+
key: Optional[Union[Variable, Global[int], Default[None]]] = Field(
|
|
21
|
+
None, description="Set authentication key for the server"
|
|
22
|
+
)
|
|
23
|
+
vpn: Union[Variable, Global[int], Default[int]] = Field(
|
|
24
|
+
default=as_default(0), description="Set VPN in which NTP server is located"
|
|
25
|
+
)
|
|
26
|
+
version: Union[Variable, Global[int], Default[int]] = Field(default=as_default(4), description="Set NTP version")
|
|
27
|
+
source_interface: Optional[Union[Variable, Global[str], Default[None]]] = Field(
|
|
28
|
+
None,
|
|
29
|
+
serialization_alias="sourceInterface",
|
|
30
|
+
validation_alias="sourceInterface",
|
|
31
|
+
description="Set interface to use to reach NTP server",
|
|
32
|
+
)
|
|
33
|
+
prefer: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
34
|
+
default=as_default(False), description="Variable this NTP server"
|
|
35
|
+
)
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
class AuthenticationVariable(BaseModel):
|
|
39
|
+
model_config = ConfigDict(
|
|
40
|
+
extra="forbid",
|
|
41
|
+
populate_by_name=True,
|
|
42
|
+
)
|
|
43
|
+
key_id: Union[Variable, Global[int]] = Field(
|
|
44
|
+
..., serialization_alias="keyId", validation_alias="keyId", description="MD5 authentication key ID"
|
|
45
|
+
)
|
|
46
|
+
md5_value: Union[Variable, Global[str]] = Field(
|
|
47
|
+
...,
|
|
48
|
+
serialization_alias="md5Value",
|
|
49
|
+
validation_alias="md5Value",
|
|
50
|
+
description="Enter cleartext or AES-encrypted MD5 authentication key"
|
|
51
|
+
"[Note: Catalyst SD-WAN Manager will encrypt this field before saving."
|
|
52
|
+
"Cleartext strings will not be returned back to the user in GET responses for sensitive fields.]",
|
|
53
|
+
)
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
class Authentication(BaseModel):
|
|
57
|
+
model_config = ConfigDict(
|
|
58
|
+
extra="forbid",
|
|
59
|
+
populate_by_name=True,
|
|
60
|
+
)
|
|
61
|
+
authentication_keys: List[AuthenticationVariable] = Field(
|
|
62
|
+
default_factory=list,
|
|
63
|
+
serialization_alias="authenticationKeys",
|
|
64
|
+
validation_alias="authenticationKeys",
|
|
65
|
+
description="Set MD5 authentication key",
|
|
66
|
+
)
|
|
67
|
+
trusted_keys: Optional[Union[Variable, Global[List[int]], Default[None]]] = Field(
|
|
68
|
+
None,
|
|
69
|
+
serialization_alias="trustedKeys",
|
|
70
|
+
validation_alias="trustedKeys",
|
|
71
|
+
description="Designate authentication key as trustworthy",
|
|
72
|
+
)
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
class Leader(BaseModel):
|
|
76
|
+
model_config = ConfigDict(
|
|
77
|
+
extra="forbid",
|
|
78
|
+
populate_by_name=True,
|
|
79
|
+
)
|
|
80
|
+
enable: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
81
|
+
default=as_default(False), description="Variable device as NTP Leader"
|
|
82
|
+
)
|
|
83
|
+
stratum: Optional[Union[Variable, Global[int], Default[None]]] = Field(
|
|
84
|
+
default=as_default(None), description="Variable device as NTP Leader"
|
|
85
|
+
)
|
|
86
|
+
source: Optional[Union[Variable, Global[str], Default[None]]] = Field(
|
|
87
|
+
default=as_default(None), description="Variable device as NTP Leader"
|
|
88
|
+
)
|
|
89
|
+
|
|
90
|
+
|
|
91
|
+
class NtpParcel(_ParcelBase):
|
|
92
|
+
type_: Literal["ntp"] = Field(default="ntp", exclude=True)
|
|
93
|
+
model_config = ConfigDict(
|
|
94
|
+
extra="forbid",
|
|
95
|
+
populate_by_name=True,
|
|
96
|
+
)
|
|
97
|
+
server: List[ServerItem] = Field(
|
|
98
|
+
default_factory=list, validation_alias=AliasPath("data", "server"), description="Configure NTP servers"
|
|
99
|
+
)
|
|
100
|
+
authentication: Authentication = Field(
|
|
101
|
+
default_factory=Authentication, validation_alias=AliasPath("data", "authentication") # type: ignore
|
|
102
|
+
)
|
|
103
|
+
leader: Leader = Field(default_factory=Leader, validation_alias=AliasPath("data", "leader")) # type: ignore
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
# Copyright 2024 Cisco Systems, Inc. and its affiliates
|
|
2
|
+
from __future__ import annotations
|
|
3
|
+
|
|
4
|
+
from typing import List, Literal, Optional, Union
|
|
5
|
+
|
|
6
|
+
from pydantic import AliasPath, BaseModel, ConfigDict, Field
|
|
7
|
+
|
|
8
|
+
from catalystwan.api.configuration_groups.parcel import Default, Global, Variable, _ParcelBase
|
|
9
|
+
|
|
10
|
+
SiteTypesForTransportGateway = Literal["type-1", "type-2", "type-3", "cloud", "branch", "br", "spoke"]
|
|
11
|
+
TransportGateway = Literal["prefer", "ecmp-with-direct-path"]
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class AdvertiseIp(BaseModel):
|
|
15
|
+
model_config = ConfigDict(
|
|
16
|
+
extra="forbid",
|
|
17
|
+
)
|
|
18
|
+
bgp: Union[Variable, Global[bool], Default[bool]] = Field(default=Default[bool](value=False), description="BGP")
|
|
19
|
+
ospf: Union[Variable, Global[bool], Default[bool]] = Field(default=Default[bool](value=False), description="OSPF")
|
|
20
|
+
connected: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
21
|
+
default=Default[bool](value=False), description="Variable"
|
|
22
|
+
)
|
|
23
|
+
static: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
24
|
+
default=Default[bool](value=False), description="Variable"
|
|
25
|
+
)
|
|
26
|
+
eigrp: Union[Variable, Global[bool], Default[bool]] = Field(default=Default[bool](value=False), description="EIGRP")
|
|
27
|
+
lisp: Union[Variable, Global[bool], Default[bool]] = Field(default=Default[bool](value=False), description="LISP")
|
|
28
|
+
isis: Union[Variable, Global[bool], Default[bool]] = Field(default=Default[bool](value=False), description="ISIS")
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
class AdvertiseIpv6(AdvertiseIp):
|
|
32
|
+
pass
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
class AdvertiseIpv4(AdvertiseIp):
|
|
36
|
+
ospfv3: Union[Variable, Global[bool], Default[bool]] = Field(default=Default[bool](value=False), description="OSPF")
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
class OMPParcel(_ParcelBase):
|
|
40
|
+
type_: Literal["omp"] = Field(default="omp", exclude=True)
|
|
41
|
+
|
|
42
|
+
model_config = ConfigDict(
|
|
43
|
+
extra="forbid",
|
|
44
|
+
populate_by_name=True,
|
|
45
|
+
)
|
|
46
|
+
graceful_restart: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
47
|
+
default=Default[bool](value=True),
|
|
48
|
+
validation_alias=AliasPath("data", "gracefulRestart"),
|
|
49
|
+
description="Graceful Restart for OMP",
|
|
50
|
+
)
|
|
51
|
+
overlay_as: Union[Variable, Global[float], Default[None]] = Field(
|
|
52
|
+
default=Default[None](value=None),
|
|
53
|
+
validation_alias=AliasPath("data", "overlayAs"),
|
|
54
|
+
description="Overlay AS Number",
|
|
55
|
+
)
|
|
56
|
+
send_path_limit: Union[Variable, Global[int], Default[int]] = Field(
|
|
57
|
+
default=Default[int](value=4),
|
|
58
|
+
validation_alias=AliasPath("data", "sendPathLimit"),
|
|
59
|
+
description="Number of Paths Advertised per Prefix",
|
|
60
|
+
)
|
|
61
|
+
ecmp_limit: Union[Variable, Global[float], Default[int]] = Field(
|
|
62
|
+
default=Default[int](value=4),
|
|
63
|
+
validation_alias=AliasPath("data", "ecmpLimit"),
|
|
64
|
+
description="Set maximum number of OMP paths to install in cEdge route table",
|
|
65
|
+
)
|
|
66
|
+
shutdown: Union[Variable, Global[bool], Default[bool]] = Field(
|
|
67
|
+
default=Default[bool](value=False), validation_alias=AliasPath("data", "shutdown"), description="Variable"
|
|
68
|
+
)
|
|
69
|
+
omp_admin_distance_ipv4: Union[Variable, Global[int], Default[int]] = Field(
|
|
70
|
+
default=Default[int](value=251),
|
|
71
|
+
validation_alias=AliasPath("data", "ompAdminDistanceIpv4"),
|
|
72
|
+
description="OMP Admin Distance IPv4",
|
|
73
|
+
)
|
|
74
|
+
omp_admin_distance_ipv6: Union[Variable, Global[int], Default[int]] = Field(
|
|
75
|
+
default=Default[int](value=251),
|
|
76
|
+
validation_alias=AliasPath("data", "ompAdminDistanceIpv6"),
|
|
77
|
+
description="OMP Admin Distance IPv6",
|
|
78
|
+
)
|
|
79
|
+
advertisement_interval: Union[Variable, Global[int], Default[int]] = Field(
|
|
80
|
+
default=Default[int](value=1),
|
|
81
|
+
validation_alias=AliasPath("data", "advertisementInterval"),
|
|
82
|
+
description="Advertisement Interval (seconds)",
|
|
83
|
+
)
|
|
84
|
+
graceful_restart_timer: Union[Variable, Global[int], Default[int]] = Field(
|
|
85
|
+
default=Default[int](value=43200),
|
|
86
|
+
validation_alias=AliasPath("data", "gracefulRestartTimer"),
|
|
87
|
+
description="Graceful Restart Timer (seconds)",
|
|
88
|
+
)
|
|
89
|
+
eor_timer: Union[Variable, Global[int], Default[int]] = Field(
|
|
90
|
+
default=Default[int](value=300), validation_alias=AliasPath("data", "eorTimer"), description="EOR Timer"
|
|
91
|
+
)
|
|
92
|
+
holdtime: Union[Variable, Global[int], Default[int]] = Field(
|
|
93
|
+
default=Default[int](value=60),
|
|
94
|
+
validation_alias=AliasPath("data", "holdtime"),
|
|
95
|
+
description="Hold Time (seconds)",
|
|
96
|
+
)
|
|
97
|
+
advertise_ipv4: AdvertiseIpv4 = Field(
|
|
98
|
+
default_factory=AdvertiseIpv4, validation_alias=AliasPath("data", "advertiseIpv4")
|
|
99
|
+
)
|
|
100
|
+
advertise_ipv6: AdvertiseIpv6 = Field(
|
|
101
|
+
default_factory=AdvertiseIpv6, validation_alias=AliasPath("data", "advertiseIpv6")
|
|
102
|
+
)
|
|
103
|
+
ignore_region_path_length: Optional[Union[Variable, Global[bool], Default[bool]]] = Field(
|
|
104
|
+
None,
|
|
105
|
+
validation_alias=AliasPath("data", "ignoreRegionPathLength"),
|
|
106
|
+
description="Treat hierarchical and direct (secondary region) paths equally",
|
|
107
|
+
)
|
|
108
|
+
transport_gateway: Optional[Union[Variable, Global[TransportGateway], Default[None]]] = Field(
|
|
109
|
+
None, validation_alias=AliasPath("data", "transportGateway"), description="Transport Gateway Path Behavior"
|
|
110
|
+
)
|
|
111
|
+
site_types_for_transport_gateway: Optional[
|
|
112
|
+
Union[
|
|
113
|
+
Variable,
|
|
114
|
+
Global[List[SiteTypesForTransportGateway]],
|
|
115
|
+
Default[None],
|
|
116
|
+
]
|
|
117
|
+
] = Field(None, validation_alias=AliasPath("data", "siteTypesForVariable"), description="Site Types")
|
|
118
|
+
site_types: Optional[Union[Global[List[SiteTypesForTransportGateway]], Variable, Default[None]]] = Field(
|
|
119
|
+
default=None, validation_alias=AliasPath("data", "siteTypes")
|
|
120
|
+
)
|