আইওএসে গুগল সাইন-ইন ব্যবহার করে প্রমাণীকরণ করুন

আপনি আপনার অ্যাপে Google সাইন-ইন সংহত করে আপনার ব্যবহারকারীদের তাদের Google অ্যাকাউন্ট ব্যবহার করে Firebase- এর মাধ্যমে প্রমাণীকরণ করতে পারেন।

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

  1. আপনার iOS প্রকল্পে Firebase যোগ করুন । আপনার নিম্নলিখিত pods অন্তর্ভুক্ত করুন Podfile :
    pod 'Firebase/Auth'
    pod 'GoogleSignIn'
    
  2. আপনি এখনও আপনার Firebase প্রকল্পে আপনার অ্যাপ সংযুক্ত না করে থাকেন, থেকে তা করতে Firebase কনসোল
  3. Firebase কনসোলে Google সাইন-ইন সক্ষম করুন:
    1. ইন Firebase কনসোল , প্রমাণীকরণ অধ্যায় খুলুন।
    2. পদ্ধতি ট্যাবে সাইন অন, গুগল সাইন-ইন পদ্ধতি সক্ষম করতে হবে এবং সংরক্ষণ ক্লিক করুন।

1. প্রয়োজনীয় হেডার ফাইল আমদানি করুন

প্রথমে, আপনাকে অবশ্যই আপনার অ্যাপে Firebase SDK এবং Google সাইন-ইন SDK হেডার ফাইলগুলি আমদানি করতে হবে।

সুইফট

import Firebase
import GoogleSignIn

উদ্দেশ্য গ

@import Firebase;
@import GoogleSignIn;

2. গুগল সাইন-ইন প্রয়োগ করুন

এই ধাপগুলি অনুসরণ করে Google সাইন-ইন বাস্তবায়ন করুন। দেখুন Google সাইন-ইন ডেভেলপার ডকুমেন্টেশন আইওএস সহ Google সাইন-ইন ব্যবহার বিশদ বিবরণের জন্য।

  1. আপনার Xcode প্রকল্পে কাস্টম URL স্কিম যুক্ত করুন:
    1. আপনার প্রকল্প কনফিগারেশন খুলুন: বাম গাছের ভিউতে প্রকল্পের নামটিতে ডাবল ক্লিক করুন। ও লক্ষ্যমাত্রা অধ্যায় থেকে আপনার অ্যাপ্লিকেশন নির্বাচন করুন তারপর তথ্য ট্যাব বাছুন এবং URL প্রকারভেদ অধ্যায় প্রসারিত।
    2. + বোতামে ক্লিক করুন, এবং আপনার বিপরীত ক্লায়েন্ট ID জন্য একটি URL স্কিম যোগ করুন। এই মান খুঁজতে, খুলতে GoogleService-Info.plist কনফিগারেশন ফাইল, এবং বর্ণন REVERSED_CLIENT_ID কী। যে কী মান অনুলিপি করুন, এবং এটি URL টি প্রকল্প কনফিগারেশন পৃষ্ঠাতে বাক্সে আটকে দিন। অন্যান্য ক্ষেত্র খালি রাখুন।

      সম্পন্ন হলে, আপনার কনফিগারেশনটি নিম্নলিখিতগুলির মতো দেখতে হবে (তবে আপনার অ্যাপ্লিকেশন-নির্দিষ্ট মানগুলির সাথে):

  2. আপনার অ্যাপ প্রতিনিধি এর দশকে application:didFinishLaunchingWithOptions: পদ্ধতি, কনফিগার FirebaseApp অবজেক্ট।

    সুইফট

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

    উদ্দেশ্য গ

    // Use Firebase library to configure APIs
    [FIRApp configure];
    
  3. বাস্তবায়ন application:openURL:options: আপনার অ্যাপ্লিকেশন প্রতিনিধি পদ্ধতি। পদ্ধতি কল করা উচিত handleURL পদ্ধতি GIDSignIn উদাহরণস্বরূপ, যা সঠিকভাবে URL রয়েছে যা আপনার আবেদন প্রমাণীকরণ প্রক্রিয়া শেষে পায় হ্যান্ডেল করবে।

    সুইফট

    @available(iOS 9.0, *)
    func application(_ application: UIApplication, open url: URL,
                     options: [UIApplication.OpenURLOptionsKey: Any])
      -> Bool {
      return GIDSignIn.sharedInstance.handle(url)
    }
    

    উদ্দেশ্য গ

    - (BOOL)application:(nonnull UIApplication *)application
                openURL:(nonnull NSURL *)url
                options:(nonnull NSDictionary<NSString *, id> *)options {
      return [[GIDSignIn sharedInstance] handleURL:url];
    }
    
  4. আপনার অ্যাপের জন্য উপস্থাপন ভিউ কন্ট্রোলার এবং ক্লায়েন্ট আইডি গুগল সাইন ইন সাইন-ইন পদ্ধতিতে প্রেরণ করুন এবং ফলস্বরূপ গুগল এথ টোকেন থেকে একটি ফায়ারবেস প্রমাণ শংসাপত্র তৈরি করুন:

    সুইফট

    guard let clientID = FirebaseApp.app()?.options.clientID else { return }
    
    // Create Google Sign In configuration object.
    let config = GIDConfiguration(clientID: clientID)
    
    // Start the sign in flow!
    GIDSignIn.sharedInstance.signIn(with: config, presenting: self) { [unowned self] user, error in
    
      if let error = error {
        // ...
        return
      }
    
      guard
        let authentication = user?.authentication,
        let idToken = authentication.idToken
      else {
        return
      }
    
      let credential = GoogleAuthProvider.credential(withIDToken: idToken,
                                                     accessToken: authentication.accessToken)
    
      // ...
    }
    

    উদ্দেশ্য গ

    GIDConfiguration *config = [[GIDConfiguration alloc] initWithClientID:[FIRApp defaultApp].options.clientID];
    
    __weak __auto_type weakSelf = self;
    [GIDSignIn.sharedInstance signInWithConfiguration:config presentingViewController:self callback:^(GIDGoogleUser * _Nullable user, NSError * _Nullable error) {
      __auto_type strongSelf = weakSelf;
      if (strongSelf == nil) { return; }
    
      if (error == nil) {
        GIDAuthentication *authentication = user.authentication;
        FIRAuthCredential *credential =
        [FIRGoogleAuthProvider credentialWithIDToken:authentication.idToken
                                         accessToken:authentication.accessToken];
        // ...
      } else {
        // ...
      }
    }];
    
    
  5. একটি যোগ করুন GIDSignInButton আপনার স্টোরিবোর্ড, XIB ফাইল, অথবা এটি প্রোগ্রামের মাধ্যমে instantiate। আপনার স্টোরিবোর্ড বা XIB ফাইল বাটন যুক্ত করার জন্য, কোনো দৃশ্য যোগ করতে পারেন এবং তার নিজস্ব শ্রেণী নির্ধারণ GIDSignInButton
  6. ঐচ্ছিক: বোতামটি কাস্টমাইজ করতে চান তাহলে, নিচের কাজগুলো করুন:

    সুইফট

    1. আপনার ভিউ কন্ট্রোলারে, সাইন-ইন বোতামটিকে সম্পত্তি হিসাবে ঘোষণা করুন।
      @IBOutlet weak var signInButton: GIDSignInButton!
    2. বাটন সংযুক্ত করুন signInButton সম্পত্তি আপনি শুধু ঘোষণা করেন।
    3. বৈশিষ্ট্য সেট করে বোতাম কাস্টমাইজ GIDSignInButton অবজেক্ট।

    উদ্দেশ্য গ

    1. আপনার ভিউ কন্ট্রোলারের হেডার ফাইলে, সাইন-ইন বোতামটিকে সম্পত্তি হিসেবে ঘোষণা করুন।
      @property(weak, nonatomic) IBOutlet GIDSignInButton *signInButton;
    2. বাটন সংযুক্ত করুন signInButton সম্পত্তি আপনি শুধু ঘোষণা করেন।
    3. বৈশিষ্ট্য সেট করে বোতাম কাস্টমাইজ GIDSignInButton অবজেক্ট।

3. Firebase দিয়ে প্রমাণীকরণ করুন

অবশেষে, পূর্ববর্তী ধাপে তৈরি করা auth শংসাপত্রের সাথে Firebase লগইন প্রক্রিয়া সম্পন্ন করুন।

সুইফট

Auth.auth().signIn(with: credential) { authResult, error in
    if let error = error {
      let authError = error as NSError
      if isMFAEnabled, authError.code == AuthErrorCode.secondFactorRequired.rawValue {
        // The user is a multi-factor user. Second factor challenge is required.
        let resolver = authError
          .userInfo[AuthErrorUserInfoMultiFactorResolverKey] as! MultiFactorResolver
        var displayNameString = ""
        for tmpFactorInfo in resolver.hints {
          displayNameString += tmpFactorInfo.displayName ?? ""
          displayNameString += " "
        }
        self.showTextInputPrompt(
          withMessage: "Select factor to sign in\n\(displayNameString)",
          completionBlock: { userPressedOK, displayName in
            var selectedHint: PhoneMultiFactorInfo?
            for tmpFactorInfo in resolver.hints {
              if displayName == tmpFactorInfo.displayName {
                selectedHint = tmpFactorInfo as? PhoneMultiFactorInfo
              }
            }
            PhoneAuthProvider.provider()
              .verifyPhoneNumber(with: selectedHint!, uiDelegate: nil,
                                 multiFactorSession: resolver
                                   .session) { verificationID, error in
                if error != nil {
                  print(
                    "Multi factor start sign in failed. Error: \(error.debugDescription)"
                  )
                } else {
                  self.showTextInputPrompt(
                    withMessage: "Verification code for \(selectedHint?.displayName ?? "")",
                    completionBlock: { userPressedOK, verificationCode in
                      let credential: PhoneAuthCredential? = PhoneAuthProvider.provider()
                        .credential(withVerificationID: verificationID!,
                                    verificationCode: verificationCode!)
                      let assertion: MultiFactorAssertion? = PhoneMultiFactorGenerator
                        .assertion(with: credential!)
                      resolver.resolveSignIn(with: assertion!) { authResult, error in
                        if error != nil {
                          print(
                            "Multi factor finanlize sign in failed. Error: \(error.debugDescription)"
                          )
                        } else {
                          self.navigationController?.popViewController(animated: true)
                        }
                      }
                    }
                  )
                }
              }
          }
        )
      } else {
        self.showMessagePrompt(error.localizedDescription)
        return
      }
      // ...
      return
    }
    // User is signed in
    // ...
}

উদ্দেশ্য গ

[[FIRAuth auth] signInWithCredential:credential
                          completion:^(FIRAuthDataResult * _Nullable authResult,
                                       NSError * _Nullable error) {
    if (isMFAEnabled && error && error.code == FIRAuthErrorCodeSecondFactorRequired) {
      FIRMultiFactorResolver *resolver = error.userInfo[FIRAuthErrorUserInfoMultiFactorResolverKey];
      NSMutableString *displayNameString = [NSMutableString string];
      for (FIRMultiFactorInfo *tmpFactorInfo in resolver.hints) {
        [displayNameString appendString:tmpFactorInfo.displayName];
        [displayNameString appendString:@" "];
      }
      [self showTextInputPromptWithMessage:[NSString stringWithFormat:@"Select factor to sign in\n%@", displayNameString]
                           completionBlock:^(BOOL userPressedOK, NSString *_Nullable displayName) {
       FIRPhoneMultiFactorInfo* selectedHint;
       for (FIRMultiFactorInfo *tmpFactorInfo in resolver.hints) {
         if ([displayName isEqualToString:tmpFactorInfo.displayName]) {
           selectedHint = (FIRPhoneMultiFactorInfo *)tmpFactorInfo;
         }
       }
       [FIRPhoneAuthProvider.provider
        verifyPhoneNumberWithMultiFactorInfo:selectedHint
        UIDelegate:nil
        multiFactorSession:resolver.session
        completion:^(NSString * _Nullable verificationID, NSError * _Nullable error) {
          if (error) {
            [self showMessagePrompt:error.localizedDescription];
          } else {
            [self showTextInputPromptWithMessage:[NSString stringWithFormat:@"Verification code for %@", selectedHint.displayName]
                                 completionBlock:^(BOOL userPressedOK, NSString *_Nullable verificationCode) {
             FIRPhoneAuthCredential *credential =
                 [[FIRPhoneAuthProvider provider] credentialWithVerificationID:verificationID
                                                              verificationCode:verificationCode];
             FIRMultiFactorAssertion *assertion = [FIRPhoneMultiFactorGenerator assertionWithCredential:credential];
             [resolver resolveSignInWithAssertion:assertion completion:^(FIRAuthDataResult * _Nullable authResult, NSError * _Nullable error) {
               if (error) {
                 [self showMessagePrompt:error.localizedDescription];
               } else {
                 NSLog(@"Multi factor finanlize sign in succeeded.");
               }
             }];
           }];
          }
        }];
     }];
    }
  else if (error) {
    // ...
    return;
  }
  // User successfully signed in. Get user data from the FIRUser object
  if (authResult == nil) { return; }
  FIRUser *user = authResult.user;
  // ...
}];

পরবর্তী পদক্ষেপ

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

  • আপনার অ্যাপ্লিকেশান, আপনি থেকে ব্যবহারকারীর সাধারণ প্রোফাইল তথ্য পেতে পারেন FIRUser অবজেক্ট। দেখুন ব্যবহারকারীদের পরিচালনা

  • আপনার Firebase রিয়েলটাইম ডাটাবেস এবং ক্লাউড স্টোরেজ সিকিউরিটি রুলস , আপনি পেতে পারেন সাইন ইন থেকে ব্যবহারকারী এর অনন্য ব্যবহারকারী আইডি auth পরিবর্তনশীল, এবং এটি ব্যবহার কোন ডেটা একটি ব্যবহারকারী অ্যাক্সেস করতে পারবেন নিয়ন্ত্রন করতে পারেন।

আপনি ব্যবহারকারীদের দ্বারা একাধিক প্রমাণীকরণ প্রদানকারীর ব্যবহার করে আপনার অ্যাপ্লিকেশানে সাইন ইন করার অনুমতি দিতে পারেন একটি বিদ্যমান ব্যবহারকারীর অ্যাকাউন্টের সাথে প্রমাণীকরণ প্রদানকারী পরিচয়পত্র লিঙ্ক।

একটি ব্যবহারকারী সাইন আউট করতে, কল signOut:

সুইফট

    let firebaseAuth = Auth.auth()
do {
  try firebaseAuth.signOut()
} catch let signOutError as NSError {
  print("Error signing out: %@", signOutError)
}
  

উদ্দেশ্য গ

    NSError *signOutError;
BOOL status = [[FIRAuth auth] signOut:&signOutError];
if (!status) {
  NSLog(@"Error signing out: %@", signOutError);
  return;
}

আপনি প্রমাণীকরণের ত্রুটির সম্পূর্ণ পরিসরের জন্য ত্রুটি পরিচালনা কোড যোগ করতে চাইতে পারেন। দেখুন হাতল ত্রুটি