@firebase/ai 2.3.0-20250917161512 → 2.3.0-canary.0ffcb26af

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.
@@ -14,7 +14,7 @@
14
14
  * See the License for the specific language governing permissions and
15
15
  * limitations under the License.
16
16
  */
17
- import { Tool, GenerationConfig, Citation, FinishReason, GroundingMetadata, PromptFeedback, SafetyRating, UsageMetadata } from '../public-types';
17
+ import { Tool, GenerationConfig, Citation, FinishReason, GroundingMetadata, PromptFeedback, SafetyRating, UsageMetadata, URLContextMetadata } from '../public-types';
18
18
  import { Content, Part } from './content';
19
19
  /**
20
20
  * @internal
@@ -47,6 +47,7 @@ export interface GoogleAIGenerateContentCandidate {
47
47
  safetyRatings?: SafetyRating[];
48
48
  citationMetadata?: GoogleAICitationMetadata;
49
49
  groundingMetadata?: GroundingMetadata;
50
+ urlContextMetadata?: URLContextMetadata;
50
51
  }
51
52
  /**
52
53
  * @internal
@@ -218,7 +218,7 @@ export interface RequestOptions {
218
218
  * Defines a tool that model can call to access external knowledge.
219
219
  * @public
220
220
  */
221
- export type Tool = FunctionDeclarationsTool | GoogleSearchTool | CodeExecutionTool;
221
+ export type Tool = FunctionDeclarationsTool | GoogleSearchTool | CodeExecutionTool | URLContextTool;
222
222
  /**
223
223
  * Structured representation of a function declaration as defined by the
224
224
  * {@link https://spec.openapis.org/oas/v3.0.3 | OpenAPI 3.0 specification}.
@@ -291,6 +291,26 @@ export interface CodeExecutionTool {
291
291
  */
292
292
  export interface GoogleSearch {
293
293
  }
294
+ /**
295
+ * A tool that allows you to provide additional context to the models in the form of public web
296
+ * URLs. By including URLs in your request, the Gemini model will access the content from those
297
+ * pages to inform and enhance its response.
298
+ *
299
+ * @beta
300
+ */
301
+ export interface URLContextTool {
302
+ /**
303
+ * Specifies the URL Context configuration.
304
+ */
305
+ urlContext: URLContext;
306
+ }
307
+ /**
308
+ * Specifies the URL Context configuration.
309
+ *
310
+ * @beta
311
+ */
312
+ export interface URLContext {
313
+ }
294
314
  /**
295
315
  * A `FunctionDeclarationsTool` is a piece of code that enables the system to
296
316
  * interact with external systems to perform an action, or set of actions,
@@ -102,8 +102,16 @@ export interface UsageMetadata {
102
102
  */
103
103
  thoughtsTokenCount?: number;
104
104
  totalTokenCount: number;
105
+ /**
106
+ * The number of tokens used by tools.
107
+ */
108
+ toolUsePromptTokenCount?: number;
105
109
  promptTokensDetails?: ModalityTokenCount[];
106
110
  candidatesTokensDetails?: ModalityTokenCount[];
111
+ /**
112
+ * A list of tokens used by tools, broken down by modality.
113
+ */
114
+ toolUsePromptTokensDetails?: ModalityTokenCount[];
107
115
  }
108
116
  /**
109
117
  * Represents token counting info for a single modality.
@@ -143,6 +151,7 @@ export interface GenerateContentCandidate {
143
151
  safetyRatings?: SafetyRating[];
144
152
  citationMetadata?: CitationMetadata;
145
153
  groundingMetadata?: GroundingMetadata;
154
+ urlContextMetadata?: URLContextMetadata;
146
155
  }
147
156
  /**
148
157
  * Citation metadata that may be found on a {@link GenerateContentCandidate}.
@@ -323,6 +332,89 @@ export interface Segment {
323
332
  */
324
333
  text: string;
325
334
  }
335
+ /**
336
+ * Metadata related to {@link URLContextTool}.
337
+ *
338
+ * @beta
339
+ */
340
+ export interface URLContextMetadata {
341
+ /**
342
+ * List of URL metadata used to provide context to the Gemini model.
343
+ */
344
+ urlMetadata: URLMetadata[];
345
+ }
346
+ /**
347
+ * Metadata for a single URL retrieved by the {@link URLContextTool} tool.
348
+ *
349
+ * @beta
350
+ */
351
+ export interface URLMetadata {
352
+ /**
353
+ * The retrieved URL.
354
+ */
355
+ retrievedUrl?: string;
356
+ /**
357
+ * The status of the URL retrieval.
358
+ */
359
+ urlRetrievalStatus?: URLRetrievalStatus;
360
+ }
361
+ /**
362
+ * The status of a URL retrieval.
363
+ *
364
+ * @remarks
365
+ * <b>URL_RETRIEVAL_STATUS_UNSPECIFIED:</b> Unspecified retrieval status.
366
+ * <br/>
367
+ * <b>URL_RETRIEVAL_STATUS_SUCCESS:</b> The URL retrieval was successful.
368
+ * <br/>
369
+ * <b>URL_RETRIEVAL_STATUS_ERROR:</b> The URL retrieval failed.
370
+ * <br/>
371
+ * <b>URL_RETRIEVAL_STATUS_PAYWALL:</b> The URL retrieval failed because the content is behind a paywall.
372
+ * <br/>
373
+ * <b>URL_RETRIEVAL_STATUS_UNSAFE:</b> The URL retrieval failed because the content is unsafe.
374
+ * <br/>
375
+ *
376
+ * @beta
377
+ */
378
+ export declare const URLRetrievalStatus: {
379
+ /**
380
+ * Unspecified retrieval status.
381
+ */
382
+ URL_RETRIEVAL_STATUS_UNSPECIFIED: string;
383
+ /**
384
+ * The URL retrieval was successful.
385
+ */
386
+ URL_RETRIEVAL_STATUS_SUCCESS: string;
387
+ /**
388
+ * The URL retrieval failed.
389
+ */
390
+ URL_RETRIEVAL_STATUS_ERROR: string;
391
+ /**
392
+ * The URL retrieval failed because the content is behind a paywall.
393
+ */
394
+ URL_RETRIEVAL_STATUS_PAYWALL: string;
395
+ /**
396
+ * The URL retrieval failed because the content is unsafe.
397
+ */
398
+ URL_RETRIEVAL_STATUS_UNSAFE: string;
399
+ };
400
+ /**
401
+ * The status of a URL retrieval.
402
+ *
403
+ * @remarks
404
+ * <b>URL_RETRIEVAL_STATUS_UNSPECIFIED:</b> Unspecified retrieval status.
405
+ * <br/>
406
+ * <b>URL_RETRIEVAL_STATUS_SUCCESS:</b> The URL retrieval was successful.
407
+ * <br/>
408
+ * <b>URL_RETRIEVAL_STATUS_ERROR:</b> The URL retrieval failed.
409
+ * <br/>
410
+ * <b>URL_RETRIEVAL_STATUS_PAYWALL:</b> The URL retrieval failed because the content is behind a paywall.
411
+ * <br/>
412
+ * <b>URL_RETRIEVAL_STATUS_UNSAFE:</b> The URL retrieval failed because the content is unsafe.
413
+ * <br/>
414
+ *
415
+ * @beta
416
+ */
417
+ export type URLRetrievalStatus = (typeof URLRetrievalStatus)[keyof typeof URLRetrievalStatus];
326
418
  /**
327
419
  * @public
328
420
  */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@firebase/ai",
3
- "version": "2.3.0-20250917161512",
3
+ "version": "2.3.0-canary.0ffcb26af",
4
4
  "description": "The Firebase AI SDK",
5
5
  "author": "Firebase <firebase-support@google.com> (https://firebase.google.com/)",
6
6
  "engines": {
@@ -48,19 +48,19 @@
48
48
  "trusted-type-check": "tsec -p tsconfig.json --noEmit"
49
49
  },
50
50
  "peerDependencies": {
51
- "@firebase/app": "0.x",
52
- "@firebase/app-types": "0.x"
51
+ "@firebase/app": "0.14.3-canary.0ffcb26af",
52
+ "@firebase/app-types": "0.9.3-canary.0ffcb26af"
53
53
  },
54
54
  "dependencies": {
55
- "@firebase/app-check-interop-types": "0.3.3",
56
- "@firebase/component": "0.7.0",
57
- "@firebase/logger": "0.5.0",
58
- "@firebase/util": "1.13.0",
55
+ "@firebase/app-check-interop-types": "0.3.3-canary.0ffcb26af",
56
+ "@firebase/component": "0.7.0-canary.0ffcb26af",
57
+ "@firebase/logger": "0.5.0-canary.0ffcb26af",
58
+ "@firebase/util": "1.13.0-canary.0ffcb26af",
59
59
  "tslib": "^2.1.0"
60
60
  },
61
61
  "license": "Apache-2.0",
62
62
  "devDependencies": {
63
- "@firebase/app": "0.14.2",
63
+ "@firebase/app": "0.14.3-canary.0ffcb26af",
64
64
  "@rollup/plugin-json": "6.1.0",
65
65
  "rollup": "2.79.2",
66
66
  "rollup-plugin-replace": "2.2.0",