AWSCognito Auth `getSession` 不会在 Swift 中触发回调

AWSCognito Auth `getSession` does not fire callback in Swift

我对 Swift 有点陌生,但我正在尝试将 AWSCognitoAuth 改编为 Capacitor 的 Swift 插件。我在这里创建了一个回购协议:https://github.com/Kikketer/CapacitorTest

最大的问题之一是 iOS 项目中没有触发回调:

cognitoAuth.getSession(self.bridge.viewController) { (session, err) in
// this is never called after I click the "sign in" button in Cognito
    if(err != nil) {
        NSLog(err.debugDescription)
        call.reject(err.debugDescription)
    } else {
        call.resolve([
            "accessToken": session?.accessToken?.tokenString ?? ""])
    }
}

通过我在自述文件中描述的所有设置,这是亮点:

  1. 我设置了 Cognito 用户池,添加了一个用户,并为其创建了一个应用程序页面
  2. 我引入了最新的 AWSCognito pod(此时为 2.9)
  3. 我为 Capacitor 写了一个插件来弥合差距,但理论上 Capacitor 与此无关,因为它似乎纯粹是 Swift 和本机实现问题:https://github.com/Kikketer/CapacitorTest/blob/master/ios/App/App/CognitoPlugin.swift#L12
  4. 当我单击应用程序中的 "sign in" 按钮时,Cognito 会像它应该的那样在 "special iOS browser" 中启动,但在我单击该浏览器中的登录按钮后,它只是挂在那里。
  5. 除非我单击 "Done",否则永远不会触发回调(在这种情况下,这是一个错误,不会返回任何实际令牌)。

我在任何日志中都没有看到任何明显的错误,所以我不确定下一步该怎么做。

我知道有相当多的设置可以重复这个问题,但我们将不胜感激。

编辑:我做了更仔细的调查,我得到了 405 响应,但页面上没有显示实际的错误消息:

The Server responded with a status of 405
https://[mydomain].auth.us-east-2.amazoncognito.com/login?response_type=code&client_id=[myclientid]&state=[a big guid]&redirect_uri=com.testthing.myapp://signin&scope=email%20openid&code_challenge=[a long code]&code_challenge_method=S256

所以我在考虑那个405(方法不允许)错误后想通了。发生的事情是 POST 被发送到我的应用程序,但我的应用程序没有处理 POST(因为 Capacitor 默认处理 GET)。

这是一个简单的改变,让它完全发挥作用,更新了 AppDelegate.swift 文件以正确处理 open url

func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]) -> Bool {
    // TODO parse the url and only launch cognito auth for ://signin and ://signout
    return AWSCognitoAuth(forKey: "AWSCognito").application(app, open: url, options: options)

    // This was here before
    //return CAPBridge.handleOpenUrl(url, options)
  }

希望这对尝试使用 Cognito + Swift 的其他人有所帮助。