File size: 2,316 Bytes
a4b70d9
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
from __future__ import annotations

import os
from typing import (
    Any,
    AsyncGenerator,
    Generator,
    AsyncIterator,
    Iterator,
    NewType,
    Tuple,
    Union,
    List,
    Dict,
    Type,
    IO,
    Optional,
    TYPE_CHECKING,
)
from typing_extensions import TypedDict

# Only import PIL for type-checkers; no runtime dependency required.
if TYPE_CHECKING:
    from PIL.Image import Image as PILImage
else:
    class PILImage:  # minimal placeholder to avoid runtime import errors
        pass

# Response chunk type from providers
from .providers.response import ResponseType

# ---- Hashes & cookie aliases -------------------------------------------------

SHA256 = NewType("SHA256", str)
Cookies = Dict[str, str]

# ---- Streaming result types --------------------------------------------------

CreateResult = Iterator[Union[str, ResponseType]]
AsyncResult = AsyncIterator[Union[str, ResponseType]]

# ---- Message schema ----------------------------------------------------------
# Typical message structure:
#   {"role": "user" | "assistant" | "system" | "tool", "content": str | [ContentPart, ...]}
# where content parts can be text or (optionally) structured pieces like images.

class ContentPart(TypedDict, total=False):
    type: str           # e.g., "text", "image_url", etc.
    text: str           # present when type == "text"
    image_url: Dict[str, str]  # present when type == "image_url"
    input_audio: Dict[str, str]  # present when type == "input_audio"
    bucket_id: str
    name: str

class Message(TypedDict):
    role: str
    content: Union[str, List[ContentPart]]

Messages = List[Message]

# ---- Media inputs ------------------------------------------------------------

# Paths, raw bytes, file-like objects, or PIL Image objects are accepted.
ImageType = Union[str, bytes, IO[bytes], PILImage, os.PathLike]
MediaListType = List[Tuple[ImageType, Optional[str]]]

__all__ = [
    "Any",
    "AsyncGenerator",
    "Generator",
    "AsyncIterator",
    "Iterator",
    "Tuple",
    "Union",
    "List",
    "Dict",
    "Type",
    "IO",
    "Optional",
    "TypedDict",
    "SHA256",
    "CreateResult",
    "AsyncResult",
    "Messages",
    "Message",
    "ContentPart",
    "Cookies",
    "Image",
    "ImageType",
    "MediaListType",
    "ResponseType",
]