1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/kanboard_ynh.git synced 2024-09-03 19:36:17 +02:00
kanboard_ynh/sources/app/Auth/GitHub.php

164 lines
4 KiB
PHP
Raw Normal View History

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
if ($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;
}
}
}