无法使用swift SDK对aws appsync的用户进行身份验证

问题描述 投票:2回答:1

我正在尝试使用AWS Swift SDK从我的Swift移动应用程序连接到我的AWS AppSync服务,但不断收到以下错误:

Error occurred: (401 unauthorized) Did not receive a successful HTTP code.

我正在使用用户池,并按照swift教程设置了所有内容。我的问题是,如何在我的请求中合并控制台中生成的AppSync.json配置文件?这在教程中没有提到,可能是我无法连接的原因。

json文件如下所示:

{
    "graphqlEndpoint": "my_endpoint_url",
    "region": "us-east-1",
    "authenticationType": "AMAZON_COGNITO_USER_POOLS",
    "apiKey": null
}

目前我正在使用以下配置:

// Set up  Amazon Cognito credentials
let credentialsProvider = AWSCognitoCredentialsProvider(regionType: CognitoIdentityRegion,
                                                        identityPoolId: CognitoIdentityPoolId, identityProviderManager: pool)
// You can choose your database location, accessible by SDK
let databaseURL = URL(fileURLWithPath:NSTemporaryDirectory()).appendingPathComponent(database_name)

do {
    // Initialize the AWS AppSync configuration

    let appSyncConfig = try AWSAppSyncClientConfiguration(url: AppSyncEndpointURL,
                                                          serviceRegion: AppSyncRegion,
                                                          credentialsProvider: credentialsProvider,
                                                          databaseURL:databaseURL)

    appSyncClient = try AWSAppSyncClient(appSyncConfig: appSyncConfig)
    // Set id as the cache key for objects
    appSyncClient?.apolloClient?.cacheKeyForObject = { $0["id"] }
} catch {
    print("Error initializing appsync client. \(error)")
}

编辑#1

事实证明,该示例使用的是API密钥方法而不是用户池。所以现在我已将配置更改为:

let appSyncConfig = try AWSAppSyncClientConfiguration(url: AppSyncEndpointURL, serviceRegion: AppSyncRegion, userPoolsAuthProvider: CognitoUserPoolsAuthProvider(pool: pool))

问题是现在的消息是:

Use of unresolved identifier 'CognitoUserPoolsAuthProvider'

如果我尝试:

let appSyncConfig = try AWSAppSyncClientConfiguration(url: AppSyncEndpointURL, serviceRegion: AppSyncRegion, userPoolsAuthProvider: AWSCognitoUserPoolsAuthProvider(pool: pool))

错误是:

'AWSCognitoUserPoolsAuthProvider' cannot be constructed because it has no accessible initializers

不确定如何满足config中的userPoolsAuthProvider:参数。

swift xcode amazon-web-services amazon-cognito aws-appsync
1个回答
0
投票

为解决您的具体问题,userPoolsAuthProvider需要接受扩展AWSCognitoUserPoolsAuthProvider协议的类。所以你的实例化看起来像这样:

 let appSyncConfig = try AWSAppSyncClientConfiguration(url: AppSyncEndpointURL,
                                                          serviceRegion: AppSyncRegion,
                                                          userPoolsAuthProvider: self,
                                                          databaseURL:databaseURL)

然后在您创建AppSyncClient的类中,您将扩展如下:

extension YourClass: AWSCognitoUserPoolsAuthProvider {
  func getLatestAuthToken() -> String {
    var token: String = ""

    // pool is an instance of AWSCognitoIdentityUserPool
    self.pool?.currentUser()?.getSession().continueOnSuccessWith(block: { (task) -> Any? in 
      token = task.result!.idToken!.tokenString
      return nil
    }).waitUnitFinished()
  }

  return token
}

另外我认为AppSync配置默认在项目中查找awsconfiguration.json文件。您之前发布了这一消息,因此AWS服务和AppSync可能会发生变化。

希望这可以帮助

© www.soinside.com 2019 - 2024. All rights reserved.