beamlit 0.1.0__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (211) hide show
  1. beamlit/__init__.py +8 -0
  2. beamlit/api/__init__.py +1 -0
  3. beamlit/api/agents/__init__.py +0 -0
  4. beamlit/api/agents/create_agent.py +155 -0
  5. beamlit/api/agents/create_agent_release.py +146 -0
  6. beamlit/api/agents/delete_agent.py +146 -0
  7. beamlit/api/agents/delete_agent_deployment.py +163 -0
  8. beamlit/api/agents/delete_agent_deployment_history.py +172 -0
  9. beamlit/api/agents/get_agent.py +146 -0
  10. beamlit/api/agents/get_agent_deployment.py +163 -0
  11. beamlit/api/agents/get_agent_deployment_history.py +172 -0
  12. beamlit/api/agents/get_agent_deployment_logs.py +164 -0
  13. beamlit/api/agents/get_agent_deployment_metrics.py +159 -0
  14. beamlit/api/agents/get_agent_metrics.py +150 -0
  15. beamlit/api/agents/list_agent_deployment_history.py +164 -0
  16. beamlit/api/agents/list_agent_deployments.py +155 -0
  17. beamlit/api/agents/list_agents.py +127 -0
  18. beamlit/api/agents/put_agent_deployment.py +185 -0
  19. beamlit/api/agents/put_agent_deployment_history.py +198 -0
  20. beamlit/api/agents/update_agent.py +168 -0
  21. beamlit/api/authentication_providers/__init__.py +0 -0
  22. beamlit/api/authentication_providers/get_model_with_repo_for_authentication_provider.py +184 -0
  23. beamlit/api/authentication_providers/list_models_for_authentication_provider.py +163 -0
  24. beamlit/api/authentication_providers/list_organizations_for_authentication_provider.py +163 -0
  25. beamlit/api/configurations/__init__.py +0 -0
  26. beamlit/api/configurations/get_configuration.py +122 -0
  27. beamlit/api/environments/__init__.py +0 -0
  28. beamlit/api/environments/create_environment.py +167 -0
  29. beamlit/api/environments/delete_environment.py +154 -0
  30. beamlit/api/environments/get_environment.py +154 -0
  31. beamlit/api/environments/get_environment_metrics.py +158 -0
  32. beamlit/api/environments/list_environments.py +139 -0
  33. beamlit/api/environments/update_environment.py +180 -0
  34. beamlit/api/functions/__init__.py +0 -0
  35. beamlit/api/functions/create_function.py +155 -0
  36. beamlit/api/functions/create_function_release.py +150 -0
  37. beamlit/api/functions/delete_function.py +146 -0
  38. beamlit/api/functions/delete_function_deployment.py +163 -0
  39. beamlit/api/functions/get_function.py +146 -0
  40. beamlit/api/functions/get_function_deployment.py +163 -0
  41. beamlit/api/functions/get_function_deployment_logs.py +164 -0
  42. beamlit/api/functions/get_function_deployment_metrics.py +159 -0
  43. beamlit/api/functions/get_function_metrics.py +150 -0
  44. beamlit/api/functions/list_function_deployments.py +155 -0
  45. beamlit/api/functions/list_functions.py +131 -0
  46. beamlit/api/functions/put_function_deployment.py +185 -0
  47. beamlit/api/functions/update_function.py +168 -0
  48. beamlit/api/history/__init__.py +0 -0
  49. beamlit/api/history/get_agents_history.py +155 -0
  50. beamlit/api/history/list_agents_history.py +131 -0
  51. beamlit/api/invitations/__init__.py +0 -0
  52. beamlit/api/invitations/list_all_pending_invitations.py +142 -0
  53. beamlit/api/locations/__init__.py +0 -0
  54. beamlit/api/locations/list_locations.py +139 -0
  55. beamlit/api/metrics/__init__.py +0 -0
  56. beamlit/api/metrics/get_metrics.py +130 -0
  57. beamlit/api/model_providers/__init__.py +0 -0
  58. beamlit/api/model_providers/create_model_provider.py +163 -0
  59. beamlit/api/model_providers/delete_model_provider.py +154 -0
  60. beamlit/api/model_providers/get_model_provider.py +154 -0
  61. beamlit/api/model_providers/list_model_providers.py +139 -0
  62. beamlit/api/model_providers/update_model_provider.py +176 -0
  63. beamlit/api/models/__init__.py +0 -0
  64. beamlit/api/models/create_model.py +168 -0
  65. beamlit/api/models/delete_model.py +154 -0
  66. beamlit/api/models/delete_model_deployment.py +171 -0
  67. beamlit/api/models/get_model.py +154 -0
  68. beamlit/api/models/get_model_deployment.py +171 -0
  69. beamlit/api/models/get_model_deployment_logs.py +168 -0
  70. beamlit/api/models/get_model_deployment_metrics.py +163 -0
  71. beamlit/api/models/get_model_metrics.py +154 -0
  72. beamlit/api/models/list_model_deployments.py +163 -0
  73. beamlit/api/models/list_models.py +135 -0
  74. beamlit/api/models/put_model_deployment.py +193 -0
  75. beamlit/api/models/release_model.py +154 -0
  76. beamlit/api/models/update_model.py +181 -0
  77. beamlit/api/policies/__init__.py +0 -0
  78. beamlit/api/policies/create_policy.py +167 -0
  79. beamlit/api/policies/delete_policy.py +154 -0
  80. beamlit/api/policies/get_policy.py +154 -0
  81. beamlit/api/policies/list_policies.py +139 -0
  82. beamlit/api/policies/update_policy.py +180 -0
  83. beamlit/api/service_accounts/__init__.py +0 -0
  84. beamlit/api/service_accounts/create_api_key_for_service_account.py +177 -0
  85. beamlit/api/service_accounts/create_workspace_service_account.py +168 -0
  86. beamlit/api/service_accounts/delete_api_key_for_service_account.py +104 -0
  87. beamlit/api/service_accounts/delete_workspace_service_account.py +158 -0
  88. beamlit/api/service_accounts/get_workspace_service_accounts.py +139 -0
  89. beamlit/api/service_accounts/list_api_keys_for_service_account.py +163 -0
  90. beamlit/api/service_accounts/update_workspace_service_account.py +181 -0
  91. beamlit/api/store/__init__.py +0 -0
  92. beamlit/api/store/get_store_agent.py +146 -0
  93. beamlit/api/store/get_store_function.py +146 -0
  94. beamlit/api/store/list_store_agents.py +131 -0
  95. beamlit/api/store/list_store_functions.py +131 -0
  96. beamlit/api/workspaces/__init__.py +0 -0
  97. beamlit/api/workspaces/accept_workspace_invitation.py +161 -0
  98. beamlit/api/workspaces/create_worspace.py +163 -0
  99. beamlit/api/workspaces/decline_workspace_invitation.py +158 -0
  100. beamlit/api/workspaces/delete_workspace.py +154 -0
  101. beamlit/api/workspaces/get_workspace.py +154 -0
  102. beamlit/api/workspaces/invite_workspace_user.py +174 -0
  103. beamlit/api/workspaces/leave_workspace.py +161 -0
  104. beamlit/api/workspaces/list_workspace_users.py +139 -0
  105. beamlit/api/workspaces/list_workspaces.py +139 -0
  106. beamlit/api/workspaces/remove_workspace_user.py +101 -0
  107. beamlit/api/workspaces/update_workspace.py +176 -0
  108. beamlit/api/workspaces/update_workspace_user_role.py +187 -0
  109. beamlit/authentication/__init__.py +24 -0
  110. beamlit/authentication/apikey.py +14 -0
  111. beamlit/authentication/authentication.py +35 -0
  112. beamlit/authentication/credentials.py +165 -0
  113. beamlit/authentication/device_mode.py +115 -0
  114. beamlit/client.py +270 -0
  115. beamlit/errors.py +16 -0
  116. beamlit/models/__init__.py +189 -0
  117. beamlit/models/acl.py +149 -0
  118. beamlit/models/agent.py +151 -0
  119. beamlit/models/agent_chain.py +77 -0
  120. beamlit/models/agent_configuration.py +68 -0
  121. beamlit/models/agent_deployment.py +327 -0
  122. beamlit/models/agent_deployment_configuration.py +43 -0
  123. beamlit/models/agent_deployment_history.py +183 -0
  124. beamlit/models/agent_deployment_history_event.py +131 -0
  125. beamlit/models/agent_deployment_pod_template.py +43 -0
  126. beamlit/models/agent_release.py +68 -0
  127. beamlit/models/api_key.py +140 -0
  128. beamlit/models/authentication_provider_model.py +142 -0
  129. beamlit/models/authentication_provider_organization.py +86 -0
  130. beamlit/models/configuration.py +72 -0
  131. beamlit/models/continent.py +68 -0
  132. beamlit/models/country.py +68 -0
  133. beamlit/models/create_api_key_for_service_account_body.py +67 -0
  134. beamlit/models/create_workspace_service_account_body.py +69 -0
  135. beamlit/models/create_workspace_service_account_response_200.py +103 -0
  136. beamlit/models/delete_workspace_service_account_response_200.py +94 -0
  137. beamlit/models/deployment_configuration.py +68 -0
  138. beamlit/models/deployment_configurations.py +43 -0
  139. beamlit/models/deployment_serverless_config.py +129 -0
  140. beamlit/models/environment.py +162 -0
  141. beamlit/models/environment_metrics.py +75 -0
  142. beamlit/models/flavor.py +68 -0
  143. beamlit/models/function.py +151 -0
  144. beamlit/models/function_configuration.py +68 -0
  145. beamlit/models/function_deployment.py +327 -0
  146. beamlit/models/function_deployment_configuration.py +43 -0
  147. beamlit/models/function_deployment_pod_template.py +43 -0
  148. beamlit/models/function_kit.py +95 -0
  149. beamlit/models/function_provider_ref.py +68 -0
  150. beamlit/models/function_release.py +68 -0
  151. beamlit/models/get_workspace_service_accounts_response_200_item.py +94 -0
  152. beamlit/models/invite_workspace_user_body.py +58 -0
  153. beamlit/models/labels.py +43 -0
  154. beamlit/models/labels_type_0.py +43 -0
  155. beamlit/models/location.py +120 -0
  156. beamlit/models/location_response.py +111 -0
  157. beamlit/models/metric.py +68 -0
  158. beamlit/models/metrics.py +111 -0
  159. beamlit/models/model.py +151 -0
  160. beamlit/models/model_deployment.py +283 -0
  161. beamlit/models/model_deployment_log.py +68 -0
  162. beamlit/models/model_deployment_metrics.py +170 -0
  163. beamlit/models/model_deployment_metrics_inference_per_second_per_region.py +75 -0
  164. beamlit/models/model_deployment_metrics_query_per_second_per_region_per_code.py +73 -0
  165. beamlit/models/model_deployment_pod_template.py +43 -0
  166. beamlit/models/model_metrics.py +94 -0
  167. beamlit/models/model_provider.py +187 -0
  168. beamlit/models/model_provider_ref.py +68 -0
  169. beamlit/models/model_release.py +68 -0
  170. beamlit/models/model_with_deployments.py +174 -0
  171. beamlit/models/pending_invitation.py +122 -0
  172. beamlit/models/pending_invitation_accept.py +81 -0
  173. beamlit/models/pending_invitation_render.py +135 -0
  174. beamlit/models/pending_invitation_render_invited_by.py +86 -0
  175. beamlit/models/pending_invitation_render_workspace.py +68 -0
  176. beamlit/models/pending_invitation_workspace_details.py +70 -0
  177. beamlit/models/policy.py +216 -0
  178. beamlit/models/policy_location.py +68 -0
  179. beamlit/models/provider_config.py +101 -0
  180. beamlit/models/qps.py +59 -0
  181. beamlit/models/resource_deployment_log.py +68 -0
  182. beamlit/models/resource_deployment_metrics.py +172 -0
  183. beamlit/models/resource_deployment_metrics_inference_per_second_per_region.py +75 -0
  184. beamlit/models/resource_deployment_metrics_query_per_second_per_region_per_code.py +73 -0
  185. beamlit/models/resource_metrics.py +94 -0
  186. beamlit/models/runtime.py +152 -0
  187. beamlit/models/runtime_readiness_probe.py +43 -0
  188. beamlit/models/runtime_resources.py +43 -0
  189. beamlit/models/serverless_config.py +122 -0
  190. beamlit/models/standard_fields_dynamo_db.py +86 -0
  191. beamlit/models/store_agent.py +165 -0
  192. beamlit/models/store_agent_configuration.py +95 -0
  193. beamlit/models/store_agent_labels.py +43 -0
  194. beamlit/models/store_configuration.py +149 -0
  195. beamlit/models/store_configuration_option.py +77 -0
  196. beamlit/models/store_function.py +207 -0
  197. beamlit/models/store_function_configuration.py +95 -0
  198. beamlit/models/store_function_kit.py +95 -0
  199. beamlit/models/store_function_labels.py +43 -0
  200. beamlit/models/store_function_parameter.py +86 -0
  201. beamlit/models/update_workspace_service_account_body.py +67 -0
  202. beamlit/models/update_workspace_service_account_response_200.py +94 -0
  203. beamlit/models/update_workspace_user_role_body.py +58 -0
  204. beamlit/models/workspace.py +126 -0
  205. beamlit/models/workspace_labels.py +43 -0
  206. beamlit/models/workspace_user.py +113 -0
  207. beamlit/py.typed +1 -0
  208. beamlit/types.py +46 -0
  209. beamlit-0.1.0.dist-info/METADATA +59 -0
  210. beamlit-0.1.0.dist-info/RECORD +211 -0
  211. beamlit-0.1.0.dist-info/WHEEL +4 -0
@@ -0,0 +1,94 @@
1
+ from typing import Any, Type, TypeVar, Union
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ from ..types import UNSET, Unset
7
+
8
+ T = TypeVar("T", bound="GetWorkspaceServiceAccountsResponse200Item")
9
+
10
+
11
+ @_attrs_define
12
+ class GetWorkspaceServiceAccountsResponse200Item:
13
+ """
14
+ Attributes:
15
+ client_id (Union[Unset, str]): Service account client ID
16
+ created_at (Union[Unset, str]): Creation timestamp
17
+ description (Union[Unset, str]): Service account description
18
+ name (Union[Unset, str]): Service account name
19
+ updated_at (Union[Unset, str]): Last update timestamp
20
+ """
21
+
22
+ client_id: Union[Unset, str] = UNSET
23
+ created_at: Union[Unset, str] = UNSET
24
+ description: Union[Unset, str] = UNSET
25
+ name: Union[Unset, str] = UNSET
26
+ updated_at: Union[Unset, str] = UNSET
27
+ additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
28
+
29
+ def to_dict(self) -> dict[str, Any]:
30
+ client_id = self.client_id
31
+
32
+ created_at = self.created_at
33
+
34
+ description = self.description
35
+
36
+ name = self.name
37
+
38
+ updated_at = self.updated_at
39
+
40
+ field_dict: dict[str, Any] = {}
41
+ field_dict.update(self.additional_properties)
42
+ field_dict.update({})
43
+ if client_id is not UNSET:
44
+ field_dict["client_id"] = client_id
45
+ if created_at is not UNSET:
46
+ field_dict["created_at"] = created_at
47
+ if description is not UNSET:
48
+ field_dict["description"] = description
49
+ if name is not UNSET:
50
+ field_dict["name"] = name
51
+ if updated_at is not UNSET:
52
+ field_dict["updated_at"] = updated_at
53
+
54
+ return field_dict
55
+
56
+ @classmethod
57
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
58
+ d = src_dict.copy()
59
+ client_id = d.pop("client_id", UNSET)
60
+
61
+ created_at = d.pop("created_at", UNSET)
62
+
63
+ description = d.pop("description", UNSET)
64
+
65
+ name = d.pop("name", UNSET)
66
+
67
+ updated_at = d.pop("updated_at", UNSET)
68
+
69
+ get_workspace_service_accounts_response_200_item = cls(
70
+ client_id=client_id,
71
+ created_at=created_at,
72
+ description=description,
73
+ name=name,
74
+ updated_at=updated_at,
75
+ )
76
+
77
+ get_workspace_service_accounts_response_200_item.additional_properties = d
78
+ return get_workspace_service_accounts_response_200_item
79
+
80
+ @property
81
+ def additional_keys(self) -> list[str]:
82
+ return list(self.additional_properties.keys())
83
+
84
+ def __getitem__(self, key: str) -> Any:
85
+ return self.additional_properties[key]
86
+
87
+ def __setitem__(self, key: str, value: Any) -> None:
88
+ self.additional_properties[key] = value
89
+
90
+ def __delitem__(self, key: str) -> None:
91
+ del self.additional_properties[key]
92
+
93
+ def __contains__(self, key: str) -> bool:
94
+ return key in self.additional_properties
@@ -0,0 +1,58 @@
1
+ from typing import Any, Type, TypeVar, Union
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ from ..types import UNSET, Unset
7
+
8
+ T = TypeVar("T", bound="InviteWorkspaceUserBody")
9
+
10
+
11
+ @_attrs_define
12
+ class InviteWorkspaceUserBody:
13
+ """
14
+ Attributes:
15
+ email (Union[Unset, str]):
16
+ """
17
+
18
+ email: Union[Unset, str] = UNSET
19
+ additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
20
+
21
+ def to_dict(self) -> dict[str, Any]:
22
+ email = self.email
23
+
24
+ field_dict: dict[str, Any] = {}
25
+ field_dict.update(self.additional_properties)
26
+ field_dict.update({})
27
+ if email is not UNSET:
28
+ field_dict["email"] = email
29
+
30
+ return field_dict
31
+
32
+ @classmethod
33
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
34
+ d = src_dict.copy()
35
+ email = d.pop("email", UNSET)
36
+
37
+ invite_workspace_user_body = cls(
38
+ email=email,
39
+ )
40
+
41
+ invite_workspace_user_body.additional_properties = d
42
+ return invite_workspace_user_body
43
+
44
+ @property
45
+ def additional_keys(self) -> list[str]:
46
+ return list(self.additional_properties.keys())
47
+
48
+ def __getitem__(self, key: str) -> Any:
49
+ return self.additional_properties[key]
50
+
51
+ def __setitem__(self, key: str, value: Any) -> None:
52
+ self.additional_properties[key] = value
53
+
54
+ def __delitem__(self, key: str) -> None:
55
+ del self.additional_properties[key]
56
+
57
+ def __contains__(self, key: str) -> bool:
58
+ return key in self.additional_properties
@@ -0,0 +1,43 @@
1
+ from typing import Any, Type, TypeVar
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ T = TypeVar("T", bound="Labels")
7
+
8
+
9
+ @_attrs_define
10
+ class Labels:
11
+ """Labels"""
12
+
13
+ additional_properties: dict[str, str] = _attrs_field(init=False, factory=dict)
14
+
15
+ def to_dict(self) -> dict[str, Any]:
16
+ field_dict: dict[str, Any] = {}
17
+ field_dict.update(self.additional_properties)
18
+
19
+ return field_dict
20
+
21
+ @classmethod
22
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
23
+ d = src_dict.copy()
24
+ labels = cls()
25
+
26
+ labels.additional_properties = d
27
+ return labels
28
+
29
+ @property
30
+ def additional_keys(self) -> list[str]:
31
+ return list(self.additional_properties.keys())
32
+
33
+ def __getitem__(self, key: str) -> str:
34
+ return self.additional_properties[key]
35
+
36
+ def __setitem__(self, key: str, value: str) -> None:
37
+ self.additional_properties[key] = value
38
+
39
+ def __delitem__(self, key: str) -> None:
40
+ del self.additional_properties[key]
41
+
42
+ def __contains__(self, key: str) -> bool:
43
+ return key in self.additional_properties
@@ -0,0 +1,43 @@
1
+ from typing import Any, Type, TypeVar
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ T = TypeVar("T", bound="LabelsType0")
7
+
8
+
9
+ @_attrs_define
10
+ class LabelsType0:
11
+ """Labels"""
12
+
13
+ additional_properties: dict[str, str] = _attrs_field(init=False, factory=dict)
14
+
15
+ def to_dict(self) -> dict[str, Any]:
16
+ field_dict: dict[str, Any] = {}
17
+ field_dict.update(self.additional_properties)
18
+
19
+ return field_dict
20
+
21
+ @classmethod
22
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
23
+ d = src_dict.copy()
24
+ labels_type_0 = cls()
25
+
26
+ labels_type_0.additional_properties = d
27
+ return labels_type_0
28
+
29
+ @property
30
+ def additional_keys(self) -> list[str]:
31
+ return list(self.additional_properties.keys())
32
+
33
+ def __getitem__(self, key: str) -> str:
34
+ return self.additional_properties[key]
35
+
36
+ def __setitem__(self, key: str, value: str) -> None:
37
+ self.additional_properties[key] = value
38
+
39
+ def __delitem__(self, key: str) -> None:
40
+ del self.additional_properties[key]
41
+
42
+ def __contains__(self, key: str) -> bool:
43
+ return key in self.additional_properties
@@ -0,0 +1,120 @@
1
+ from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ from ..types import UNSET, Unset
7
+
8
+ if TYPE_CHECKING:
9
+ from ..models.flavor import Flavor
10
+
11
+
12
+ T = TypeVar("T", bound="Location")
13
+
14
+
15
+ @_attrs_define
16
+ class Location:
17
+ """Location availability for policies
18
+
19
+ Attributes:
20
+ continent (Union[Unset, str]): Location continent
21
+ country (Union[Unset, str]): Location country
22
+ flavors (Union[Unset, List['Flavor']]): Location flavors
23
+ location (Union[Unset, str]): Location name
24
+ name (Union[Unset, str]): Location name
25
+ status (Union[Unset, str]): Location status
26
+ """
27
+
28
+ continent: Union[Unset, str] = UNSET
29
+ country: Union[Unset, str] = UNSET
30
+ flavors: Union[Unset, List["Flavor"]] = UNSET
31
+ location: Union[Unset, str] = UNSET
32
+ name: Union[Unset, str] = UNSET
33
+ status: Union[Unset, str] = UNSET
34
+ additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
35
+
36
+ def to_dict(self) -> dict[str, Any]:
37
+ continent = self.continent
38
+
39
+ country = self.country
40
+
41
+ flavors: Union[Unset, List[Dict[str, Any]]] = UNSET
42
+ if not isinstance(self.flavors, Unset):
43
+ flavors = []
44
+ for flavors_item_data in self.flavors:
45
+ flavors_item = flavors_item_data.to_dict()
46
+ flavors.append(flavors_item)
47
+
48
+ location = self.location
49
+
50
+ name = self.name
51
+
52
+ status = self.status
53
+
54
+ field_dict: dict[str, Any] = {}
55
+ field_dict.update(self.additional_properties)
56
+ field_dict.update({})
57
+ if continent is not UNSET:
58
+ field_dict["continent"] = continent
59
+ if country is not UNSET:
60
+ field_dict["country"] = country
61
+ if flavors is not UNSET:
62
+ field_dict["flavors"] = flavors
63
+ if location is not UNSET:
64
+ field_dict["location"] = location
65
+ if name is not UNSET:
66
+ field_dict["name"] = name
67
+ if status is not UNSET:
68
+ field_dict["status"] = status
69
+
70
+ return field_dict
71
+
72
+ @classmethod
73
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
74
+ from ..models.flavor import Flavor
75
+
76
+ d = src_dict.copy()
77
+ continent = d.pop("continent", UNSET)
78
+
79
+ country = d.pop("country", UNSET)
80
+
81
+ flavors = []
82
+ _flavors = d.pop("flavors", UNSET)
83
+ for flavors_item_data in _flavors or []:
84
+ flavors_item = Flavor.from_dict(flavors_item_data)
85
+
86
+ flavors.append(flavors_item)
87
+
88
+ location = d.pop("location", UNSET)
89
+
90
+ name = d.pop("name", UNSET)
91
+
92
+ status = d.pop("status", UNSET)
93
+
94
+ location = cls(
95
+ continent=continent,
96
+ country=country,
97
+ flavors=flavors,
98
+ location=location,
99
+ name=name,
100
+ status=status,
101
+ )
102
+
103
+ location.additional_properties = d
104
+ return location
105
+
106
+ @property
107
+ def additional_keys(self) -> list[str]:
108
+ return list(self.additional_properties.keys())
109
+
110
+ def __getitem__(self, key: str) -> Any:
111
+ return self.additional_properties[key]
112
+
113
+ def __setitem__(self, key: str, value: Any) -> None:
114
+ self.additional_properties[key] = value
115
+
116
+ def __delitem__(self, key: str) -> None:
117
+ del self.additional_properties[key]
118
+
119
+ def __contains__(self, key: str) -> bool:
120
+ return key in self.additional_properties
@@ -0,0 +1,111 @@
1
+ from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ from ..types import UNSET, Unset
7
+
8
+ if TYPE_CHECKING:
9
+ from ..models.flavor import Flavor
10
+
11
+
12
+ T = TypeVar("T", bound="LocationResponse")
13
+
14
+
15
+ @_attrs_define
16
+ class LocationResponse:
17
+ """Location availability for policies
18
+
19
+ Attributes:
20
+ continent (Union[Unset, str]): Continent of the location
21
+ country (Union[Unset, str]): Country of the location
22
+ flavors (Union[Unset, List['Flavor']]): Hardware flavors available in the location
23
+ location (Union[Unset, str]): Name of the location
24
+ status (Union[Unset, str]): Status of the location
25
+ """
26
+
27
+ continent: Union[Unset, str] = UNSET
28
+ country: Union[Unset, str] = UNSET
29
+ flavors: Union[Unset, List["Flavor"]] = UNSET
30
+ location: Union[Unset, str] = UNSET
31
+ status: Union[Unset, str] = UNSET
32
+ additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
33
+
34
+ def to_dict(self) -> dict[str, Any]:
35
+ continent = self.continent
36
+
37
+ country = self.country
38
+
39
+ flavors: Union[Unset, List[Dict[str, Any]]] = UNSET
40
+ if not isinstance(self.flavors, Unset):
41
+ flavors = []
42
+ for flavors_item_data in self.flavors:
43
+ flavors_item = flavors_item_data.to_dict()
44
+ flavors.append(flavors_item)
45
+
46
+ location = self.location
47
+
48
+ status = self.status
49
+
50
+ field_dict: dict[str, Any] = {}
51
+ field_dict.update(self.additional_properties)
52
+ field_dict.update({})
53
+ if continent is not UNSET:
54
+ field_dict["continent"] = continent
55
+ if country is not UNSET:
56
+ field_dict["country"] = country
57
+ if flavors is not UNSET:
58
+ field_dict["flavors"] = flavors
59
+ if location is not UNSET:
60
+ field_dict["location"] = location
61
+ if status is not UNSET:
62
+ field_dict["status"] = status
63
+
64
+ return field_dict
65
+
66
+ @classmethod
67
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
68
+ from ..models.flavor import Flavor
69
+
70
+ d = src_dict.copy()
71
+ continent = d.pop("continent", UNSET)
72
+
73
+ country = d.pop("country", UNSET)
74
+
75
+ flavors = []
76
+ _flavors = d.pop("flavors", UNSET)
77
+ for flavors_item_data in _flavors or []:
78
+ flavors_item = Flavor.from_dict(flavors_item_data)
79
+
80
+ flavors.append(flavors_item)
81
+
82
+ location = d.pop("location", UNSET)
83
+
84
+ status = d.pop("status", UNSET)
85
+
86
+ location_response = cls(
87
+ continent=continent,
88
+ country=country,
89
+ flavors=flavors,
90
+ location=location,
91
+ status=status,
92
+ )
93
+
94
+ location_response.additional_properties = d
95
+ return location_response
96
+
97
+ @property
98
+ def additional_keys(self) -> list[str]:
99
+ return list(self.additional_properties.keys())
100
+
101
+ def __getitem__(self, key: str) -> Any:
102
+ return self.additional_properties[key]
103
+
104
+ def __setitem__(self, key: str, value: Any) -> None:
105
+ self.additional_properties[key] = value
106
+
107
+ def __delitem__(self, key: str) -> None:
108
+ del self.additional_properties[key]
109
+
110
+ def __contains__(self, key: str) -> bool:
111
+ return key in self.additional_properties
@@ -0,0 +1,68 @@
1
+ from typing import Any, Type, TypeVar, Union
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ from ..types import UNSET, Unset
7
+
8
+ T = TypeVar("T", bound="Metric")
9
+
10
+
11
+ @_attrs_define
12
+ class Metric:
13
+ """Metric
14
+
15
+ Attributes:
16
+ timestamp (Union[Unset, str]): Metric timestamp
17
+ value (Union[Unset, str]): Metric value
18
+ """
19
+
20
+ timestamp: Union[Unset, str] = UNSET
21
+ value: Union[Unset, str] = UNSET
22
+ additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
23
+
24
+ def to_dict(self) -> dict[str, Any]:
25
+ timestamp = self.timestamp
26
+
27
+ value = self.value
28
+
29
+ field_dict: dict[str, Any] = {}
30
+ field_dict.update(self.additional_properties)
31
+ field_dict.update({})
32
+ if timestamp is not UNSET:
33
+ field_dict["timestamp"] = timestamp
34
+ if value is not UNSET:
35
+ field_dict["value"] = value
36
+
37
+ return field_dict
38
+
39
+ @classmethod
40
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
41
+ d = src_dict.copy()
42
+ timestamp = d.pop("timestamp", UNSET)
43
+
44
+ value = d.pop("value", UNSET)
45
+
46
+ metric = cls(
47
+ timestamp=timestamp,
48
+ value=value,
49
+ )
50
+
51
+ metric.additional_properties = d
52
+ return metric
53
+
54
+ @property
55
+ def additional_keys(self) -> list[str]:
56
+ return list(self.additional_properties.keys())
57
+
58
+ def __getitem__(self, key: str) -> Any:
59
+ return self.additional_properties[key]
60
+
61
+ def __setitem__(self, key: str, value: Any) -> None:
62
+ self.additional_properties[key] = value
63
+
64
+ def __delitem__(self, key: str) -> None:
65
+ del self.additional_properties[key]
66
+
67
+ def __contains__(self, key: str) -> bool:
68
+ return key in self.additional_properties
@@ -0,0 +1,111 @@
1
+ from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union
2
+
3
+ from attrs import define as _attrs_define
4
+ from attrs import field as _attrs_field
5
+
6
+ from ..types import UNSET, Unset
7
+
8
+ if TYPE_CHECKING:
9
+ from ..models.metric import Metric
10
+
11
+
12
+ T = TypeVar("T", bound="Metrics")
13
+
14
+
15
+ @_attrs_define
16
+ class Metrics:
17
+ """Metrics for resources
18
+
19
+ Attributes:
20
+ agents (Union[Unset, Any]): Metrics for agents
21
+ functions (Union[Unset, Any]): Metrics for functions
22
+ inference_per_second_global (Union[Unset, List['Metric']]): Array of metrics
23
+ models (Union[Unset, Any]): Metrics for models
24
+ query_per_second (Union[Unset, float]): RPS value (in last 24 hours) per location, for all resources globally
25
+ """
26
+
27
+ agents: Union[Unset, Any] = UNSET
28
+ functions: Union[Unset, Any] = UNSET
29
+ inference_per_second_global: Union[Unset, List["Metric"]] = UNSET
30
+ models: Union[Unset, Any] = UNSET
31
+ query_per_second: Union[Unset, float] = UNSET
32
+ additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
33
+
34
+ def to_dict(self) -> dict[str, Any]:
35
+ agents = self.agents
36
+
37
+ functions = self.functions
38
+
39
+ inference_per_second_global: Union[Unset, List[Dict[str, Any]]] = UNSET
40
+ if not isinstance(self.inference_per_second_global, Unset):
41
+ inference_per_second_global = []
42
+ for componentsschemas_array_metric_item_data in self.inference_per_second_global:
43
+ componentsschemas_array_metric_item = componentsschemas_array_metric_item_data.to_dict()
44
+ inference_per_second_global.append(componentsschemas_array_metric_item)
45
+
46
+ models = self.models
47
+
48
+ query_per_second = self.query_per_second
49
+
50
+ field_dict: dict[str, Any] = {}
51
+ field_dict.update(self.additional_properties)
52
+ field_dict.update({})
53
+ if agents is not UNSET:
54
+ field_dict["agents"] = agents
55
+ if functions is not UNSET:
56
+ field_dict["functions"] = functions
57
+ if inference_per_second_global is not UNSET:
58
+ field_dict["inference_per_second_global"] = inference_per_second_global
59
+ if models is not UNSET:
60
+ field_dict["models"] = models
61
+ if query_per_second is not UNSET:
62
+ field_dict["query_per_second"] = query_per_second
63
+
64
+ return field_dict
65
+
66
+ @classmethod
67
+ def from_dict(cls: Type[T], src_dict: dict[str, Any]) -> T:
68
+ from ..models.metric import Metric
69
+
70
+ d = src_dict.copy()
71
+ agents = d.pop("agents", UNSET)
72
+
73
+ functions = d.pop("functions", UNSET)
74
+
75
+ inference_per_second_global = []
76
+ _inference_per_second_global = d.pop("inference_per_second_global", UNSET)
77
+ for componentsschemas_array_metric_item_data in _inference_per_second_global or []:
78
+ componentsschemas_array_metric_item = Metric.from_dict(componentsschemas_array_metric_item_data)
79
+
80
+ inference_per_second_global.append(componentsschemas_array_metric_item)
81
+
82
+ models = d.pop("models", UNSET)
83
+
84
+ query_per_second = d.pop("query_per_second", UNSET)
85
+
86
+ metrics = cls(
87
+ agents=agents,
88
+ functions=functions,
89
+ inference_per_second_global=inference_per_second_global,
90
+ models=models,
91
+ query_per_second=query_per_second,
92
+ )
93
+
94
+ metrics.additional_properties = d
95
+ return metrics
96
+
97
+ @property
98
+ def additional_keys(self) -> list[str]:
99
+ return list(self.additional_properties.keys())
100
+
101
+ def __getitem__(self, key: str) -> Any:
102
+ return self.additional_properties[key]
103
+
104
+ def __setitem__(self, key: str, value: Any) -> None:
105
+ self.additional_properties[key] = value
106
+
107
+ def __delitem__(self, key: str) -> None:
108
+ del self.additional_properties[key]
109
+
110
+ def __contains__(self, key: str) -> bool:
111
+ return key in self.additional_properties