Создание универсального метода с AlamoFire в Swift

Я использую AlamoFire для своих вызовов API, и у меня есть что-то подобное по всему моему проекту

static func login(userName: String, password: String) -> User {
    let parameters = ["userName": userName , "password": password]
    let user = User()
    Alamofire.request(.POST, "myserver.com/login", parameters: parameters, encoding: .JSON)
        .validate()
        .responseObject { (response: Response<User, NSError>) in
            switch response.result {
            case .Success(let value):
                user.valueHandle?(value)
            case .Failure(let error):
                user.errorHandle?(error)
            }
    }

    return user
}

(увидетьhttps://stackoverflow.com/a/37949671/406322 о том, как я придумал приведенный выше код).

Проблема в том, что у меня есть много объектов, отличных от User, и есть повторение кода только с другим типом объекта, поэтому я пытаюсь создать универсальный метод, что-то вроде этого:

static func sendRequest<T>(method: Alamofire.Method, urlString: String, parameters: [String: AnyObject]?) -> T {
        let response : T
        Alamofire.request(method, urlString, parameters:parameters)
            .validate()
            .responseObject { (response: Response<T, NSError>) in
                switch response.result {
                case .Success(let value):
                    response.valueHandle?(value)
                case .Failure(let error):
                    response.errorHandle?(error)
                }
        }

        return response 
 }

Но Свифт жалуется:

Cannot convert value of type '(Response<T, NSError>) -> ()' to expected argument type 'Response<_, NSError> -> Void'

Это так, я могу сделать что-то вроде этого:

User.swift
static func login(userName: String, password: String) -> User {
        let parameters = ["userName": userName, "password": password]
    return sendRequest<User>(.GET, "http://myserver.com/users", parameters)
}

и в моем коде вызова:

User.login(txtUserName.text!, password: txtPassword.text!)
            .success { (value) in
                var user = value as! User
                //do something with user
            }
            .error { (error) in
                //show error
            }

Что я не правильно делаю?

 Prabhu23 июн. 2016 г., 17:42
@ AMomchilov да, но я делаю это на один уровень выше, поэтому обработчики ответов отправляются обратно в мой вызывающий код (как обещания javascript).
 Alexander23 июн. 2016 г., 17:35
 Prabhu23 июн. 2016 г., 17:58
@ AMomchilov Я отредактировал свой вопрос, чтобы уточнить

Ответы на вопрос(1)

Решение Вопроса

class BaseUser: ResponseObjectSerializable {
    var valueHandle : ((BaseUser)->())?
    var errorHandle : ((NSError)->())?

    required init?(response: NSHTTPURLResponse, representation: AnyObject) {

    }
}



func sendRequest<T:BaseUser>(method: Alamofire.Method, urlString: String, parameters: [String: AnyObject]?) -> T {
    let res : T
    Alamofire.request(method, urlString, parameters:parameters)
        .validate()
        .responseObject { (response: Response<T, NSError>) in
            switch response.result {
            case .Success(let value):
                res.valueHandle?(value)
            case .Failure(let error):
                res.errorHandle?(error)
            }
    }

    return res
}

class может держать ручку, и с baseobj вам не нужно писать их снова и снова, используя протокол

Ваш ответ на вопрос