Я создал класс Network Manager, который позволяет совместно использовать экземпляр ответа через контроллеры.В зависимости от типа контроллера я вызываю API, который определен как метод GET, однако в некоторых случаях для отправки серверу требуется метод POST и ожидание ответа, начиная с аутентификации выдачи токена.
В классе Network Manager IСозданная функция вызываетHttpRequest
func callingHttpRequest(params:Dictionary<String,Any>, apiname:String,cuurentView:UIViewController,taskCallback: @escaping (Int,
AnyObject?) -> Void) {
let urlString = HOST_NAME + apiname
print("url",urlString)
print("params", params)
Alamofire.request(urlString,method: .get,parameters:params).validate().responseJSON { response in
switch response.result {
case .success(let resultData):
taskCallback(1,resultData as AnyObject)
break
case .failure(let error):
let returnData = String(data: response.data! , encoding: .utf8)
print("returnData" ,returnData)
print("request URL", response.request)
if !Connectivity.isConnectedToInternet(){
NetworkManager.sharedInstance.dismissLoader()
cuurentView.view.isUserInteractionEnabled = true
let AC = UIAlertController(title: "Warning", message: error.localizedDescription, preferredStyle: .alert)
let okBtn = UIAlertAction(title: "Retry", style: .default, handler: {(_ action: UIAlertAction) -> Void in
taskCallback(2, "" as AnyObject)
})
let noBtn = UIAlertAction(title: "Cancel", style: .destructive, handler: {(_ action: UIAlertAction) -> Void in
})
AC.addAction(okBtn)
AC.addAction(noBtn)
cuurentView.present(AC, animated: true, completion: { _ in })
}
else{
let errorCode:Int = error._code;
if errorCode != -999 && errorCode != -1005{
NetworkManager.sharedInstance.dismissLoader()
cuurentView.view.isUserInteractionEnabled = true
let AC = UIAlertController(title: "Warning", message: error.localizedDescription, preferredStyle: .alert)
let okBtn = UIAlertAction(title: "Retry", style: .default, handler: {(_ action: UIAlertAction) -> Void in
taskCallback(2, "" as AnyObject)
})
let noBtn = UIAlertAction(title: "Cancel", style: .destructive, handler: {(_ action: UIAlertAction) -> Void in
})
AC.addAction(okBtn)
AC.addAction(noBtn)
cuurentView.present(AC, animated: true, completion: { _ in })
}else if errorCode == -1005{
NetworkManager.sharedInstance.dismissLoader()
taskCallback(2, "" as AnyObject)
}
}
break;
}
}
}
В то время как в ViewController я вызываю функцию tokenRequest для создания токена, предоставленного с сервера.
func tokenRequest(){
var tokenRequest = [String:String]();
tokenRequest["Authorization"] = token_auth;
tokenRequest["token_id"] = "token_id";
tokenRequest["token_id"] = "token_id";
NetworkManager.sharedInstance.callingHttpRequest(params:tokenRequest, apiname:"feed/api/gettoken", cuurentView: self){val,responseObject in
if val == 1{
print("responseobjec", responseObject)
let dict = responseObject as! NSDictionary
sharedPrefrence.set(dict.object(forKey: "access_token") as! String, forKey: "access_token")
sharedPrefrence.synchronize();
self.callingHttppApi()
}else if val == 2{
NetworkManager.sharedInstance.dismissLoader()
self.loginRequest()
}
}
}
По умолчанию Network Manager имеет Alamofire.request(urlString,method: .get,parameters:params)
имеет метододнако получить функцию tokenRequest необходимо method: .post
.
Я добавляю сообщение метода в функцию
NetworkManager.sharedInstance.callingHttpRequest(params:loginRequest, apiname:"feed/rest_api/gettoken&grant_type=client_credentials", method: .post, cuurentView: self
Это вернуло ошибку "Дополнительный аргумент" метод "в вызове".