mirror of
https://github.com/e107inc/e107.git
synced 2025-08-05 22:27:34 +02:00
Corrected filename
This commit is contained in:
80
e107_handlers/hybridauth/Hybrid/Providers/Github.php
Normal file
80
e107_handlers/hybridauth/Hybrid/Providers/Github.php
Normal file
@@ -0,0 +1,80 @@
|
||||
<?php
|
||||
/*!
|
||||
* HybridAuth
|
||||
* http://hybridauth.sourceforge.net | https://github.com/hybridauth/hybridauth
|
||||
* (c) 2009-2011 HybridAuth authors | hybridauth.sourceforge.net/licenses.html
|
||||
*/
|
||||
|
||||
/**
|
||||
* Hybrid_Providers_GitHub
|
||||
*/
|
||||
class Hybrid_Providers_GitHub extends Hybrid_Provider_Model_OAuth2
|
||||
{
|
||||
// default permissions
|
||||
// (no scope) => public read-only access (includes public user profile info, public repo info, and gists).
|
||||
public $scope = "";
|
||||
|
||||
/**
|
||||
* IDp wrappers initializer
|
||||
*/
|
||||
function initialize()
|
||||
{
|
||||
parent::initialize();
|
||||
|
||||
// Provider api end-points
|
||||
$this->api->api_base_url = "https://api.github.com/";
|
||||
$this->api->authorize_url = "https://github.com/login/oauth/authorize";
|
||||
$this->api->token_url = "https://github.com/login/oauth/access_token";
|
||||
}
|
||||
|
||||
/**
|
||||
* load the user profile from the IDp api client
|
||||
*/
|
||||
function getUserProfile()
|
||||
{
|
||||
$data = $this->api->api( "user" );
|
||||
|
||||
if ( ! isset( $data->id ) ){
|
||||
throw new Exception( "User profile request failed! {$this->providerId} returned an invalid response.", 6 );
|
||||
}
|
||||
|
||||
$this->user->profile->identifier = @ $data->id;
|
||||
$this->user->profile->displayName = @ $data->name;
|
||||
$this->user->profile->description = @ $data->bio;
|
||||
$this->user->profile->photoURL = @ $data->avatar_url;
|
||||
$this->user->profile->profileURL = @ $data->html_url;
|
||||
$this->user->profile->email = @ $data->email;
|
||||
$this->user->profile->webSiteURL = @ $data->blog;
|
||||
$this->user->profile->region = @ $data->location;
|
||||
|
||||
if( empty($this->user->profile->displayName) ){
|
||||
$this->user->profile->displayName = @ $data->login;
|
||||
}
|
||||
|
||||
// request user emails from github api
|
||||
if( empty($data->email) ){
|
||||
try{
|
||||
$emails = $this->api->api("user/emails");
|
||||
|
||||
// fail gracefully, and let apps collect the email if not present
|
||||
if (is_array($emails)) {
|
||||
foreach ($emails as $email) {
|
||||
if ($email instanceof stdClass
|
||||
&& property_exists('primary', $email)
|
||||
&& true === $email->primary
|
||||
&& property_exists('email', $email)
|
||||
) {
|
||||
$this->user->profile->email = $email->email;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch( GithubApiException $e ){
|
||||
throw new Exception( "User email request failed! {$this->providerId} returned an error: $e", 6 );
|
||||
}
|
||||
}
|
||||
|
||||
return $this->user->profile;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user