src/OAuth2/Client/Provider/Payments.php
<?php
namespace MDOAuth\OAuth2\Client\Provider;
use League\OAuth2\Client\Provider\AbstractProvider;
use League\OAuth2\Client\Provider\Exception\IdentityProviderException;
use League\OAuth2\Client\Token\AccessToken;
use Psr\Http\Message\ResponseInterface;
use League\OAuth2\Client\Tool\BearerAuthorizationTrait;
class Payments extends AbstractProvider
{
use BearerAuthorizationTrait;
const CLIENT_ID = 'webapp';
const DEFAULT_BASE_URL = 'https://payments-backend.mdirector.com';
protected $baseUrl = false;
public function __construct(array $options = [], array $collaborators = [])
{
parent::__construct($options, $collaborators);
$this->clientId = self::CLIENT_ID;
if (!$this->baseUrl) {
$this->baseUrl = self::DEFAULT_BASE_URL;
}
}
public function getBaseAuthorizationUrl()
{
return null;
}
public function getBaseAccessTokenUrl(array $params)
{
return $this->baseUrl . '/oauth';
}
public function getResourceOwnerDetailsUrl(AccessToken $token)
{
return null;
}
protected function getDefaultScopes()
{
return null;
}
protected function checkResponse(ResponseInterface $response, $data)
{
if (!empty($data['error'])) {
$error = $data['error'];
if (isset($data['error_description'])) {
$error .= ': ' . $data['error_description'];
}
throw new IdentityProviderException($error, 0, $data);
}
}
protected function createResourceOwner(array $response, AccessToken $token)
{
return null;
}
}