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
|
|
|
|
2014-11-23 20:13:38 +01:00
|
|
|
use Core\Request;
|
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
|
|
|
* Google 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
|
|
|
* @author Frederic Guillot
|
|
|
|
*/
|
|
|
|
class Google extends Base
|
|
|
|
{
|
2014-10-22 19:59:09 +02:00
|
|
|
/**
|
|
|
|
* Backend name
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const AUTH_NAME = 'Google';
|
|
|
|
|
2014-07-20 12:26:15 +02:00
|
|
|
/**
|
|
|
|
* Authenticate a Google user
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $google_id Google unique id
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function authenticate($google_id)
|
|
|
|
{
|
2014-10-22 19:59:09 +02:00
|
|
|
$user = $this->user->getByGoogleId($google_id);
|
2014-07-20 12:26:15 +02:00
|
|
|
|
|
|
|
if ($user) {
|
|
|
|
|
|
|
|
// Create the user session
|
2014-10-22 19:59:09 +02:00
|
|
|
$this->user->updateSession($user);
|
2014-07-20 12:26:15 +02:00
|
|
|
|
|
|
|
// Update login history
|
2014-10-22 19:59:09 +02:00
|
|
|
$this->lastLogin->create(
|
|
|
|
self::AUTH_NAME,
|
2014-07-20 12:26:15 +02:00
|
|
|
$user['id'],
|
2014-11-23 20:13:38 +01:00
|
|
|
Request::getIpAddress(),
|
|
|
|
Request::getUserAgent()
|
2014-07-20 12:26:15 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unlink a Google 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,
|
|
|
|
'google_id' => '',
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the user table based on the Google profile information
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param integer $user_id User id
|
|
|
|
* @param array $profile Google profile
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
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,
|
|
|
|
'google_id' => $profile['id'],
|
|
|
|
'email' => $profile['email'],
|
|
|
|
'name' => $profile['name'],
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the Google service instance
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return \OAuth\OAuth2\Service\Google
|
|
|
|
*/
|
|
|
|
public function getService()
|
|
|
|
{
|
|
|
|
$uriFactory = new UriFactory();
|
|
|
|
$currentUri = $uriFactory->createFromSuperGlobalArray($_SERVER);
|
|
|
|
$currentUri->setQuery('controller=user&action=google');
|
|
|
|
|
|
|
|
$storage = new Session(false);
|
|
|
|
|
|
|
|
$credentials = new Credentials(
|
|
|
|
GOOGLE_CLIENT_ID,
|
|
|
|
GOOGLE_CLIENT_SECRET,
|
|
|
|
$currentUri->getAbsoluteUri()
|
|
|
|
);
|
|
|
|
|
|
|
|
$serviceFactory = new ServiceFactory();
|
|
|
|
|
|
|
|
return $serviceFactory->createService(
|
|
|
|
'google',
|
|
|
|
$credentials,
|
|
|
|
$storage,
|
|
|
|
array('userinfo_email', 'userinfo_profile')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the authorization URL
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @return \OAuth\Common\Http\Uri\Uri
|
|
|
|
*/
|
|
|
|
public function getAuthorizationUrl()
|
|
|
|
{
|
|
|
|
return $this->getService()->getAuthorizationUri();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get Google profile information from the API
|
|
|
|
*
|
|
|
|
* @access public
|
|
|
|
* @param string $code Google authorization code
|
|
|
|
* @return bool|array
|
|
|
|
*/
|
|
|
|
public function getGoogleProfile($code)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
|
|
|
|
$googleService = $this->getService();
|
|
|
|
$googleService->requestAccessToken($code);
|
|
|
|
return json_decode($googleService->request('https://www.googleapis.com/oauth2/v1/userinfo'), true);
|
|
|
|
}
|
|
|
|
catch (TokenResponseException $e) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|