如果在Swift中失败,如何在完成过程中对API执行多次调用并退出?

问题描述

我对Swift还是比较陌生,希望您能帮助我。 如果服务的响应告诉我有更多信息,则需要对服务执行多次调用。 如果没有更多信息,请退出循环并将结果的数组传递给成功完成。如果服务失败,请结束此循环并将错误传递给完成。

这是我正在编写的代码,但不知何故。

func requestAccountDetail(_ accountId: String) {
    APIDataManager.requestAccountDetail(accountId,completion: { result in
      switch result {
        case .success(let response):
          self.retrieveSucceed(with: response)
        case .failure(let error):
          self.retrieveFailed(with: error)
      }
    })
  }

这是我要讲的逻辑

func requestAccountDetail(_ accountId: String,completion: @escaping (GetAccountDetailResult) -> Void) {
    var moreinformationIsAvailable: Bool = false
    var pageId: Int = 1
    let pageIdIncrement: Int = 1
    var responses: [ResponseModel] = []
    var exitEarly: Bool = false
    var serviceError: Error = Error()

    repeat {
      let inputParams: InputParams = generateInputParameters(accountId,pageId)
      let service: Service =
        service.AccountDetail(inputParams)
      let client: apiclient = apiclient(apiConfiguration: APIDefaultServices())
      client.perform(service: service,completion: { (response: AccountDetailResponse) in
        switch response {
        case .success(let response):
          responses.append(response)
          moreinformationIsAvailable = response.moreinformationFlag
          if moreinformationIsAvailable {
            pageId += pageIdIncrement
          }
        case .failure(let error):
          exitEarly = true
          serviceError = error
        }
      })
      if exitEarly { break }
    } while moreinformationIsAvailable

    if exitEarly {
      completion(.failure(error))
    } else {
      completion(.success(responses))
   }
}

很抱歉,如果这段代码是一团糟,我正在学习如何与补全完美配合。任何改进都非常欢迎。 谢谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...