Check out what’s new from Firebase at Google I/O 2022. Learn more

ফায়ারবেস ইনস্টলেশন পরিচালনা করুন

Firebase ইনস্টলেশন পরিষেবা (FIS) একটি Firebase অ্যাপের প্রতিটি ইনস্টল করা উদাহরণের জন্য একটি Firebase ইনস্টলেশন আইডি (FID) প্রদান করে। Firebase ইনস্টলেশন আইডি অভ্যন্তরীণভাবে এই Firebase পরিষেবাগুলির দ্বারা ব্যবহৃত হয়:

ফায়ারবেস পরিষেবা ফায়ারবেস ইনস্টলেশন কার্যকারিতা
ফায়ারবেস ক্লাউড মেসেজিং

Firebase ক্লাউড মেসেজিং বার্তা বিতরণের জন্য ডিভাইসগুলিকে লক্ষ্য করতে Firebase ইনস্টলেশন আইডি ব্যবহার করে।

ফায়ারবেস ইন-অ্যাপ মেসেজিং

Firebase ইন-অ্যাপ মেসেজিং বার্তা বিতরণের জন্য ডিভাইসগুলিকে লক্ষ্য করতে Firebase ইনস্টলেশন আইডি ব্যবহার করে।

ফায়ারবেস পারফরম্যান্স মনিটরিং

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

Firebase এর জন্য Google Analytics

Firebase-এর জন্য Google Analytics বিশ্লেষণ এবং অ্যাট্রিবিউশন তথ্য প্রদান করতে ডেটা ব্যবহার করে। সংগৃহীত সুনির্দিষ্ট তথ্য ডিভাইস এবং পরিবেশ অনুসারে পরিবর্তিত হতে পারে।

ফায়ারবেস রিমোট কনফিগারেশন

রিমোট কনফিগার শেষ-ব্যবহারকারী ডিভাইসে ফিরে যাওয়ার জন্য কনফিগারেশন মান নির্বাচন করতে Firebase ইনস্টলেশন আইডি ব্যবহার করে।

ফায়ারবেস এমএল

ইনস্টলেশন প্রমাণীকরণ টোকেন নামক শংসাপত্রগুলি ফায়ারবেস এমএল দ্বারা ডিভাইস প্রমাণীকরণের জন্য ব্যবহার করা হয় যখন অ্যাপ্লিকেশন দৃষ্টান্তগুলির সাথে ইন্টারঅ্যাক্ট করা হয়, উদাহরণস্বরূপ, অ্যাপ্লিকেশন দৃষ্টান্তগুলিতে বিকাশকারী মডেলগুলি বিতরণ করার জন্য৷

সাধারণত, ফায়ারবেস পরিষেবাগুলি ডেভেলপারদের সরাসরি FIS API-এর সাথে ইন্টারঅ্যাক্ট করার প্রয়োজন ছাড়াই Firebase ইনস্টলেশন পরিষেবা ব্যবহার করে। যাইহোক, এমন কিছু ক্ষেত্রে রয়েছে যেখানে অ্যাপ বিকাশকারীরা সরাসরি FIS API কল করতে চাইতে পারেন, যেমন:

  • একটি ফায়ারবেস ইনস্টলেশন এবং ইনস্টলেশনের সাথে সংযুক্ত ডেটা মুছতে।
  • নির্দিষ্ট অ্যাপ ইনস্টলেশন লক্ষ্য করার জন্য শনাক্তকারী (ফায়ারবেস ইনস্টলেশন আইডি) পুনরুদ্ধার করতে।
  • ফায়ারবেস ইনস্টলেশন প্রমাণীকরণের জন্য ইনস্টলেশন প্রমাণীকরণ টোকেন পুনরুদ্ধার করতে।

সরাসরি FIS API কল করা শুরু করতে, আপনার অ্যাপে SDK যোগ করুন।

আপনার অ্যাপে Firebase ইনস্টলেশন SDK যোগ করুন

iOS+

  1. আপনার Podfile এ Firebase ইনস্টলেশনের নির্ভরতা যোগ করুন:
    pod 'FirebaseInstallations'
  2. pod install চালান এবং তৈরি .xcworkspace ফাইলটি খুলুন।
  3. আপনার UIApplicationDelegateFirebaseCore মডিউল আমদানি করুন, সেইসাথে আপনার অ্যাপ প্রতিনিধি যে কোনো Firebase মডিউল ব্যবহার করেন। উদাহরণস্বরূপ, ক্লাউড ফায়ারস্টোর এবং প্রমাণীকরণ ব্যবহার করতে:

    সুইফট

    import FirebaseCore
    import FirebaseFirestore
    import FirebaseAuth
    // ...
          

    উদ্দেশ্য গ

    @import FirebaseCore;
    @import FirebaseFirestore;
    @import FirebaseAuth;
    // ...
          
  4. একটি FirebaseApp শেয়ার করা উদাহরণ কনফিগার করুন, সাধারণত আপনার অ্যাপের application:didFinishLaunchingWithOptions: পদ্ধতি:

    সুইফট

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

    উদ্দেশ্য গ

    // Use Firebase library to configure APIs
    [FIRApp configure];

অ্যান্ড্রয়েড

আপনার মডিউল (অ্যাপ-লেভেল) গ্রেডল ফাইলে (সাধারণত app/build.gradle ) ফায়ারবেস ইনস্টলেশন অ্যান্ড্রয়েড SDK-এর জন্য নির্ভরতা যোগ করুন :

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

জাভাস্ক্রিপ্ট

আপনার ওয়েব অ্যাপ্লিকেশন কীভাবে হোস্ট করা হয়েছে তার উপর নির্ভর করে, আপনার কনফিগারেশন স্বয়ংক্রিয়ভাবে পরিচালনা করা যেতে পারে বা আপনাকে আপনার Firebase কনফিগারেশন অবজেক্ট আপডেট করতে হতে পারে।

উদাহরণস্বরূপ, যদি আপনার নির্ভরতা index.html এ যোগ করা হয়, তাহলে <head> উপাদানে নির্ভরতা যোগ করুন:

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

ফ্লাটার

  1. আপনার ফ্লাটার প্রকল্পের রুট ডিরেক্টরি থেকে, ফায়ারবেস ইনস্টলেশন প্লাগইন ইনস্টল করতে নিম্নলিখিত কমান্ডটি চালান:

    flutter pub add firebase_app_installations
    
  2. আপনার প্রকল্প পুনর্নির্মাণ:

    flutter run
    
  3. Firebase ইনস্টলেশন প্লাগইন আমদানি করুন:

    import 'package:firebase_app_installations/firebase_app_installations.dart';
    

একটি Firebase ইনস্টলেশন মুছুন

ফায়ারবেস ইনস্টলেশনের সাথে যুক্ত ডেটা সাধারণত ব্যক্তিগতভাবে সনাক্ত করা যায় না । তবুও, ব্যবহারকারীদের এই ডেটা পরিচালনা এবং মুছে ফেলার বিকল্প দেওয়া সহায়ক হতে পারে।

ফায়ারবেস ইনস্টলেশন আইডি প্রতিটি অ্যাপ্লিকেশনের প্রতিটি ইনস্টলেশনের জন্য আলাদা; একই ডিভাইসে বিভিন্ন অ্যাপ্লিকেশনের বিভিন্ন ফায়ারবেস ইনস্টলেশন আইডি রয়েছে। ফায়ারবেস ইনস্টলেশন আইডিগুলি অ্যাপ ইনস্টলেশন এবং সেই অ্যাপ ইনস্টলেশনের সাথে সংযুক্ত ডেটা সনাক্ত করে।

আপনি যখন একটি ইনস্টলেশন আইডি মুছে দেন, তখন সেই ইনস্টলেশন আইডির সাথে সংযুক্ত ডেটা 180 দিনের মধ্যে ইনস্টলেশন শনাক্ত করতে Firebase ইনস্টলেশন আইডি ব্যবহার করে এমন সমস্ত Firebase পরিষেবার লাইভ এবং ব্যাকআপ সিস্টেম থেকে সরিয়ে দেওয়া হয়। এই প্রক্রিয়াটি মুছে ফেলা এবং ধরে রাখার বিষয়ে Google-এর বিবৃতিতে উচ্চ স্তরে বর্ণনা করা হয়েছে।

আপনি আপনার অ্যাপে সমস্ত FID-উৎপাদনকারী পরিষেবাগুলি নিষ্ক্রিয় না করলে, FIS কয়েক দিনের মধ্যে একটি নতুন ID তৈরি করে৷ Firebase সদ্য তৈরি আইডিটিকে একটি নতুন Firebase ইনস্টলেশন হিসাবে বিবেচনা করে এবং এটিকে কোনোভাবেই পূর্ববর্তী আইডি বা ডেটার সাথে সংযুক্ত করে না।

একটি ক্লায়েন্ট API কল সহ একটি FID মুছুন৷

Firebase পরিষেবাগুলি দ্বারা তৈরি করা FID মুছে ফেলতে, Firebase ইনস্টলেশন SDK থেকে উপযুক্ত পদ্ধতিতে কল করুন:

সুইফট

Installations.installations().delete { error in
  if let error = error {
    print("Error deleting installation: \(error)")
    return
  }
  print("Installation deleted");
}

উদ্দেশ্য গ

[[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+KTX

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

জাভাস্ক্রিপ্ট

await firebase.installations().delete();

Dart

await FirebaseInstallations.instance.delete();

একটি সার্ভার API কল সহ একটি FID মুছুন৷

একটি সার্ভার API কল সহ একটি FID মুছে ফেলতে, আপনার সার্ভারে Firebase অ্যাডমিন SDK যোগ করুন , যদি আপনি ইতিমধ্যে না করে থাকেন।

একবার SDK যোগ করা হলে, আপনার পছন্দের ভাষায় মুছে ফেলার ফাংশনে একটি কলের মাধ্যমে FID মুছুন (দ্রষ্টব্য: Node.js ব্যতীত, এই পদ্ধতিগুলি ইনস্ট্যান্স আইডি নামকরণকে প্রতিফলিত করে। যাইহোক, যেকোনো বর্তমান ফায়ারবেসের সাথে কল করার সময় এগুলি আসলে FID মুছে দেয় 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();

পাইথন

  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)
}

আপনি যখন একটি সার্ভার API কলের মাধ্যমে একটি Firebase ইনস্টলেশন আইডি মুছে ফেলেন, তখন Firebase পরিষেবাগুলি সেই ইনস্টলেশন আইডির সাথে সংযুক্ত ডেটা মুছে ফেলার প্রক্রিয়া শুরু করে, 1-2 দিনের মধ্যে সেই আইডির জন্য নতুন ডেটা গ্রহণ করা বন্ধ করে এবং তারপর ক্লায়েন্ট অ্যাপকে অবহিত করে। যে আইডিটি মুছে ফেলা হয়েছে। যতক্ষণ না ফায়ারবেস ক্লায়েন্ট অ্যাপকে অবহিত করে, ততক্ষণ অ্যাপের কিছু পরিষেবা আইডিকে টার্গেট করতে পারে—উদাহরণস্বরূপ, একটি Firebase ইনস্টলেশন কয়েক ঘণ্টার জন্য FCM বিজ্ঞপ্তিগুলি পেতে পারে।

আপনি যদি বর্তমান ফায়ারবেস ইনস্টলেশন আইডি মুছে ফেলতে চান এবং অবিলম্বে একটি নতুন, সম্পর্কহীন আইডি সহ Firebase পরিষেবাগুলি ব্যবহার করতে চান, তাহলে মুছে ফেলার জন্য ক্লায়েন্ট API ব্যবহার করুন।

ক্লায়েন্ট শনাক্তকারী পুনরুদ্ধার করুন

আপনার অ্যাপের নির্দিষ্ট ইনস্টলেশন শনাক্ত করার প্রয়োজন হলে, আপনি Firebase ইনস্টলেশন আইডি পুনরুদ্ধার করে তা করতে পারেন। উদাহরণ স্বরূপ, ফায়ারবেস ইন-অ্যাপ মেসেজিং ডেভেলপমেন্টের সময় টেস্টিং করার জন্য, আপনি সঠিক টেস্ট ডিভাইসটি সনাক্ত করতে এবং এর Firebase ইনস্টলেশন আইডি ব্যবহার করে লক্ষ্য করতে পারেন।

একটি Firebase ইনস্টলেশন আইডি পুনরুদ্ধার করতে:

সুইফট

Installations.installations().installationID { (id, error) in
  if let error = error {
    print("Error fetching id: \(error)")
    return
  }
  guard let id = id else { return }
  print("Installation ID: \(id)")
}

উদ্দেশ্য গ

[[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+KTX

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

জাভাস্ক্রিপ্ট

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

Dart

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

ইনস্টলেশন প্রমাণীকরণ টোকেন পুনরুদ্ধার করুন

ফায়ারবেস পরিষেবাগুলি FIS থেকে পুনরুদ্ধার করা প্রমাণীকরণ টোকেনগুলির সাহায্যে Firebase ইনস্টলেশনগুলিকে প্রমাণীকরণ করতে পারে৷ উদাহরণস্বরূপ, রিমোট কনফিগারেশনের জন্য A/B পরীক্ষা ডিজাইন করার সময়, আপনি ইনস্টলেশন প্রমাণীকরণ টোকেন ব্যবহার করে একটি লক্ষ্যযুক্ত পরীক্ষা ডিভাইস প্রমাণীকরণ করতে পারেন।

একটি ইনস্টলেশন প্রমাণীকরণ টোকেন হল JSON ওয়েব টোকেন (JWT) ফরম্যাটে একটি স্বল্পস্থায়ী ধারক টোকেন যাতে একটি ইনস্টলেশনের জন্য নিম্নলিখিত তথ্য থাকে:

  • ফায়ারবেস ইনস্টলেশন আইডি
  • সংশ্লিষ্ট প্রকল্প (প্রজেক্ট projectNumber )
  • সংশ্লিষ্ট ফায়ারবেস অ্যাপ্লিকেশন আইডি ( appId )
  • টোকেনের মেয়াদ শেষ হওয়ার তারিখ

একটি ইনস্টলেশন প্রমাণীকরণ টোকেন প্রত্যাহার করা যায় না এবং মেয়াদ শেষ হওয়ার তারিখ পর্যন্ত বৈধ থাকে। ডিফল্ট টোকেন জীবনকাল এক সপ্তাহ।

একটি ইনস্টলেশন প্রমাণীকরণ টোকেন পুনরুদ্ধার করতে:

সুইফট

Installations.installations().authTokenForcingRefresh(true, completion: { (result, error) in
  if let error = error {
    print("Error fetching token: \(error)")
    return
  }
  guard let result = result else { return }
  print("Installation auth token: \(result.authToken)")
})

উদ্দেশ্য গ

[[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+KTX

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

জাভাস্ক্রিপ্ট

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

Dart

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

Firebase ইনস্টলেশন আইডি লাইফসাইকেল মনিটর করুন

একটি অ্যাপের স্বাভাবিক ক্রিয়াকলাপের সময়, ফায়ারবেস ইনস্টলেশন আইডি (এফআইডি) বিশেষ পর্যবেক্ষণের প্রয়োজন হয় না। যাইহোক, যে অ্যাপগুলি স্পষ্টভাবে FID পুনরুদ্ধার করে এবং ব্যবহার করে তাদের FID-এর সম্ভাব্য মোছা বা ঘূর্ণন নিরীক্ষণের জন্য যুক্তি যোগ করা উচিত। এখানে কিছু ক্ষেত্রে রয়েছে যেখানে FID মুছে ফেলা বা ঘোরানো যেতে পারে:

  • অ্যাপটিকে আনইনস্টল বা পুনরায় ইনস্টল করা, উদাহরণস্বরূপ যখন একজন শেষ ব্যবহারকারী একটি নতুন ডিভাইসে ইনস্টল করেন।
  • শেষ ব্যবহারকারী অ্যাপ বা ডিভাইসের ক্যাশে সাফ করে।
  • অ্যাপ্লিকেশান নিষ্ক্রিয়তার কারণে ব্যাকএন্ডে এফআইডি মুছে ফেলার ট্রিগার হয়েছে (বর্তমানে এটির থ্রেশহোল্ড 270 দিনের নিষ্ক্রিয়তা)।

যখন অ্যাপগুলি এই ধরণের ক্ষেত্রে FID ঘূর্ণন বা মুছে ফেলার অভিজ্ঞতা নেয়, তখন তাদের একটি নতুন FID বরাদ্দ করা হয়। এছাড়াও, একটি মুছে ফেলা FID এর সাথে যুক্ত ইনস্টলেশন প্রমাণীকরণ টোকেনটি মুছে ফেলা হয়, তার নিজস্ব পরিপক্কতা নির্বিশেষে, এবং একটি নতুন ইনস্টলেশন প্রমাণীকরণ টোকেন দিয়ে প্রতিস্থাপিত হয়।

অ্যাপগুলি এই পরিবর্তনগুলি নিরীক্ষণ করতে পারে এবং সেই অনুযায়ী সাড়া দিতে পারে।

FID ঘূর্ণন নিরীক্ষণ করতে:

সুইফট

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

উদ্দেশ্য গ

__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];
}];

NSNotificationName.InstallationIDDidChange নামের একটি NSNotification ডিফল্ট NSNotificationName.InstallationIDDidChange এ পোস্ট করা হয় যখনই একটি নতুন FID বরাদ্দ করা হয়।

অ্যান্ড্রয়েড

Kotlin এবং Java ক্লায়েন্টদের নতুন FID পুনরুদ্ধার করতে ব্যর্থ কলগুলিতে প্রতিক্রিয়া জানাতে পুনরায় চেষ্টা করার যুক্তি যোগ করা উচিত।

জাভাস্ক্রিপ্ট

ওয়েব অ্যাপগুলি onIdChange সদস্যতা নিতে পারে৷

যখনই একটি নতুন FID তৈরি করা হয়, সাবস্ক্রাইব করা কলব্যাকটি ট্রিগার হয়:

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 অ্যাপ ইনস্টলের শনাক্তকারীর জন্য Instance ID SDK-এর উপর নির্ভর করত। ফায়ারবেস ইনস্টলেশন নির্ভরযোগ্যতা, কর্মক্ষমতা এবং নিরাপত্তার ক্ষেত্রে ইন্সট্যান্স আইডির তুলনায় উল্লেখযোগ্য সুবিধা প্রদান করে। Firebase অ্যাপগুলি যেগুলি ইন্সট্যান্স আইডি SDK-এর উপর নির্ভর করে সেগুলি Firebase ইনস্টলেশনে স্থানান্তরিত হওয়া উচিত।

আপনার অ্যাপের উপর ভিত্তি করে মাইগ্রেশন প্রক্রিয়া ভিন্ন:

  • যে অ্যাপগুলি সরাসরি ইন্সট্যান্স আইডি API-কে কল করে না সেগুলি তাদের SDK সংস্করণ আপডেট করে স্থানান্তর করতে পারে৷ বেশিরভাগ ফায়ারবেস অ্যাপ এই বিভাগে পড়ে।

  • যে অ্যাপগুলি স্পষ্টভাবে ইন্সট্যান্স আইডিতে API কল করে তাদের অবশ্যই SDK সংস্করণ আপডেট করতে হবে এবং তাদের Firebase ইনস্টলেশন বা FCM সমতুল্যগুলির সাথে ইন্সট্যান্স আইডি পদ্ধতিগুলি প্রতিস্থাপন করতে কোড পরিবর্তন করতে হবে। যদি আপনার অ্যাপ FCM রেজিস্ট্রেশন টোকেনগুলি পুনরুদ্ধার করতে ইন্সট্যান্স আইডি ব্যবহার করে বা স্পষ্টভাবে অ্যাপ ইনস্ট্যান্স বা অন্য কোনও উদ্দেশ্যে লক্ষ্য করার জন্য ইনস্ট্যান্স আইডি ব্যবহার করে, তাহলে আপনাকে আপনার অ্যাপ্লিকেশন কোড আপডেট করতে হবে।

বর্তমানে, এফআইএস উত্তরাধিকার শনাক্তকারী ফায়ারবেস ইনস্ট্যান্স আইডির সাথে পশ্চাদপদ-সামঞ্জস্যপূর্ণ। একটি IID মুছে ফেলা হল এই Firebase SDKগুলির সাথে ডেটা মুছে ফেলার অনুরোধ করার একটি বিকল্প পদ্ধতি:

  • iOS 6.14.0 এবং তার নিচের
  • 27 ফেব্রুয়ারি, 2020-এর আগে Android SDK

এর মানে হল যে অ্যাপগুলিকে Firebase ইনস্টলেশনে স্থানান্তরিত করার প্রয়োজন নেই; যাইহোক, এটি করা অত্যন্ত বাঞ্ছনীয়।

Firebase ইনস্টলেশনের জন্য ন্যূনতম SDK সংস্করণে আপগ্রেড করা হচ্ছে

ইনস্ট্যান্স আইডি থেকে ফায়ারবেস ইনস্টলেশনে স্থানান্তর করতে, নিশ্চিত করুন যে আপনার অ্যাপ্লিকেশনগুলি নিম্নলিখিত Firebase SDKগুলির অন্তত তালিকাভুক্ত ন্যূনতম সংস্করণ নম্বরগুলি ব্যবহার করে:

ফায়ারবেস SDK ন্যূনতম অ্যান্ড্রয়েড সংস্করণ সর্বনিম্ন iOS সংস্করণ
ফায়ারবেস ক্লাউড মেসেজিং v20.3.0 v6.34.0
রিমোট কনফিগারেশন v19.2.0 v6.24.0
Firebase এর জন্য Google Analytics \ (পরিমাপ SDK) v17.4.4 v6.18.0
ইন-অ্যাপ মেসেজিং v19.0.7 v6.24.0
কর্মক্ষমতা নিরীক্ষণ v19.0.8 v6.21.0
ক্র্যাশলাইটিক্স v17.2.1 v6.23.0
এমএল কিট v22.1.2 v6.28.0

কোড আপডেট করা হচ্ছে যা স্পষ্টভাবে ইন্সট্যান্স আইডি এপিআইকে কল করে

যদি আপনার Android বা Apple অ্যাপ সরাসরি Instance ID SDK পদ্ধতি ব্যবহার করে, তাহলে আপনি Firebase ইনস্টলেশন SDK বা FCM SDK-এ অভিন্ন বিকল্পগুলির সাথে সেই ব্যবহার প্রতিস্থাপন করতে পারেন।

একটি শনাক্তকারী পুনরুদ্ধার করা হচ্ছে

ইনস্ট্যান্স আইডি পাওয়ার পদ্ধতিগুলি একটি ইনস্টলেশন আইডি পাওয়ার পদ্ধতি দিয়ে প্রতিস্থাপিত হয়। উদাহরণ স্বরূপ:

আগে

সুইফট

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)"
  }
}

উদ্দেশ্য গ

[[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+KTX

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

পরে

সুইফট

Installations.installations().installationID { (id, error) in
  if let error = error {
    print("Error fetching id: \(error)")
    return
  }
  guard let id = id else { return }
  print("Installation ID: \(id)")
}

উদ্দেশ্য গ

[[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+KTX

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

একটি শনাক্তকারী মুছে ফেলা হচ্ছে

ইনস্ট্যান্স আইডি মুছে ফেলার পদ্ধতিগুলি ফায়ারবেস ইনস্টলেশন আইডি মুছে ফেলার পদ্ধতিগুলির সাথে প্রতিস্থাপিত হয়। উদাহরণ স্বরূপ:

আগে

সুইফট

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

উদ্দেশ্য গ

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

অ্যান্ড্রয়েড

FirebaseInstanceId.deleteInstanceId();

পরে

সুইফট

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

উদ্দেশ্য গ

- (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+KTX

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

একটি FCM রেজিস্ট্রেশন টোকেন পুনরুদ্ধার করা হচ্ছে

ফায়ারবেস ইনস্টলেশন চালু করার আগে, 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+KTX

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()
        })

সুইফট

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)"
  }
}

উদ্দেশ্য গ

[[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+KTX

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()
})

সুইফট

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)"
  }
}

উদ্দেশ্য গ

[[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;
  }
}];