FCM JavaScript API আপনাকে Push API সমর্থন করে এমন ব্রাউজারে চলমান ওয়েব অ্যাপে বিজ্ঞপ্তি বার্তা পেতে দেয়। এতে এই সমর্থন ম্যাট্রিক্সে তালিকাভুক্ত ব্রাউজার সংস্করণ এবং Push API-এর মাধ্যমে Chrome এক্সটেনশন অন্তর্ভুক্ত রয়েছে।
FCM SDK শুধুমাত্র HTTPS-এ পরিবেশিত পৃষ্ঠাগুলিতে সমর্থিত। এটি পরিষেবা কর্মীদের ব্যবহারের কারণে, যা শুধুমাত্র HTTPS সাইটগুলিতে উপলব্ধ৷ আপনার যদি কোনো প্রদানকারীর প্রয়োজন হয়, Firebase হোস্টিং সুপারিশ করা হয় এবং আপনার নিজের ডোমেনে HTTPS হোস্টিংয়ের জন্য একটি বিনা খরচে স্তর প্রদান করে।
FCM JavaScript API দিয়ে শুরু করতে, আপনাকে আপনার ওয়েব অ্যাপে Firebase যোগ করতে হবে এবং নিবন্ধন টোকেন অ্যাক্সেস করার জন্য যুক্তি যোগ করতে হবে।
FCM SDK যোগ করুন এবং আরম্ভ করুন
আপনি যদি ইতিমধ্যেই না করে থাকেন তাহলে Firebase JS SDK ইনস্টল করুন এবং Firebase শুরু করুন ।
Firebase ক্লাউড মেসেজিং JS SDK যোগ করুন এবং Firebase ক্লাউড মেসেজিং শুরু করুন:
ওয়েব মডুলার API
import { initializeApp } from "firebase/app"; import { getMessaging } from "firebase/messaging"; // TODO: Replace the following with your app's Firebase project configuration // See: https://firebase.google.com/docs/web/learn-more#config-object const firebaseConfig = { // ... }; // Initialize Firebase const app = initializeApp(firebaseConfig); // Initialize Firebase Cloud Messaging and get a reference to the service const messaging = getMessaging(app);
ওয়েব নামস্থান API
import firebase from "firebase/compat/app"; import "firebase/compat/messaging"; // TODO: Replace the following with your app's Firebase project configuration // See: https://firebase.google.com/docs/web/learn-more#config-object const firebaseConfig = { // ... }; // Initialize Firebase firebase.initializeApp(firebaseConfig); // Initialize Firebase Cloud Messaging and get a reference to the service const messaging = firebase.messaging();
আপনি যদি বর্তমানে ওয়েবের জন্য FCM ব্যবহার করেন এবং SDK 6.7.0 বা তার পরে আপগ্রেড করতে চান, তাহলে আপনাকে Google Cloud Console-এ আপনার প্রোজেক্টের জন্য FCM রেজিস্ট্রেশন API সক্ষম করতে হবে। আপনি যখন API সক্ষম করবেন, নিশ্চিত করুন যে আপনি Firebase-এর জন্য ব্যবহার করেন সেই একই Google অ্যাকাউন্ট দিয়ে আপনি Cloud Console-এ লগ ইন করেছেন এবং সঠিক প্রজেক্ট নির্বাচন করতে ভুলবেন না। FCM SDK যুক্ত করা নতুন প্রকল্পগুলিতে ডিফল্টরূপে এই API সক্ষম করা থাকে৷
FCM দিয়ে ওয়েব শংসাপত্র কনফিগার করুন
এফসিএম ওয়েব ইন্টারফেস সমর্থিত ওয়েব পুশ পরিষেবাগুলিতে অনুরোধ পাঠানোর অনুমোদনের জন্য "স্বেচ্ছাসেবী অ্যাপ্লিকেশন সার্ভার আইডেন্টিফিকেশন" বা "VAPID" কী নামক ওয়েব শংসাপত্র ব্যবহার করে। বিজ্ঞপ্তিগুলি পুশ করতে আপনার অ্যাপটি সদস্যতা নিতে, আপনাকে আপনার Firebase প্রকল্পের সাথে এক জোড়া কী সংযুক্ত করতে হবে৷ আপনি হয় একটি নতুন কী জোড়া তৈরি করতে পারেন বা Firebase কনসোলের মাধ্যমে আপনার বিদ্যমান কী জোড়া আমদানি করতে পারেন।
একটি নতুন কী জোড়া তৈরি করুন
- Firebase কনসোল সেটিংস ফলকের ক্লাউড মেসেজিং ট্যাবটি খুলুন এবং ওয়েব কনফিগারেশন বিভাগে স্ক্রোল করুন।
- ওয়েব পুশ সার্টিফিকেট ট্যাবে, কী জোড়া তৈরি করুন ক্লিক করুন। কনসোল একটি নোটিশ প্রদর্শন করে যে কী জোড়া তৈরি করা হয়েছে এবং সর্বজনীন কী স্ট্রিং এবং তারিখ যোগ করা হয়েছে তা প্রদর্শন করে।
একটি বিদ্যমান কী জোড়া আমদানি করুন
আপনার যদি একটি বিদ্যমান কী জোড়া থাকে যা আপনি ইতিমধ্যেই আপনার ওয়েব অ্যাপের সাথে ব্যবহার করছেন, আপনি এটি FCM এ আমদানি করতে পারেন যাতে আপনি FCM API-এর মাধ্যমে আপনার বিদ্যমান ওয়েব অ্যাপের দৃষ্টান্তগুলিতে পৌঁছাতে পারেন। কী আমদানি করতে, আপনার Firebase প্রকল্পে মালিক-স্তরের অ্যাক্সেস থাকতে হবে। বেস64 ইউআরএল নিরাপদ এনকোডেড আকারে আপনার বিদ্যমান সর্বজনীন এবং ব্যক্তিগত কী আমদানি করুন:
- Firebase কনসোল সেটিংস ফলকের ক্লাউড মেসেজিং ট্যাবটি খুলুন এবং ওয়েব কনফিগারেশন বিভাগে স্ক্রোল করুন।
- ওয়েব পুশ সার্টিফিকেট ট্যাবে, লিঙ্ক টেক্সট খুঁজুন এবং নির্বাচন করুন, "একটি বিদ্যমান কী জোড়া আমদানি করুন।"
- একটি কী জোড়া ডায়ালগে আমদানি করুন , সংশ্লিষ্ট ক্ষেত্রে আপনার সর্বজনীন এবং ব্যক্তিগত কীগুলি প্রদান করুন এবং আমদানিতে ক্লিক করুন। কনসোল সর্বজনীন কী স্ট্রিং এবং যোগ করা তারিখ প্রদর্শন করে।
কীভাবে আপনার অ্যাপে কী যুক্ত করবেন তার নির্দেশাবলীর জন্য, আপনার অ্যাপে ওয়েব শংসাপত্র কনফিগার করুন দেখুন। কীগুলির বিন্যাস এবং কীভাবে সেগুলি তৈরি করতে হয় সে সম্পর্কে আরও তথ্যের জন্য, অ্যাপ্লিকেশন সার্ভার কীগুলি দেখুন।
আপনার অ্যাপে ওয়েব শংসাপত্র কনফিগার করুন
মেথড getToken(): Promise<string>
FCM কে VAPID কী শংসাপত্র ব্যবহার করার অনুমতি দেয় যখন বিভিন্ন পুশ পরিষেবাতে বার্তার অনুরোধ পাঠানো হয়। FCM এর সাথে ওয়েব শংসাপত্র কনফিগার করার নির্দেশাবলী অনুসারে আপনি যে কী তৈরি করেছেন বা আমদানি করেছেন তা ব্যবহার করে, মেসেজিং অবজেক্ট পুনরুদ্ধার করার পরে এটি আপনার কোডে যোগ করুন:
import { getMessaging, getToken } from "firebase/messaging";
const messaging = getMessaging();
// Add the public key generated from the console here.
getToken(messaging, {vapidKey: "BKagOny0KF_2pCJQ3m....moL0ewzQ8rZu"});
নিবন্ধন টোকেন অ্যাক্সেস করুন
যখন আপনাকে একটি অ্যাপের উদাহরণের জন্য বর্তমান নিবন্ধন টোকেন পুনরুদ্ধার করতে হবে, প্রথমে Notification.requestPermission()
এর মাধ্যমে ব্যবহারকারীর কাছ থেকে বিজ্ঞপ্তির অনুমতির অনুরোধ করুন। দেখানো হিসাবে বলা হলে, অনুমতি দেওয়া হলে এটি একটি টোকেন ফেরত দেয় বা অস্বীকার করা হলে প্রতিশ্রুতি প্রত্যাখ্যান করে:
function requestPermission() { console.log('Requesting permission...'); Notification.requestPermission().then((permission) => { if (permission === 'granted') { console.log('Notification permission granted.');
FCM-এর জন্য একটি firebase-messaging-sw.js
ফাইল প্রয়োজন। যদি না আপনার কাছে আগে থেকেই একটি firebase-messaging-sw.js
ফাইল থাকে, সেই নামের একটি খালি ফাইল তৈরি করুন এবং একটি টোকেন পুনরুদ্ধার করার আগে এটিকে আপনার ডোমেনের রুটে রাখুন। আপনি পরে ক্লায়েন্ট সেটআপ প্রক্রিয়ায় ফাইলটিতে অর্থপূর্ণ বিষয়বস্তু যোগ করতে পারেন।
বর্তমান টোকেন পুনরুদ্ধার করতে:
Web modular API
import { getMessaging, getToken } from "firebase/messaging"; // Get registration token. Initially this makes a network call, once retrieved // subsequent calls to getToken will return from cache. const messaging = getMessaging(); getToken(messaging, { vapidKey: '<YOUR_PUBLIC_VAPID_KEY_HERE>' }).then((currentToken) => { if (currentToken) { // Send the token to your server and update the UI if necessary // ... } else { // Show permission request UI console.log('No registration token available. Request permission to generate one.'); // ... } }).catch((err) => { console.log('An error occurred while retrieving token. ', err); // ... });
Web namespaced API
// Get registration token. Initially this makes a network call, once retrieved // subsequent calls to getToken will return from cache. messaging.getToken({ vapidKey: '<YOUR_PUBLIC_VAPID_KEY_HERE>' }).then((currentToken) => { if (currentToken) { // Send the token to your server and update the UI if necessary // ... } else { // Show permission request UI console.log('No registration token available. Request permission to generate one.'); // ... } }).catch((err) => { console.log('An error occurred while retrieving token. ', err); // ... });
আপনি টোকেনটি পাওয়ার পরে, এটি আপনার অ্যাপ সার্ভারে পাঠান এবং আপনার পছন্দের পদ্ধতি ব্যবহার করে সংরক্ষণ করুন।
পরবর্তী পদক্ষেপ
আপনি সেটআপ পদক্ষেপগুলি সম্পন্ন করার পরে, ওয়েবের জন্য FCM (জাভাস্ক্রিপ্ট) এর সাথে এগিয়ে যাওয়ার জন্য এখানে কয়েকটি বিকল্প রয়েছে:
- বার্তা পেতে আপনার অ্যাপে কার্যকারিতা যোগ করুন।
- আমাদের টিউটোরিয়ালগুলির মধ্যে একটি ব্যবহার করে দেখুন: একটি পটভূমি অ্যাপে আপনার প্রথম বার্তা পাঠান বা একাধিক ডিভাইসে বার্তা পাঠান ।
- GitHub-এ একটি সম্পূর্ণ নমুনা পর্যালোচনা করুন।
- জাভাস্ক্রিপ্ট রেফারেন্স পর্যালোচনা করুন।
- API বাস্তবায়নের একটি ভিডিও ওয়াকথ্রু দেখুন।