graphiant-sdk 25.10.1__py3-none-any.whl → 25.10.2__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 (84) hide show
  1. graphiant_sdk/__init__.py +62 -1290
  2. graphiant_sdk/api/__init__.py +1 -16
  3. graphiant_sdk/api/default_api.py +6589 -7804
  4. graphiant_sdk/api_client.py +5 -5
  5. graphiant_sdk/configuration.py +1 -1
  6. graphiant_sdk/models/__init__.py +31 -1246
  7. graphiant_sdk/models/v1_auth_login_temp_post_request.py +6 -4
  8. graphiant_sdk/models/v1_devices_device_id_config_put_request_core_core_vrf_bgp_neighbors_value_neighbor.py +6 -6
  9. graphiant_sdk/models/v1_devices_device_id_config_put_request_core_core_vrf_bgp_redistribution_value.py +3 -3
  10. graphiant_sdk/models/v1_devices_device_id_config_put_request_edge_site_to_site_vpn_value_site_to_site_vpn.py +3 -3
  11. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response.py +166 -0
  12. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_ipsec_tunnel_config_inner.py +150 -0
  13. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details.py +109 -0
  14. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details_customer.py +94 -0
  15. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details_service.py +95 -0
  16. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details_service_prefixes_inner.py +91 -0
  17. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_match_details_get200_response.py +95 -0
  18. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post200_response.py +109 -0
  19. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request.py +140 -0
  20. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_global_object_ops_value.py +87 -0
  21. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_policy_inner.py +89 -0
  22. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn.py +95 -0
  23. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details.py +117 -0
  24. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing.py +97 -0
  25. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp.py +115 -0
  26. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value.py +91 -0
  27. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value_family.py +98 -0
  28. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_md5_password.py +87 -0
  29. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_static.py +87 -0
  30. graphiant_sdk/models/v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_tunnel1.py +93 -0
  31. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_post200_response.py +7 -5
  32. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_post_request.py +93 -0
  33. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_post_request_service.py +112 -0
  34. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_post_request_service_nat_inner.py +89 -0
  35. graphiant_sdk/models/v1_extranets_b2b_peering_match_service_to_customer_post_request_service_service_prefixes_inner.py +89 -0
  36. graphiant_sdk/models/v1_extranets_b2b_peering_producer_id_matching_customers_summary_get200_response.py +95 -0
  37. graphiant_sdk/models/v1_extranets_b2b_peering_producer_id_matching_customers_summary_get200_response_info_inner.py +104 -0
  38. graphiant_sdk/models/v1_extranets_b2b_peering_producer_post_request_policy.py +19 -4
  39. graphiant_sdk/models/v1_extranets_b2b_post_request_policy.py +33 -4
  40. graphiant_sdk/models/v1_extranets_b2b_post_request_policy_global_object_device_summaries_value.py +95 -0
  41. graphiant_sdk/models/v1_extranets_b2b_post_request_policy_global_object_device_summaries_value_routing_policies_inner.py +114 -0
  42. graphiant_sdk/models/v1_extranets_get200_response_policies_inner_branches_excluded_devices_inner_ipsec_tunnels_inner.py +3 -3
  43. graphiant_sdk/models/v1_extranets_get200_response_policies_inner_branches_excluded_devices_inner_region.py +5 -3
  44. graphiant_sdk/models/v1_gateways_guest_consumer_match_id_get200_response.py +103 -0
  45. graphiant_sdk/models/v1_gateways_put_request_details.py +3 -3
  46. graphiant_sdk/models/v1_global_config_patch_request_snmps_value_config_notify_filter_profiles_value_notify_filter_profile.py +3 -3
  47. graphiant_sdk/models/v1_invitation_email_post_request.py +3 -1
  48. graphiant_sdk/models/v1_temp_password_put_request.py +4 -2
  49. graphiant_sdk/models/v2_assistant_conversation_interface_state_get200_response.py +87 -0
  50. {graphiant_sdk-25.10.1.dist-info → graphiant_sdk-25.10.2.dist-info}/METADATA +3 -4
  51. {graphiant_sdk-25.10.1.dist-info → graphiant_sdk-25.10.2.dist-info}/RECORD +84 -24
  52. test/test_v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response.py +224 -0
  53. test/test_v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_ipsec_tunnel_config_inner.py +82 -0
  54. test/test_v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details.py +74 -0
  55. test/test_v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details_customer.py +56 -0
  56. test/test_v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details_service.py +57 -0
  57. test/test_v1_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_match_details_service_prefixes_inner.py +53 -0
  58. test/test_v1_extranets_b2b_peering_consumer_match_id_match_details_get200_response.py +77 -0
  59. test/test_v1_extranets_b2b_peering_consumer_match_id_post200_response.py +74 -0
  60. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request.py +130 -0
  61. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_global_object_ops_value.py +53 -0
  62. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_policy_inner.py +54 -0
  63. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn.py +92 -0
  64. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details.py +87 -0
  65. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing.py +69 -0
  66. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp.py +64 -0
  67. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value.py +56 -0
  68. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_address_families_value_family.py +55 -0
  69. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_bgp_md5_password.py +51 -0
  70. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_static.py +53 -0
  71. test/test_v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_tunnel1.py +54 -0
  72. test/test_v1_extranets_b2b_peering_match_service_to_customer_post_request.py +65 -0
  73. test/test_v1_extranets_b2b_peering_match_service_to_customer_post_request_service.py +63 -0
  74. test/test_v1_extranets_b2b_peering_match_service_to_customer_post_request_service_nat_inner.py +52 -0
  75. test/test_v1_extranets_b2b_peering_match_service_to_customer_post_request_service_service_prefixes_inner.py +52 -0
  76. test/test_v1_extranets_b2b_peering_producer_id_matching_customers_summary_get200_response.py +64 -0
  77. test/test_v1_extranets_b2b_peering_producer_id_matching_customers_summary_get200_response_info_inner.py +61 -0
  78. test/test_v1_extranets_b2b_post_request_policy_global_object_device_summaries_value.py +67 -0
  79. test/test_v1_extranets_b2b_post_request_policy_global_object_device_summaries_value_routing_policies_inner.py +64 -0
  80. test/test_v1_gateways_guest_consumer_match_id_get200_response.py +131 -0
  81. test/test_v2_assistant_conversation_interface_state_get200_response.py +51 -0
  82. {graphiant_sdk-25.10.1.dist-info → graphiant_sdk-25.10.2.dist-info}/WHEEL +0 -0
  83. {graphiant_sdk-25.10.1.dist-info → graphiant_sdk-25.10.2.dist-info}/licenses/LICENSE +0 -0
  84. {graphiant_sdk-25.10.1.dist-info → graphiant_sdk-25.10.2.dist-info}/top_level.txt +0 -0
@@ -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_extranets_b2b_post_request_policy_global_object_device_summaries_value_routing_policies_inner import V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValueRoutingPoliciesInner
23
+ from typing import Optional, Set
24
+ from typing_extensions import Self
25
+
26
+ class V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValue(BaseModel):
27
+ """
28
+ V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValue
29
+ """ # noqa: E501
30
+ routing_policies: Optional[List[V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValueRoutingPoliciesInner]] = Field(default=None, alias="routingPolicies")
31
+ __properties: ClassVar[List[str]] = ["routingPolicies"]
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 V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValue 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 routing_policies (list)
73
+ _items = []
74
+ if self.routing_policies:
75
+ for _item_routing_policies in self.routing_policies:
76
+ if _item_routing_policies:
77
+ _items.append(_item_routing_policies.to_dict())
78
+ _dict['routingPolicies'] = _items
79
+ return _dict
80
+
81
+ @classmethod
82
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
83
+ """Create an instance of V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValue 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
+ "routingPolicies": [V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValueRoutingPoliciesInner.from_dict(_item) for _item in obj["routingPolicies"]] if obj.get("routingPolicies") is not None else None
92
+ })
93
+ return _obj
94
+
95
+
@@ -0,0 +1,114 @@
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, StrictInt, StrictStr
21
+ from typing import Any, ClassVar, Dict, List, Optional
22
+ from typing_extensions import Annotated
23
+ from typing import Optional, Set
24
+ from typing_extensions import Self
25
+
26
+ class V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValueRoutingPoliciesInner(BaseModel):
27
+ """
28
+ V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValueRoutingPoliciesInner
29
+ """ # noqa: E501
30
+ attach_point: Optional[StrictStr] = Field(default=None, alias="attachPoint")
31
+ id: Optional[StrictInt] = None
32
+ ip_version: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="ipVersion")
33
+ name: Optional[StrictStr] = None
34
+ num_attached_devices: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numAttachedDevices")
35
+ num_attached_sites: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numAttachedSites")
36
+ num_failures: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numFailures")
37
+ num_in_sync_devices: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numInSyncDevices")
38
+ num_override_devices: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numOverrideDevices")
39
+ num_policies: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numPolicies")
40
+ num_prefixes: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numPrefixes")
41
+ num_rules: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numRules")
42
+ num_statements: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="numStatements")
43
+ traffic_policy_type: Optional[StrictStr] = Field(default=None, alias="trafficPolicyType")
44
+ __properties: ClassVar[List[str]] = ["attachPoint", "id", "ipVersion", "name", "numAttachedDevices", "numAttachedSites", "numFailures", "numInSyncDevices", "numOverrideDevices", "numPolicies", "numPrefixes", "numRules", "numStatements", "trafficPolicyType"]
45
+
46
+ model_config = ConfigDict(
47
+ populate_by_name=True,
48
+ validate_assignment=True,
49
+ protected_namespaces=(),
50
+ )
51
+
52
+
53
+ def to_str(self) -> str:
54
+ """Returns the string representation of the model using alias"""
55
+ return pprint.pformat(self.model_dump(by_alias=True))
56
+
57
+ def to_json(self) -> str:
58
+ """Returns the JSON representation of the model using alias"""
59
+ # TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
60
+ return json.dumps(self.to_dict())
61
+
62
+ @classmethod
63
+ def from_json(cls, json_str: str) -> Optional[Self]:
64
+ """Create an instance of V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValueRoutingPoliciesInner from a JSON string"""
65
+ return cls.from_dict(json.loads(json_str))
66
+
67
+ def to_dict(self) -> Dict[str, Any]:
68
+ """Return the dictionary representation of the model using alias.
69
+
70
+ This has the following differences from calling pydantic's
71
+ `self.model_dump(by_alias=True)`:
72
+
73
+ * `None` is only added to the output dict for nullable fields that
74
+ were set at model initialization. Other fields with value `None`
75
+ are ignored.
76
+ """
77
+ excluded_fields: Set[str] = set([
78
+ ])
79
+
80
+ _dict = self.model_dump(
81
+ by_alias=True,
82
+ exclude=excluded_fields,
83
+ exclude_none=True,
84
+ )
85
+ return _dict
86
+
87
+ @classmethod
88
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
89
+ """Create an instance of V1ExtranetsB2bPostRequestPolicyGlobalObjectDeviceSummariesValueRoutingPoliciesInner from a dict"""
90
+ if obj is None:
91
+ return None
92
+
93
+ if not isinstance(obj, dict):
94
+ return cls.model_validate(obj)
95
+
96
+ _obj = cls.model_validate({
97
+ "attachPoint": obj.get("attachPoint"),
98
+ "id": obj.get("id"),
99
+ "ipVersion": obj.get("ipVersion"),
100
+ "name": obj.get("name"),
101
+ "numAttachedDevices": obj.get("numAttachedDevices"),
102
+ "numAttachedSites": obj.get("numAttachedSites"),
103
+ "numFailures": obj.get("numFailures"),
104
+ "numInSyncDevices": obj.get("numInSyncDevices"),
105
+ "numOverrideDevices": obj.get("numOverrideDevices"),
106
+ "numPolicies": obj.get("numPolicies"),
107
+ "numPrefixes": obj.get("numPrefixes"),
108
+ "numRules": obj.get("numRules"),
109
+ "numStatements": obj.get("numStatements"),
110
+ "trafficPolicyType": obj.get("trafficPolicyType")
111
+ })
112
+ return _obj
113
+
114
+
@@ -20,7 +20,7 @@ import json
20
20
  from pydantic import BaseModel, ConfigDict, Field, StrictBool, StrictStr
21
21
  from typing import Any, ClassVar, Dict, List, Optional
22
22
  from typing_extensions import Annotated
23
- from graphiant_sdk.models.v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_static import V1ExtranetsB2bPeeringConsumerIdPostRequestSiteToSiteVpnIpsecGatewayDetailsRoutingStatic
23
+ from graphiant_sdk.models.v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details_routing_static import V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpnIpsecGatewayDetailsRoutingStatic
24
24
  from graphiant_sdk.models.v1_extranets_get200_response_policies_inner_branches_excluded_devices_inner_ipsec_tunnels_inner_bgp import V1ExtranetsGet200ResponsePoliciesInnerBranchesExcludedDevicesInnerIpsecTunnelsInnerBgp
25
25
  from typing import Optional, Set
26
26
  from typing_extensions import Self
@@ -44,7 +44,7 @@ class V1ExtranetsGet200ResponsePoliciesInnerBranchesExcludedDevicesInnerIpsecTun
44
44
  remote_address_v4: Optional[StrictStr] = Field(default=None, alias="remoteAddressV4")
45
45
  remote_address_v6: Optional[StrictStr] = Field(default=None, alias="remoteAddressV6")
46
46
  remote_ike_peer_identity: Optional[StrictStr] = Field(default=None, alias="remoteIkePeerIdentity")
47
- static: Optional[V1ExtranetsB2bPeeringConsumerIdPostRequestSiteToSiteVpnIpsecGatewayDetailsRoutingStatic] = None
47
+ static: Optional[V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpnIpsecGatewayDetailsRoutingStatic] = None
48
48
  tcp_mss: Optional[Annotated[int, Field(strict=True, ge=0)]] = Field(default=None, alias="tcpMss")
49
49
  vpn_profile: Optional[StrictStr] = Field(default=None, alias="vpnProfile")
50
50
  __properties: ClassVar[List[str]] = ["bgp", "destinationAddress", "ikeInitiator", "ipsecLabel", "lan", "localAddressV4", "localAddressV6", "localCircuit", "localIkePeerIdentity", "mtu", "name", "presharedKey", "remoteAddressV4", "remoteAddressV6", "remoteIkePeerIdentity", "static", "tcpMss", "vpnProfile"]
@@ -121,7 +121,7 @@ class V1ExtranetsGet200ResponsePoliciesInnerBranchesExcludedDevicesInnerIpsecTun
121
121
  "remoteAddressV4": obj.get("remoteAddressV4"),
122
122
  "remoteAddressV6": obj.get("remoteAddressV6"),
123
123
  "remoteIkePeerIdentity": obj.get("remoteIkePeerIdentity"),
124
- "static": V1ExtranetsB2bPeeringConsumerIdPostRequestSiteToSiteVpnIpsecGatewayDetailsRoutingStatic.from_dict(obj["static"]) if obj.get("static") is not None else None,
124
+ "static": V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpnIpsecGatewayDetailsRoutingStatic.from_dict(obj["static"]) if obj.get("static") is not None else None,
125
125
  "tcpMss": obj.get("tcpMss"),
126
126
  "vpnProfile": obj.get("vpnProfile")
127
127
  })
@@ -17,7 +17,7 @@ import pprint
17
17
  import re # noqa: F401
18
18
  import json
19
19
 
20
- from pydantic import BaseModel, ConfigDict, StrictInt, StrictStr
20
+ from pydantic import BaseModel, ConfigDict, StrictBool, StrictInt, StrictStr
21
21
  from typing import Any, ClassVar, Dict, List, Optional
22
22
  from typing import Optional, Set
23
23
  from typing_extensions import Self
@@ -28,7 +28,8 @@ class V1ExtranetsGet200ResponsePoliciesInnerBranchesExcludedDevicesInnerRegion(B
28
28
  """ # noqa: E501
29
29
  id: Optional[StrictInt] = None
30
30
  name: Optional[StrictStr] = None
31
- __properties: ClassVar[List[str]] = ["id", "name"]
31
+ unavailable: Optional[StrictBool] = None
32
+ __properties: ClassVar[List[str]] = ["id", "name", "unavailable"]
32
33
 
33
34
  model_config = ConfigDict(
34
35
  populate_by_name=True,
@@ -82,7 +83,8 @@ class V1ExtranetsGet200ResponsePoliciesInnerBranchesExcludedDevicesInnerRegion(B
82
83
 
83
84
  _obj = cls.model_validate({
84
85
  "id": obj.get("id"),
85
- "name": obj.get("name")
86
+ "name": obj.get("name"),
87
+ "unavailable": obj.get("unavailable")
86
88
  })
87
89
  return _obj
88
90
 
@@ -0,0 +1,103 @@
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_extranets_b2b_peering_consumer_customer_id_consumer_details_get200_response_ipsec_tunnel_config_inner import V1ExtranetsB2bPeeringConsumerCustomerIdConsumerDetailsGet200ResponseIpsecTunnelConfigInner
23
+ from graphiant_sdk.models.v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn import V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpn
24
+ from typing import Optional, Set
25
+ from typing_extensions import Self
26
+
27
+ class V1GatewaysGuestConsumerMatchIdGet200Response(BaseModel):
28
+ """
29
+ V1GatewaysGuestConsumerMatchIdGet200Response
30
+ """ # noqa: E501
31
+ destination_prefixes: Optional[List[StrictStr]] = Field(default=None, alias="destinationPrefixes")
32
+ ipsec_tunnel_config: Optional[List[V1ExtranetsB2bPeeringConsumerCustomerIdConsumerDetailsGet200ResponseIpsecTunnelConfigInner]] = Field(default=None, alias="ipsecTunnelConfig")
33
+ site_to_site_vpn: Optional[V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpn] = Field(default=None, alias="siteToSiteVpn")
34
+ __properties: ClassVar[List[str]] = ["destinationPrefixes", "ipsecTunnelConfig", "siteToSiteVpn"]
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 V1GatewaysGuestConsumerMatchIdGet200Response 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 ipsec_tunnel_config (list)
76
+ _items = []
77
+ if self.ipsec_tunnel_config:
78
+ for _item_ipsec_tunnel_config in self.ipsec_tunnel_config:
79
+ if _item_ipsec_tunnel_config:
80
+ _items.append(_item_ipsec_tunnel_config.to_dict())
81
+ _dict['ipsecTunnelConfig'] = _items
82
+ # override the default output from pydantic by calling `to_dict()` of site_to_site_vpn
83
+ if self.site_to_site_vpn:
84
+ _dict['siteToSiteVpn'] = self.site_to_site_vpn.to_dict()
85
+ return _dict
86
+
87
+ @classmethod
88
+ def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
89
+ """Create an instance of V1GatewaysGuestConsumerMatchIdGet200Response from a dict"""
90
+ if obj is None:
91
+ return None
92
+
93
+ if not isinstance(obj, dict):
94
+ return cls.model_validate(obj)
95
+
96
+ _obj = cls.model_validate({
97
+ "destinationPrefixes": obj.get("destinationPrefixes"),
98
+ "ipsecTunnelConfig": [V1ExtranetsB2bPeeringConsumerCustomerIdConsumerDetailsGet200ResponseIpsecTunnelConfigInner.from_dict(_item) for _item in obj["ipsecTunnelConfig"]] if obj.get("ipsecTunnelConfig") is not None else None,
99
+ "siteToSiteVpn": V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpn.from_dict(obj["siteToSiteVpn"]) if obj.get("siteToSiteVpn") is not None else None
100
+ })
101
+ return _obj
102
+
103
+
@@ -19,7 +19,7 @@ import json
19
19
 
20
20
  from pydantic import BaseModel, ConfigDict, Field, StrictInt, StrictStr
21
21
  from typing import Any, ClassVar, Dict, List, Optional
22
- from graphiant_sdk.models.v1_extranets_b2b_peering_consumer_id_post_request_site_to_site_vpn_ipsec_gateway_details import V1ExtranetsB2bPeeringConsumerIdPostRequestSiteToSiteVpnIpsecGatewayDetails
22
+ from graphiant_sdk.models.v1_extranets_b2b_peering_consumer_match_id_post_request_site_to_site_vpn_ipsec_gateway_details import V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpnIpsecGatewayDetails
23
23
  from graphiant_sdk.models.v1_gateways_put_request_details_aws import V1GatewaysPutRequestDetailsAws
24
24
  from graphiant_sdk.models.v1_gateways_put_request_details_azure import V1GatewaysPutRequestDetailsAzure
25
25
  from graphiant_sdk.models.v1_gateways_put_request_details_gcp import V1GatewaysPutRequestDetailsGcp
@@ -35,7 +35,7 @@ class V1GatewaysPutRequestDetails(BaseModel):
35
35
  azure: Optional[V1GatewaysPutRequestDetailsAzure] = None
36
36
  description: Optional[StrictStr] = None
37
37
  gcp: Optional[V1GatewaysPutRequestDetailsGcp] = None
38
- ipsec_gateway: Optional[V1ExtranetsB2bPeeringConsumerIdPostRequestSiteToSiteVpnIpsecGatewayDetails] = Field(default=None, alias="ipsecGateway")
38
+ ipsec_gateway: Optional[V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpnIpsecGatewayDetails] = Field(default=None, alias="ipsecGateway")
39
39
  oci: Optional[V1GatewaysPutRequestDetailsOci] = None
40
40
  region_id: Optional[StrictInt] = Field(default=None, alias="regionId")
41
41
  speed: Optional[StrictStr] = None
@@ -112,7 +112,7 @@ class V1GatewaysPutRequestDetails(BaseModel):
112
112
  "azure": V1GatewaysPutRequestDetailsAzure.from_dict(obj["azure"]) if obj.get("azure") is not None else None,
113
113
  "description": obj.get("description"),
114
114
  "gcp": V1GatewaysPutRequestDetailsGcp.from_dict(obj["gcp"]) if obj.get("gcp") is not None else None,
115
- "ipsecGateway": V1ExtranetsB2bPeeringConsumerIdPostRequestSiteToSiteVpnIpsecGatewayDetails.from_dict(obj["ipsecGateway"]) if obj.get("ipsecGateway") is not None else None,
115
+ "ipsecGateway": V1ExtranetsB2bPeeringConsumerMatchIdPostRequestSiteToSiteVpnIpsecGatewayDetails.from_dict(obj["ipsecGateway"]) if obj.get("ipsecGateway") is not None else None,
116
116
  "oci": V1GatewaysPutRequestDetailsOci.from_dict(obj["oci"]) if obj.get("oci") is not None else None,
117
117
  "regionId": obj.get("regionId"),
118
118
  "speed": obj.get("speed"),
@@ -19,7 +19,7 @@ import json
19
19
 
20
20
  from pydantic import BaseModel, ConfigDict, Field, StrictStr
21
21
  from typing import Any, ClassVar, Dict, List, Optional
22
- from graphiant_sdk.models.v1_global_config_patch_request_snmps_value_config_notify_filter_profiles_value_notify_filter_profile_include_exclude_list_value import V1GlobalConfigPatchRequestSnmpsValueConfigNotifyFilterProfilesValueNotifyFilterProfileIncludeExcludeListValue
22
+ from graphiant_sdk.models.v2_assistant_conversation_interface_state_get200_response import V2AssistantConversationInterfaceStateGet200Response
23
23
  from typing import Optional, Set
24
24
  from typing_extensions import Self
25
25
 
@@ -27,7 +27,7 @@ class V1GlobalConfigPatchRequestSnmpsValueConfigNotifyFilterProfilesValueNotifyF
27
27
  """
28
28
  V1GlobalConfigPatchRequestSnmpsValueConfigNotifyFilterProfilesValueNotifyFilterProfile
29
29
  """ # noqa: E501
30
- include_exclude_list: Optional[Dict[str, V1GlobalConfigPatchRequestSnmpsValueConfigNotifyFilterProfilesValueNotifyFilterProfileIncludeExcludeListValue]] = Field(default=None, alias="includeExcludeList")
30
+ include_exclude_list: Optional[Dict[str, V2AssistantConversationInterfaceStateGet200Response]] = Field(default=None, alias="includeExcludeList")
31
31
  name: Optional[StrictStr] = None
32
32
  __properties: ClassVar[List[str]] = ["includeExcludeList", "name"]
33
33
 
@@ -90,7 +90,7 @@ class V1GlobalConfigPatchRequestSnmpsValueConfigNotifyFilterProfilesValueNotifyF
90
90
 
91
91
  _obj = cls.model_validate({
92
92
  "includeExcludeList": dict(
93
- (_k, V1GlobalConfigPatchRequestSnmpsValueConfigNotifyFilterProfilesValueNotifyFilterProfileIncludeExcludeListValue.from_dict(_v))
93
+ (_k, V2AssistantConversationInterfaceStateGet200Response.from_dict(_v))
94
94
  for _k, _v in obj["includeExcludeList"].items()
95
95
  )
96
96
  if obj.get("includeExcludeList") is not None
@@ -26,12 +26,13 @@ class V1InvitationEmailPostRequest(BaseModel):
26
26
  """
27
27
  V1InvitationEmailPostRequest
28
28
  """ # noqa: E501
29
+ admin_email: Optional[StrictStr] = Field(default=None, alias="adminEmail")
29
30
  customer_id: Optional[StrictInt] = Field(default=None, alias="customerId")
30
31
  customer_name: Optional[StrictStr] = Field(default=None, alias="customerName")
31
32
  is_graphiant: Optional[StrictBool] = Field(default=None, alias="isGraphiant")
32
33
  service_id: Optional[StrictInt] = Field(default=None, alias="serviceId")
33
34
  service_name: Optional[StrictStr] = Field(default=None, alias="serviceName")
34
- __properties: ClassVar[List[str]] = ["customerId", "customerName", "isGraphiant", "serviceId", "serviceName"]
35
+ __properties: ClassVar[List[str]] = ["adminEmail", "customerId", "customerName", "isGraphiant", "serviceId", "serviceName"]
35
36
 
36
37
  model_config = ConfigDict(
37
38
  populate_by_name=True,
@@ -84,6 +85,7 @@ class V1InvitationEmailPostRequest(BaseModel):
84
85
  return cls.model_validate(obj)
85
86
 
86
87
  _obj = cls.model_validate({
88
+ "adminEmail": obj.get("adminEmail"),
87
89
  "customerId": obj.get("customerId"),
88
90
  "customerName": obj.get("customerName"),
89
91
  "isGraphiant": obj.get("isGraphiant"),
@@ -17,7 +17,7 @@ import pprint
17
17
  import re # noqa: F401
18
18
  import json
19
19
 
20
- from pydantic import BaseModel, ConfigDict, Field, StrictStr
20
+ from pydantic import BaseModel, ConfigDict, Field, StrictInt, StrictStr
21
21
  from typing import Any, ClassVar, Dict, List, Optional
22
22
  from typing import Optional, Set
23
23
  from typing_extensions import Self
@@ -28,8 +28,9 @@ class V1TempPasswordPutRequest(BaseModel):
28
28
  """ # noqa: E501
29
29
  customer_name: Optional[StrictStr] = Field(default=None, alias="customerName")
30
30
  emails: Optional[List[StrictStr]] = None
31
+ match_id: Optional[StrictInt] = Field(default=None, alias="matchId")
31
32
  service_name: Optional[StrictStr] = Field(default=None, alias="serviceName")
32
- __properties: ClassVar[List[str]] = ["customerName", "emails", "serviceName"]
33
+ __properties: ClassVar[List[str]] = ["customerName", "emails", "matchId", "serviceName"]
33
34
 
34
35
  model_config = ConfigDict(
35
36
  populate_by_name=True,
@@ -84,6 +85,7 @@ class V1TempPasswordPutRequest(BaseModel):
84
85
  _obj = cls.model_validate({
85
86
  "customerName": obj.get("customerName"),
86
87
  "emails": obj.get("emails"),
88
+ "matchId": obj.get("matchId"),
87
89
  "serviceName": obj.get("serviceName")
88
90
  })
89
91
  return _obj
@@ -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, StrictBool
21
+ from typing import Any, ClassVar, Dict, List, Optional
22
+ from typing import Optional, Set
23
+ from typing_extensions import Self
24
+
25
+ class V2AssistantConversationInterfaceStateGet200Response(BaseModel):
26
+ """
27
+ V2AssistantConversationInterfaceStateGet200Response
28
+ """ # noqa: E501
29
+ enabled: Optional[StrictBool] = None
30
+ __properties: ClassVar[List[str]] = ["enabled"]
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 V2AssistantConversationInterfaceStateGet200Response 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 V2AssistantConversationInterfaceStateGet200Response 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
+ "enabled": obj.get("enabled")
84
+ })
85
+ return _obj
86
+
87
+
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: graphiant_sdk
3
- Version: 25.10.1
3
+ Version: 25.10.2
4
4
  Summary: Graphiant APIs
5
5
  Home-page: https://www.graphiant.com
6
6
  Author: Graphiant Inc
@@ -14,7 +14,6 @@ Requires-Dist: urllib3<3.0.0,>=2.1.0
14
14
  Requires-Dist: python-dateutil>=2.8.2
15
15
  Requires-Dist: pydantic>=2
16
16
  Requires-Dist: typing-extensions>=4.7.1
17
- Requires-Dist: lazy-imports<2,>=1
18
17
  Dynamic: author
19
18
  Dynamic: home-page
20
19
  Dynamic: license-file
@@ -278,12 +277,12 @@ brew install openapi-generator # macOS
278
277
 
279
278
  # Generate SDK
280
279
  openapi-generator generate \
281
- -i graphiant_api_docs_v25.10.1.json \
280
+ -i graphiant_api_docs_v25.10.2.json \
282
281
  -g python \
283
282
  --git-user-id Graphiant-Inc \
284
283
  --git-repo-id graphiant-sdk-python \
285
284
  --package-name graphiant_sdk \
286
- --additional-properties=packageVersion=25.10.1
285
+ --additional-properties=packageVersion=25.10.2
287
286
  ```
288
287
 
289
288
  > **Note**: Latest API documentation can be downloaded from the Graphiant portal under "Support Hub" > "Developer Tools".