Ich migiere mein Projekt von Swift 2.3 nach Swift 3. Und habe Schwierigkeiten wie erwartet.Unklarer Verweis auf Mitglied Swift 3
Hier ist eine Funktion, die für OAuth mit OAuthSwift verwendet wird. Ich habe versucht,
class func OAuthSwiftAuthorization(inViewController viewController: UIViewController, withOAuthInfo info:FitnessTracker, successHandler:@escaping MyOAuthNewSuccessHandler, failure: @escaping ((_ error: NSError) -> Void)) {
let oauthswift = OAuth2Swift(
consumerKey: info.consumerKey,
consumerSecret: info.consumerSecret,
authorizeUrl: info.authorizeUrl,
accessTokenUrl: info.accessTokenUrl,
responseType: info.responseType
)
oauthswift.authorizeURLHandler = SafariURLHandler(viewController: viewController, oauthSwift: oauthswift)
oauthswift.accessTokenBasicAuthentification = true
oauthswift.allowMissingStateCheck = true
oauthswift.authorize(withCallbackURL: URL(string: info.callBackUrl)!, scope: info.scope, state: info.state, success: { (credential, response, parameters) in
successHandler(credential, response, parameters)
}) { (error) in
failure(error: error)
print(error.localizedDescription)
}
}
zu konvertieren Aber ich erhalte eine Fehlermeldung bei
oauthswift.authorize(withCallbackURL: URL(string: info.callBackUrl)!, scope: info.scope, state: info.state, success: { (credential, response, parameters) in
Fehlerzustände
Mehrdeutige Bezug auf Mitglieder genehmigen (withCallbackURL: Umfang: Zustand: Parameter: Header : Erfolg: Fehler :) '
Hier ist der Arbeitscode von Swi ft 2.
oauthswift.authorizeWithCallbackURL(
URL(string: info.callBackUrl)!,
scope: info.scope, state:info.state,
success: { credential, response, parameters in
successHandler(credientials: credential, response: response, params: parameters)
},
failure: { error in
failure(error: error)
print(error.localizedDescription)
}
)
UPDATE:
Fehler nicht erscheint Unitil ich Erfolg und im Fehlerfall handelrs geben. Dies ist in Ordnung:
oauthswift.authorize(withCallbackURL: URL(string: info.callBackUrl)!, scope: info.scope, state: info.state, success: { (credential, response, parameters) in
// successHandler(credential, response, parameters)
}) { (erorr) in
// failure(error: error
}
Also bitte führen Sie mich Danke.
Nicht mit einem Trailing-Verschluss hat den Trick. Aber ich verstehe nicht warum !! –
Es ist ein Manko, siehe hier: https://lists.swift.org/pipermail/swift-dev/Week-of-Mon-20160704/002370.html –