2014-07-20 12:26:15 +02:00
|
|
|
<?php
|
|
|
|
|
2014-10-22 19:59:09 +02:00
|
|
|
namespace Auth;
|
2014-07-20 12:26:15 +02:00
|
|
|
|
2015-01-16 14:23:05 +01:00
|
|
|
use Event\AuthEvent;
|
2014-07-20 12:26:15 +02:00
|
|
|
use OAuth\Common\Storage\Session;
|
|
|
|
use OAuth\Common\Consumer\Credentials;
|
|
|
|
use OAuth\Common\Http\Uri\UriFactory;
|
|
|
|
use OAuth\ServiceFactory;
|
|
|
|
use OAuth\Common\Http\Exception\TokenResponseException;
|
|
|
|
|
|
|
|
/**
|
2014-10-22 19:59:09 +02:00
|
|
|
* GitHub backend
|
2014-07-20 12:26:15 +02:00
|
|
|
*
|
2014-10-22 19:59:09 +02:00
|
|
|
* @package auth
|
2014-07-20 12:26:15 +02:00
|
|
|
*/
|
|
|
|
class GitHub extends Base
|
|
|
|
{
|
2014-10-22 19:59:09 +02:00
|
|
|
/**
|
|
|
|
* Backend name
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const AUTH_NAME = 'Github';
|
|
|
|
|
2014-07-20 12:26:15 +02:00
|
|
|
/**
|
|
|
|
* Authenticate a GitHub user
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $github_id GitHub user id
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function authenticate($github_id)
|
|
|
|
{
|
2014-10-22 19:59:09 +02:00
|
|
|
$user = $this->user->getByGitHubId($github_id);
|
2014-07-20 12:26:15 +02:00
|
|
|
|
2015-04-21 17:56:16 +02:00
|
|
|
if (! empty($user)) {
|
2015-01-16 14:23:05 +01:00
|
|
|
$this->userSession->refresh($user);
|
|
|
|
$this->container['dispatcher']->dispatch('auth.success', new AuthEvent(self::AUTH_NAME, $user['id']));
|
2014-07-20 12:26:15 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unlink a GitHub account for a given user
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param integer $user_id User id
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function unlink($user_id)
|
|
|
|
{
|
2014-10-22 19:59:09 +02:00
|
|
|
return $this->user->update(array(
|
2014-07-20 12:26:15 +02:00
|
|
|
'id' => $user_id,
|
|
|
|
'github_id' => '',
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the user table based on the GitHub profile information
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param integer $user_id User id
|
|
|
|
* @param array $profile GitHub profile
|
|
|
|
* @return boolean
|
|
|
|
* @todo Don't overwrite existing email/name with empty GitHub data
|
|
|
|
*/
|
|
|
|
public function updateUser($user_id, array $profile)
|
|
|
|
{
|
2014-10-22 19:59:09 +02:00
|
|
|
return $this->user->update(array(
|
2014-07-20 12:26:15 +02:00
|
|
|
'id' => $user_id,
|
|
|
|
'github_id' => $profile['id'],
|
|
|
|
'email' => $profile['email'],
|
|
|
|
'name' => $profile['name'],
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the GitHub service instance
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return \OAuth\OAuth2\Service\GitHub
|
|
|
|
*/
|
|
|
|
public function getService()
|
|
|
|
{
|
|
|
|
$uriFactory = new UriFactory();
|
|
|
|
$currentUri = $uriFactory->createFromSuperGlobalArray($_SERVER);
|
|
|
|
$currentUri->setQuery('controller=user&action=gitHub');
|
|
|
|
|
|
|
|
$storage = new Session(false);
|
|
|
|
|
|
|
|
$credentials = new Credentials(
|
|
|
|
GITHUB_CLIENT_ID,
|
|
|
|
GITHUB_CLIENT_SECRET,
|
|
|
|
$currentUri->getAbsoluteUri()
|
|
|
|
);
|
|
|
|
|
|
|
|
$serviceFactory = new ServiceFactory();
|
|
|
|
|
|
|
|
return $serviceFactory->createService(
|
|
|
|
'gitHub',
|
|
|
|
$credentials,
|
|
|
|
$storage,
|
|
|
|
array('')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the authorization URL
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return \OAuth\Common\Http\Uri\Uri
|
|
|
|
*/
|
|
|
|
public function getAuthorizationUrl()
|
|
|
|
{
|
|
|
|
return $this->getService()->getAuthorizationUri();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get GitHub profile information from the API
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $code GitHub authorization code
|
|
|
|
* @return bool|array
|
|
|
|
*/
|
|
|
|
public function getGitHubProfile($code)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$gitHubService = $this->getService();
|
|
|
|
$gitHubService->requestAccessToken($code);
|
2014-10-22 19:59:09 +02:00
|
|
|
|
2014-07-20 12:26:15 +02:00
|
|
|
return json_decode($gitHubService->request('user'), true);
|
|
|
|
}
|
|
|
|
catch (TokenResponseException $e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2014-10-22 19:59:09 +02:00
|
|
|
|
2014-07-20 12:26:15 +02:00
|
|
|
/**
|
|
|
|
* Revokes this user's GitHub tokens for Kanboard
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return bool|array
|
|
|
|
* @todo Currently this simply removes all our tokens for this user, ideally it should
|
|
|
|
* restrict itself to the one in question
|
|
|
|
*/
|
|
|
|
public function revokeGitHubAccess()
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$gitHubService = $this->getService();
|
|
|
|
|
|
|
|
$basicAuthHeader = array('Authorization' => 'Basic ' .
|
|
|
|
base64_encode(GITHUB_CLIENT_ID.':'.GITHUB_CLIENT_SECRET));
|
|
|
|
|
|
|
|
return json_decode($gitHubService->request('/applications/'.GITHUB_CLIENT_ID.'/tokens', 'DELETE', null, $basicAuthHeader), true);
|
|
|
|
}
|
|
|
|
catch (TokenResponseException $e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|