আপনার পার্স iOS অ্যাপ Firebase-এ স্থানান্তর করুন

আপনি যদি একজন পার্স ব্যবহারকারী হন একটি পরিষেবা সমাধান হিসাবে একটি বিকল্প ব্যাকএন্ড খুঁজছেন, Firebase হতে পারে আপনার iOS অ্যাপের জন্য আদর্শ পছন্দ।

এই নির্দেশিকাটি বর্ণনা করে যে কীভাবে আপনার অ্যাপে নির্দিষ্ট পরিষেবাগুলিকে একীভূত করতে হয়। মৌলিক ফায়ারবেস সেটআ�� নির্দেশাবলীর জন্য, iOS+ সেটআপ নির্দেশিকা দেখুন।

Google Analytics

Google Analytics হল একটি বিনামূল্যের অ্যাপ পরিমাপ সমাধান যা অ্যাপ ব্যবহার এবং ব্যবহারকারীর ব্যস্ততার অন্তর্দৃষ্টি প্রদান করে। Analytics Firebase বৈশিষ্ট্য জুড়ে একত্রিত করে এবং আপনাকে 500টি পর্যন্ত স্বতন্ত্র ইভেন্টের জন্য সীমাহীন প্রতিবেদন প্রদান করে যা আপনি Firebase SDK ব্যবহার করে সংজ্ঞায়িত করতে পারেন।

আরও জানতে Google Analytics ডক্স দেখুন।

প্রস্তাবিত মাইগ্রেশন কৌশল

বিভিন্ন বিশ্লেষণ প্রদানকারী ব্যবহার করা একটি সাধারণ দৃশ্য যা Google Analytics এ সহজেই প্রযোজ্য। Analytics স্বয়ংক্রিয়ভাবে সংগ্রহ করে এমন ইভেন্ট এবং ব্যবহারকারীর বৈশিষ্ট্য থেকে উপকৃত হতে আপনার অ্যাপে এটি যোগ করুন, যেমন ফার্স্ট ওপেন, অ্যাপ আপডেট, ডিভাইস মডেল, বয়স।

কাস্টম ইভেন্ট এবং ব্যবহারকারীর বৈশিষ্ট্যগুলির জন্য, আপনি ইভেন্ট এবং বৈশিষ্ট্যগুলি লগ করার জন্য পার্স অ্যানালিটিক্স এবং Google Analytics উভয় ব্যবহার করে একটি ডবল রাইটিং কৌশল নিযুক্ত করতে পারেন, যা আপনাকে ধীরে ধীরে নতুন সমাধান রোল আউট করতে দেয়৷

কোড তুলনা

বিশ্লেষণ পার্স

// Start collecting data
[PFAnalytics trackAppOpenedWithLaunchOptions:launchOptions];

NSDictionary *dimensions = @{
  // Define ranges to bucket data points into meaningful segments
  @"priceRange": @"1000-1500",
  // Did the user filter the query?
  @"source": @"craigslist",
  // Do searches happen more often on weekdays or weekends?
  @"dayType": @"weekday"
};
// Send the dimensions to Parse along with the 'search' event
[PFAnalytics trackEvent:@"search" dimensions:dimensions];

Google Analytics

// Obtain the AppMeasurement instance and start collecting data
[FIRApp configure];

// Send the event with your params
[FIRAnalytics logEventWithName:@"search" parameters:@{
  // Define ranges to bucket data points into meaningful segments
  @"priceRange": @"1000-1500",
  // Did the user filter the query?
  @"source": @"craigslist",
  // Do searches happen more often on weekdays or weekends?
  @"dayType": @"weekday"
}];

Firebase Realtime Database

Firebase Realtime Database হল একটি NoSQL ক্লাউড-হোস্টেড ডাটাবেস। ডেটা JSON হিসাবে সংরক্ষণ করা হয় এবং প্রতিটি সংযুক্ত ক্লায়েন্টের সাথে রিয়েল টাইমে সিঙ্ক্রোনাইজ করা হয়।

আরও জানতে Firebase Realtime Database ডক্স দেখুন।

পার্স ডেটার সাথে পার্থক্য

বস্তু

পার্সে আপনি একটি PFObject বা এটির একটি সাবক্লাস সঞ্চয় করেন, যাতে JSON-সামঞ্জস্যপূর্ণ ডেটার মূল-মান জোড়া রয়েছে। ডেটা স্কিমলেস, যার মানে প্রতিটি PFObject এ কী কী আছে তা আপনাকে নির্দিষ্ট করতে হবে না।

সমস্ত Firebase Realtime Database ডেটা JSON অবজেক্ট হিসাবে সংরক্ষণ করা হয় এবং PFObject এর জন্য কোন সমতুল্য নেই; আপনি সহজভাবে জেএসওএন ট্রি মানগুলিতে লিখতে পারেন যা উপলব্ধ JSON প্রকারের সাথে মিলে যায়।

আপনি কীভাবে একটি গেমের জন্য উচ্চ স্কোর সংরক্ষণ করতে পারেন তার একটি উদাহরণ নিচে দেওয়া হল।

পার্স
PFObject *gameScore = [PFObject objectWithClassName:@"GameScore"];
gameScore[@"score"] = @1337;
gameScore[@"playerName"] = @"Sean Plott";
gameScore[@"cheatMode"] = @NO;
[gameScore saveInBackgroundWithBlock:^(BOOL succeeded, NSError *error) {
  if (succeeded) {
    // The object has been saved.
  } else {
    // There was a problem, check error.description
  }
}];
ফায়ারবেস
// Create a reference to the database
FIRDatabaseReference *ref = [[FIRDatabase database] reference];
NSString *key = [[ref child:@"scores"] childByAutoId].key;
NSDictionary *score = @{@"score": @1337,
                        @"playerName": @"Sean Plott",
                        @"cheatMode": @NO};
[key setValue:score withCompletionBlock:^(NSError *error,  FIRDatabaseReference *ref) {
  if (error) {
    // The object has been saved.
  } else {
    // There was a problem, check error.description
  }
}];
আরও বিশদ বিবরণের জন্য, অ্যাপল প্ল্যাটফর্মে ডেটা পড়ুন এবং লিখুন নির্দেশিকা দেখুন।

ডেটার মধ্যে সম্পর্ক

একটি PFObject অন্য PFObject এর সাথে সম্পর্ক রাখতে পারে: যেকোনো বস্তু অন্য বস্তুকে মান হিসেবে ব্যবহার করতে পারে।

Firebase Realtime Database , ফ্ল্যাট ডেটা স্ট্রাকচার ব্যবহার করে সম্পর্কগুলিকে আরও ভালভাবে প্রকাশ করা হয় যা ডেটাকে আলাদা পাথে বিভক্ত করে, যাতে সেগুলি আলাদা কলে দক্ষতার সাথে ডাউনলোড করা যায়।

ব্লগিং অ্যাপে পোস্ট এবং তাদের লেখকদের মধ্যে আপনি কীভাবে সম্পর্ক গঠন করতে পারেন তার একটি উদাহরণ নিচে দেওয়া হল।

পার্স
// Create the author
PFObject *myAuthor = [PFObject objectWithClassName:@"Author"];
myAuthor[@"name"] = @"Grace Hopper";
myAuthor[@"birthDate"] = @"December 9, 1906";
myAuthor[@"nickname"] = @"Amazing Grace";

// Create the post
PFObject *myPost = [PFObject objectWithClassName:@"Post"];
myPost[@"title"] = @"Announcing COBOL, a New Programming Language";

// Add a relation between the Post and the Author
myPost[@"parent"] = myAuthor;

// This will save both myAuthor and myPost
[myPost saveInBackground];
ফায়ারবেস
// Create a reference to the database
FIRDatabaseReference *ref = [[FIRDatabase database] reference];

// Create the author
NSString *myAuthorKey = @"ghopper";
NSDictionary *author = @{@"name": @"Grace Hopper",
                         @"birthDate": @"December 9, 1906",
                         @"nickname": @"Amazing Grace"};
// Save the author
[[ref child:myAuthorKey] setValue:author]

// Create and save the post
NSString *key = [[ref child:@"posts"] childByAutoId].key;
NSDictionary *post = @{@"author": myAuthorKey,
                       @"title": @"Announcing COBOL, a New Programming Language"};
[key setValue:post]

নিম্নলিখিত তথ্য বিন্যাস ফলাফল.

{
  // Info about the authors
  "authors": {
    "ghopper": {
      "name": "Grace Hopper",
      "date_of_birth": "December 9, 1906",
      "nickname": "Amazing Grace"
    },
    ...
  },
  // Info about the posts: the "author" fields contains the key for the author
  "posts": {
    "-JRHTHaIs-jNPLXOQivY": {
      "author": "ghopper",
      "title": "Announcing COBOL, a New Programming Language"
    }
    ...
  }
}
আরো বিস্তারিত জানার জন্য, আপনার ডাটাবেসের গঠন নির্দেশিকা দেখুন।

ডেটা পড়া

পার্সে আপনি একটি নির্দিষ্ট পার্স অবজেক্টের আইডি ব্যবহার করে ডেটা পড়েন বা PFQuery ব্যবহার করে অনুসন্ধান চালান।

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

"বস্তু" বিভাগে উপস্থাপিত উদাহরণের উপর ভিত্তি করে আপনি কীভাবে একটি নির্দিষ্ট খেলোয়াড়ের জন্য স্কোর পুনরুদ্ধার করতে পারেন তার একটি উদাহরণ নিচে দেওয়া হল।

পার্স
PFQuery *query = [PFQuery queryWithClassName:@"GameScore"];
[query whereKey:@"playerName" equalTo:@"Dan Stemkoski"];
[query findObjectsInBackgroundWithBlock:^(NSArray *objects, NSError *error) {
  if (!error) {
    for (PFObject *score in objects) {
      NSString *gameScore = score[@"score"];
      NSLog(@"Retrieved: %@", gameScore);
    }
  } else {
    // Log details of the failure
    NSLog(@"Error: %@ %@", error, [error userInfo]);
  }
}];
ফায়ারবেস
// Create a reference to the database
FIRDatabaseReference *ref = [[FIRDatabase database] reference];

// This type of listener is not one time, and you need to cancel it to stop
// receiving updates.
[[[[ref child:@"scores"] queryOrderedByChild:@"playerName"] queryEqualToValue:@"Dan Stemkoski"]
    observeEventType:FIRDataEventTypeChildAdded withBlock:^(FIRDataSnapshot *snapshot) {
  // This will fire for each matching child node.
  NSDictionary *score = snapshot.value;
  NSString gameScore = score[@"score"];
  NSLog(@"Retrieved: %@", gameScore);
}];
উপলভ্য ধরনের ইভেন্ট শ্রোতাদের সম্পর্কে আরও বিশদ বিবরণের জন্য এবং কীভাবে ডেটা অর্ডার এবং ফিল্টার করতে হয়, অ্যাপল প্ল্যাটফর্মে ডেটা পড়ুন এবং লিখুন নির্দেশিকা দেখুন।

প্রস্তাবিত মাইগ্রেশন কৌশল

আপনার ডেটা পুনর্বিবেচনা করুন

Firebase Realtime Database সমস্ত সংযুক্ত ক্লায়েন্ট জুড়ে মিলিসেকেন্ডে ডেটা সিঙ্ক করার জন্য অপ্টিমাইজ করা হয়েছে এবং ফলাফলের ডেটা কাঠামো পার্স কোর ডেটা থেকে আলাদা। এর মানে হল যে আপনার মাইগ্রেশনের প্রথম ধাপ হল আপনার ডেটাতে কী পরিবর্তন প্রয়োজন তা বিবেচনা করা, যার মধ্যে রয়েছে:

  • কিভাবে আপনার পার্স অবজেক্ট ফায়ারবেস ডেটাতে ম্যাপ করা উচিত
  • আপনার যদি পিতামাতা-সন্তানের সম্পর্ক থাকে তবে কীভাবে আপনার ডেটা বিভিন্ন পাথ জুড়ে বিভক্ত করবেন যাতে এটি আলাদা কলে দক্ষতার সাথে ডাউনলোড করা যায়।

আপনার ডেটা স্থানান্তর করুন

Firebase-এ আপনার ডেটা কীভাবে গঠন করবেন তা আপনি সিদ্ধান্ত নেওয়ার পরে, আপনার অ্যাপের উভয় ডেটাবেসে লেখার প্রয়োজনের সময়কাল কীভাবে পরিচালনা করবেন তা আপনাকে পরিকল্পনা করতে হবে। আপনার পছন্দ হল:

ব্যাকগ্রাউন্ড সিঙ্ক

এই পরিস্থিতিতে, আপনার কাছে অ্যাপটির দ��টি সংস্করণ রয়েছে: পুরানো সংস্করণ যা পার্স ব্যবহার করে এবং একটি নতুন সংস্করণ যা ফায়ারবেস ব্যবহার করে৷ দুটি ডাটাবেসের মধ্যে সিঙ্কগুলি পার্স ক্লাউড কোড (ফায়ারবেস থেকে পার্স) দ্বারা পরিচালিত হয়, আপনার কোড ফায়ারবেসের পরিবর্তনগুলি শুনে এবং সেই পরিবর্তনগুলিকে পার্সের সাথে সিঙ্ক করে৷ আপনি নতুন সংস্করণ ব্যবহার শুরু করার আগে, আপনাকে অবশ্যই:

  • আপনার বিদ্যমান পার্স ডেটাকে নতুন Firebase কাঠামোতে রূপান্তর করুন এবং Firebase Realtime Database লিখুন।
  • পার্স ক্লাউড কোড ফাংশনগুলি লিখুন যেগুলি পুরানো ক্লায়েন্টদের দ্বারা পার্স ডেটাতে করা Firebase Realtime Database পরিবর্তনগুলি লিখতে Firebase REST API ব্যবহার করে৷
  • কোড লিখুন এবং স্থাপন করুন যা ফায়ারবেসে পরিবর্তনগুলি শোনে এবং সেগুলিকে পার্স ডাটাবেসে সিঙ্ক করে৷

এই দৃশ্যটি পুরানো এবং নতুন কোডের একটি পরিষ্কার বিচ্ছেদ নিশ্চিত করে এবং ক্লায়েন্টদের সহজ রাখে। এই দৃশ্যের চ্যালেঞ্জগুলি হল প্রাথমিক রপ্তানিতে বড় ডেটাসেটগুলি পরিচালনা করা এবং দ্বিমুখী সিঙ্ক অসীম পুনরাবৃত্তি তৈরি না করে তা নিশ্চিত করা৷

ডাবল লিখুন

এই পরিস্থিতিতে, আপনি অ্যাপটির একটি নতুন সংস্করণ লিখবেন যা ফায়ারবেস এবং পার্স উভয়ই ব্যবহার করে, পার্স ক্লাউড কোড ব্যবহার করে পুরানো ক্লায়েন্টদের দ্বারা করা পরিবর্তনগুলিকে পার্স ডেটা থেকে Firebase Realtime Database সিঙ্ক করতে। যখন পর্যাপ্ত লোক অ্যাপের পার্স-অনলি সংস্করণ থেকে স্থানান্তরিত হয়, তখন আপনি ডবল রাইটিং সংস্করণ থেকে পার্স কোডটি সরাতে পারেন।

এই পরিস্থিতিতে কোন সার্ভার সাইড কোড প্রয়োজন হয় না. এর অসুবিধাগুলি হল যে ডেটা যা অ্যাক্সেস করা হয় না তা স্থানান্তরিত হয় না এবং উভয় SDK ব্যবহার করে আপনার অ্যাপের আকার বৃদ্ধি পায়।

Firebase Authentication

Firebase Authentication ব্যবহারকারীদের পাসওয়ার্ড এবং জনপ্রিয় ফেডারেটেড পরিচয় প্রদানকারী যেমন Google, Facebook এবং Twitter ব্যবহার করে প্রমাণীকরণ করতে পারে। সমস্ত প্ল্যাটফর্ম জুড়ে আপনার অ্যাপের জন্য একটি সম্পূর্ণ প্রমাণীকরণ অভিজ্ঞতা বাস্তবায়ন এবং বজায় রাখার জন্য প্র��়োজনীয় উল্লেখযোগ্য বিনিয়োগ সংরক্ষণ করতে এটি UI লাইব্রেরিগুলিও সরবরাহ করে।

আরও জানতে Firebase Authentication ডক্স দেখুন।

পার্স প্রমাণের সাথে পার্থক্য

পার্স PFUser নামে একটি বিশেষ ব্যবহারকারী শ্রেণী প্রদান করে যা ব্যবহারকারীর অ্যাকাউন্ট পরিচালনার জন্য প্রয়োজনীয় কার্যকারিতা স্বয়ংক্রিয়ভাবে পরিচালনা করে। PFUser হল PFObject এর একটি সাবক্লাস, যার অর্থ ব্যবহারকারীর ডেটা পার্স ডেটাতে পাওয়া যায় এবং অন্যান্য PFObject এর মতো অতিরিক্ত ক্ষেত্রগুলির সাথে প্রসারিত করা যেতে পারে।

একটি FIRUser মৌলিক বৈশিষ্ট্যগুলির একটি নির্দিষ্ট সেট রয়েছে—একটি অনন্য আইডি, একটি প্রাথমিক ইমেল ঠিকানা, একটি নাম এবং একটি ফটো URL-একটি পৃথক প্রকল্পের ব্যবহারকারী ডাটাবেসে সংরক্ষিত; সেই বৈশিষ্ট্যগুলি ব্যবহারকারী দ্বারা আপডেট করা যেতে পারে। আপনি সরাসরি FIRUser অবজেক্টে অন্যান্য বৈশিষ্ট্য যোগ করতে পারবেন না; পরিবর্তে, আপনি আপনার Firebase Realtime Database অতিরিক্ত বৈশিষ্ট্য সংরক্ষণ করতে পারেন।

আপনি কীভাবে একজন ব্যবহারকারীকে সাইন আপ করতে পারেন এবং একটি অতিরিক্ত ফোন নম্বর ক্ষেত্র যোগ করতে পারেন তার একটি উদাহরণ নিচে দেওয়া হল৷

পার্স
PFUser *user = [PFUser user];
user.username = @"my name";
user.password = @"my pass";
user.email = @"email@example.com";

// other fields can be set just like with PFObject
user[@"phone"] = @"415-392-0202";

[user signUpInBackgroundWithBlock:^(BOOL succeeded, NSError *error) {
  if (!error) {
    // Hooray! Let them use the app now.
  } else {
    // Something went wrong
    NSString *errorString = [error userInfo][@"error"];
  }
}];
ফায়ারবেস
[[FIRAuth auth] createUserWithEmail:@"email@example.com"
                           password:@"my pass"
                         completion:^(FIRUser *_Nullable user, NSError *_Nullable error) {
  if (!error) {
    FIRDatabaseReference *ref = [[FIRDatabase database] reference];
    [[[[ref child:@"users"] child:user.uid] child:@"phone"] setValue:@"415-392-0202"
  } else {
    // Something went wrong
    NSString *errorString = [error userInfo][@"error"];
  }
}];

প্রস্তাবিত মাইগ্রেশন কৌশল

অ্যাকাউন্ট মাইগ্রেট করুন

ব্যবহারকারীর অ্যাকাউন্টগুলিকে পার্স থেকে ফায়ারবেসে স্থানান্তর করতে, আপনার ব্যবহারকারীর ডেটাবেসকে একটি JSON বা CSV ফাইলে রপ্তানি করুন, তারপর Firebase CLI-এর auth:import কমান্ড ব্যবহার করে ফাইলটিকে আপনার Firebase প্রকল্পে আমদানি করুন৷

প্রথমে, পার্স কনসোল বা আপনার স্ব-হোস্ট করা ডাটাবেস থেকে আপনার ব্যবহারকারীর ডাটাবেস রপ্তানি করুন। উদাহরণস্বরূপ, পার্স কনসোল থেকে রপ্তানি করা একটি JSON ফাইল নিম্নলিখিতগুলির মতো দেখতে হতে পারে:

{ // Username/password user
  "bcryptPassword": "$2a$10$OBp2hxB7TaYZgKyTiY48luawlTuYAU6BqzxJfpHoJMdZmjaF4HFh6",
  "email": "user@example.com",
  "username": "testuser",
  "objectId": "abcde1234",
  ...
},
{ // Facebook user
  "authData": {
    "facebook": {
      "access_token": "ABCDEFGHIJKLMNOPQRSTUVWXYZ",
      "expiration_date": "2017-01-02T03:04:05.006Z",
      "id": "1000000000"
    }
  },
  "username": "wXyZ987654321StUv",
  "objectId": "fghij5678",
  ...
}

তারপর, রপ্তানি করা ফাইলটিকে Firebase CLI-এর প্রয়োজনীয় বিন্যা��ে রূপান্তর করুন। আপনার ফায়ারবেস ব্যবহারকারীদের localId হিসাবে আপনার পার্স ব্যবহারকারীদের objectId ব্যবহার করুন। এছাড়াও, base64 পার্স থেকে bcryptPassword মান এনকোড করুন এবং passwordHash ক্ষেত্রে ব্যবহার করুন। যেমন:

{
  "users": [
    {
      "localId": "abcde1234",  // Parse objectId
      "email": "user@example.com",
      "displayName": "testuser",
      "passwordHash": "JDJhJDEwJE9CcDJoeEI3VGFZWmdLeVRpWTQ4bHVhd2xUdVlBVTZCcXp4SmZwSG9KTWRabWphRjRIRmg2",
    },
    {
      "localId": "fghij5678",  // Parse objectId
      "displayName": "wXyZ987654321StUv",
      "providerUserInfo": [
        {
          "providerId": "facebook.com",
          "rawId": "1000000000",  // Facebook ID
        }
      ]
    }
  ]
}

অবশেষে, হ্যাশ অ্যালগরিদম হিসাবে bcrypt নির্দিষ্ট করে Firebase CLI দিয়ে রূপান্তরিত ফাইলটি আমদানি করুন:

firebase auth:import account_file.json --hash-algo=BCRYPT

ব্যবহারকারীর ডেটা স্থানান্তর করুন

আপনি যদি আপনার ব্যবহারকারীদের জন্য অতিরিক্ত ডেটা সঞ্চয় করে থাকেন তবে ডেটা মাইগ্রেশন বিভাগে বর্ণিত কৌশলগুলি ব্যবহার করে আপনি এটিকে Firebase Realtime Database স্থানান্তর করতে পারেন। আপনি যদি অ্যাকাউন্ট মাইগ্রেশন বিভাগে বর্ণিত ফ্লো ব্যবহার করে অ্যাকাউন্টগুলি স্থানান্তর করেন, আপনার ফায়ারবেস অ্যাকাউন্টগুলিতে আপনার পার্স অ্যাকাউন্টগুলির একই আইডি থাকে, যা আপনাকে ব্যবহারকারী আইডি দ্বারা চাবি করা যেকোনো সম্পর্ককে সহজেই স্থানান্তর এবং পুনরুত্পাদন করতে দেয়।

Firebase Cloud Messaging

Firebase Cloud Messaging ( FCM ) হল একটি ক্রস-প্ল্যাটফর্ম মেসেজিং সলিউশন যা আপনাকে বিনা খরচে নির্ভরযোগ্যভাবে বার্তা এবং বিজ্ঞপ্তি প্রদান করতে দেয়। নোটিফিকেশন কম্পোজার হল Firebase Cloud Messaging -এ নির্মিত একটি বিনা খরচে পরিষেবা যা মোবাইল অ্যাপ ডে��েলপারদের লক্ষ্যযুক্ত ব্যবহারকারীর বিজ্ঞপ্তিগুলিকে সক্ষম করে৷

আরও জানতে Firebase Cloud Messaging ডক্স দেখুন।

পার্স পুশ বিজ্ঞপ্তিগুলির সাথে পার্থক্য

বিজ্ঞপ্তির জন্য নিবন্ধিত একটি ডিভাইসে ইনস্টল করা প্রতিটি পার্স অ্যাপ্লিকেশনের একটি সম্পর্কিত Installation অবজেক্ট থাকে, যেখানে আপনি বিজ্ঞপ্তিগুলি লক্ষ্য করার জন্য প্রয়োজনীয় সমস্ত ডেটা সংরক্ষণ করেন। Installation হল PFUser এর একটি সাবক্লাস, যার মানে আপনি আপনার Installation ইনস্ট্যান্সে যেকোন অতিরিক্ত ডেটা যোগ করতে পারেন।

নোটিফিকেশন কম্পোজার অ্যাপ, অ্যাপ ভার্সন এবং ডিভাইসের ভাষার মতো তথ্যের উপর ভিত্তি করে পূর্বনির্ধারিত ব্যবহারকারী সেগমেন্ট প্রদান করে। আপনি শ্রোতা তৈরি করতে Google Analytics ইভেন্ট এবং বৈশিষ্ট্য ব্যবহার করে আরও জটিল ব্যবহারকারী বিভাগ তৈরি করতে পারেন। আরও জানতে শ্রোতাদের সহায়তা নির্দেশিকা দেখুন। এই টার্গেটিং তথ্যগুলি Firebase Realtime Database দৃশ্যমান নয়৷

প্রস্তাবিত মাইগ্রেশন কৌশল

ডিভাইস টোকেন স্থানান্তর করা

পার্স যখন বিজ্ঞপ্তির জন্য ইনস্টলেশন লক্ষ্য করতে APNs ডিভাইস টোকেন ব্যবহার করে, FCM APNs ডিভাইস টোকেনে ম্যাপ করা FCM রেজিস্ট্রেশন টোকেন ব্যবহার করে। শুধু আপনার Apple অ্যাপে FCM SDK যোগ করুন এবং এটি স্বয়ংক্রিয়ভাবে একটি FCM টোকেন আনবে

চ্যানেলগুলিকে FCM বিষয়গুলিতে স্থানান্তর করা হচ্ছে৷

আপনি যদি বিজ্ঞপ্তি পাঠানোর জন্য পার্স চ্যানেল ব্যবহার করেন, তাহলে আপনি FCM বিষয়গুলিতে স্থানান্তর করতে পারেন, যা একই প্রকাশক-সাবস্ক্রাইবার মডেল প্রদান করে। পার্স থেকে FCM এ রূপান্তর পরিচালনা করতে, আপনি অ্যাপটির একটি নতুন সংস্করণ লিখতে পারেন যা পার্স চ্যানেলগুলি থেকে সদস্যতা ত্যাগ করতে পার্স SDK ��বং সংশ্লিষ্ট FCM বিষয়গুলিতে সদস্যতা নিতে FCM SDK ব্যবহার করে৷

উদাহরণস্বরূপ, যদি আপনার ব্যবহারকারী "জায়েন্টস" বিষয়ে সদস্যতা নেন, তাহলে আপনি এরকম কিছু করবেন:

PFInstallation *currentInstallation = [PFInstallation currentInstallation];
[currentInstallation removeObject:@"Giants" forKey:@"channels"];
[currentInstallation saveInBackgroundWithBlock:^(BOOL succeeded, NSError *error) {
  if (succeeded) {
    [[FIRMessaging messaging] subscribeToTopic:@"/topics/Giants"];
  } else {
    // Something went wrong unsubscribing
  }
}];

এই কৌশলটি ব্যবহার করে, আপনি পুরানো এবং নতুন উভয় সংস্করণের ব্যবহারকারীদের সমর্থন করে পার্স চ্যানেল এবং সংশ্লিষ্ট FCM বিষয়ে বার্তা পাঠাতে পারেন। যখন পর্যাপ্ত ব্যবহারকারীরা অ্যাপের পার্স-অনলি সংস্করণ থেকে স্থানান্তরিত হয়, আপনি সেই সংস্করণটি সানসেট করতে পারেন এবং শুধুমাত্র FCM ব্যবহার করে পাঠানো শুরু করতে পারেন।

আরও জানতে FCM বিষয়ের ডক্স দেখুন।

Firebase Remote Config

Firebase Remote Config হল একটি ক্লাউড পরিষেবা যা আপনাকে ব্যবহারকারীদের একটি অ্যাপ আপডেট ডাউনলোড করার প্রয়োজন ছাড়াই আপনার অ্যাপের আচরণ এবং চেহারা পরিবর্তন করতে দেয়। রিমোট কনফিগ ব্যবহার করার সময়, আপনি অ্যাপ-মধ্যস্থ ডিফল্ট মান তৈরি করেন যা আপনার অ্যাপের আচরণ এবং চেহারা নিয়ন্ত্রণ করে। তারপরে, আপনি পরবর্তীতে সমস্ত অ্যাপ ব্যবহারকারীদের জন্য বা আপনার ইউজারবেসের অংশগুলির জন্য অ্যাপ-মধ্যস্থ ডিফল্ট মানগুলিকে ওভাররাইড করতে Firebase কনসোল ব্যবহার করতে পারেন।

Firebase Remote Config আপনার মাইগ্রেশনের সময় খুব দরকারী হতে পারে যেখানে আপনি বিভিন্ন সমাধান পরীক্ষা করতে চান এবং গতিশীলভাবে আরও ক্লায়েন্টকে ভিন্ন প্রদানকারীর কাছে স্থানান্তর করতে সক্ষম হন। উদাহরণস্বরূপ, যদি আপনার অ্যাপের এমন একটি সংস্করণ থাকে যা ডেটার জন্য Firebase এবং ��ার্স উভয়ই ব্যবহার করে, তাহলে আপনি Firebase থেকে কোন ক্লায়েন্ট পড়বেন তা নির্ধারণ করতে একটি র্যান্ডম পার্সেন্টাইল নিয়ম ব্যবহার করতে পারেন এবং ধীরে ধীরে শতাংশ বাড়াতে পারেন।

Firebase Remote Config সম্পর্কে আরও জানতে, Remote Config ভূমিকা দেখুন।

পার্স কনফিগারেশনের সাথে পার্থক্য

পার্স কনফিগারেশনের মাধ্যমে আপনি পার্স কনফিগার ড্যাশবোর্ডে আপনার অ্যাপে কী/মান জোড়া যোগ করতে পারেন এবং তারপর ক্লায়েন্টে PFConfig আনতে পারেন। প্রতিটি PFConfig উদাহরণ যা আপনি পান তা সর্বদা অপরিবর্তনীয়। আপনি যখন নেটওয়ার্ক থেকে ভবিষ্যতে একটি নতুন PFConfig পুনরুদ্ধার করবেন, এটি কোনো বিদ্যমান PFConfig দৃষ্টান্ত পরিবর্তন করবে না, বরং একটি নতুন তৈরি করবে এবং এটি currentConfig এর মাধ্যমে উপলব্ধ করবে।

Firebase Remote Config সাহায্যে আপনি কী/মান জোড়ার জন্য অ্যাপ-মধ্যস্থ ডিফল্ট তৈরি করেন যা আপনি Firebase কনসোল থেকে ওভাররাইড করতে পারেন এবং আপনি আপনার ব্যবহারকারীর বিভিন্ন বিভাগে আপনার অ্যাপের ব্যবহারকারীর অভিজ্ঞতার ভিন্নতা প্রদান করতে নিয়ম ও শর্তাবলী ব্যবহার করতে পারেন। Firebase Remote Config একটি সিঙ্গলটন ক্লাস প্রয়োগ করে যা আপনার অ্যাপে কী/মান জোড়া উপলব্ধ করে। প্রাথমিকভাবে সিঙ্গেলটন ডিফল্ট মানগুলি প্রদান করে যা আপনি অ্যাপ-এর মধ্যে সংজ্ঞায়িত করেন। আপনি আপনার অ্যাপের জন্য সুবিধাজনক যেকোনো মুহূর্তে সার্ভার থেকে মানগুলির একটি নতুন সেট আনতে পারেন; নতুন সেটটি সফলভাবে আনার পরে, অ্যাপে নতুন মানগুলি উপলব্ধ করতে আপনি কখন এটি সক্রিয় করবেন তা চয়ন করতে পারেন৷

প্রস্তাবিত মাইগ্রেশন কৌশল

আপনি Firebase কনসোলে আপনার পার্স কনফিগারের কী/মান জোড়া অনুলিপি করে Firebase Remote Config যেতে পারেন এবং তারপরে Firebase Remote Config ব্যবহার করে এমন অ্যাপের একটি নতুন সংস্করণ স্থাপন করে।

আপনি যদি পার্স কনফিগ এবং Firebase Remote Config উভয়ের সাথে পরীক্ষা করতে চান তবে আপনি অ্যাপটির একটি নতুন সংস্করণ স্থাপন করতে পারেন যা উভয় SDK ব্যবহার করে যতক্ষণ না পর্যাপ্ত ব্যবহারকারীরা শুধুমাত্র পার্স সংস্করণ থেকে স্থানান্তরিত হয়।

কোড তুলনা

পার্স

[PFConfig getConfigInBackgroundWithBlock:^(PFConfig *config, NSError *error) {
  if (!error) {
    NSLog(@"Yay! Config was fetched from the server.");
  } else {
    NSLog(@"Failed to fetch. Using Cached Config.");
    config = [PFConfig currentConfig];
  }

  NSString *welcomeMessage = config[@"welcomeMessage"];
  if (!welcomeMessage) {
    NSLog(@"Falling back to default message.");
    welcomeMessage = @"Welcome!";
  }
}];

ফায়ারবেস

FIRRemoteConfig remoteConfig = [FIRRemoteConfig remoteConfig];
// Set defaults from a plist file
[remoteConfig setDefaultsFromPlistFileName:@"RemoteConfigDefaults"];

[remoteConfig fetchWithCompletionHandler:^(FIRRemoteConfigFetchStatus status, NSError *error) {
  if (status == FIRRemoteConfigFetchStatusSuccess) {
    NSLog(@"Yay! Config was fetched from the server.");
    // Once the config is successfully fetched it must be activated before newly fetched
    // values are returned.
    [self.remoteConfig activateFetched];
  } else {
    NSLog(@"Failed to fetch. Using last fetched or default.");
  }
}];

// ...

// When this is called, the value of the latest fetched and activated config is returned;
// if there's none, the default value is returned.
NSString welcomeMessage = remoteConfig[@"welcomeMessage"].stringValue;