| প্ল্যাটফর্ম নির্বাচন করুন: | iOS+ অ্যান্ড্রয়েড ওয়েব ফ্লাটার ইউনিটি C++ |
মেসেজ গ্রহণ করার জন্য, আপনি FirebaseMessagingService এক্সটেন্ড করে এমন একটি সার্ভিস ব্যবহার করতে পারেন। আপনার সার্ভিসে onMessageReceived এবং onDeletedMessages কলব্যাকগুলো ওভাররাইড করা উচিত। একটি সম্পূর্ণ উদাহরণের জন্য, Firebase Cloud Messaging কুইকস্টার্ট স্যাম্পলটি দেখুন।
নিম্নলিখিত ব্যতিক্রমগুলি ছাড়া বেশিরভাগ মেসেজ টাইপের জন্য onMessageReceived প্রদান করা হয়:
আপনার অ্যাপ ব্যাকগ্রাউন্ডে থাকা অবস্থায় নোটিফিকেশন মেসেজ পাঠানো হয় । এক্ষেত্রে, নোটিফিকেশনটি ডিভাইসের সিস্টেম ট্রে-তে পৌঁছে যায়। কোনো নোটিফিকেশনে ট্যাপ করলে ডিফল্টভাবে অ্যাপ লঞ্চারটি খুলে যায়।
যেসব মেসেজে নোটিফিকেশন এবং ডেটা পেলোড উভয়ই থাকে, সেগুলো ব্যাকগ্রাউন্ডে গ্রহণ করা হলে নোটিফিকেশনটি ডিভাইসের সিস্টেম ট্রে-তে এবং ডেটা পেলোডটি আপনার লঞ্চার অ্যাক্টিভিটির ইন্টেন্টের এক্সট্রাস-এ ডেলিভার করা হয়।
সারসংক্ষেপে:
| অ্যাপের অবস্থা | বিজ্ঞপ্তি | ডেটা | উভয় |
|---|---|---|---|
| সম্মুখভাগ | onMessageReceived | onMessageReceived | onMessageReceived |
| পটভূমি | সিস্টেম ট্রে | onMessageReceived | নোটিফিকেশন: সিস্টেম ট্রে ডেটা: ইন্টেন্টের এক্সট্রাস-এর মধ্যে। |
বার্তার প্রকারভেদ সম্পর্কে আরও তথ্যের জন্য, বিজ্ঞপ্তি এবং ডেটা বার্তা দেখুন।
onMessageReceived কলব্যাকের এক্সিকিউশন উইন্ডো খুবই সংক্ষিপ্ত। এই উইন্ডোর সময়কাল অনেক কারণের উপর নির্ভর করে, যার মধ্যে রয়েছে OS-এর বিলম্ব, অ্যাপ চালু হওয়ার সময়, অন্যান্য অপারেশনের কারণে মেইন থ্রেড ব্লক হয়ে যাওয়া, অথবা পূর্ববর্তী onMessageReceived কলগুলো সম্পন্ন হতে অতিরিক্ত সময় নেওয়া।
এই কারণে, আপনার onMessageReceived এ দীর্ঘ সময় ধরে চলা কাজগুলি (যেমন নোটিফিকেশনে দেখানোর জন্য সার্ভার থেকে ছবি আনা) এড়িয়ে চলা উচিত এবং এর পরিবর্তে, যে কাজগুলি সম্পন্ন হতে কয়েক সেকেন্ডের বেশি সময় লাগতে পারে, সেগুলি পরিচালনা করার জন্য WorkManager ব্যবহার করে একটি টাস্ক শিডিউল করা উচিত। মেসেজ প্রায়োরিটি এবং এটি কীভাবে প্রসেসিংকে প্রভাবিত করে সে সম্পর্কে আরও তথ্যের জন্য, উচ্চ এবং সাধারণ প্রায়োরিটির মেসেজের জন্য মেসেজ প্রসেসিং দেখুন।
অ্যাপ ম্যানিফেস্ট সম্পাদনা করুন
FirebaseMessagingService ব্যবহার করতে হলে, আপনার অ্যাপ ম্যানিফেস্টে নিম্নলিখিত বিষয়গুলো যোগ করতে হবে:
<service
android:name=".java.MyFirebaseMessagingService"
android:exported="false">
<intent-filter>
<action android:name="com.google.firebase.MESSAGING_EVENT" />
</intent-filter>
</service>
নোটিফিকেশনের চেহারা কাস্টমাইজ করতে ডিফল্ট মান সেট করার পরামর্শ দেওয়া হয়। আপনি একটি কাস্টম ডিফল্ট আইকন এবং একটি কাস্টম ডিফল্ট রঙ নির্দিষ্ট করতে পারেন, যা নোটিফিকেশন পেলোডে সমতুল্য মান সেট করা না থাকলে প্রয়োগ করা হবে।
কাস্টম ডিফল্ট আইকন এবং কাস্টম রঙ সেট করতে application ট্যাগের ভিতরে এই লাইনগুলো যোগ করুন:
<!-- Set custom default icon. This is used when no icon is set for incoming notification messages.
See README(https://goo.gl/l4GJaQ) for more. -->
<meta-data
android:name="com.google.firebase.messaging.default_notification_icon"
android:resource="@drawable/ic_stat_ic_notification" />
<!-- Set color used with incoming notification messages. This is used when no color is set for the incoming
notification message. See README(https://goo.gl/6BKBk7) for more. -->
<meta-data
android:name="com.google.firebase.messaging.default_notification_color"
android:resource="@color/colorAccent" />
অ্যান্ড্রয়েড কাস্টম ডিফল্ট আইকন প্রদর্শন করে এবং ব্যবহার করে
- নোটিফিকেশন কম্পোজার থেকে পাঠানো সমস্ত নোটিফিকেশন বার্তা।
- যেকোনো নোটিফিকেশন মেসেজ, যা নোটিফিকেশন পেলোডে আইকনটি স্পষ্টভাবে সেট করে না।
যদি কোনো কাস্টম ডিফল্ট আইকন সেট করা না থাকে এবং নোটিফিকেশন পেলোডেও কোনো আইকন সেট করা না থাকে, তাহলে অ্যান্ড্রয়েড অ্যাপ্লিকেশন আইকনটি সাদা রঙে প্রদর্শন করে।
onMessageReceived ওভাররাইড করুন
FirebaseMessagingService.onMessageReceived মেথডটি ওভাররাইড করার মাধ্যমে, আপনি প্রাপ্ত RemoteMessage অবজেক্টের উপর ভিত্তি করে বিভিন্ন অ্যাকশন সম্পাদন করতে এবং মেসেজের ডেটা পেতে পারেন:
Kotlin
override fun onMessageReceived(remoteMessage: RemoteMessage) { // TODO(developer): Handle FCM messages here. // Not getting messages here? See why this may be: https://goo.gl/39bRNJ Log.d(TAG, "From: ${remoteMessage.from}") // Check if message contains a data payload. if (remoteMessage.data.isNotEmpty()) { Log.d(TAG, "Message data payload: ${remoteMessage.data}") // Check if data needs to be processed by long running job if (needsToBeScheduled()) { // For long-running tasks (10 seconds or more) use WorkManager. scheduleJob() } else { // Handle message within 10 seconds handleNow() } } // Check if message contains a notification payload. remoteMessage.notification?.let { Log.d(TAG, "Message Notification Body: ${it.body}") } // Also if you intend on generating your own notifications as a result of a received FCM // message, here is where that should be initiated. See sendNotification method below. }
Java
@Override public void onMessageReceived(RemoteMessage remoteMessage) { // TODO(developer): Handle FCM messages here. // Not getting messages here? See why this may be: https://goo.gl/39bRNJ Log.d(TAG, "From: " + remoteMessage.getFrom()); // Check if message contains a data payload. if (remoteMessage.getData().size() > 0) { Log.d(TAG, "Message data payload: " + remoteMessage.getData()); if (/* Check if data needs to be processed by long running job */ true) { // For long-running tasks (10 seconds or more) use WorkManager. scheduleJob(); } else { // Handle message within 10 seconds handleNow(); } } // Check if message contains a notification payload. if (remoteMessage.getNotification() != null) { Log.d(TAG, "Message Notification Body: " + remoteMessage.getNotification().getBody()); } // Also if you intend on generating your own notifications as a result of a received FCM // message, here is where that should be initiated. See sendNotification method below. }
onDeletedMessages ওভাররাইড করুন
কিছু পরিস্থিতিতে, FCM কোনো মেসেজ ডেলিভার নাও করতে পারে। এমনটা ঘটে যখন কোনো নির্দিষ্ট ডিভাইসে আপনার অ্যাপের জন্য কানেক্ট হওয়ার সময় অনেক বেশি মেসেজ (>100) পেন্ডিং থাকে অথবা যদি ডিভাইসটি এক মাসের বেশি সময় ধরে FCM এর সাথে কানেক্ট না হয়ে থাকে। এইসব ক্ষেত্রে, আপনি FirebaseMessagingService.onDeletedMessages() -এ একটি কলব্যাক পেতে পারেন। যখন অ্যাপ ইনস্ট্যান্স এই কলব্যাকটি পায়, তখন এটির উচিত আপনার অ্যাপ সার্ভারের সাথে একটি সম্পূর্ণ সিঙ্ক করা। যদি আপনি গত ৪ সপ্তাহের মধ্যে সেই ডিভাইসের অ্যাপে কোনো মেসেজ না পাঠিয়ে থাকেন, FCM onDeletedMessages() কল করবে না।
ব্যাকগ্রাউন্ডে থাকা অ্যাপে নোটিফিকেশন মেসেজ পরিচালনা করুন
যখন আপনার অ্যাপ ব্যাকগ্রাউন্ডে থাকে, অ্যান্ড্রয়েড নোটিফিকেশন মেসেজগুলো সিস্টেম ট্রে-তে পাঠিয়ে দেয়। ব্যবহারকারী নোটিফিকেশনটিতে ট্যাপ করলে ডিফল্টরূপে অ্যাপ লঞ্চারটি খুলে যায়।
এর মধ্যে সেইসব মেসেজ অন্তর্ভুক্ত রয়েছে যেগুলিতে নোটিফিকেশন এবং ডেটা পেলোড উভয়ই থাকে (এবং নোটিফিকেশন কনসোল থেকে পাঠানো সমস্ত মেসেজও)। এই ক্ষেত্রে, নোটিফিকেশনটি ডিভাইসের সিস্টেম ট্রে-তে ডেলিভার করা হয়, এবং ডেটা পেলোডটি আপনার লঞ্চার অ্যাক্টিভিটির ইন্টেন্টের এক্সট্রাস-এ ডেলিভার করা হয়।
আপনার অ্যাপে বার্তা ডেলিভারি সম্পর্কে আরও তথ্যের জন্য, FCM রিপোর্টিং ড্যাশবোর্ড দেখুন, যেখানে অ্যাপল এবং অ্যান্ড্রয়েড ডিভাইসে পাঠানো ও খোলা বার্তার সংখ্যার পাশাপাশি অ্যান্ড্রয়েড অ্যাপের 'ইম্প্রেশন' (ব্যবহারকারীদের দেখা নোটিফিকেশন) ডেটাও রেকর্ড করা থাকে।