私はアプリケーションにrunkeeperを使用して、そのアプリケーションにrunkeeperを接続し、そこからデータを取得しています。ボタンをクリックすると、私はrunkeeperのWebアプリケーションにログインしているブラウザにアクセスし、アクセストークンとuser_Idを取得してサービスにアクセスし、私のアプリケーションに戻ります。もう一度、アプリケーションのボタンをクリックして接続すると、アプリケーションにリダイレクトするように要求されますが、クリックするたびにクリックしてログインする必要があります。私はキャッシュとクッキーをクリアする必要があることを知っていますが、方法はわかりません。Runkeeper Login
@IBAction func btnRunKeeperClicked(sender: AnyObject) {
MSYRunKeeper.shareInstance.loginWithRunKeeper { (result, success) in
print(result)
if success{
print(result)
let accessToken = result["accessToken"] as? String ?? ""
self.hitServiceToGetDataFromRunkeeper(accessToken)
}else{
print("error...")
}
}
}
FUNCのhitServiceToGetDataFromRunkeeper(accessToken:文字列){
showActivityIndicator(true, inViewConroller: self, animated: true)
let dict = HelperClass.userDefaultForAny("User_Detail")
var userID = ""
var serviceKey = ""
if(dict != nil){
userID = (dict!["userID"] as? String)!
serviceKey = (dict!["service_key"] as? String)!
}
var paramDictionary = NSMutableDictionary()
paramDictionary = ["method":"runkeeperLogin","service_key":serviceKey,"userID":userID,"runkeeperAccessToken":accessToken,"isRunkeeperConnect":"1"]
print_debug(paramDictionary)
FSServicesClass.sharedInstance.postWithParamater(paramDictionary, sBlock: { (result) in
if(NSDictionary(dictionary: result).valueForKey("success")?.integerValue == 1){
showActivityIndicator(false, inViewConroller: self, animated: true)
self.btnRunKeeperConnected.setTitle("Connected", forState: .Normal)
if self.btnFitBitConnected.titleLabel?.text == "Connected"{
self.btnFitBitConnected.setTitle("Disconnected", forState: .Normal)
}
print(result)
let dict = HelperClass.userDefaultForAny("User_Detail")
HelperClass.removeFromUserDefaultForKey("User_Detail")
let dict2 = updateUserDetailForConnetectdAppsAndDevices(dict!, isfitbitConnected: "0", isRunkeeperConnected: "1")
HelperClass.saveToUserDefault(dict2, key: "User_Detail")
popAlertMessageController(self, title: "Alert", message: NSDictionary(dictionary: result).valueForKey("errstr") as? String ?? "")
}else{
showActivityIndicator(false, inViewConroller: self, animated: true)
popAlertMessageController(self, title: "Alert", message: NSDictionary(dictionary: result).valueForKey("errstr") as? String ?? "")
}
}, fBlock: {(ErrorResult) in
showActivityIndicator(false, inViewConroller: self, animated: true)
popAlertMessageController(self, title: "Please try again", message: NSDictionary(dictionary: ErrorResult).valueForKey("errstr") as? String ?? "")
//print(ErrorResult)
})
}
あなたが使っているrunkeeper apiを共有できますか? –
OAuth 1.0またはOAuth 2.0を使用していますか? – iDeveloper
OAuth 2.0を使用 – Ishika