graphiant-sdk 25.9.1__py3-none-any.whl → 25.10.1__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 (186) hide show
  1. graphiant_sdk/__init__.py +271 -76
  2. graphiant_sdk/api/default_api.py +25113 -10436
  3. graphiant_sdk/api_client.py +1 -1
  4. graphiant_sdk/configuration.py +1 -1
  5. graphiant_sdk/models/__init__.py +180 -50
  6. graphiant_sdk/models/v1_auth_login_temp_post200_response.py +91 -0
  7. graphiant_sdk/models/v1_auth_login_temp_post_request.py +89 -0
  8. graphiant_sdk/models/v1_b2b_extranet_monitoring_filter_post200_response.py +91 -0
  9. graphiant_sdk/models/v1_b2b_extranet_monitoring_filter_post200_response_filters.py +104 -0
  10. graphiant_sdk/models/{v1_edges_hardware_assigned_get200_response_edges_summary_inner_upgrade_summary_running_version.py → v1_b2b_extranet_monitoring_filter_post200_response_filters_customers_inner.py} +12 -10
  11. graphiant_sdk/models/v1_b2b_extranet_monitoring_filter_post_request.py +91 -0
  12. graphiant_sdk/models/v1_backbone_health_device_device_id_post200_response.py +3 -3
  13. graphiant_sdk/models/v1_bwtracker_enterprise_details_post200_response_bwusage_details.py +11 -2
  14. graphiant_sdk/models/v1_devices_device_id_config_put_request_core_core_vrf_bgp_neighbors_value_neighbor.py +6 -6
  15. graphiant_sdk/models/v1_devices_device_id_config_put_request_edge_interfaces_value_interface.py +6 -2
  16. graphiant_sdk/models/v1_devices_device_id_config_put_request_edge_site_to_site_vpn_value_site_to_site_vpn.py +3 -3
  17. graphiant_sdk/models/v1_devices_running_version_post200_response_versions_inner.py +3 -3
  18. graphiant_sdk/models/v1_devices_upgrade_schedule_put_request.py +14 -4
  19. graphiant_sdk/models/{v1_devices_device_id_staged_config_compare_get200_response.py → v1_diagnostic_reboot_device_id_put_request.py} +8 -8
  20. graphiant_sdk/models/v1_edges_hardware_assigned_get200_response_edges_summary_inner_upgrade_summary.py +17 -5
  21. graphiant_sdk/models/v1_edges_hardware_assigned_get200_response_edges_summary_inner_upgrade_summary_schedule.py +3 -3
  22. graphiant_sdk/models/v1_enterprise_allocation_get200_response_consumption_summary_global_summary.py +5 -1
  23. graphiant_sdk/models/v1_enterprises_get200_response_enterprises_inner.py +3 -1
  24. graphiant_sdk/models/v1_enterprises_patch_request.py +3 -1
  25. graphiant_sdk/models/{v1_extranet_sites_usage_post200_response.py → v1_extranet_b2b_monitoring_peering_service_bandwidth_usage_post200_response.py} +9 -9
  26. graphiant_sdk/models/{v2_extranet_service_overtime_consumption_post200_response_dl_agg_stats_inner.py → v1_extranet_b2b_monitoring_peering_service_bandwidth_usage_post200_response_dl_stats_inner.py} +4 -4
  27. graphiant_sdk/models/{v1_extranet_sites_usage_post_request.py → v1_extranet_b2b_monitoring_peering_service_bandwidth_usage_post_request.py} +4 -4
  28. graphiant_sdk/models/{v1_bwtracker_region_site_summary_post200_response_bwusage_summary.py → v1_extranet_b2b_monitoring_peering_service_consumers_usage_top_post200_response.py} +18 -21
  29. graphiant_sdk/models/{v2_extranet_consumers_usage_top_post200_response_top_consumers_inner.py → v1_extranet_b2b_monitoring_peering_service_consumers_usage_top_post200_response_top_consumers_inner.py} +4 -4
  30. graphiant_sdk/models/{v2_extranet_lan_segments_usage_top_post_request.py → v1_extranet_b2b_monitoring_peering_service_consumers_usage_top_post_request.py} +4 -4
  31. graphiant_sdk/models/v1_extranet_b2b_monitoring_peering_service_consumption_overview_post200_response.py +115 -0
  32. graphiant_sdk/models/{v2_extranet_sites_consumption_overview_post200_response_lan_segments_inner.py → v1_extranet_b2b_monitoring_peering_service_consumption_overview_post200_response_first_level_inner.py} +4 -4
  33. graphiant_sdk/models/v1_extranet_b2b_monitoring_peering_service_consumption_overview_post_request.py +105 -0
  34. graphiant_sdk/models/v1_extranet_b2b_monitoring_peering_service_service_customer_list_post200_response.py +87 -0
  35. graphiant_sdk/models/{v2_extranet_consumers_usage_top_post_request.py → v1_extranet_b2b_monitoring_peering_service_service_customer_list_post_request.py} +7 -7
  36. graphiant_sdk/models/v1_extranet_b2b_monitoring_peering_service_service_health_post200_response.py +95 -0
  37. graphiant_sdk/models/v1_extranet_b2b_monitoring_peering_service_service_health_post200_response_service_health_inner.py +100 -0
  38. graphiant_sdk/models/v1_extranet_b2b_monitoring_peering_service_service_health_post200_response_service_health_inner_customer_prefix_health.py +89 -0
  39. graphiant_sdk/models/{v2_extranet_service_overtime_consumption_post200_response.py → v1_extranet_b2b_monitoring_peering_service_service_overtime_consumption_post200_response.py} +9 -9
  40. graphiant_sdk/models/{v2_extranet_sites_consumption_overview_post_request.py → v1_extranet_b2b_monitoring_peering_service_service_overtime_consumption_post_request.py} +4 -4
  41. graphiant_sdk/models/v1_extranets_b2b_general_customers_summary_get200_response.py +95 -0
  42. graphiant_sdk/models/v1_extranets_b2b_general_customers_summary_get200_response_customers_inner.py +104 -0
  43. graphiant_sdk/models/{v1_healthcheck_devices_get200_response.py → v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response.py} +8 -8
  44. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response_details_inner.py +109 -0
  45. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response_details_inner_customer.py +94 -0
  46. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response_details_inner_service.py +93 -0
  47. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post200_response.py +109 -0
  48. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request.py +123 -0
  49. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_policy_inner.py +89 -0
  50. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn.py +95 -0
  51. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details.py +117 -0
  52. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing.py +97 -0
  53. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp.py +115 -0
  54. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value.py +91 -0
  55. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value_family.py +98 -0
  56. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_md5_password.py +87 -0
  57. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_static.py +87 -0
  58. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_tunnel1.py +93 -0
  59. graphiant_sdk/models/{v1_healthcheck_devices_get200_response_details_inner_onboarding_status.py → v1_extranets_b2b_peering_customer_id_get200_response.py} +17 -10
  60. graphiant_sdk/models/v1_extranets_b2b_peering_customer_id_put_request.py +87 -0
  61. graphiant_sdk/models/v1_extranets_b2b_peering_customer_post200_response.py +93 -0
  62. graphiant_sdk/models/v1_extranets_b2b_peering_customer_post_request.py +95 -0
  63. graphiant_sdk/models/{v1_global_site_lists_id_sites_get200_response_entries_inner_tag_inner.py → v1_extranets_b2b_peering_customer_post_request_invite.py} +11 -12
  64. graphiant_sdk/models/v1_extranets_b2b_peering_match_customers_post200_response.py +95 -0
  65. graphiant_sdk/models/{v2_extranet_consumers_usage_top_post200_response.py → v1_extranets_b2b_peering_match_customers_post_request.py} +17 -15
  66. graphiant_sdk/models/v1_extranets_b2b_peering_match_customers_post_request_info_inner.py +104 -0
  67. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_post200_response.py +95 -0
  68. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_put200_response.py +91 -0
  69. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_put_request.py +93 -0
  70. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_put_request_service.py +112 -0
  71. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_put_request_service_nat_inner.py +89 -0
  72. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_put_request_service_service_prefixes_inner.py +89 -0
  73. graphiant_sdk/models/v1_extranets_b2b_peering_match_services_summary_get200_response.py +95 -0
  74. graphiant_sdk/models/v1_extranets_b2b_peering_match_services_summary_get200_response_services_inner.py +104 -0
  75. graphiant_sdk/models/v1_extranets_b2b_peering_producer_id_get200_response.py +95 -0
  76. graphiant_sdk/models/v1_extranets_b2b_peering_producer_id_put_request.py +91 -0
  77. graphiant_sdk/models/v1_extranets_b2b_peering_producer_post200_response.py +93 -0
  78. graphiant_sdk/models/v1_extranets_b2b_peering_producer_post200_response_policy.py +93 -0
  79. graphiant_sdk/models/v1_extranets_b2b_peering_producer_post_request.py +95 -0
  80. graphiant_sdk/models/v1_extranets_b2b_peering_producer_post_request_policy.py +111 -0
  81. graphiant_sdk/models/v1_extranets_b2b_post_request_policy.py +19 -2
  82. graphiant_sdk/models/v1_extranets_b2b_producers_summary_get200_response_info_inner.py +16 -3
  83. graphiant_sdk/models/v1_extranets_get200_response_policies_inner_branches_excluded_devices_inner_ipsec_tunnels_inner.py +3 -3
  84. graphiant_sdk/models/{v1_bwtracker_region_site_summary_post200_response.py → v1_gateways_guest_consumer_get200_response.py} +11 -11
  85. graphiant_sdk/models/v1_gateways_put_request_details.py +3 -3
  86. graphiant_sdk/models/v1_global_site_lists_id_sites_get200_response_entries_inner.py +3 -3
  87. graphiant_sdk/models/v1_groups_get200_response_groups_inner_permissions.py +3 -1
  88. graphiant_sdk/models/v1_groups_id_members_get200_response_users_inner.py +7 -1
  89. graphiant_sdk/models/v1_groups_id_members_post_request.py +5 -3
  90. graphiant_sdk/models/{v1_healthcheck_devices_get200_response_details_inner_odp_status.py → v1_invitation_email_post_request.py} +17 -11
  91. graphiant_sdk/models/v1_software_auto_upgrade_default_get200_response.py +7 -7
  92. graphiant_sdk/models/v1_software_releases_summary_get200_response_summaries_inner.py +6 -1
  93. graphiant_sdk/models/v1_temp_password_put_request.py +91 -0
  94. graphiant_sdk/models/v1_troubleshooting_device_device_id_post200_response.py +3 -3
  95. graphiant_sdk/models/{v2_assistant_conversation_context_history_post_request.py → v2_aggregated_notification_enable_disable_post_request.py} +4 -4
  96. graphiant_sdk/models/v2_aggregated_notification_get_state_get200_response.py +87 -0
  97. graphiant_sdk/models/v2_assistant_add_to_conversation_post200_response.py +4 -2
  98. graphiant_sdk/models/v2_assistant_get_conversations_post200_response.py +5 -3
  99. graphiant_sdk/models/v2_assistant_get_conversations_post200_response_conversation_list_inner.py +5 -3
  100. graphiant_sdk/models/v2_assurance_applicationdetailsbyname_post200_response_app_id_record.py +13 -1
  101. graphiant_sdk/models/{v1_software_auto_upgrade_default_get200_response_details.py → v2_assurance_applicationdetailsbyname_post200_response_app_id_record_exchange_service_inner.py} +9 -15
  102. graphiant_sdk/models/v2_assurance_applicationdetailsbyname_post200_response_app_name_record.py +11 -1
  103. graphiant_sdk/models/v2_assurance_bucket_app_servers_post_request.py +3 -1
  104. graphiant_sdk/models/v2_assurance_bucket_apps_post200_response_apps_inner.py +7 -1
  105. graphiant_sdk/models/v2_assurance_bucket_apps_post_request.py +3 -1
  106. graphiant_sdk/models/v2_assurance_bucket_services_post200_response.py +95 -0
  107. graphiant_sdk/models/{v2_assurance_bucket_topologies_post_request.py → v2_assurance_bucket_services_post_request.py} +4 -4
  108. graphiant_sdk/models/v2_extranet_lan_segments_usage_top_post200_response.py +3 -3
  109. graphiant_sdk/models/v2_extranet_sites_consumption_overview_post200_response.py +7 -7
  110. {graphiant_sdk-25.9.1.dist-info → graphiant_sdk-25.10.1.dist-info}/METADATA +3 -3
  111. {graphiant_sdk-25.9.1.dist-info → graphiant_sdk-25.10.1.dist-info}/RECORD +185 -65
  112. test/test_v1_auth_login_temp_post200_response.py +53 -0
  113. test/test_v1_auth_login_temp_post_request.py +52 -0
  114. test/test_v1_b2b_extranet_monitoring_filter_post200_response.py +65 -0
  115. test/test_v1_b2b_extranet_monitoring_filter_post200_response_filters.py +64 -0
  116. test/test_v1_b2b_extranet_monitoring_filter_post200_response_filters_customers_inner.py +54 -0
  117. test/test_v1_b2b_extranet_monitoring_filter_post_request.py +53 -0
  118. test/test_v1_diagnostic_reboot_device_id_put_request.py +51 -0
  119. test/test_v1_extranet_b2b_monitoring_peering_service_bandwidth_usage_post200_response.py +67 -0
  120. test/test_v1_extranet_b2b_monitoring_peering_service_bandwidth_usage_post200_response_dl_stats_inner.py +55 -0
  121. test/test_v1_extranet_b2b_monitoring_peering_service_bandwidth_usage_post_request.py +64 -0
  122. test/test_v1_extranet_b2b_monitoring_peering_service_consumers_usage_top_post200_response.py +58 -0
  123. test/test_v1_extranet_b2b_monitoring_peering_service_consumers_usage_top_post200_response_top_consumers_inner.py +53 -0
  124. test/test_v1_extranet_b2b_monitoring_peering_service_consumers_usage_top_post_request.py +61 -0
  125. test/test_v1_extranet_b2b_monitoring_peering_service_consumption_overview_post200_response.py +81 -0
  126. test/test_v1_extranet_b2b_monitoring_peering_service_consumption_overview_post200_response_first_level_inner.py +57 -0
  127. test/test_v1_extranet_b2b_monitoring_peering_service_consumption_overview_post_request.py +65 -0
  128. test/test_v1_extranet_b2b_monitoring_peering_service_service_customer_list_post200_response.py +53 -0
  129. test/test_v1_extranet_b2b_monitoring_peering_service_service_customer_list_post_request.py +60 -0
  130. test/test_v1_extranet_b2b_monitoring_peering_service_service_health_post200_response.py +62 -0
  131. test/test_v1_extranet_b2b_monitoring_peering_service_service_health_post200_response_service_health_inner.py +62 -0
  132. test/test_v1_extranet_b2b_monitoring_peering_service_service_health_post200_response_service_health_inner_customer_prefix_health.py +54 -0
  133. test/test_v1_extranet_b2b_monitoring_peering_service_service_overtime_consumption_post200_response.py +66 -0
  134. test/test_v1_extranet_b2b_monitoring_peering_service_service_overtime_consumption_post_request.py +63 -0
  135. test/test_v1_extranets_b2b_general_customers_summary_get200_response.py +64 -0
  136. test/test_v1_extranets_b2b_general_customers_summary_get200_response_customers_inner.py +61 -0
  137. test/test_v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response.py +75 -0
  138. test/test_v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response_details_inner.py +72 -0
  139. test/test_v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response_details_inner_customer.py +56 -0
  140. test/test_v1_extranets_b2b_peering_consumer_customer_id_match_details_get200_response_details_inner_service.py +56 -0
  141. test/test_v1_extranets_b2b_peering_consumer_id_post200_response.py +74 -0
  142. test/test_v1_extranets_b2b_peering_consumer_id_post_request.py +123 -0
  143. test/test_v1_extranets_b2b_peering_consumer_id_post_request_policy_inner.py +54 -0
  144. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn.py +92 -0
  145. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details.py +87 -0
  146. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing.py +69 -0
  147. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp.py +64 -0
  148. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value.py +56 -0
  149. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value_family.py +55 -0
  150. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_md5_password.py +51 -0
  151. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_static.py +53 -0
  152. test/test_v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_tunnel1.py +54 -0
  153. test/test_v1_extranets_b2b_peering_customer_id_get200_response.py +57 -0
  154. test/test_v1_extranets_b2b_peering_customer_id_put_request.py +51 -0
  155. test/test_v1_extranets_b2b_peering_customer_post200_response.py +56 -0
  156. test/test_v1_extranets_b2b_peering_customer_post_request.py +57 -0
  157. test/test_v1_extranets_b2b_peering_customer_post_request_invite.py +54 -0
  158. test/test_v1_extranets_b2b_peering_match_customers_post200_response.py +64 -0
  159. test/test_v1_extranets_b2b_peering_match_customers_post_request.py +65 -0
  160. test/test_v1_extranets_b2b_peering_match_customers_post_request_info_inner.py +61 -0
  161. test/test_v1_extranets_b2b_peering_match_service_to_customer_post200_response.py +66 -0
  162. test/test_v1_extranets_b2b_peering_match_service_to_customer_put200_response.py +64 -0
  163. test/test_v1_extranets_b2b_peering_match_service_to_customer_put_request.py +65 -0
  164. test/test_v1_extranets_b2b_peering_match_service_to_customer_put_request_service.py +63 -0
  165. test/test_v1_extranets_b2b_peering_match_service_to_customer_put_request_service_nat_inner.py +52 -0
  166. test/test_v1_extranets_b2b_peering_match_service_to_customer_put_request_service_service_prefixes_inner.py +52 -0
  167. test/test_v1_extranets_b2b_peering_match_services_summary_get200_response.py +62 -0
  168. test/test_v1_extranets_b2b_peering_match_services_summary_get200_response_services_inner.py +59 -0
  169. test/test_v1_extranets_b2b_peering_producer_id_get200_response.py +80 -0
  170. test/test_v1_extranets_b2b_peering_producer_id_put_request.py +76 -0
  171. test/test_v1_extranets_b2b_peering_producer_post200_response.py +79 -0
  172. test/test_v1_extranets_b2b_peering_producer_post200_response_policy.py +77 -0
  173. test/test_v1_extranets_b2b_peering_producer_post_request.py +78 -0
  174. test/test_v1_extranets_b2b_peering_producer_post_request_policy.py +75 -0
  175. test/test_v1_gateways_guest_consumer_get200_response.py +93 -0
  176. test/test_v1_invitation_email_post_request.py +55 -0
  177. test/test_v1_temp_password_put_request.py +55 -0
  178. test/test_v2_aggregated_notification_enable_disable_post_request.py +51 -0
  179. test/test_v2_aggregated_notification_get_state_get200_response.py +51 -0
  180. test/test_v2_assurance_applicationdetailsbyname_post200_response_app_id_record_exchange_service_inner.py +52 -0
  181. test/test_v2_assurance_bucket_services_post200_response.py +55 -0
  182. test/test_v2_assurance_bucket_services_post_request.py +51 -0
  183. graphiant_sdk/models/v1_healthcheck_devices_get200_response_details_inner.py +0 -124
  184. {graphiant_sdk-25.9.1.dist-info → graphiant_sdk-25.10.1.dist-info}/WHEEL +0 -0
  185. {graphiant_sdk-25.9.1.dist-info → graphiant_sdk-25.10.1.dist-info}/licenses/LICENSE +0 -0
  186. {graphiant_sdk-25.9.1.dist-info → graphiant_sdk-25.10.1.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,115 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ Graphiant APIs
5
+
6
+ Graphiant API documentation.
7
+
8
+ The version of the OpenAPI document: 1.0.0
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
10
+
11
+ Do not edit the class manually.
12
+ """ # noqa: E501
13
+
14
+
15
+ from __future__ import annotations
16
+ import pprint
17
+ import re # noqa: F401
18
+ import json
19
+
20
+ from pydantic import BaseModel, ConfigDict, Field, StrictFloat, StrictInt
21
+ from typing import Any, ClassVar, Dict, List, Optional, Union
22
+ from graphiant_sdk.models.v1_extranet_b2b_monitoring_peering_service_consumption_overview_post200_response_first_level_inner import V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner
23
+ from typing import Optional, Set
24
+ from typing_extensions import Self
25
+
26
+ class V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200Response(BaseModel):
27
+ """
28
+ V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200Response
29
+ """ # noqa: E501
30
+ first_level: Optional[List[V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner]] = Field(default=None, alias="firstLevel")
31
+ second_level: Optional[List[V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner]] = Field(default=None, alias="secondLevel")
32
+ third_level: Optional[List[V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner]] = Field(default=None, alias="thirdLevel")
33
+ total_usage: Optional[Union[StrictFloat, StrictInt]] = Field(default=None, alias="totalUsage")
34
+ __properties: ClassVar[List[str]] = ["firstLevel", "secondLevel", "thirdLevel", "totalUsage"]
35
+
36
+ model_config = ConfigDict(
37
+ populate_by_name=True,
38
+ validate_assignment=True,
39
+ protected_namespaces=(),
40
+ )
41
+
42
+
43
+ def to_str(self) -> str:
44
+ """Returns the string representation of the model using alias"""
45
+ return pprint.pformat(self.model_dump(by_alias=True))
46
+
47
+ def to_json(self) -> str:
48
+ """Returns the JSON representation of the model using alias"""
49
+ # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
50
+ return json.dumps(self.to_dict())
51
+
52
+ @classmethod
53
+ def from_json(cls, json_str: str) -> Optional[Self]:
54
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200Response from a JSON string"""
55
+ return cls.from_dict(json.loads(json_str))
56
+
57
+ def to_dict(self) -> Dict[str, Any]:
58
+ """Return the dictionary representation of the model using alias.
59
+
60
+ This has the following differences from calling pydantic's
61
+ `self.model_dump(by_alias=True)`:
62
+
63
+ * `None` is only added to the output dict for nullable fields that
64
+ were set at model initialization. Other fields with value `None`
65
+ are ignored.
66
+ """
67
+ excluded_fields: Set[str] = set([
68
+ ])
69
+
70
+ _dict = self.model_dump(
71
+ by_alias=True,
72
+ exclude=excluded_fields,
73
+ exclude_none=True,
74
+ )
75
+ # override the default output from pydantic by calling `to_dict()` of each item in first_level (list)
76
+ _items = []
77
+ if self.first_level:
78
+ for _item_first_level in self.first_level:
79
+ if _item_first_level:
80
+ _items.append(_item_first_level.to_dict())
81
+ _dict['firstLevel'] = _items
82
+ # override the default output from pydantic by calling `to_dict()` of each item in second_level (list)
83
+ _items = []
84
+ if self.second_level:
85
+ for _item_second_level in self.second_level:
86
+ if _item_second_level:
87
+ _items.append(_item_second_level.to_dict())
88
+ _dict['secondLevel'] = _items
89
+ # override the default output from pydantic by calling `to_dict()` of each item in third_level (list)
90
+ _items = []
91
+ if self.third_level:
92
+ for _item_third_level in self.third_level:
93
+ if _item_third_level:
94
+ _items.append(_item_third_level.to_dict())
95
+ _dict['thirdLevel'] = _items
96
+ return _dict
97
+
98
+ @classmethod
99
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
100
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200Response from a dict"""
101
+ if obj is None:
102
+ return None
103
+
104
+ if not isinstance(obj, dict):
105
+ return cls.model_validate(obj)
106
+
107
+ _obj = cls.model_validate({
108
+ "firstLevel": [V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner.from_dict(_item) for _item in obj["firstLevel"]] if obj.get("firstLevel") is not None else None,
109
+ "secondLevel": [V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner.from_dict(_item) for _item in obj["secondLevel"]] if obj.get("secondLevel") is not None else None,
110
+ "thirdLevel": [V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner.from_dict(_item) for _item in obj["thirdLevel"]] if obj.get("thirdLevel") is not None else None,
111
+ "totalUsage": obj.get("totalUsage")
112
+ })
113
+ return _obj
114
+
115
+
@@ -23,9 +23,9 @@ from typing_extensions import Annotated
23
23
  from typing import Optional, Set
24
24
  from typing_extensions import Self
25
25
 
26
- class V2ExtranetSitesConsumptionOverviewPost200ResponseLanSegmentsInner(BaseModel):
26
+ class V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner(BaseModel):
27
27
  """
28
- V2ExtranetSitesConsumptionOverviewPost200ResponseLanSegmentsInner
28
+ V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner
29
29
  """ # noqa: E501
30
30
  connections: Optional[Dict[str, Annotated[int, Field(strict=True, ge=0)]]] = None
31
31
  connections_v2: Optional[Dict[str, Union[StrictFloat, StrictInt]]] = Field(default=None, alias="connectionsV2")
@@ -50,7 +50,7 @@ class V2ExtranetSitesConsumptionOverviewPost200ResponseLanSegmentsInner(BaseMode
50
50
 
51
51
  @classmethod
52
52
  def from_json(cls, json_str: str) -> Optional[Self]:
53
- """Create an instance of V2ExtranetSitesConsumptionOverviewPost200ResponseLanSegmentsInner from a JSON string"""
53
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner from a JSON string"""
54
54
  return cls.from_dict(json.loads(json_str))
55
55
 
56
56
  def to_dict(self) -> Dict[str, Any]:
@@ -75,7 +75,7 @@ class V2ExtranetSitesConsumptionOverviewPost200ResponseLanSegmentsInner(BaseMode
75
75
 
76
76
  @classmethod
77
77
  def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
78
- """Create an instance of V2ExtranetSitesConsumptionOverviewPost200ResponseLanSegmentsInner from a dict"""
78
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPost200ResponseFirstLevelInner from a dict"""
79
79
  if obj is None:
80
80
  return None
81
81
 
@@ -0,0 +1,105 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ Graphiant APIs
5
+
6
+ Graphiant API documentation.
7
+
8
+ The version of the OpenAPI document: 1.0.0
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
10
+
11
+ Do not edit the class manually.
12
+ """ # noqa: E501
13
+
14
+
15
+ from __future__ import annotations
16
+ import pprint
17
+ import re # noqa: F401
18
+ import json
19
+
20
+ from pydantic import BaseModel, ConfigDict, Field, StrictBool, StrictInt, StrictStr
21
+ from typing import Any, ClassVar, Dict, List, Optional
22
+ from graphiant_sdk.models.v2_notificationlist_post_request_time_window import V2NotificationlistPostRequestTimeWindow
23
+ from typing import Optional, Set
24
+ from typing_extensions import Self
25
+
26
+ class V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPostRequest(BaseModel):
27
+ """
28
+ V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPostRequest
29
+ """ # noqa: E501
30
+ customer_name: Optional[StrictStr] = Field(default=None, alias="customerName")
31
+ flipped_view: Optional[StrictBool] = Field(default=None, alias="flippedView")
32
+ id: Optional[StrictInt] = None
33
+ is_b2_b: Optional[StrictBool] = Field(default=None, alias="isB2B")
34
+ is_provider: Optional[StrictBool] = Field(default=None, alias="isProvider")
35
+ site_id: Optional[StrictInt] = Field(default=None, alias="siteId")
36
+ time_window: Optional[V2NotificationlistPostRequestTimeWindow] = Field(default=None, alias="timeWindow")
37
+ vrf_id: Optional[StrictInt] = Field(default=None, alias="vrfId")
38
+ __properties: ClassVar[List[str]] = ["customerName", "flippedView", "id", "isB2B", "isProvider", "siteId", "timeWindow", "vrfId"]
39
+
40
+ model_config = ConfigDict(
41
+ populate_by_name=True,
42
+ validate_assignment=True,
43
+ protected_namespaces=(),
44
+ )
45
+
46
+
47
+ def to_str(self) -> str:
48
+ """Returns the string representation of the model using alias"""
49
+ return pprint.pformat(self.model_dump(by_alias=True))
50
+
51
+ def to_json(self) -> str:
52
+ """Returns the JSON representation of the model using alias"""
53
+ # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
54
+ return json.dumps(self.to_dict())
55
+
56
+ @classmethod
57
+ def from_json(cls, json_str: str) -> Optional[Self]:
58
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPostRequest from a JSON string"""
59
+ return cls.from_dict(json.loads(json_str))
60
+
61
+ def to_dict(self) -> Dict[str, Any]:
62
+ """Return the dictionary representation of the model using alias.
63
+
64
+ This has the following differences from calling pydantic's
65
+ `self.model_dump(by_alias=True)`:
66
+
67
+ * `None` is only added to the output dict for nullable fields that
68
+ were set at model initialization. Other fields with value `None`
69
+ are ignored.
70
+ """
71
+ excluded_fields: Set[str] = set([
72
+ ])
73
+
74
+ _dict = self.model_dump(
75
+ by_alias=True,
76
+ exclude=excluded_fields,
77
+ exclude_none=True,
78
+ )
79
+ # override the default output from pydantic by calling `to_dict()` of time_window
80
+ if self.time_window:
81
+ _dict['timeWindow'] = self.time_window.to_dict()
82
+ return _dict
83
+
84
+ @classmethod
85
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
86
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceConsumptionOverviewPostRequest from a dict"""
87
+ if obj is None:
88
+ return None
89
+
90
+ if not isinstance(obj, dict):
91
+ return cls.model_validate(obj)
92
+
93
+ _obj = cls.model_validate({
94
+ "customerName": obj.get("customerName"),
95
+ "flippedView": obj.get("flippedView"),
96
+ "id": obj.get("id"),
97
+ "isB2B": obj.get("isB2B"),
98
+ "isProvider": obj.get("isProvider"),
99
+ "siteId": obj.get("siteId"),
100
+ "timeWindow": V2NotificationlistPostRequestTimeWindow.from_dict(obj["timeWindow"]) if obj.get("timeWindow") is not None else None,
101
+ "vrfId": obj.get("vrfId")
102
+ })
103
+ return _obj
104
+
105
+
@@ -0,0 +1,87 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ Graphiant APIs
5
+
6
+ Graphiant API documentation.
7
+
8
+ The version of the OpenAPI document: 1.0.0
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
10
+
11
+ Do not edit the class manually.
12
+ """ # noqa: E501
13
+
14
+
15
+ from __future__ import annotations
16
+ import pprint
17
+ import re # noqa: F401
18
+ import json
19
+
20
+ from pydantic import BaseModel, ConfigDict, Field, StrictStr
21
+ from typing import Any, ClassVar, Dict, List, Optional
22
+ from typing import Optional, Set
23
+ from typing_extensions import Self
24
+
25
+ class V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPost200Response(BaseModel):
26
+ """
27
+ V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPost200Response
28
+ """ # noqa: E501
29
+ customer_name: Optional[List[StrictStr]] = Field(default=None, alias="customerName")
30
+ __properties: ClassVar[List[str]] = ["customerName"]
31
+
32
+ model_config = ConfigDict(
33
+ populate_by_name=True,
34
+ validate_assignment=True,
35
+ protected_namespaces=(),
36
+ )
37
+
38
+
39
+ def to_str(self) -> str:
40
+ """Returns the string representation of the model using alias"""
41
+ return pprint.pformat(self.model_dump(by_alias=True))
42
+
43
+ def to_json(self) -> str:
44
+ """Returns the JSON representation of the model using alias"""
45
+ # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
46
+ return json.dumps(self.to_dict())
47
+
48
+ @classmethod
49
+ def from_json(cls, json_str: str) -> Optional[Self]:
50
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPost200Response from a JSON string"""
51
+ return cls.from_dict(json.loads(json_str))
52
+
53
+ def to_dict(self) -> Dict[str, Any]:
54
+ """Return the dictionary representation of the model using alias.
55
+
56
+ This has the following differences from calling pydantic's
57
+ `self.model_dump(by_alias=True)`:
58
+
59
+ * `None` is only added to the output dict for nullable fields that
60
+ were set at model initialization. Other fields with value `None`
61
+ are ignored.
62
+ """
63
+ excluded_fields: Set[str] = set([
64
+ ])
65
+
66
+ _dict = self.model_dump(
67
+ by_alias=True,
68
+ exclude=excluded_fields,
69
+ exclude_none=True,
70
+ )
71
+ return _dict
72
+
73
+ @classmethod
74
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
75
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPost200Response from a dict"""
76
+ if obj is None:
77
+ return None
78
+
79
+ if not isinstance(obj, dict):
80
+ return cls.model_validate(obj)
81
+
82
+ _obj = cls.model_validate({
83
+ "customerName": obj.get("customerName")
84
+ })
85
+ return _obj
86
+
87
+
@@ -23,14 +23,14 @@ from graphiant_sdk.models.v2_notificationlist_post_request_time_window import V2
23
23
  from typing import Optional, Set
24
24
  from typing_extensions import Self
25
25
 
26
- class V2ExtranetConsumersUsageTopPostRequest(BaseModel):
26
+ class V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPostRequest(BaseModel):
27
27
  """
28
- V2ExtranetConsumersUsageTopPostRequest
28
+ V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPostRequest
29
29
  """ # noqa: E501
30
30
  id: Optional[StrictInt] = None
31
- is_b2_b: Optional[StrictBool] = Field(default=None, alias="isB2B")
31
+ is_provider: Optional[StrictBool] = Field(default=None, alias="isProvider")
32
32
  time_window: Optional[V2NotificationlistPostRequestTimeWindow] = Field(default=None, alias="timeWindow")
33
- __properties: ClassVar[List[str]] = ["id", "isB2B", "timeWindow"]
33
+ __properties: ClassVar[List[str]] = ["id", "isProvider", "timeWindow"]
34
34
 
35
35
  model_config = ConfigDict(
36
36
  populate_by_name=True,
@@ -50,7 +50,7 @@ class V2ExtranetConsumersUsageTopPostRequest(BaseModel):
50
50
 
51
51
  @classmethod
52
52
  def from_json(cls, json_str: str) -> Optional[Self]:
53
- """Create an instance of V2ExtranetConsumersUsageTopPostRequest from a JSON string"""
53
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPostRequest from a JSON string"""
54
54
  return cls.from_dict(json.loads(json_str))
55
55
 
56
56
  def to_dict(self) -> Dict[str, Any]:
@@ -78,7 +78,7 @@ class V2ExtranetConsumersUsageTopPostRequest(BaseModel):
78
78
 
79
79
  @classmethod
80
80
  def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
81
- """Create an instance of V2ExtranetConsumersUsageTopPostRequest from a dict"""
81
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceCustomerListPostRequest from a dict"""
82
82
  if obj is None:
83
83
  return None
84
84
 
@@ -87,7 +87,7 @@ class V2ExtranetConsumersUsageTopPostRequest(BaseModel):
87
87
 
88
88
  _obj = cls.model_validate({
89
89
  "id": obj.get("id"),
90
- "isB2B": obj.get("isB2B"),
90
+ "isProvider": obj.get("isProvider"),
91
91
  "timeWindow": V2NotificationlistPostRequestTimeWindow.from_dict(obj["timeWindow"]) if obj.get("timeWindow") is not None else None
92
92
  })
93
93
  return _obj
@@ -0,0 +1,95 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ Graphiant APIs
5
+
6
+ Graphiant API documentation.
7
+
8
+ The version of the OpenAPI document: 1.0.0
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
10
+
11
+ Do not edit the class manually.
12
+ """ # noqa: E501
13
+
14
+
15
+ from __future__ import annotations
16
+ import pprint
17
+ import re # noqa: F401
18
+ import json
19
+
20
+ from pydantic import BaseModel, ConfigDict, Field
21
+ from typing import Any, ClassVar, Dict, List, Optional
22
+ from graphiant_sdk.models.v1_extranet_b2b_monitoring_peering_service_service_health_post200_response_service_health_inner import V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInner
23
+ from typing import Optional, Set
24
+ from typing_extensions import Self
25
+
26
+ class V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200Response(BaseModel):
27
+ """
28
+ V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200Response
29
+ """ # noqa: E501
30
+ service_health: Optional[List[V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInner]] = Field(default=None, alias="serviceHealth")
31
+ __properties: ClassVar[List[str]] = ["serviceHealth"]
32
+
33
+ model_config = ConfigDict(
34
+ populate_by_name=True,
35
+ validate_assignment=True,
36
+ protected_namespaces=(),
37
+ )
38
+
39
+
40
+ def to_str(self) -> str:
41
+ """Returns the string representation of the model using alias"""
42
+ return pprint.pformat(self.model_dump(by_alias=True))
43
+
44
+ def to_json(self) -> str:
45
+ """Returns the JSON representation of the model using alias"""
46
+ # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
47
+ return json.dumps(self.to_dict())
48
+
49
+ @classmethod
50
+ def from_json(cls, json_str: str) -> Optional[Self]:
51
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200Response from a JSON string"""
52
+ return cls.from_dict(json.loads(json_str))
53
+
54
+ def to_dict(self) -> Dict[str, Any]:
55
+ """Return the dictionary representation of the model using alias.
56
+
57
+ This has the following differences from calling pydantic's
58
+ `self.model_dump(by_alias=True)`:
59
+
60
+ * `None` is only added to the output dict for nullable fields that
61
+ were set at model initialization. Other fields with value `None`
62
+ are ignored.
63
+ """
64
+ excluded_fields: Set[str] = set([
65
+ ])
66
+
67
+ _dict = self.model_dump(
68
+ by_alias=True,
69
+ exclude=excluded_fields,
70
+ exclude_none=True,
71
+ )
72
+ # override the default output from pydantic by calling `to_dict()` of each item in service_health (list)
73
+ _items = []
74
+ if self.service_health:
75
+ for _item_service_health in self.service_health:
76
+ if _item_service_health:
77
+ _items.append(_item_service_health.to_dict())
78
+ _dict['serviceHealth'] = _items
79
+ return _dict
80
+
81
+ @classmethod
82
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
83
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200Response from a dict"""
84
+ if obj is None:
85
+ return None
86
+
87
+ if not isinstance(obj, dict):
88
+ return cls.model_validate(obj)
89
+
90
+ _obj = cls.model_validate({
91
+ "serviceHealth": [V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInner.from_dict(_item) for _item in obj["serviceHealth"]] if obj.get("serviceHealth") is not None else None
92
+ })
93
+ return _obj
94
+
95
+
@@ -0,0 +1,100 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ Graphiant APIs
5
+
6
+ Graphiant API documentation.
7
+
8
+ The version of the OpenAPI document: 1.0.0
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
10
+
11
+ Do not edit the class manually.
12
+ """ # noqa: E501
13
+
14
+
15
+ from __future__ import annotations
16
+ import pprint
17
+ import re # noqa: F401
18
+ import json
19
+
20
+ from pydantic import BaseModel, ConfigDict, Field, StrictStr
21
+ from typing import Any, ClassVar, Dict, List, Optional
22
+ from graphiant_sdk.models.v1_extranet_b2b_monitoring_peering_service_service_health_post200_response_service_health_inner_customer_prefix_health import V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth
23
+ from typing import Optional, Set
24
+ from typing_extensions import Self
25
+
26
+ class V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInner(BaseModel):
27
+ """
28
+ V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInner
29
+ """ # noqa: E501
30
+ customer_name: Optional[StrictStr] = Field(default=None, alias="customerName")
31
+ customer_prefix_health: Optional[V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth] = Field(default=None, alias="customerPrefixHealth")
32
+ overall_health: Optional[StrictStr] = Field(default=None, alias="overallHealth")
33
+ producer_prefix_health: Optional[V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth] = Field(default=None, alias="producerPrefixHealth")
34
+ __properties: ClassVar[List[str]] = ["customerName", "customerPrefixHealth", "overallHealth", "producerPrefixHealth"]
35
+
36
+ model_config = ConfigDict(
37
+ populate_by_name=True,
38
+ validate_assignment=True,
39
+ protected_namespaces=(),
40
+ )
41
+
42
+
43
+ def to_str(self) -> str:
44
+ """Returns the string representation of the model using alias"""
45
+ return pprint.pformat(self.model_dump(by_alias=True))
46
+
47
+ def to_json(self) -> str:
48
+ """Returns the JSON representation of the model using alias"""
49
+ # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
50
+ return json.dumps(self.to_dict())
51
+
52
+ @classmethod
53
+ def from_json(cls, json_str: str) -> Optional[Self]:
54
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInner from a JSON string"""
55
+ return cls.from_dict(json.loads(json_str))
56
+
57
+ def to_dict(self) -> Dict[str, Any]:
58
+ """Return the dictionary representation of the model using alias.
59
+
60
+ This has the following differences from calling pydantic's
61
+ `self.model_dump(by_alias=True)`:
62
+
63
+ * `None` is only added to the output dict for nullable fields that
64
+ were set at model initialization. Other fields with value `None`
65
+ are ignored.
66
+ """
67
+ excluded_fields: Set[str] = set([
68
+ ])
69
+
70
+ _dict = self.model_dump(
71
+ by_alias=True,
72
+ exclude=excluded_fields,
73
+ exclude_none=True,
74
+ )
75
+ # override the default output from pydantic by calling `to_dict()` of customer_prefix_health
76
+ if self.customer_prefix_health:
77
+ _dict['customerPrefixHealth'] = self.customer_prefix_health.to_dict()
78
+ # override the default output from pydantic by calling `to_dict()` of producer_prefix_health
79
+ if self.producer_prefix_health:
80
+ _dict['producerPrefixHealth'] = self.producer_prefix_health.to_dict()
81
+ return _dict
82
+
83
+ @classmethod
84
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
85
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInner from a dict"""
86
+ if obj is None:
87
+ return None
88
+
89
+ if not isinstance(obj, dict):
90
+ return cls.model_validate(obj)
91
+
92
+ _obj = cls.model_validate({
93
+ "customerName": obj.get("customerName"),
94
+ "customerPrefixHealth": V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth.from_dict(obj["customerPrefixHealth"]) if obj.get("customerPrefixHealth") is not None else None,
95
+ "overallHealth": obj.get("overallHealth"),
96
+ "producerPrefixHealth": V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth.from_dict(obj["producerPrefixHealth"]) if obj.get("producerPrefixHealth") is not None else None
97
+ })
98
+ return _obj
99
+
100
+
@@ -0,0 +1,89 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ Graphiant APIs
5
+
6
+ Graphiant API documentation.
7
+
8
+ The version of the OpenAPI document: 1.0.0
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
10
+
11
+ Do not edit the class manually.
12
+ """ # noqa: E501
13
+
14
+
15
+ from __future__ import annotations
16
+ import pprint
17
+ import re # noqa: F401
18
+ import json
19
+
20
+ from pydantic import BaseModel, ConfigDict, Field, StrictStr
21
+ from typing import Any, ClassVar, Dict, List, Optional
22
+ from typing import Optional, Set
23
+ from typing_extensions import Self
24
+
25
+ class V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth(BaseModel):
26
+ """
27
+ V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth
28
+ """ # noqa: E501
29
+ health: Optional[StrictStr] = None
30
+ missing_prefixes: Optional[List[StrictStr]] = Field(default=None, alias="missingPrefixes")
31
+ __properties: ClassVar[List[str]] = ["health", "missingPrefixes"]
32
+
33
+ model_config = ConfigDict(
34
+ populate_by_name=True,
35
+ validate_assignment=True,
36
+ protected_namespaces=(),
37
+ )
38
+
39
+
40
+ def to_str(self) -> str:
41
+ """Returns the string representation of the model using alias"""
42
+ return pprint.pformat(self.model_dump(by_alias=True))
43
+
44
+ def to_json(self) -> str:
45
+ """Returns the JSON representation of the model using alias"""
46
+ # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
47
+ return json.dumps(self.to_dict())
48
+
49
+ @classmethod
50
+ def from_json(cls, json_str: str) -> Optional[Self]:
51
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth from a JSON string"""
52
+ return cls.from_dict(json.loads(json_str))
53
+
54
+ def to_dict(self) -> Dict[str, Any]:
55
+ """Return the dictionary representation of the model using alias.
56
+
57
+ This has the following differences from calling pydantic's
58
+ `self.model_dump(by_alias=True)`:
59
+
60
+ * `None` is only added to the output dict for nullable fields that
61
+ were set at model initialization. Other fields with value `None`
62
+ are ignored.
63
+ """
64
+ excluded_fields: Set[str] = set([
65
+ ])
66
+
67
+ _dict = self.model_dump(
68
+ by_alias=True,
69
+ exclude=excluded_fields,
70
+ exclude_none=True,
71
+ )
72
+ return _dict
73
+
74
+ @classmethod
75
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
76
+ """Create an instance of V1ExtranetB2bMonitoringPeeringServiceServiceHealthPost200ResponseServiceHealthInnerCustomerPrefixHealth from a dict"""
77
+ if obj is None:
78
+ return None
79
+
80
+ if not isinstance(obj, dict):
81
+ return cls.model_validate(obj)
82
+
83
+ _obj = cls.model_validate({
84
+ "health": obj.get("health"),
85
+ "missingPrefixes": obj.get("missingPrefixes")
86
+ })
87
+ return _obj
88
+
89
+