@ai-sdk/google 0.0.0 → 0.0.1

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.
package/README.md CHANGED
@@ -17,7 +17,7 @@ You can import `Google` from `ai/google` and initialize a provider instance with
17
17
  import { Google } from '@ai-sdk/google';
18
18
 
19
19
  const google = new Google({
20
- baseUrl: '', // optional base URL for proxies etc.
20
+ baseURL: '', // optional base URL for proxies etc.
21
21
  apiKey: '', // optional API key, default to env property GOOGLE_GENERATIVE_AI_API_KEY
22
22
  });
23
23
  ```
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ai-sdk/google",
3
- "version": "0.0.0",
3
+ "version": "0.0.1",
4
4
  "license": "Apache-2.0",
5
5
  "sideEffects": false,
6
6
  "main": "./dist/index.js",
@@ -19,7 +19,7 @@
19
19
  },
20
20
  "dependencies": {
21
21
  "@ai-sdk/provider": "0.0.0",
22
- "@ai-sdk/provider-utils": "0.0.0"
22
+ "@ai-sdk/provider-utils": "0.0.1"
23
23
  },
24
24
  "devDependencies": {
25
25
  "@types/node": "^18",
package/dist/index.d.mts DELETED
@@ -1,47 +0,0 @@
1
- import { LanguageModelV1 } from '@ai-sdk/provider';
2
-
3
- type GoogleGenerativeAIModelId = 'models/gemini-1.5-pro-latest' | 'models/gemini-pro' | 'models/gemini-pro-vision' | (string & {});
4
- interface GoogleGenerativeAISettings {
5
- topK?: number;
6
- }
7
-
8
- type GoogleGenerativeAIConfig = {
9
- provider: string;
10
- baseUrl: string;
11
- headers: () => Record<string, string | undefined>;
12
- generateId: () => string;
13
- };
14
- declare class GoogleGenerativeAILanguageModel implements LanguageModelV1 {
15
- readonly specificationVersion = "v1";
16
- readonly defaultObjectGenerationMode: undefined;
17
- readonly modelId: GoogleGenerativeAIModelId;
18
- readonly settings: GoogleGenerativeAISettings;
19
- private readonly config;
20
- constructor(modelId: GoogleGenerativeAIModelId, settings: GoogleGenerativeAISettings, config: GoogleGenerativeAIConfig);
21
- get provider(): string;
22
- private getArgs;
23
- doGenerate(options: Parameters<LanguageModelV1['doGenerate']>[0]): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>>;
24
- doStream(options: Parameters<LanguageModelV1['doStream']>[0]): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>>;
25
- }
26
-
27
- /**
28
- * Google provider.
29
- */
30
- declare class Google {
31
- readonly baseUrl?: string;
32
- readonly apiKey?: string;
33
- private readonly generateId;
34
- constructor(options?: {
35
- baseUrl?: string;
36
- apiKey?: string;
37
- generateId?: () => string;
38
- });
39
- private get baseConfig();
40
- generativeAI(modelId: GoogleGenerativeAIModelId, settings?: GoogleGenerativeAISettings): GoogleGenerativeAILanguageModel;
41
- }
42
- /**
43
- * Default Google provider instance.
44
- */
45
- declare const google: Google;
46
-
47
- export { Google, google };
package/dist/index.d.ts DELETED
@@ -1,47 +0,0 @@
1
- import { LanguageModelV1 } from '@ai-sdk/provider';
2
-
3
- type GoogleGenerativeAIModelId = 'models/gemini-1.5-pro-latest' | 'models/gemini-pro' | 'models/gemini-pro-vision' | (string & {});
4
- interface GoogleGenerativeAISettings {
5
- topK?: number;
6
- }
7
-
8
- type GoogleGenerativeAIConfig = {
9
- provider: string;
10
- baseUrl: string;
11
- headers: () => Record<string, string | undefined>;
12
- generateId: () => string;
13
- };
14
- declare class GoogleGenerativeAILanguageModel implements LanguageModelV1 {
15
- readonly specificationVersion = "v1";
16
- readonly defaultObjectGenerationMode: undefined;
17
- readonly modelId: GoogleGenerativeAIModelId;
18
- readonly settings: GoogleGenerativeAISettings;
19
- private readonly config;
20
- constructor(modelId: GoogleGenerativeAIModelId, settings: GoogleGenerativeAISettings, config: GoogleGenerativeAIConfig);
21
- get provider(): string;
22
- private getArgs;
23
- doGenerate(options: Parameters<LanguageModelV1['doGenerate']>[0]): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>>;
24
- doStream(options: Parameters<LanguageModelV1['doStream']>[0]): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>>;
25
- }
26
-
27
- /**
28
- * Google provider.
29
- */
30
- declare class Google {
31
- readonly baseUrl?: string;
32
- readonly apiKey?: string;
33
- private readonly generateId;
34
- constructor(options?: {
35
- baseUrl?: string;
36
- apiKey?: string;
37
- generateId?: () => string;
38
- });
39
- private get baseConfig();
40
- generativeAI(modelId: GoogleGenerativeAIModelId, settings?: GoogleGenerativeAISettings): GoogleGenerativeAILanguageModel;
41
- }
42
- /**
43
- * Default Google provider instance.
44
- */
45
- declare const google: Google;
46
-
47
- export { Google, google };
package/dist/index.js DELETED
@@ -1,470 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.ts
21
- var src_exports = {};
22
- __export(src_exports, {
23
- Google: () => Google,
24
- google: () => google
25
- });
26
- module.exports = __toCommonJS(src_exports);
27
-
28
- // src/google-facade.ts
29
- var import_provider_utils4 = require("@ai-sdk/provider-utils");
30
-
31
- // src/google-generative-ai-language-model.ts
32
- var import_provider2 = require("@ai-sdk/provider");
33
- var import_provider_utils3 = require("@ai-sdk/provider-utils");
34
- var import_zod2 = require("zod");
35
-
36
- // src/convert-to-google-generative-ai-messages.ts
37
- var import_provider = require("@ai-sdk/provider");
38
- var import_provider_utils = require("@ai-sdk/provider-utils");
39
- function convertToGoogleGenerativeAIMessages(prompt) {
40
- const messages = [];
41
- for (const { role, content } of prompt) {
42
- switch (role) {
43
- case "system": {
44
- messages.push({ role: "user", parts: [{ text: content }] });
45
- messages.push({ role: "model", parts: [{ text: "" }] });
46
- break;
47
- }
48
- case "user": {
49
- messages.push({
50
- role: "user",
51
- parts: content.map((part) => {
52
- var _a;
53
- switch (part.type) {
54
- case "text": {
55
- return { text: part.text };
56
- }
57
- case "image": {
58
- if (part.image instanceof URL) {
59
- throw new import_provider.UnsupportedFunctionalityError({
60
- functionality: "URL image parts"
61
- });
62
- } else {
63
- return {
64
- inlineData: {
65
- mimeType: (_a = part.mimeType) != null ? _a : "image/jpeg",
66
- data: (0, import_provider_utils.convertUint8ArrayToBase64)(part.image)
67
- }
68
- };
69
- }
70
- }
71
- }
72
- })
73
- });
74
- break;
75
- }
76
- case "assistant": {
77
- messages.push({
78
- role: "model",
79
- parts: content.map((part) => {
80
- switch (part.type) {
81
- case "text": {
82
- return part.text.length === 0 ? void 0 : { text: part.text };
83
- }
84
- case "tool-call": {
85
- return {
86
- functionCall: {
87
- name: part.toolName,
88
- args: part.args
89
- }
90
- };
91
- }
92
- }
93
- }).filter(
94
- (part) => part !== void 0
95
- )
96
- });
97
- break;
98
- }
99
- case "tool": {
100
- messages.push({
101
- role: "user",
102
- parts: content.map((part) => ({
103
- functionResponse: {
104
- name: part.toolName,
105
- response: part.result
106
- }
107
- }))
108
- });
109
- break;
110
- }
111
- default: {
112
- const _exhaustiveCheck = role;
113
- throw new Error(`Unsupported role: ${_exhaustiveCheck}`);
114
- }
115
- }
116
- }
117
- return messages;
118
- }
119
-
120
- // src/google-error.ts
121
- var import_provider_utils2 = require("@ai-sdk/provider-utils");
122
- var import_zod = require("zod");
123
- var googleErrorDataSchema = import_zod.z.object({
124
- error: import_zod.z.object({
125
- code: import_zod.z.number().nullable(),
126
- message: import_zod.z.string(),
127
- status: import_zod.z.string()
128
- })
129
- });
130
- var googleFailedResponseHandler = (0, import_provider_utils2.createJsonErrorResponseHandler)({
131
- errorSchema: googleErrorDataSchema,
132
- errorToMessage: (data) => data.error.message
133
- });
134
-
135
- // src/map-google-generative-ai-finish-reason.ts
136
- function mapGoogleGenerativeAIFinishReason({
137
- finishReason,
138
- hasToolCalls
139
- }) {
140
- switch (finishReason) {
141
- case "STOP":
142
- return hasToolCalls ? "tool-calls" : "stop";
143
- case "MAX_TOKENS":
144
- return "length";
145
- case "RECITATION":
146
- case "SAFETY":
147
- return "content-filter";
148
- case "FINISH_REASON_UNSPECIFIED":
149
- case "OTHER":
150
- default:
151
- return "other";
152
- }
153
- }
154
-
155
- // src/google-generative-ai-language-model.ts
156
- var GoogleGenerativeAILanguageModel = class {
157
- constructor(modelId, settings, config) {
158
- this.specificationVersion = "v1";
159
- this.defaultObjectGenerationMode = void 0;
160
- this.modelId = modelId;
161
- this.settings = settings;
162
- this.config = config;
163
- }
164
- get provider() {
165
- return this.config.provider;
166
- }
167
- getArgs({
168
- mode,
169
- prompt,
170
- maxTokens,
171
- temperature,
172
- topP,
173
- frequencyPenalty,
174
- presencePenalty,
175
- seed
176
- }) {
177
- var _a;
178
- const type = mode.type;
179
- const warnings = [];
180
- if (frequencyPenalty != null) {
181
- warnings.push({
182
- type: "unsupported-setting",
183
- setting: "frequencyPenalty"
184
- });
185
- }
186
- if (presencePenalty != null) {
187
- warnings.push({
188
- type: "unsupported-setting",
189
- setting: "presencePenalty"
190
- });
191
- }
192
- if (seed != null) {
193
- warnings.push({
194
- type: "unsupported-setting",
195
- setting: "seed"
196
- });
197
- }
198
- const baseArgs = {
199
- generationConfig: {
200
- // model specific settings:
201
- topK: this.settings.topK,
202
- // standardized settings:
203
- maxOutputTokens: maxTokens,
204
- temperature,
205
- topP
206
- },
207
- // prompt:
208
- contents: convertToGoogleGenerativeAIMessages(prompt)
209
- };
210
- switch (type) {
211
- case "regular": {
212
- const functionDeclarations = (_a = mode.tools) == null ? void 0 : _a.map((tool) => {
213
- var _a2;
214
- return {
215
- name: tool.name,
216
- description: (_a2 = tool.description) != null ? _a2 : "",
217
- parameters: prepareJsonSchema(tool.parameters)
218
- };
219
- });
220
- return {
221
- args: {
222
- ...baseArgs,
223
- tools: functionDeclarations == null ? void 0 : { functionDeclarations }
224
- },
225
- warnings
226
- };
227
- }
228
- case "object-json": {
229
- throw new import_provider2.UnsupportedFunctionalityError({
230
- functionality: "object-json mode"
231
- });
232
- }
233
- case "object-tool": {
234
- throw new import_provider2.UnsupportedFunctionalityError({
235
- functionality: "object-tool mode"
236
- });
237
- }
238
- case "object-grammar": {
239
- throw new import_provider2.UnsupportedFunctionalityError({
240
- functionality: "object-grammar mode"
241
- });
242
- }
243
- default: {
244
- const _exhaustiveCheck = type;
245
- throw new Error(`Unsupported type: ${_exhaustiveCheck}`);
246
- }
247
- }
248
- }
249
- async doGenerate(options) {
250
- var _a;
251
- const { args, warnings } = this.getArgs(options);
252
- const response = await (0, import_provider_utils3.postJsonToApi)({
253
- url: `${this.config.baseUrl}/${this.modelId}:generateContent`,
254
- headers: this.config.headers(),
255
- body: args,
256
- failedResponseHandler: googleFailedResponseHandler,
257
- successfulResponseHandler: (0, import_provider_utils3.createJsonResponseHandler)(responseSchema),
258
- abortSignal: options.abortSignal
259
- });
260
- const { contents: rawPrompt, ...rawSettings } = args;
261
- const candidate = response.candidates[0];
262
- const toolCalls = getToolCallsFromParts({
263
- parts: candidate.content.parts,
264
- generateId: this.config.generateId
265
- });
266
- return {
267
- text: getTextFromParts(candidate.content.parts),
268
- toolCalls,
269
- finishReason: mapGoogleGenerativeAIFinishReason({
270
- finishReason: candidate.finishReason,
271
- hasToolCalls: toolCalls != null && toolCalls.length > 0
272
- }),
273
- usage: {
274
- promptTokens: NaN,
275
- completionTokens: (_a = candidate.tokenCount) != null ? _a : NaN
276
- },
277
- rawCall: { rawPrompt, rawSettings },
278
- warnings
279
- };
280
- }
281
- async doStream(options) {
282
- const { args, warnings } = this.getArgs(options);
283
- const response = await (0, import_provider_utils3.postJsonToApi)({
284
- url: `${this.config.baseUrl}/${this.modelId}:streamGenerateContent?alt=sse`,
285
- headers: this.config.headers(),
286
- body: args,
287
- failedResponseHandler: googleFailedResponseHandler,
288
- successfulResponseHandler: (0, import_provider_utils3.createEventSourceResponseHandler)(chunkSchema),
289
- abortSignal: options.abortSignal
290
- });
291
- const { contents: rawPrompt, ...rawSettings } = args;
292
- let finishReason = "other";
293
- let usage = {
294
- promptTokens: Number.NaN,
295
- completionTokens: Number.NaN
296
- };
297
- const generateId2 = this.config.generateId;
298
- let hasToolCalls = false;
299
- return {
300
- stream: response.pipeThrough(
301
- new TransformStream({
302
- transform(chunk, controller) {
303
- if (!chunk.success) {
304
- controller.enqueue({ type: "error", error: chunk.error });
305
- return;
306
- }
307
- const value = chunk.value;
308
- const candidate = value.candidates[0];
309
- if ((candidate == null ? void 0 : candidate.finishReason) != null) {
310
- finishReason = mapGoogleGenerativeAIFinishReason({
311
- finishReason: candidate.finishReason,
312
- hasToolCalls
313
- });
314
- }
315
- if (candidate.tokenCount != null) {
316
- usage = {
317
- promptTokens: NaN,
318
- completionTokens: candidate.tokenCount
319
- };
320
- }
321
- const content = candidate.content;
322
- if (content == null) {
323
- return;
324
- }
325
- const deltaText = getTextFromParts(content.parts);
326
- if (deltaText != null) {
327
- controller.enqueue({
328
- type: "text-delta",
329
- textDelta: deltaText
330
- });
331
- }
332
- const toolCallDeltas = getToolCallsFromParts({
333
- parts: content.parts,
334
- generateId: generateId2
335
- });
336
- if (toolCallDeltas != null) {
337
- for (const toolCall of toolCallDeltas) {
338
- controller.enqueue({
339
- type: "tool-call-delta",
340
- toolCallType: "function",
341
- toolCallId: toolCall.toolCallId,
342
- toolName: toolCall.toolName,
343
- argsTextDelta: toolCall.args
344
- });
345
- controller.enqueue({
346
- type: "tool-call",
347
- toolCallType: "function",
348
- toolCallId: toolCall.toolCallId,
349
- toolName: toolCall.toolName,
350
- args: toolCall.args
351
- });
352
- hasToolCalls = true;
353
- }
354
- }
355
- },
356
- flush(controller) {
357
- controller.enqueue({ type: "finish", finishReason, usage });
358
- }
359
- })
360
- ),
361
- rawCall: { rawPrompt, rawSettings },
362
- warnings
363
- };
364
- }
365
- };
366
- function prepareJsonSchema(jsonSchema) {
367
- if (typeof jsonSchema !== "object") {
368
- return jsonSchema;
369
- }
370
- if (Array.isArray(jsonSchema)) {
371
- return jsonSchema.map(prepareJsonSchema);
372
- }
373
- const result = {};
374
- for (const [key, value] of Object.entries(jsonSchema)) {
375
- if (key === "additionalProperties" || key === "$schema") {
376
- continue;
377
- }
378
- result[key] = prepareJsonSchema(value);
379
- }
380
- return result;
381
- }
382
- function getToolCallsFromParts({
383
- parts,
384
- generateId: generateId2
385
- }) {
386
- const functionCallParts = parts.filter(
387
- (part) => "functionCall" in part
388
- );
389
- return functionCallParts.length === 0 ? void 0 : functionCallParts.map((part) => ({
390
- toolCallType: "function",
391
- toolCallId: generateId2(),
392
- toolName: part.functionCall.name,
393
- args: JSON.stringify(part.functionCall.args)
394
- }));
395
- }
396
- function getTextFromParts(parts) {
397
- const textParts = parts.filter((part) => "text" in part);
398
- return textParts.length === 0 ? void 0 : textParts.map((part) => part.text).join("");
399
- }
400
- var contentSchema = import_zod2.z.object({
401
- role: import_zod2.z.string(),
402
- parts: import_zod2.z.array(
403
- import_zod2.z.union([
404
- import_zod2.z.object({
405
- text: import_zod2.z.string()
406
- }),
407
- import_zod2.z.object({
408
- functionCall: import_zod2.z.object({
409
- name: import_zod2.z.string(),
410
- args: import_zod2.z.unknown()
411
- })
412
- })
413
- ])
414
- )
415
- });
416
- var responseSchema = import_zod2.z.object({
417
- candidates: import_zod2.z.array(
418
- import_zod2.z.object({
419
- content: contentSchema,
420
- finishReason: import_zod2.z.string().optional(),
421
- tokenCount: import_zod2.z.number().optional()
422
- })
423
- )
424
- });
425
- var chunkSchema = import_zod2.z.object({
426
- candidates: import_zod2.z.array(
427
- import_zod2.z.object({
428
- content: contentSchema.optional(),
429
- finishReason: import_zod2.z.string().optional(),
430
- tokenCount: import_zod2.z.number().optional()
431
- })
432
- )
433
- });
434
-
435
- // src/google-facade.ts
436
- var Google = class {
437
- constructor(options = {}) {
438
- var _a;
439
- this.baseUrl = options.baseUrl;
440
- this.apiKey = options.apiKey;
441
- this.generateId = (_a = options.generateId) != null ? _a : import_provider_utils4.generateId;
442
- }
443
- get baseConfig() {
444
- var _a;
445
- return {
446
- baseUrl: (_a = this.baseUrl) != null ? _a : "https://generativelanguage.googleapis.com/v1beta",
447
- headers: () => ({
448
- "x-goog-api-key": (0, import_provider_utils4.loadApiKey)({
449
- apiKey: this.apiKey,
450
- environmentVariableName: "GOOGLE_GENERATIVE_AI_API_KEY",
451
- description: "Google Generative AI"
452
- })
453
- })
454
- };
455
- }
456
- generativeAI(modelId, settings = {}) {
457
- return new GoogleGenerativeAILanguageModel(modelId, settings, {
458
- provider: "google.generative-ai",
459
- ...this.baseConfig,
460
- generateId: this.generateId
461
- });
462
- }
463
- };
464
- var google = new Google();
465
- // Annotate the CommonJS export names for ESM import in node:
466
- 0 && (module.exports = {
467
- Google,
468
- google
469
- });
470
- //# sourceMappingURL=index.js.map
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/index.ts","../src/google-facade.ts","../src/google-generative-ai-language-model.ts","../src/convert-to-google-generative-ai-messages.ts","../src/google-error.ts","../src/map-google-generative-ai-finish-reason.ts"],"sourcesContent":["export * from './google-facade';\n","import { generateId, loadApiKey } from '@ai-sdk/provider-utils';\nimport { GoogleGenerativeAILanguageModel } from './google-generative-ai-language-model';\nimport {\n GoogleGenerativeAIModelId,\n GoogleGenerativeAISettings,\n} from './google-generative-ai-settings';\n\n/**\n * Google provider.\n */\nexport class Google {\n readonly baseUrl?: string;\n readonly apiKey?: string;\n\n private readonly generateId: () => string;\n\n constructor(\n options: {\n baseUrl?: string;\n apiKey?: string;\n generateId?: () => string;\n } = {},\n ) {\n this.baseUrl = options.baseUrl;\n this.apiKey = options.apiKey;\n this.generateId = options.generateId ?? generateId;\n }\n\n private get baseConfig() {\n return {\n baseUrl:\n this.baseUrl ?? 'https://generativelanguage.googleapis.com/v1beta',\n headers: () => ({\n 'x-goog-api-key': loadApiKey({\n apiKey: this.apiKey,\n environmentVariableName: 'GOOGLE_GENERATIVE_AI_API_KEY',\n description: 'Google Generative AI',\n }),\n }),\n };\n }\n\n generativeAI(\n modelId: GoogleGenerativeAIModelId,\n settings: GoogleGenerativeAISettings = {},\n ) {\n return new GoogleGenerativeAILanguageModel(modelId, settings, {\n provider: 'google.generative-ai',\n ...this.baseConfig,\n generateId: this.generateId,\n });\n }\n}\n\n/**\n * Default Google provider instance.\n */\nexport const google = new Google();\n","import {\n LanguageModelV1,\n LanguageModelV1CallWarning,\n LanguageModelV1FinishReason,\n LanguageModelV1StreamPart,\n UnsupportedFunctionalityError,\n} from '@ai-sdk/provider';\nimport {\n ParseResult,\n createEventSourceResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\nimport { convertToGoogleGenerativeAIMessages } from './convert-to-google-generative-ai-messages';\nimport { googleFailedResponseHandler } from './google-error';\nimport { GoogleGenerativeAIContentPart } from './google-generative-ai-prompt';\nimport {\n GoogleGenerativeAIModelId,\n GoogleGenerativeAISettings,\n} from './google-generative-ai-settings';\nimport { mapGoogleGenerativeAIFinishReason } from './map-google-generative-ai-finish-reason';\n\ntype GoogleGenerativeAIConfig = {\n provider: string;\n baseUrl: string;\n headers: () => Record<string, string | undefined>;\n generateId: () => string;\n};\n\nexport class GoogleGenerativeAILanguageModel implements LanguageModelV1 {\n readonly specificationVersion = 'v1';\n readonly defaultObjectGenerationMode = undefined;\n\n readonly modelId: GoogleGenerativeAIModelId;\n readonly settings: GoogleGenerativeAISettings;\n\n private readonly config: GoogleGenerativeAIConfig;\n\n constructor(\n modelId: GoogleGenerativeAIModelId,\n settings: GoogleGenerativeAISettings,\n config: GoogleGenerativeAIConfig,\n ) {\n this.modelId = modelId;\n this.settings = settings;\n this.config = config;\n }\n\n get provider(): string {\n return this.config.provider;\n }\n\n private getArgs({\n mode,\n prompt,\n maxTokens,\n temperature,\n topP,\n frequencyPenalty,\n presencePenalty,\n seed,\n }: Parameters<LanguageModelV1['doGenerate']>[0]) {\n const type = mode.type;\n\n const warnings: LanguageModelV1CallWarning[] = [];\n\n if (frequencyPenalty != null) {\n warnings.push({\n type: 'unsupported-setting',\n setting: 'frequencyPenalty',\n });\n }\n\n if (presencePenalty != null) {\n warnings.push({\n type: 'unsupported-setting',\n setting: 'presencePenalty',\n });\n }\n\n if (seed != null) {\n warnings.push({\n type: 'unsupported-setting',\n setting: 'seed',\n });\n }\n\n const baseArgs = {\n generationConfig: {\n // model specific settings:\n topK: this.settings.topK,\n\n // standardized settings:\n maxOutputTokens: maxTokens,\n temperature,\n topP,\n },\n\n // prompt:\n contents: convertToGoogleGenerativeAIMessages(prompt),\n };\n\n switch (type) {\n case 'regular': {\n const functionDeclarations = mode.tools?.map(tool => ({\n name: tool.name,\n description: tool.description ?? '',\n parameters: prepareJsonSchema(tool.parameters),\n }));\n\n return {\n args: {\n ...baseArgs,\n tools:\n functionDeclarations == null\n ? undefined\n : { functionDeclarations },\n },\n warnings,\n };\n }\n\n case 'object-json': {\n throw new UnsupportedFunctionalityError({\n functionality: 'object-json mode',\n });\n }\n\n case 'object-tool': {\n throw new UnsupportedFunctionalityError({\n functionality: 'object-tool mode',\n });\n }\n\n case 'object-grammar': {\n throw new UnsupportedFunctionalityError({\n functionality: 'object-grammar mode',\n });\n }\n\n default: {\n const _exhaustiveCheck: never = type;\n throw new Error(`Unsupported type: ${_exhaustiveCheck}`);\n }\n }\n }\n\n async doGenerate(\n options: Parameters<LanguageModelV1['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>> {\n const { args, warnings } = this.getArgs(options);\n\n const response = await postJsonToApi({\n url: `${this.config.baseUrl}/${this.modelId}:generateContent`,\n headers: this.config.headers(),\n body: args,\n failedResponseHandler: googleFailedResponseHandler,\n successfulResponseHandler: createJsonResponseHandler(responseSchema),\n abortSignal: options.abortSignal,\n });\n\n const { contents: rawPrompt, ...rawSettings } = args;\n const candidate = response.candidates[0];\n\n const toolCalls = getToolCallsFromParts({\n parts: candidate.content.parts,\n generateId: this.config.generateId,\n });\n\n return {\n text: getTextFromParts(candidate.content.parts),\n toolCalls,\n finishReason: mapGoogleGenerativeAIFinishReason({\n finishReason: candidate.finishReason,\n hasToolCalls: toolCalls != null && toolCalls.length > 0,\n }),\n usage: {\n promptTokens: NaN,\n completionTokens: candidate.tokenCount ?? NaN,\n },\n rawCall: { rawPrompt, rawSettings },\n warnings,\n };\n }\n\n async doStream(\n options: Parameters<LanguageModelV1['doStream']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>> {\n const { args, warnings } = this.getArgs(options);\n\n const response = await postJsonToApi({\n url: `${this.config.baseUrl}/${this.modelId}:streamGenerateContent?alt=sse`,\n headers: this.config.headers(),\n body: args,\n failedResponseHandler: googleFailedResponseHandler,\n successfulResponseHandler: createEventSourceResponseHandler(chunkSchema),\n abortSignal: options.abortSignal,\n });\n\n const { contents: rawPrompt, ...rawSettings } = args;\n\n let finishReason: LanguageModelV1FinishReason = 'other';\n let usage: { promptTokens: number; completionTokens: number } = {\n promptTokens: Number.NaN,\n completionTokens: Number.NaN,\n };\n\n const generateId = this.config.generateId;\n let hasToolCalls = false;\n\n return {\n stream: response.pipeThrough(\n new TransformStream<\n ParseResult<z.infer<typeof chunkSchema>>,\n LanguageModelV1StreamPart\n >({\n transform(chunk, controller) {\n if (!chunk.success) {\n controller.enqueue({ type: 'error', error: chunk.error });\n return;\n }\n\n const value = chunk.value;\n\n const candidate = value.candidates[0];\n\n if (candidate?.finishReason != null) {\n finishReason = mapGoogleGenerativeAIFinishReason({\n finishReason: candidate.finishReason,\n hasToolCalls,\n });\n }\n\n if (candidate.tokenCount != null) {\n usage = {\n promptTokens: NaN,\n completionTokens: candidate.tokenCount,\n };\n }\n\n const content = candidate.content;\n\n if (content == null) {\n return;\n }\n\n const deltaText = getTextFromParts(content.parts);\n if (deltaText != null) {\n controller.enqueue({\n type: 'text-delta',\n textDelta: deltaText,\n });\n }\n\n const toolCallDeltas = getToolCallsFromParts({\n parts: content.parts,\n generateId,\n });\n\n if (toolCallDeltas != null) {\n for (const toolCall of toolCallDeltas) {\n controller.enqueue({\n type: 'tool-call-delta',\n toolCallType: 'function',\n toolCallId: toolCall.toolCallId,\n toolName: toolCall.toolName,\n argsTextDelta: toolCall.args,\n });\n\n controller.enqueue({\n type: 'tool-call',\n toolCallType: 'function',\n toolCallId: toolCall.toolCallId,\n toolName: toolCall.toolName,\n args: toolCall.args,\n });\n\n hasToolCalls = true;\n }\n }\n },\n\n flush(controller) {\n controller.enqueue({ type: 'finish', finishReason, usage });\n },\n }),\n ),\n rawCall: { rawPrompt, rawSettings },\n warnings,\n };\n }\n}\n\n// Removes all \"additionalProperty\" and \"$schema\" properties from the object (recursively)\n// (not supported by Google Generative AI)\nfunction prepareJsonSchema(jsonSchema: any): unknown {\n if (typeof jsonSchema !== 'object') {\n return jsonSchema;\n }\n\n if (Array.isArray(jsonSchema)) {\n return jsonSchema.map(prepareJsonSchema);\n }\n\n const result: Record<string, any> = {};\n\n for (const [key, value] of Object.entries(jsonSchema)) {\n if (key === 'additionalProperties' || key === '$schema') {\n continue;\n }\n\n result[key] = prepareJsonSchema(value);\n }\n\n return result;\n}\n\nfunction getToolCallsFromParts({\n parts,\n generateId,\n}: {\n parts: z.infer<typeof contentSchema>['parts'];\n generateId: () => string;\n}) {\n const functionCallParts = parts.filter(\n part => 'functionCall' in part,\n ) as Array<\n GoogleGenerativeAIContentPart & {\n functionCall: { name: string; args: unknown };\n }\n >;\n\n return functionCallParts.length === 0\n ? undefined\n : functionCallParts.map(part => ({\n toolCallType: 'function' as const,\n toolCallId: generateId(),\n toolName: part.functionCall.name,\n args: JSON.stringify(part.functionCall.args),\n }));\n}\n\nfunction getTextFromParts(parts: z.infer<typeof contentSchema>['parts']) {\n const textParts = parts.filter(part => 'text' in part) as Array<\n GoogleGenerativeAIContentPart & { text: string }\n >;\n\n return textParts.length === 0\n ? undefined\n : textParts.map(part => part.text).join('');\n}\n\nconst contentSchema = z.object({\n role: z.string(),\n parts: z.array(\n z.union([\n z.object({\n text: z.string(),\n }),\n z.object({\n functionCall: z.object({\n name: z.string(),\n args: z.unknown(),\n }),\n }),\n ]),\n ),\n});\n\n// limited version of the schema, focussed on what is needed for the implementation\n// this approach limits breakages when the API changes and increases efficiency\nconst responseSchema = z.object({\n candidates: z.array(\n z.object({\n content: contentSchema,\n finishReason: z.string().optional(),\n tokenCount: z.number().optional(),\n }),\n ),\n});\n\n// limited version of the schema, focussed on what is needed for the implementation\n// this approach limits breakages when the API changes and increases efficiency\nconst chunkSchema = z.object({\n candidates: z.array(\n z.object({\n content: contentSchema.optional(),\n finishReason: z.string().optional(),\n tokenCount: z.number().optional(),\n }),\n ),\n});\n","import {\n LanguageModelV1Prompt,\n UnsupportedFunctionalityError,\n} from '@ai-sdk/provider';\nimport { convertUint8ArrayToBase64 } from '@ai-sdk/provider-utils';\nimport {\n GoogleGenerativeAIContentPart,\n GoogleGenerativeAIPrompt,\n} from './google-generative-ai-prompt';\n\nexport function convertToGoogleGenerativeAIMessages(\n prompt: LanguageModelV1Prompt,\n): GoogleGenerativeAIPrompt {\n const messages: GoogleGenerativeAIPrompt = [];\n\n for (const { role, content } of prompt) {\n switch (role) {\n case 'system': {\n // system message becomes user message:\n messages.push({ role: 'user', parts: [{ text: content }] });\n\n // required for to ensure turn-taking:\n messages.push({ role: 'model', parts: [{ text: '' }] });\n\n break;\n }\n\n case 'user': {\n messages.push({\n role: 'user',\n parts: content.map(part => {\n switch (part.type) {\n case 'text': {\n return { text: part.text };\n }\n case 'image': {\n if (part.image instanceof URL) {\n throw new UnsupportedFunctionalityError({\n functionality: 'URL image parts',\n });\n } else {\n return {\n inlineData: {\n mimeType: part.mimeType ?? 'image/jpeg',\n data: convertUint8ArrayToBase64(part.image),\n },\n };\n }\n }\n }\n }),\n });\n break;\n }\n\n case 'assistant': {\n messages.push({\n role: 'model',\n parts: content\n .map(part => {\n switch (part.type) {\n case 'text': {\n return part.text.length === 0\n ? undefined\n : { text: part.text };\n }\n case 'tool-call': {\n return {\n functionCall: {\n name: part.toolName,\n args: part.args,\n },\n };\n }\n }\n })\n .filter(\n part => part !== undefined,\n ) as GoogleGenerativeAIContentPart[],\n });\n break;\n }\n\n case 'tool': {\n messages.push({\n role: 'user',\n parts: content.map(part => ({\n functionResponse: {\n name: part.toolName,\n response: part.result,\n },\n })),\n });\n break;\n }\n default: {\n const _exhaustiveCheck: never = role;\n throw new Error(`Unsupported role: ${_exhaustiveCheck}`);\n }\n }\n }\n\n return messages;\n}\n","import { createJsonErrorResponseHandler } from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\n\nconst googleErrorDataSchema = z.object({\n error: z.object({\n code: z.number().nullable(),\n message: z.string(),\n status: z.string(),\n }),\n});\n\nexport type GoogleErrorData = z.infer<typeof googleErrorDataSchema>;\n\nexport const googleFailedResponseHandler = createJsonErrorResponseHandler({\n errorSchema: googleErrorDataSchema,\n errorToMessage: data => data.error.message,\n});\n","import { LanguageModelV1FinishReason } from '@ai-sdk/provider';\n\nexport function mapGoogleGenerativeAIFinishReason({\n finishReason,\n hasToolCalls,\n}: {\n finishReason: string | null | undefined;\n hasToolCalls: boolean;\n}): LanguageModelV1FinishReason {\n switch (finishReason) {\n case 'STOP':\n return hasToolCalls ? 'tool-calls' : 'stop';\n case 'MAX_TOKENS':\n return 'length';\n case 'RECITATION':\n case 'SAFETY':\n return 'content-filter';\n case 'FINISH_REASON_UNSPECIFIED':\n case 'OTHER':\n default:\n return 'other';\n }\n}\n"],"mappings":"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","names":["import_provider_utils","import_provider","import_provider_utils","import_zod","import_provider_utils","_a","generateId"]}
package/dist/index.mjs DELETED
@@ -1,450 +0,0 @@
1
- // src/google-facade.ts
2
- import { generateId, loadApiKey } from "@ai-sdk/provider-utils";
3
-
4
- // src/google-generative-ai-language-model.ts
5
- import {
6
- UnsupportedFunctionalityError as UnsupportedFunctionalityError2
7
- } from "@ai-sdk/provider";
8
- import {
9
- createEventSourceResponseHandler,
10
- createJsonResponseHandler,
11
- postJsonToApi
12
- } from "@ai-sdk/provider-utils";
13
- import { z as z2 } from "zod";
14
-
15
- // src/convert-to-google-generative-ai-messages.ts
16
- import {
17
- UnsupportedFunctionalityError
18
- } from "@ai-sdk/provider";
19
- import { convertUint8ArrayToBase64 } from "@ai-sdk/provider-utils";
20
- function convertToGoogleGenerativeAIMessages(prompt) {
21
- const messages = [];
22
- for (const { role, content } of prompt) {
23
- switch (role) {
24
- case "system": {
25
- messages.push({ role: "user", parts: [{ text: content }] });
26
- messages.push({ role: "model", parts: [{ text: "" }] });
27
- break;
28
- }
29
- case "user": {
30
- messages.push({
31
- role: "user",
32
- parts: content.map((part) => {
33
- var _a;
34
- switch (part.type) {
35
- case "text": {
36
- return { text: part.text };
37
- }
38
- case "image": {
39
- if (part.image instanceof URL) {
40
- throw new UnsupportedFunctionalityError({
41
- functionality: "URL image parts"
42
- });
43
- } else {
44
- return {
45
- inlineData: {
46
- mimeType: (_a = part.mimeType) != null ? _a : "image/jpeg",
47
- data: convertUint8ArrayToBase64(part.image)
48
- }
49
- };
50
- }
51
- }
52
- }
53
- })
54
- });
55
- break;
56
- }
57
- case "assistant": {
58
- messages.push({
59
- role: "model",
60
- parts: content.map((part) => {
61
- switch (part.type) {
62
- case "text": {
63
- return part.text.length === 0 ? void 0 : { text: part.text };
64
- }
65
- case "tool-call": {
66
- return {
67
- functionCall: {
68
- name: part.toolName,
69
- args: part.args
70
- }
71
- };
72
- }
73
- }
74
- }).filter(
75
- (part) => part !== void 0
76
- )
77
- });
78
- break;
79
- }
80
- case "tool": {
81
- messages.push({
82
- role: "user",
83
- parts: content.map((part) => ({
84
- functionResponse: {
85
- name: part.toolName,
86
- response: part.result
87
- }
88
- }))
89
- });
90
- break;
91
- }
92
- default: {
93
- const _exhaustiveCheck = role;
94
- throw new Error(`Unsupported role: ${_exhaustiveCheck}`);
95
- }
96
- }
97
- }
98
- return messages;
99
- }
100
-
101
- // src/google-error.ts
102
- import { createJsonErrorResponseHandler } from "@ai-sdk/provider-utils";
103
- import { z } from "zod";
104
- var googleErrorDataSchema = z.object({
105
- error: z.object({
106
- code: z.number().nullable(),
107
- message: z.string(),
108
- status: z.string()
109
- })
110
- });
111
- var googleFailedResponseHandler = createJsonErrorResponseHandler({
112
- errorSchema: googleErrorDataSchema,
113
- errorToMessage: (data) => data.error.message
114
- });
115
-
116
- // src/map-google-generative-ai-finish-reason.ts
117
- function mapGoogleGenerativeAIFinishReason({
118
- finishReason,
119
- hasToolCalls
120
- }) {
121
- switch (finishReason) {
122
- case "STOP":
123
- return hasToolCalls ? "tool-calls" : "stop";
124
- case "MAX_TOKENS":
125
- return "length";
126
- case "RECITATION":
127
- case "SAFETY":
128
- return "content-filter";
129
- case "FINISH_REASON_UNSPECIFIED":
130
- case "OTHER":
131
- default:
132
- return "other";
133
- }
134
- }
135
-
136
- // src/google-generative-ai-language-model.ts
137
- var GoogleGenerativeAILanguageModel = class {
138
- constructor(modelId, settings, config) {
139
- this.specificationVersion = "v1";
140
- this.defaultObjectGenerationMode = void 0;
141
- this.modelId = modelId;
142
- this.settings = settings;
143
- this.config = config;
144
- }
145
- get provider() {
146
- return this.config.provider;
147
- }
148
- getArgs({
149
- mode,
150
- prompt,
151
- maxTokens,
152
- temperature,
153
- topP,
154
- frequencyPenalty,
155
- presencePenalty,
156
- seed
157
- }) {
158
- var _a;
159
- const type = mode.type;
160
- const warnings = [];
161
- if (frequencyPenalty != null) {
162
- warnings.push({
163
- type: "unsupported-setting",
164
- setting: "frequencyPenalty"
165
- });
166
- }
167
- if (presencePenalty != null) {
168
- warnings.push({
169
- type: "unsupported-setting",
170
- setting: "presencePenalty"
171
- });
172
- }
173
- if (seed != null) {
174
- warnings.push({
175
- type: "unsupported-setting",
176
- setting: "seed"
177
- });
178
- }
179
- const baseArgs = {
180
- generationConfig: {
181
- // model specific settings:
182
- topK: this.settings.topK,
183
- // standardized settings:
184
- maxOutputTokens: maxTokens,
185
- temperature,
186
- topP
187
- },
188
- // prompt:
189
- contents: convertToGoogleGenerativeAIMessages(prompt)
190
- };
191
- switch (type) {
192
- case "regular": {
193
- const functionDeclarations = (_a = mode.tools) == null ? void 0 : _a.map((tool) => {
194
- var _a2;
195
- return {
196
- name: tool.name,
197
- description: (_a2 = tool.description) != null ? _a2 : "",
198
- parameters: prepareJsonSchema(tool.parameters)
199
- };
200
- });
201
- return {
202
- args: {
203
- ...baseArgs,
204
- tools: functionDeclarations == null ? void 0 : { functionDeclarations }
205
- },
206
- warnings
207
- };
208
- }
209
- case "object-json": {
210
- throw new UnsupportedFunctionalityError2({
211
- functionality: "object-json mode"
212
- });
213
- }
214
- case "object-tool": {
215
- throw new UnsupportedFunctionalityError2({
216
- functionality: "object-tool mode"
217
- });
218
- }
219
- case "object-grammar": {
220
- throw new UnsupportedFunctionalityError2({
221
- functionality: "object-grammar mode"
222
- });
223
- }
224
- default: {
225
- const _exhaustiveCheck = type;
226
- throw new Error(`Unsupported type: ${_exhaustiveCheck}`);
227
- }
228
- }
229
- }
230
- async doGenerate(options) {
231
- var _a;
232
- const { args, warnings } = this.getArgs(options);
233
- const response = await postJsonToApi({
234
- url: `${this.config.baseUrl}/${this.modelId}:generateContent`,
235
- headers: this.config.headers(),
236
- body: args,
237
- failedResponseHandler: googleFailedResponseHandler,
238
- successfulResponseHandler: createJsonResponseHandler(responseSchema),
239
- abortSignal: options.abortSignal
240
- });
241
- const { contents: rawPrompt, ...rawSettings } = args;
242
- const candidate = response.candidates[0];
243
- const toolCalls = getToolCallsFromParts({
244
- parts: candidate.content.parts,
245
- generateId: this.config.generateId
246
- });
247
- return {
248
- text: getTextFromParts(candidate.content.parts),
249
- toolCalls,
250
- finishReason: mapGoogleGenerativeAIFinishReason({
251
- finishReason: candidate.finishReason,
252
- hasToolCalls: toolCalls != null && toolCalls.length > 0
253
- }),
254
- usage: {
255
- promptTokens: NaN,
256
- completionTokens: (_a = candidate.tokenCount) != null ? _a : NaN
257
- },
258
- rawCall: { rawPrompt, rawSettings },
259
- warnings
260
- };
261
- }
262
- async doStream(options) {
263
- const { args, warnings } = this.getArgs(options);
264
- const response = await postJsonToApi({
265
- url: `${this.config.baseUrl}/${this.modelId}:streamGenerateContent?alt=sse`,
266
- headers: this.config.headers(),
267
- body: args,
268
- failedResponseHandler: googleFailedResponseHandler,
269
- successfulResponseHandler: createEventSourceResponseHandler(chunkSchema),
270
- abortSignal: options.abortSignal
271
- });
272
- const { contents: rawPrompt, ...rawSettings } = args;
273
- let finishReason = "other";
274
- let usage = {
275
- promptTokens: Number.NaN,
276
- completionTokens: Number.NaN
277
- };
278
- const generateId2 = this.config.generateId;
279
- let hasToolCalls = false;
280
- return {
281
- stream: response.pipeThrough(
282
- new TransformStream({
283
- transform(chunk, controller) {
284
- if (!chunk.success) {
285
- controller.enqueue({ type: "error", error: chunk.error });
286
- return;
287
- }
288
- const value = chunk.value;
289
- const candidate = value.candidates[0];
290
- if ((candidate == null ? void 0 : candidate.finishReason) != null) {
291
- finishReason = mapGoogleGenerativeAIFinishReason({
292
- finishReason: candidate.finishReason,
293
- hasToolCalls
294
- });
295
- }
296
- if (candidate.tokenCount != null) {
297
- usage = {
298
- promptTokens: NaN,
299
- completionTokens: candidate.tokenCount
300
- };
301
- }
302
- const content = candidate.content;
303
- if (content == null) {
304
- return;
305
- }
306
- const deltaText = getTextFromParts(content.parts);
307
- if (deltaText != null) {
308
- controller.enqueue({
309
- type: "text-delta",
310
- textDelta: deltaText
311
- });
312
- }
313
- const toolCallDeltas = getToolCallsFromParts({
314
- parts: content.parts,
315
- generateId: generateId2
316
- });
317
- if (toolCallDeltas != null) {
318
- for (const toolCall of toolCallDeltas) {
319
- controller.enqueue({
320
- type: "tool-call-delta",
321
- toolCallType: "function",
322
- toolCallId: toolCall.toolCallId,
323
- toolName: toolCall.toolName,
324
- argsTextDelta: toolCall.args
325
- });
326
- controller.enqueue({
327
- type: "tool-call",
328
- toolCallType: "function",
329
- toolCallId: toolCall.toolCallId,
330
- toolName: toolCall.toolName,
331
- args: toolCall.args
332
- });
333
- hasToolCalls = true;
334
- }
335
- }
336
- },
337
- flush(controller) {
338
- controller.enqueue({ type: "finish", finishReason, usage });
339
- }
340
- })
341
- ),
342
- rawCall: { rawPrompt, rawSettings },
343
- warnings
344
- };
345
- }
346
- };
347
- function prepareJsonSchema(jsonSchema) {
348
- if (typeof jsonSchema !== "object") {
349
- return jsonSchema;
350
- }
351
- if (Array.isArray(jsonSchema)) {
352
- return jsonSchema.map(prepareJsonSchema);
353
- }
354
- const result = {};
355
- for (const [key, value] of Object.entries(jsonSchema)) {
356
- if (key === "additionalProperties" || key === "$schema") {
357
- continue;
358
- }
359
- result[key] = prepareJsonSchema(value);
360
- }
361
- return result;
362
- }
363
- function getToolCallsFromParts({
364
- parts,
365
- generateId: generateId2
366
- }) {
367
- const functionCallParts = parts.filter(
368
- (part) => "functionCall" in part
369
- );
370
- return functionCallParts.length === 0 ? void 0 : functionCallParts.map((part) => ({
371
- toolCallType: "function",
372
- toolCallId: generateId2(),
373
- toolName: part.functionCall.name,
374
- args: JSON.stringify(part.functionCall.args)
375
- }));
376
- }
377
- function getTextFromParts(parts) {
378
- const textParts = parts.filter((part) => "text" in part);
379
- return textParts.length === 0 ? void 0 : textParts.map((part) => part.text).join("");
380
- }
381
- var contentSchema = z2.object({
382
- role: z2.string(),
383
- parts: z2.array(
384
- z2.union([
385
- z2.object({
386
- text: z2.string()
387
- }),
388
- z2.object({
389
- functionCall: z2.object({
390
- name: z2.string(),
391
- args: z2.unknown()
392
- })
393
- })
394
- ])
395
- )
396
- });
397
- var responseSchema = z2.object({
398
- candidates: z2.array(
399
- z2.object({
400
- content: contentSchema,
401
- finishReason: z2.string().optional(),
402
- tokenCount: z2.number().optional()
403
- })
404
- )
405
- });
406
- var chunkSchema = z2.object({
407
- candidates: z2.array(
408
- z2.object({
409
- content: contentSchema.optional(),
410
- finishReason: z2.string().optional(),
411
- tokenCount: z2.number().optional()
412
- })
413
- )
414
- });
415
-
416
- // src/google-facade.ts
417
- var Google = class {
418
- constructor(options = {}) {
419
- var _a;
420
- this.baseUrl = options.baseUrl;
421
- this.apiKey = options.apiKey;
422
- this.generateId = (_a = options.generateId) != null ? _a : generateId;
423
- }
424
- get baseConfig() {
425
- var _a;
426
- return {
427
- baseUrl: (_a = this.baseUrl) != null ? _a : "https://generativelanguage.googleapis.com/v1beta",
428
- headers: () => ({
429
- "x-goog-api-key": loadApiKey({
430
- apiKey: this.apiKey,
431
- environmentVariableName: "GOOGLE_GENERATIVE_AI_API_KEY",
432
- description: "Google Generative AI"
433
- })
434
- })
435
- };
436
- }
437
- generativeAI(modelId, settings = {}) {
438
- return new GoogleGenerativeAILanguageModel(modelId, settings, {
439
- provider: "google.generative-ai",
440
- ...this.baseConfig,
441
- generateId: this.generateId
442
- });
443
- }
444
- };
445
- var google = new Google();
446
- export {
447
- Google,
448
- google
449
- };
450
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/google-facade.ts","../src/google-generative-ai-language-model.ts","../src/convert-to-google-generative-ai-messages.ts","../src/google-error.ts","../src/map-google-generative-ai-finish-reason.ts"],"sourcesContent":["import { generateId, loadApiKey } from '@ai-sdk/provider-utils';\nimport { GoogleGenerativeAILanguageModel } from './google-generative-ai-language-model';\nimport {\n GoogleGenerativeAIModelId,\n GoogleGenerativeAISettings,\n} from './google-generative-ai-settings';\n\n/**\n * Google provider.\n */\nexport class Google {\n readonly baseUrl?: string;\n readonly apiKey?: string;\n\n private readonly generateId: () => string;\n\n constructor(\n options: {\n baseUrl?: string;\n apiKey?: string;\n generateId?: () => string;\n } = {},\n ) {\n this.baseUrl = options.baseUrl;\n this.apiKey = options.apiKey;\n this.generateId = options.generateId ?? generateId;\n }\n\n private get baseConfig() {\n return {\n baseUrl:\n this.baseUrl ?? 'https://generativelanguage.googleapis.com/v1beta',\n headers: () => ({\n 'x-goog-api-key': loadApiKey({\n apiKey: this.apiKey,\n environmentVariableName: 'GOOGLE_GENERATIVE_AI_API_KEY',\n description: 'Google Generative AI',\n }),\n }),\n };\n }\n\n generativeAI(\n modelId: GoogleGenerativeAIModelId,\n settings: GoogleGenerativeAISettings = {},\n ) {\n return new GoogleGenerativeAILanguageModel(modelId, settings, {\n provider: 'google.generative-ai',\n ...this.baseConfig,\n generateId: this.generateId,\n });\n }\n}\n\n/**\n * Default Google provider instance.\n */\nexport const google = new Google();\n","import {\n LanguageModelV1,\n LanguageModelV1CallWarning,\n LanguageModelV1FinishReason,\n LanguageModelV1StreamPart,\n UnsupportedFunctionalityError,\n} from '@ai-sdk/provider';\nimport {\n ParseResult,\n createEventSourceResponseHandler,\n createJsonResponseHandler,\n postJsonToApi,\n} from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\nimport { convertToGoogleGenerativeAIMessages } from './convert-to-google-generative-ai-messages';\nimport { googleFailedResponseHandler } from './google-error';\nimport { GoogleGenerativeAIContentPart } from './google-generative-ai-prompt';\nimport {\n GoogleGenerativeAIModelId,\n GoogleGenerativeAISettings,\n} from './google-generative-ai-settings';\nimport { mapGoogleGenerativeAIFinishReason } from './map-google-generative-ai-finish-reason';\n\ntype GoogleGenerativeAIConfig = {\n provider: string;\n baseUrl: string;\n headers: () => Record<string, string | undefined>;\n generateId: () => string;\n};\n\nexport class GoogleGenerativeAILanguageModel implements LanguageModelV1 {\n readonly specificationVersion = 'v1';\n readonly defaultObjectGenerationMode = undefined;\n\n readonly modelId: GoogleGenerativeAIModelId;\n readonly settings: GoogleGenerativeAISettings;\n\n private readonly config: GoogleGenerativeAIConfig;\n\n constructor(\n modelId: GoogleGenerativeAIModelId,\n settings: GoogleGenerativeAISettings,\n config: GoogleGenerativeAIConfig,\n ) {\n this.modelId = modelId;\n this.settings = settings;\n this.config = config;\n }\n\n get provider(): string {\n return this.config.provider;\n }\n\n private getArgs({\n mode,\n prompt,\n maxTokens,\n temperature,\n topP,\n frequencyPenalty,\n presencePenalty,\n seed,\n }: Parameters<LanguageModelV1['doGenerate']>[0]) {\n const type = mode.type;\n\n const warnings: LanguageModelV1CallWarning[] = [];\n\n if (frequencyPenalty != null) {\n warnings.push({\n type: 'unsupported-setting',\n setting: 'frequencyPenalty',\n });\n }\n\n if (presencePenalty != null) {\n warnings.push({\n type: 'unsupported-setting',\n setting: 'presencePenalty',\n });\n }\n\n if (seed != null) {\n warnings.push({\n type: 'unsupported-setting',\n setting: 'seed',\n });\n }\n\n const baseArgs = {\n generationConfig: {\n // model specific settings:\n topK: this.settings.topK,\n\n // standardized settings:\n maxOutputTokens: maxTokens,\n temperature,\n topP,\n },\n\n // prompt:\n contents: convertToGoogleGenerativeAIMessages(prompt),\n };\n\n switch (type) {\n case 'regular': {\n const functionDeclarations = mode.tools?.map(tool => ({\n name: tool.name,\n description: tool.description ?? '',\n parameters: prepareJsonSchema(tool.parameters),\n }));\n\n return {\n args: {\n ...baseArgs,\n tools:\n functionDeclarations == null\n ? undefined\n : { functionDeclarations },\n },\n warnings,\n };\n }\n\n case 'object-json': {\n throw new UnsupportedFunctionalityError({\n functionality: 'object-json mode',\n });\n }\n\n case 'object-tool': {\n throw new UnsupportedFunctionalityError({\n functionality: 'object-tool mode',\n });\n }\n\n case 'object-grammar': {\n throw new UnsupportedFunctionalityError({\n functionality: 'object-grammar mode',\n });\n }\n\n default: {\n const _exhaustiveCheck: never = type;\n throw new Error(`Unsupported type: ${_exhaustiveCheck}`);\n }\n }\n }\n\n async doGenerate(\n options: Parameters<LanguageModelV1['doGenerate']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doGenerate']>>> {\n const { args, warnings } = this.getArgs(options);\n\n const response = await postJsonToApi({\n url: `${this.config.baseUrl}/${this.modelId}:generateContent`,\n headers: this.config.headers(),\n body: args,\n failedResponseHandler: googleFailedResponseHandler,\n successfulResponseHandler: createJsonResponseHandler(responseSchema),\n abortSignal: options.abortSignal,\n });\n\n const { contents: rawPrompt, ...rawSettings } = args;\n const candidate = response.candidates[0];\n\n const toolCalls = getToolCallsFromParts({\n parts: candidate.content.parts,\n generateId: this.config.generateId,\n });\n\n return {\n text: getTextFromParts(candidate.content.parts),\n toolCalls,\n finishReason: mapGoogleGenerativeAIFinishReason({\n finishReason: candidate.finishReason,\n hasToolCalls: toolCalls != null && toolCalls.length > 0,\n }),\n usage: {\n promptTokens: NaN,\n completionTokens: candidate.tokenCount ?? NaN,\n },\n rawCall: { rawPrompt, rawSettings },\n warnings,\n };\n }\n\n async doStream(\n options: Parameters<LanguageModelV1['doStream']>[0],\n ): Promise<Awaited<ReturnType<LanguageModelV1['doStream']>>> {\n const { args, warnings } = this.getArgs(options);\n\n const response = await postJsonToApi({\n url: `${this.config.baseUrl}/${this.modelId}:streamGenerateContent?alt=sse`,\n headers: this.config.headers(),\n body: args,\n failedResponseHandler: googleFailedResponseHandler,\n successfulResponseHandler: createEventSourceResponseHandler(chunkSchema),\n abortSignal: options.abortSignal,\n });\n\n const { contents: rawPrompt, ...rawSettings } = args;\n\n let finishReason: LanguageModelV1FinishReason = 'other';\n let usage: { promptTokens: number; completionTokens: number } = {\n promptTokens: Number.NaN,\n completionTokens: Number.NaN,\n };\n\n const generateId = this.config.generateId;\n let hasToolCalls = false;\n\n return {\n stream: response.pipeThrough(\n new TransformStream<\n ParseResult<z.infer<typeof chunkSchema>>,\n LanguageModelV1StreamPart\n >({\n transform(chunk, controller) {\n if (!chunk.success) {\n controller.enqueue({ type: 'error', error: chunk.error });\n return;\n }\n\n const value = chunk.value;\n\n const candidate = value.candidates[0];\n\n if (candidate?.finishReason != null) {\n finishReason = mapGoogleGenerativeAIFinishReason({\n finishReason: candidate.finishReason,\n hasToolCalls,\n });\n }\n\n if (candidate.tokenCount != null) {\n usage = {\n promptTokens: NaN,\n completionTokens: candidate.tokenCount,\n };\n }\n\n const content = candidate.content;\n\n if (content == null) {\n return;\n }\n\n const deltaText = getTextFromParts(content.parts);\n if (deltaText != null) {\n controller.enqueue({\n type: 'text-delta',\n textDelta: deltaText,\n });\n }\n\n const toolCallDeltas = getToolCallsFromParts({\n parts: content.parts,\n generateId,\n });\n\n if (toolCallDeltas != null) {\n for (const toolCall of toolCallDeltas) {\n controller.enqueue({\n type: 'tool-call-delta',\n toolCallType: 'function',\n toolCallId: toolCall.toolCallId,\n toolName: toolCall.toolName,\n argsTextDelta: toolCall.args,\n });\n\n controller.enqueue({\n type: 'tool-call',\n toolCallType: 'function',\n toolCallId: toolCall.toolCallId,\n toolName: toolCall.toolName,\n args: toolCall.args,\n });\n\n hasToolCalls = true;\n }\n }\n },\n\n flush(controller) {\n controller.enqueue({ type: 'finish', finishReason, usage });\n },\n }),\n ),\n rawCall: { rawPrompt, rawSettings },\n warnings,\n };\n }\n}\n\n// Removes all \"additionalProperty\" and \"$schema\" properties from the object (recursively)\n// (not supported by Google Generative AI)\nfunction prepareJsonSchema(jsonSchema: any): unknown {\n if (typeof jsonSchema !== 'object') {\n return jsonSchema;\n }\n\n if (Array.isArray(jsonSchema)) {\n return jsonSchema.map(prepareJsonSchema);\n }\n\n const result: Record<string, any> = {};\n\n for (const [key, value] of Object.entries(jsonSchema)) {\n if (key === 'additionalProperties' || key === '$schema') {\n continue;\n }\n\n result[key] = prepareJsonSchema(value);\n }\n\n return result;\n}\n\nfunction getToolCallsFromParts({\n parts,\n generateId,\n}: {\n parts: z.infer<typeof contentSchema>['parts'];\n generateId: () => string;\n}) {\n const functionCallParts = parts.filter(\n part => 'functionCall' in part,\n ) as Array<\n GoogleGenerativeAIContentPart & {\n functionCall: { name: string; args: unknown };\n }\n >;\n\n return functionCallParts.length === 0\n ? undefined\n : functionCallParts.map(part => ({\n toolCallType: 'function' as const,\n toolCallId: generateId(),\n toolName: part.functionCall.name,\n args: JSON.stringify(part.functionCall.args),\n }));\n}\n\nfunction getTextFromParts(parts: z.infer<typeof contentSchema>['parts']) {\n const textParts = parts.filter(part => 'text' in part) as Array<\n GoogleGenerativeAIContentPart & { text: string }\n >;\n\n return textParts.length === 0\n ? undefined\n : textParts.map(part => part.text).join('');\n}\n\nconst contentSchema = z.object({\n role: z.string(),\n parts: z.array(\n z.union([\n z.object({\n text: z.string(),\n }),\n z.object({\n functionCall: z.object({\n name: z.string(),\n args: z.unknown(),\n }),\n }),\n ]),\n ),\n});\n\n// limited version of the schema, focussed on what is needed for the implementation\n// this approach limits breakages when the API changes and increases efficiency\nconst responseSchema = z.object({\n candidates: z.array(\n z.object({\n content: contentSchema,\n finishReason: z.string().optional(),\n tokenCount: z.number().optional(),\n }),\n ),\n});\n\n// limited version of the schema, focussed on what is needed for the implementation\n// this approach limits breakages when the API changes and increases efficiency\nconst chunkSchema = z.object({\n candidates: z.array(\n z.object({\n content: contentSchema.optional(),\n finishReason: z.string().optional(),\n tokenCount: z.number().optional(),\n }),\n ),\n});\n","import {\n LanguageModelV1Prompt,\n UnsupportedFunctionalityError,\n} from '@ai-sdk/provider';\nimport { convertUint8ArrayToBase64 } from '@ai-sdk/provider-utils';\nimport {\n GoogleGenerativeAIContentPart,\n GoogleGenerativeAIPrompt,\n} from './google-generative-ai-prompt';\n\nexport function convertToGoogleGenerativeAIMessages(\n prompt: LanguageModelV1Prompt,\n): GoogleGenerativeAIPrompt {\n const messages: GoogleGenerativeAIPrompt = [];\n\n for (const { role, content } of prompt) {\n switch (role) {\n case 'system': {\n // system message becomes user message:\n messages.push({ role: 'user', parts: [{ text: content }] });\n\n // required for to ensure turn-taking:\n messages.push({ role: 'model', parts: [{ text: '' }] });\n\n break;\n }\n\n case 'user': {\n messages.push({\n role: 'user',\n parts: content.map(part => {\n switch (part.type) {\n case 'text': {\n return { text: part.text };\n }\n case 'image': {\n if (part.image instanceof URL) {\n throw new UnsupportedFunctionalityError({\n functionality: 'URL image parts',\n });\n } else {\n return {\n inlineData: {\n mimeType: part.mimeType ?? 'image/jpeg',\n data: convertUint8ArrayToBase64(part.image),\n },\n };\n }\n }\n }\n }),\n });\n break;\n }\n\n case 'assistant': {\n messages.push({\n role: 'model',\n parts: content\n .map(part => {\n switch (part.type) {\n case 'text': {\n return part.text.length === 0\n ? undefined\n : { text: part.text };\n }\n case 'tool-call': {\n return {\n functionCall: {\n name: part.toolName,\n args: part.args,\n },\n };\n }\n }\n })\n .filter(\n part => part !== undefined,\n ) as GoogleGenerativeAIContentPart[],\n });\n break;\n }\n\n case 'tool': {\n messages.push({\n role: 'user',\n parts: content.map(part => ({\n functionResponse: {\n name: part.toolName,\n response: part.result,\n },\n })),\n });\n break;\n }\n default: {\n const _exhaustiveCheck: never = role;\n throw new Error(`Unsupported role: ${_exhaustiveCheck}`);\n }\n }\n }\n\n return messages;\n}\n","import { createJsonErrorResponseHandler } from '@ai-sdk/provider-utils';\nimport { z } from 'zod';\n\nconst googleErrorDataSchema = z.object({\n error: z.object({\n code: z.number().nullable(),\n message: z.string(),\n status: z.string(),\n }),\n});\n\nexport type GoogleErrorData = z.infer<typeof googleErrorDataSchema>;\n\nexport const googleFailedResponseHandler = createJsonErrorResponseHandler({\n errorSchema: googleErrorDataSchema,\n errorToMessage: data => data.error.message,\n});\n","import { LanguageModelV1FinishReason } from '@ai-sdk/provider';\n\nexport function mapGoogleGenerativeAIFinishReason({\n finishReason,\n hasToolCalls,\n}: {\n finishReason: string | null | undefined;\n hasToolCalls: boolean;\n}): LanguageModelV1FinishReason {\n switch (finishReason) {\n case 'STOP':\n return hasToolCalls ? 'tool-calls' : 'stop';\n case 'MAX_TOKENS':\n return 'length';\n case 'RECITATION':\n case 'SAFETY':\n return 'content-filter';\n case 'FINISH_REASON_UNSPECIFIED':\n case 'OTHER':\n default:\n return 'other';\n }\n}\n"],"mappings":";AAAA,SAAS,YAAY,kBAAkB;;;ACAvC;AAAA,EAKE,iCAAAA;AAAA,OACK;AACP;AAAA,EAEE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,KAAAC,UAAS;;;ACblB;AAAA,EAEE;AAAA,OACK;AACP,SAAS,iCAAiC;AAMnC,SAAS,oCACd,QAC0B;AAC1B,QAAM,WAAqC,CAAC;AAE5C,aAAW,EAAE,MAAM,QAAQ,KAAK,QAAQ;AACtC,YAAQ,MAAM;AAAA,MACZ,KAAK,UAAU;AAEb,iBAAS,KAAK,EAAE,MAAM,QAAQ,OAAO,CAAC,EAAE,MAAM,QAAQ,CAAC,EAAE,CAAC;AAG1D,iBAAS,KAAK,EAAE,MAAM,SAAS,OAAO,CAAC,EAAE,MAAM,GAAG,CAAC,EAAE,CAAC;AAEtD;AAAA,MACF;AAAA,MAEA,KAAK,QAAQ;AACX,iBAAS,KAAK;AAAA,UACZ,MAAM;AAAA,UACN,OAAO,QAAQ,IAAI,UAAQ;AA9BrC;AA+BY,oBAAQ,KAAK,MAAM;AAAA,cACjB,KAAK,QAAQ;AACX,uBAAO,EAAE,MAAM,KAAK,KAAK;AAAA,cAC3B;AAAA,cACA,KAAK,SAAS;AACZ,oBAAI,KAAK,iBAAiB,KAAK;AAC7B,wBAAM,IAAI,8BAA8B;AAAA,oBACtC,eAAe;AAAA,kBACjB,CAAC;AAAA,gBACH,OAAO;AACL,yBAAO;AAAA,oBACL,YAAY;AAAA,sBACV,WAAU,UAAK,aAAL,YAAiB;AAAA,sBAC3B,MAAM,0BAA0B,KAAK,KAAK;AAAA,oBAC5C;AAAA,kBACF;AAAA,gBACF;AAAA,cACF;AAAA,YACF;AAAA,UACF,CAAC;AAAA,QACH,CAAC;AACD;AAAA,MACF;AAAA,MAEA,KAAK,aAAa;AAChB,iBAAS,KAAK;AAAA,UACZ,MAAM;AAAA,UACN,OAAO,QACJ,IAAI,UAAQ;AACX,oBAAQ,KAAK,MAAM;AAAA,cACjB,KAAK,QAAQ;AACX,uBAAO,KAAK,KAAK,WAAW,IACxB,SACA,EAAE,MAAM,KAAK,KAAK;AAAA,cACxB;AAAA,cACA,KAAK,aAAa;AAChB,uBAAO;AAAA,kBACL,cAAc;AAAA,oBACZ,MAAM,KAAK;AAAA,oBACX,MAAM,KAAK;AAAA,kBACb;AAAA,gBACF;AAAA,cACF;AAAA,YACF;AAAA,UACF,CAAC,EACA;AAAA,YACC,UAAQ,SAAS;AAAA,UACnB;AAAA,QACJ,CAAC;AACD;AAAA,MACF;AAAA,MAEA,KAAK,QAAQ;AACX,iBAAS,KAAK;AAAA,UACZ,MAAM;AAAA,UACN,OAAO,QAAQ,IAAI,WAAS;AAAA,YAC1B,kBAAkB;AAAA,cAChB,MAAM,KAAK;AAAA,cACX,UAAU,KAAK;AAAA,YACjB;AAAA,UACF,EAAE;AAAA,QACJ,CAAC;AACD;AAAA,MACF;AAAA,MACA,SAAS;AACP,cAAM,mBAA0B;AAChC,cAAM,IAAI,MAAM,qBAAqB,gBAAgB,EAAE;AAAA,MACzD;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;;;ACvGA,SAAS,sCAAsC;AAC/C,SAAS,SAAS;AAElB,IAAM,wBAAwB,EAAE,OAAO;AAAA,EACrC,OAAO,EAAE,OAAO;AAAA,IACd,MAAM,EAAE,OAAO,EAAE,SAAS;AAAA,IAC1B,SAAS,EAAE,OAAO;AAAA,IAClB,QAAQ,EAAE,OAAO;AAAA,EACnB,CAAC;AACH,CAAC;AAIM,IAAM,8BAA8B,+BAA+B;AAAA,EACxE,aAAa;AAAA,EACb,gBAAgB,UAAQ,KAAK,MAAM;AACrC,CAAC;;;ACdM,SAAS,kCAAkC;AAAA,EAChD;AAAA,EACA;AACF,GAGgC;AAC9B,UAAQ,cAAc;AAAA,IACpB,KAAK;AACH,aAAO,eAAe,eAAe;AAAA,IACvC,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AAAA,IACL,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AAAA,IACL,KAAK;AAAA,IACL;AACE,aAAO;AAAA,EACX;AACF;;;AHQO,IAAM,kCAAN,MAAiE;AAAA,EAStE,YACE,SACA,UACA,QACA;AAZF,SAAS,uBAAuB;AAChC,SAAS,8BAA8B;AAYrC,SAAK,UAAU;AACf,SAAK,WAAW;AAChB,SAAK,SAAS;AAAA,EAChB;AAAA,EAEA,IAAI,WAAmB;AACrB,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEQ,QAAQ;AAAA,IACd;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,GAAiD;AA9DnD;AA+DI,UAAM,OAAO,KAAK;AAElB,UAAM,WAAyC,CAAC;AAEhD,QAAI,oBAAoB,MAAM;AAC5B,eAAS,KAAK;AAAA,QACZ,MAAM;AAAA,QACN,SAAS;AAAA,MACX,CAAC;AAAA,IACH;AAEA,QAAI,mBAAmB,MAAM;AAC3B,eAAS,KAAK;AAAA,QACZ,MAAM;AAAA,QACN,SAAS;AAAA,MACX,CAAC;AAAA,IACH;AAEA,QAAI,QAAQ,MAAM;AAChB,eAAS,KAAK;AAAA,QACZ,MAAM;AAAA,QACN,SAAS;AAAA,MACX,CAAC;AAAA,IACH;AAEA,UAAM,WAAW;AAAA,MACf,kBAAkB;AAAA;AAAA,QAEhB,MAAM,KAAK,SAAS;AAAA;AAAA,QAGpB,iBAAiB;AAAA,QACjB;AAAA,QACA;AAAA,MACF;AAAA;AAAA,MAGA,UAAU,oCAAoC,MAAM;AAAA,IACtD;AAEA,YAAQ,MAAM;AAAA,MACZ,KAAK,WAAW;AACd,cAAM,wBAAuB,UAAK,UAAL,mBAAY,IAAI,UAAK;AAzG1D,cAAAC;AAyG8D;AAAA,YACpD,MAAM,KAAK;AAAA,YACX,cAAaA,MAAA,KAAK,gBAAL,OAAAA,MAAoB;AAAA,YACjC,YAAY,kBAAkB,KAAK,UAAU;AAAA,UAC/C;AAAA;AAEA,eAAO;AAAA,UACL,MAAM;AAAA,YACJ,GAAG;AAAA,YACH,OACE,wBAAwB,OACpB,SACA,EAAE,qBAAqB;AAAA,UAC/B;AAAA,UACA;AAAA,QACF;AAAA,MACF;AAAA,MAEA,KAAK,eAAe;AAClB,cAAM,IAAIC,+BAA8B;AAAA,UACtC,eAAe;AAAA,QACjB,CAAC;AAAA,MACH;AAAA,MAEA,KAAK,eAAe;AAClB,cAAM,IAAIA,+BAA8B;AAAA,UACtC,eAAe;AAAA,QACjB,CAAC;AAAA,MACH;AAAA,MAEA,KAAK,kBAAkB;AACrB,cAAM,IAAIA,+BAA8B;AAAA,UACtC,eAAe;AAAA,QACjB,CAAC;AAAA,MACH;AAAA,MAEA,SAAS;AACP,cAAM,mBAA0B;AAChC,cAAM,IAAI,MAAM,qBAAqB,gBAAgB,EAAE;AAAA,MACzD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,WACJ,SAC6D;AAtJjE;AAuJI,UAAM,EAAE,MAAM,SAAS,IAAI,KAAK,QAAQ,OAAO;AAE/C,UAAM,WAAW,MAAM,cAAc;AAAA,MACnC,KAAK,GAAG,KAAK,OAAO,OAAO,IAAI,KAAK,OAAO;AAAA,MAC3C,SAAS,KAAK,OAAO,QAAQ;AAAA,MAC7B,MAAM;AAAA,MACN,uBAAuB;AAAA,MACvB,2BAA2B,0BAA0B,cAAc;AAAA,MACnE,aAAa,QAAQ;AAAA,IACvB,CAAC;AAED,UAAM,EAAE,UAAU,WAAW,GAAG,YAAY,IAAI;AAChD,UAAM,YAAY,SAAS,WAAW,CAAC;AAEvC,UAAM,YAAY,sBAAsB;AAAA,MACtC,OAAO,UAAU,QAAQ;AAAA,MACzB,YAAY,KAAK,OAAO;AAAA,IAC1B,CAAC;AAED,WAAO;AAAA,MACL,MAAM,iBAAiB,UAAU,QAAQ,KAAK;AAAA,MAC9C;AAAA,MACA,cAAc,kCAAkC;AAAA,QAC9C,cAAc,UAAU;AAAA,QACxB,cAAc,aAAa,QAAQ,UAAU,SAAS;AAAA,MACxD,CAAC;AAAA,MACD,OAAO;AAAA,QACL,cAAc;AAAA,QACd,mBAAkB,eAAU,eAAV,YAAwB;AAAA,MAC5C;AAAA,MACA,SAAS,EAAE,WAAW,YAAY;AAAA,MAClC;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,SACJ,SAC2D;AAC3D,UAAM,EAAE,MAAM,SAAS,IAAI,KAAK,QAAQ,OAAO;AAE/C,UAAM,WAAW,MAAM,cAAc;AAAA,MACnC,KAAK,GAAG,KAAK,OAAO,OAAO,IAAI,KAAK,OAAO;AAAA,MAC3C,SAAS,KAAK,OAAO,QAAQ;AAAA,MAC7B,MAAM;AAAA,MACN,uBAAuB;AAAA,MACvB,2BAA2B,iCAAiC,WAAW;AAAA,MACvE,aAAa,QAAQ;AAAA,IACvB,CAAC;AAED,UAAM,EAAE,UAAU,WAAW,GAAG,YAAY,IAAI;AAEhD,QAAI,eAA4C;AAChD,QAAI,QAA4D;AAAA,MAC9D,cAAc,OAAO;AAAA,MACrB,kBAAkB,OAAO;AAAA,IAC3B;AAEA,UAAMC,cAAa,KAAK,OAAO;AAC/B,QAAI,eAAe;AAEnB,WAAO;AAAA,MACL,QAAQ,SAAS;AAAA,QACf,IAAI,gBAGF;AAAA,UACA,UAAU,OAAO,YAAY;AAC3B,gBAAI,CAAC,MAAM,SAAS;AAClB,yBAAW,QAAQ,EAAE,MAAM,SAAS,OAAO,MAAM,MAAM,CAAC;AACxD;AAAA,YACF;AAEA,kBAAM,QAAQ,MAAM;AAEpB,kBAAM,YAAY,MAAM,WAAW,CAAC;AAEpC,iBAAI,uCAAW,iBAAgB,MAAM;AACnC,6BAAe,kCAAkC;AAAA,gBAC/C,cAAc,UAAU;AAAA,gBACxB;AAAA,cACF,CAAC;AAAA,YACH;AAEA,gBAAI,UAAU,cAAc,MAAM;AAChC,sBAAQ;AAAA,gBACN,cAAc;AAAA,gBACd,kBAAkB,UAAU;AAAA,cAC9B;AAAA,YACF;AAEA,kBAAM,UAAU,UAAU;AAE1B,gBAAI,WAAW,MAAM;AACnB;AAAA,YACF;AAEA,kBAAM,YAAY,iBAAiB,QAAQ,KAAK;AAChD,gBAAI,aAAa,MAAM;AACrB,yBAAW,QAAQ;AAAA,gBACjB,MAAM;AAAA,gBACN,WAAW;AAAA,cACb,CAAC;AAAA,YACH;AAEA,kBAAM,iBAAiB,sBAAsB;AAAA,cAC3C,OAAO,QAAQ;AAAA,cACf,YAAAA;AAAA,YACF,CAAC;AAED,gBAAI,kBAAkB,MAAM;AAC1B,yBAAW,YAAY,gBAAgB;AACrC,2BAAW,QAAQ;AAAA,kBACjB,MAAM;AAAA,kBACN,cAAc;AAAA,kBACd,YAAY,SAAS;AAAA,kBACrB,UAAU,SAAS;AAAA,kBACnB,eAAe,SAAS;AAAA,gBAC1B,CAAC;AAED,2BAAW,QAAQ;AAAA,kBACjB,MAAM;AAAA,kBACN,cAAc;AAAA,kBACd,YAAY,SAAS;AAAA,kBACrB,UAAU,SAAS;AAAA,kBACnB,MAAM,SAAS;AAAA,gBACjB,CAAC;AAED,+BAAe;AAAA,cACjB;AAAA,YACF;AAAA,UACF;AAAA,UAEA,MAAM,YAAY;AAChB,uBAAW,QAAQ,EAAE,MAAM,UAAU,cAAc,MAAM,CAAC;AAAA,UAC5D;AAAA,QACF,CAAC;AAAA,MACH;AAAA,MACA,SAAS,EAAE,WAAW,YAAY;AAAA,MAClC;AAAA,IACF;AAAA,EACF;AACF;AAIA,SAAS,kBAAkB,YAA0B;AACnD,MAAI,OAAO,eAAe,UAAU;AAClC,WAAO;AAAA,EACT;AAEA,MAAI,MAAM,QAAQ,UAAU,GAAG;AAC7B,WAAO,WAAW,IAAI,iBAAiB;AAAA,EACzC;AAEA,QAAM,SAA8B,CAAC;AAErC,aAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,UAAU,GAAG;AACrD,QAAI,QAAQ,0BAA0B,QAAQ,WAAW;AACvD;AAAA,IACF;AAEA,WAAO,GAAG,IAAI,kBAAkB,KAAK;AAAA,EACvC;AAEA,SAAO;AACT;AAEA,SAAS,sBAAsB;AAAA,EAC7B;AAAA,EACA,YAAAA;AACF,GAGG;AACD,QAAM,oBAAoB,MAAM;AAAA,IAC9B,UAAQ,kBAAkB;AAAA,EAC5B;AAMA,SAAO,kBAAkB,WAAW,IAChC,SACA,kBAAkB,IAAI,WAAS;AAAA,IAC7B,cAAc;AAAA,IACd,YAAYA,YAAW;AAAA,IACvB,UAAU,KAAK,aAAa;AAAA,IAC5B,MAAM,KAAK,UAAU,KAAK,aAAa,IAAI;AAAA,EAC7C,EAAE;AACR;AAEA,SAAS,iBAAiB,OAA+C;AACvE,QAAM,YAAY,MAAM,OAAO,UAAQ,UAAU,IAAI;AAIrD,SAAO,UAAU,WAAW,IACxB,SACA,UAAU,IAAI,UAAQ,KAAK,IAAI,EAAE,KAAK,EAAE;AAC9C;AAEA,IAAM,gBAAgBC,GAAE,OAAO;AAAA,EAC7B,MAAMA,GAAE,OAAO;AAAA,EACf,OAAOA,GAAE;AAAA,IACPA,GAAE,MAAM;AAAA,MACNA,GAAE,OAAO;AAAA,QACP,MAAMA,GAAE,OAAO;AAAA,MACjB,CAAC;AAAA,MACDA,GAAE,OAAO;AAAA,QACP,cAAcA,GAAE,OAAO;AAAA,UACrB,MAAMA,GAAE,OAAO;AAAA,UACf,MAAMA,GAAE,QAAQ;AAAA,QAClB,CAAC;AAAA,MACH,CAAC;AAAA,IACH,CAAC;AAAA,EACH;AACF,CAAC;AAID,IAAM,iBAAiBA,GAAE,OAAO;AAAA,EAC9B,YAAYA,GAAE;AAAA,IACZA,GAAE,OAAO;AAAA,MACP,SAAS;AAAA,MACT,cAAcA,GAAE,OAAO,EAAE,SAAS;AAAA,MAClC,YAAYA,GAAE,OAAO,EAAE,SAAS;AAAA,IAClC,CAAC;AAAA,EACH;AACF,CAAC;AAID,IAAM,cAAcA,GAAE,OAAO;AAAA,EAC3B,YAAYA,GAAE;AAAA,IACZA,GAAE,OAAO;AAAA,MACP,SAAS,cAAc,SAAS;AAAA,MAChC,cAAcA,GAAE,OAAO,EAAE,SAAS;AAAA,MAClC,YAAYA,GAAE,OAAO,EAAE,SAAS;AAAA,IAClC,CAAC;AAAA,EACH;AACF,CAAC;;;AD9XM,IAAM,SAAN,MAAa;AAAA,EAMlB,YACE,UAII,CAAC,GACL;AAtBJ;AAuBI,SAAK,UAAU,QAAQ;AACvB,SAAK,SAAS,QAAQ;AACtB,SAAK,cAAa,aAAQ,eAAR,YAAsB;AAAA,EAC1C;AAAA,EAEA,IAAY,aAAa;AA5B3B;AA6BI,WAAO;AAAA,MACL,UACE,UAAK,YAAL,YAAgB;AAAA,MAClB,SAAS,OAAO;AAAA,QACd,kBAAkB,WAAW;AAAA,UAC3B,QAAQ,KAAK;AAAA,UACb,yBAAyB;AAAA,UACzB,aAAa;AAAA,QACf,CAAC;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAAA,EAEA,aACE,SACA,WAAuC,CAAC,GACxC;AACA,WAAO,IAAI,gCAAgC,SAAS,UAAU;AAAA,MAC5D,UAAU;AAAA,MACV,GAAG,KAAK;AAAA,MACR,YAAY,KAAK;AAAA,IACnB,CAAC;AAAA,EACH;AACF;AAKO,IAAM,SAAS,IAAI,OAAO;","names":["UnsupportedFunctionalityError","z","_a","UnsupportedFunctionalityError","generateId","z"]}