ফায়ারবেস অ্যান্ড্রয়েড কোডল্যাব - বন্ধুত্বপূর্ণ চ্যাট তৈরি করুন

1। সংক্ষিপ্ত বিবরণ

স্ক্রিনশট

ছবি: ওয়ার্কিং ফ্রেন্ডলি চ্যাট অ্যাপ।

বন্ধুত্বপূর্ণ চ্যাট কোডল্যাবে স্বাগতম। এই কোডল্যাবে, আপনি Android এ একটি চ্যাট অ্যাপ তৈরি করতে ফায়ারবেস প্ল্যাটফর্ম ব্যবহার করতে শিখবেন।

আপনি কি শিখবেন

  • ব্যবহারকারীদের সাইন ইন করার অনুমতি দেওয়ার জন্য ফায়ারবেস প্রমাণীকরণ কীভাবে ব্যবহার করবেন।
  • ফায়ারবেস রিয়েলটাইম ডেটাবেস ব্যবহার করে কীভাবে ডেটা সিঙ্ক করবেন।
  • ফায়ারবেসের জন্য ক্লাউড স্টোরেজে বাইনারি ফাইল কীভাবে সংরক্ষণ করবেন।
  • ফায়ারবেসের সাথে একটি অ্যান্ড্রয়েড অ্যাপ তৈরি করতে ফায়ারবেস স্থানীয় এমুলেটর স্যুট কীভাবে ব্যবহার করবেন।

আপনি কি প্রয়োজন হবে

2. নমুনা কোড পান

সংগ্রহস্থল ক্লোন করুন

কমান্ড লাইন থেকে GitHub সংগ্রহস্থল ক্লোন করুন:

$ git clone https://github.com/firebase/codelab-friendlychat-android

অ্যান্ড্রয়েড স্টুডিওতে আমদানি করুন

অ্যান্ড্রয়েড স্টুডিও নির্বাচন ফাইল> ওপেন সালে তারপর নির্বাচন build-android-start ডিরেক্টরি ( android_studio_folder ) যে ডিরেক্টরি থেকে আপনি নমুনা কোড ডাউনলোড করেছেন।

আপনি এখন থাকা উচিত build-android-start প্রকল্পের অ্যান্ড্রয়েড স্টুডিও খোলা। আপনি যদি একটি সম্পর্কে একটি সতর্কবার্তা দেখতে পান, তাহলে google-services.json ফাইল পাওয়া যাচ্ছে না, চিন্তা করবেন না। এটি পরবর্তী ধাপে যোগ করা হবে।

নির্ভরতা পরীক্ষা করুন

এই কোডল্যাবে আপনার প্রয়োজনীয় সমস্ত নির্ভরতা আপনার জন্য ইতিমধ্যেই যোগ করা হয়েছে, তবে কীভাবে আপনার অ্যাপে Firebase SDK যোগ করবেন তা বোঝা গুরুত্বপূর্ণ:

build.gradle

buildscript {
    // ...

    dependencies {
        classpath 'com.android.tools.build:gradle:4.1.2'

        // The google-services plugin is required to parse the google-services.json file
        classpath 'com.google.gms:google-services:4.3.5'
    }
}

app/build.gradle

plugins {
    id 'com.android.application'
    id 'kotlin-android'
    id 'com.google.gms.google-services'
}

android {
    // ...
}

dependencies {
    // ...

    // Google Sign In SDK
    implementation 'com.google.android.gms:play-services-auth:19.0.0'

    // Firebase SDK
    implementation platform('com.google.firebase:firebase-bom:26.6.0')
    implementation 'com.google.firebase:firebase-database-ktx'
    implementation 'com.google.firebase:firebase-storage-ktx'
    implementation 'com.google.firebase:firebase-auth-ktx'

    // Firebase UI Library
    implementation 'com.firebaseui:firebase-ui-auth:7.2.0'
    implementation 'com.firebaseui:firebase-ui-database:7.2.0'
}

3. Firebase CLI ইনস্টল করুন৷

অর্ডার চালানোর জন্য Firebase এমুলেটর সুইট , আপনি ইনস্টল এবং ব্যবহার করতে হবে Firebase CLI

CLI ইনস্টল করুন

বিকল্প 1 - npm দিয়ে ইনস্টল করুন

আপনি যদি ইতিমধ্যেই আপনার মেশিনে Node.js এবং npm ইনস্টল করে থাকেন তবে আপনি নিম্নলিখিত কমান্ডের সাহায্যে CLI ইনস্টল করতে পারেন:

npm install -g firebase-tools@latest

বিকল্প 2 - স্বতন্ত্র বাইনারি ইনস্টল করুন

আপনি Node.js / npm না থাকে তাহলে অথবা আপনি অ্যাপ্লিকেশন উন্নয়ন নতুন হন, আপনি নিম্নলিখিত একটি স্বতন্ত্র বাইনারি হিসাবে CLI ইনস্টল করতে পারেন এখানে আপনার প্ল্যাটফর্মে জন্য নির্দেশাবলী

ইনস্টলেশন পরীক্ষা করুন

একবার আপনি Firebase CLI ইনস্টল করা আছে, নিশ্চিত করুন যে আপনি সংস্করণ আছে করতে নিম্নলিখিত কমান্ড ব্যবহার 9.11.0 বা উচ্চতর:

firebase --version

4. ফায়ারবেস এমুলেটর স্যুটের সাথে সংযোগ করুন৷

এমুলেটরগুলি শুরু করুন

আপনার টার্মিনালে, আপনার স্থানীয় রুট থেকে নিম্নোক্ত কমান্ডটি প্রয়োগ codelab-friendlychat-android ডিরেক্টরি:

firebase emulators:start --project=demo-friendlychat-android

আপনি এই মত কিছু লগ দেখতে হবে. বন্দর মান সংজ্ঞায়িত করা হয়েছে firebase.json ফাইল যা ক্লোন নমুনা কোড অন্তর্ভুক্ত করা হয়।

$ firebase emulators:start --project=demo-friendlychat-android
i  emulators: Starting emulators: auth, database, storage
i  emulators: Detected demo project ID "demo-friendlychat-android", emulated services will use a demo configuration and attempts to access non-emulated services for this project will fail.
i  database: Database Emulator logging to database-debug.log
i  ui: Emulator UI logging to ui-debug.log

┌─────────────────────────────────────────────────────────────┐
│ ✔  All emulators ready! It is now safe to connect your app. │
│ i  View Emulator UI at http://localhost:4000                │
└─────────────────────────────────────────────────────────────┘

┌────────────────┬────────────────┬────────────────────────────────┐
│ Emulator       │ Host:Port      │ View in Emulator UI            │
├────────────────┼────────────────┼────────────────────────────────┤
│ Authentication │ localhost:9099 │ http://localhost:4000/auth     │
├────────────────┼────────────────┼────────────────────────────────┤
│ Database       │ localhost:9000 │ http://localhost:4000/database │
├────────────────┼────────────────┼────────────────────────────────┤
│ Storage        │ localhost:9199 │ http://localhost:4000/storage  │
└────────────────┴────────────────┴────────────────────────────────┘
  Emulator Hub running at localhost:4400
  Other reserved ports: 4500

Issues? Report them at https://github.com/firebase/firebase-tools/issues and attach the *-debug.log files.

নেভিগেট করুন HTTP: // স্থানীয় হোস্ট: 4000 দেখতে Firebase এমুলেটর সুইট UI 'তে আপনার ওয়েব ব্রাউজারে:

এমুলেটর স্যুট UI হোম

ত্যাগ emulators:start codelab বাকি জন্য কমান্ড চলমান।

আপনার অ্যাপ্লিকেশন সংযোগ করুন

অ্যান্ড্রয়েড স্টুডিওতে, খোলা MainActivity.kt , তারপর নিচের কোডটি ভিতরে যোগ onCreate পদ্ধতি:

// When running in debug mode, connect to the Firebase Emulator Suite.
// "10.0.2.2" is a special IP address which allows the Android Emulator
// to connect to "localhost" on the host computer. The port values (9xxx)
// must match the values defined in the firebase.json file.
if (BuildConfig.DEBUG) {
    Firebase.database.useEmulator("10.0.2.2", 9000)
    Firebase.auth.useEmulator("10.0.2.2", 9099)
    Firebase.storage.useEmulator("10.0.2.2", 9199)
}

5. স্টার্টার অ্যাপ চালান

google-services.json যোগ করুন

Firebase সাথে সংযোগ স্থাপনের জন্য আপনার অ্যান্ড্রয়েড অ্যাপের জন্য জন্য, আপনাকে একটি যোগ করা আবশ্যক google-services.json ভিতরে ফাইল app আপনার অ্যান্ড্রয়েড প্রকল্পের ফোল্ডার। এই কোডল্যাবের উদ্দেশ্যে, আমরা একটি মক JSON ফাইল প্রদান করেছি যা আপনাকে Firebase এমুলেটর স্যুটের সাথে সংযোগ করার অনুমতি দেবে।

কপি mock-google-services.json মধ্যে ফাইল build-android-start/app ফোল্ডারে google-services.json :

cp mock-google-services.json build-android-start/app/google-services.json

এই কোডল্যাবের চূড়ান্ত ধাপে, আপনি শিখবেন কিভাবে একটি বাস্তব ফায়ারবেস প্রজেক্ট এবং ফায়ারবেস অ্যান্ড্রয়েড অ্যাপ তৈরি করতে হয় যাতে আপনি এই মক JSON ফাইলটিকে আপনার নিজস্ব কনফিগারেশন দিয়ে প্রতিস্থাপন করতে পারেন।

অ্যাপটি চালান

এখন আপনি অ্যান্ড্রয়েড স্টুডিওতে প্রোজেক্ট ইম্পোর্ট করেছেন এবং একটি ফায়ারবেস কনফিগারেশন JSON ফাইল যোগ করেছেন, আপনি প্রথমবারের জন্য অ্যাপটি চালানোর জন্য প্রস্তুত।

  1. আপনার অ্যান্ড্রয়েড এমুলেটর শুরু করুন।
  2. অ্যান্ড্রয়েড স্টুডিওতে, চালান (ক্লিক এক্সিকিউট ) টুলবারে।

অ্যাপটি আপনার অ্যান্ড্রয়েড এমুলেটরে চালু করা উচিত। এই মুহুর্তে, আপনার একটি খালি বার্তা তালিকা দেখতে হবে এবং বার্তা পাঠানো এবং গ্রহণ করা কাজ করবে না। এই কোডল্যাবের পরবর্তী ধাপে, আপনি ব্যবহারকারীদের প্রমাণীকরণ করবেন যাতে তারা বন্ধুত্বপূর্ণ চ্যাট ব্যবহার করতে পারে।

6. প্রমাণীকরণ সক্ষম করুন

এই অ্যাপটি সমস্ত চ্যাট বার্তা সংরক্ষণ করতে Firebase রিয়েলটাইম ডেটাবেস ব্যবহার করবে। যদিও আমরা ডেটা যোগ করার আগে, আমাদের নিশ্চিত হওয়া উচিত যে অ্যাপটি সুরক্ষিত এবং শুধুমাত্র প্রমাণীকৃত ব্যবহারকারীরা বার্তা পোস্ট করতে পারে। এই ধাপে, আমরা ফায়ারবেস প্রমাণীকরণ সক্ষম করব এবং রিয়েলটাইম ডেটাবেস সুরক্ষা নিয়মগুলি কনফিগার করব।

মৌলিক সাইন-ইন কার্যকারিতা যোগ করুন

পরবর্তীতে আমরা ব্যবহারকারীদের সনাক্ত করতে এবং একটি সাইন-ইন স্ক্রীন প্রয়োগ করতে অ্যাপটিতে কিছু মৌলিক ফায়ারবেস প্রমাণীকরণ কোড যোগ করব।

বর্তমান ব্যবহারকারীর জন্য চেক করুন

প্রথম নিম্নলিখিত উদাহরণস্বরূপ পরিবর্তনশীল যোগ MainActivity.kt শ্রেণী:

MainActivity.kt

// Firebase instance variables
private lateinit var auth: FirebaseAuth

এখন সংশোধন করা যাক MainActivity যখনই অ্যাপ্লিকেশন খুলুন এবং অবিশ্বস্ত হয় সাইন-ইন স্ক্রিনে ব্যবহারকারীর পাঠান। নিচের টি যোগ onCreate() পরে পদ্ধতি binding দৃশ্য সংযুক্ত হয়:

MainActivity.kt

// Initialize Firebase Auth and check if the user is signed in
auth = Firebase.auth
if (auth.currentUser == null) {
    // Not signed in, launch the Sign In activity
    startActivity(Intent(this, SignInActivity::class.java))
    finish()
    return
}

আমরা তাহলে ব্যবহারকারী সময় সাইন ইন করে চেক করতে চান onStart() :

MainActivity.kt

public override fun onStart() {
    super.onStart()
    // Check if user is signed in.
    if (auth.currentUser == null) {
        // Not signed in, launch the Sign In activity
        startActivity(Intent(this, SignInActivity::class.java))
        finish()
        return
    }
}

তারপর বাস্তবায়ন getUserPhotoUrl() এবং getUserName() বর্তমানে প্রামাণ Firebase ব্যবহারকারী সম্পর্কে সঠিক তথ্য ফিরে যাওয়ার পদ্ধতি:

MainActivity.kt

private fun getPhotoUrl(): String? {
    val user = auth.currentUser
    return user?.photoUrl?.toString()
}

private fun getUserName(): String? {
    val user = auth.currentUser
    return if (user != null) {
        user.displayName
    } else ANONYMOUS
}

তারপর বাস্তবায়ন signOut() out বোতাম চিহ্ন হ্যান্ডেল করতে পদ্ধতি:

MainActivity.kt

private fun signOut() {
    AuthUI.getInstance().signOut()
    startActivity(Intent(this, SignInActivity::class.java))
    finish()
}

এখন প্রয়োজনে ব্যবহারকারীকে সাইন-ইন স্ক্রিনে পাঠানোর জন্য আমাদের কাছে সমস্ত যুক্তি রয়েছে৷ পরবর্তীতে ব্যবহারকারীদের সঠিকভাবে প্রমাণীকরণের জন্য আমাদের সাইন-ইন স্ক্রীন বাস্তবায়ন করতে হবে।

সাইন-ইন স্ক্রীন বাস্তবায়ন করুন

ফাইল খুলুন SignInActivity.kt । এখানে একটি সাধারণ সাইন-ইন বোতাম প্রমাণীকরণ শুরু করতে ব্যবহার করা হয়। এই বিভাগে, আপনি সাইন ইনের জন্য যুক্তি প্রয়োগ করতে FirebaseUI ব্যবহার করবেন।

একটি প্রমাণীকরণ উদাহরণস্বরূপ পরিবর্তনশীল যোগ SignInActivity অধীনে বর্গ // Firebase instance variables মন্তব্য:

SignInActivity.kt

// Firebase instance variables
private lateinit var auth: FirebaseAuth

তারপর, সম্পাদনা onCreate() পদ্ধতি একই ভাবে আপনি করেছিল মধ্যে Firebase আরম্ভ করতে MainActivity :

SignInActivity.kt

// Initialize FirebaseAuth
auth = Firebase.auth

একটি অ্যাড ActivityResultLauncher করার ক্ষেত্র SignInActivity :

SignInActivity.kt

// ADD THIS
private val signIn: ActivityResultLauncher<Intent> =
        registerForActivityResult(FirebaseAuthUIActivityResultContract(), this::onSignInResult)

override fun onCreate(savedInstanceState: Bundle?) {
    // ...
}

পাশে, সম্পাদনা onStart() প্রবাহ FirebaseUI চিহ্ন বন্ধ লাথি পদ্ধতি:

SignInActivity.kt

public override fun onStart() {
    super.onStart()

    // If there is no signed in user, launch FirebaseUI
    // Otherwise head to MainActivity
    if (Firebase.auth.currentUser == null) {
        // Sign in with FirebaseUI, see docs for more details:
        // https://firebase.google.com/docs/auth/android/firebaseui
        val signInIntent = AuthUI.getInstance()
                .createSignInIntentBuilder()
                .setLogo(R.mipmap.ic_launcher)
                .setAvailableProviders(listOf(
                        AuthUI.IdpConfig.EmailBuilder().build(),
                        AuthUI.IdpConfig.GoogleBuilder().build(),
                ))
                .build()

        signIn.launch(signInIntent)
    } else {
        goToMainActivity()
    }
}

এর পরে, বাস্তবায়ন onSignInResult ফলাফলের সাইন ইন হ্যান্ডেল করতে পদ্ধতি। তাহলে সাইন ইন ফল সফল হয়েছে, অব্যাহত MainActivity :

SignInActivity.kt

private fun onSignInResult(result: FirebaseAuthUIAuthenticationResult) {
    if (result.resultCode == RESULT_OK) {
        Log.d(TAG, "Sign in successful!")
        goToMainActivity()
    } else {
        Toast.makeText(
                this,
                "There was an error signing in",
                Toast.LENGTH_LONG).show()

        val response = result.idpResponse
        if (response == null) {
            Log.w(TAG, "Sign in canceled")
        } else {
            Log.w(TAG, "Sign in error", response.error)
        }
    }
}

এটাই! আপনি FirebaseUI এর সাথে প্রমাণীকরণ প্রয়োগ করেছেন মাত্র কয়েকটি পদ্ধতি কলে এবং কোনো সার্ভার-সাইড কনফিগারেশন পরিচালনা করার প্রয়োজন ছাড়াই।

আপনার কাজ পরীক্ষা করুন

আপনার অ্যান্ড্রয়েড এমুলেটরে অ্যাপটি চালান। আপনাকে অবিলম্বে সাইন-ইন স্ক্রিনে পাঠানো উচিত। সাইন ইন আলতো চাপুন ইমেইল বাটন দিয়ে, তারপর অ্যাকাউন্ট তৈরি করুন। সবকিছু সঠিকভাবে বাস্তবায়িত হলে, আপনাকে মেসেজিং স্ক্রিনে পাঠানো উচিত।

সাইন ইন করার পর আপনার ব্রাউজারের Firebase এমুলেটর সুইট UI 'তে খুলতে তারপর দেখতে এই প্রথম সাইন ইন থাকা ব্যবহারকারীর অ্যাকাউন্ট প্রমাণীকরণ ট্যাবটি ক্লিক করুন।

7. বার্তা পড়ুন

এই ধাপে, আমরা রিয়েলটাইম ডাটাবেসে সংরক্ষিত বার্তাগুলি পড়তে এবং প্রদর্শন করার জন্য কার্যকারিতা যোগ করব।

নমুনা বার্তা আমদানি করুন

  1. Firebase এমুলেটর সুইট UI 'তে সালে রিয়েলটাইম ডাটাবেস ট্যাব নির্বাচন করুন।
  2. ড্র্যাগ এবং ড্রপ initial_messages.json তথ্য ভিউয়ার মধ্যে codelab সংগ্রহস্থলের আপনার স্থানীয় অনুলিপি থেকে ফাইল।

আপনি এখন অধীন কয়েক বার্তা থাকা উচিত messages ডেটাবেসের নোড।

ডেটা পড়ুন

বার্তা সিঙ্ক্রোনাইজ করুন

এই বিভাগে আমরা কোড যোগ করি যা অ্যাপ UI-তে নতুন যোগ করা বার্তাগুলিকে এর দ্বারা সিঙ্ক্রোনাইজ করে:

  • ফায়ারবেস রিয়েলটাইম ডেটাবেস শুরু করা এবং ডেটাতে করা পরিবর্তনগুলি পরিচালনা করার জন্য একজন শ্রোতা যোগ করা।
  • আপডেট করা হচ্ছে RecyclerView অ্যাডাপ্টারের সুতরাং নতুন বার্তাগুলিকে দেখানো হবে।
  • আপনার অন্যান্য Firebase উদাহরণস্বরূপ ভেরিয়েবল সঙ্গে ডাটাবেস ইনস্ট্যান্স ভেরিয়েবল যোগ করার পদ্ধতি MainActivity শ্রেণী:

MainActivity.kt

// Firebase instance variables
// ...
private lateinit var db: FirebaseDatabase
private lateinit var adapter: FriendlyMessageAdapter

আপনার MainActivity এর সংশোধন onCreate() মন্তব্য অধীনে পদ্ধতি // Initialize Realtime Database and FirebaseRecyclerAdapter কোড নিচে সংজ্ঞায়িত করে। এই কোড রিয়েলটাইম ডাটাবেস থেকে সব বিদ্যমান বার্তাগুলি যোগ করা হয়েছে এবং তারপর অধীনে নতুন শিশু এন্ট্রি জন্য শোনে messages আপনার Firebase রিয়েলটাইম ডেটাবেসে পথ। এটি প্রতিটি বার্তার জন্য UI এ একটি নতুন উপাদান যুক্ত করে:

MainActivity.kt

// Initialize Realtime Database
db = Firebase.database
val messagesRef = db.reference.child(MESSAGES_CHILD)

// The FirebaseRecyclerAdapter class and options come from the FirebaseUI library
// See: https://github.com/firebase/FirebaseUI-Android
val options = FirebaseRecyclerOptions.Builder<FriendlyMessage>()
    .setQuery(messagesRef, FriendlyMessage::class.java)
    .build()
adapter = FriendlyMessageAdapter(options, getUserName())
binding.progressBar.visibility = ProgressBar.INVISIBLE
manager = LinearLayoutManager(this)
manager.stackFromEnd = true
binding.messageRecyclerView.layoutManager = manager
binding.messageRecyclerView.adapter = adapter

// Scroll down when a new message arrives
// See MyScrollToBottomObserver for details
adapter.registerAdapterDataObserver(
    MyScrollToBottomObserver(binding.messageRecyclerView, adapter, manager)
)

পরবর্তী FriendlyMessageAdapter.kt বর্গ বাস্তবায়ন bind() ভেতরের বর্গ মধ্যে পদ্ধতি MessageViewHolder() :

FriendlyMessageAdapter.kt

inner class MessageViewHolder(private val binding: MessageBinding) : ViewHolder(binding.root) {
    fun bind(item: FriendlyMessage) {
        binding.messageTextView.text = item.text
        setTextColor(item.name, binding.messageTextView)

        binding.messengerTextView.text = if (item.name == null) ANONYMOUS else item.name
        if (item.photoUrl != null) {
            loadImageIntoView(binding.messengerImageView, item.photoUrl!!)
        } else {
            binding.messengerImageView.setImageResource(R.drawable.ic_account_circle_black_36dp)
        }
    }
    ...
}

আমরা, প্রদর্শন বার্তা হয় ইমেজ প্রয়োজন তেমনি বাস্তবায়ন bind() ভেতরের বর্গ মধ্যে পদ্ধতি ImageMessageViewHolder() :

FriendlyMessageAdapter.kt

inner class ImageMessageViewHolder(private val binding: ImageMessageBinding) :
    ViewHolder(binding.root) {
    fun bind(item: FriendlyMessage) {
        loadImageIntoView(binding.messageImageView, item.imageUrl!!)

        binding.messengerTextView.text = if (item.name == null) ANONYMOUS else item.name
        if (item.photoUrl != null) {
            loadImageIntoView(binding.messengerImageView, item.photoUrl!!)
        } else {
            binding.messengerImageView.setImageResource(R.drawable.ic_account_circle_black_36dp)
        }
    }
}

অবশেষে, ফিরে MainActivity , শুরু ও স্টপ Firebase রিয়েলটাইম ডাটাবেস থেকে আপডেট জন্য শোনা। আপডেট করুন onPause() এবং onResume() পদ্ধতি MainActivity নিচের চিত্রের:

MainActivity.kt

public override fun onPause() {
    adapter.stopListening()
    super.onPause()
}

public override fun onResume() {
    super.onResume()
    adapter.startListening()
}

পরীক্ষা সিঙ্কিং বার্তা

  1. চালান ক্লিক করুন ( এক্সিকিউট )
  2. এমুলেটর সুইট UI 'তে সালে নিজে, রিয়েলটাইম ডাটাবেস ট্যাবটিতে ফিরে তারপর একটি নতুন বার্তা যোগ করুন। নিশ্চিত করুন যে বার্তাটি আপনার Android অ্যাপে দেখা যাচ্ছে:

অভিনন্দন, আপনি এইমাত্র আপনার অ্যাপে একটি রিয়েলটাইম ডাটাবেস যোগ করেছেন!

8. বার্তা পাঠান

পাঠ্য বার্তা প্রেরণ বাস্তবায়ন করুন

এই বিভাগে, আপনি অ্যাপ ব্যবহারকারীদের পাঠ্য বার্তা পাঠানোর ক্ষমতা যোগ করবেন। সেন্ড বাটন ক্লিক করুন ইভেন্টের জন্য শোনা নিচের কোড স্নিপেট, একটি নতুন সৃষ্টি FriendlyMessage বার্তা ক্ষেত্রের বিষয়বস্তু সঙ্গে বস্তু, এবং ডাটাবেস বার্তা push কর্মের। push() পদ্ধতি ধাক্কা বস্তুর পথে এক স্বয়ংক্রিয়ভাবে উত্পন্ন আইডি যোগ করে। এই আইডিগুলি অনুক্রমিক যা নিশ্চিত করে যে নতুন বার্তাগুলি তালিকার শেষে যোগ করা হবে৷

আপডেটে সেন্ড বাটন ক্লিক শ্রোতা onCreate() পদ্ধতি MainActivity বর্গ। এই কোড এর নীচে হয় onCreate() পদ্ধতি ইতিমধ্যে। আপডেট করুন onClick() শরীর নিচের কোড মেলে:

MainActivity.kt

// Disable the send button when there's no text in the input field
// See MyButtonObserver for details
binding.messageEditText.addTextChangedListener(MyButtonObserver(binding.sendButton))

// When the send button is clicked, send a text message
binding.sendButton.setOnClickListener {
    val friendlyMessage = FriendlyMessage(
        binding.messageEditText.text.toString(),
        getUserName(),
        getPhotoUrl(),
        null /* no image */
    )
    db.reference.child(MESSAGES_CHILD).push().setValue(friendlyMessage)
    binding.messageEditText.setText("")
}

ইমেজ বার্তা প্রেরণ বাস্তবায়ন

এই বিভাগে, আপনি অ্যাপ ব্যবহারকারীদের ইমেজ বার্তা পাঠানোর ক্ষমতা যোগ করবেন। একটি ইমেজ বার্তা তৈরি করা এই পদক্ষেপগুলির সাথে সম্পন্ন করা হয়:

  • ছবি নির্বাচন করুন
  • ছবি নির্বাচন পরিচালনা করুন
  • রিয়েলটাইম ডাটাবেসে অস্থায়ী চিত্র বার্তা লিখুন
  • নির্বাচিত ছবি আপলোড করা শুরু করুন
  • আপলোড সম্পূর্ণ হলে আপলোড করা ছবির সাথে ইমেজ মেসেজ ইউআরএল আপডেট করুন

ছবি নির্বাচন করুন

ছবি যোগ করতে এই কোডল্যাব ফায়ারবেসের জন্য ক্লাউড স্টোরেজ ব্যবহার করে। আপনার অ্যাপের বাইনারি ডেটা সঞ্চয় করার জন্য ক্লাউড স্টোরেজ একটি ভাল জায়গা।

ছবি নির্বাচন পরিচালনা করুন এবং অস্থায়ী বার্তা লিখুন

একবার ব্যবহারকারী চিত্রটি নির্বাচন করেছেন, ইমেজ নির্বাচন Intent চালু করা হয়। ইতিমধ্যে শেষে কোডে বাস্তবায়িত হয় onCreate() পদ্ধতি। কর্ম সমাপ্ত হলে এটা আহ্বান MainActivity এর onImageSelected() পদ্ধতি। নীচের কোড স্নিপেট ব্যবহার করে, আপনি একটি অস্থায়ী চিত্র url সহ ডাটাবেসে একটি বার্তা লিখবেন যা নির্দেশ করে যে ছবিটি আপলোড করা হচ্ছে৷

MainActivity.kt

private fun onImageSelected(uri: Uri) {
    Log.d(TAG, "Uri: $uri")
    val user = auth.currentUser
    val tempMessage = FriendlyMessage(null, getUserName(), getPhotoUrl(), LOADING_IMAGE_URL)
    db.reference
            .child(MESSAGES_CHILD)
            .push()
            .setValue(
                    tempMessage,
                    DatabaseReference.CompletionListener { databaseError, databaseReference ->
                        if (databaseError != null) {
                            Log.w(
                                    TAG, "Unable to write message to database.",
                                    databaseError.toException()
                            )
                            return@CompletionListener
                        }

                        // Build a StorageReference and then upload the file
                        val key = databaseReference.key
                        val storageReference = Firebase.storage
                                .getReference(user!!.uid)
                                .child(key!!)
                                .child(uri.lastPathSegment!!)
                        putImageInStorage(storageReference, uri, key)
                    })
}

ছবি আপলোড করুন এবং বার্তা আপডেট করুন

পদ্ধতি জুড়ুন putImageInStorage() থেকে MainActivity । এটা বলা হয় onImageSelected() নির্বাচিত চিত্রটি আপলোড শুরু করার। আপলোড সম্পূর্ণ হলে আপনি উপযুক্ত ছবি ব্যবহার করার জন্য বার্তাটি আপডেট করবেন।

MainActivity.kt

private fun putImageInStorage(storageReference: StorageReference, uri: Uri, key: String?) {
    // First upload the image to Cloud Storage
    storageReference.putFile(uri)
        .addOnSuccessListener(
            this
        ) { taskSnapshot -> // After the image loads, get a public downloadUrl for the image
            // and add it to the message.
            taskSnapshot.metadata!!.reference!!.downloadUrl
                .addOnSuccessListener { uri ->
                    val friendlyMessage =
                        FriendlyMessage(null, getUserName(), getPhotoUrl(), uri.toString())
                    db.reference
                        .child(MESSAGES_CHILD)
                        .child(key!!)
                        .setValue(friendlyMessage)
                }
        }
        .addOnFailureListener(this) { e ->
            Log.w(
                TAG,
                "Image upload task was unsuccessful.",
                e
            )
        }
}

বার্তা পাঠানোর পরীক্ষা করুন

  1. অ্যান্ড্রয়েড স্টুডিওতে, ক্লিক করুন এক্সিকিউট রান বোতাম।
  2. আপনার অ্যান্ড্রয়েড এমুলেটরে, একটি বার্তা লিখুন, তারপর পাঠান বোতামটি আলতো চাপুন। নতুন বার্তাটি অ্যাপ UI এবং Firebase Emulator Suite UI-তে দৃশ্যমান হওয়া উচিত।
  3. অ্যান্ড্রয়েড এমুলেটরে, আপনার ডিভাইস থেকে একটি ছবি নির্বাচন করতে "+" ছবিতে আলতো চাপুন৷ নতুন বার্তাটি প্রথমে একটি স্থানধারক চিত্রের সাথে দৃশ্যমান হওয়া উচিত, এবং তারপরে চিত্র আপলোড সম্পূর্ণ হলে নির্বাচিত চিত্রের সাথে। নতুন বার্তাটি এমুলেটর স্যুট UI-তেও দৃশ্যমান হওয়া উচিত, বিশেষত রিয়েলটাইম ডেটাবেস ট্যাবে একটি বস্তু হিসাবে এবং স্টোরেজ ট্যাবে একটি ব্লব হিসাবে।

9. অভিনন্দন!

আপনি Firebase ব্যবহার করে একটি রিয়েল-টাইম চ্যাট অ্যাপ্লিকেশন তৈরি করেছেন!

আপনি যা শিখেছেন

  • ফায়ারবেস প্রমাণীকরণ
  • ফায়ারবেস রিয়েলটাইম ডাটাবেস
  • ফায়ারবেসের জন্য ক্লাউড স্টোরেজ

এরপর, আপনার নিজের Android অ্যাপে Firebase যোগ করতে এই কোডল্যাবে আপনি যা শিখেছেন তা ব্যবহার করার চেষ্টা করুন! Firebase সম্পর্কে আরো জানতে, এখানে যান firebase.google.com

তুমি কেমন একটি বাস্তব Firebase প্রকল্পের সেট আপ করুন এবং (ক ডেমো প্রকল্প এবং শুধুমাত্র emulated সম্পদ পরিবর্তে) বাস্তব Firebase সম্পদ ব্যবহার শিখতে চান, পরবর্তী ধাপে অবিরত।

নোট: আপনি একটি বাস্তব Firebase প্রকল্পের সেট আপ করুন এবং বিশেষ করে যখন আপনি একটি বাস্তব অ্যাপ্লিকেশন নির্মাণের শুরু করার আগে, আমরা উন্নয়ন এবং পরীক্ষার জন্য Firebase স্থানীয় এমুলেটর সুইট ব্যবহার করার প্রস্তাব দিই পরেও।

10. ঐচ্ছিক: একটি ফায়ারবেস প্রকল্প তৈরি এবং সেট আপ করুন৷

এই ধাপে, আপনি এই কোডল্যাবের সাথে ব্যবহার করার জন্য একটি বাস্তব Firebase প্রকল্প এবং একটি Firebase Android অ্যাপ তৈরি করবেন। এছাড়াও আপনি আপনার অ্যাপে আপনার অ্যাপ-নির্দিষ্ট ফায়ারবেস কনফিগারেশন যোগ করবেন। এবং অবশেষে, আপনি আপনার অ্যাপের সাথে ব্যবহার করার জন্য বাস্তব ফায়ারবেস সংস্থান সেট আপ করবেন।

একটি ফায়ারবেস প্রকল্প তৈরি করুন

  1. আপনার ব্রাউজারে, এখানে যান Firebase কনসোল
  2. যোগ প্রকল্পের নির্বাচন করুন।
  3. একটি প্রকল্পের নাম নির্বাচন করুন বা লিখুন। আপনি চাইলে যেকোনো নাম ব্যবহার করতে পারেন।
  4. এই কোডল্যাবের জন্য আপনার Google Analytics এর প্রয়োজন নেই, তাই আপনি এটিকে আপনার প্রকল্পের জন্য সক্ষম করা এড়িয়ে যেতে পারেন।
  5. প্রকল্প তৈরি করুন ক্লিক করুন। যখন আপনার প্রকল্পের প্রস্তুত, অবিরত ক্লিক করুন।

আপনার Android প্রকল্পে Firebase যোগ করুন

আপনি এই ধাপটি শুরু করার আগে, আপনার অ্যাপের SHA1 হ্যাশ পান। আপনার স্থানীয় থেকে নিম্নোক্ত কমান্ড সঞ্চালন করুন build-android-start ডিরেক্টরি আপনার ডিবাগ কী SHA1 এ নির্ধারণ করুন:

./gradlew signingReport

Store: /Users/<username>/.android/debug.keystore
Alias: AndroidDebugKey
MD5: A5:88:41:04:8F:06:59:6A:AE:33:76:87:AA:AD:19:23
SHA1: A7:89:F5:06:A8:07:A1:22:EC:90:6A:A6:EA:C3:D4:8B:3A:30:AB:18
SHA-256: 05:A2:2A:35:EE:F2:51:23:72:4D:72:67:A5:6A:8A:58:22:2C:00:A6:AB:F6:45:D5:A1:82:D8:90:A4:69:C8:FE
Valid until: Wednesday, August 10, 2044

আপনি উপরের মত কিছু আউটপুট দেখতে হবে. গুরুত্বপূর্ণ লাইন SHA1 হ্যাশ। আপনি আপনার SHA1 এ হ্যাশ খুঁজে পেতে অসমর্থ হন, তাহলে দেখুন এই পৃষ্ঠার আরও তথ্যের জন্য।

Firebase কনসোলে ফিরে যান, এবং আপনার Firebase প্রকল্পের সাথে আপনার Android প্রকল্প নিবন্ধন করতে এই পদক্ষেপগুলি অনুসরণ করুন:

  1. আপনার নতুন প্রকল্পের ওভারভিউ স্ক্রীন থেকে, সেটআপ ওয়ার্কফ্লো চালু করতে Android আইকনে ক্লিক করুন: অ্যান্ড্রয়েড অ্যাপ যোগ করুন
  2. পরবর্তী স্ক্রীনে, প্রবেশ com.google.firebase.codelab.friendlychat আপনার অ্যাপের জন্য প্যাকেজের নাম হিসাবে।
  3. নিবন্ধন অ্যাপ, তারপর ক্লিক করে ডাউনলোড করুন Google এর services.json আপনার Firebase কনফিগারেশন ফাইল ডাউনলোড করতে ক্লিক করুন।
  4. কপি google-services.json মধ্যে ফাইল app আপনার অ্যান্ড্রয়েড প্রকল্পের ডিরেক্টরি।
  5. কনসোলের সেটআপ কর্মপ্রবাহ দেখানো পরবর্তী পদক্ষেপসমূহ কর (তারা ইতিমধ্যে আপনার জন্য কাজ করে থাকেন build-android-start প্রকল্পের)।
  6. Gradle ফাইলগুলির সাথে আপনার প্রকল্প সিঙ্ক করে সমস্ত নির্ভরতা আপনার অ্যাপে উপলব্ধ রয়েছে তা নিশ্চিত করুন৷ অ্যান্ড্রয়েড স্টুডিও সরঞ্জামদণ্ড থেকে, ফাইল> Gradle ফাইল সঙ্গে সিঙ্ক প্রকল্প নির্বাচন করুন।

ফায়ারবেস প্রমাণীকরণ কনফিগার করুন

আপনার অ্যাপ আপনার ব্যবহারকারীদের পক্ষ থেকে Firebase প্রমাণীকরণ API গুলি অ্যাক্সেস করার আগে, আপনাকে Firebase প্রমাণীকরণ এবং আপনি আপনার অ্যাপে যে সাইন-ইন প্রদানকারীগুলি ব্যবহার করতে চান তা সক্ষম করতে হবে৷

  1. ইন Firebase কনসোল , বাম প্রান্তের নেভিগেশন প্যানেল থেকে প্রমাণীকরণ নির্বাচন করুন।
  2. সাইন-ইন পদ্ধতি ট্যাবটি নির্বাচন করুন।
  3. , ইমেইল / পাসওয়ার্ড ক্লিক করুন, তারপর সক্রিয় (নীল) সুইচ টগল।
  4. , গুগল ক্লিক করুন, তারপর সক্রিয় (নীল) সুইচ টগল এবং একটি প্রকল্প সমর্থন ইমেল সেট।

আপনি যদি এই কোডল্যাবে পরে "CONFIGURATION_NOT_FOUND" বার্তা সহ ত্রুটি পান, তাহলে এই ধাপে ফিরে আসুন এবং আপনার কাজটি দুবার পরীক্ষা করুন৷

রিয়েলটাইম ডাটাবেস কনফিগার করুন

এই কোডল্যাবের অ্যাপটি ফায়ারবেস রিয়েলটাইম ডেটাবেসে চ্যাট মেসেজ সঞ্চয় করে। এই বিভাগে, আমরা একটি ডাটাবেস তৈরি করব এবং Firebase নিরাপত্তা নিয়ম নামক JSON কনফিগারেশন ভাষার মাধ্যমে এর নিরাপত্তা কনফিগার করব।

  1. ইন Firebase কনসোল , বাম প্রান্তের নেভিগেশন প্যানেল থেকে রিয়েলটাইম ডাটাবেস নির্বাচন করুন।
  2. ক্লিক করুন একটি নতুন রিয়েলটাইম ডাটাবেস ইনস্ট্যান্স তৈরি করতে ডাটাবেস তৈরি করুন। যখন বলা হবে, নির্বাচন us-central1 অঞ্চল, তারপর Next ক্লিক করুন।
  3. কখন নিরাপত্তা নিয়ম সম্পর্কে প্রণোদিত করা হয়, লক মোড নির্বাচন করুন, তারপর Enable এ ক্লিক করুন।
  4. একবার ডাটাবেস ইনস্ট্যান্স তৈরি হয়েছে, বিধি ট্যাব নির্বাচন করুন, তারপর নিম্নলিখিত সঙ্গে নিয়ম কনফিগারেশন আপডেট করুন:
     {
       "rules": {
         "messages": {
           ".read": "auth.uid != null",
           ".write": "auth.uid != null"
         }
       }
     }
    

কিভাবে সিকিউরিটি রুলস কাজ ( "প্রমাণীকরণ" পরিবর্তনশীল উপর ডকুমেন্টেশন সহ) উপর আরো তথ্যের জন্য, দেখুন রিয়েলটাইম ডাটাবেস নিরাপত্তা ডকুমেন্টেশন

ফায়ারবেসের জন্য ক্লাউড স্টোরেজ কনফিগার করুন

  1. ইন Firebase কনসোল , বাম প্রান্তের নেভিগেশন প্যানেল থেকে সংগ্রহস্থল নির্বাচন করুন।
  2. আপনার প্রকল্পের জন্য ক্লাউড স্টোরেজ সক্ষম করতে শুরু করা যাক ক্লিক করুন।
  3. প্রস্তাবিত ডিফল্টগুলি ব্যবহার করে আপনার বালতি সেট আপ করতে ডায়ালগের ধাপগুলি অনুসরণ করুন৷

Firebase সম্পদের সাথে সংযোগ করুন

এই codelab এর আগের পদক্ষেপে, আপনাকে নিম্নলিখিত যোগ MainActivity.kt । এই শর্তসাপেক্ষ ব্লক আপনার Android প্রকল্পকে Firebase এমুলেটর স্যুটের সাথে সংযুক্ত করেছে।

// REMOVE OR DISABLE THIS
if (BuildConfig.DEBUG) {
    Firebase.database.useEmulator("10.0.2.2", 9000)
    Firebase.auth.useEmulator("10.0.2.2", 9099)
    Firebase.storage.useEmulator("10.0.2.2", 9199)
}

আপনি আপনার নতুন বাস্তব Firebase প্রকল্প এবং তার বাস্তব Firebase সম্পদ আপনার অ্যাপ সংযোগ স্থাপন করতে চান, আপনি পারেন এই ব্লক সরাতে বা মুক্তি মোডে আপনার অ্যাপটি চালাতে যাতে করতে BuildConfig.DEBUG হয় false