$client_id = 'XXXXXXX'; // ID
$client_secret = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'; // Секретный ключ
$redirect_uri = 'https://site.ru/social_login_callback/mail.php'; // Замените на свой путь обработчика
if (isset($_GET['code'])) {
$result = false;
$params = array(
'client_id' => $client_id,
'client_secret' => $client_secret,
'grant_type' => 'authorization_code',
'code' => $_GET['code'],
'redirect_uri' => $redirect_uri
);
$url = 'https://connect.mail.ru/oauth/token';
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, urldecode(http_build_query($params)));
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
$result = curl_exec($curl);
curl_close($curl);
$tokenInfo = json_decode($result, true);
if (isset($tokenInfo['access_token'])) {
$sign = md5("app_id={$client_id}method=users.getInfosecure=1session_key={$tokenInfo['access_token']}{$client_secret}");
$params = array(
'method' => 'users.getInfo',
'secure' => '1',
'app_id' => $client_id,
'session_key' => $tokenInfo['access_token'],
'sig' => $sign
);
$userInfo = json_decode(file_get_contents('http://www.appsmail.ru/platform/api' . '?' . urldecode(http_build_query($params))), true);
if (isset($userInfo[0]['uid'])) {
$userInfo = array_shift($userInfo);
$result = true;
}
}
$email = $userInfo['email']; // почта юзера
// все получаемые данные
if ($result) {
echo "Социальный ID пользователя: " . $userInfo['uid'];
echo "Имя пользователя: " . $userInfo['nick'];
echo "Email: " . $userInfo['email'];
echo "Ссылка на профиль пользователя: " . $userInfo['link'];
echo "Пол пользователя: " . $userInfo['sex'];
echo "День Рождения: " . $userInfo['birthday'];
echo $userInfo['pic_small'];
}
}