Viewing file: BitbucketProvider.php (2.84 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Laravel\Socialite\Two;
use Exception; use GuzzleHttp\RequestOptions; use Illuminate\Support\Arr;
class BitbucketProvider extends AbstractProvider implements ProviderInterface { /** * The scopes being requested. * * @var array */ protected $scopes = ['email'];
/** * The separating character for the requested scopes. * * @var string */ protected $scopeSeparator = ' ';
/** * {@inheritdoc} */ protected function getAuthUrl($state) { return $this->buildAuthUrlFromBase('https://bitbucket.org/site/oauth2/authorize', $state); }
/** * {@inheritdoc} */ protected function getTokenUrl() { return 'https://bitbucket.org/site/oauth2/access_token'; }
/** * {@inheritdoc} */ protected function getUserByToken($token) { $response = $this->getHttpClient()->get('https://api.bitbucket.org/2.0/user', [ RequestOptions::QUERY => ['access_token' => $token], ]);
$user = json_decode($response->getBody(), true);
if (in_array('email', $this->scopes, true)) { $user['email'] = $this->getEmailByToken($token); }
return $user; }
/** * Get the email for the given access token. * * @param string $token * @return string|null */ protected function getEmailByToken($token) { $emailsUrl = 'https://api.bitbucket.org/2.0/user/emails?access_token='.$token;
try { $response = $this->getHttpClient()->get($emailsUrl); } catch (Exception $e) { return; }
$emails = json_decode($response->getBody(), true);
foreach ($emails['values'] as $email) { if ($email['type'] === 'email' && $email['is_primary'] && $email['is_confirmed']) { return $email['email']; } } }
/** * {@inheritdoc} */ protected function mapUserToObject(array $user) { return (new User)->setRaw($user)->map([ 'id' => $user['uuid'], 'nickname' => $user['username'], 'name' => Arr::get($user, 'display_name'), 'email' => Arr::get($user, 'email'), 'avatar' => Arr::get($user, 'links.avatar.href'), ]); }
/** * Get the access token for the given code. * * @param string $code * @return string */ public function getAccessToken($code) { $response = $this->getHttpClient()->post($this->getTokenUrl(), [ RequestOptions::AUTH => [$this->clientId, $this->clientSecret], RequestOptions::HEADERS => ['Accept' => 'application/json'], RequestOptions::FORM_PARAMS => $this->getTokenFields($code), ]);
return json_decode($response->getBody(), true)['access_token']; } }
|