2017-01-31 3 views
5

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.

Antwort

7

Ich denke, das Problem wird durch einige Mängel der Swift-Typ-Schlussfolgerung in Kombination mit Verschlüssen verursacht. Sie könnten eine der folgenden Möglichkeiten ausprobieren:

Entweder verwenden Sie keine abschließenden Verschlüsse, z.

oauthswift.authorize(withCallbackURL: URL(string: info.callBackUrl)!, scope: info.scope, state: info.state, success: { (credential, response, parameters) in 

     successHandler(credential, response, parameters) 
}, failure: { (error) in 

    failure(error: error) 
    print(error.localizedDescription) 
}) 

oder einen expliziten Typ für Fehler, z.

oauthswift.authorize(withCallbackURL: URL(string: info.callBackUrl)!, scope: info.scope, state: info.state, success: { (credential, response, parameters) in 

     successHandler(credential, response, parameters) 
}) { (error: Error) in 

    failure(error: error) 
    print(error.localizedDescription) 
} 
+0

Nicht mit einem Trailing-Verschluss hat den Trick. Aber ich verstehe nicht warum !! –

+0

Es ist ein Manko, siehe hier: https://lists.swift.org/pipermail/swift-dev/Week-of-Mon-20160704/002370.html –

Verwandte Themen