একটি প্রগতিশীল ওয়েব অ্যাপে (PWA) Firebase ব্যবহার করুন

প্রগ্রেসিভ ওয়েব অ্যাপস (PWAs) হল ওয়েব অ্যাপ যা আপনার ব্যবহারকারীদের একটি নির্ভরযোগ্য, দ্রুত এবং আকর্ষক অভিজ্ঞতা নিশ্চিত করার জন্য নির্দেশিকাগুলির একটি সেট অনুসরণ করে।

ফায়ারবেস অনেকগুলি পরিষেবা অফার করে যা আপনাকে অনেকগুলি PWA সেরা অনুশীলনগুলি পূরণ করতে দক্ষতার সাথে আপনার অ্যাপে প্রগতিশীল বৈশিষ্ট্যগুলি যোগ করতে সহায়তা করতে পারে, যার মধ্যে রয়েছে:

PWA সেরা অনুশীলন ফায়ারবেস পরিষেবাগুলি কীভাবে সাহায্য করতে পারে৷
নিরাপদ এবং নিরাপদ
  • Firebase Hosting আপনার কাস্টম ডোমেন এবং ডিফল্ট Firebase সাবডোমেনের জন্য কোনো খরচ ছাড়াই SSL সার্টিফিকেটের বিধান করে।
  • Firebase Authentication আপনাকে সমস্ত ডিভাইস জুড়ে ব্যবহারকারীদের নিরাপদে সাইন ইন করতে সক্ষম করে।
  • FirebaseUI প্রমাণীকরণ প্রবাহের জন্য সর্বোত্তম অনুশীলন প্রয়োগ করে।
দ্রুত লোড সময়
  • Firebase Hosting HTTP/2 সমর্থন করে এবং একটি বিশ্বব্যাপী CDN-এ আপনার স্ট্যাটিক এবং ডাইনামিক উভয় বিষয়বস্তু ক্যাশে করতে পারে।
  • Firebase JavaScript SDK হল মডুলার, এবং যখন প্রয়োজন হয় তখন আপনি গতিশীলভাবে লাইব্রেরি আমদানি করতে পারেন।
নেটওয়ার্ক স্থিতিস্থাপকতা
  • Cloud Firestore সাথে, আপনি রিয়েল টাইমে এবং অফলাইনে ডেটা সঞ্চয় এবং অ্যাক্সেস করতে পারেন।
  • Firebase Authentication একটি ব্যবহারকারীর প্রমাণীকরণ অবস্থা বজায় রাখে, এমনকি অফলাইনেও।
ব্যবহারকারীদের নিযুক্ত করুন
  • Firebase Cloud Messaging আপনাকে আপনার ব্যবহারকারীদের ডিভাইসে পুশ বার্তা পাঠাতে সক্ষম করে।
  • Cloud Functions for Firebase সাহায্যে, আপনি ক্লাউড ইভেন্টের উপর ভিত্তি করে পুনঃনিযুক্তি বার্তাগুলি স্বয়ংক্রিয় করতে পারেন৷

আমাদের ক্রস-ব্রাউজার Firebase JavaScript SDK ব্যবহার করে একটি আধুনিক, উচ্চ-পারফরম্যান্স PWA তৈরি করতে Firebase প্ল্যাটফর্ম কীভাবে আপনাকে সাহায্য করতে পারে তার একটি সংক্ষিপ্ত বিবরণ এই পৃষ্ঠাটি অফার করে।

আপনার ওয়েব অ্যাপে Firebase যোগ করতে আমাদের শুরু করার নির্দেশিকা দেখুন।

নিরাপদ এবং নিরাপদ

আপনার সাইট পরিবেশন করা থেকে শুরু করে একটি প্রমাণীকরণ প্রবাহ বাস্তবায়ন পর্যন্ত, এটি গুরুত্বপূর্ণ যে আপনার PWA একটি নিরাপদ এবং বিশ্বস্ত কর্মপ্রবাহ প্রদান করে।

HTTPS এর মাধ্যমে আপনার PWA পরিবেশন করুন

পারফরম্যান্স হোস্টিং পরিষেবা

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

Firebase Hosting , ডিফল্টরূপে, HTTPS-এর মাধ্যমে আপনার অ্যাপের সামগ্রী পরিবেশন করে। আপনি আপনার সামগ্রী বিনা খরচে Firebase-সাবডোমেনে বা আপনার নিজস্ব কাস্টম ডোমেনে পরিবেশন করতে পারেন। আমাদের হোস্টিং পরিষেবা স্বয়ংক্রিয়ভাবে এবং কোনো খরচ ছাড়াই আপনার কাস্টম ডোমেনের জন্য একটি SSL শংসাপত্রের ব্যবস্থা করে।

আপনি কিভাবে Firebase প্ল্যাটফর্মে আপনার PWA হোস্ট করতে পারেন তা শিখতে Firebase Hosting এর শুরুর নির্দেশিকা দেখুন।

একটি নিরাপদ প্রমাণীকরণ প্রবাহ অফার

ড্রপ-ইন প্রতিক্রিয়াশীল প্রমাণীকরণ প্রবাহ

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

FirebaseUI একাধিক সাইন-ইন প্রদানকারীকে সমর্থন করে। সাইন-ইন প্রদানকারীদের জন্য কনফিগার করা কোডের মাত্র কয়েকটি লাইন দিয়ে আপনার অ্যাপে FirebaseUI প্রমাণীকরণ প্রবাহ যোগ করুন:

// FirebaseUI config.
var uiConfig = {
  signInSuccessUrl: 'URL',  // the URL to direct to upon success
  signInOptions: [
    firebase.auth.GoogleAuthProvider.PROVIDER_ID,
    firebase.auth.EmailAuthProvider.PROVIDER_ID
  ]
};

// Initialize the FirebaseUI widget using Firebase.
var ui = new firebaseui.auth.AuthUI(firebase.auth());
ui.start('#firebaseui-auth-container', uiConfig);

FirebaseUI দ্বারা অফার করা বিভিন্ন কনফিগারেশন বিকল্প সম্পর্কে আরও জানতে GitHub-এ আমাদের ডকুমেন্টেশন দেখুন।

ডিভাইস জুড়ে ব্যবহারকারীদের সাইন ইন করুন

ডিভাইস জুড়ে সাইন-ইন করুন

এক-ট্যাপ সাইন ইন সংহত করতে FirebaseUI ব্যবহার করে, আপনার অ্যাপ স্বয়ংক্রিয়ভাবে ব্যবহারকারীদের সাইন ইন করতে পারে, এমনকি তারা তাদের সাইন-ইন শংসাপত্রের সাথে সেট আপ করা বিভিন্ন ডিভাইসেও।

কনফিগারেশনের একটি লাইন পরিবর্তন করে FirebaseUI ব্যবহার করে এক-ট্যাপ সাইন-ইন সক্ষম করুন:

// FirebaseUI config.
var uiConfig = {
  signInSuccessUrl: 'URL',  // the URL to direct to upon success
  authMethod: 'https://accounts.google.com',
  signInOptions: firebase.auth.GoogleAuthProvider.PROVIDER_ID,
  // Enable one-tap sign-in.
  credentialHelper: firebaseui.auth.CredentialHelper.GOOGLE_YOLO
};

FirebaseUI দ্বারা অফার করা বিভিন্ন কনফিগারেশন বিকল্প সম্পর্কে আরও জানতে GitHub-এ আমাদের ডকুমেন্টেশন দেখুন।

দ্রুত লোড সময়

দুর্দান্ত পারফরম্যান্স ব্যবহারকারীর অভিজ্ঞতা উন্নত করে, ব্যবহারকারীদের ধরে রাখতে সহায়তা করে এবং রূপান্তর বাড়ায়। দুর্দান্ত পারফরম্যান্স, যেমন কম " প্রথম অর্থপূর্ণ পেইন্টে সময়" এবং " ইন্টারেক্টিভ করার সময় ", PWA-এর জন্য একটি গুরুত্বপূর্ণ প্রয়োজন।

দক্ষতার সাথে আপনার স্ট্যাটিক সম্পদ পরিবেশন করুন

পারফরম্যান্স হোস্টিং পরিষেবা

Firebase Hosting একটি বিশ্বব্যাপী CDN এর মাধ্যমে আপনার সামগ্রী পরিবেশন করে এবং এটি HTTP/2 সামঞ্জস্যপূর্ণ। আপনি যখন Firebase-এর সাথে আপনার স্ট্যাটিক সম্পদগুলি হোস্ট করেন, তখন আমরা আপনার জন্য এইগুলি কনফিগার করি -- এই পরিষেবাটির সুবিধা নিতে আপনাকে অতিরিক্ত কিছু করতে হবে না৷

আপনার গতিশীল বিষয়বস্তু ক্যাশে

Firebase Hosting এর সাথে, আপনার ওয়েব অ্যাপটি Cloud Functions বা একটি Cloud Run কন্টেইনারাইজড অ্যাপ দ্বারা সার্ভার-সাইড জেনারেট করা গতিশীল সামগ্রীও পরিবেশন করতে পারে। এই পরিষেবাটি ব্যবহার করে, আপনি কোডের একটি লাইন সহ একটি শক্তিশালী বিশ্বব্যাপী CDN-এ আপনার গতিশীল সামগ্রী ক্যাশে করতে পারেন:

res.set('Cache-Control', 'public, max-age=300, s-maxage=600');

এই পরিষেবাটি আপনাকে আপনার ব্যাক-এন্ডে অতিরিক্ত কল এড়াতে, প্রতিক্রিয়ার গতি বাড়াতে এবং খরচ কমাতে দেয়।

আপনি কীভাবে গতিশীল সামগ্রী ( Cloud Functions বা Cloud Run দ্বারা চালিত) পরিবেশন করতে পারেন এবং Firebase Hosting সাথে CDN-ক্যাশিং সক্ষম করতে পারেন তা জানতে আমাদের ডকুমেন্টেশন দেখুন।

তাদের প্রয়োজন হলেই পরিষেবাগুলি লোড করুন৷

Firebase JavaScript SDK প্রাথমিক ডাউনলোডের আকার ন্যূনতম রাখতে আংশিকভাবে আমদানি করা যেতে পারে। Firebase পরিষেবাগুলি আমদানি করতে এই মডুলার SDK-এর সুবিধা নিন যেগুলি আপনার অ্যাপের প্রয়োজন শুধুমাত্র যখন প্রয়োজন হয়৷

উদাহরণস্বরূপ, আপনার অ্যাপের প্রাথমিক পেইন্টের গতি বাড়ানোর জন্য আপনার অ্যাপটি প্রথমে Firebase Authentication লোড করতে পারে। তারপর, যখন আপনার অ্যাপের প্রয়োজন হয়, তখন আপনি Cloud Firestore মতো অন্যান্য ফায়ারবেস পরিষেবা লোড করতে পারেন।

একটি প্যাকেজ ম্যানেজার যেমন ওয়েবপ্যাক ব্যবহার করে, আপনি প্রথমে Firebase Authentication লোড করতে পারেন:

import firebase from 'firebase/app';
import 'firebase/auth';

// Load Firebase project configuration.
const app = firebase.initializeApp(firebaseConfig);

তারপর, যখন আপনার ডেটা স্তর অ্যাক্সেস করতে হবে, তখন গতিশীল আমদানি ব্যবহার করে Cloud Firestore লাইব্রেরি লোড করুন:

import('firebase/firestore').then(() => {
  const firestore = app.firestore();
  // Use Cloud Firestore ...
});

নেটওয়ার্ক স্থিতিস্থাপকতা

আপনার ব্যবহারকারীদের নির্ভরযোগ্য ইন্টারনেট অ্যাক্সেস নাও থাকতে পারে। PWA গুলি নেটিভ মোবাইল অ্যাপের মতো আচরণ করা উচিত এবং যখনই সম্ভব অফলাইনে কাজ করা উচিত৷

অফলাইনে আপনার অ্যাপ ডেটা অ্যাক্সেস করুন

Cloud Firestore অফলাইন ডেটা স্থিরতা সমর্থন করে যা আপনার অ্যাপের ডেটা স্তরকে অফলাইনে স্বচ্ছভাবে কাজ করতে সক্ষম করে। আপনার স্ট্যাটিক সম্পদ ক্যাশ করতে পরিষেবা কর্মীদের সাথে মিলিত, আপনার PWA সম্পূর্ণরূপে অফলাইনে কাজ করতে পারে। আপনি কোডের একটি লাইন দিয়ে অফলাইন ডেটা স্থিরতা সক্ষম করতে পারেন:

firebase.firestore().enablePersistence().then(() => {
  const firestore = app.firestore();
  // Use Cloud Firestore ...
});

অফলাইনে অনুমোদনের অবস্থা বজায় রাখুন

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

firebase.auth().onAuthStateChanged((user) => {
  if (user) {
    // User is signed-in ...
  } else {
    // User is signed out ...
  }
});

Cloud Firestore এবং Firebase Authentication সাথে শুরু করতে আমাদের ডকুমেন্টেশন দেখুন।

ব্যবহারকারীদের নিযুক্ত করুন

আপনি কখন আপনার অ্যাপের জন্য নতুন বৈশিষ্ট্য প্রকাশ করেন তা আপনার ব্যবহারকারীরা জানতে চান এবং আপনি ব্যবহারকারীর ব্যস্ততা উচ্চ রাখতে চান। সক্রিয়ভাবে এবং দায়িত্বশীলভাবে আপনার ব্যবহারকারীদের কাছে পৌঁছানোর জন্য আপনার PWA সেট আপ করুন।

আপনার ব্যবহারকারীদের পুশ বিজ্ঞপ্তি প্রদর্শন করুন

Firebase Cloud Messaging মাধ্যমে, আপনি আপনার সার্ভার থেকে আপনার ব্যবহারকারীদের ডিভাইসে প্রাসঙ্গিক বিজ্ঞপ্তিগুলি পুশ করতে পারেন৷ এই পরিষেবাটি আপনাকে অ্যাপটি বন্ধ থাকা অবস্থায়ও আপনার ব্যবহারকারীদের সময়মত বিজ্ঞপ্তিগুলি প্রদর্শন করতে দেয়৷

স্বয়ংক্রিয়ভাবে ব্যবহারকারীর পুনঃনিযুক্তি

Cloud Functions for Firebase ব্যবহার করে, ক্লাউড ইভেন্টের উপর ভিত্তি করে আপনার ব্যবহারকারীদের পুনঃনিযুক্তি বার্তা পাঠান, উদাহরণস্বরূপ Cloud Firestore ডেটা লেখা বা ব্যবহারকারীর অ্যাকাউন্ট মুছে ফেলা । আপনি একজন ব্যবহারকারীকে একটি পুশ বিজ্ঞপ্তি পাঠাতে পারেন যখন সেই ব্যবহারকারী একটি নতুন অনুসরণকারী পায় :

// Send push notification when user gets a new follower.
exports.sendNotification = functions.database.ref('/followers/{userUID}/{followerUID}')
    .onWrite((change, context) => {
      const userUID = context.params.userUID;
      const followerUID = context.params.followerUID;

      const tokens = getUserDeviceTokens(userUID);
      const name = getUserDisplayName(followerUID);

      // Notification details.
      const payload = {
        notification: {
          title: 'You have a new follower!',
          body: `${name} is now following you.`
        }
      };
      return admin.messaging().sendToDevice(tokens, payload);
    });