Firebase AI Logic and its client SDKs were formerly called "Vertex AI in Firebase". To better reflect our expanded services and features (for example, we now support the Gemini Developer API!), we renamed and repackaged our services into Firebase AI Logic.
To securely access Google's generative AI models directly from your mobile or web apps, you can now choose a "Gemini API" provider — either the long-available Vertex AI Gemini API or now the Gemini Developer API. This means that you now have the option to use the Gemini Developer API, which provides a no-cost tier with reasonable rate limits and quotas.
Overview of steps to migrate to the Firebase AI Logic SDKs
Step 1: Choose the best "Gemini API" provider for your app and use cases.
Step 2: Set up your Firebase project so that you can use the Gemini Developer API.
Only applicable if you're swapping to use the Gemini Developer API instead of the Vertex AI Gemini API.Step 3: Update the library used in your app.
Step 4: Update the initialization in your app.
Step 5: Update your code depending on the features that you use.
Step 1: Choose the best "Gemini API" provider for your app
With this migration, you have a choice in "Gemini API" provider:
The old "Vertex AI in Firebase" SDKs could only use the Vertex AI Gemini API.
The new Firebase AI Logic SDKs let you choose which "Gemini API" provider you want to call directly from your mobile or web app – either the Gemini Developer API or the Vertex AI Gemini API.
Review the differences between using the two Gemini API providers, especially in terms of supported features, pricing, and rate limits. For just one example, the Gemini Developer API doesn't support providing files using Cloud Storage URLs, but it might be a good choice if you want to take advantage of its no-cost tier and reasonable quota.
If you want to keep using the Vertex AI Gemini API:
Skip the next step and jump straight to updating the library in your app, and then the rest of this guide.If you want to swap to the Gemini Developer API:
Continue to the next step to set up your Firebase project to use that API, and then the rest of this guide.
Step 2: Set up your Firebase project so that you can use the Gemini Developer API
This step is only required if you want to swap to using the Gemini Developer API with the Firebase AI Logic client SDKs. However, if you want to keep using the Vertex AI Gemini API, skip to the next step.
Note that it's OK to have both of the "Gemini API" providers enabled in your project at the same time.
In the Firebase console, go to the Firebase AI Logic page.
Go to the Settings tab, and select Gemini Developer API.
Enable the Gemini Developer API.
The console will make sure the required APIs are enabled and generate a Gemini API key in your Firebase project.
Continue in this migration guide to update the library and initialization in your app.
Step 3: Update the library used in your app
Update your app's codebase to use the Firebase AI Logic library.
Swift
In Xcode, with your app project open, update your Firebase package to v11.13.0 or later using one of the following options:
Option 1: Update all packages: Navigate to File > Packages > Update to Latest Package Versions.
Option 2: Update Firebase individually: Navigate to the Firebase package in the section called Package Dependencies. Right-click on the Firebase package, and then select Update Package.
Make sure that the Firebase package now shows v11.13.0 or later. If it doesn't, verify that your specified Package Requirements allow updating to v11.13.0 or later.
Select your app's target in the Project Editor, and then navigate to the Frameworks, Libraries, and Embedded Content section.
Add the new library: Select the + button, and then add FirebaseAI from the Firebase package.
After you've finished migrating your app (see the remaining sections in this guide), make sure to remove the old library:
Select FirebaseVertexAI, and then press the — button.
Kotlin
In your module (app-level) Gradle file (usually
<project>/<app-module>/build.gradle.kts
or<project>/<app-module>/build.gradle
), replace old dependencies (as applicable) with the following.Note that it might be easier to migrate your app's codebase (see the remaining sections in this guide) before deleting the old dependency.
// BEFORE dependencies { implementation(platform("com.google.firebase:firebase-bom:33.x.y"))
implementation("com.google.firebase:firebase-vertexai")// OR if not using the BoMimplementation("com.google.firebase:firebase-vertexai:16.x.y")} // AFTER dependencies { // Import the BoM for the Firebase platform implementation(platform("com.google.firebase:firebase-bom:33.13.0")) // Add the dependency for the Firebase AI Logic library // When using the BoM, you don't specify versions in Firebase library dependencies implementation("com.google.firebase:firebase-ai") }Sync your Android project with Gradle files.
Note that if you choose to not use the Firebase Android BoM, then just add
the dependency for the firebase-ai
library and accept the latest version
that's suggested by Android Studio.
Java
In your module (app-level) Gradle file (usually
<project>/<app-module>/build.gradle.kts
or<project>/<app-module>/build.gradle
), replace old dependencies (as applicable) with the following.Note that it might be easier to migrate your app's codebase (see the remaining sections in this guide) before deleting the old dependency.
// BEFORE dependencies { implementation(platform("com.google.firebase:firebase-bom:33.x.y"))
implementation("com.google.firebase:firebase-vertexai")// OR if not using the BoMimplementation("com.google.firebase:firebase-vertexai:16.x.y")} // AFTER dependencies { // Import the BoM for the Firebase platform implementation(platform("com.google.firebase:firebase-bom:33.13.0")) // Add the dependency for the Firebase AI Logic library // When using the BoM, you don't specify versions in Firebase library dependencies implementation("com.google.firebase:firebase-ai") }Sync your Android project with Gradle files.
Note that if you choose to not use the Firebase Android BoM, then just add
the dependency for the firebase-ai
library and accept the latest version
that's suggested by Android Studio.
Web
Get the latest version of the Firebase JS SDK for Web using npm:
npm i firebase@latest
OR
yarn add firebase@latest
Wherever you've imported the library, update your import statements to use
firebase/ai
instead.Note that it might be easier to migrate your app's codebase (see the remaining sections in this guide) before deleting the old imports.
// BEFORE import { initializeApp } from "firebase/app";
import { getVertexAI, getGenerativeModel } from "firebase/vertexai";// AFTER import { initializeApp } from "firebase/app"; import { getAI, getGenerativeModel } from "firebase/ai";
Dart
Update to the use the
firebase_ai
package in yourpubspec.yaml
file by running the following command from your Flutter project directory:flutter pub add firebase_ai
Rebuild your Flutter project:
flutter run
After you've finished migrating your app (see the remaining sections in this guide), make sure to delete the old package:
flutter pub remove firebase_vertexai
Unity
Support for Unity wasn't available from "Vertex AI in Firebase".
Learn how to get started with the Firebase AI Logic SDK for Unity.
Step 4: Update the initialization in your app
Click your Gemini API provider to view provider-specific content and code on this page. |
Update how you initialize the service for your chosen API provider and
create a GenerativeModel
instance.
Swift
import FirebaseAI
// Initialize the Gemini Developer API backend service
let ai = FirebaseAI.firebaseAI(backend: .googleAI())
// Create a `GenerativeModel` instance with a model that supports your use case
let model = ai.generativeModel(modelName: "gemini-2.0-flash")
Kotlin
// Initialize the Gemini Developer API backend service
// Create a `GenerativeModel` instance with a model that supports your use case
val model = Firebase.ai(backend = GenerativeBackend.googleAI())
.generativeModel("gemini-2.0-flash")
Java
// Initialize the Gemini Developer API backend service
// Create a `GenerativeModel` instance with a model that supports your use case
GenerativeModel ai = FirebaseAI.getInstance(GenerativeBackend.googleAI())
.generativeModel("gemini-2.0-flash");
// Use the GenerativeModelFutures Java compatibility layer which offers
// support for ListenableFuture and Publisher APIs
GenerativeModelFutures model = GenerativeModelFutures.from(ai);
Web
import { initializeApp } from "firebase/app";
import { getAI, getGenerativeModel, GoogleAIBackend } from "firebase/ai";
// TODO(developer) Replace the following with your app's Firebase configuration
// See: https://firebase.google.com/docs/web/learn-more#config-object
const firebaseConfig = {
// ...
};
// Initialize FirebaseApp
const firebaseApp = initializeApp(firebaseConfig);
// Initialize the Gemini Developer API backend service
const ai = getAI(firebaseApp, { backend: new GoogleAIBackend() });
// Create a `GenerativeModel` instance with a model that supports your use case
const model = getGenerativeModel(ai, { model: "gemini-2.0-flash" });
Dart
import 'package:firebase_ai/firebase_ai.dart';
import 'package:firebase_core/firebase_core.dart';
import 'firebase_options.dart';
// Initialize FirebaseApp
await Firebase.initializeApp(
options: DefaultFirebaseOptions.currentPlatform,
);
// Initialize the Gemini Developer API backend service
// Create a `GenerativeModel` instance with a model that supports your use case
final model =
FirebaseAI.googleAI().generativeModel(model: 'gemini-2.0-flash');
Unity
Support for Unity wasn't available from "Vertex AI in Firebase".
Learn how to get started with the Firebase AI Logic SDK for Unity.
Note that depending on the capability you're using, you might not always
create a GenerativeModel
instance.
- To access an Imagen model,
create an
ImagenModel
instance.
Step 5: Update your code depending on features that you use
This step describes changes that may be required depending on which features you use.
If you use Cloud Storage URLs and you swapped to use the Gemini Developer API in this migration, then you need to update your multimodal requests to include files as inline data (or use YouTube URLs for videos).
Review the following lists for any changes that you might need to make in your code to accommodate taking up the Firebase AI Logic SDK.
Swift
No additional changes.
Kotlin
Live API
- Removed
UNSPECIFIED
value for enum classResponseModality
. Instead usenull
.
- Removed
Java
Live API
- Removed
UNSPECIFIED
value for enum classResponseModality
. Instead usenull
.
- Removed
Changed various Java builder methods to now correctly return the instance of their class, instead of void.
Web
Changes required only if you're starting to use the Gemini Developer API (instead of the Vertex AI Gemini API):
Safety settings
- Removed usages of the unsupported
SafetySetting.method
.
- Removed usages of the unsupported
Inline data
- Removed usages of the unsupported
InlineDataPart.videoMetadata
.
- Removed usages of the unsupported
Dart
No additional changes.
Unity
Support for Unity wasn't available from "Vertex AI in Firebase".
Learn how to get started with the Firebase AI Logic SDK for Unity.
Give feedback about your experience with Firebase AI Logic