Skip to content

Commit

Permalink
Merge pull request #187 from geofflancaster/master
Browse files Browse the repository at this point in the history
update google scopes and endpoint to remove deprecated values
  • Loading branch information
ramsey committed Dec 29, 2014
2 parents ce7ea3d + 5952f5d commit a3fd10e
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 12 deletions.
30 changes: 20 additions & 10 deletions src/Provider/Google.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ class Google extends AbstractProvider
public $scopeSeparator = ' ';

public $scopes = [
'https://www.googleapis.com/auth/userinfo.profile',
'https://www.googleapis.com/auth/userinfo.email',
'profile',
'email',
];

/**
Expand Down Expand Up @@ -41,7 +41,10 @@ public function urlAccessToken()

public function urlUserDetails(\League\OAuth2\Client\Token\AccessToken $token)
{
return 'https://www.googleapis.com/oauth2/v1/userinfo?alt=json&access_token='.$token;
return
'https://www.googleapis.com/plus/v1/people/me?'.
'fields=name(familyName%2CgivenName)%2CdisplayName%2C'.
'emails%2Fvalue%2Cimage%2Furl&alt=json&access_token='.$token;
}

public function userDetails($response, \League\OAuth2\Client\Token\AccessToken $token)
Expand All @@ -50,14 +53,19 @@ public function userDetails($response, \League\OAuth2\Client\Token\AccessToken $

$user = new User();

$imageUrl = (isset($response['picture'])) ? $response['picture'] : null;
$imageUrl = (isset($response['image']) &&
$response['image']->url) ? $response['image']->url : null;
$email =
(isset($response['emails']) &&
count($response['emails']) &&
$response['emails'][0]->value)? $response['emails'][0]->value : null;

$user->exchangeArray([
'uid' => $response['id'],
'name' => $response['name'],
'firstname' => $response['given_name'],
'lastName' => $response['family_name'],
'email' => $response['email'],
'name' => $response['displayName'],
'firstname' => $response['name']->givenName,
'lastName' => $response['name']->familyName,
'email' => $email,
'imageUrl' => $imageUrl,
]);

Expand All @@ -71,12 +79,14 @@ public function userUid($response, \League\OAuth2\Client\Token\AccessToken $toke

public function userEmail($response, \League\OAuth2\Client\Token\AccessToken $token)
{
return isset($response->email) && $response->email ? $response->email : null;
return ($response->emails &&
count($response->emails) &&
$response->emails[0]->value) ? $response->emails[0]->value : null;
}

public function userScreenName($response, \League\OAuth2\Client\Token\AccessToken $token)
{
return [$response->given_name, $response->family_name];
return [$response->name->givenName, $response->name->familyName];
}

public function getAuthorizationUrl($options = array())
Expand Down
4 changes: 2 additions & 2 deletions test/src/Provider/GoogleTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ public function testGetAccessToken()

public function testScopes()
{
$this->assertEquals(['https://www.googleapis.com/auth/userinfo.profile', 'https://www.googleapis.com/auth/userinfo.email'], $this->provider->getScopes());
$this->assertEquals(['profile', 'email'], $this->provider->getScopes());
}

public function testUserData()
Expand All @@ -80,7 +80,7 @@ public function testUserData()
$postResponse->shouldReceive('getBody')->times(1)->andReturn('{"access_token": "mock_access_token", "expires": 3600, "refresh_token": "mock_refresh_token", "uid": 1}');

$getResponse = m::mock('Guzzle\Http\Message\Response');
$getResponse->shouldReceive('getBody')->times(4)->andReturn('{"id": 12345, "name": "mock_name", "given_name": "mock_first_name", "family_name": "mock_last_name", "email": "mock_email"}');
$getResponse->shouldReceive('getBody')->times(4)->andReturn('{"emails": [{"value": "mock_email"}],"id": "12345","displayName": "mock_name","name": {"familyName": "mock_last_name","givenName": "mock_first_name"},"image": {"url": "mock_image_url"}}');

$client = m::mock('Guzzle\Service\Client');
$client->shouldReceive('setBaseUrl')->times(5);
Expand Down

0 comments on commit a3fd10e

Please sign in to comment.