mixpeek 0.12.0__py3-none-any.whl → 0.13__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.
- mixpeek/__init__.py +5 -79
- mixpeek/_hooks/__init__.py +5 -0
- mixpeek/_hooks/registration.py +13 -0
- mixpeek/_hooks/sdkhooks.py +76 -0
- mixpeek/_hooks/types.py +94 -0
- mixpeek/_version.py +11 -3
- mixpeek/assets.py +1561 -0
- mixpeek/basesdk.py +350 -0
- mixpeek/collections.py +1029 -0
- mixpeek/featureextractors.py +205 -0
- mixpeek/features.py +1181 -0
- mixpeek/health.py +167 -0
- mixpeek/httpclient.py +84 -0
- mixpeek/ingest.py +831 -0
- mixpeek/interactions.py +221 -0
- mixpeek/models/__init__.py +751 -0
- mixpeek/models/actionusage.py +16 -0
- mixpeek/models/apierror.py +22 -0
- mixpeek/models/apikey.py +25 -0
- mixpeek/models/apikeyupdate.py +49 -0
- mixpeek/models/assetfeatures.py +55 -0
- mixpeek/models/assetresponse.py +166 -0
- mixpeek/models/assets_model_searchquery.py +21 -0
- mixpeek/models/assetupdate.py +28 -0
- mixpeek/models/availableindexesresponse.py +23 -0
- mixpeek/models/availablemodels.py +12 -0
- mixpeek/models/boolindexparams.py +18 -0
- mixpeek/models/collectionmodel.py +70 -0
- mixpeek/models/collectionresult.py +73 -0
- mixpeek/models/create_api_key_organizations_users_user_email_api_keys_postop.py +23 -0
- mixpeek/models/create_collection_collections_postop.py +62 -0
- mixpeek/models/create_interaction_features_search_interactions_postop.py +59 -0
- mixpeek/models/createcollectionrequest.py +59 -0
- mixpeek/models/createnamespacerequest.py +62 -0
- mixpeek/models/datetimeindexparams.py +18 -0
- mixpeek/models/dateusage.py +22 -0
- mixpeek/models/db_model_paginationresponse.py +59 -0
- mixpeek/models/db_model_taskresponse.py +20 -0
- mixpeek/models/delete_api_key_organizations_users_user_email_api_keys_key_name_deleteop.py +23 -0
- mixpeek/models/delete_asset_assets_asset_id_deleteop.py +57 -0
- mixpeek/models/delete_collection_collections_collection_deleteop.py +59 -0
- mixpeek/models/delete_feature_features_feature_id_deleteop.py +57 -0
- mixpeek/models/delete_interaction_features_search_interactions_interaction_id_deleteop.py +59 -0
- mixpeek/models/delete_namespace_namespaces_namespace_deleteop.py +18 -0
- mixpeek/models/delete_user_organizations_users_user_email_deleteop.py +16 -0
- mixpeek/models/denseembedding.py +16 -0
- mixpeek/models/embeddingrequest.py +59 -0
- mixpeek/models/embeddingresponse.py +64 -0
- mixpeek/models/errormessage.py +13 -0
- mixpeek/models/errorresponse.py +21 -0
- mixpeek/models/facedetectsettings.py +52 -0
- mixpeek/models/featureextractionembeddingrequest.py +54 -0
- mixpeek/models/featureresponse.py +74 -0
- mixpeek/models/features_model_paginationresponse.py +59 -0
- mixpeek/models/featureupdaterequest.py +21 -0
- mixpeek/models/filtercondition.py +74 -0
- mixpeek/models/floatindexparams.py +18 -0
- mixpeek/models/full_asset_update_assets_asset_id_putop.py +69 -0
- mixpeek/models/full_feature_update_features_feature_id_putop.py +69 -0
- mixpeek/models/geoindexparams.py +18 -0
- mixpeek/models/get_asset_assets_asset_id_getop.py +73 -0
- mixpeek/models/get_asset_with_features_assets_asset_id_features_getop.py +73 -0
- mixpeek/models/get_collection_collections_collection_getop.py +59 -0
- mixpeek/models/get_feature_features_feature_id_getop.py +70 -0
- mixpeek/models/get_interaction_features_search_interactions_interaction_id_getop.py +59 -0
- mixpeek/models/get_namespace_namespaces_namespace_getop.py +18 -0
- mixpeek/models/get_task_tasks_task_id_getop.py +57 -0
- mixpeek/models/get_user_organizations_users_user_email_getop.py +16 -0
- mixpeek/models/groupbyoptions.py +71 -0
- mixpeek/models/groupbyoptionsasset.py +71 -0
- mixpeek/models/groupedassetdata.py +18 -0
- mixpeek/models/healthcheckresponse.py +13 -0
- mixpeek/models/httpvalidationerror.py +21 -0
- mixpeek/models/imagedescribesettings.py +82 -0
- mixpeek/models/imagedetectsettings.py +53 -0
- mixpeek/models/imagereadsettings.py +71 -0
- mixpeek/models/imagesettings.py +79 -0
- mixpeek/models/ingest_image_url_ingest_images_url_postop.py +59 -0
- mixpeek/models/ingest_text_ingest_text_postop.py +59 -0
- mixpeek/models/ingest_video_url_ingest_videos_url_postop.py +59 -0
- mixpeek/models/inputtype.py +11 -0
- mixpeek/models/integerindexparams.py +24 -0
- mixpeek/models/interactionresponse.py +87 -0
- mixpeek/models/interactiontype.py +11 -0
- mixpeek/models/jsonimageoutputsettings.py +55 -0
- mixpeek/models/jsontextoutputsettings.py +55 -0
- mixpeek/models/jsonvideooutputsettings.py +55 -0
- mixpeek/models/keywordindexparams.py +21 -0
- mixpeek/models/kill_task_tasks_task_id_deleteop.py +57 -0
- mixpeek/models/list_assets_assets_postop.py +77 -0
- mixpeek/models/list_collections_collections_getop.py +65 -0
- mixpeek/models/list_features_features_postop.py +79 -0
- mixpeek/models/list_interactions_features_search_interactions_getop.py +96 -0
- mixpeek/models/listassetsrequest.py +75 -0
- mixpeek/models/listassetsresponse.py +22 -0
- mixpeek/models/listcollectionsresponse.py +22 -0
- mixpeek/models/listfeaturesrequest.py +77 -0
- mixpeek/models/listfeaturesresponse.py +22 -0
- mixpeek/models/logicaloperator_input.py +88 -0
- mixpeek/models/logicaloperator_output.py +103 -0
- mixpeek/models/logodetectsettings.py +52 -0
- mixpeek/models/modality.py +13 -0
- mixpeek/models/modeldetails.py +57 -0
- mixpeek/models/namespaceresponse.py +54 -0
- mixpeek/models/organizationmodel.py +45 -0
- mixpeek/models/partial_asset_update_assets_asset_id_patchop.py +69 -0
- mixpeek/models/payloadindexconfig.py +94 -0
- mixpeek/models/payloadindextype.py +17 -0
- mixpeek/models/payloadschematype.py +15 -0
- mixpeek/models/percolaterequest.py +57 -0
- mixpeek/models/permission.py +10 -0
- mixpeek/models/processimageurlinput.py +99 -0
- mixpeek/models/processtextinput.py +94 -0
- mixpeek/models/processvideourlinput.py +99 -0
- mixpeek/models/querysettings.py +56 -0
- mixpeek/models/rerankingoptions.py +47 -0
- mixpeek/models/search_assets_assets_search_postop.py +59 -0
- mixpeek/models/search_features_features_search_postop.py +96 -0
- mixpeek/models/search_model_searchquery_input.py +76 -0
- mixpeek/models/searchassetsrequest.py +78 -0
- mixpeek/models/searchinteraction.py +82 -0
- mixpeek/models/searchquery_output.py +79 -0
- mixpeek/models/searchrequestfeatures_input.py +151 -0
- mixpeek/models/searchrequestfeatures_output.py +151 -0
- mixpeek/models/sortoption.py +28 -0
- mixpeek/models/sparseembedding.py +21 -0
- mixpeek/models/tasks_model_taskresponse.py +24 -0
- mixpeek/models/taskstatus.py +16 -0
- mixpeek/models/textindexparams.py +31 -0
- mixpeek/models/textsettings.py +61 -0
- mixpeek/models/tokenizertype.py +11 -0
- mixpeek/models/update_api_key_organizations_users_user_email_api_keys_key_name_patchop.py +30 -0
- mixpeek/models/update_collection_collections_collection_putop.py +74 -0
- mixpeek/models/update_namespace_namespaces_namespace_putop.py +28 -0
- mixpeek/models/updateassetrequest.py +60 -0
- mixpeek/models/updatenamespacerequest.py +26 -0
- mixpeek/models/usage.py +18 -0
- mixpeek/models/usermodel_input.py +36 -0
- mixpeek/models/usermodel_output.py +36 -0
- mixpeek/models/uuidindexparams.py +21 -0
- mixpeek/models/validationerror.py +26 -0
- mixpeek/models/vectormodel.py +11 -0
- mixpeek/models/vectortype.py +9 -0
- mixpeek/models/videodescribesettings.py +82 -0
- mixpeek/models/videodetectsettings.py +53 -0
- mixpeek/models/videoreadsettings.py +71 -0
- mixpeek/models/videosettings.py +101 -0
- mixpeek/models/videotranscriptionsettings.py +69 -0
- mixpeek/namespaces.py +1143 -0
- mixpeek/organizations.py +1508 -0
- mixpeek/py.typed +1 -0
- mixpeek/sdk.py +135 -0
- mixpeek/sdkconfiguration.py +45 -0
- mixpeek/searchinteractions.py +647 -0
- mixpeek/tasks.py +387 -0
- mixpeek/types/__init__.py +19 -29
- mixpeek/types/basemodel.py +39 -0
- mixpeek/utils/__init__.py +97 -0
- mixpeek/utils/annotations.py +55 -0
- mixpeek/utils/enums.py +34 -0
- mixpeek/utils/eventstreaming.py +238 -0
- mixpeek/utils/forms.py +202 -0
- mixpeek/utils/headers.py +136 -0
- mixpeek/utils/logger.py +27 -0
- mixpeek/utils/metadata.py +118 -0
- mixpeek/utils/queryparams.py +205 -0
- mixpeek/utils/requestbodies.py +66 -0
- mixpeek/utils/retries.py +217 -0
- mixpeek/utils/security.py +174 -0
- mixpeek/utils/serializers.py +215 -0
- mixpeek/utils/url.py +155 -0
- mixpeek/utils/values.py +134 -0
- mixpeek-0.13.dist-info/METADATA +439 -0
- mixpeek-0.13.dist-info/RECORD +176 -0
- {mixpeek-0.12.0.dist-info → mixpeek-0.13.dist-info}/WHEEL +1 -1
- py.typed +1 -0
- mixpeek/_base_client.py +0 -2041
- mixpeek/_client.py +0 -444
- mixpeek/_compat.py +0 -221
- mixpeek/_constants.py +0 -14
- mixpeek/_exceptions.py +0 -108
- mixpeek/_files.py +0 -123
- mixpeek/_models.py +0 -788
- mixpeek/_qs.py +0 -150
- mixpeek/_resource.py +0 -43
- mixpeek/_response.py +0 -824
- mixpeek/_streaming.py +0 -333
- mixpeek/_types.py +0 -219
- mixpeek/_utils/__init__.py +0 -56
- mixpeek/_utils/_logs.py +0 -25
- mixpeek/_utils/_proxy.py +0 -62
- mixpeek/_utils/_reflection.py +0 -42
- mixpeek/_utils/_streams.py +0 -12
- mixpeek/_utils/_sync.py +0 -81
- mixpeek/_utils/_transform.py +0 -387
- mixpeek/_utils/_typing.py +0 -120
- mixpeek/_utils/_utils.py +0 -414
- mixpeek/lib/.keep +0 -4
- mixpeek/resources/__init__.py +0 -117
- mixpeek/resources/accounts.py +0 -271
- mixpeek/resources/assets/__init__.py +0 -33
- mixpeek/resources/assets/assets.py +0 -708
- mixpeek/resources/assets/features.py +0 -172
- mixpeek/resources/collections.py +0 -283
- mixpeek/resources/entities/__init__.py +0 -47
- mixpeek/resources/entities/entities.py +0 -134
- mixpeek/resources/entities/faces.py +0 -514
- mixpeek/resources/entities/labels.py +0 -388
- mixpeek/resources/features/__init__.py +0 -33
- mixpeek/resources/features/features.py +0 -562
- mixpeek/resources/features/search.py +0 -731
- mixpeek/resources/healthcheck.py +0 -135
- mixpeek/resources/index/__init__.py +0 -47
- mixpeek/resources/index/images.py +0 -249
- mixpeek/resources/index/index.py +0 -289
- mixpeek/resources/index/videos.py +0 -249
- mixpeek/resources/tasks.py +0 -258
- mixpeek/types/account_update_params.py +0 -28
- mixpeek/types/asset_create_params.py +0 -36
- mixpeek/types/asset_create_response.py +0 -15
- mixpeek/types/asset_response.py +0 -46
- mixpeek/types/asset_search_params.py +0 -43
- mixpeek/types/asset_search_response.py +0 -15
- mixpeek/types/asset_update_params.py +0 -25
- mixpeek/types/asset_update_response.py +0 -11
- mixpeek/types/assets/__init__.py +0 -3
- mixpeek/types/collection_list_params.py +0 -19
- mixpeek/types/collection_list_response.py +0 -14
- mixpeek/types/entities/__init__.py +0 -13
- mixpeek/types/entities/face_create_params.py +0 -21
- mixpeek/types/entities/face_list_params.py +0 -18
- mixpeek/types/entities/face_list_response.py +0 -15
- mixpeek/types/entities/face_response.py +0 -17
- mixpeek/types/entities/face_update_params.py +0 -22
- mixpeek/types/entities/label_list_params.py +0 -18
- mixpeek/types/entities/label_list_response.py +0 -30
- mixpeek/types/entities/label_response.py +0 -30
- mixpeek/types/entities/label_update_params.py +0 -21
- mixpeek/types/feature.py +0 -32
- mixpeek/types/feature_list_params.py +0 -37
- mixpeek/types/feature_list_response.py +0 -28
- mixpeek/types/feature_retrieve_params.py +0 -18
- mixpeek/types/feature_update_params.py +0 -16
- mixpeek/types/features/__init__.py +0 -8
- mixpeek/types/features/search_feedback_params.py +0 -23
- mixpeek/types/features/search_file_params.py +0 -29
- mixpeek/types/features/search_text_params.py +0 -72
- mixpeek/types/features/search_url_params.py +0 -72
- mixpeek/types/grouped_asset_data.py +0 -24
- mixpeek/types/health_check_response.py +0 -10
- mixpeek/types/index/__init__.py +0 -8
- mixpeek/types/index/image_url_params.py +0 -135
- mixpeek/types/index/image_url_response.py +0 -20
- mixpeek/types/index/video_url_params.py +0 -154
- mixpeek/types/index/video_url_response.py +0 -20
- mixpeek/types/index_text_params.py +0 -77
- mixpeek/types/index_text_response.py +0 -14
- mixpeek/types/shared/__init__.py +0 -7
- mixpeek/types/shared/filter_condition.py +0 -19
- mixpeek/types/shared/logical_operator.py +0 -12
- mixpeek/types/shared/model_pagination_response.py +0 -21
- mixpeek/types/shared/sort_option.py +0 -15
- mixpeek/types/shared/task_response.py +0 -15
- mixpeek/types/shared_params/__init__.py +0 -4
- mixpeek/types/shared_params/logical_operator.py +0 -13
- mixpeek/types/shared_params/sort_option.py +0 -15
- mixpeek/types/user.py +0 -34
- mixpeek-0.12.0.dist-info/METADATA +0 -345
- mixpeek-0.12.0.dist-info/RECORD +0 -99
- mixpeek-0.12.0.dist-info/licenses/LICENSE +0 -201
@@ -0,0 +1,205 @@
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
2
|
+
|
3
|
+
from .basesdk import BaseSDK
|
4
|
+
from mixpeek import models, utils
|
5
|
+
from mixpeek._hooks import HookContext
|
6
|
+
from mixpeek.types import OptionalNullable, UNSET
|
7
|
+
from typing import Any, Mapping, Optional
|
8
|
+
|
9
|
+
|
10
|
+
class FeatureExtractors(BaseSDK):
|
11
|
+
def extract_embeddings(
|
12
|
+
self,
|
13
|
+
*,
|
14
|
+
type_: models.InputType,
|
15
|
+
vector_index: models.VectorModel,
|
16
|
+
value: OptionalNullable[str] = UNSET,
|
17
|
+
retries: OptionalNullable[utils.RetryConfig] = UNSET,
|
18
|
+
server_url: Optional[str] = None,
|
19
|
+
timeout_ms: Optional[int] = None,
|
20
|
+
http_headers: Optional[Mapping[str, str]] = None,
|
21
|
+
) -> models.EmbeddingResponse:
|
22
|
+
r"""Extract Embeddings
|
23
|
+
|
24
|
+
:param type:
|
25
|
+
:param vector_index:
|
26
|
+
:param value: The input content to embed. Could be a URL, text content, file path, or base64 encoded string
|
27
|
+
:param retries: Override the default retry configuration for this method
|
28
|
+
:param server_url: Override the default server URL for this method
|
29
|
+
:param timeout_ms: Override the default request timeout configuration for this method in milliseconds
|
30
|
+
:param http_headers: Additional headers to set or replace on requests.
|
31
|
+
"""
|
32
|
+
base_url = None
|
33
|
+
url_variables = None
|
34
|
+
if timeout_ms is None:
|
35
|
+
timeout_ms = self.sdk_configuration.timeout_ms
|
36
|
+
|
37
|
+
if server_url is not None:
|
38
|
+
base_url = server_url
|
39
|
+
|
40
|
+
request = models.FeatureExtractionEmbeddingRequest(
|
41
|
+
type=type_,
|
42
|
+
value=value,
|
43
|
+
vector_index=vector_index,
|
44
|
+
)
|
45
|
+
|
46
|
+
req = self.build_request(
|
47
|
+
method="POST",
|
48
|
+
path="/features/extractors/embed",
|
49
|
+
base_url=base_url,
|
50
|
+
url_variables=url_variables,
|
51
|
+
request=request,
|
52
|
+
request_body_required=True,
|
53
|
+
request_has_path_params=False,
|
54
|
+
request_has_query_params=False,
|
55
|
+
user_agent_header="user-agent",
|
56
|
+
accept_header_value="application/json",
|
57
|
+
http_headers=http_headers,
|
58
|
+
get_serialized_body=lambda: utils.serialize_request_body(
|
59
|
+
request, False, False, "json", models.FeatureExtractionEmbeddingRequest
|
60
|
+
),
|
61
|
+
timeout_ms=timeout_ms,
|
62
|
+
)
|
63
|
+
|
64
|
+
if retries == UNSET:
|
65
|
+
if self.sdk_configuration.retry_config is not UNSET:
|
66
|
+
retries = self.sdk_configuration.retry_config
|
67
|
+
|
68
|
+
retry_config = None
|
69
|
+
if isinstance(retries, utils.RetryConfig):
|
70
|
+
retry_config = (retries, ["429", "500", "502", "503", "504"])
|
71
|
+
|
72
|
+
http_res = self.do_request(
|
73
|
+
hook_ctx=HookContext(
|
74
|
+
operation_id="extract_embeddings_features_extractors_embed_post",
|
75
|
+
oauth2_scopes=[],
|
76
|
+
security_source=None,
|
77
|
+
),
|
78
|
+
request=req,
|
79
|
+
error_status_codes=["400", "401", "403", "404", "422", "4XX", "500", "5XX"],
|
80
|
+
retry_config=retry_config,
|
81
|
+
)
|
82
|
+
|
83
|
+
data: Any = None
|
84
|
+
if utils.match_response(http_res, "200", "application/json"):
|
85
|
+
return utils.unmarshal_json(http_res.text, models.EmbeddingResponse)
|
86
|
+
if utils.match_response(
|
87
|
+
http_res, ["400", "401", "403", "404", "500"], "application/json"
|
88
|
+
):
|
89
|
+
data = utils.unmarshal_json(http_res.text, models.ErrorResponseData)
|
90
|
+
raise models.ErrorResponse(data=data)
|
91
|
+
if utils.match_response(http_res, "422", "application/json"):
|
92
|
+
data = utils.unmarshal_json(http_res.text, models.HTTPValidationErrorData)
|
93
|
+
raise models.HTTPValidationError(data=data)
|
94
|
+
if utils.match_response(http_res, ["4XX", "5XX"], "*"):
|
95
|
+
http_res_text = utils.stream_to_text(http_res)
|
96
|
+
raise models.APIError(
|
97
|
+
"API error occurred", http_res.status_code, http_res_text, http_res
|
98
|
+
)
|
99
|
+
|
100
|
+
content_type = http_res.headers.get("Content-Type")
|
101
|
+
http_res_text = utils.stream_to_text(http_res)
|
102
|
+
raise models.APIError(
|
103
|
+
f"Unexpected response received (code: {http_res.status_code}, type: {content_type})",
|
104
|
+
http_res.status_code,
|
105
|
+
http_res_text,
|
106
|
+
http_res,
|
107
|
+
)
|
108
|
+
|
109
|
+
async def extract_embeddings_async(
|
110
|
+
self,
|
111
|
+
*,
|
112
|
+
type_: models.InputType,
|
113
|
+
vector_index: models.VectorModel,
|
114
|
+
value: OptionalNullable[str] = UNSET,
|
115
|
+
retries: OptionalNullable[utils.RetryConfig] = UNSET,
|
116
|
+
server_url: Optional[str] = None,
|
117
|
+
timeout_ms: Optional[int] = None,
|
118
|
+
http_headers: Optional[Mapping[str, str]] = None,
|
119
|
+
) -> models.EmbeddingResponse:
|
120
|
+
r"""Extract Embeddings
|
121
|
+
|
122
|
+
:param type:
|
123
|
+
:param vector_index:
|
124
|
+
:param value: The input content to embed. Could be a URL, text content, file path, or base64 encoded string
|
125
|
+
:param retries: Override the default retry configuration for this method
|
126
|
+
:param server_url: Override the default server URL for this method
|
127
|
+
:param timeout_ms: Override the default request timeout configuration for this method in milliseconds
|
128
|
+
:param http_headers: Additional headers to set or replace on requests.
|
129
|
+
"""
|
130
|
+
base_url = None
|
131
|
+
url_variables = None
|
132
|
+
if timeout_ms is None:
|
133
|
+
timeout_ms = self.sdk_configuration.timeout_ms
|
134
|
+
|
135
|
+
if server_url is not None:
|
136
|
+
base_url = server_url
|
137
|
+
|
138
|
+
request = models.FeatureExtractionEmbeddingRequest(
|
139
|
+
type=type_,
|
140
|
+
value=value,
|
141
|
+
vector_index=vector_index,
|
142
|
+
)
|
143
|
+
|
144
|
+
req = self.build_request_async(
|
145
|
+
method="POST",
|
146
|
+
path="/features/extractors/embed",
|
147
|
+
base_url=base_url,
|
148
|
+
url_variables=url_variables,
|
149
|
+
request=request,
|
150
|
+
request_body_required=True,
|
151
|
+
request_has_path_params=False,
|
152
|
+
request_has_query_params=False,
|
153
|
+
user_agent_header="user-agent",
|
154
|
+
accept_header_value="application/json",
|
155
|
+
http_headers=http_headers,
|
156
|
+
get_serialized_body=lambda: utils.serialize_request_body(
|
157
|
+
request, False, False, "json", models.FeatureExtractionEmbeddingRequest
|
158
|
+
),
|
159
|
+
timeout_ms=timeout_ms,
|
160
|
+
)
|
161
|
+
|
162
|
+
if retries == UNSET:
|
163
|
+
if self.sdk_configuration.retry_config is not UNSET:
|
164
|
+
retries = self.sdk_configuration.retry_config
|
165
|
+
|
166
|
+
retry_config = None
|
167
|
+
if isinstance(retries, utils.RetryConfig):
|
168
|
+
retry_config = (retries, ["429", "500", "502", "503", "504"])
|
169
|
+
|
170
|
+
http_res = await self.do_request_async(
|
171
|
+
hook_ctx=HookContext(
|
172
|
+
operation_id="extract_embeddings_features_extractors_embed_post",
|
173
|
+
oauth2_scopes=[],
|
174
|
+
security_source=None,
|
175
|
+
),
|
176
|
+
request=req,
|
177
|
+
error_status_codes=["400", "401", "403", "404", "422", "4XX", "500", "5XX"],
|
178
|
+
retry_config=retry_config,
|
179
|
+
)
|
180
|
+
|
181
|
+
data: Any = None
|
182
|
+
if utils.match_response(http_res, "200", "application/json"):
|
183
|
+
return utils.unmarshal_json(http_res.text, models.EmbeddingResponse)
|
184
|
+
if utils.match_response(
|
185
|
+
http_res, ["400", "401", "403", "404", "500"], "application/json"
|
186
|
+
):
|
187
|
+
data = utils.unmarshal_json(http_res.text, models.ErrorResponseData)
|
188
|
+
raise models.ErrorResponse(data=data)
|
189
|
+
if utils.match_response(http_res, "422", "application/json"):
|
190
|
+
data = utils.unmarshal_json(http_res.text, models.HTTPValidationErrorData)
|
191
|
+
raise models.HTTPValidationError(data=data)
|
192
|
+
if utils.match_response(http_res, ["4XX", "5XX"], "*"):
|
193
|
+
http_res_text = await utils.stream_to_text_async(http_res)
|
194
|
+
raise models.APIError(
|
195
|
+
"API error occurred", http_res.status_code, http_res_text, http_res
|
196
|
+
)
|
197
|
+
|
198
|
+
content_type = http_res.headers.get("Content-Type")
|
199
|
+
http_res_text = await utils.stream_to_text_async(http_res)
|
200
|
+
raise models.APIError(
|
201
|
+
f"Unexpected response received (code: {http_res.status_code}, type: {content_type})",
|
202
|
+
http_res.status_code,
|
203
|
+
http_res_text,
|
204
|
+
http_res,
|
205
|
+
)
|