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: Enable the required APIs. 
- 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.
Step 2: Enable the required APIs
Ensure that all required APIs are enabled in your Firebase project to use your chosen "Gemini API" provider.
Note that you can have both of API providers enabled in your project at the same time.
- Sign into the Firebase console, and then select your Firebase project. 
- In the Firebase console, go to the Firebase AI Logic page. 
- Click Get started to launch a guided workflow that helps you set up the required APIs and resources for your project. 
- Select the "Gemini API" provider that you'd like to use with the Firebase AI Logic SDKs. You can always set up and use the other API provider later, if you'd like. - Gemini Developer API — billing optional (available on the no-cost Spark pricing plan) 
 The console's workflow will enable the required APIs and create a Gemini API key in your project.
 Do not add this Gemini API key into your app's codebase. Learn more.
- Vertex AI Gemini API — billing required (requires the pay-as-you-go Blaze pricing plan) 
 The console's workflow will enable the required APIs in your 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-Preview, and then press the — button.
Kotlin
- In your module (app-level) Gradle file (usually - <project>/<app-module>/build.gradle.ktsor- <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("com.google.firebase:firebase-vertexai:16.0.0-betaXX")} // AFTER dependencies { // Import the BoM for the Firebase platform implementation(platform("com.google.firebase:firebase-bom:34.4.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.ktsor- <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("com.google.firebase:firebase-vertexai:16.0.0-betaXX")} // AFTER dependencies { // Import the BoM for the Firebase platform implementation(platform("com.google.firebase:firebase-bom:34.4.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/aiinstead.- 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-preview";// AFTER import { initializeApp } from "firebase/app"; import { getAI, getGenerativeModel } from "firebase/ai";
Dart
- Update to the use the - firebase_aipackage in your- pubspec.yamlfile 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.5-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.5-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.5-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.5-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.5-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 ImagenModelinstance.
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 must update your multimodal requests to include files as inline data (or use YouTube URLs for videos). 
- Several changes were introduced for the GA versions of the "Vertex AI in Firebase" SDKs. These same changes are required to use the Firebase AI Logic SDKs. 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. 
Required for all languages and platforms
- Function calling 
 If you implemented this feature before GA, then you'll need to make updates to how you define your schema. We recommend reviewing the updated function calling guide to learn how to write your function declarations.
- Generating structured output (like JSON) using - responseSchema
 If you implemented this feature before GA, then you'll need to make updates to how you define your schema. We recommend reviewing the new structured output guide to learn how to write JSON schemas.
- Timeout - Changed the default timeout for requests to be 180 seconds.
 
Required based on platform or language
Swift
- Enumerations - Replaced most - enumtypes with- structs with static variables. This change allows more flexibility for evolving the API in a backward-compatible way. When using- switchstatements, you must now include a- default:case to cover unknown or unhandled values, including new values that are added to the SDK in the future.
- Renamed the - BlockThresholdenumeration to- HarmBlockThreshold; this type is now a- struct.
- Removed - unknownand- unspecifiedcases from the following enumerations (now- structs):- HarmCategory,- HarmBlockThreshold,- HarmProbability,- BlockReason, and- FinishReason.
- Replaced the enumeration - ModelContent.Partwith a protocol named- Partto allow new types to be added in a backward-compatible way. This change is described in greater detail in the Content parts section.
 
- Content parts - Removed the - ThrowingPartsRepresentableprotocol, and simplified the initializers for- ModelContentto avoid occasional compiler errors. Images that don't encode properly will still throw errors when being used in- generateContent.
- Replaced the - ModelContent.Partcases with the following- structtypes conforming to the- Partprotocol:- .textto- TextPart
- .datato- InlineDataPart
- .fileDatato- FileDataPart
- .functionCallto- FunctionCallPart
- .functionResponseto- FunctionResponsePart
 
 
- Harm category - Changed the HarmCategoryto no longer be nested in theSafetySettingtype. If you're referring to it asSafetySetting.HarmCategory, that can be replaced withHarmCategory.
 
- Changed the 
- Safety feedback - Removed the SafetyFeedbacktype, since it wasn't used in any of the responses.
 
- Removed the 
- Citation metadata - Renamed the citationSourcesproperty tocitationsinCitationMetadata.
 
- Renamed the 
- Total billable characters - Changed the totalBillableCharactersproperty inCountTokensResponseto be optional to reflect situations where no characters are sent.
 
- Changed the 
- Candidate response - Renamed CandidateResponsetoCandidateto match other platforms.
 
- Renamed 
- Generation configuration - Changed the public properties of GenerationConfigtointernal. They all remain configurable in the initializer.
 
- Changed the public properties of 
Kotlin
- Enumerations - Replaced - enumclasses and- sealedclasses with regular classes. This change allows more flexibility for evolving the API in a backward compatible way.
- Renamed the - BlockThresholdenumeration to- HarmBlockThreshold.
- Removed values from the following enumerations: - HarmBlockThreshold,- HarmProbability,- HarmSeverity,- BlockReason, and- FinishReason.
 
- Blob methods - Renamed all methods that included Blobas part of their name to useInlineDatainstead.
 
- Renamed all methods that included 
- Safety settings - Changed the field methodto be nullable.
 
- Changed the field 
- Duration class - Removed all usages of Kotlin's Durationclass, and replaced it withlong. This change provides better interoperability with Java.
 
- Removed all usages of Kotlin's 
- Citation metadata - Wrapped all the fields previously declared in CitationMetadatainto a new class calledCitation. Citations can be found in the list calledcitationsinCitationMetadata. This change allows better alignment of types across platforms.
 
- Wrapped all the fields previously declared in 
- Count tokens - Changed the field totalBillableCharactersto be nullable.
 
- Changed the field 
- Total billable characters - Changed the totalBillableCharactersproperty inCountTokensResponseto be optional to reflect situations where no characters are sent.
 
- Changed the 
- Instantiating a model - Moved the requestOptionsparameter to the end of the parameter list to align with other platforms.
 
- Moved the 
- Live API - Removed - UNSPECIFIEDvalue for enum class- ResponseModality. Instead use- null.
- Renamed - LiveGenerationConfig.setResponseModalitiesto- LiveGenerationConfig.setResponseModality.
- Removed the - LiveContentResponse.Statusclass, and instead have nested the status fields as properties of- LiveContentResponse.
- Removed the - LiveContentResponseclass, and instead have provided subclasses of- LiveServerMessagethat match the responses from the model.
- Changed - LiveModelFutures.connectto return- ListenableFuture<LiveSessionFutures>instead of- ListenableFuture<LiveSession>.
 
Java
- Enumerations - Replaced - enumclasses and- sealedclasses with regular classes. This change allows more flexibility for evolving the API in a backward compatible way.
- Renamed the - BlockThresholdenumeration to- HarmBlockThreshold.
- Removed values from the following enumerations: - HarmBlockThreshold,- HarmProbability,- HarmSeverity,- BlockReason, and- FinishReason.
 
- Blob methods - Renamed all methods that included Blobas part of their name to useInlineDatainstead.
 
- Renamed all methods that included 
- Safety settings - Changed the field methodto be nullable.
 
- Changed the field 
- Duration class - Removed all usages of Kotlin's Durationclass, and replaced it withlong. This change provides better interoperability with Java.
 
- Removed all usages of Kotlin's 
- Citation metadata - Wrapped all the fields previously declared in CitationMetadatainto a new class calledCitation. Citations can be found in the list calledcitationsinCitationMetadata. This change allows better alignment of types across platforms.
 
- Wrapped all the fields previously declared in 
- Count tokens - Changed the field totalBillableCharactersto be nullable.
 
- Changed the field 
- Total billable characters - Changed the totalBillableCharactersproperty inCountTokensResponseto be optional to reflect situations where no characters are sent.
 
- Changed the 
- Instantiating a model - Moved the requestOptionsparameter to the end of the parameter list to align with other platforms.
 
- Moved the 
- Live API - Removed - UNSPECIFIEDvalue for enum class- ResponseModality. Instead use- null.
- Renamed - LiveGenerationConfig.setResponseModalitiesto- LiveGenerationConfig.setResponseModality.
- Removed the - LiveContentResponse.Statusclass, and instead have nested the status fields as properties of- LiveContentResponse.
- Removed the - LiveContentResponseclass, and instead have provided subclasses of- LiveServerMessagethat match the responses from the model.
- Changed - LiveModelFutures.connectto return- ListenableFuture<LiveSessionFutures>instead of- ListenableFuture<LiveSession>.
 
- Changed various Java builder methods to now correctly return the instance of their class, instead of - void.
Web
- Enumerations - Removed values from the following enumerations: HarmCategory,BlockThreshold,HarmProbability,HarmSeverity,BlockReason, andFinishReason.
 
- Removed values from the following enumerations: 
- Block reason - Changed blockReasoninPromptFeedbackto be optional.
 
- Changed 
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
- Enumerations - Removed values from the following enumerations: HarmCategory,HarmProbability,BlockReason, andFinishReason.
 
- Removed values from the following enumerations: 
- Data part - Renamed DataParttoInlineDataPart, and thestaticdatafunction toinlineDatato align with other platforms.
 
- Renamed 
- Request options - Removed RequestOptionssincetimeoutwasn't functional. It will be re-added in the near future, but it will be moved to theGenerativeModeltype to match other platforms.
 
- Removed 
- Stop sequences - Changed the stopSequencesparameter inGenerationConfigto be optional and to default tonullinstead of an empty array.
 
- Changed the 
- Citations - Renamed the citationSourcesproperty tocitationsinCitationMetadata. TheCitationSourcetype was renamed toCitationto match other platforms.
 
- Renamed the 
- Unnecessary public types, methods, and properties - Removed the following types, methods, and properties which were
unintentionally exposed: defaultTimeout,CountTokensResponseFields,parseCountTokensResponse,parseEmbedContentResponse,parseGenerateContentResponse,parseContent,BatchEmbedContentsResponse,ContentEmbedding,EmbedContentRequest, andEmbedContentResponse.
 
- Removed the following types, methods, and properties which were
unintentionally exposed: 
- Count tokens - Removed extra fields from the countTokensfunction that are no longer necessary. Onlycontentsis needed.
 
- Removed extra fields from the 
- Instantiating a model - Moved the systemInstructionparameter to the end of the parameter list to align with other platforms.
 
- Moved the 
- Embedding functionality - Removed unsupported embedding functionality (embedContentandbatchEmbedContents) from the model.
 
- Removed unsupported embedding functionality (
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.
Possible errors related to migrating
As you're migrating to use the GA version of Firebase AI Logic, you might encounter errors if you haven't completed all of the required changes as described in this migration guide.
403 Error: Requests to this API firebasevertexai.googleapis.com ... are blocked.
If you receive a 403 error that says
Requests to this API firebasevertexai.googleapis.com ... are blocked.,
it usually means that the Firebase API key in your
Firebase configuration file or object doesn't have a required API in its
allowlist for the product that you're trying to use.
Make sure that the Firebase API key used by your app has all the required APIs included in the key's "API restrictions" allowlist. For Firebase AI Logic, your Firebase API key needs to have at minimum the Firebase AI Logic API in its allowlist. This API should have been automatically added to your API key's allowlist when you enabled the required APIs in the Firebase console.
You can view all your API keys in the APIs & Services > Credentials panel in the Google Cloud console.
Give feedback about your experience with Firebase AI Logic