mistralai 0.4.2__py3-none-any.whl → 0.5.5a50__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.
- mistralai/__init__.py +5 -0
- mistralai/_hooks/__init__.py +5 -0
- mistralai/_hooks/custom_user_agent.py +16 -0
- mistralai/_hooks/deprecation_warning.py +26 -0
- mistralai/_hooks/registration.py +17 -0
- mistralai/_hooks/sdkhooks.py +57 -0
- mistralai/_hooks/types.py +76 -0
- mistralai/async_client.py +5 -413
- mistralai/basesdk.py +216 -0
- mistralai/chat.py +475 -0
- mistralai/client.py +5 -414
- mistralai/embeddings.py +182 -0
- mistralai/files.py +600 -84
- mistralai/fim.py +439 -0
- mistralai/fine_tuning.py +855 -0
- mistralai/httpclient.py +78 -0
- mistralai/models/__init__.py +80 -0
- mistralai/models/archiveftmodelout.py +19 -0
- mistralai/models/assistantmessage.py +58 -0
- mistralai/models/chatcompletionchoice.py +33 -0
- mistralai/models/chatcompletionrequest.py +114 -0
- mistralai/models/chatcompletionresponse.py +27 -0
- mistralai/models/chatcompletionstreamrequest.py +112 -0
- mistralai/models/checkpointout.py +25 -0
- mistralai/models/completionchunk.py +27 -0
- mistralai/models/completionevent.py +15 -0
- mistralai/models/completionresponsestreamchoice.py +53 -0
- mistralai/models/contentchunk.py +17 -0
- mistralai/models/delete_model_v1_models_model_id_deleteop.py +16 -0
- mistralai/models/deletefileout.py +24 -0
- mistralai/models/deletemodelout.py +25 -0
- mistralai/models/deltamessage.py +52 -0
- mistralai/models/detailedjobout.py +96 -0
- mistralai/models/embeddingrequest.py +66 -0
- mistralai/models/embeddingresponse.py +24 -0
- mistralai/models/embeddingresponsedata.py +19 -0
- mistralai/models/eventout.py +55 -0
- mistralai/models/files_api_routes_delete_fileop.py +16 -0
- mistralai/models/files_api_routes_retrieve_fileop.py +16 -0
- mistralai/models/files_api_routes_upload_fileop.py +51 -0
- mistralai/models/fileschema.py +76 -0
- mistralai/models/fimcompletionrequest.py +99 -0
- mistralai/models/fimcompletionresponse.py +27 -0
- mistralai/models/fimcompletionstreamrequest.py +97 -0
- mistralai/models/finetuneablemodel.py +8 -0
- mistralai/models/ftmodelcapabilitiesout.py +21 -0
- mistralai/models/ftmodelout.py +70 -0
- mistralai/models/function.py +19 -0
- mistralai/models/functioncall.py +16 -0
- mistralai/models/githubrepositoryin.py +57 -0
- mistralai/models/githubrepositoryout.py +57 -0
- mistralai/models/httpvalidationerror.py +23 -0
- mistralai/models/jobin.py +78 -0
- mistralai/models/jobmetadataout.py +59 -0
- mistralai/models/jobout.py +112 -0
- mistralai/models/jobs_api_routes_fine_tuning_archive_fine_tuned_modelop.py +16 -0
- mistralai/models/jobs_api_routes_fine_tuning_cancel_fine_tuning_jobop.py +18 -0
- mistralai/models/jobs_api_routes_fine_tuning_create_fine_tuning_jobop.py +73 -0
- mistralai/models/jobs_api_routes_fine_tuning_get_fine_tuning_jobop.py +18 -0
- mistralai/models/jobs_api_routes_fine_tuning_get_fine_tuning_jobsop.py +86 -0
- mistralai/models/jobs_api_routes_fine_tuning_start_fine_tuning_jobop.py +16 -0
- mistralai/models/jobs_api_routes_fine_tuning_unarchive_fine_tuned_modelop.py +16 -0
- mistralai/models/jobs_api_routes_fine_tuning_update_fine_tuned_modelop.py +19 -0
- mistralai/models/jobsout.py +20 -0
- mistralai/models/legacyjobmetadataout.py +85 -0
- mistralai/models/listfilesout.py +17 -0
- mistralai/models/metricout.py +55 -0
- mistralai/models/modelcapabilities.py +21 -0
- mistralai/models/modelcard.py +71 -0
- mistralai/models/modellist.py +18 -0
- mistralai/models/responseformat.py +18 -0
- mistralai/models/retrieve_model_v1_models_model_id_getop.py +16 -0
- mistralai/models/retrievefileout.py +76 -0
- mistralai/models/sampletype.py +7 -0
- mistralai/models/sdkerror.py +22 -0
- mistralai/models/security.py +16 -0
- mistralai/models/source.py +7 -0
- mistralai/models/systemmessage.py +26 -0
- mistralai/models/textchunk.py +17 -0
- mistralai/models/tool.py +18 -0
- mistralai/models/toolcall.py +20 -0
- mistralai/models/toolmessage.py +55 -0
- mistralai/models/trainingfile.py +17 -0
- mistralai/models/trainingparameters.py +53 -0
- mistralai/models/trainingparametersin.py +61 -0
- mistralai/models/unarchiveftmodelout.py +19 -0
- mistralai/models/updateftmodelin.py +49 -0
- mistralai/models/uploadfileout.py +76 -0
- mistralai/models/usageinfo.py +18 -0
- mistralai/models/usermessage.py +26 -0
- mistralai/models/validationerror.py +24 -0
- mistralai/models/wandbintegration.py +61 -0
- mistralai/models/wandbintegrationout.py +57 -0
- mistralai/models_.py +928 -0
- mistralai/py.typed +1 -0
- mistralai/sdk.py +111 -0
- mistralai/sdkconfiguration.py +53 -0
- mistralai/types/__init__.py +21 -0
- mistralai/types/basemodel.py +35 -0
- mistralai/utils/__init__.py +82 -0
- mistralai/utils/annotations.py +19 -0
- mistralai/utils/enums.py +34 -0
- mistralai/utils/eventstreaming.py +179 -0
- mistralai/utils/forms.py +207 -0
- mistralai/utils/headers.py +136 -0
- mistralai/utils/metadata.py +118 -0
- mistralai/utils/queryparams.py +203 -0
- mistralai/utils/requestbodies.py +66 -0
- mistralai/utils/retries.py +216 -0
- mistralai/utils/security.py +182 -0
- mistralai/utils/serializers.py +181 -0
- mistralai/utils/url.py +150 -0
- mistralai/utils/values.py +128 -0
- {mistralai-0.4.2.dist-info → mistralai-0.5.5a50.dist-info}/LICENSE +1 -1
- mistralai-0.5.5a50.dist-info/METADATA +626 -0
- mistralai-0.5.5a50.dist-info/RECORD +228 -0
- mistralai_azure/__init__.py +5 -0
- mistralai_azure/_hooks/__init__.py +5 -0
- mistralai_azure/_hooks/custom_user_agent.py +16 -0
- mistralai_azure/_hooks/registration.py +15 -0
- mistralai_azure/_hooks/sdkhooks.py +57 -0
- mistralai_azure/_hooks/types.py +76 -0
- mistralai_azure/basesdk.py +215 -0
- mistralai_azure/chat.py +475 -0
- mistralai_azure/httpclient.py +78 -0
- mistralai_azure/models/__init__.py +28 -0
- mistralai_azure/models/assistantmessage.py +58 -0
- mistralai_azure/models/chatcompletionchoice.py +33 -0
- mistralai_azure/models/chatcompletionrequest.py +114 -0
- mistralai_azure/models/chatcompletionresponse.py +27 -0
- mistralai_azure/models/chatcompletionstreamrequest.py +112 -0
- mistralai_azure/models/completionchunk.py +27 -0
- mistralai_azure/models/completionevent.py +15 -0
- mistralai_azure/models/completionresponsestreamchoice.py +53 -0
- mistralai_azure/models/contentchunk.py +17 -0
- mistralai_azure/models/deltamessage.py +52 -0
- mistralai_azure/models/function.py +19 -0
- mistralai_azure/models/functioncall.py +16 -0
- mistralai_azure/models/httpvalidationerror.py +23 -0
- mistralai_azure/models/responseformat.py +18 -0
- mistralai_azure/models/sdkerror.py +22 -0
- mistralai_azure/models/security.py +16 -0
- mistralai_azure/models/systemmessage.py +26 -0
- mistralai_azure/models/textchunk.py +17 -0
- mistralai_azure/models/tool.py +18 -0
- mistralai_azure/models/toolcall.py +20 -0
- mistralai_azure/models/toolmessage.py +55 -0
- mistralai_azure/models/usageinfo.py +18 -0
- mistralai_azure/models/usermessage.py +26 -0
- mistralai_azure/models/validationerror.py +24 -0
- mistralai_azure/py.typed +1 -0
- mistralai_azure/sdk.py +102 -0
- mistralai_azure/sdkconfiguration.py +53 -0
- mistralai_azure/types/__init__.py +21 -0
- mistralai_azure/types/basemodel.py +35 -0
- mistralai_azure/utils/__init__.py +80 -0
- mistralai_azure/utils/annotations.py +19 -0
- mistralai_azure/utils/enums.py +34 -0
- mistralai_azure/utils/eventstreaming.py +179 -0
- mistralai_azure/utils/forms.py +207 -0
- mistralai_azure/utils/headers.py +136 -0
- mistralai_azure/utils/metadata.py +118 -0
- mistralai_azure/utils/queryparams.py +203 -0
- mistralai_azure/utils/requestbodies.py +66 -0
- mistralai_azure/utils/retries.py +216 -0
- mistralai_azure/utils/security.py +168 -0
- mistralai_azure/utils/serializers.py +181 -0
- mistralai_azure/utils/url.py +150 -0
- mistralai_azure/utils/values.py +128 -0
- mistralai_gcp/__init__.py +5 -0
- mistralai_gcp/_hooks/__init__.py +5 -0
- mistralai_gcp/_hooks/custom_user_agent.py +16 -0
- mistralai_gcp/_hooks/registration.py +15 -0
- mistralai_gcp/_hooks/sdkhooks.py +57 -0
- mistralai_gcp/_hooks/types.py +76 -0
- mistralai_gcp/basesdk.py +215 -0
- mistralai_gcp/chat.py +463 -0
- mistralai_gcp/fim.py +439 -0
- mistralai_gcp/httpclient.py +78 -0
- mistralai_gcp/models/__init__.py +31 -0
- mistralai_gcp/models/assistantmessage.py +58 -0
- mistralai_gcp/models/chatcompletionchoice.py +33 -0
- mistralai_gcp/models/chatcompletionrequest.py +110 -0
- mistralai_gcp/models/chatcompletionresponse.py +27 -0
- mistralai_gcp/models/chatcompletionstreamrequest.py +108 -0
- mistralai_gcp/models/completionchunk.py +27 -0
- mistralai_gcp/models/completionevent.py +15 -0
- mistralai_gcp/models/completionresponsestreamchoice.py +53 -0
- mistralai_gcp/models/contentchunk.py +17 -0
- mistralai_gcp/models/deltamessage.py +52 -0
- mistralai_gcp/models/fimcompletionrequest.py +99 -0
- mistralai_gcp/models/fimcompletionresponse.py +27 -0
- mistralai_gcp/models/fimcompletionstreamrequest.py +97 -0
- mistralai_gcp/models/function.py +19 -0
- mistralai_gcp/models/functioncall.py +16 -0
- mistralai_gcp/models/httpvalidationerror.py +23 -0
- mistralai_gcp/models/responseformat.py +18 -0
- mistralai_gcp/models/sdkerror.py +22 -0
- mistralai_gcp/models/security.py +16 -0
- mistralai_gcp/models/systemmessage.py +26 -0
- mistralai_gcp/models/textchunk.py +17 -0
- mistralai_gcp/models/tool.py +18 -0
- mistralai_gcp/models/toolcall.py +20 -0
- mistralai_gcp/models/toolmessage.py +55 -0
- mistralai_gcp/models/usageinfo.py +18 -0
- mistralai_gcp/models/usermessage.py +26 -0
- mistralai_gcp/models/validationerror.py +24 -0
- mistralai_gcp/py.typed +1 -0
- mistralai_gcp/sdk.py +165 -0
- mistralai_gcp/sdkconfiguration.py +53 -0
- mistralai_gcp/types/__init__.py +21 -0
- mistralai_gcp/types/basemodel.py +35 -0
- mistralai_gcp/utils/__init__.py +80 -0
- mistralai_gcp/utils/annotations.py +19 -0
- mistralai_gcp/utils/enums.py +34 -0
- mistralai_gcp/utils/eventstreaming.py +179 -0
- mistralai_gcp/utils/forms.py +207 -0
- mistralai_gcp/utils/headers.py +136 -0
- mistralai_gcp/utils/metadata.py +118 -0
- mistralai_gcp/utils/queryparams.py +203 -0
- mistralai_gcp/utils/requestbodies.py +66 -0
- mistralai_gcp/utils/retries.py +216 -0
- mistralai_gcp/utils/security.py +168 -0
- mistralai_gcp/utils/serializers.py +181 -0
- mistralai_gcp/utils/url.py +150 -0
- mistralai_gcp/utils/values.py +128 -0
- py.typed +1 -0
- mistralai/client_base.py +0 -211
- mistralai/constants.py +0 -5
- mistralai/exceptions.py +0 -54
- mistralai/jobs.py +0 -172
- mistralai/models/chat_completion.py +0 -93
- mistralai/models/common.py +0 -9
- mistralai/models/embeddings.py +0 -19
- mistralai/models/files.py +0 -23
- mistralai/models/jobs.py +0 -100
- mistralai/models/models.py +0 -39
- mistralai-0.4.2.dist-info/METADATA +0 -82
- mistralai-0.4.2.dist-info/RECORD +0 -20
- {mistralai-0.4.2.dist-info → mistralai-0.5.5a50.dist-info}/WHEEL +0 -0
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from .annotations import get_discriminator
|
|
4
|
+
from .enums import OpenEnumMeta
|
|
5
|
+
from .headers import get_headers, get_response_headers
|
|
6
|
+
from .metadata import (
|
|
7
|
+
FieldMetadata,
|
|
8
|
+
find_metadata,
|
|
9
|
+
FormMetadata,
|
|
10
|
+
HeaderMetadata,
|
|
11
|
+
MultipartFormMetadata,
|
|
12
|
+
PathParamMetadata,
|
|
13
|
+
QueryParamMetadata,
|
|
14
|
+
RequestMetadata,
|
|
15
|
+
SecurityMetadata,
|
|
16
|
+
)
|
|
17
|
+
from .queryparams import get_query_params
|
|
18
|
+
from .retries import BackoffStrategy, Retries, retry, retry_async, RetryConfig
|
|
19
|
+
from .requestbodies import serialize_request_body, SerializedRequestBody
|
|
20
|
+
from .security import get_security
|
|
21
|
+
from .serializers import (
|
|
22
|
+
get_pydantic_model,
|
|
23
|
+
marshal_json,
|
|
24
|
+
unmarshal,
|
|
25
|
+
unmarshal_json,
|
|
26
|
+
serialize_decimal,
|
|
27
|
+
serialize_float,
|
|
28
|
+
serialize_int,
|
|
29
|
+
stream_to_text,
|
|
30
|
+
validate_decimal,
|
|
31
|
+
validate_float,
|
|
32
|
+
validate_int,
|
|
33
|
+
validate_open_enum,
|
|
34
|
+
)
|
|
35
|
+
from .url import generate_url, template_url, remove_suffix
|
|
36
|
+
from .values import get_global_from_env, match_content_type, match_status_codes, match_response
|
|
37
|
+
|
|
38
|
+
__all__ = [
|
|
39
|
+
"BackoffStrategy",
|
|
40
|
+
"FieldMetadata",
|
|
41
|
+
"find_metadata",
|
|
42
|
+
"FormMetadata",
|
|
43
|
+
"generate_url",
|
|
44
|
+
"get_discriminator",
|
|
45
|
+
"get_global_from_env",
|
|
46
|
+
"get_headers",
|
|
47
|
+
"get_pydantic_model",
|
|
48
|
+
"get_query_params",
|
|
49
|
+
"get_response_headers",
|
|
50
|
+
"get_security",
|
|
51
|
+
"HeaderMetadata",
|
|
52
|
+
"marshal_json",
|
|
53
|
+
"match_content_type",
|
|
54
|
+
"match_status_codes",
|
|
55
|
+
"match_response",
|
|
56
|
+
"MultipartFormMetadata",
|
|
57
|
+
"OpenEnumMeta",
|
|
58
|
+
"PathParamMetadata",
|
|
59
|
+
"QueryParamMetadata",
|
|
60
|
+
"remove_suffix",
|
|
61
|
+
"Retries",
|
|
62
|
+
"retry",
|
|
63
|
+
"retry_async",
|
|
64
|
+
"RetryConfig",
|
|
65
|
+
"RequestMetadata",
|
|
66
|
+
"SecurityMetadata",
|
|
67
|
+
"serialize_decimal",
|
|
68
|
+
"serialize_float",
|
|
69
|
+
"serialize_int",
|
|
70
|
+
"serialize_request_body",
|
|
71
|
+
"SerializedRequestBody",
|
|
72
|
+
"stream_to_text",
|
|
73
|
+
"template_url",
|
|
74
|
+
"unmarshal",
|
|
75
|
+
"unmarshal_json",
|
|
76
|
+
"validate_decimal",
|
|
77
|
+
"validate_float",
|
|
78
|
+
"validate_int",
|
|
79
|
+
"validate_open_enum",
|
|
80
|
+
]
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from typing import Any
|
|
4
|
+
|
|
5
|
+
def get_discriminator(model: Any, fieldname: str, key: str) -> str:
|
|
6
|
+
if isinstance(model, dict):
|
|
7
|
+
try:
|
|
8
|
+
return f'{model.get(key)}'
|
|
9
|
+
except AttributeError as e:
|
|
10
|
+
raise ValueError(f'Could not find discriminator key {key} in {model}') from e
|
|
11
|
+
|
|
12
|
+
if hasattr(model, fieldname):
|
|
13
|
+
return f'{getattr(model, fieldname)}'
|
|
14
|
+
|
|
15
|
+
fieldname = fieldname.upper()
|
|
16
|
+
if hasattr(model, fieldname):
|
|
17
|
+
return f'{getattr(model, fieldname)}'
|
|
18
|
+
|
|
19
|
+
raise ValueError(f'Could not find discriminator field {fieldname} in {model}')
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
import enum
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class OpenEnumMeta(enum.EnumMeta):
|
|
7
|
+
def __call__(
|
|
8
|
+
cls, value, names=None, *, module=None, qualname=None, type=None, start=1
|
|
9
|
+
):
|
|
10
|
+
# The `type` kwarg also happens to be a built-in that pylint flags as
|
|
11
|
+
# redeclared. Safe to ignore this lint rule with this scope.
|
|
12
|
+
# pylint: disable=redefined-builtin
|
|
13
|
+
|
|
14
|
+
if names is not None:
|
|
15
|
+
return super().__call__(
|
|
16
|
+
value,
|
|
17
|
+
names=names,
|
|
18
|
+
module=module,
|
|
19
|
+
qualname=qualname,
|
|
20
|
+
type=type,
|
|
21
|
+
start=start,
|
|
22
|
+
)
|
|
23
|
+
|
|
24
|
+
try:
|
|
25
|
+
return super().__call__(
|
|
26
|
+
value,
|
|
27
|
+
names=names, # pyright: ignore[reportArgumentType]
|
|
28
|
+
module=module,
|
|
29
|
+
qualname=qualname,
|
|
30
|
+
type=type,
|
|
31
|
+
start=start,
|
|
32
|
+
)
|
|
33
|
+
except ValueError:
|
|
34
|
+
return value
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
import re
|
|
4
|
+
import json
|
|
5
|
+
from typing import Callable, TypeVar, Optional, Generator, AsyncGenerator, Tuple
|
|
6
|
+
import httpx
|
|
7
|
+
|
|
8
|
+
T = TypeVar("T")
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
class ServerEvent:
|
|
12
|
+
id: Optional[str] = None
|
|
13
|
+
event: Optional[str] = None
|
|
14
|
+
data: Optional[str] = None
|
|
15
|
+
retry: Optional[int] = None
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
MESSAGE_BOUNDARIES = [
|
|
19
|
+
b"\r\n\r\n",
|
|
20
|
+
b"\n\n",
|
|
21
|
+
b"\r\r",
|
|
22
|
+
]
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
async def stream_events_async(
|
|
26
|
+
response: httpx.Response,
|
|
27
|
+
decoder: Callable[[str], T],
|
|
28
|
+
sentinel: Optional[str] = None,
|
|
29
|
+
) -> AsyncGenerator[T, None]:
|
|
30
|
+
buffer = bytearray()
|
|
31
|
+
position = 0
|
|
32
|
+
discard = False
|
|
33
|
+
async for chunk in response.aiter_bytes():
|
|
34
|
+
# We've encountered the sentinel value and should no longer process
|
|
35
|
+
# incoming data. Instead we throw new data away until the server closes
|
|
36
|
+
# the connection.
|
|
37
|
+
if discard:
|
|
38
|
+
continue
|
|
39
|
+
|
|
40
|
+
buffer += chunk
|
|
41
|
+
for i in range(position, len(buffer)):
|
|
42
|
+
char = buffer[i : i + 1]
|
|
43
|
+
seq: Optional[bytes] = None
|
|
44
|
+
if char in [b"\r", b"\n"]:
|
|
45
|
+
for boundary in MESSAGE_BOUNDARIES:
|
|
46
|
+
seq = _peek_sequence(i, buffer, boundary)
|
|
47
|
+
if seq is not None:
|
|
48
|
+
break
|
|
49
|
+
if seq is None:
|
|
50
|
+
continue
|
|
51
|
+
|
|
52
|
+
block = buffer[position:i]
|
|
53
|
+
position = i + len(seq)
|
|
54
|
+
event, discard = _parse_event(block, decoder, sentinel)
|
|
55
|
+
if event is not None:
|
|
56
|
+
yield event
|
|
57
|
+
|
|
58
|
+
if position > 0:
|
|
59
|
+
buffer = buffer[position:]
|
|
60
|
+
position = 0
|
|
61
|
+
|
|
62
|
+
event, discard = _parse_event(buffer, decoder, sentinel)
|
|
63
|
+
if event is not None:
|
|
64
|
+
yield event
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
def stream_events(
|
|
68
|
+
response: httpx.Response,
|
|
69
|
+
decoder: Callable[[str], T],
|
|
70
|
+
sentinel: Optional[str] = None,
|
|
71
|
+
) -> Generator[T, None, None]:
|
|
72
|
+
buffer = bytearray()
|
|
73
|
+
position = 0
|
|
74
|
+
discard = False
|
|
75
|
+
for chunk in response.iter_bytes():
|
|
76
|
+
# We've encountered the sentinel value and should no longer process
|
|
77
|
+
# incoming data. Instead we throw new data away until the server closes
|
|
78
|
+
# the connection.
|
|
79
|
+
if discard:
|
|
80
|
+
continue
|
|
81
|
+
|
|
82
|
+
buffer += chunk
|
|
83
|
+
for i in range(position, len(buffer)):
|
|
84
|
+
char = buffer[i : i + 1]
|
|
85
|
+
seq: Optional[bytes] = None
|
|
86
|
+
if char in [b"\r", b"\n"]:
|
|
87
|
+
for boundary in MESSAGE_BOUNDARIES:
|
|
88
|
+
seq = _peek_sequence(i, buffer, boundary)
|
|
89
|
+
if seq is not None:
|
|
90
|
+
break
|
|
91
|
+
if seq is None:
|
|
92
|
+
continue
|
|
93
|
+
|
|
94
|
+
block = buffer[position:i]
|
|
95
|
+
position = i + len(seq)
|
|
96
|
+
event, discard = _parse_event(block, decoder, sentinel)
|
|
97
|
+
if event is not None:
|
|
98
|
+
yield event
|
|
99
|
+
|
|
100
|
+
if position > 0:
|
|
101
|
+
buffer = buffer[position:]
|
|
102
|
+
position = 0
|
|
103
|
+
|
|
104
|
+
event, discard = _parse_event(buffer, decoder, sentinel)
|
|
105
|
+
if event is not None:
|
|
106
|
+
yield event
|
|
107
|
+
|
|
108
|
+
|
|
109
|
+
def _parse_event(
|
|
110
|
+
raw: bytearray, decoder: Callable[[str], T], sentinel: Optional[str] = None
|
|
111
|
+
) -> Tuple[Optional[T], bool]:
|
|
112
|
+
block = raw.decode()
|
|
113
|
+
lines = re.split(r"\r?\n|\r", block)
|
|
114
|
+
publish = False
|
|
115
|
+
event = ServerEvent()
|
|
116
|
+
data = ""
|
|
117
|
+
for line in lines:
|
|
118
|
+
if not line:
|
|
119
|
+
continue
|
|
120
|
+
|
|
121
|
+
delim = line.find(":")
|
|
122
|
+
if delim <= 0:
|
|
123
|
+
continue
|
|
124
|
+
|
|
125
|
+
field = line[0:delim]
|
|
126
|
+
value = line[delim + 1 :] if delim < len(line) - 1 else ""
|
|
127
|
+
if len(value) and value[0] == " ":
|
|
128
|
+
value = value[1:]
|
|
129
|
+
|
|
130
|
+
if field == "event":
|
|
131
|
+
event.event = value
|
|
132
|
+
publish = True
|
|
133
|
+
elif field == "data":
|
|
134
|
+
data += value + "\n"
|
|
135
|
+
publish = True
|
|
136
|
+
elif field == "id":
|
|
137
|
+
event.id = value
|
|
138
|
+
publish = True
|
|
139
|
+
elif field == "retry":
|
|
140
|
+
event.retry = int(value) if value.isdigit() else None
|
|
141
|
+
publish = True
|
|
142
|
+
|
|
143
|
+
if sentinel and data == f"{sentinel}\n":
|
|
144
|
+
return None, True
|
|
145
|
+
|
|
146
|
+
if data:
|
|
147
|
+
data = data[:-1]
|
|
148
|
+
event.data = data
|
|
149
|
+
|
|
150
|
+
if (
|
|
151
|
+
data.isnumeric()
|
|
152
|
+
or data == "true"
|
|
153
|
+
or data == "false"
|
|
154
|
+
or data == "null"
|
|
155
|
+
or data.startswith("{")
|
|
156
|
+
or data.startswith("[")
|
|
157
|
+
or data.startswith('"')
|
|
158
|
+
):
|
|
159
|
+
try:
|
|
160
|
+
event.data = json.loads(data)
|
|
161
|
+
except Exception:
|
|
162
|
+
pass
|
|
163
|
+
|
|
164
|
+
out = None
|
|
165
|
+
if publish:
|
|
166
|
+
out = decoder(json.dumps(event.__dict__))
|
|
167
|
+
|
|
168
|
+
return out, False
|
|
169
|
+
|
|
170
|
+
|
|
171
|
+
def _peek_sequence(position: int, buffer: bytearray, sequence: bytes):
|
|
172
|
+
if len(sequence) > (len(buffer) - position):
|
|
173
|
+
return None
|
|
174
|
+
|
|
175
|
+
for i, seq in enumerate(sequence):
|
|
176
|
+
if buffer[position + i] != seq:
|
|
177
|
+
return None
|
|
178
|
+
|
|
179
|
+
return sequence
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from typing import (
|
|
4
|
+
Any,
|
|
5
|
+
Dict,
|
|
6
|
+
get_type_hints,
|
|
7
|
+
List,
|
|
8
|
+
Tuple,
|
|
9
|
+
)
|
|
10
|
+
from pydantic import BaseModel
|
|
11
|
+
from pydantic.fields import FieldInfo
|
|
12
|
+
|
|
13
|
+
from .serializers import marshal_json
|
|
14
|
+
|
|
15
|
+
from .metadata import (
|
|
16
|
+
FormMetadata,
|
|
17
|
+
MultipartFormMetadata,
|
|
18
|
+
find_field_metadata,
|
|
19
|
+
)
|
|
20
|
+
from .values import _val_to_string
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
def _populate_form(
|
|
24
|
+
field_name: str,
|
|
25
|
+
explode: bool,
|
|
26
|
+
obj: Any,
|
|
27
|
+
delimiter: str,
|
|
28
|
+
form: Dict[str, List[str]],
|
|
29
|
+
):
|
|
30
|
+
if obj is None:
|
|
31
|
+
return form
|
|
32
|
+
|
|
33
|
+
if isinstance(obj, BaseModel):
|
|
34
|
+
items = []
|
|
35
|
+
|
|
36
|
+
obj_fields: Dict[str, FieldInfo] = obj.__class__.model_fields
|
|
37
|
+
for name in obj_fields:
|
|
38
|
+
obj_field = obj_fields[name]
|
|
39
|
+
obj_field_name = obj_field.alias if obj_field.alias is not None else name
|
|
40
|
+
if obj_field_name == "":
|
|
41
|
+
continue
|
|
42
|
+
|
|
43
|
+
val = getattr(obj, name)
|
|
44
|
+
if val is None:
|
|
45
|
+
continue
|
|
46
|
+
|
|
47
|
+
if explode:
|
|
48
|
+
form[obj_field_name] = [_val_to_string(val)]
|
|
49
|
+
else:
|
|
50
|
+
items.append(f"{obj_field_name}{delimiter}{_val_to_string(val)}")
|
|
51
|
+
|
|
52
|
+
if len(items) > 0:
|
|
53
|
+
form[field_name] = [delimiter.join(items)]
|
|
54
|
+
elif isinstance(obj, Dict):
|
|
55
|
+
items = []
|
|
56
|
+
for key, value in obj.items():
|
|
57
|
+
if value is None:
|
|
58
|
+
continue
|
|
59
|
+
|
|
60
|
+
if explode:
|
|
61
|
+
form[key] = [_val_to_string(value)]
|
|
62
|
+
else:
|
|
63
|
+
items.append(f"{key}{delimiter}{_val_to_string(value)}")
|
|
64
|
+
|
|
65
|
+
if len(items) > 0:
|
|
66
|
+
form[field_name] = [delimiter.join(items)]
|
|
67
|
+
elif isinstance(obj, List):
|
|
68
|
+
items = []
|
|
69
|
+
|
|
70
|
+
for value in obj:
|
|
71
|
+
if value is None:
|
|
72
|
+
continue
|
|
73
|
+
|
|
74
|
+
if explode:
|
|
75
|
+
if not field_name in form:
|
|
76
|
+
form[field_name] = []
|
|
77
|
+
form[field_name].append(_val_to_string(value))
|
|
78
|
+
else:
|
|
79
|
+
items.append(_val_to_string(value))
|
|
80
|
+
|
|
81
|
+
if len(items) > 0:
|
|
82
|
+
form[field_name] = [delimiter.join([str(item) for item in items])]
|
|
83
|
+
else:
|
|
84
|
+
form[field_name] = [_val_to_string(obj)]
|
|
85
|
+
|
|
86
|
+
return form
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
def serialize_multipart_form(
|
|
90
|
+
media_type: str, request: Any
|
|
91
|
+
) -> Tuple[str, Dict[str, Any], Dict[str, Any]]:
|
|
92
|
+
form: Dict[str, Any] = {}
|
|
93
|
+
files: Dict[str, Any] = {}
|
|
94
|
+
|
|
95
|
+
if not isinstance(request, BaseModel):
|
|
96
|
+
raise TypeError("invalid request body type")
|
|
97
|
+
|
|
98
|
+
request_fields: Dict[str, FieldInfo] = request.__class__.model_fields
|
|
99
|
+
request_field_types = get_type_hints(request.__class__)
|
|
100
|
+
|
|
101
|
+
for name in request_fields:
|
|
102
|
+
field = request_fields[name]
|
|
103
|
+
|
|
104
|
+
val = getattr(request, name)
|
|
105
|
+
if val is None:
|
|
106
|
+
continue
|
|
107
|
+
|
|
108
|
+
field_metadata = find_field_metadata(field, MultipartFormMetadata)
|
|
109
|
+
if not field_metadata:
|
|
110
|
+
continue
|
|
111
|
+
|
|
112
|
+
f_name = field.alias if field.alias is not None else name
|
|
113
|
+
|
|
114
|
+
if field_metadata.file:
|
|
115
|
+
file_fields: Dict[str, FieldInfo] = val.__class__.model_fields
|
|
116
|
+
|
|
117
|
+
file_name = ""
|
|
118
|
+
field_name = ""
|
|
119
|
+
content = None
|
|
120
|
+
content_type = None
|
|
121
|
+
|
|
122
|
+
for file_field_name in file_fields:
|
|
123
|
+
file_field = file_fields[file_field_name]
|
|
124
|
+
|
|
125
|
+
file_metadata = find_field_metadata(file_field, MultipartFormMetadata)
|
|
126
|
+
if file_metadata is None:
|
|
127
|
+
continue
|
|
128
|
+
|
|
129
|
+
if file_metadata.content:
|
|
130
|
+
content = getattr(val, file_field_name, None)
|
|
131
|
+
elif file_field_name == "content_type":
|
|
132
|
+
content_type = getattr(val, file_field_name, None)
|
|
133
|
+
else:
|
|
134
|
+
field_name = (
|
|
135
|
+
file_field.alias
|
|
136
|
+
if file_field.alias is not None
|
|
137
|
+
else file_field_name
|
|
138
|
+
)
|
|
139
|
+
file_name = getattr(val, file_field_name)
|
|
140
|
+
|
|
141
|
+
if field_name == "" or file_name == "" or content is None:
|
|
142
|
+
raise ValueError("invalid multipart/form-data file")
|
|
143
|
+
|
|
144
|
+
if content_type is not None:
|
|
145
|
+
files[field_name] = (file_name, content, content_type)
|
|
146
|
+
else:
|
|
147
|
+
files[field_name] = (file_name, content)
|
|
148
|
+
elif field_metadata.json:
|
|
149
|
+
files[f_name] = (
|
|
150
|
+
None,
|
|
151
|
+
marshal_json(val, request_field_types[name]),
|
|
152
|
+
"application/json",
|
|
153
|
+
)
|
|
154
|
+
else:
|
|
155
|
+
if isinstance(val, List):
|
|
156
|
+
values = []
|
|
157
|
+
|
|
158
|
+
for value in val:
|
|
159
|
+
if value is None:
|
|
160
|
+
continue
|
|
161
|
+
values.append(_val_to_string(value))
|
|
162
|
+
|
|
163
|
+
form[f_name + "[]"] = values
|
|
164
|
+
else:
|
|
165
|
+
form[f_name] = _val_to_string(val)
|
|
166
|
+
return media_type, form, files
|
|
167
|
+
|
|
168
|
+
|
|
169
|
+
def serialize_form_data(data: Any) -> Dict[str, Any]:
|
|
170
|
+
form: Dict[str, List[str]] = {}
|
|
171
|
+
|
|
172
|
+
if isinstance(data, BaseModel):
|
|
173
|
+
data_fields: Dict[str, FieldInfo] = data.__class__.model_fields
|
|
174
|
+
data_field_types = get_type_hints(data.__class__)
|
|
175
|
+
for name in data_fields:
|
|
176
|
+
field = data_fields[name]
|
|
177
|
+
|
|
178
|
+
val = getattr(data, name)
|
|
179
|
+
if val is None:
|
|
180
|
+
continue
|
|
181
|
+
|
|
182
|
+
metadata = find_field_metadata(field, FormMetadata)
|
|
183
|
+
if metadata is None:
|
|
184
|
+
continue
|
|
185
|
+
|
|
186
|
+
f_name = field.alias if field.alias is not None else name
|
|
187
|
+
|
|
188
|
+
if metadata.json:
|
|
189
|
+
form[f_name] = [marshal_json(val, data_field_types[name])]
|
|
190
|
+
else:
|
|
191
|
+
if metadata.style == "form":
|
|
192
|
+
_populate_form(
|
|
193
|
+
f_name,
|
|
194
|
+
metadata.explode,
|
|
195
|
+
val,
|
|
196
|
+
",",
|
|
197
|
+
form,
|
|
198
|
+
)
|
|
199
|
+
else:
|
|
200
|
+
raise ValueError(f"Invalid form style for field {name}")
|
|
201
|
+
elif isinstance(data, Dict):
|
|
202
|
+
for key, value in data.items():
|
|
203
|
+
form[key] = [_val_to_string(value)]
|
|
204
|
+
else:
|
|
205
|
+
raise TypeError(f"Invalid request body type {type(data)} for form data")
|
|
206
|
+
|
|
207
|
+
return form
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from typing import (
|
|
4
|
+
Any,
|
|
5
|
+
Dict,
|
|
6
|
+
List,
|
|
7
|
+
Optional,
|
|
8
|
+
)
|
|
9
|
+
from httpx import Headers
|
|
10
|
+
from pydantic import BaseModel
|
|
11
|
+
from pydantic.fields import FieldInfo
|
|
12
|
+
|
|
13
|
+
from .metadata import (
|
|
14
|
+
HeaderMetadata,
|
|
15
|
+
find_field_metadata,
|
|
16
|
+
)
|
|
17
|
+
|
|
18
|
+
from .values import _populate_from_globals, _val_to_string
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
def get_headers(headers_params: Any, gbls: Optional[Any] = None) -> Dict[str, str]:
|
|
22
|
+
headers: Dict[str, str] = {}
|
|
23
|
+
|
|
24
|
+
globals_already_populated = []
|
|
25
|
+
if headers_params is not None:
|
|
26
|
+
globals_already_populated = _populate_headers(headers_params, gbls, headers, [])
|
|
27
|
+
if gbls is not None:
|
|
28
|
+
_populate_headers(gbls, None, headers, globals_already_populated)
|
|
29
|
+
|
|
30
|
+
return headers
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
def _populate_headers(
|
|
34
|
+
headers_params: Any,
|
|
35
|
+
gbls: Any,
|
|
36
|
+
header_values: Dict[str, str],
|
|
37
|
+
skip_fields: List[str],
|
|
38
|
+
) -> List[str]:
|
|
39
|
+
globals_already_populated: List[str] = []
|
|
40
|
+
|
|
41
|
+
if not isinstance(headers_params, BaseModel):
|
|
42
|
+
return globals_already_populated
|
|
43
|
+
|
|
44
|
+
param_fields: Dict[str, FieldInfo] = headers_params.__class__.model_fields
|
|
45
|
+
for name in param_fields:
|
|
46
|
+
if name in skip_fields:
|
|
47
|
+
continue
|
|
48
|
+
|
|
49
|
+
field = param_fields[name]
|
|
50
|
+
f_name = field.alias if field.alias is not None else name
|
|
51
|
+
|
|
52
|
+
metadata = find_field_metadata(field, HeaderMetadata)
|
|
53
|
+
if metadata is None:
|
|
54
|
+
continue
|
|
55
|
+
|
|
56
|
+
value, global_found = _populate_from_globals(
|
|
57
|
+
name, getattr(headers_params, name), HeaderMetadata, gbls
|
|
58
|
+
)
|
|
59
|
+
if global_found:
|
|
60
|
+
globals_already_populated.append(name)
|
|
61
|
+
value = _serialize_header(metadata.explode, value)
|
|
62
|
+
|
|
63
|
+
if value != "":
|
|
64
|
+
header_values[f_name] = value
|
|
65
|
+
|
|
66
|
+
return globals_already_populated
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
def _serialize_header(explode: bool, obj: Any) -> str:
|
|
70
|
+
if obj is None:
|
|
71
|
+
return ""
|
|
72
|
+
|
|
73
|
+
if isinstance(obj, BaseModel):
|
|
74
|
+
items = []
|
|
75
|
+
obj_fields: Dict[str, FieldInfo] = obj.__class__.model_fields
|
|
76
|
+
for name in obj_fields:
|
|
77
|
+
obj_field = obj_fields[name]
|
|
78
|
+
obj_param_metadata = find_field_metadata(obj_field, HeaderMetadata)
|
|
79
|
+
|
|
80
|
+
if not obj_param_metadata:
|
|
81
|
+
continue
|
|
82
|
+
|
|
83
|
+
f_name = obj_field.alias if obj_field.alias is not None else name
|
|
84
|
+
|
|
85
|
+
val = getattr(obj, name)
|
|
86
|
+
if val is None:
|
|
87
|
+
continue
|
|
88
|
+
|
|
89
|
+
if explode:
|
|
90
|
+
items.append(f"{f_name}={_val_to_string(val)}")
|
|
91
|
+
else:
|
|
92
|
+
items.append(f_name)
|
|
93
|
+
items.append(_val_to_string(val))
|
|
94
|
+
|
|
95
|
+
if len(items) > 0:
|
|
96
|
+
return ",".join(items)
|
|
97
|
+
elif isinstance(obj, Dict):
|
|
98
|
+
items = []
|
|
99
|
+
|
|
100
|
+
for key, value in obj.items():
|
|
101
|
+
if value is None:
|
|
102
|
+
continue
|
|
103
|
+
|
|
104
|
+
if explode:
|
|
105
|
+
items.append(f"{key}={_val_to_string(value)}")
|
|
106
|
+
else:
|
|
107
|
+
items.append(key)
|
|
108
|
+
items.append(_val_to_string(value))
|
|
109
|
+
|
|
110
|
+
if len(items) > 0:
|
|
111
|
+
return ",".join([str(item) for item in items])
|
|
112
|
+
elif isinstance(obj, List):
|
|
113
|
+
items = []
|
|
114
|
+
|
|
115
|
+
for value in obj:
|
|
116
|
+
if value is None:
|
|
117
|
+
continue
|
|
118
|
+
|
|
119
|
+
items.append(_val_to_string(value))
|
|
120
|
+
|
|
121
|
+
if len(items) > 0:
|
|
122
|
+
return ",".join(items)
|
|
123
|
+
else:
|
|
124
|
+
return f"{_val_to_string(obj)}"
|
|
125
|
+
|
|
126
|
+
return ""
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
def get_response_headers(headers: Headers) -> Dict[str, List[str]]:
|
|
130
|
+
res: Dict[str, List[str]] = {}
|
|
131
|
+
for k, v in headers.items():
|
|
132
|
+
if not k in res:
|
|
133
|
+
res[k] = []
|
|
134
|
+
|
|
135
|
+
res[k].append(v)
|
|
136
|
+
return res
|