iOS - Alamofire RequestRetrier не вызывается - PullRequest
0 голосов
/ 13 сентября 2018

Я пытаюсь реализовать механизм повторных попыток, и я увидел, что у alamofire есть такой.Я пытаюсь реализовать простой механизм повторных попыток с количеством раз для запроса, но что-то не так.

class OAuth2Handler: RequestAdapter, RequestRetrier {
  func adapt(_ urlRequest: URLRequest) throws -> URLRequest {
    return urlRequest
 }

var defaultRetryCount = 4
private  var requestsAndRetryCounts: [(Request, Int)] = []
private  var lock = NSLock()

private func index(request: Request) -> Int? {
    return requestsAndRetryCounts.index(where: { $0.0 === request })
}

func addRetryInfo(request: Request, retryCount: Int? = nil) {
    lock.lock() ; defer { lock.unlock() }
    guard index(request: request) == nil else { print("ERROR addRetryInfo called for already tracked request"); return }

    requestsAndRetryCounts.append((request, retryCount ?? defaultRetryCount))
}

func deleteRetryInfo(request: Request) {
    lock.lock() ; defer { lock.unlock() }
    guard let index = index(request: request) else { print("ERROR deleteRetryInfo called for not tracked request"); return }

    requestsAndRetryCounts.remove(at: index)
}

func should(_ manager: SessionManager, retry request: Request, with error: Error, completion: @escaping RequestRetryCompletion){

    lock.lock() ; defer { lock.unlock() }

    guard let index = index(request: request) else { completion(false, 0); return }
    let (request, retryCount) = requestsAndRetryCounts[index]

    if retryCount == 0 {
        completion(false, 0)
    } else {
        requestsAndRetryCounts[index] = (request, retryCount - 1)
        completion(true, 0.5)
    }
 }
}

Это класс, который я пытаюсь использовать это:

let sessionManager = SessionManager()

override init() {
    sessionManager.adapter = RequestAdapter.self as? RequestAdapter
    sessionManager.retrier = OAuth2Handler()
}


func sendRequest(url: String,meth: HTTPMethod,parameters: [String: AnyObject]?, success: @escaping (String, Data) -> Void, failure: @escaping (Error) -> Void) {

    self.asyncSerialWorker.enqueueWork { (done) in
        self.sessionManager.request(url, method:meth).responseJSON { (responseObject) -> Void in
            if responseObject.result.isSuccess {
                print("Generic succsess")
                let value = responseObject.result.value
                let json = JSON(value!)
                guard let result = responseObject.data else {return}
                success(self.parser.parseMaiden(json: json), result)
            }

            if responseObject.result.isFailure {
                let error : Error = responseObject.result.error!

                print("login failed")
                failure(error)
            }
            done()
        }
    }
} 

если есть какие-то другие предложения, я бы хотел их услышать

спасибо

Ответы [ 2 ]

0 голосов
/ 16 сентября 2018

Итак, проблема заключалась в том, чтобы добавить запрос к повторной попытке, поэтому сначала я сделал это:

let sessionManager = SessionManager()
var retrier = OAuth2Handler()

override init() {
    sessionManager.retrier = retrier
}

и в самом звонке я сделал следующее:

func sendRequest(url: String,meth: HTTPMethod,parameters: [String: AnyObject]?, success: @escaping (String, Data) -> Void, failure: @escaping (Error) -> Void) {
    let request = sessionManager.request(url, method: meth, parameters: parameters, encoding: JSONEncoding.default)
    retrier.addRetryInfo(request: request)

    self.asyncSerialWorker.enqueueWork { (done) in
        self.sessionManager.request(url, method:meth).responseJSON { (responseObject) -> Void in
            if responseObject.result.isSuccess {
                print("Generic succsess")
                let value = responseObject.result.value
                let json = JSON(value!)
                guard let result = responseObject.data else {return}
                success(self.parser.parseMaiden(json: json), result)
            }

            if responseObject.result.isFailure {
                let error : Error = responseObject.result.error!

                print("login failed")
                failure(error)
            }
            done()
        }
    }
}

как вы видите, я добавил к повтору запрос:

              retrier.addRetryInfo(request: request)

может быть, я должен сделать успешное удаление (проверим и обновлю)

0 голосов
/ 13 сентября 2018

sessionManager.adapter = RequestAdapter.self as? RequestAdapter кажется очень неправильным. Вы должны установить его на экземпляр вашего OAuth2Handler.

...