আপনার iOS অ্যাপে মাল্টি-ফ্যাক্টর প্রমাণীকরণ যোগ করুন

আপনি যদি আইডেন্টিটি প্ল্যাটফর্মের সাথে Firebase প্রমাণীকরণে আপগ্রেড করে থাকেন, তাহলে আপনি আপনার iOS অ্যাপে SMS মাল্টি-ফ্যাক্টর প্রমাণীকরণ যোগ করতে পারেন।

মাল্টি-ফ্যাক্টর প্রমাণীকরণ আপনার অ্যাপের নিরাপত্তা বাড়ায়। যদিও আক্রমণকারীরা প্রায়শই পাসওয়ার্ড এবং সামাজিক অ্যাকাউন্টগুলির সাথে আপস করে, একটি পাঠ্য বার্তা আটকানো আরও কঠিন।

তুমি শুরু করার আগে

  1. মাল্টি-ফ্যাক্টর প্রমাণীকরণ সমর্থন করে এমন অন্তত একটি প্রদানকারী সক্ষম করুন৷ ফোন প্রমাণীকরণ, বেনামী প্রমাণীকরণ এবং Apple গেম সেন্টার ছাড়া প্রতিটি প্রদানকারী MFA সমর্থন করে।

  2. আপনার অ্যাপ ব্যবহারকারীর ইমেল যাচাই করছে তা নিশ্চিত করুন। MFA-এর ইমেল যাচাইকরণ প্রয়োজন। এটি ক্ষতিকারক অভিনেতাদের তাদের মালিকানাধীন নয় এমন একটি ইমেল দিয়ে পরিষেবার জন্য নিবন্ধন করতে এবং তারপরে একটি দ্বিতীয় ফ্যাক্টর যোগ করে প্রকৃত মালিককে লক আউট করতে বাধা দেয়৷

মাল্টি-ফ্যাক্টর প্রমাণীকরণ সক্ষম করা হচ্ছে

  1. Firebase কনসোলের প্রমাণীকরণ > সাইন-ইন পদ্ধতি পৃষ্ঠা খুলুন।

  2. উন্নত বিভাগে, এসএমএস মাল্টি-ফ্যাক্টর প্রমাণীকরণ সক্ষম করুন।

    আপনি যে ফোন নম্বরগুলি দিয়ে আপনার অ্যাপটি পরীক্ষা করবেন সেগুলিও আপনার লিখতে হবে৷ ঐচ্ছিক হলেও, ডেভেলপমেন্টের সময় থ্রটলিং এড়াতে পরীক্ষার ফোন নম্বর নিবন্ধন করার দৃঢ়ভাবে সুপারিশ করা হয়।

  3. আপনি যদি ইতিমধ্যে আপনার অ্যাপের ডোমেন অনুমোদন না করে থাকেন, তাহলে Firebase কনসোলের প্রমাণীকরণ > সেটিংস পৃষ্ঠায় অনুমতি তালিকায় এটি যোগ করুন।

আপনার অ্যাপ যাচাই করা হচ্ছে

Firebase কে যাচাই করতে হবে যে আপনার অ্যাপ থেকে SMS অনুরোধ আসছে। আপনি এটি দুটি উপায়ে করতে পারেন:

  • নীরব APN-এর বিজ্ঞপ্তি : আপনি যখন প্রথমবার কোনো ব্যবহারকারীকে সাইন ইন করেন, তখন Firebase ব্যবহারকারীর ডিভাইসে একটি নীরব পুশ বিজ্ঞপ্তি পাঠাতে পারে। অ্যাপটি বিজ্ঞপ্তি পেলে প্রমাণীকরণ এগিয়ে যেতে পারে। মনে রাখবেন যে iOS 8.0 থেকে শুরু করে, আপনাকে এই পদ্ধতিটি ব্যবহার করার জন্য পুশ বিজ্ঞপ্তিগুলিকে অনুমতি দেওয়ার জন্য ব্যবহারকারীকে বলার দরকার নেই৷

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

নীরব বিজ্ঞপ্তি ব্যবহার করে

Firebase-এর সাথে ব্যবহারের জন্য APN-এর বিজ্ঞপ্তি সক্ষম করতে:

  1. এক্সকোডে, আপনার প্রকল্পের জন্য পুশ বিজ্ঞপ্তিগুলি সক্ষম করুন

  2. Firebase কনসোল ব্যবহার করে আপনার APN-এর প্রমাণীকরণ কী আপলোড করুন (আপনার পরিবর্তনগুলি স্বয়ংক্রিয়ভাবে Google ক্লাউড ফায়ারবেসে নিয়ে যাবে)। যদি আপনার কাছে ইতিমধ্যেই আপনার APN-এর প্রমাণীকরণ কী না থাকে, তাহলে এটি কীভাবে পেতে হয় তা শিখতে FCM-এর সাথে APN কনফিগার করা দেখুন।

    1. ফায়ারবেস কনসোল খুলুন।

    2. প্রজেক্ট সেটিংসে নেভিগেট করুন।

    3. ক্লাউড মেসেজিং ট্যাবটি নির্বাচন করুন।

    4. APNs প্রমাণীকরণ কী-এর অধীনে, iOS অ্যাপ কনফিগারেশন বিভাগে, আপলোড ক্লিক করুন।

    5. আপনার কী নির্বাচন করুন.

    6. কীটির জন্য কী আইডি যোগ করুন। আপনি Apple বিকাশকারী সদস্য কেন্দ্রে সার্টিফিকেট, শনাক্তকারী এবং প্রোফাইলের অধীনে কী আইডি খুঁজে পেতে পারেন।

    7. আপলোড ক্লিক করুন।

আপনার যদি ইতিমধ্যেই একটি APNs শংসাপত্র থাকে, তাহলে আপনি পরিবর্তে শংসাপত্রটি আপলোড করতে পারেন৷

reCAPTCHA যাচাইকরণ ব্যবহার করা হচ্ছে

ক্লায়েন্ট SDK কে reCAPTCHA ব্যবহার করতে সক্ষম করতে:

  1. Xcode এ আপনার প্রকল্প কনফিগারেশন খুলুন।

  2. বাম ট্রি ভিউতে প্রকল্পের নামে ডাবল-ক্লিক করুন।

  3. লক্ষ্য বিভাগ থেকে আপনার অ্যাপ্লিকেশন নির্বাচন করুন.

  4. তথ্য ট্যাব নির্বাচন করুন.

  5. URL প্রকার বিভাগ প্রসারিত করুন।

  6. + বোতামে ক্লিক করুন।

  7. URL স্কিম ক্ষেত্রে আপনার বিপরীত ক্লায়েন্ট আইডি লিখুন। আপনি GoogleService-Info.plist কনফিগারেশন ফাইলে REVERSED_CLIENT_ID হিসাবে তালিকাভুক্ত এই মানটি খুঁজে পেতে পারেন।

সম্পূর্ণ হলে, আপনার কনফিগারেশন নিম্নলিখিত অনুরূপ দেখতে হবে:

কাস্টম স্কিম

ঐচ্ছিকভাবে, reCAPTCHA প্রদর্শন করার সময় আপনি আপনার অ্যাপটি SFSafariViewController বা UIWebView উপস্থাপন করার উপায় কাস্টমাইজ করতে পারেন। এটি করার জন্য, একটি কাস্টম ক্লাস তৈরি করুন যা FIRAuthUIDelegate প্রোটোকলের সাথে সামঞ্জস্যপূর্ণ, এবং এটিকে verifyPhoneNumber:UIDelegate:completion: করতে পাস করুন।

একটি তালিকাভুক্তি প্যাটার্ন নির্বাচন

আপনার অ্যাপের মাল্টি-ফ্যাক্টর প্রমাণীকরণ প্রয়োজন কিনা এবং কীভাবে এবং কখন আপনার ব্যবহারকারীদের নথিভুক্ত করবেন তা আপনি চয়ন করতে পারেন। কিছু সাধারণ নিদর্শন অন্তর্ভুক্ত:

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

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

  • সাইন আপ স্ক্রীনের পরিবর্তে ব্যবহারকারীর অ্যাকাউন্ট বা প্রোফাইল ব্যবস্থাপনা পৃষ্ঠা থেকে একটি দ্বিতীয় ফ্যাক্টর যোগ করার ক্ষমতা প্রদান করুন। নিরাপত্তা-সংবেদনশীল ব্যবহারকারীদের জন্য মাল্টি-ফ্যাক্টর প্রমাণীকরণ উপলব্ধ করার সময় এটি নিবন্ধকরণ প্রক্রিয়ার সময় ঘর্ষণকে কমিয়ে দেয়।

  • ব্যবহারকারী যখন বর্ধিত সুরক্ষা প্রয়োজনীয়তা সহ বৈশিষ্ট্যগুলি অ্যাক্সেস করতে চায় তখন ক্রমবর্ধমানভাবে একটি দ্বিতীয় ফ্যাক্টর যোগ করা প্রয়োজন৷

একটি দ্বিতীয় ফ্যাক্টর নথিভুক্ত করা

একজন ব্যবহারকারীর জন্য একটি নতুন সেকেন্ডারি ফ্যাক্টর নথিভুক্ত করতে:

  1. ব্যবহারকারীকে পুনরায় প্রমাণীকরণ করুন।

  2. ব্যবহারকারীকে তাদের ফোন নম্বর লিখতে বলুন।

  3. ব্যবহারকারীর জন্য একটি মাল্টি-ফ্যাক্টর সেশন পান:

    সুইফট

    authResult.user.multiFactor.getSessionWithCompletion() { (session, error) in
      // ...
    }
    

    উদ্দেশ্য গ

    [authResult.user.multiFactor
      getSessionWithCompletion:^(FIRMultiFactorSession * _Nullable session,
                                NSError * _Nullable error) {
        // ...
    }];
    
  4. ব্যবহারকারীর ফোনে একটি যাচাইকরণ বার্তা পাঠান। নিশ্চিত করুন যে ফোন নম্বরটি একটি লিডিং + দিয়ে ফরম্যাট করা হয়েছে এবং অন্য কোনও বিরাম চিহ্ন বা হোয়াইটস্পেস নেই (উদাহরণস্বরূপ: +15105551234 )

    সুইফট

    // Send SMS verification code.
    PhoneAuthProvider.provider().verifyPhoneNumber(
      phoneNumber,
      uiDelegate: nil,
      multiFactorSession: session) { (verificationId, error) in
        // verificationId will be needed for enrollment completion.
    }
    

    উদ্দেশ্য গ

    // Send SMS verification code.
    [FIRPhoneAuthProvider.provider verifyPhoneNumber:phoneNumber
                                          UIDelegate:nil
                                  multiFactorSession:session
                                          completion:^(NSString * _Nullable verificationID,
                                                        NSError * _Nullable error) {
        // verificationId will be needed for enrollment completion.
    }];
    

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

    verifyPhoneNumber() পদ্ধতিটি সাইলেন্ট পুশ নোটিফিকেশন ব্যবহার করে ব্যাকগ্রাউন্ডে অ্যাপ যাচাইকরণ প্রক্রিয়া শুরু করে। যদি সাইলেন্ট পুশ নোটিফিকেশন পাওয়া না যায়, তাহলে এর পরিবর্তে একটি reCAPTCHA চ্যালেঞ্জ জারি করা হয়।

  5. একবার এসএমএস কোড পাঠানো হলে, ব্যবহারকারীকে কোডটি যাচাই করতে বলুন। তারপর, একটি PhoneAuthCredential তৈরি করতে তাদের প্রতিক্রিয়া ব্যবহার করুন:

    সুইফট

    // Ask user for the verification code. Then:
    let credential = PhoneAuthProvider.provider().credential(
      withVerificationID: verificationId,
      verificationCode: verificationCode)
    

    উদ্দেশ্য গ

    // Ask user for the SMS verification code. Then:
    FIRPhoneAuthCredential *credential = [FIRPhoneAuthProvider.provider
                                           credentialWithVerificationID:verificationID
                                           verificationCode:kPhoneSecondFactorVerificationCode];
    
  6. একটি দাবী বস্তু শুরু করুন:

    সুইফট

    let assertion = PhoneMultiFactorGenerator.assertion(with: credential)
    

    উদ্দেশ্য গ

    FIRMultiFactorAssertion *assertion = [FIRPhoneMultiFactorGenerator assertionWithCredential:credential];
    
  7. তালিকাভুক্তি সম্পূর্ণ করুন। ঐচ্ছিকভাবে, আপনি দ্বিতীয় ফ্যাক্টরের জন্য একটি প্রদর্শন নাম উল্লেখ করতে পারেন। এটি একাধিক সেকেন্ড ফ্যাক্টর সহ ব্যবহারকারীদের জন্য দরকারী, যেহেতু প্রমাণীকরণ প্রবাহের সময় ফোন নম্বরটি মাস্ক করা হয় (উদাহরণস্বরূপ, +1******1234)।

    সুইফট

    // Complete enrollment. This will update the underlying tokens
    // and trigger ID token change listener.
    user.multiFactor.enroll(with: assertion, displayName: displayName) { (error) in
      // ...
    }
    

    উদ্দেশ্য গ

    // Complete enrollment. This will update the underlying tokens
    // and trigger ID token change listener.
    [authResult.user.multiFactor enrollWithAssertion:assertion
                                         displayName:nil
                                          completion:^(NSError * _Nullable error) {
        // ...
    }];
    

নীচের কোডটি দ্বিতীয় ফ্যাক্টর নথিভুক্ত করার একটি সম্পূর্ণ উদাহরণ দেখায়:

সুইফট

let user = Auth.auth().currentUser
user?.multiFactor.getSessionWithCompletion({ (session, error) in
  // Send SMS verification code.
  PhoneAuthProvider.provider().verifyPhoneNumber(
    phoneNumber,
    uiDelegate: nil,
    multiFactorSession: session
  ) { (verificationId, error) in
    // verificationId will be needed for enrollment completion.
    // Ask user for the verification code.
    let credential = PhoneAuthProvider.provider().credential(
      withVerificationID: verificationId!,
      verificationCode: phoneSecondFactorVerificationCode)
    let assertion = PhoneMultiFactorGenerator.assertion(with: credential)
    // Complete enrollment. This will update the underlying tokens
    // and trigger ID token change listener.
    user?.multiFactor.enroll(with: assertion, displayName: displayName) { (error) in
      // ...
    }
  }
})

উদ্দেশ্য গ

FIRUser *user = FIRAuth.auth.currentUser;
[user.multiFactor getSessionWithCompletion:^(FIRMultiFactorSession * _Nullable session,
                                              NSError * _Nullable error) {
    // Send SMS verification code.
    [FIRPhoneAuthProvider.provider
      verifyPhoneNumber:phoneNumber
      UIDelegate:nil
      multiFactorSession:session
      completion:^(NSString * _Nullable verificationID, NSError * _Nullable error) {
        // verificationId will be needed for enrollment completion.

        // Ask user for the verification code.
        // ...

        // Then:
        FIRPhoneAuthCredential *credential =
            [FIRPhoneAuthProvider.provider credentialWithVerificationID:verificationID
                                                        verificationCode:kPhoneSecondFactorVerificationCode];
        FIRMultiFactorAssertion *assertion =
            [FIRPhoneMultiFactorGenerator assertionWithCredential:credential];

        // Complete enrollment. This will update the underlying tokens
        // and trigger ID token change listener.
        [user.multiFactor enrollWithAssertion:assertion
                                  displayName:displayName
                                    completion:^(NSError * _Nullable error) {
            // ...
        }];
    }];
}];

অভিনন্দন! আপনি সফলভাবে একজন ব্যবহারকারীর জন্য একটি দ্বিতীয় প্রমাণীকরণ ফ্যাক্টর নিবন্ধন করেছেন।

একটি দ্বিতীয় ফ্যাক্টর সহ ব্যবহারকারীদের সাইন ইন করা

দুই-ফ্যাক্টর এসএমএস যাচাইকরণের মাধ্যমে একজন ব্যবহারকারীকে সাইন ইন করতে:

  1. ব্যবহারকারীকে তাদের প্রথম ফ্যাক্টর দিয়ে সাইন ইন করুন, তারপর মাল্টি-ফ্যাক্টর প্রমাণীকরণের প্রয়োজনীয়তা নির্দেশ করে একটি ত্রুটি ধরুন। এই ত্রুটিটিতে একটি সমাধানকারী, নথিভুক্ত দ্বিতীয় কারণগুলির উপর ইঙ্গিত এবং একটি অন্তর্নিহিত অধিবেশন রয়েছে যা প্রমাণ করে যে ব্যবহারকারী প্রথম ফ্যাক্টরের সাথে সফলভাবে প্রমাণীকৃত হয়েছে৷

    উদাহরণস্বরূপ, যদি ব্যবহারকারীর প্রথম ফ্যাক্টরটি একটি ইমেল এবং পাসওয়ার্ড হয়:

    সুইফট

    Auth.auth().signIn(
      withEmail: email,
      password: password
    ) { (result, error) in
      let authError = error as NSError
      if authError?.code == AuthErrorCode.secondFactorRequired.rawValue {
        // The user is a multi-factor user. Second factor challenge is required.
        let resolver =
          authError!.userInfo[AuthErrorUserInfoMultiFactorResolverKey] as! MultiFactorResolver
        // ...
      } else {
        // Handle other errors such as wrong password.
      }
    }
    

    উদ্দেশ্য গ

    [FIRAuth.auth signInWithEmail:email
                         password:password
                       completion:^(FIRAuthDataResult * _Nullable authResult,
                                    NSError * _Nullable error) {
        if (error == nil || error.code != FIRAuthErrorCodeSecondFactorRequired) {
            // User is not enrolled with a second factor and is successfully signed in.
            // ...
        } else {
            // The user is a multi-factor user. Second factor challenge is required.
        }
    }];
    

    যদি ব্যবহারকারীর প্রথম ফ্যাক্টরটি একটি ফেডারেটেড প্রদানকারী হয়, যেমন OAuth, তাহলে getCredentialWith() কল করার পরে ত্রুটিটি ধরুন।

  2. ব্যবহারকারীর একাধিক সেকেন্ডারি ফ্যাক্টর নথিভুক্ত থাকলে, কোনটি ব্যবহার করতে হবে তাদের জিজ্ঞাসা করুন। আপনি resolver.hints[selectedIndex].phoneNumber সহ মাস্ক করা ফোন নম্বর এবং resolver.hints[selectedIndex].displayName সহ ডিসপ্লে নাম পেতে পারেন।

    সুইফট

    // Ask user which second factor to use. Then:
    if resolver.hints[selectedIndex].factorID == PhoneMultiFactorID {
      // User selected a phone second factor.
      // ...
    } else if resolver.hints[selectedIndex].factorID == TotpMultiFactorID {
      // User selected a TOTP second factor.
      // ...
    } else {
      // Unsupported second factor.
    }
    

    উদ্দেশ্য গ

    FIRMultiFactorResolver *resolver =
        (FIRMultiFactorResolver *) error.userInfo[FIRAuthErrorUserInfoMultiFactorResolverKey];
    
    // Ask user which second factor to use. Then:
    FIRPhoneMultiFactorInfo *hint = (FIRPhoneMultiFactorInfo *) resolver.hints[selectedIndex];
    if (hint.factorID == FIRPhoneMultiFactorID) {
      // User selected a phone second factor.
      // ...
    } else if (hint.factorID == FIRTOTPMultiFactorID) {
      // User selected a TOTP second factor.
      // ...
    } else {
      // Unsupported second factor.
    }
    
  3. ব্যবহারকারীর ফোনে একটি যাচাইকরণ বার্তা পাঠান:

    সুইফট

    // Send SMS verification code.
    let hint = resolver.hints[selectedIndex] as! PhoneMultiFactorInfo
    PhoneAuthProvider.provider().verifyPhoneNumber(
      with: hint,
      uiDelegate: nil,
      multiFactorSession: resolver.session
    ) { (verificationId, error) in
      // verificationId will be needed for sign-in completion.
    }
    

    উদ্দেশ্য গ

    // Send SMS verification code
    [FIRPhoneAuthProvider.provider
      verifyPhoneNumberWithMultiFactorInfo:hint
      UIDelegate:nil
      multiFactorSession:resolver.session
      completion:^(NSString * _Nullable verificationID, NSError * _Nullable error) {
        if (error != nil) {
            // Failed to verify phone number.
        }
    }];
    
  4. একবার এসএমএস কোড পাঠানো হলে, ব্যবহারকারীকে কোডটি যাচাই করতে বলুন এবং এটি একটি PhoneAuthCredential তৈরি করতে ব্যবহার করুন:

    সুইফট

    // Ask user for the verification code. Then:
    let credential = PhoneAuthProvider.provider().credential(
      withVerificationID: verificationId!,
      verificationCode: verificationCodeFromUser)
    

    উদ্দেশ্য গ

    // Ask user for the SMS verification code. Then:
    FIRPhoneAuthCredential *credential =
        [FIRPhoneAuthProvider.provider
          credentialWithVerificationID:verificationID
                      verificationCode:verificationCodeFromUser];
    
  5. শংসাপত্রের সাথে একটি দাবী অবজেক্ট শুরু করুন:

    সুইফট

    let assertion = PhoneMultiFactorGenerator.assertion(with: credential)
    

    উদ্দেশ্য গ

    FIRMultiFactorAssertion *assertion =
        [FIRPhoneMultiFactorGenerator assertionWithCredential:credential];
    
  6. সাইন-ইন সমাধান করুন। তারপরে আপনি আসল সাইন-ইন ফলাফল অ্যাক্সেস করতে পারেন, যার মধ্যে স্ট্যান্ডার্ড প্রদানকারী-নির্দিষ্ট ডেটা এবং প্রমাণীকরণ শংসাপত্র রয়েছে:

    সুইফট

    // Complete sign-in. This will also trigger the Auth state listeners.
    resolver.resolveSignIn(with: assertion) { (authResult, error) in
      // authResult will also contain the user, additionalUserInfo, optional
      // credential (null for email/password) associated with the first factor sign-in.
    
      // For example, if the user signed in with Google as a first factor,
      // authResult.additionalUserInfo will contain data related to Google provider that
      // the user signed in with.
    
      // user.credential contains the Google OAuth credential.
      // user.credential.accessToken contains the Google OAuth access token.
      // user.credential.idToken contains the Google OAuth ID token.
    }
    

    উদ্দেশ্য গ

    // Complete sign-in.
    [resolver resolveSignInWithAssertion:assertion
                              completion:^(FIRAuthDataResult * _Nullable authResult,
                                            NSError * _Nullable error) {
        if (error != nil) {
            // User successfully signed in with the second factor phone number.
        }
    }];
    

নীচের কোডটি একটি মাল্টি-ফ্যাক্টর ব্যবহারকারী সাইন ইন করার একটি সম্পূর্ণ উদাহরণ দেখায়:

সুইফট

Auth.auth().signIn(
  withEmail: email,
  password: password
) { (result, error) in
  let authError = error as NSError?
  if authError?.code == AuthErrorCode.secondFactorRequired.rawValue {
    let resolver =
      authError!.userInfo[AuthErrorUserInfoMultiFactorResolverKey] as! MultiFactorResolver

    // Ask user which second factor to use.
    // ...

    // Then:
    let hint = resolver.hints[selectedIndex] as! PhoneMultiFactorInfo

    // Send SMS verification code
    PhoneAuthProvider.provider().verifyPhoneNumber(
      with: hint,
      uiDelegate: nil,
      multiFactorSession: resolver.session
    ) { (verificationId, error) in
      if error != nil {
        // Failed to verify phone number.
      }
      // Ask user for the SMS verification code.
      // ...

      // Then:
      let credential = PhoneAuthProvider.provider().credential(
        withVerificationID: verificationId!,
        verificationCode: verificationCodeFromUser)
      let assertion = PhoneMultiFactorGenerator.assertion(with: credential)

      // Complete sign-in.
      resolver.resolveSignIn(with: assertion) { (authResult, error) in
        if error != nil {
          // User successfully signed in with the second factor phone number.
        }
      }
    }
  }
}

উদ্দেশ্য গ

[FIRAuth.auth signInWithEmail:email
                     password:password
                   completion:^(FIRAuthDataResult * _Nullable authResult,
                               NSError * _Nullable error) {
    if (error == nil || error.code != FIRAuthErrorCodeSecondFactorRequired) {
        // User is not enrolled with a second factor and is successfully signed in.
        // ...
    } else {
        FIRMultiFactorResolver *resolver =
            (FIRMultiFactorResolver *) error.userInfo[FIRAuthErrorUserInfoMultiFactorResolverKey];

        // Ask user which second factor to use.
        // ...

        // Then:
        FIRPhoneMultiFactorInfo *hint = (FIRPhoneMultiFactorInfo *) resolver.hints[selectedIndex];

        // Send SMS verification code
        [FIRPhoneAuthProvider.provider
          verifyPhoneNumberWithMultiFactorInfo:hint
                                    UIDelegate:nil
                            multiFactorSession:resolver.session
                                    completion:^(NSString * _Nullable verificationID,
                                                NSError * _Nullable error) {
            if (error != nil) {
                // Failed to verify phone number.
            }

            // Ask user for the SMS verification code.
            // ...

            // Then:
            FIRPhoneAuthCredential *credential =
                [FIRPhoneAuthProvider.provider
                  credentialWithVerificationID:verificationID
                              verificationCode:kPhoneSecondFactorVerificationCode];
            FIRMultiFactorAssertion *assertion =
                [FIRPhoneMultiFactorGenerator assertionWithCredential:credential];

            // Complete sign-in.
            [resolver resolveSignInWithAssertion:assertion
                                      completion:^(FIRAuthDataResult * _Nullable authResult,
                                                    NSError * _Nullable error) {
                if (error != nil) {
                    // User successfully signed in with the second factor phone number.
                }
            }];
        }];
    }
}];

অভিনন্দন! আপনি মাল্টি-ফ্যাক্টর প্রমাণীকরণ ব্যবহার করে একজন ব্যবহারকারীকে সফলভাবে সাইন ইন করেছেন।

এরপর কি