google-genai 1.38.0__py3-none-any.whl → 1.39.1__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.
- google/genai/_api_client.py +29 -0
- google/genai/_common.py +25 -10
- google/genai/_live_converters.py +2074 -1924
- google/genai/_operations_converters.py +108 -117
- google/genai/_replay_api_client.py +8 -4
- google/genai/_tokens_converters.py +465 -458
- google/genai/_transformers.py +44 -26
- google/genai/batches.py +1101 -1138
- google/genai/caches.py +747 -771
- google/genai/client.py +87 -0
- google/genai/files.py +110 -123
- google/genai/local_tokenizer.py +7 -2
- google/genai/models.py +2716 -2814
- google/genai/operations.py +10 -22
- google/genai/tunings.py +358 -391
- google/genai/types.py +192 -4
- google/genai/version.py +1 -1
- {google_genai-1.38.0.dist-info → google_genai-1.39.1.dist-info}/METADATA +82 -1
- google_genai-1.39.1.dist-info/RECORD +39 -0
- google_genai-1.38.0.dist-info/RECORD +0 -39
- {google_genai-1.38.0.dist-info → google_genai-1.39.1.dist-info}/WHEEL +0 -0
- {google_genai-1.38.0.dist-info → google_genai-1.39.1.dist-info}/licenses/LICENSE +0 -0
- {google_genai-1.38.0.dist-info → google_genai-1.39.1.dist-info}/top_level.txt +0 -0
@@ -38,24 +38,6 @@ def _FetchPredictOperationParameters_to_mldev(
|
|
38
38
|
return to_object
|
39
39
|
|
40
40
|
|
41
|
-
def _GetOperationParameters_to_mldev(
|
42
|
-
from_object: Union[dict[str, Any], object],
|
43
|
-
parent_object: Optional[dict[str, Any]] = None,
|
44
|
-
) -> dict[str, Any]:
|
45
|
-
to_object: dict[str, Any] = {}
|
46
|
-
if getv(from_object, ['operation_name']) is not None:
|
47
|
-
setv(
|
48
|
-
to_object,
|
49
|
-
['_url', 'operationName'],
|
50
|
-
getv(from_object, ['operation_name']),
|
51
|
-
)
|
52
|
-
|
53
|
-
if getv(from_object, ['config']) is not None:
|
54
|
-
setv(to_object, ['config'], getv(from_object, ['config']))
|
55
|
-
|
56
|
-
return to_object
|
57
|
-
|
58
|
-
|
59
41
|
def _FetchPredictOperationParameters_to_vertex(
|
60
42
|
from_object: Union[dict[str, Any], object],
|
61
43
|
parent_object: Optional[dict[str, Any]] = None,
|
@@ -71,61 +53,80 @@ def _FetchPredictOperationParameters_to_vertex(
|
|
71
53
|
getv(from_object, ['resource_name']),
|
72
54
|
)
|
73
55
|
|
74
|
-
if getv(from_object, ['config']) is not None:
|
75
|
-
setv(to_object, ['config'], getv(from_object, ['config']))
|
76
|
-
|
77
56
|
return to_object
|
78
57
|
|
79
58
|
|
80
|
-
def
|
59
|
+
def _GenerateVideosOperation_from_mldev(
|
81
60
|
from_object: Union[dict[str, Any], object],
|
82
61
|
parent_object: Optional[dict[str, Any]] = None,
|
83
62
|
) -> dict[str, Any]:
|
84
63
|
to_object: dict[str, Any] = {}
|
85
|
-
if getv(from_object, ['
|
64
|
+
if getv(from_object, ['name']) is not None:
|
65
|
+
setv(to_object, ['name'], getv(from_object, ['name']))
|
66
|
+
|
67
|
+
if getv(from_object, ['metadata']) is not None:
|
68
|
+
setv(to_object, ['metadata'], getv(from_object, ['metadata']))
|
69
|
+
|
70
|
+
if getv(from_object, ['done']) is not None:
|
71
|
+
setv(to_object, ['done'], getv(from_object, ['done']))
|
72
|
+
|
73
|
+
if getv(from_object, ['error']) is not None:
|
74
|
+
setv(to_object, ['error'], getv(from_object, ['error']))
|
75
|
+
|
76
|
+
if getv(from_object, ['response', 'generateVideoResponse']) is not None:
|
86
77
|
setv(
|
87
78
|
to_object,
|
88
|
-
['
|
89
|
-
|
79
|
+
['response'],
|
80
|
+
_GenerateVideosResponse_from_mldev(
|
81
|
+
getv(from_object, ['response', 'generateVideoResponse']), to_object
|
82
|
+
),
|
90
83
|
)
|
91
84
|
|
92
|
-
if getv(from_object, ['
|
93
|
-
setv(
|
85
|
+
if getv(from_object, ['response', 'generateVideoResponse']) is not None:
|
86
|
+
setv(
|
87
|
+
to_object,
|
88
|
+
['result'],
|
89
|
+
_GenerateVideosResponse_from_mldev(
|
90
|
+
getv(from_object, ['response', 'generateVideoResponse']), to_object
|
91
|
+
),
|
92
|
+
)
|
94
93
|
|
95
94
|
return to_object
|
96
95
|
|
97
96
|
|
98
|
-
def
|
97
|
+
def _GenerateVideosOperation_from_vertex(
|
99
98
|
from_object: Union[dict[str, Any], object],
|
100
99
|
parent_object: Optional[dict[str, Any]] = None,
|
101
100
|
) -> dict[str, Any]:
|
102
101
|
to_object: dict[str, Any] = {}
|
103
|
-
if getv(from_object, ['
|
104
|
-
setv(to_object, ['
|
102
|
+
if getv(from_object, ['name']) is not None:
|
103
|
+
setv(to_object, ['name'], getv(from_object, ['name']))
|
105
104
|
|
106
|
-
if getv(from_object, ['
|
107
|
-
setv(
|
108
|
-
to_object,
|
109
|
-
['video_bytes'],
|
110
|
-
base_t.t_bytes(getv(from_object, ['video', 'encodedVideo'])),
|
111
|
-
)
|
105
|
+
if getv(from_object, ['metadata']) is not None:
|
106
|
+
setv(to_object, ['metadata'], getv(from_object, ['metadata']))
|
112
107
|
|
113
|
-
if getv(from_object, ['
|
114
|
-
setv(to_object, ['
|
108
|
+
if getv(from_object, ['done']) is not None:
|
109
|
+
setv(to_object, ['done'], getv(from_object, ['done']))
|
115
110
|
|
116
|
-
|
111
|
+
if getv(from_object, ['error']) is not None:
|
112
|
+
setv(to_object, ['error'], getv(from_object, ['error']))
|
117
113
|
|
114
|
+
if getv(from_object, ['response']) is not None:
|
115
|
+
setv(
|
116
|
+
to_object,
|
117
|
+
['response'],
|
118
|
+
_GenerateVideosResponse_from_vertex(
|
119
|
+
getv(from_object, ['response']), to_object
|
120
|
+
),
|
121
|
+
)
|
118
122
|
|
119
|
-
|
120
|
-
from_object: Union[dict[str, Any], object],
|
121
|
-
parent_object: Optional[dict[str, Any]] = None,
|
122
|
-
) -> dict[str, Any]:
|
123
|
-
to_object: dict[str, Any] = {}
|
124
|
-
if getv(from_object, ['_self']) is not None:
|
123
|
+
if getv(from_object, ['response']) is not None:
|
125
124
|
setv(
|
126
125
|
to_object,
|
127
|
-
['
|
128
|
-
|
126
|
+
['result'],
|
127
|
+
_GenerateVideosResponse_from_vertex(
|
128
|
+
getv(from_object, ['response']), to_object
|
129
|
+
),
|
129
130
|
)
|
130
131
|
|
131
132
|
return to_object
|
@@ -163,62 +164,50 @@ def _GenerateVideosResponse_from_mldev(
|
|
163
164
|
return to_object
|
164
165
|
|
165
166
|
|
166
|
-
def
|
167
|
+
def _GenerateVideosResponse_from_vertex(
|
167
168
|
from_object: Union[dict[str, Any], object],
|
168
169
|
parent_object: Optional[dict[str, Any]] = None,
|
169
170
|
) -> dict[str, Any]:
|
170
171
|
to_object: dict[str, Any] = {}
|
171
|
-
if getv(from_object, ['
|
172
|
-
setv(
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
if getv(from_object, ['error']) is not None:
|
181
|
-
setv(to_object, ['error'], getv(from_object, ['error']))
|
172
|
+
if getv(from_object, ['videos']) is not None:
|
173
|
+
setv(
|
174
|
+
to_object,
|
175
|
+
['generated_videos'],
|
176
|
+
[
|
177
|
+
_GeneratedVideo_from_vertex(item, to_object)
|
178
|
+
for item in getv(from_object, ['videos'])
|
179
|
+
],
|
180
|
+
)
|
182
181
|
|
183
|
-
if getv(from_object, ['
|
182
|
+
if getv(from_object, ['raiMediaFilteredCount']) is not None:
|
184
183
|
setv(
|
185
184
|
to_object,
|
186
|
-
['
|
187
|
-
|
188
|
-
getv(from_object, ['response', 'generateVideoResponse']), to_object
|
189
|
-
),
|
185
|
+
['rai_media_filtered_count'],
|
186
|
+
getv(from_object, ['raiMediaFilteredCount']),
|
190
187
|
)
|
191
188
|
|
192
|
-
if getv(from_object, ['
|
189
|
+
if getv(from_object, ['raiMediaFilteredReasons']) is not None:
|
193
190
|
setv(
|
194
191
|
to_object,
|
195
|
-
['
|
196
|
-
|
197
|
-
getv(from_object, ['response', 'generateVideoResponse']), to_object
|
198
|
-
),
|
192
|
+
['rai_media_filtered_reasons'],
|
193
|
+
getv(from_object, ['raiMediaFilteredReasons']),
|
199
194
|
)
|
200
195
|
|
201
196
|
return to_object
|
202
197
|
|
203
198
|
|
204
|
-
def
|
199
|
+
def _GeneratedVideo_from_mldev(
|
205
200
|
from_object: Union[dict[str, Any], object],
|
206
201
|
parent_object: Optional[dict[str, Any]] = None,
|
207
202
|
) -> dict[str, Any]:
|
208
203
|
to_object: dict[str, Any] = {}
|
209
|
-
if getv(from_object, ['
|
210
|
-
setv(to_object, ['uri'], getv(from_object, ['gcsUri']))
|
211
|
-
|
212
|
-
if getv(from_object, ['bytesBase64Encoded']) is not None:
|
204
|
+
if getv(from_object, ['_self']) is not None:
|
213
205
|
setv(
|
214
206
|
to_object,
|
215
|
-
['
|
216
|
-
|
207
|
+
['video'],
|
208
|
+
_Video_from_mldev(getv(from_object, ['_self']), to_object),
|
217
209
|
)
|
218
210
|
|
219
|
-
if getv(from_object, ['mimeType']) is not None:
|
220
|
-
setv(to_object, ['mime_type'], getv(from_object, ['mimeType']))
|
221
|
-
|
222
211
|
return to_object
|
223
212
|
|
224
213
|
|
@@ -237,71 +226,73 @@ def _GeneratedVideo_from_vertex(
|
|
237
226
|
return to_object
|
238
227
|
|
239
228
|
|
240
|
-
def
|
229
|
+
def _GetOperationParameters_to_mldev(
|
241
230
|
from_object: Union[dict[str, Any], object],
|
242
231
|
parent_object: Optional[dict[str, Any]] = None,
|
243
232
|
) -> dict[str, Any]:
|
244
233
|
to_object: dict[str, Any] = {}
|
245
|
-
if getv(from_object, ['
|
234
|
+
if getv(from_object, ['operation_name']) is not None:
|
246
235
|
setv(
|
247
236
|
to_object,
|
248
|
-
['
|
249
|
-
[
|
250
|
-
_GeneratedVideo_from_vertex(item, to_object)
|
251
|
-
for item in getv(from_object, ['videos'])
|
252
|
-
],
|
237
|
+
['_url', 'operationName'],
|
238
|
+
getv(from_object, ['operation_name']),
|
253
239
|
)
|
254
240
|
|
255
|
-
|
256
|
-
setv(
|
257
|
-
to_object,
|
258
|
-
['rai_media_filtered_count'],
|
259
|
-
getv(from_object, ['raiMediaFilteredCount']),
|
260
|
-
)
|
241
|
+
return to_object
|
261
242
|
|
262
|
-
|
243
|
+
|
244
|
+
def _GetOperationParameters_to_vertex(
|
245
|
+
from_object: Union[dict[str, Any], object],
|
246
|
+
parent_object: Optional[dict[str, Any]] = None,
|
247
|
+
) -> dict[str, Any]:
|
248
|
+
to_object: dict[str, Any] = {}
|
249
|
+
if getv(from_object, ['operation_name']) is not None:
|
263
250
|
setv(
|
264
251
|
to_object,
|
265
|
-
['
|
266
|
-
getv(from_object, ['
|
252
|
+
['_url', 'operationName'],
|
253
|
+
getv(from_object, ['operation_name']),
|
267
254
|
)
|
268
255
|
|
269
256
|
return to_object
|
270
257
|
|
271
258
|
|
272
|
-
def
|
259
|
+
def _Video_from_mldev(
|
273
260
|
from_object: Union[dict[str, Any], object],
|
274
261
|
parent_object: Optional[dict[str, Any]] = None,
|
275
262
|
) -> dict[str, Any]:
|
276
263
|
to_object: dict[str, Any] = {}
|
277
|
-
if getv(from_object, ['
|
278
|
-
setv(to_object, ['
|
279
|
-
|
280
|
-
if getv(from_object, ['metadata']) is not None:
|
281
|
-
setv(to_object, ['metadata'], getv(from_object, ['metadata']))
|
282
|
-
|
283
|
-
if getv(from_object, ['done']) is not None:
|
284
|
-
setv(to_object, ['done'], getv(from_object, ['done']))
|
285
|
-
|
286
|
-
if getv(from_object, ['error']) is not None:
|
287
|
-
setv(to_object, ['error'], getv(from_object, ['error']))
|
264
|
+
if getv(from_object, ['video', 'uri']) is not None:
|
265
|
+
setv(to_object, ['uri'], getv(from_object, ['video', 'uri']))
|
288
266
|
|
289
|
-
if getv(from_object, ['
|
267
|
+
if getv(from_object, ['video', 'encodedVideo']) is not None:
|
290
268
|
setv(
|
291
269
|
to_object,
|
292
|
-
['
|
293
|
-
|
294
|
-
getv(from_object, ['response']), to_object
|
295
|
-
),
|
270
|
+
['video_bytes'],
|
271
|
+
base_t.t_bytes(getv(from_object, ['video', 'encodedVideo'])),
|
296
272
|
)
|
297
273
|
|
298
|
-
if getv(from_object, ['
|
274
|
+
if getv(from_object, ['encoding']) is not None:
|
275
|
+
setv(to_object, ['mime_type'], getv(from_object, ['encoding']))
|
276
|
+
|
277
|
+
return to_object
|
278
|
+
|
279
|
+
|
280
|
+
def _Video_from_vertex(
|
281
|
+
from_object: Union[dict[str, Any], object],
|
282
|
+
parent_object: Optional[dict[str, Any]] = None,
|
283
|
+
) -> dict[str, Any]:
|
284
|
+
to_object: dict[str, Any] = {}
|
285
|
+
if getv(from_object, ['gcsUri']) is not None:
|
286
|
+
setv(to_object, ['uri'], getv(from_object, ['gcsUri']))
|
287
|
+
|
288
|
+
if getv(from_object, ['bytesBase64Encoded']) is not None:
|
299
289
|
setv(
|
300
290
|
to_object,
|
301
|
-
['
|
302
|
-
|
303
|
-
getv(from_object, ['response']), to_object
|
304
|
-
),
|
291
|
+
['video_bytes'],
|
292
|
+
base_t.t_bytes(getv(from_object, ['bytesBase64Encoded'])),
|
305
293
|
)
|
306
294
|
|
295
|
+
if getv(from_object, ['mimeType']) is not None:
|
296
|
+
setv(to_object, ['mime_type'], getv(from_object, ['mimeType']))
|
297
|
+
|
307
298
|
return to_object
|
@@ -255,6 +255,7 @@ class ReplayApiClient(BaseApiClient):
|
|
255
255
|
project: Optional[str] = None,
|
256
256
|
location: Optional[str] = None,
|
257
257
|
http_options: Optional[HttpOptions] = None,
|
258
|
+
private: bool = False,
|
258
259
|
):
|
259
260
|
super().__init__(
|
260
261
|
vertexai=vertexai,
|
@@ -273,6 +274,7 @@ class ReplayApiClient(BaseApiClient):
|
|
273
274
|
self.replay_session: Union[ReplayFile, None] = None
|
274
275
|
self._mode = mode
|
275
276
|
self._replay_id = replay_id
|
277
|
+
self._private = private
|
276
278
|
|
277
279
|
def initialize_replay_session(self, replay_id: str) -> None:
|
278
280
|
self._replay_id = replay_id
|
@@ -484,10 +486,12 @@ class ReplayApiClient(BaseApiClient):
|
|
484
486
|
raw_body = json.loads(raw_body)
|
485
487
|
raw_body = json.dumps(raw_body)
|
486
488
|
expected['sdk_http_response']['body'] = raw_body
|
487
|
-
|
488
|
-
|
489
|
-
|
490
|
-
|
489
|
+
if not self._private:
|
490
|
+
assert (
|
491
|
+
actual == expected
|
492
|
+
), f'SDK response mismatch:\nActual: {actual}\nExpected: {expected}'
|
493
|
+
else:
|
494
|
+
print('Expected SDK response mismatch:\nActual: {actual}\nExpected: {expected}')
|
491
495
|
self._sdk_response_index += 1
|
492
496
|
|
493
497
|
def _request(
|