iOS বাস্তবায়ন

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

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

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

pod init

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

pod 'FirebaseInstanceId'

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

pod install

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

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

টোকেন তৈরি করার জন্য Google Developers Console দ্বারা জেনারেট করা একটি Project ID প্রয়োজন৷

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] কল করে সর্বশেষ টোকেনটি পুনরুদ্ধার করা যেতে পারে।

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