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