Firebase इंस्टॉलेशन मैनेज करें

Firebase इंस्टॉलेशन सेवा (FIS), Firebase ऐप्लिकेशन के हर इंस्टॉल किए गए इंस्टेंस के लिए, Firebase इंस्टॉलेशन आईडी (एफ़आईडी) उपलब्ध कराती है. Firebase इंस्टॉलेशन आईडी का इस्तेमाल, Firebase की इन सेवाओं में अंदरूनी तौर पर किया जाता है:

Firebase की सेवा Firebase इंस्टॉलेशन की सुविधा
Firebase Cloud Messaging

Firebase Cloud Messaging, मैसेज डिलीवरी के लिए डिवाइसों को टारगेट करने के लिए, Firebase इंस्टॉलेशन आईडी का इस्तेमाल करता है.

Firebase Crashlytics

Firebase Crashlytics, ऐप्लिकेशन इंस्टेंस के Firebase इंस्टॉलेशन आईडी में हुए बदलावों के आधार पर, Crashlytics इंस्टॉलेशन यूनीक आइडेंटिटी (यूयूआईडी) को रोटेट करता है. आने वाले समय में, इंस्टॉलेशन आईडी का इस्तेमाल उन सुविधाओं को चालू करने के लिए किया जा सकता है जो क्रैश रिपोर्टिंग और क्रैश मैनेजमेंट सेवाओं को बेहतर बनाती हैं.

Firebase In-App Messaging

Firebase In-App Messaging, मैसेज डिलीवरी के लिए डिवाइसों को टारगेट करने के लिए, Firebase इंस्टॉलेशन आईडी का इस्तेमाल करता है.

Firebase Performance Monitoring

Performance Monitoring, नेटवर्क संसाधनों को ऐक्सेस करने वाले यूनीक Firebase इंस्टॉलेशन की संख्या का हिसाब लगाने के लिए, Firebase इंस्टॉलेशन आईडी का इस्तेमाल करता है. इससे यह पक्का किया जाता है कि ऐक्सेस पैटर्न पूरी तरह से गुमनाम हों. यह परफ़ॉर्मेंस इवेंट रिपोर्टिंग की दर को मैनेज करने के लिए, Firebase Remote Config के साथ Firebase इंस्टॉलेशन आईडी का भी इस्तेमाल करता है.

Firebase Remote Config

Remote Config, Firebase इंस्टॉलेशन आईडी का इस्तेमाल करता है, ताकि वह उपयोगकर्ता के डिवाइसों पर दिखाने के लिए कॉन्फ़िगरेशन वैल्यू चुन सके.

Firebase ML

Firebase ML, ऐप्लिकेशन इंस्टेंस के साथ इंटरैक्ट करते समय, डिवाइस की पुष्टि करने के लिए, इंस्टॉलेशन की पुष्टि करने वाले टोकन नाम के क्रेडेंशियल का इस्तेमाल करता है. उदाहरण के लिए, ऐप्लिकेशन इंस्टेंस में डेवलपर मॉडल डिस्ट्रिब्यूट करने के लिए.

Firebase उपयोगकर्ता सेगमेंटेशन स्टोरेज

Firebase उपयोगकर्ता सेगमेंटेशन स्टोरेज, Firebase इंस्टॉलेशन आईडी और उनसे जुड़े एट्रिब्यूट और सेगमेंट को स्टोर करता है. इससे, Firebase की उन अन्य सेवाओं को टारगेटिंग की जानकारी दी जा सकती है जो इनका इस्तेमाल करती हैं.

आम तौर पर, Firebase की सेवाएं Firebase इंस्टॉलेशन सेवा का इस्तेमाल करती हैं. इसके लिए, डेवलपर को सीधे FIS API के साथ इंटरैक्ट करने की ज़रूरत नहीं होती. हालांकि, ऐसे मामले भी हो सकते हैं जिनमें ऐप्लिकेशन डेवलपर सीधे तौर पर एफ़आईएस एपीआई को कॉल करना चाहें. जैसे:

  • Firebase इंस्टॉलेशन और उससे जुड़े डेटा को मिटाने के लिए.
  • खास ऐप्लिकेशन इंस्टॉल को टारगेट करने के लिए, आइडेंटिफ़ायर (Firebase इंस्टॉलेशन आईडी) वापस पाने के लिए.
  • Firebase इंस्टॉलेशन की पुष्टि करने के लिए, इंस्टॉलेशन के पुष्टि करने वाले टोकन वापस पाने के लिए.

सीधे तौर पर FIS API को कॉल करने के लिए, अपने ऐप्लिकेशन में SDK टूल जोड़ें.

अपने ऐप्लिकेशन में Firebase इंस्टॉलेशन SDK टूल जोड़ना

iOS+

  1. अपनी Podfile में Firebase इंस्टॉलेशन के लिए डिपेंडेंसी जोड़ें:
    pod 'FirebaseInstallations'
  2. pod install चलाएं और बनाई गई .xcworkspace फ़ाइल खोलें.
  3. अपने UIApplicationDelegate में FirebaseCore मॉड्यूल के साथ-साथ, उन सभी Firebase मॉड्यूल को इंपोर्ट करें जिनका इस्तेमाल आपका ऐप्लिकेशन डेलीगेट करता है. उदाहरण के लिए, Cloud Firestore और Authentication का इस्तेमाल करने के लिए:

    SwiftUI

    import SwiftUI import FirebaseCore import FirebaseFirestore import FirebaseAuth // ...       

    Swift

    import FirebaseCore import FirebaseFirestore import FirebaseAuth // ...       

    Objective-C

    @import FirebaseCore; @import FirebaseFirestore; @import FirebaseAuth; // ...       
  4. अपने ऐप्लिकेशन डेलीगेट के application(_:didFinishLaunchingWithOptions:) तरीके में, FirebaseApp शेयर किया गया इंस्टेंस कॉन्फ़िगर करें:

    SwiftUI

    // Use Firebase library to configure APIs FirebaseApp.configure()

    Swift

    // Use Firebase library to configure APIs FirebaseApp.configure()

    Objective-C

    // Use Firebase library to configure APIs [FIRApp configure];
  5. अगर SwiftUI का इस्तेमाल किया जा रहा है, तो आपको एक ऐप्लिकेशन डेलीगेट बनाना होगा और उसे UIApplicationDelegateAdaptor या NSApplicationDelegateAdaptor के ज़रिए अपने App स्ट्रक्चर से अटैच करना होगा. आपको ऐप्लिकेशन डेलीगेट स्विज़लिंग की सुविधा भी बंद करनी होगी. ज़्यादा जानकारी के लिए, SwiftUI के निर्देश देखें.

    SwiftUI

    @main struct YourApp: App {   // register app delegate for Firebase setup   @UIApplicationDelegateAdaptor(AppDelegate.self) var delegate    var body: some Scene {     WindowGroup {       NavigationView {         ContentView()       }     }   } }       

Android

अपने मॉड्यूल (ऐप्लिकेशन-लेवल) की Gradle फ़ाइल (आम तौर पर app/build.gradle) में, Firebase इंस्टॉलेशन वाले Android SDK टूल के लिए डिपेंडेंसी जोड़ें:

implementation 'com.google.firebase:firebase-installations:18.0.0' 

JavaScript

आपके वेब ऐप्लिकेशन को होस्ट करने के तरीके के आधार पर, आपका कॉन्फ़िगरेशन अपने-आप मैनेज हो सकता है. इसके अलावा, आपको Firebase कॉन्फ़िगरेशन ऑब्जेक्ट को अपडेट करना पड़ सकता है.

उदाहरण के लिए, अगर आपकी डिपेंडेंसी index.html में जोड़ी गई हैं, तो <head> एलिमेंट में डिपेंडेंसी जोड़ें:

<script src="/__/firebase/11.7.1/firebase-installations.js"></script>

Flutter

  1. अपने Flutter प्रोजेक्ट की रूट डायरेक्ट्री से, Firebase इंस्टॉलेशन प्लग इन इंस्टॉल करने के लिए, यह कमांड चलाएं:

    flutter pub add firebase_app_installations 
  2. अपना प्रोजेक्ट फिर से बनाएं:

    flutter run 
  3. Firebase इंस्टॉलेशन प्लग इन इंपोर्ट करें:

    import 'package:firebase_app_installations/firebase_app_installations.dart'; 

Firebase इंस्टॉलेशन मिटाना

आम तौर पर, Firebase इंस्टॉलेशन से जुड़ा डेटा, किसी व्यक्ति की पहचान नहीं करता. इसके बावजूद, उपयोगकर्ताओं को इस डेटा को मैनेज और मिटाने का विकल्प देना मददगार हो सकता है.

हर ऐप्लिकेशन के हर इंस्टॉल के लिए, Firebase इंस्टॉल आईडी अलग-अलग होते हैं. एक ही डिवाइस पर मौजूद अलग-अलग ऐप्लिकेशन के Firebase इंस्टॉल आईडी अलग-अलग होते हैं. Firebase इंस्टॉलेशन आईडी, ऐप्लिकेशन के इंस्टॉल और उनसे जुड़े डेटा की पहचान करते हैं.

किसी इंस्टॉलेशन आईडी को मिटाने पर, उससे जुड़ा डेटा, 180 दिनों के अंदर इंस्टॉलेशन की पहचान करने के लिए Firebase इंस्टॉलेशन आईडी का इस्तेमाल करने वाली सभी Firebase सेवाओं के लाइव और बैकअप सिस्टम से हटा दिया जाता है. इस प्रोसेस के बारे में ज़्यादा जानकारी, Google के डेटा मिटाने और सेव रखने के बारे में बयान में दी गई है.

अगर आपने अपने ऐप्लिकेशन में एफ़आईडी जनरेट करने वाली सभी सेवाओं को बंद नहीं किया है, तो एफ़आईएस कुछ दिनों में नया आईडी बना देता है. Firebase, नए बनाए गए आईडी को नया Firebase इंस्टॉलेशन मानता है और इसे किसी भी तरह से पिछले आईडी या डेटा से नहीं जोड़ता.

क्लाइंट एपीआई कॉल की मदद से एफ़आईडी मिटाना

Firebase की सेवाओं से जनरेट किए गए एफ़आईडी मिटाने के लिए, Firebase इंस्टॉलेशन SDK टूल से सही तरीका चुनें:

Swift

do {   try await Installations.installations().delete()   print("Installation deleted"); } catch {   print("Error deleting installation: \(error)") }

Objective-C

[[FIRInstallations installations] deleteWithCompletion:^(NSError *error) {    if (error != nil) {      NSLog(@"Error deleting Installation %@", error);      return;    }    NSLog(@"Installation deleted"); }];

Java

FirebaseInstallations.getInstance().delete()         .addOnCompleteListener(new OnCompleteListener<Void>() {     @Override     public void onComplete(@NonNull Task<Void> task) {         if (task.isSuccessful()) {             Log.d("Installations", "Installation deleted");         } else {             Log.e("Installations", "Unable to delete Installation");         }     } });

Kotlin

FirebaseInstallations.getInstance().delete().addOnCompleteListener { task ->     if (task.isComplete) {         Log.d("Installations", "Installation deleted")     } else {         Log.e("Installations", "Unable to delete Installation")     } }

JavaScript

await firebase.installations().delete();

Dart

await FirebaseInstallations.instance.delete(); 

सर्वर एपीआई कॉल की मदद से एफ़आईडी मिटाना

अगर आपने पहले से ही अपने सर्वर में Firebase Admin SDK टूल नहीं जोड़ा है, तो सर्वर एपीआई कॉल की मदद से एफ़आईडी मिटाएं.

SDK टूल जोड़ने के बाद, अपनी पसंद की भाषा में मिटाने के फ़ंक्शन को कॉल करके एफ़आईडी मिटाएं. ध्यान दें: Node.js को छोड़कर, ये तरीके इंस्टेंस आईडी के नाम को दिखाते हैं. हालांकि, किसी भी मौजूदा Firebase SDK टूल के साथ कॉल किए जाने पर, ये सभी असल में एफ़आईडी मिटा देते हैं).

Node.js

// An FIDsent from a client service SDK const idToDelete = 'eyJhbGciOiJFUzI1N_iIs5';  admin.installations().deleteInstallation(idToDelete); 

Java

// An FID sent from a client service SDK String idToDelete = "eyJhbGciOiJFUzI1N_iIs5";  FirebaseInstanceId.getInstance().deleteInstanceIdAsync(idToDelete).get(); 

Python

  from firebase_admin import instance_id    # An FID sent from a client service SDK   id_to_delete = 'eyJhbGciOiJFUzI1N_iIs5'    instance_id.delete_instance_id(id_to_delete) 

शुरू करें

client, err := app.InstanceId(ctx) if err != nil {   log.Fatalln("error initializing client", err) }  iidToDelete := "eyJhbGciOiJFUzI1N_iIs5" if err := client.DeleteInstanceId(ctx, iidToDelete); err != nil {   log.Fatalln("error deleting FID", err) } 

सर्वर एपीआई कॉल की मदद से Firebase इंस्टॉलेशन आईडी मिटाने पर, Firebase सेवाएं उस इंस्टॉलेशन आईडी से जुड़े डेटा को मिटाने की प्रोसेस शुरू कर देती हैं. साथ ही, एक से दो दिनों के लिए उस आईडी के लिए नया डेटा स्वीकार करना बंद कर देती हैं. इसके बाद, क्लाइंट ऐप्लिकेशन को सूचना देती हैं कि आईडी मिटा दिया गया है. जब तक Firebase, क्लाइंट ऐप्लिकेशन को सूचना नहीं देता, तब तक हो सकता है कि ऐप्लिकेशन की कुछ सेवाएं अब भी आईडी को टारगेट करती रहें. उदाहरण के लिए, Firebase इंस्टॉलेशन को कुछ घंटों तक FCM सूचनाएं मिलती रहें.

अगर आपको मौजूदा Firebase इंस्टॉलेशन आईडी मिटाना है और किसी नए आईडी के साथ Firebase की सेवाओं का तुरंत इस्तेमाल करना है, तो मिटाने की प्रोसेस को मैनेज करने के लिए क्लाइंट API का इस्तेमाल करें.

क्लाइंट आइडेंटिफ़ायर वापस पाना

अगर आपको अपने ऐप्लिकेशन के किसी खास इंस्टॉल की पहचान करनी है, तो Firebase इंस्टॉल आईडी को वापस पाकर ऐसा किया जा सकता है. उदाहरण के लिए, BigQuery इंपोर्ट के लिए ऐप्लिकेशन इंस्टॉल के सेगमेंट बनाने या Firebase In-App Messaging डेवलपमेंट के दौरान जांच करने के लिए, Firebase इंस्टॉलेशन आईडी का इस्तेमाल करके सही डिवाइसों की पहचान की जा सकती है और उन्हें टारगेट किया जा सकता है.

Firebase इंस्टॉलेशन आईडी वापस पाने के लिए:

Swift

do {   let id = try await Installations.installations().installationID()   print("Installation ID: \(id)") } catch {   print("Error fetching id: \(error)") }

Objective-C

[[FIRInstallations installations] installationIDWithCompletion:^(NSString *identifier, NSError *error) {   if (error != nil) {     NSLog(@"Error fetching Installation ID %@", error);     return;   }   NSLog(@"Installation ID: %@", identifier); }];

Java

FirebaseInstallations.getInstance().getId()         .addOnCompleteListener(new OnCompleteListener<String>() {     @Override     public void onComplete(@NonNull Task<String> task) {         if (task.isSuccessful()) {             Log.d("Installations", "Installation ID: " + task.getResult());         } else {             Log.e("Installations", "Unable to get Installation ID");         }     } });

Kotlin

FirebaseInstallations.getInstance().id.addOnCompleteListener { task ->     if (task.isSuccessful) {         Log.d("Installations", "Installation ID: " + task.result)     } else {         Log.e("Installations", "Unable to get Installation ID")     } }

JavaScript

const installationId = await firebase.installations().getId(); console.log(installationId);

Dart

String id = await FirebaseInstallations.instance.getId(); 

इंस्टॉलेशन के लिए पुष्टि करने वाले टोकन वापस पाना

Firebase की सेवाएं, एफ़आईएस से मिले पुष्टि करने वाले टोकन की मदद से, Firebase इंस्टॉलेशन की पुष्टि कर सकती हैं. उदाहरण के लिए, Remote Config के लिए A/B टेस्ट डिज़ाइन करते समय, इंस्टॉलेशन की पुष्टि करने वाले टोकन का इस्तेमाल करके, टारगेट किए गए टेस्ट डिवाइस की पुष्टि की जा सकती है.

इंस्टॉलेशन के लिए पुष्टि करने वाला टोकन, JSON वेब टोकन (JWT) फ़ॉर्मैट में एक छोटा-सा बियरर टोकन होता है. इसमें इंस्टॉलेशन के लिए यह जानकारी शामिल होती है:

  • Firebase इंस्टॉलेशन आईडी
  • उससे जुड़ा प्रोजेक्ट (projectNumber)
  • इससे जुड़ा Firebase ऐप्लिकेशन आईडी (appId)
  • टोकन की समयसीमा खत्म होने की तारीख

इंस्टॉलेशन के लिए इस्तेमाल होने वाले पुष्टि करने वाले टोकन को रद्द नहीं किया जा सकता. यह टोकन, खत्म होने की तारीख तक मान्य रहता है. टोकन का डिफ़ॉल्ट लाइफ़टाइम एक हफ़्ता होता है.

इंस्टॉलेशन के लिए पुष्टि करने वाला टोकन पाने के लिए:

Swift

do {   let result = try await Installations.installations()     .authTokenForcingRefresh(true)   print("Installation auth token: \(result.authToken)") } catch {   print("Error fetching token: \(error)") }

Objective-C

[[FIRInstallations installations] authTokenForcingRefresh:true                                                completion:^(FIRInstallationsAuthTokenResult *result, NSError *error) {   if (error != nil) {     NSLog(@"Error fetching Installation token %@", error);     return;   }   NSLog(@"Installation auth token: %@", [result authToken]); }];

Java

FirebaseInstallations.getInstance().getToken(/* forceRefresh */true)         .addOnCompleteListener(new OnCompleteListener<InstallationTokenResult>() {     @Override     public void onComplete(@NonNull Task<InstallationTokenResult> task) {         if (task.isSuccessful() && task.getResult() != null) {             Log.d("Installations", "Installation auth token: " + task.getResult().getToken());         } else {             Log.e("Installations", "Unable to get Installation auth token");         }     } });

Kotlin

val forceRefresh = true FirebaseInstallations.getInstance().getToken(forceRefresh)     .addOnCompleteListener { task ->         if (task.isSuccessful) {             Log.d("Installations", "Installation auth token: " + task.result?.token)         } else {             Log.e("Installations", "Unable to get Installation auth token")         }     }

JavaScript

const installationToken = await firebase.installations()     .getToken(/* forceRefresh */ true); console.log(installationToken);

Dart

String token = await FirebaseInstallations.instance.getToken(); 

Firebase इंस्टॉलेशन आईडी के लाइफ़साइकल को मॉनिटर करना

किसी ऐप्लिकेशन के सामान्य कामकाज के दौरान, Firebase इंस्टॉलेशन आईडी (एफ़आईडी) को खास निगरानी की ज़रूरत नहीं होती. हालांकि, ऐसे ऐप्लिकेशन जो साफ़ तौर पर एफ़आईडी को वापस लाते और इस्तेमाल करते हैं, उन्हें एफ़आईडी के मिटाए जाने या बदले जाने की निगरानी करने के लिए लॉजिक जोड़ना चाहिए. यहां कुछ ऐसे मामले दिए गए हैं जिनमें एफ़आईडी मिटाए जा सकते हैं या रोटेट किए जा सकते हैं:

  • ऐप्लिकेशन को अनइंस्टॉल या फिर से इंस्टॉल करना. उदाहरण के लिए, जब कोई असली उपयोगकर्ता किसी नए डिवाइस पर ऐप्लिकेशन इंस्टॉल करता है.
  • असली उपयोगकर्ता, ऐप्लिकेशन या डिवाइस की कैश मेमोरी मिटाता है.
  • ऐप्लिकेशन का इस्तेमाल न किए जाने की वजह से, बैकएंड में एफ़आईडी मिटाने की प्रोसेस शुरू हो जाती है. फ़िलहाल, इसके लिए कोई गतिविधि न होने की अवधि 270 दिन है.

जब ऐप्लिकेशन में इस तरह के मामलों में एफ़आईडी रोटेशन या मिटाने की समस्या आती है, तो उन्हें एक नया एफ़आईडी असाइन किया जाता है. साथ ही, मिटाए गए एफ़आईडी से जुड़ा इंस्टॉलेशन के लिए पुष्टि करने वाला टोकन भी मिटा दिया जाता है. भले ही, वह टोकन इस्तेमाल करने की समयसीमा खत्म हो चुकी हो. इसके बाद, उसे इंस्टॉलेशन के लिए पुष्टि करने वाले नए टोकन से बदल दिया जाता है.

ऐप्लिकेशन इन बदलावों को मॉनिटर कर सकते हैं और उनके हिसाब से जवाब दे सकते हैं.

एफ़आईडी रोटेशन को मॉनिटर करने के लिए:

Swift

installationIDObserver = NotificationCenter.default.addObserver(         forName: .InstallationIDDidChange,         object: nil,         queue: nil ) { (notification) in   // Fetch new Installation ID   Task {     await self.fetchInstallationToken()   } }

Objective-C

__weak __auto_type weakSelf = self; self.installationIDObserver = [[NSNotificationCenter defaultCenter]         addObserverForName: FIRInstallationIDDidChangeNotification                     object:nil                      queue:nil                 usingBlock:^(NSNotification * _Nonnull notification) {     // Fetch new Installation ID     [weakSelf fetchInstallationsID]; }];

जब भी कोई नया FID असाइन किया जाता है, तो NSNotificationName.InstallationIDDidChange नाम का एक NSNotification, डिफ़ॉल्ट NSNotificationCenter पर पोस्ट किया जाता है.

Android

Kotlin और Java क्लाइंट को फिर से कोशिश करने का लॉजिक जोड़ना चाहिए, ताकि नए एफ़आईडी को वापस पाने के लिए, कॉल पूरा न होने पर जवाब दिया जा सके.

JavaScript

वेब ऐप्लिकेशन, onIdChange हुक की सदस्यता ले सकते हैं.

जब भी कोई नया एफ़आईडी बनाया जाता है, तो सदस्यता वाला कॉलबैक ट्रिगर होता है:

await firebase.installations().onIdChange((newId) => {   console.log(newId);   // TODO: Handle new installation ID. });

Dart

FirebaseInstallations.instance.onIdChange.listen((token) {   print('FID token: $token'); }); 

इंस्टेंस आईडी से Firebase इंस्टॉलेशन पर माइग्रेट करना

Firebase इंस्टॉलेशन की सुविधा लॉन्च होने से पहले, Firebase ऐप्लिकेशन इंस्टॉल के आइडेंटिफ़ायर के लिए, इंस्टेंस आईडी SDK टूल पर निर्भर था. Firebase इंस्टॉलेशन, इंस्टेंस आईडी की तुलना में भरोसेमंदता, परफ़ॉर्मेंस, और सुरक्षा के मामले में काफ़ी फ़ायदे देते हैं. इंस्टेंस आईडी SDK टूल पर निर्भर रहने वाले Firebase ऐप्लिकेशन को Firebase इंस्टॉलेशन पर माइग्रेट करना चाहिए.

आपके ऐप्लिकेशन के हिसाब से, माइग्रेशन की प्रोसेस अलग-अलग होती है:

  • ऐसे ऐप्लिकेशन जो सीधे तौर पर Instance ID एपीआई को कॉल नहीं करते, वे अपने SDK टूल के वर्शन अपडेट करके माइग्रेट कर सकते हैं. ज़्यादातर Firebase ऐप्लिकेशन इस कैटगरी में आते हैं.

  • जिन ऐप्लिकेशन में इंस्टेंस आईडी के लिए साफ़ तौर पर एपीआई कॉल किए जाते हैं उन्हें SDK टूल के वर्शन अपडेट करने होंगे और कोड में बदलाव करने होंगे. इससे, इंस्टेंस आईडी के तरीकों को उनके Firebase इंस्टॉलेशन या FCM के बराबर के तरीकों से बदला जा सकेगा. अगर आपका ऐप्लिकेशन FCM रजिस्ट्रेशन टोकन हासिल करने के लिए इंस्टेंस आईडी का इस्तेमाल करता है या ऐप्लिकेशन इंस्टेंस को टारगेट करने या किसी अन्य काम के लिए साफ़ तौर पर इंस्टेंस आईडी का इस्तेमाल करता है, तो आपको अपने ऐप्लिकेशन कोड को अपडेट करना होगा.

फ़िलहाल, एफ़आईएस, लेगसी आइडेंटिफ़ायर Firebase इंस्टेंस आईडी के साथ काम करता है. आईआईडी मिटाना, इन Firebase SDK टूल के साथ डेटा मिटाने का अनुरोध करने का एक अन्य तरीका है:

  • iOS 6.14.0 और उससे पहले के वर्शन
  • 27 फ़रवरी, 2020 से पहले के Android SDK टूल

इसका मतलब है कि ऐप्लिकेशन को Firebase इंस्टॉलेशन पर माइग्रेट करना ज़रूरी नहीं है. हालांकि, हमारा सुझाव है कि ऐसा करें.

Firebase इंस्टॉलेशन के लिए, SDK टूल के कम से कम वर्शन पर अपग्रेड करना

इंस्टेंस आईडी से Firebase इंस्टॉलेशन पर माइग्रेट करने के लिए, पक्का करें कि आपके ऐप्लिकेशन में यहां दिए गए Firebase SDK टूल के कम से कम इन वर्शन का इस्तेमाल किया जा रहा हो:

Firebase SDK टूल Android का कम से कम वर्शन iOS का कम से कम वर्शन
Firebase क्लाउड से मैसेज v20.3.0 v6.34.0
Remote Config v19.2.0 v6.24.0
Google Analytics for Firebase \ (मेज़रमेंट SDK टूल) v17.4.4 v6.18.0
इन-ऐप्लिकेशन मैसेज v19.0.7 v6.24.0
परफ़ॉर्मेंस को मॉनिटर करना v19.0.8 v6.21.0
Crashlytics v17.2.1 v6.23.0
ML Kit v22.1.2 v6.28.0

इंस्टेंस आईडी एपीआई को साफ़ तौर पर कॉल करने वाले कोड को अपडेट करना

अगर आपका Android या Apple ऐप्लिकेशन, सीधे तौर पर Instance ID SDK टूल के तरीकों का इस्तेमाल करता है, तो उस इस्तेमाल को Firebase इंस्टॉलेशन SDK टूल या FCM SDK टूल में मौजूद मिलते-जुलते विकल्पों से बदला जा सकता है.

आइडेंटिफ़ायर वापस पाना

इंस्टेंस आईडी पाने के तरीकों को, इंस्टॉलेशन आईडी पाने के तरीकों से बदल दिया गया है. उदाहरण के लिए:

इससे पहले

Swift

Messaging.messaging().token { token, error in   if let error = error {     print("Error fetching remote FCM registration token: \(error)")   } else if let token = token {     print("Remote instance ID token: \(token)")     self.remoteFCMTokenMessage.text = "Remote FCM registration token: \(token)"   } }

Objective-C

[[FIRMessaging messaging] tokenWithCompletion:^(NSString * _Nullable token, NSError * _Nullable error) {    if (error != nil) {      NSLog(@"Error fetching the remote FCM registration token: %@", error);    } else {      NSLog(@"Remote FCM registration token: %@", token);      NSString* message =        [NSString stringWithFormat:@"FCM registration token: %@", token];      self.remoteFCMTokenMessage.text = message;    }  }];

Java

FirebaseInstanceId.getInstance().getInstanceId()         .addOnCompleteListener(new OnCompleteListener<InstanceIdResult>() {             @Override             public void onComplete(@NonNull Task<InstanceIdResult> task) {                 Log.d("IID_TOKEN", task.getResult().getToken());             }         });

Kotlin

FirebaseInstanceId.getInstance().instanceId         .addOnSuccessListener { result ->             Log.d("IID_TOKEN", result.token)         }

इसके बाद

Swift

do {   let id = try await Installations.installations().installationID()   print("Installation ID: \(id)") } catch {   print("Error fetching id: \(error)") }

Objective-C

[[FIRInstallations installations] installationIDWithCompletion:^(NSString *identifier, NSError *error) {   if (error != nil) {     NSLog(@"Error fetching Installation ID %@", error);     return;   }   NSLog(@"Installation ID: %@", identifier); }];

Java

FirebaseInstallations.getInstance().getId()         .addOnCompleteListener(new OnCompleteListener<String>() {     @Override     public void onComplete(@NonNull Task<String> task) {         if (task.isSuccessful()) {             Log.d("Installations", "Installation ID: " + task.getResult());         } else {             Log.e("Installations", "Unable to get Installation ID");         }     } });

Kotlin

FirebaseInstallations.getInstance().id.addOnCompleteListener { task ->     if (task.isSuccessful) {         Log.d("Installations", "Installation ID: " + task.result)     } else {         Log.e("Installations", "Unable to get Installation ID")     } }

आइडेंटिफ़ायर मिटाना

इंस्टेंस आईडी मिटाने के तरीकों को, Firebase इंस्टॉलेशन आईडी मिटाने के तरीकों से बदल दिया गया है. उदाहरण के लिए:

इससे पहले

Swift

InstanceID.instanceID().deleteID { error in   if let error = error {     print("Error deleting instance ID: \(error)")   } } 

Objective-C

[FIRInstanceID instanceID] deleteIDWithHandler:^(NSError *error) {   if error != nil {     NSLog(@"Error deleting instance ID: %@", error);   } }]; 

Android

FirebaseInstanceId.deleteInstanceId(); 

इसके बाद

Swift

func delete(completion: @escaping (Error?) -> Void) 

Objective-C

- (void)deleteWithCompletion:(nonnull void (^)(NSError *_Nullable))completion; 

Java

FirebaseInstallations.getInstance().delete()         .addOnCompleteListener(new OnCompleteListener<Void>() {     @Override     public void onComplete(@NonNull Task<Void> task) {         if (task.isSuccessful()) {             Log.d("Installations", "Installation deleted");         } else {             Log.e("Installations", "Unable to delete Installation");         }     } });

Kotlin

FirebaseInstallations.getInstance().delete().addOnCompleteListener { task ->     if (task.isComplete) {         Log.d("Installations", "Installation deleted")     } else {         Log.e("Installations", "Unable to delete Installation")     } }

FCM रजिस्ट्रेशन टोकन वापस पाना

Firebase इंस्टॉलेशन की सुविधा लॉन्च होने से पहले, FCM क्लाइंट, इंस्टेंस आईडी से रजिस्ट्रेशन टोकन हासिल करते थे. अब FCM SDK टूल, रजिस्टरेशन टोकन को वापस पाने के तरीके उपलब्ध कराता है.

इससे पहले

Java

FirebaseInstanceId.getInstance().getInstanceId()         .addOnCompleteListener(new OnCompleteListener<InstanceIdResult>() {             @Override             public void onComplete(@NonNull Task<InstanceIdResult> task) {                 if (!task.isSuccessful()) {                     Log.w(TAG, "getInstanceId failed", task.getException());                     return;                 }                  // Get new Instance ID token                 String token = task.getResult().getToken();                  // Log and toast                 String msg = getString(R.string.msg_token_fmt, token);                 Log.d(TAG, msg);                 Toast.makeText(MainActivity.this, msg, Toast.LENGTH_SHORT).show();             }         });

Kotlin

FirebaseInstanceId.getInstance().instanceId         .addOnCompleteListener(OnCompleteListener { task ->             if (!task.isSuccessful) {                 Log.w(TAG, "getInstanceId failed", task.exception)                 return@OnCompleteListener             }              // Get new Instance ID token             val token = task.result?.token              // Log and toast             val msg = getString(R.string.msg_token_fmt, token)             Log.d(TAG, msg)             Toast.makeText(baseContext, msg, Toast.LENGTH_SHORT).show()         })

Swift

Messaging.messaging().token { token, error in   if let error = error {     print("Error fetching remote FCM registration token: \(error)")   } else if let token = token {     print("Remote instance ID token: \(token)")     self.remoteFCMTokenMessage.text = "Remote FCM registration token: \(token)"   } }

Objective-C

[[FIRMessaging messaging] tokenWithCompletion:^(NSString * _Nullable token, NSError * _Nullable error) {    if (error != nil) {      NSLog(@"Error fetching the remote FCM registration token: %@", error);    } else {      NSLog(@"Remote FCM registration token: %@", token);      NSString* message =        [NSString stringWithFormat:@"FCM registration token: %@", token];      self.remoteFCMTokenMessage.text = message;    }  }];

इसके बाद

Java

FirebaseMessaging.getInstance().getToken()     .addOnCompleteListener(new OnCompleteListener<String>() {         @Override         public void onComplete(@NonNull Task<String> task) {           if (!task.isSuccessful()) {             Log.w(TAG, "Fetching FCM registration token failed", task.getException());             return;           }            // Get new FCM registration token           String token = task.getResult();            // Log and toast           String msg = getString(R.string.msg_token_fmt, token);           Log.d(TAG, msg);           Toast.makeText(MainActivity.this, msg, Toast.LENGTH_SHORT).show();         }     });

Kotlin

FirebaseMessaging.getInstance().token.addOnCompleteListener(OnCompleteListener { task ->     if (!task.isSuccessful) {         Log.w(TAG, "Fetching FCM registration token failed", task.exception)         return@OnCompleteListener     }      // Get new FCM registration token     val token = task.result      // Log and toast     val msg = getString(R.string.msg_token_fmt, token)     Log.d(TAG, msg)     Toast.makeText(baseContext, msg, Toast.LENGTH_SHORT).show() })

Swift

Messaging.messaging().token { token, error in   if let error = error {     print("Error fetching FCM registration token: \(error)")   } else if let token = token {     print("FCM registration token: \(token)")     self.fcmRegTokenMessage.text  = "Remote FCM registration token: \(token)"   } }

Objective-C

[[FIRMessaging messaging] tokenWithCompletion:^(NSString *token, NSError *error) {   if (error != nil) {     NSLog(@"Error getting FCM registration token: %@", error);   } else {     NSLog(@"FCM registration token: %@", token);     self.fcmRegTokenMessage.text = token;   } }];