function facebookLogin(Request $request,Response $response)
{
$appid='1213187855410344';
$fb = new \Facebook\Facebook([
'app_id' => $appid,
'app_secret' => '8b1151cfa1958249297e6e061e771207',
'default_graph_version' => 'v2.8',
]);
$helper = $fb->getRedirectLoginHelper();
$permissions = ['email'];
$loginUrl = $helper->getLoginUrl('http://www.product.win/fb-callback', $permissions);
return $response->withRedirect($loginUrl);
}
function facebookCallback(Request $request, Response $slimresponse)
{
$utils=new Utils($this->guzzle,$this->id_token,$this->logger,$this->lg);
$appid='1213187855410344';
$fb = new \Facebook\Facebook([
'app_id' => $appid,
'app_secret' => '8b1151cfa1958249297e6e061e771207',
'default_graph_version' => 'v2.8',
]);
$helper = $fb->getRedirectLoginHelper();
try {
$accessToken = $helper->getAccessToken();
} catch(Facebook\Exceptions\FacebookResponseException $e) {
echo 'Graph returned an error: ' . $e->getMessage();
exit;
} catch(Facebook\Exceptions\FacebookSDKException $e) {
echo 'Facebook SDK returned an error: ' . $e->getMessage();
exit;
}
if (! isset($accessToken)) {
if ($helper->getError()) {
header('HTTP/1.0 401 Unauthorized');
echo "Error: " . $helper->getError() . "\n";
echo "Error Code: " . $helper->getErrorCode() . "\n";
echo "Error Reason: " . $helper->getErrorReason() . "\n";
echo "Error Description: " . $helper->getErrorDescription() . "\n";
} else {
header('HTTP/1.0 400 Bad Request');
echo 'Bad request';
}
exit;
}
try {
$response = $fb->get('/me?fields=id,name,email,picture,gender',$accessToken);
} catch(\Facebook\Exceptions\FacebookResponseException $e) {
echo 'Graph returned an error: ' . $e->getMessage();
exit;
} catch(\Facebook\Exceptions\FacebookSDKException $e) {
echo 'Facebook SDK returned an error: ' . $e->getMessage();
exit;
}
$me = $response->getGraphUser();
if($me->getEmail()){
$postData=[
'appid'=>$appid,
'email'=>$me->getEmail(),
'gender'=>$me->getGender(),
'name'=>$me->getName(),
'os'=>$utils->getOS(),
'picture'=>$me->getPicture()->getUrl(),
'rememberMe'=>true,
'token'=>$accessToken->getValue(),
'userid'=>$me->getId()
];
$ret=$utils->faceBookLogin(['json'=>$postData]);
if(isset($ret['id_token'])){
setcookie("id_token","Bearer ".$ret['id_token'],time()+3600*24,'/');
setcookie("fb_user",json_encode($ret),time()+3600*24,'/');
return $slimresponse->withRedirect('/');
}
}else{
die('the Facebook account doesn\'t have the email address...');
}
}