KEMBAR78
Firebase | PDF | Mobile App | Cross Platform Software
0% found this document useful (0 votes)
31 views19 pages

Firebase

Firebase is Google's client-side app development platform that integrates with various Google tools and supports multiple programming languages and frameworks. It offers a range of products divided into build and run categories, including features for authentication, cloud storage, analytics, and messaging. Firebase's cross-platform capabilities streamline the development process, allowing developers to deploy applications across different platforms efficiently.

Uploaded by

kenzykhaled660
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
31 views19 pages

Firebase

Firebase is Google's client-side app development platform that integrates with various Google tools and supports multiple programming languages and frameworks. It offers a range of products divided into build and run categories, including features for authentication, cloud storage, analytics, and messaging. Firebase's cross-platform capabilities streamline the development process, allowing developers to deploy applications across different platforms efficiently.

Uploaded by

kenzykhaled660
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 19

5/12/2025

Firebase

What is Firebase

• Firebase is Google's client-side app development platform


• based on google could and integrates with most of google tools as well, like ads.
• Its multiplatform client for iOS, Android, Flutter, and web (like Angular, React, and
Vue) uses Javascript and Typescript, Java, Kotlin, Swift, Objective-C, and C++.
• It's a collection of almost 20 products that help you build the product Google
architecture.
• They break this product into build and run categories.

1
5/12/2025

Firebase as a Client-Side Development Platform


• Google Cloud Integration: Built on Google's robust cloud infrastructure, Firebase ensures scalability,
reliability, and high availability.
• Compatibility with Google Tools: Works seamlessly with Google Ads, Google Analytics, and other Google
products to provide a holistic development experience.
• Multi-platform Support:
• iOS
• Android
• Web frameworks (Angular, React, Vue, etc.)
• Flutter (Google's UI toolkit)
• Programming languages such as JavaScript, TypeScript, Java, Kotlin, Swift, Objective-C, and C++.

Why is this important?


• Firebase's cross-platform capabilities allow developers to write once and deploy across multiple platforms,
reducing development time and effort.
• Firebase supports development across:
• Mobile: Android and iOS apps, including integration with platform-specific tools like Android Studio and
Xcode.
• Web Applications: Full support for modern frameworks like Angular, React, and Vue.js.
• Cross-Platform Frameworks:
• Flutter (Google’s UI toolkit for creating native apps).
• Unity for game development.
• C++ for native performance-driven applications.

2
5/12/2025

Firebase Build Category:


• Managed Infrastructure:
• App Check:
• Protects backend resources by verifying that incoming traffic originates from your app.
• Supports Android, iOS, and Web.
• Prevents abuse and ensures only legitimate users access your backend.
• Hosting:
• Provides secure, global hosting for static and dynamic web apps.
• Key Features:
• Supports modern frameworks like Angular, React, and Vue.js.
• Deploys directly from GitHub with continuous integration support.
• Global content delivery network (CDN) for fast loading.

Firebase Build Category:


• Authentication:
• Simplifies user login and onboarding with pre-built UI and secure authentication methods.
• Supported Methods:
• Email and Password.
• Social providers: Google, Facebook, Twitter, GitHub.
• Phone number authentication.
• Features:
• Secure token-based authentication.
• Provides user management APIs to handle sign-in and sign-out.

3
5/12/2025

Firebase Build Category:


• Cloud Storage for Firebase:
• Provides robust and secure file storage.
• Automatically synchronizes files between the app and the cloud.
• Key Features:
• Stores user-generated content like photos, videos, and documents.
• Ensures seamless integration with Firebase Authentication.
• Flexible rules for managing read/write permissions.

Firebase Build Category:


• Extensions:
• Pre-packaged, open-source solutions for common development challenges.
• Popular Extensions:
• Trigger Email: Automatically send emails based on events like user sign-ups.
• Resize Images: Dynamically resize uploaded images for better performance.
• Translate Text: Use Google Translate to localize app content.
• Benefits:
• Saves development time by automating repetitive tasks.
• Reduces errors by using tested solutions.
• Easy to integrate and configure within the Firebase Console.

4
5/12/2025

Firebase Run Category:


• A/B Testing:
• A method of comparing two or more app variations to determine which performs better.
• Key Features:
• Experiment with UI changes, new features, and app performance.
• Roll out updates to a subset of users to evaluate impact before full deployment.
• How it Works:
• Create experiments in the Firebase Console.
• Define goals such as increased user engagement, conversion rates, or retention.
• Analyze results using integrated Google Analytics.

Firebase Run Category:


• Crashlytics:
• A real-time crash reporting tool to help identify and fix stability issues in your app.
• Key Features:
• Provides detailed crash reports with contextual information.
• Alerts for new and trending issues.
• Integration with Slack and other tools for instant notifications.
• How it Works:
• Integrate Crashlytics SDK into your app.
• Monitor crashes and user-impacting issues via the Firebase Console.

10

5
5/12/2025

Firebase Run Category:


• Google Analytics:
• A free tool to measure app usage, user behavior, and engagement.
• Key Features:
• Tracks metrics like active users, session duration, and retention.
• Provides user demographics and behavior insights.
• Enables event tracking for custom user interactions.
• How it Works:
• Integrate Firebase Analytics SDK into your app.
• Define events and parameters to track specific user actions.
• View detailed reports in the Firebase Console.

11

Firebase Run Category:


• Cloud Messaging:
• Definition:
• A service to send targeted push notifications to engage users.
• Key Features:
• Send notifications to specific user segments or all users.
• Supports scheduling and automation.
• Free to use with unlimited messages.
• How it Works:
• Configure Firebase Cloud Messaging (FCM) in the Firebase Console.
• Use FCM tokens to target specific devices.

12

6
5/12/2025

Firebase Run Category:


• In-App Messaging:
• Definition:
• A tool to display contextual messages within the app.
• Key Features:
• Engage active users with real-time prompts.
• Customize messages based on user actions or app state.

13

Firebase Run Category:


• Remote Config :
• A service that allows developers to update app features and settings without deploying a new version.
• Key Features:
• Customize app experience for different user segments.
• Roll out changes gradually and revert if needed.
• Use analytics data to define conditions for configuration.
• How it Works:
• Set default parameters in the app.
• Define dynamic parameters in the Firebase Console.
• Fetch and activate configurations in the app at runtime.

14

7
5/12/2025

Firebase Run Category vs Firebase build Category:

15

Analytics
• You need to only add firebase to the
dependencies.
• The rest is done within the
https://console.firebase.google.com/
• You can look many different things, from first
time usage, how long the app is up,
demographics of users, etc.
• Data updates once every 24 hours.

16

8
5/12/2025

Cloud Messaging
• Basics, it's a push "notifications" system via google.
• Push, meaning the phone don't check for messages (ie pull messaging) and waste
battery life and network bandwidth.
• Each device gets a unique Token.
• You can then have individual devices send messages to each other or group
messages, or messages to all, based on the token.
• Requires a backend server to work.
• Either use googles hosting services or your own services.

17

Cloud Messaging
• Device
• Implements a firebaseMessaingService to receive the messages and decides what
to do with them, in the app.
• Backend systems.
• Need to implement (like a ReST based system) to receive the messages the device
is sending and forward them to the google site for distribution.
• Individual, group, or all.

18

9
5/12/2025

in-app messaging
• Not to be confused with cloud messaging, but the menu item is messaging.
• This allows you send a notification to the all (or some) of the devices where your app is
instead.
• You need on include firebase message in dependencies (or bom)
• implementation ("com.google.firebase:firebase-inappmessaging")
• The rest is done in the console.

19

Notifications
• You create a message in the notifications section.
• Send the message.
• It will then show up on the device as a notification.
• If they click the notification and it will launch your app.
• Note, if the app is up then the users won't see it (without extra code from cloud
messaging).
• You can code for in cloud messaging, so the message shows up as well.

20

10
5/12/2025

Authentication
• Allows the user to “log in" to your app.
• With any number of services using FirebaseUI
• Currently: phone number, email and password, google, Facebook, Twitter, and GitHub.
• Note Facebook and Twitter require their API key for it to work.
• You don't write the code; just call the method for sign-in or sign-out.
• It even keeps track of the password for emails.

• Dependencies, core plus


• implementation ("com.google.firebase:firebase-auth")
• implementation ("com.firebaseui:firebase-ui-auth:8.0.2")
• See https://github.com/firebase/FirebaseUI-Android

21

Setup and use

• private FirebaseAuth mFirebaseAuth;


• Private

22

11
5/12/2025

Setup and use

• private FirebaseAuth mFirebaseAuth;


• Private
FirebaseAuth.AuthStateListener
mAuthStateListener;

23

Setup and use

• private FirebaseAuth mFirebaseAuth;


• Private
FirebaseAuth.AuthStateListener
mAuthStateListener;
• mFirebaseAuth =
FirebaseAuth.getInstance();

24

12
5/12/2025

Example

mFirebaseAuth.addAuthStateListener(mAuthStateListener);

25

mFirebaseAuth.addAuthStateListener(mAuthStateListener);
mAuthStateListener = new FirebaseAuth.AuthStateListener() {

26

13
5/12/2025

mFirebaseAuth.addAuthStateListener(mAuthStateListener);
mAuthStateListener = new FirebaseAuth.AuthStateListener() {
@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {

27

mFirebaseAuth.addAuthStateListener(mAuthStateListener);
mAuthStateListener = new FirebaseAuth.AuthStateListener() {
@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();

28

14
5/12/2025

mFirebaseAuth.addAuthStateListener(mAuthStateListener);
mAuthStateListener = new FirebaseAuth.AuthStateListener() {
@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();
if (user != null) {
// User is signed in use user.getDisplayName() to get the name.
}

29

mFirebaseAuth.addAuthStateListener(mAuthStateListener);
mAuthStateListener = new FirebaseAuth.AuthStateListener() {
@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();
if (user != null) {
// User is signed in use user.getDisplayName() to get the name.
} else {

30

15
5/12/2025

mFirebaseAuth.addAuthStateListener(mAuthStateListener);
mAuthStateListener = new FirebaseAuth.AuthStateListener() {
@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();
if (user != null) {
// User is signed in use user.getDisplayName() to get the name.
} else {
// User is signed out
myActivityResultLauncher.launch(AuthUI.getInstance()

31

mFirebaseAuth.addAuthStateListener(mAuthStateListener);
mAuthStateListener = new FirebaseAuth.AuthStateListener() {
@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();
if (user != null) {
// User is signed in use user.getDisplayName() to get the name.
} else {
// User is signed out
myActivityResultLauncher.launch(AuthUI.getInstance()
.createSignInIntentBuilder()
.setIsSmartLockEnabled(false)

32

16
5/12/2025

mFirebaseAuth.addAuthStateListener(mAuthStateListener);

mAuthStateListener = new FirebaseAuth.AuthStateListener() {


@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();
if (user != null) {
// User is signed in use user.getDisplayName() to get the name.
} else {
// User is signed out
myActivityResultLauncher.launch(AuthUI.getInstance()
.createSignInIntentBuilder()

.setIsSmartLockEnabled(false)
.setAvailableProviders(Arrays.asList(

new AuthUI.IdpConfig.EmailBuilder().build(),

new AuthUI.IdpConfig.GoogleBuilder().build(),

new AuthUI.IdpConfig.PhoneBuilder().build()))

33

mFirebaseAuth.addAuthStateListener(mAuthStateListener);

mAuthStateListener = new FirebaseAuth.AuthStateListener() {


@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();
if (user != null) {
// User is signed in use user.getDisplayName() to get the name.
} else {
// User is signed out
myActivityResultLauncher.launch(AuthUI.getInstance()
.createSignInIntentBuilder()

.setIsSmartLockEnabled(false)
.setAvailableProviders(Arrays.asList(

new AuthUI.IdpConfig.EmailBuilder().build(),

new AuthUI.IdpConfig.GoogleBuilder().build(),

new AuthUI.IdpConfig.PhoneBuilder().build()))
.build() );

34

17
5/12/2025

mFirebaseAuth.addAuthStateListener(mAuthStateListener);

mAuthStateListener = new FirebaseAuth.AuthStateListener() {


@Override
public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
FirebaseUser user = firebaseAuth.getCurrentUser();
if (user != null) {
// User is signed in use user.getDisplayName() to get the name.
} else {
// User is signed out
myActivityResultLauncher.launch(AuthUI.getInstance() //see firebase UI for documentation.
.createSignInIntentBuilder()

.setIsSmartLockEnabled(false)
.setAvailableProviders(Arrays.asList(

new AuthUI.IdpConfig.EmailBuilder().build(),

new AuthUI.IdpConfig.GoogleBuilder().build(),

new AuthUI.IdpConfig.PhoneBuilder().build()))
.build() );
}
}
};

mFirebaseAuth.removeAuthStateListener(mAuthStateListener);

35

Storage
• This allows for file storage in the cloud
• It handles all the networking and syncing between cloud and device.
• Again should use authentication.
• Can specify any of rules on what the users are allowed to write to/read from the
storage.

• dependencies (using bom)


• implementation ("com.google.firebase:firebase-storage")

36

18
5/12/2025

Setup and use.

• private FirebaseStorage mFirebaseStorage = FirebaseStorage.getInstance();

37

Setup and use.

• private FirebaseStorage mFirebaseStorage = FirebaseStorage.getInstance();


• private StorageReference mChatPhotosStorageReference =
mFirebaseStorage.getReference().child("chat_photos");
• Where chat_photos is directory in storage.

38

19

You might also like