Catch up on everything announced at Firebase Summit, and learn how Firebase can help you accelerate app development and run your app with confidence. Learn More

क्लाउड फायरस्टोर में उपस्थिति बनाएं

संग्रह की मदद से व्यवस्थित रहें अपनी प्राथमिकताओं के आधार पर, कॉन्टेंट को सेव करें और कैटगरी में बांटें.

आपके द्वारा बनाए जा रहे ऐप के प्रकार के आधार पर, आपको यह पता लगाना उपयोगी हो सकता है कि आपके कौन से उपयोगकर्ता या डिवाइस सक्रिय रूप से ऑनलाइन हैं - अन्यथा "उपस्थिति" का पता लगाने के रूप में जाना जाता है।

उदाहरण के लिए, यदि आप एक सोशल नेटवर्क जैसे ऐप का निर्माण कर रहे हैं या IoT उपकरणों का एक बेड़ा तैनात कर रहे हैं, तो आप इस जानकारी का उपयोग उन मित्रों की सूची प्रदर्शित करने के लिए कर सकते हैं जो ऑनलाइन हैं और चैट करने के लिए स्वतंत्र हैं, या अपने IoT उपकरणों को "पिछली बार देखे गए" के आधार पर सॉर्ट कर सकते हैं। ।"

Cloud Firestore मूल रूप से उपस्थिति का समर्थन नहीं करता है, लेकिन आप उपस्थिति सिस्टम बनाने के लिए अन्य Firebase उत्पादों का लाभ उठा सकते हैं।

समाधान: रीयलटाइम डेटाबेस के साथ क्लाउड फ़ंक्शंस

Cloud Firestore को Firebase रीयलटाइम डेटाबेस की मूल उपस्थिति सुविधा से जोड़ने के लिए, Cloud Functions का उपयोग करें।

कनेक्शन की स्थिति की रिपोर्ट करने के लिए रीयलटाइम डेटाबेस का उपयोग करें, फिर उस डेटा को Cloud Firestore में मिरर करने के लिए Cloud Functions का उपयोग करें।

रीयलटाइम डेटाबेस में उपस्थिति का उपयोग करना

सबसे पहले, विचार करें कि रीयलटाइम डेटाबेस में एक पारंपरिक उपस्थिति प्रणाली कैसे काम करती है।

वेब

// Fetch the current user's ID from Firebase Authentication.
var uid = firebase.auth().currentUser.uid;

// Create a reference to this user's specific status node.
// This is where we will store data about being online/offline.
var userStatusDatabaseRef = firebase.database().ref('/status/' + uid);

// We'll create two constants which we will write to 
// the Realtime database when this device is offline
// or online.
var isOfflineForDatabase = {
    state: 'offline',
    last_changed: firebase.database.ServerValue.TIMESTAMP,
};

var isOnlineForDatabase = {
    state: 'online',
    last_changed: firebase.database.ServerValue.TIMESTAMP,
};

// Create a reference to the special '.info/connected' path in 
// Realtime Database. This path returns `true` when connected
// and `false` when disconnected.
firebase.database().ref('.info/connected').on('value', function(snapshot) {
    // If we're not currently connected, don't do anything.
    if (snapshot.val() == false) {
        return;
    };

    // If we are currently connected, then use the 'onDisconnect()' 
    // method to add a set which will only trigger once this 
    // client has disconnected by closing the app, 
    // losing internet, or any other means.
    userStatusDatabaseRef.onDisconnect().set(isOfflineForDatabase).then(function() {
        // The promise returned from .onDisconnect().set() will
        // resolve as soon as the server acknowledges the onDisconnect() 
        // request, NOT once we've actually disconnected:
        // https://firebase.google.com/docs/reference/js/firebase.database.OnDisconnect

        // We can now safely set ourselves as 'online' knowing that the
        // server will mark us as offline once we lose connection.
        userStatusDatabaseRef.set(isOnlineForDatabase);
    });
});

यह उदाहरण एक पूर्ण रीयलटाइम डेटाबेस उपस्थिति प्रणाली है। यह कई डिस्कनेक्शन, क्रैश आदि को संभालता है।

क्लाउड फायरस्टोर से जुड़ना

क्लाउड फायरस्टोर में एक समान समाधान को लागू करने के लिए समान रीयलटाइम डेटाबेस कोड का उपयोग करें, फिर रीयलटाइम डेटाबेस और क्लाउड फायरस्टोर को सिंक में रखने के लिए क्लाउड फ़ंक्शंस का उपयोग करें।

यदि आपने पहले से ऐसा नहीं किया है, तो अपने प्रोजेक्ट में रीयलटाइम डेटाबेस जोड़ें और उपरोक्त उपस्थिति समाधान शामिल करें।

आगे आप निम्न विधियों के माध्यम से उपस्थिति स्थिति को Cloud Firestore से सिंक्रनाइज़ करेंगे:

  1. स्थानीय रूप से, ऑफ़लाइन डिवाइस के क्लाउड फायरस्टोर कैश में ताकि ऐप को पता चले कि यह ऑफ़लाइन है।
  2. वैश्विक स्तर पर, क्लाउड फ़ंक्शन का उपयोग करना ताकि क्लाउड फायरस्टोर तक पहुंचने वाले अन्य सभी डिवाइस यह जान सकें कि यह विशिष्ट डिवाइस ऑफ़लाइन है।

Cloud Firestore का स्थानीय कैश अपडेट करना

आइए पहले मुद्दे को पूरा करने के लिए आवश्यक परिवर्तनों पर एक नज़र डालें - क्लाउड फायरस्टोर के स्थानीय कैश को अपडेट करना।

वेब

// ...
var userStatusFirestoreRef = firebase.firestore().doc('/status/' + uid);

// Firestore uses a different server timestamp value, so we'll 
// create two more constants for Firestore state.
var isOfflineForFirestore = {
    state: 'offline',
    last_changed: firebase.firestore.FieldValue.serverTimestamp(),
};

var isOnlineForFirestore = {
    state: 'online',
    last_changed: firebase.firestore.FieldValue.serverTimestamp(),
};

firebase.database().ref('.info/connected').on('value', function(snapshot) {
    if (snapshot.val() == false) {
        // Instead of simply returning, we'll also set Firestore's state
        // to 'offline'. This ensures that our Firestore cache is aware
        // of the switch to 'offline.'
        userStatusFirestoreRef.set(isOfflineForFirestore);
        return;
    };

    userStatusDatabaseRef.onDisconnect().set(isOfflineForDatabase).then(function() {
        userStatusDatabaseRef.set(isOnlineForDatabase);

        // We'll also add Firestore set here for when we come online.
        userStatusFirestoreRef.set(isOnlineForFirestore);
    });
});

इन परिवर्तनों के साथ हमने अब यह सुनिश्चित कर लिया है कि स्थानीय क्लाउड फायरस्टोर राज्य हमेशा डिवाइस की ऑनलाइन/ऑफलाइन स्थिति को प्रदर्शित करेगा। इसका मतलब है कि आप /status/{uid} दस्तावेज़ को सुन सकते हैं और कनेक्शन स्थिति को दर्शाने के लिए अपने UI को बदलने के लिए डेटा का उपयोग कर सकते हैं।

वेब

userStatusFirestoreRef.onSnapshot(function(doc) {
    var isOnline = doc.data().state == 'online';
    // ... use isOnline
});

क्लाउड फायरस्टोर को विश्व स्तर पर अपडेट कर रहा है

यद्यपि हमारा आवेदन सही ढंग से ऑनलाइन उपस्थिति की रिपोर्ट करता है, यह स्थिति अभी तक अन्य क्लाउड फायरस्टोर ऐप्स में सटीक नहीं होगी क्योंकि हमारा "ऑफ़लाइन" स्थिति लेखन केवल स्थानीय है और कनेक्शन बहाल होने पर सिंक नहीं किया जाएगा। इसका मुकाबला करने के लिए, हम एक क्लाउड फ़ंक्शन का उपयोग करेंगे जो रीयलटाइम डेटाबेस में status/{uid} पथ देखता है। जब रीयलटाइम डेटाबेस मान बदलता है तो मान Cloud Firestore से सिंक हो जाएगा ताकि सभी उपयोगकर्ताओं की स्थिति सही हो।

Node.js

const functions = require('firebase-functions');
const admin = require('firebase-admin');
admin.initializeApp();

// Since this code will be running in the Cloud Functions environment
// we call initialize Firestore without any arguments because it
// detects authentication from the environment.
const firestore = admin.firestore();

// Create a new function which is triggered on changes to /status/{uid}
// Note: This is a Realtime Database trigger, *not* Firestore.
exports.onUserStatusChanged = functions.database.ref('/status/{uid}').onUpdate(
    async (change, context) => {
      // Get the data written to Realtime Database
      const eventStatus = change.after.val();

      // Then use other event data to create a reference to the
      // corresponding Firestore document.
      const userStatusFirestoreRef = firestore.doc(`status/${context.params.uid}`);

      // It is likely that the Realtime Database change that triggered
      // this event has already been overwritten by a fast change in
      // online / offline status, so we'll re-read the current data
      // and compare the timestamps.
      const statusSnapshot = await change.after.ref.once('value');
      const status = statusSnapshot.val();
      functions.logger.log(status, eventStatus);
      // If the current timestamp for this data is newer than
      // the data that triggered this event, we exit this function.
      if (status.last_changed > eventStatus.last_changed) {
        return null;
      }

      // Otherwise, we convert the last_changed field to a Date
      eventStatus.last_changed = new Date(eventStatus.last_changed);

      // ... and write it to Firestore.
      return userStatusFirestoreRef.set(eventStatus);
    });

एक बार जब आप इस फ़ंक्शन को परिनियोजित करते हैं, तो आपके पास क्लाउड फायरस्टोर के साथ चलने वाला एक पूर्ण उपस्थिति सिस्टम होगा। नीचे किसी भी उपयोगकर्ता के लिए निगरानी का एक उदाहरण है जो ऑनलाइन आता है या where() क्वेरी का उपयोग करके ऑफ़लाइन हो जाता है।

वेब

firebase.firestore().collection('status')
    .where('state', '==', 'online')
    .onSnapshot(function(snapshot) {
        snapshot.docChanges().forEach(function(change) {
            if (change.type === 'added') {
                var msg = 'User ' + change.doc.id + ' is online.';
                console.log(msg);
                // ...
            }
            if (change.type === 'removed') {
                var msg = 'User ' + change.doc.id + ' is offline.';
                console.log(msg);
                // ...
            }
        });
    });

सीमाओं

अपने क्लाउड फायरस्टोर ऐप में उपस्थिति जोड़ने के लिए रीयलटाइम डेटाबेस का उपयोग स्केलेबल और प्रभावी है लेकिन इसकी कुछ सीमाएं हैं:

  • डिबगिंग - क्लाउड फायरस्टोर में रीयलटाइम परिवर्तनों को सुनते समय, यह समाधान कई परिवर्तनों को ट्रिगर करने की संभावना है। यदि ये परिवर्तन आपकी अपेक्षा से अधिक ईवेंट ट्रिगर करते हैं, तो Cloud Firestore ईवेंट को मैन्युअल रूप से रद्द कर दें।
  • कनेक्टिविटी - यह कार्यान्वयन क्लाउड फायरस्टोर के लिए नहीं, बल्कि रीयलटाइम डेटाबेस से कनेक्टिविटी को मापता है। यदि प्रत्येक डेटाबेस से कनेक्शन की स्थिति समान नहीं है, तो यह समाधान गलत उपस्थिति स्थिति की रिपोर्ट कर सकता है।
  • Android - Android पर, 60 सेकंड की निष्क्रियता के बाद रीयलटाइम डेटाबेस बैकएंड से डिस्कनेक्ट हो जाता है। निष्क्रियता का अर्थ है कोई खुला श्रोता या लंबित संचालन नहीं। कनेक्शन को खुला रखने के लिए, हम अनुशंसा करते हैं कि आप .info/connected के अलावा पथ में एक मूल्य ईवेंट श्रोता जोड़ें। उदाहरण के लिए आप प्रत्येक सत्र की शुरुआत में FirebaseDatabase.getInstance().getReference((new Date()).toString()).keepSynced() कर सकते हैं। अधिक जानकारी के लिए, कनेक्शन स्थिति का पता लगाना देखें।