plugins/oauth/classes/oauth/yf_oauth_driver_yandex.class.php
<?php
load('oauth_driver2', '', 'classes/oauth/');
class yf_oauth_driver_yandex extends yf_oauth_driver2
{
public $scope = '';
public $get_access_token_method = 'POST';
public $url_params_access_token = [
'grant_type' => 'authorization_code',
];
// Register for API client_id and client_secret here: https://oauth.yandex.ru/client/new
protected $url_authorize = 'https://oauth.yandex.ru/authorize';
protected $url_access_token = 'https://oauth.yandex.ru/token';
protected $url_user = 'https://login.yandex.ru/info';
/**
* @param mixed $raw
*/
public function _get_user_info_for_auth($raw = [])
{
$user_info = [
'user_id' => $raw['id'],
'login' => $raw['display_name'],
'name' => $raw['real_name'],
'email' => $raw['default_email'],
// 'avatar_url' => $raw['avatar_url'],
// 'profile_url' => $raw['url'],
'birthday' => $raw['birthday'],
'gender' => $raw['sex'],
];
return $user_info;
}
public function get_user_info()
{
$access_token = $this->_storage_get('access_token');
if ( ! $access_token) {
$access_token = $this->get_access_token();
if ( ! $access_token) {
$this->_storage_clean();
js_redirect($this->redirect_uri, $url_rewrite = false);
return false;
}
}
if ( ! $this->_storage_get('user')) {
$url = $this->url_user . '?' . http_build_query([
'oauth_token' => $access_token,
'format' => 'json',
]);
$result = common()->get_remote_page($url, $cache = false, $opts, $response);
$result = $this->_decode_result($result, $response, __FUNCTION__);
if (isset($result['error']) || substr($response['http_code'], 0, 1) == '4') {
$this->_storage_clean();
js_redirect($this->redirect_uri, $url_rewrite = false);
return false;
}
$this->_storage_set('user_info_request', ['result' => $result, 'response' => $response]);
$this->_storage_set('user', $result);
}
return $this->_storage_get('user');
}
}