Today we are going to learn how we can set up Google Firebase in a Flutter project.
data:image/s3,"s3://crabby-images/7743b/7743b18370c6723d4d62e96f1e0059f3411e2b5f" alt=""
The first thing we need to do is create our Firebase project, for that we go to https://firebase.google.com/
And click on Go to Console:
data:image/s3,"s3://crabby-images/b734d/b734d7a4bdb3af434d1faa295178377f1aac814c" alt=""
Choose Add Project
data:image/s3,"s3://crabby-images/57b96/57b96c91120fe7a153eb44350f18e3c119ae937b" alt=""
Choose a name for the APP. We can choose whether we want to activate Google Analytics.
Wait for the project to be set up and click continue:
data:image/s3,"s3://crabby-images/9b59e/9b59ef4383d10d9e81fd731f7b012546d64f7aba" alt=""
Now we install Firebase CLI: https://firebase.google.com/docs/cli?hl=es-419#setup_update_cli
We download the one we need according to the Operating System, in my case I use Windows:
data:image/s3,"s3://crabby-images/58c61/58c61215731bc4b057785881838546b4cf3495ba" alt=""
Now, in Windows it has prevented me from installing it, we click that it is safe and let it run.
It will start installing:
data:image/s3,"s3://crabby-images/b01a2/b01a2aecd3c47e19aeb420e402a3bd0949024f36" alt=""
Now it will ask us to authenticate with our Google account, we choose one and we’re done:
data:image/s3,"s3://crabby-images/87be0/87be0bda26c1228518485c84d98ee62f4597cd4a" alt=""
Once installed, we go to our project and use the following command:
dart pub global activate flutterfire_cli
We wait for it to configure.
We will see a Warning like this:
data:image/s3,"s3://crabby-images/9cfa1/9cfa12ba2b8ec9283f7adc9223fdb119a92173fd" alt=""
We have to add this Path it indicates, in the case of Windows, as follows:
Open the Start Menu:
- Click on the Windows start button in the lower-left corner of your screen.
System Configuration:
- Type “Environment Variables” and select Edit the system environment variables
data:image/s3,"s3://crabby-images/93fe0/93fe0930500c10c2345c8401217bf19acde8fcb8" alt=""
Environment Variables:
- In the window that opens, look for the option of “Environment Variables…”
data:image/s3,"s3://crabby-images/87ae7/87ae7251e671c7850980e5415be2e8e7839859cf" alt=""
Edit the PATH Variable:
- In the “System Variables” section, look for the variable called “Path” and click on “Edit”.
Add the Path:
- We look for the system variable called Path:
data:image/s3,"s3://crabby-images/626ee/626ee4bc4ded42ad14982af49483cf720befa52a" alt=""
- We click on edit and add the new one:
data:image/s3,"s3://crabby-images/25f79/25f79e9caf0da89a3f8222b9fc238c9d47a5bb69" alt=""
C:\Users\user\AppData\Local\Pub\Cache\bin
(which appears in the Warning that is shown on your screen). Change user with your username.
Save and Close:
- Click on “OK” to close the editing window and then on “OK” again to close the “System Properties” window.
Close and Open Terminals Again:
- Close any terminal you are using and open it again for the changes to take effect.
- It’s also important to restart the machine for the settings to take effect.
On MAC:
export PATH="$PATH":"$HOME/.pub-cache/bin"
Now we add firebase_core
(https://pub.dev/packages/firebase_core)
flutter pub add firebase_core
And now we use the command to configure the project:
flutterfire configure
If we encounter the following error:
FirebaseCommandException: An error occured on the Firebase CLI when attempting to run a command. COMMAND: firebase --version ERROR: The FlutterFire CLI currently requires the official Firebase CLI to also be installed, see
https://firebase.google.com/docs/cli#install_the_firebase_cli
for how to install it.
We install the following:
npm install -g firebase-tools
*Remember to have nodejs installed: https://nodejs.org/en
And it will start configuring:
data:image/s3,"s3://crabby-images/9c4d3/9c4d3f130289f3ad7d8af17bd920781c2f1ac0d8" alt=""
Now, we select the project we created earlier.
We choose the platforms that interest us:
<
div class=”wp-block-image”>
data:image/s3,"s3://crabby-images/979c3/979c3b3b3fd590c198beddbb9cfaa41a849336fd" alt=""
In my case, I leave them as default.
And we wait for it to be configured.
Now, let’s move on to the code that will make the notifications work.
We create a class called FirebaseInitializer.dart
import 'package:firebase_core/firebase_core.dart'; import '../../firebase_options.dart'; class FirebaseInitializer { static Future<void> initialize() async { try { await Firebase.initializeApp( options: DefaultFirebaseOptions.currentPlatform, ); print('Firebase initialized successfully'); } catch (e) { print('Error initializing Firebase: $e'); } } }
Once created, we have to go to our main class and add:
void main() async { await FirebaseInitializer.initialize(); }
This initializes Firebase in our app.
Si nos aparece el siguiente error:
FirebaseCommandException: Se produjo un error en la CLI de Firebase al intentar ejecutar un comando. COMANDO: firebase --version ERROR: La CLI de FlutterFire actualmente requiere que también esté instalada la CLI oficial de Firebase, consulta https://firebase.google.com/docs/cli#install_the_firebase_cli para obtener instrucciones sobre cómo instalarla.
Instalamos lo siguiente:
npm install -g firebase-tools
*Recuerda tener nodejs instalado: https://nodejs.org/en
Y ya empezará a configurarse:
data:image/s3,"s3://crabby-images/9c4d3/9c4d3f130289f3ad7d8af17bd920781c2f1ac0d8" alt=""
Ahora, seleccionamos el proyecto que hemos creado anteriormente.
Elegimos las plataformas que nos interesen:
data:image/s3,"s3://crabby-images/979c3/979c3b3b3fd590c198beddbb9cfaa41a849336fd" alt=""
En mi caso las dejo por defecto.
Y esperamos a que se configure.
Ahora vamos con el código que hará que las notificaciones funcionen.
Creamos una clase llamada FirebaseInitializer.dart
import 'package:firebase_core/firebase_core.dart'; import '../../firebase_options.dart'; class FirebaseInitializer { static Future<void> initialize() async { try { await Firebase.initializeApp( options: DefaultFirebaseOptions.currentPlatform, ); print('Firebase initialized successfully'); } catch (e) { print('Error initializing Firebase: $e'); } } }
Una vez creada, tenemos que ir a nuestra clase principal y añadimos:
void main() async { await FirebaseInitializer.initialize(); }
Con esto se inicializa Firebase en nuestra APP.
If we encounter the following error:
FirebaseCommandException: An error occurred on the Firebase CLI when attempting to run a command. COMMAND: firebase --version ERROR: The FlutterFire CLI currently requires the official Firebase CLI to also be installed, see https://firebase.google.com/docs/cli#install_the_firebase_cli for how to install it.
We install the following:
npm install -g firebase-tools
*Remember to have Node.js installed: https://nodejs.org/en
And it will start setting up:
data:image/s3,"s3://crabby-images/9c4d3/9c4d3f130289f3ad7d8af17bd920781c2f1ac0d8" alt=""
Now, we select the project we created earlier.
We choose the platforms that interest us:
data:image/s3,"s3://crabby-images/979c3/979c3b3b3fd590c198beddbb9cfaa41a849336fd" alt=""
In my case, I leave them as default.
And we wait for it to be configured.
Now, let’s move on to the code that will make the notifications work.
We create a class called FirebaseInitializer.dart
import 'package:firebase_core/firebase_core.dart'; import '../../firebase_options.dart'; class FirebaseInitializer { static Future<void> initialize() async { try { await Firebase.initializeApp( options: DefaultFirebaseOptions.currentPlatform, ); print('Firebase initialized successfully'); } catch (e) { print('Error initializing Firebase: $e'); } } }
Once created, we have to go to our main class and add:
void main() async { await FirebaseInitializer.initialize(); }
With this, Firebase is initialized in our app.
“`
data:image/s3,"s3://crabby-images/dcda1/dcda1869d3b0ea466fe645d8fc18f277ea25d855" alt=""