View file core/libs/oAuth/vendor/hybridauth/hybridauth/src/Provider/BitBucket.php

File size: 2.65Kb
<?php
/*!
* Hybridauth
* https://hybridauth.github.io | https://github.com/hybridauth/hybridauth
*  (c) 2017 Hybridauth authors | https://hybridauth.github.io/license.html
*/

namespace Hybridauth\Provider;

use Hybridauth\Adapter\OAuth2;
use Hybridauth\Exception\UnexpectedApiResponseException;
use Hybridauth\Data;
use Hybridauth\User;

/**
 * BitBucket OAuth2 provider adapter.
 */
class BitBucket extends OAuth2
{
    /**
    * {@inheritdoc}
    */
    public $scope = 'email';

    /**
    * {@inheritdoc}
    */
    protected $apiBaseUrl = 'https://api.bitbucket.org/2.0/';

    /**
    * {@inheritdoc}
    */
    protected $authorizeUrl = 'https://bitbucket.org/site/oauth2/authorize';

    /**
    * {@inheritdoc}
    */
    protected $accessTokenUrl = 'https://bitbucket.org/site/oauth2/access_token';

    /**
    * {@inheritdoc}
    */
    protected $apiDocumentation = 'https://developer.atlassian.com/bitbucket/concepts/oauth2.html';

    /**
    * {@inheritdoc}
    */
    public function getUserProfile()
    {
        $response = $this->apiRequest('user');

        $data = new Data\Collection($response);

        if (! $data->exists('uuid')) {
            throw new UnexpectedApiResponseException('Provider API returned an unexpected response.');
        }

        $userProfile = new User\Profile();

        $userProfile->identifier  = $data->get('uuid');
        $userProfile->displayName = $data->get('display_name');
        $userProfile->email       = $data->get('email');
        $userProfile->webSiteURL  = $data->get('website');
        $userProfile->region      = $data->get('location');

        $userProfile->displayName = $userProfile->displayName ?: $data->get('username');

        if (empty($userProfile->email) && strpos($this->scope, 'email') !== false) {
            try {
                $userProfile = $this->requestUserEmail($userProfile);
            }
            // user email is not mandatory so keep it quite
            catch (\Exception $e) {
            }
        }

        return $userProfile;
    }

    /**
     * Request user email
     *
     * @param $userProfile
     *
     * @return User\Profile
     */
    protected function requestUserEmail($userProfile)
    {
        $response = $this->apiRequest('user/emails');

        foreach ($response->values as $idx => $item) {
            if (! empty($item->is_primary) && $item->is_primary == true) {
                $userProfile->email = $item->email;

                if (! empty($item->is_confirmed) && $item->is_confirmed == true) {
                    $userProfile->emailVerified = $userProfile->email;
                }

                break;
            }
        }

        return $userProfile;
    }
}