Как обновить статус токена JWT Code 500 в Alamofire Swift - PullRequest
0 голосов
/ 04 июля 2018

Спасибо, что посмотрели на мой вопрос. Я вхожу в точку. Я должен обновить токен JWT, используя Alamofire Swift. Срок действия токена истекает каждые 30 минут, поэтому, пока я выполняю запрос POST или GET, срок действия токена может истечь и он достигает кода ошибки (кода состояния) 500. Затем я должен вызвать API обновления токена и получить новый токен с сервера, а затем снова вызвать предыдущий API , Моя проблема заключается в том, как я могу перезвонить сбой API после получения нового токена. Надежда может помочь кому-то в этом с лучшим решением. Заранее спасибо.

текущий статус.

метод запроса API,

func statusStaffCheckInOut(completion: @escaping(Bool)->Void){

        guard let userID= userLoginModel.user?.id else{ return }
        guard let jwtToken = userLoginModel.jwt else{ return }

        let x_headers = ["x-authorization": "\(jwtToken)","id":"\(userID)"]

        Alamofire.request("\(BASE_MIDDLEWARE_URL)/url",method: .get, encoding: JSONEncoding.default , headers: x_headers).validate(statusCode: 200..<300)
            .validate(contentType: ["application/json"]).responseJSON { response in
                // print("Request: \(String(describing: response.request))")
                // response serialization result
                if let json = response.result.value as? [String:Any]{
                    userLoginModel.staffcheckincheckout?.setValuesForKeys(json)
                    completion(true)
                 }else {
                    if let statusCode = response.response?.statusCode{
                        print("status code \(statusCode)")
                        if statusCode == 500{ ///Check 500 Error code
                            print("Status code ***\(500)***")
                            ///Refresh taken call
                            self.refreshJWTToken(trigeredURL: "url"){(response) in
                            }
                        }
                    }
                    completion(false)
                }
        }
    }

Обновить токен Метод:

//MARK:- Token Refresh
    func refreshJWTToken(trigeredURL: String,completion: @escaping([[String:Any]],Bool)->Void){

        guard let userID = userLoginModel.user?.id else{ return }

        let url = "\(BASE_MIDDLEWARE_URL)/url?id=\(userID)"

        Alamofire.request(url,method: .get, encoding: JSONEncoding.default).validate(statusCode: 200..<300)
            .validate(contentType: ["application/json"]).responseJSON { response in
                if let json = response.result.value as? String{
                    userLoginModel.jwt = json
                    print("Refreshed JWT: \(json)")
                    completion([["Message":"Success"]],true)
                }else {
                    completion([["Message":"Faild"]],false)
                }
        }
    }

1 Ответ

0 голосов
/ 10 августа 2018

Я изменил ваш запрос, чтобы удовлетворить ваши потребности.

Перечисление:

enum APIResult<T> {
case success(T)
case failure(NSError)

}

Метод запроса API:

func statusStaffCheckInOut(callback: @escaping(APIResult<Void>) -> Void){

    guard let userID= userLoginModel.user?.id else{ return }
    guard let jwtToken = userLoginModel.jwt else{ return }

    let x_headers = ["x-authorization": "\(jwtToken)","id":"\(userID)"]

    Alamofire.request("\(BASE_MIDDLEWARE_URL)/url",method: .get, encoding: JSONEncoding.default , headers: x_headers).validate(statusCode: 200..<300)
        .validate(contentType: ["application/json"]).responseJSON { response in
            // print("Request: \(String(describing: response.request))")
            // response serialization result

            if let json = response.result.value as? [String:Any]{
                userLoginModel.staffcheckincheckout?.setValuesForKeys(json)
                //                    completion(true)
                callback(.success(()))
            }else {
                if let statusCode = response.response?.statusCode{
                    print("status code \(statusCode)")
                    if statusCode == 500 { ///Check 500 Error code
                        print("Status code ***\(500)***")
                        ///Refresh token call
                        self.refreshJWTToken(trigeredURL: "url"){ result in
                            switch result {
                            case .success(_):
                                self.statusStaffCheckInOut(){ result in
                                    switch result {
                                    case .success(()) : callback(.success(()))
                                    case let .failure(error): callback(.failure(error))
                                    }
                                }
                            case let .failure(error):
                                callback(.failure(error))
                            }
                        }
                    }
                }
                callback(.failure(NSError(domain: "Error", code: -1, userInfo: [NSLocalizedDescriptionKey: "Invalid authorization"])))
            }

    }
}

Метод обновления токена:

//MARK:- Token Refresh
func refreshJWTToken(trigeredURL: String,callback: @escaping(APIResult<Void>) -> Void){

    guard let userID = userLoginModel.user?.id else{ return }

    let url = "\(BASE_MIDDLEWARE_URL)/url?id=\(userID)"

    Alamofire.request(url,method: .get, encoding: JSONEncoding.default).validate(statusCode: 200..<300)
        .validate(contentType: ["application/json"]).responseJSON { result in
            switch response.result {
            case let .success(value):
                if let json = value as? String{
                    userLoginModel.jwt = json
                    print("Refreshed JWT: \(json)")
                    callback(.success(()))
                }else {
                    callback(.failure(NSError(domain: "Error", code: -1, userInfo: [NSLocalizedDescriptionKey: "Invalid authorization"])))
                }
            case let .failure(error):
                callback(.failure(NSError(domain: "Error", code: -1, userInfo: [NSLocalizedDescriptionKey: "Invalid authorization"])))
            }
    }
}

Я использую универсальный возврат для результата API. Вы можете передать что угодно в случае обратного вызова.

...