blaxel 0.64.0__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.
- blaxel/__init__.py +8 -0
- blaxel/agents/__init__.py +5 -0
- blaxel/agents/chain.py +153 -0
- blaxel/agents/chat.py +286 -0
- blaxel/agents/decorator.py +208 -0
- blaxel/agents/thread.py +24 -0
- blaxel/agents/voice/openai.py +255 -0
- blaxel/agents/voice/utils.py +25 -0
- blaxel/api/__init__.py +1 -0
- blaxel/api/agents/__init__.py +0 -0
- blaxel/api/agents/create_agent.py +155 -0
- blaxel/api/agents/delete_agent.py +146 -0
- blaxel/api/agents/get_agent.py +146 -0
- blaxel/api/agents/get_agent_logs.py +151 -0
- blaxel/api/agents/get_agent_metrics.py +150 -0
- blaxel/api/agents/get_agent_trace_ids.py +201 -0
- blaxel/api/agents/list_agent_revisions.py +155 -0
- blaxel/api/agents/list_agents.py +127 -0
- blaxel/api/agents/update_agent.py +168 -0
- blaxel/api/configurations/__init__.py +0 -0
- blaxel/api/configurations/get_configuration.py +122 -0
- blaxel/api/default/__init__.py +0 -0
- blaxel/api/default/get_trace.py +150 -0
- blaxel/api/default/get_trace_ids.py +218 -0
- blaxel/api/default/get_trace_logs.py +186 -0
- blaxel/api/default/list_mcp_hub_definitions.py +127 -0
- blaxel/api/functions/__init__.py +0 -0
- blaxel/api/functions/create_function.py +155 -0
- blaxel/api/functions/delete_function.py +146 -0
- blaxel/api/functions/get_function.py +146 -0
- blaxel/api/functions/get_function_logs.py +151 -0
- blaxel/api/functions/get_function_metrics.py +150 -0
- blaxel/api/functions/get_function_trace_ids.py +201 -0
- blaxel/api/functions/list_function_revisions.py +158 -0
- blaxel/api/functions/list_functions.py +131 -0
- blaxel/api/functions/update_function.py +168 -0
- blaxel/api/integrations/__init__.py +0 -0
- blaxel/api/integrations/create_integration_connection.py +167 -0
- blaxel/api/integrations/delete_integration_connection.py +158 -0
- blaxel/api/integrations/get_integration.py +97 -0
- blaxel/api/integrations/get_integration_connection.py +158 -0
- blaxel/api/integrations/get_integration_connection_model.py +104 -0
- blaxel/api/integrations/get_integration_connection_model_endpoint_configurations.py +97 -0
- blaxel/api/integrations/list_integration_connection_models.py +97 -0
- blaxel/api/integrations/list_integration_connections.py +139 -0
- blaxel/api/integrations/update_integration_connection.py +180 -0
- blaxel/api/invitations/__init__.py +0 -0
- blaxel/api/invitations/list_all_pending_invitations.py +142 -0
- blaxel/api/knowledgebases/__init__.py +0 -0
- blaxel/api/knowledgebases/create_knowledgebase.py +163 -0
- blaxel/api/knowledgebases/delete_knowledgebase.py +154 -0
- blaxel/api/knowledgebases/get_knowledgebase.py +154 -0
- blaxel/api/knowledgebases/list_knowledgebase_revisions.py +158 -0
- blaxel/api/knowledgebases/list_knowledgebases.py +139 -0
- blaxel/api/knowledgebases/update_knowledgebase.py +176 -0
- blaxel/api/locations/__init__.py +0 -0
- blaxel/api/locations/list_locations.py +139 -0
- blaxel/api/metrics/__init__.py +0 -0
- blaxel/api/metrics/get_metrics.py +130 -0
- blaxel/api/models/__init__.py +0 -0
- blaxel/api/models/create_model.py +163 -0
- blaxel/api/models/delete_model.py +154 -0
- blaxel/api/models/get_model.py +154 -0
- blaxel/api/models/get_model_logs.py +155 -0
- blaxel/api/models/get_model_metrics.py +158 -0
- blaxel/api/models/get_model_trace_ids.py +201 -0
- blaxel/api/models/list_model_revisions.py +158 -0
- blaxel/api/models/list_models.py +135 -0
- blaxel/api/models/update_model.py +176 -0
- blaxel/api/policies/__init__.py +0 -0
- blaxel/api/policies/create_policy.py +167 -0
- blaxel/api/policies/delete_policy.py +154 -0
- blaxel/api/policies/get_policy.py +154 -0
- blaxel/api/policies/list_policies.py +139 -0
- blaxel/api/policies/update_policy.py +180 -0
- blaxel/api/privateclusters/__init__.py +0 -0
- blaxel/api/privateclusters/create_private_cluster.py +132 -0
- blaxel/api/privateclusters/delete_private_cluster.py +156 -0
- blaxel/api/privateclusters/get_private_cluster.py +159 -0
- blaxel/api/privateclusters/get_private_cluster_health.py +97 -0
- blaxel/api/privateclusters/list_private_clusters.py +140 -0
- blaxel/api/privateclusters/update_private_cluster.py +156 -0
- blaxel/api/privateclusters/update_private_cluster_health.py +97 -0
- blaxel/api/service_accounts/__init__.py +0 -0
- blaxel/api/service_accounts/create_api_key_for_service_account.py +177 -0
- blaxel/api/service_accounts/create_workspace_service_account.py +170 -0
- blaxel/api/service_accounts/delete_api_key_for_service_account.py +104 -0
- blaxel/api/service_accounts/delete_workspace_service_account.py +160 -0
- blaxel/api/service_accounts/get_workspace_service_accounts.py +141 -0
- blaxel/api/service_accounts/list_api_keys_for_service_account.py +163 -0
- blaxel/api/service_accounts/update_workspace_service_account.py +183 -0
- blaxel/api/store/__init__.py +0 -0
- blaxel/api/store/get_store_agent.py +146 -0
- blaxel/api/store/get_store_function.py +146 -0
- blaxel/api/store/list_store_agents.py +131 -0
- blaxel/api/store/list_store_functions.py +131 -0
- blaxel/api/workspaces/__init__.py +0 -0
- blaxel/api/workspaces/accept_workspace_invitation.py +161 -0
- blaxel/api/workspaces/create_worspace.py +163 -0
- blaxel/api/workspaces/decline_workspace_invitation.py +158 -0
- blaxel/api/workspaces/delete_workspace.py +154 -0
- blaxel/api/workspaces/get_workspace.py +154 -0
- blaxel/api/workspaces/invite_workspace_user.py +174 -0
- blaxel/api/workspaces/leave_workspace.py +161 -0
- blaxel/api/workspaces/list_workspace_users.py +139 -0
- blaxel/api/workspaces/list_workspaces.py +139 -0
- blaxel/api/workspaces/remove_workspace_user.py +101 -0
- blaxel/api/workspaces/update_workspace.py +176 -0
- blaxel/api/workspaces/update_workspace_user_role.py +187 -0
- blaxel/authentication/__init__.py +45 -0
- blaxel/authentication/apikey.py +50 -0
- blaxel/authentication/authentication.py +176 -0
- blaxel/authentication/clientcredentials.py +103 -0
- blaxel/authentication/credentials.py +295 -0
- blaxel/authentication/device_mode.py +197 -0
- blaxel/client.py +281 -0
- blaxel/common/__init__.py +17 -0
- blaxel/common/error.py +27 -0
- blaxel/common/instrumentation.py +317 -0
- blaxel/common/logger.py +60 -0
- blaxel/common/secrets.py +39 -0
- blaxel/common/settings.py +150 -0
- blaxel/common/slugify.py +18 -0
- blaxel/common/utils.py +34 -0
- blaxel/deploy/__init__.py +8 -0
- blaxel/deploy/deploy.py +316 -0
- blaxel/deploy/format.py +46 -0
- blaxel/deploy/parser.py +192 -0
- blaxel/errors.py +16 -0
- blaxel/functions/__init__.py +7 -0
- blaxel/functions/common.py +228 -0
- blaxel/functions/decorator.py +64 -0
- blaxel/functions/local/local.py +48 -0
- blaxel/functions/mcp/client.py +96 -0
- blaxel/functions/mcp/mcp.py +168 -0
- blaxel/functions/mcp/utils.py +56 -0
- blaxel/functions/remote/remote.py +183 -0
- blaxel/models/__init__.py +233 -0
- blaxel/models/acl.py +133 -0
- blaxel/models/agent.py +126 -0
- blaxel/models/agent_chain.py +88 -0
- blaxel/models/agent_spec.py +346 -0
- blaxel/models/api_key.py +142 -0
- blaxel/models/configuration.py +85 -0
- blaxel/models/continent.py +70 -0
- blaxel/models/core_event.py +97 -0
- blaxel/models/core_spec.py +249 -0
- blaxel/models/core_spec_configurations.py +77 -0
- blaxel/models/country.py +70 -0
- blaxel/models/create_api_key_for_service_account_body.py +69 -0
- blaxel/models/create_workspace_service_account_body.py +71 -0
- blaxel/models/create_workspace_service_account_response_200.py +105 -0
- blaxel/models/delete_workspace_service_account_response_200.py +96 -0
- blaxel/models/entrypoint.py +96 -0
- blaxel/models/entrypoint_env.py +45 -0
- blaxel/models/flavor.py +70 -0
- blaxel/models/form.py +120 -0
- blaxel/models/form_config.py +45 -0
- blaxel/models/form_oauthomitempty.py +45 -0
- blaxel/models/form_secrets.py +45 -0
- blaxel/models/function.py +126 -0
- blaxel/models/function_kit.py +97 -0
- blaxel/models/function_spec.py +310 -0
- blaxel/models/get_trace_ids_response_200.py +45 -0
- blaxel/models/get_trace_logs_response_200.py +45 -0
- blaxel/models/get_trace_response_200.py +45 -0
- blaxel/models/get_workspace_service_accounts_response_200_item.py +96 -0
- blaxel/models/histogram_bucket.py +79 -0
- blaxel/models/histogram_stats.py +88 -0
- blaxel/models/integration_connection.py +96 -0
- blaxel/models/integration_connection_spec.py +114 -0
- blaxel/models/integration_connection_spec_config.py +45 -0
- blaxel/models/integration_connection_spec_secret.py +45 -0
- blaxel/models/integration_model.py +162 -0
- blaxel/models/integration_repository.py +88 -0
- blaxel/models/invite_workspace_user_body.py +60 -0
- blaxel/models/knowledgebase.py +126 -0
- blaxel/models/knowledgebase_spec.py +163 -0
- blaxel/models/knowledgebase_spec_options.py +45 -0
- blaxel/models/last_n_requests_metric.py +79 -0
- blaxel/models/latency_metric.py +144 -0
- blaxel/models/location_response.py +113 -0
- blaxel/models/mcp_definition.py +188 -0
- blaxel/models/mcp_definition_entrypoint.py +45 -0
- blaxel/models/mcp_definition_form.py +45 -0
- blaxel/models/metadata.py +139 -0
- blaxel/models/metadata_labels.py +45 -0
- blaxel/models/metric.py +79 -0
- blaxel/models/metrics.py +169 -0
- blaxel/models/metrics_models.py +45 -0
- blaxel/models/metrics_request_total_per_code.py +45 -0
- blaxel/models/metrics_rps_per_code.py +45 -0
- blaxel/models/model.py +126 -0
- blaxel/models/model_private_cluster.py +79 -0
- blaxel/models/model_spec.py +249 -0
- blaxel/models/o_auth.py +72 -0
- blaxel/models/owner_fields.py +70 -0
- blaxel/models/pending_invitation.py +124 -0
- blaxel/models/pending_invitation_accept.py +85 -0
- blaxel/models/pending_invitation_render.py +147 -0
- blaxel/models/pending_invitation_render_invited_by.py +88 -0
- blaxel/models/pending_invitation_render_workspace.py +70 -0
- blaxel/models/pending_invitation_workspace_details.py +72 -0
- blaxel/models/pod_template_spec.py +45 -0
- blaxel/models/policy.py +96 -0
- blaxel/models/policy_location.py +70 -0
- blaxel/models/policy_max_tokens.py +106 -0
- blaxel/models/policy_spec.py +151 -0
- blaxel/models/private_cluster.py +183 -0
- blaxel/models/private_location.py +61 -0
- blaxel/models/repository.py +70 -0
- blaxel/models/request_duration_over_time_metric.py +97 -0
- blaxel/models/request_duration_over_time_metrics.py +80 -0
- blaxel/models/request_total_by_origin_metric.py +115 -0
- blaxel/models/request_total_by_origin_metric_request_total_by_origin.py +45 -0
- blaxel/models/request_total_by_origin_metric_request_total_by_origin_and_code.py +45 -0
- blaxel/models/request_total_metric.py +123 -0
- blaxel/models/request_total_metric_request_total_per_code.py +45 -0
- blaxel/models/request_total_metric_rps_per_code.py +45 -0
- blaxel/models/resource_log.py +79 -0
- blaxel/models/resource_metrics.py +270 -0
- blaxel/models/resource_metrics_request_total_per_code.py +45 -0
- blaxel/models/resource_metrics_rps_per_code.py +45 -0
- blaxel/models/revision_configuration.py +97 -0
- blaxel/models/revision_metadata.py +124 -0
- blaxel/models/runtime.py +196 -0
- blaxel/models/runtime_startup_probe.py +45 -0
- blaxel/models/serverless_config.py +80 -0
- blaxel/models/spec_configuration.py +70 -0
- blaxel/models/store_agent.py +178 -0
- blaxel/models/store_agent_labels.py +45 -0
- blaxel/models/store_configuration.py +151 -0
- blaxel/models/store_configuration_option.py +79 -0
- blaxel/models/store_function.py +211 -0
- blaxel/models/store_function_kit.py +97 -0
- blaxel/models/store_function_labels.py +45 -0
- blaxel/models/store_function_parameter.py +88 -0
- blaxel/models/time_fields.py +70 -0
- blaxel/models/token_rate_metric.py +88 -0
- blaxel/models/token_rate_metrics.py +120 -0
- blaxel/models/token_total_metric.py +106 -0
- blaxel/models/trace_ids_response.py +45 -0
- blaxel/models/update_workspace_service_account_body.py +69 -0
- blaxel/models/update_workspace_service_account_response_200.py +96 -0
- blaxel/models/update_workspace_user_role_body.py +60 -0
- blaxel/models/websocket_channel.py +88 -0
- blaxel/models/workspace.py +148 -0
- blaxel/models/workspace_labels.py +45 -0
- blaxel/models/workspace_user.py +115 -0
- blaxel/py.typed +1 -0
- blaxel/run.py +108 -0
- blaxel/serve/app.py +131 -0
- blaxel/serve/middlewares/__init__.py +10 -0
- blaxel/serve/middlewares/accesslog.py +32 -0
- blaxel/serve/middlewares/processtime.py +28 -0
- blaxel/types.py +46 -0
- blaxel-0.64.0.dist-info/METADATA +96 -0
- blaxel-0.64.0.dist-info/RECORD +261 -0
- blaxel-0.64.0.dist-info/WHEEL +4 -0
- blaxel-0.64.0.dist-info/entry_points.txt +2 -0
- blaxel-0.64.0.dist-info/licenses/LICENSE +21 -0
@@ -0,0 +1,154 @@
|
|
1
|
+
from http import HTTPStatus
|
2
|
+
from typing import Any, Optional, Union
|
3
|
+
|
4
|
+
import httpx
|
5
|
+
|
6
|
+
from ... import errors
|
7
|
+
from ...client import AuthenticatedClient, Client
|
8
|
+
from ...models.model import Model
|
9
|
+
from ...types import Response
|
10
|
+
|
11
|
+
|
12
|
+
def _get_kwargs(
|
13
|
+
model_name: str,
|
14
|
+
) -> dict[str, Any]:
|
15
|
+
_kwargs: dict[str, Any] = {
|
16
|
+
"method": "get",
|
17
|
+
"url": f"/models/{model_name}",
|
18
|
+
}
|
19
|
+
|
20
|
+
return _kwargs
|
21
|
+
|
22
|
+
|
23
|
+
def _parse_response(*, client: Union[AuthenticatedClient, Client], response: httpx.Response) -> Optional[Model]:
|
24
|
+
if response.status_code == 200:
|
25
|
+
response_200 = Model.from_dict(response.json())
|
26
|
+
|
27
|
+
return response_200
|
28
|
+
if client.raise_on_unexpected_status:
|
29
|
+
raise errors.UnexpectedStatus(response.status_code, response.content)
|
30
|
+
else:
|
31
|
+
return None
|
32
|
+
|
33
|
+
|
34
|
+
def _build_response(*, client: Union[AuthenticatedClient, Client], response: httpx.Response) -> Response[Model]:
|
35
|
+
return Response(
|
36
|
+
status_code=HTTPStatus(response.status_code),
|
37
|
+
content=response.content,
|
38
|
+
headers=response.headers,
|
39
|
+
parsed=_parse_response(client=client, response=response),
|
40
|
+
)
|
41
|
+
|
42
|
+
|
43
|
+
def sync_detailed(
|
44
|
+
model_name: str,
|
45
|
+
*,
|
46
|
+
client: AuthenticatedClient,
|
47
|
+
) -> Response[Model]:
|
48
|
+
"""Get model
|
49
|
+
|
50
|
+
Returns a model by name.
|
51
|
+
|
52
|
+
Args:
|
53
|
+
model_name (str):
|
54
|
+
|
55
|
+
Raises:
|
56
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
57
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
58
|
+
|
59
|
+
Returns:
|
60
|
+
Response[Model]
|
61
|
+
"""
|
62
|
+
|
63
|
+
kwargs = _get_kwargs(
|
64
|
+
model_name=model_name,
|
65
|
+
)
|
66
|
+
|
67
|
+
response = client.get_httpx_client().request(
|
68
|
+
**kwargs,
|
69
|
+
)
|
70
|
+
|
71
|
+
return _build_response(client=client, response=response)
|
72
|
+
|
73
|
+
|
74
|
+
def sync(
|
75
|
+
model_name: str,
|
76
|
+
*,
|
77
|
+
client: AuthenticatedClient,
|
78
|
+
) -> Optional[Model]:
|
79
|
+
"""Get model
|
80
|
+
|
81
|
+
Returns a model by name.
|
82
|
+
|
83
|
+
Args:
|
84
|
+
model_name (str):
|
85
|
+
|
86
|
+
Raises:
|
87
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
88
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
89
|
+
|
90
|
+
Returns:
|
91
|
+
Model
|
92
|
+
"""
|
93
|
+
|
94
|
+
return sync_detailed(
|
95
|
+
model_name=model_name,
|
96
|
+
client=client,
|
97
|
+
).parsed
|
98
|
+
|
99
|
+
|
100
|
+
async def asyncio_detailed(
|
101
|
+
model_name: str,
|
102
|
+
*,
|
103
|
+
client: AuthenticatedClient,
|
104
|
+
) -> Response[Model]:
|
105
|
+
"""Get model
|
106
|
+
|
107
|
+
Returns a model by name.
|
108
|
+
|
109
|
+
Args:
|
110
|
+
model_name (str):
|
111
|
+
|
112
|
+
Raises:
|
113
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
114
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
115
|
+
|
116
|
+
Returns:
|
117
|
+
Response[Model]
|
118
|
+
"""
|
119
|
+
|
120
|
+
kwargs = _get_kwargs(
|
121
|
+
model_name=model_name,
|
122
|
+
)
|
123
|
+
|
124
|
+
response = await client.get_async_httpx_client().request(**kwargs)
|
125
|
+
|
126
|
+
return _build_response(client=client, response=response)
|
127
|
+
|
128
|
+
|
129
|
+
async def asyncio(
|
130
|
+
model_name: str,
|
131
|
+
*,
|
132
|
+
client: AuthenticatedClient,
|
133
|
+
) -> Optional[Model]:
|
134
|
+
"""Get model
|
135
|
+
|
136
|
+
Returns a model by name.
|
137
|
+
|
138
|
+
Args:
|
139
|
+
model_name (str):
|
140
|
+
|
141
|
+
Raises:
|
142
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
143
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
144
|
+
|
145
|
+
Returns:
|
146
|
+
Model
|
147
|
+
"""
|
148
|
+
|
149
|
+
return (
|
150
|
+
await asyncio_detailed(
|
151
|
+
model_name=model_name,
|
152
|
+
client=client,
|
153
|
+
)
|
154
|
+
).parsed
|
@@ -0,0 +1,155 @@
|
|
1
|
+
from http import HTTPStatus
|
2
|
+
from typing import Any, Optional, Union
|
3
|
+
|
4
|
+
import httpx
|
5
|
+
|
6
|
+
from ... import errors
|
7
|
+
from ...client import AuthenticatedClient, Client
|
8
|
+
from ...models.resource_log import ResourceLog
|
9
|
+
from ...types import Response
|
10
|
+
|
11
|
+
|
12
|
+
def _get_kwargs(
|
13
|
+
model_name: str,
|
14
|
+
) -> dict[str, Any]:
|
15
|
+
_kwargs: dict[str, Any] = {
|
16
|
+
"method": "get",
|
17
|
+
"url": f"/models/{model_name}/logs",
|
18
|
+
}
|
19
|
+
|
20
|
+
return _kwargs
|
21
|
+
|
22
|
+
|
23
|
+
def _parse_response(
|
24
|
+
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
|
25
|
+
) -> Optional[list["ResourceLog"]]:
|
26
|
+
if response.status_code == 200:
|
27
|
+
response_200 = []
|
28
|
+
_response_200 = response.json()
|
29
|
+
for response_200_item_data in _response_200:
|
30
|
+
response_200_item = ResourceLog.from_dict(response_200_item_data)
|
31
|
+
|
32
|
+
response_200.append(response_200_item)
|
33
|
+
|
34
|
+
return response_200
|
35
|
+
if client.raise_on_unexpected_status:
|
36
|
+
raise errors.UnexpectedStatus(response.status_code, response.content)
|
37
|
+
else:
|
38
|
+
return None
|
39
|
+
|
40
|
+
|
41
|
+
def _build_response(
|
42
|
+
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
|
43
|
+
) -> Response[list["ResourceLog"]]:
|
44
|
+
return Response(
|
45
|
+
status_code=HTTPStatus(response.status_code),
|
46
|
+
content=response.content,
|
47
|
+
headers=response.headers,
|
48
|
+
parsed=_parse_response(client=client, response=response),
|
49
|
+
)
|
50
|
+
|
51
|
+
|
52
|
+
def sync_detailed(
|
53
|
+
model_name: str,
|
54
|
+
*,
|
55
|
+
client: AuthenticatedClient,
|
56
|
+
) -> Response[list["ResourceLog"]]:
|
57
|
+
"""Returns logs for a model deployment by name.
|
58
|
+
|
59
|
+
Args:
|
60
|
+
model_name (str):
|
61
|
+
|
62
|
+
Raises:
|
63
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
64
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
65
|
+
|
66
|
+
Returns:
|
67
|
+
Response[list['ResourceLog']]
|
68
|
+
"""
|
69
|
+
|
70
|
+
kwargs = _get_kwargs(
|
71
|
+
model_name=model_name,
|
72
|
+
)
|
73
|
+
|
74
|
+
response = client.get_httpx_client().request(
|
75
|
+
**kwargs,
|
76
|
+
)
|
77
|
+
|
78
|
+
return _build_response(client=client, response=response)
|
79
|
+
|
80
|
+
|
81
|
+
def sync(
|
82
|
+
model_name: str,
|
83
|
+
*,
|
84
|
+
client: AuthenticatedClient,
|
85
|
+
) -> Optional[list["ResourceLog"]]:
|
86
|
+
"""Returns logs for a model deployment by name.
|
87
|
+
|
88
|
+
Args:
|
89
|
+
model_name (str):
|
90
|
+
|
91
|
+
Raises:
|
92
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
93
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
94
|
+
|
95
|
+
Returns:
|
96
|
+
list['ResourceLog']
|
97
|
+
"""
|
98
|
+
|
99
|
+
return sync_detailed(
|
100
|
+
model_name=model_name,
|
101
|
+
client=client,
|
102
|
+
).parsed
|
103
|
+
|
104
|
+
|
105
|
+
async def asyncio_detailed(
|
106
|
+
model_name: str,
|
107
|
+
*,
|
108
|
+
client: AuthenticatedClient,
|
109
|
+
) -> Response[list["ResourceLog"]]:
|
110
|
+
"""Returns logs for a model deployment by name.
|
111
|
+
|
112
|
+
Args:
|
113
|
+
model_name (str):
|
114
|
+
|
115
|
+
Raises:
|
116
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
117
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
118
|
+
|
119
|
+
Returns:
|
120
|
+
Response[list['ResourceLog']]
|
121
|
+
"""
|
122
|
+
|
123
|
+
kwargs = _get_kwargs(
|
124
|
+
model_name=model_name,
|
125
|
+
)
|
126
|
+
|
127
|
+
response = await client.get_async_httpx_client().request(**kwargs)
|
128
|
+
|
129
|
+
return _build_response(client=client, response=response)
|
130
|
+
|
131
|
+
|
132
|
+
async def asyncio(
|
133
|
+
model_name: str,
|
134
|
+
*,
|
135
|
+
client: AuthenticatedClient,
|
136
|
+
) -> Optional[list["ResourceLog"]]:
|
137
|
+
"""Returns logs for a model deployment by name.
|
138
|
+
|
139
|
+
Args:
|
140
|
+
model_name (str):
|
141
|
+
|
142
|
+
Raises:
|
143
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
144
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
145
|
+
|
146
|
+
Returns:
|
147
|
+
list['ResourceLog']
|
148
|
+
"""
|
149
|
+
|
150
|
+
return (
|
151
|
+
await asyncio_detailed(
|
152
|
+
model_name=model_name,
|
153
|
+
client=client,
|
154
|
+
)
|
155
|
+
).parsed
|
@@ -0,0 +1,158 @@
|
|
1
|
+
from http import HTTPStatus
|
2
|
+
from typing import Any, Optional, Union
|
3
|
+
|
4
|
+
import httpx
|
5
|
+
|
6
|
+
from ... import errors
|
7
|
+
from ...client import AuthenticatedClient, Client
|
8
|
+
from ...models.resource_metrics import ResourceMetrics
|
9
|
+
from ...types import Response
|
10
|
+
|
11
|
+
|
12
|
+
def _get_kwargs(
|
13
|
+
model_name: str,
|
14
|
+
) -> dict[str, Any]:
|
15
|
+
_kwargs: dict[str, Any] = {
|
16
|
+
"method": "get",
|
17
|
+
"url": f"/models/{model_name}/metrics",
|
18
|
+
}
|
19
|
+
|
20
|
+
return _kwargs
|
21
|
+
|
22
|
+
|
23
|
+
def _parse_response(
|
24
|
+
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
|
25
|
+
) -> Optional[ResourceMetrics]:
|
26
|
+
if response.status_code == 200:
|
27
|
+
response_200 = ResourceMetrics.from_dict(response.json())
|
28
|
+
|
29
|
+
return response_200
|
30
|
+
if client.raise_on_unexpected_status:
|
31
|
+
raise errors.UnexpectedStatus(response.status_code, response.content)
|
32
|
+
else:
|
33
|
+
return None
|
34
|
+
|
35
|
+
|
36
|
+
def _build_response(
|
37
|
+
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
|
38
|
+
) -> Response[ResourceMetrics]:
|
39
|
+
return Response(
|
40
|
+
status_code=HTTPStatus(response.status_code),
|
41
|
+
content=response.content,
|
42
|
+
headers=response.headers,
|
43
|
+
parsed=_parse_response(client=client, response=response),
|
44
|
+
)
|
45
|
+
|
46
|
+
|
47
|
+
def sync_detailed(
|
48
|
+
model_name: str,
|
49
|
+
*,
|
50
|
+
client: AuthenticatedClient,
|
51
|
+
) -> Response[ResourceMetrics]:
|
52
|
+
"""Get model metrics
|
53
|
+
|
54
|
+
Returns metrics for a model by name.
|
55
|
+
|
56
|
+
Args:
|
57
|
+
model_name (str):
|
58
|
+
|
59
|
+
Raises:
|
60
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
61
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
62
|
+
|
63
|
+
Returns:
|
64
|
+
Response[ResourceMetrics]
|
65
|
+
"""
|
66
|
+
|
67
|
+
kwargs = _get_kwargs(
|
68
|
+
model_name=model_name,
|
69
|
+
)
|
70
|
+
|
71
|
+
response = client.get_httpx_client().request(
|
72
|
+
**kwargs,
|
73
|
+
)
|
74
|
+
|
75
|
+
return _build_response(client=client, response=response)
|
76
|
+
|
77
|
+
|
78
|
+
def sync(
|
79
|
+
model_name: str,
|
80
|
+
*,
|
81
|
+
client: AuthenticatedClient,
|
82
|
+
) -> Optional[ResourceMetrics]:
|
83
|
+
"""Get model metrics
|
84
|
+
|
85
|
+
Returns metrics for a model by name.
|
86
|
+
|
87
|
+
Args:
|
88
|
+
model_name (str):
|
89
|
+
|
90
|
+
Raises:
|
91
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
92
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
93
|
+
|
94
|
+
Returns:
|
95
|
+
ResourceMetrics
|
96
|
+
"""
|
97
|
+
|
98
|
+
return sync_detailed(
|
99
|
+
model_name=model_name,
|
100
|
+
client=client,
|
101
|
+
).parsed
|
102
|
+
|
103
|
+
|
104
|
+
async def asyncio_detailed(
|
105
|
+
model_name: str,
|
106
|
+
*,
|
107
|
+
client: AuthenticatedClient,
|
108
|
+
) -> Response[ResourceMetrics]:
|
109
|
+
"""Get model metrics
|
110
|
+
|
111
|
+
Returns metrics for a model by name.
|
112
|
+
|
113
|
+
Args:
|
114
|
+
model_name (str):
|
115
|
+
|
116
|
+
Raises:
|
117
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
118
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
119
|
+
|
120
|
+
Returns:
|
121
|
+
Response[ResourceMetrics]
|
122
|
+
"""
|
123
|
+
|
124
|
+
kwargs = _get_kwargs(
|
125
|
+
model_name=model_name,
|
126
|
+
)
|
127
|
+
|
128
|
+
response = await client.get_async_httpx_client().request(**kwargs)
|
129
|
+
|
130
|
+
return _build_response(client=client, response=response)
|
131
|
+
|
132
|
+
|
133
|
+
async def asyncio(
|
134
|
+
model_name: str,
|
135
|
+
*,
|
136
|
+
client: AuthenticatedClient,
|
137
|
+
) -> Optional[ResourceMetrics]:
|
138
|
+
"""Get model metrics
|
139
|
+
|
140
|
+
Returns metrics for a model by name.
|
141
|
+
|
142
|
+
Args:
|
143
|
+
model_name (str):
|
144
|
+
|
145
|
+
Raises:
|
146
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
147
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
148
|
+
|
149
|
+
Returns:
|
150
|
+
ResourceMetrics
|
151
|
+
"""
|
152
|
+
|
153
|
+
return (
|
154
|
+
await asyncio_detailed(
|
155
|
+
model_name=model_name,
|
156
|
+
client=client,
|
157
|
+
)
|
158
|
+
).parsed
|
@@ -0,0 +1,201 @@
|
|
1
|
+
from http import HTTPStatus
|
2
|
+
from typing import Any, Optional, Union
|
3
|
+
|
4
|
+
import httpx
|
5
|
+
|
6
|
+
from ... import errors
|
7
|
+
from ...client import AuthenticatedClient, Client
|
8
|
+
from ...models.trace_ids_response import TraceIdsResponse
|
9
|
+
from ...types import UNSET, Response, Unset
|
10
|
+
|
11
|
+
|
12
|
+
def _get_kwargs(
|
13
|
+
model_name: str,
|
14
|
+
*,
|
15
|
+
limit: Union[Unset, str] = UNSET,
|
16
|
+
start_time: Union[Unset, str] = UNSET,
|
17
|
+
end_time: Union[Unset, str] = UNSET,
|
18
|
+
) -> dict[str, Any]:
|
19
|
+
params: dict[str, Any] = {}
|
20
|
+
|
21
|
+
params["limit"] = limit
|
22
|
+
|
23
|
+
params["startTime"] = start_time
|
24
|
+
|
25
|
+
params["endTime"] = end_time
|
26
|
+
|
27
|
+
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
|
28
|
+
|
29
|
+
_kwargs: dict[str, Any] = {
|
30
|
+
"method": "get",
|
31
|
+
"url": f"/models/{model_name}/traces",
|
32
|
+
"params": params,
|
33
|
+
}
|
34
|
+
|
35
|
+
return _kwargs
|
36
|
+
|
37
|
+
|
38
|
+
def _parse_response(
|
39
|
+
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
|
40
|
+
) -> Optional[TraceIdsResponse]:
|
41
|
+
if response.status_code == 200:
|
42
|
+
response_200 = TraceIdsResponse.from_dict(response.json())
|
43
|
+
|
44
|
+
return response_200
|
45
|
+
if client.raise_on_unexpected_status:
|
46
|
+
raise errors.UnexpectedStatus(response.status_code, response.content)
|
47
|
+
else:
|
48
|
+
return None
|
49
|
+
|
50
|
+
|
51
|
+
def _build_response(
|
52
|
+
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
|
53
|
+
) -> Response[TraceIdsResponse]:
|
54
|
+
return Response(
|
55
|
+
status_code=HTTPStatus(response.status_code),
|
56
|
+
content=response.content,
|
57
|
+
headers=response.headers,
|
58
|
+
parsed=_parse_response(client=client, response=response),
|
59
|
+
)
|
60
|
+
|
61
|
+
|
62
|
+
def sync_detailed(
|
63
|
+
model_name: str,
|
64
|
+
*,
|
65
|
+
client: AuthenticatedClient,
|
66
|
+
limit: Union[Unset, str] = UNSET,
|
67
|
+
start_time: Union[Unset, str] = UNSET,
|
68
|
+
end_time: Union[Unset, str] = UNSET,
|
69
|
+
) -> Response[TraceIdsResponse]:
|
70
|
+
"""Get model trace IDs
|
71
|
+
|
72
|
+
Args:
|
73
|
+
model_name (str):
|
74
|
+
limit (Union[Unset, str]):
|
75
|
+
start_time (Union[Unset, str]):
|
76
|
+
end_time (Union[Unset, str]):
|
77
|
+
|
78
|
+
Raises:
|
79
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
80
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
81
|
+
|
82
|
+
Returns:
|
83
|
+
Response[TraceIdsResponse]
|
84
|
+
"""
|
85
|
+
|
86
|
+
kwargs = _get_kwargs(
|
87
|
+
model_name=model_name,
|
88
|
+
limit=limit,
|
89
|
+
start_time=start_time,
|
90
|
+
end_time=end_time,
|
91
|
+
)
|
92
|
+
|
93
|
+
response = client.get_httpx_client().request(
|
94
|
+
**kwargs,
|
95
|
+
)
|
96
|
+
|
97
|
+
return _build_response(client=client, response=response)
|
98
|
+
|
99
|
+
|
100
|
+
def sync(
|
101
|
+
model_name: str,
|
102
|
+
*,
|
103
|
+
client: AuthenticatedClient,
|
104
|
+
limit: Union[Unset, str] = UNSET,
|
105
|
+
start_time: Union[Unset, str] = UNSET,
|
106
|
+
end_time: Union[Unset, str] = UNSET,
|
107
|
+
) -> Optional[TraceIdsResponse]:
|
108
|
+
"""Get model trace IDs
|
109
|
+
|
110
|
+
Args:
|
111
|
+
model_name (str):
|
112
|
+
limit (Union[Unset, str]):
|
113
|
+
start_time (Union[Unset, str]):
|
114
|
+
end_time (Union[Unset, str]):
|
115
|
+
|
116
|
+
Raises:
|
117
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
118
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
119
|
+
|
120
|
+
Returns:
|
121
|
+
TraceIdsResponse
|
122
|
+
"""
|
123
|
+
|
124
|
+
return sync_detailed(
|
125
|
+
model_name=model_name,
|
126
|
+
client=client,
|
127
|
+
limit=limit,
|
128
|
+
start_time=start_time,
|
129
|
+
end_time=end_time,
|
130
|
+
).parsed
|
131
|
+
|
132
|
+
|
133
|
+
async def asyncio_detailed(
|
134
|
+
model_name: str,
|
135
|
+
*,
|
136
|
+
client: AuthenticatedClient,
|
137
|
+
limit: Union[Unset, str] = UNSET,
|
138
|
+
start_time: Union[Unset, str] = UNSET,
|
139
|
+
end_time: Union[Unset, str] = UNSET,
|
140
|
+
) -> Response[TraceIdsResponse]:
|
141
|
+
"""Get model trace IDs
|
142
|
+
|
143
|
+
Args:
|
144
|
+
model_name (str):
|
145
|
+
limit (Union[Unset, str]):
|
146
|
+
start_time (Union[Unset, str]):
|
147
|
+
end_time (Union[Unset, str]):
|
148
|
+
|
149
|
+
Raises:
|
150
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
151
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
152
|
+
|
153
|
+
Returns:
|
154
|
+
Response[TraceIdsResponse]
|
155
|
+
"""
|
156
|
+
|
157
|
+
kwargs = _get_kwargs(
|
158
|
+
model_name=model_name,
|
159
|
+
limit=limit,
|
160
|
+
start_time=start_time,
|
161
|
+
end_time=end_time,
|
162
|
+
)
|
163
|
+
|
164
|
+
response = await client.get_async_httpx_client().request(**kwargs)
|
165
|
+
|
166
|
+
return _build_response(client=client, response=response)
|
167
|
+
|
168
|
+
|
169
|
+
async def asyncio(
|
170
|
+
model_name: str,
|
171
|
+
*,
|
172
|
+
client: AuthenticatedClient,
|
173
|
+
limit: Union[Unset, str] = UNSET,
|
174
|
+
start_time: Union[Unset, str] = UNSET,
|
175
|
+
end_time: Union[Unset, str] = UNSET,
|
176
|
+
) -> Optional[TraceIdsResponse]:
|
177
|
+
"""Get model trace IDs
|
178
|
+
|
179
|
+
Args:
|
180
|
+
model_name (str):
|
181
|
+
limit (Union[Unset, str]):
|
182
|
+
start_time (Union[Unset, str]):
|
183
|
+
end_time (Union[Unset, str]):
|
184
|
+
|
185
|
+
Raises:
|
186
|
+
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
|
187
|
+
httpx.TimeoutException: If the request takes longer than Client.timeout.
|
188
|
+
|
189
|
+
Returns:
|
190
|
+
TraceIdsResponse
|
191
|
+
"""
|
192
|
+
|
193
|
+
return (
|
194
|
+
await asyncio_detailed(
|
195
|
+
model_name=model_name,
|
196
|
+
client=client,
|
197
|
+
limit=limit,
|
198
|
+
start_time=start_time,
|
199
|
+
end_time=end_time,
|
200
|
+
)
|
201
|
+
).parsed
|