Как отправить запрос POST или GET с BODY в зависимости от типа API - PullRequest
0 голосов
/ 27 сентября 2018

Я создал класс 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

Это вернуло ошибку "Дополнительный аргумент" метод "в вызове".

1 Ответ

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

Ваша подпись NetworkManager метода не включает method в качестве аргумента.

У вас есть:

callingHttpRequest(params: Dictionary<String,Any>, 
                  apiname: String, 
              cuurentView: UIViewController, 
             taskCallback: @escaping (Int, AnyObject?) -> Void))

Но вы пытаетесь вызвать его, передавая дополнительный аргумент method, который не существует:

callingHttpRequest(params:loginRequest, apiname:"feed/rest_api/gettoken&grant_type=client_credentials", method: .post, // **Does not exist** cuurentView: self) taskCallback: {})

Если вы хотите передать method, вам нужно добавить этот аргумент в ваш метод для его вызова.

...