iOS বাস্তবায়ন

নিম্নলিখিত উদাহরণগুলি আপনাকে iOS ক্লায়েন্টে Instance ID বাস্তবায়নে সাহায্য করবে। মনে রাখবেন যে এই উদাহরণগুলি GCM স্কোপ ব্যবহার করে, যা আপনি Firebase Cloud Messaging এর জন্য iOS ক্লায়েন্টের টোকেন পরিচালনা করতে ব্যবহার করবেন।

আপনার CocoaPods নির্ভরতা সেট আপ করুন

ইনস্ট্যান্স আইডি নির্ভরতা ইনস্টল এবং পরিচালনা করতে CocoaPods ব্যবহার করে। একটি টার্মিনাল উইন্ডো খুলুন এবং আপনার অ্যাপ্লিকেশনের জন্য Xcode প্রকল্পের অবস্থানে নেভিগেট করুন। যদি আপনি ইতিমধ্যে আপনার অ্যাপ্লিকেশনের জন্য একটি Podfile তৈরি না করে থাকেন, তাহলে এখনই একটি তৈরি করুন:

pod init

আপনার অ্যাপ্লিকেশনের জন্য তৈরি পডফাইলটি খুলুন এবং নিম্নলিখিতগুলি যোগ করুন:

pod 'FirebaseInstanceId'

ফাইলটি সংরক্ষণ করুন এবং চালান:

pod install

এটি আপনার অ্যাপ্লিকেশনের জন্য একটি .xcworkspace ফাইল তৈরি করে। আপনার অ্যাপ্লিকেশনের ভবিষ্যতের সমস্ত ডেভেলপমেন্টের জন্য এই ফাইলটি ব্যবহার করুন।

একটি টোকেন তৈরি করুন

টোকেন তৈরি করতে গুগল ডেভেলপারস কনসোল দ্বারা তৈরি একটি প্রজেক্ট আইডি প্রয়োজন।

NSString *authorizedEntity = PROJECT_ID;
String *scope = kFIRInstanceIDScopeFirebaseMessaging;
NSDictionary *options = @{
  @"apns_token" : <APNS Token data>,
  // 1 if APNS sandbox token else 0
  @"apns_sandbox" : @(1),
};
[[FIRInstanceID instanceID] tokenWithAuthorizedEntity:authorizedEntity
                                                scope:scope
                                              options:options
                                              handler:
                  ^(NSString * _Nullable token, NSError * _Nullable error) {
                      // ...
}];

টোকেন এবং ইনস্ট্যান্স আইডি পরিচালনা করুন

ইনস্ট্যান্স আইডি আপনাকে টোকেনগুলি মুছে ফেলতে এবং রিফ্রেশ করতে দেয়।

টোকেন এবং ইনস্ট্যান্স আইডি মুছে ফেলুন

NSString *authorizedEntity = PROJECT_ID; // Project ID
String *scope = kFIRInstanceIDScopeFirebaseMessaging;
FIRInstanceIDDeleteTokenHandler handler = ^void(NSError *error) {
  if (error) {
    // Failed to delete the token. Check error and do an exponential
    // backoff to retry again.
  } else {
    // Successfully deleted the token.
  }
};
[[FIRInstanceID instanceID]
    deleteTokenWithAuthorizedEntity:authorizedEntity
                              scope:scope
                            handler:handler];

আপনি ইনস্ট্যান্স আইডিটিও মুছে ফেলতে পারেন, এই ক্ষেত্রে পরের বার যখন আপনি getInstance() কল করবেন তখন আপনি একটি নতুন ইনস্ট্যান্স আইডি পাবেন:

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

টোকেন রিফ্রেশ করুন

ইনস্ট্যান্স আইডি পরিষেবা টোকেন তৈরি বা পুনরুজ্জীবিত করতে পারে। যখন এটি ঘটে, তখন একটি বিজ্ঞপ্তি পাঠানো হবে। আপনি kFIRInstanceIDTokenRefreshNotification নামক বিজ্ঞপ্তিগুলির জন্য একজন পর্যবেক্ষক যোগ করে এই বিজ্ঞপ্তিটি শুনতে পারেন।

[[NSNotificationCenter defaultCenter] addObserver:self
         selector:@selector(tokenRefreshNotification:) 
         name:kFIRInstanceIDTokenRefreshNotification object:nil];

টোকেন তৈরির আগে এই পর্যবেক্ষকটি তৈরি করতে হবে, উদাহরণস্বরূপ [FIRApp configure] কল করার আগে। [[FIRInstanceID instanceID] token] কল করে সর্বশেষ টোকেনটি পুনরুদ্ধার করা যেতে পারে।

মনে রাখবেন যে ক্লাউড মেসেজিংয়ের জন্য টোকেন তৈরি পর্যবেক্ষণের জন্য, একটি নির্দিষ্ট প্রতিনিধি উপলব্ধ রয়েছে।