Проверка электронной почты Firebase всегда возвращает ложного пользователя, не подтвержденного. IOS - PullRequest
0 голосов
/ 31 октября 2018

Я выполняю проверку электронной почты через Firebase, но когда пользователь получил электронное письмо, оно перенаправляет его в приложение, и это нормально. Когда я пытаюсь войти с подтвержденным адресом электронной почты Auth.auth().currentUser?.isEmailVerified, всегда возвращайте false. Ниже мой код:

class ViewController: UIViewController {

@IBOutlet weak var emailTextField: UITextField!
@IBOutlet weak var signInBtn: UIButton!
var link: String!

override func viewDidLoad() {
    super.viewDidLoad()
    if let link = UserDefaults.standard.value(forKey: "Link") as? String{
        self.link = link
        signInBtn.isEnabled = true
    }
}

override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
    self.view.endEditing(true)
}

@IBAction func didTapSignInWithEmailLink(_ sender: AnyObject) {
    if let email = self.emailTextField.text {
        Auth.auth().signIn(withEmail: email, link: self.link) { (user, error) in
            if let error = error {
                print("\(error.localizedDescription)")
                return
            }
        }
    } else {
        print("Email can't be empty")
    }

    print(Auth.auth().currentUser?.email)
    if Auth.auth().currentUser?.isEmailVerified == true {
        print("User verified")
    } else {
        print("User not verified")
    }

}
@IBAction func didTapSendSignInLink(_ sender: AnyObject) {
    if let email = emailTextField.text {
        let actionCodeSettings = ActionCodeSettings()
        actionCodeSettings.url = URL(string: "https://example.firebaseapp.com")

        // The sign-in operation has to always be completed in the app.
        actionCodeSettings.handleCodeInApp = true
        actionCodeSettings.setIOSBundleID(Bundle.main.bundleIdentifier!)
        actionCodeSettings.setAndroidPackageName("com.example.android",
                                                 installIfNotAvailable: false, minimumVersion: "12")
        Auth.auth().sendSignInLink(toEmail: email, actionCodeSettings: actionCodeSettings) { error in
            if let error = error {
                print("\(error.localizedDescription)")
                return
            }
            print("Check your email for link")
        }
    } else {
        print("Email cant be empty")
    }
}
override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}


}

1 Ответ

0 голосов
/ 14 декабря 2018

Я нашел решение, которое нам нужно для перезагрузки пользователя, которое обновит текущий статус пользователя. Вызвать Auth.auth.currentUser.reload в кнопке didTapSignInWithEmailLink func:

Auth.auth().currentUser?.reload(completion: { (error) in
            if error == nil{
                if let email = self.emailTextField.text {
                    Auth.auth().signIn(withEmail: email, link: self.link) { (user, error) in
                        if let error = error {
                            print("\(error.localizedDescription)")
                            return
                        }
                    }
                } else {
                    print("Email can't be empty")
                }

                print(Auth.auth().currentUser?.email)
                if Auth.auth().currentUser?.isEmailVerified == true {
                    print("User verified")
                } else {
                    print("User not verified")
                }
            } else {
                print(error?.localizedDescription)
            }
        })
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...