我正在浏览Google的示例应用程序Friendly Pix的iOS源代码,并注意到我不了解他们使用的登录逻辑。具体来说,在他们的AppDelegate.swift
代码(完整源代码here)中,他们使用以下方法设置授权属性:
let authUI = FUIAuth.defaultAuthUI()
authUI?.delegate = self
authUI?.tosurl = kFirebaseTermsOfService
authUI?.isSignInWithEmailHidden = true
let providers: [FUIAuthProvider] = [FUIGoogleAuth(), FUIFacebookAuth()]
authUI?.providers = providers
之后,他们通过最终调用此方法来处理登录回调:
func handleOpenUrl(_ url: URL, sourceApplication: String?) -> Bool {
if FUIAuth.defaultAuthUI()?.handleOpen(url, sourceApplication: sourceApplication) ?? false {
return true
}
return GIDSignIn.sharedInstance().handle(url, sourceApplication: sourceApplication, annotation: nil)
}
这让我想到了一个问题:他们为什么叫GIDSignIn.sharedInstance().handle(...)
?由于FUIGoogleAuth()
是FUIAuth.defaultAuthUI()
的供应商之一,所以FUIAuth.defaultAuthUI()?.handleOpen(...)
不会在内部处理任何Google登录吗?在什么情况下handle()
方法的GIDSignIn
通过调用handleOpen()
的FUIAuth
方法做任何尚未完成的事情?
我或许这是为了处理FUIAuth.defaultAuthUI()
可以返回nil
的可能性,但是,如果发生这种情况,我认为应用程序不会进展到这么远,因为触发回调的身份验证是:
let authViewController = FUIAuth.defaultAuthUI()?.authViewController()
authViewController?.navigationBar.isHidden = true
self.present(authViewController!, animated: true, completion: nil)
如果authViewController
是nil
(如果FUIAuth.defaultAuthUI()
返回nil
会发生),这会在最后一行崩溃。
我使用的是现已弃用的Firebase邀请,但它不接受Firebase Auth令牌。我正在更新代码,应该很快就会出来。