Вход Регистрация
Файл: vendor/lusitanian/oauth/src/OAuth/OAuth1/Service/BitBucket.php
Строк: 186
<?php
namespace OAuthOAuth1Service;

use 
OAuthOAuth1SignatureSignatureInterface;
use 
OAuthOAuth1TokenStdOAuth1Token;
use 
OAuthCommonHttpExceptionTokenResponseException;
use 
OAuthCommonHttpUriUri;
use 
OAuthCommonConsumerCredentials;
use 
OAuthCommonHttpUriUriInterface;
use 
OAuthCommonStorageTokenStorageInterface;
use 
OAuthCommonHttpClientClientInterface;

class 
BitBucket extends AbstractService
{
    public function 
__construct(Credentials $credentialsClientInterface $httpClientTokenStorageInterface $storageSignatureInterface $signatureUriInterface $baseApiUri null)
    {
        
parent::__construct($credentials$httpClient$storage$signature$baseApiUri);
        if( 
null === $baseApiUri ) {
            
$this->baseApiUri = new Uri('https://bitbucket.org/api/1.0/');
        }
    }

    
/**
     * @return OAuthCommonHttpUriUriInterface
     */
    
public function getRequestTokenEndpoint()
    {
        return new 
Uri('https://bitbucket.org/!api/1.0/oauth/request_token');
    }

    
/**
     * @return OAuthCommonHttpUriUriInterface
     */
    
public function getAuthorizationEndpoint()
    {
        return new 
Uri('https://bitbucket.org/!api/1.0/oauth/authenticate');
    }

    
/**
     * @return OAuthCommonHttpUriUriInterface
     */
    
public function getAccessTokenEndpoint()
    {
        return new 
Uri('https://bitbucket.org/!api/1.0/oauth/access_token');
    }

    
/**
     * We need a separate request token parser only to verify the `oauth_callback_confirmed` parameter. For the actual
     * parsing we can just use the default access token parser.
     *
     * @param string $responseBody
     * @return OAuthCommonTokenTokenInterface|OAuthOAuth1TokenStdOAuth1Token
     * @throws OAuthCommonHttpExceptionTokenResponseException
     */
    
protected function parseRequestTokenResponse($responseBody)
    {
        
parse_str($responseBody$data);

        if( 
null === $data || !is_array($data) ) {
            throw new 
TokenResponseException('Unable to parse response.');
        } elseif (!isset(
$data['oauth_callback_confirmed']) || $data['oauth_callback_confirmed'] != 'true') {
            throw new 
TokenResponseException('Error in retrieving token.');
        }

        return 
$this->parseAccessTokenResponse($responseBody);
    }

    
/**
     * @param string $responseBody
     * @return OAuthCommonTokenTokenInterface|OAuthOAuth1TokenStdOAuth1Token
     * @throws OAuthCommonHttpExceptionTokenResponseException
     */
    
protected function parseAccessTokenResponse($responseBody)
    {

        
parse_str($responseBody$data);

        if( 
null === $data || !is_array($data) ) {
            throw new 
TokenResponseException('Unable to parse response.');
        } elseif( isset(
$data['error'] ) ) {
            throw new 
TokenResponseException('Error in retrieving token: "' $data['error'] . '"');
        }

        
$token = new StdOAuth1Token();

        
$token->setRequestToken$data['oauth_token'] );
        
$token->setRequestTokenSecret$data['oauth_token_secret'] );
        
$token->setAccessToken$data['oauth_token'] );
        
$token->setAccessTokenSecret$data['oauth_token_secret'] );

        
$token->setEndOfLife(StdOAuth1Token::EOL_NEVER_EXPIRES);
        unset( 
$data['oauth_token'], $data['oauth_token_secret'] );
        
$token->setExtraParams$data );

        return 
$token;
    }
}
Онлайн: 2
Реклама