File: //proc/self/root/proc/self/cwd/nueva/modules/ps_accounts/src/Account/Session/ShopSession.php
<?php
/**
* Copyright since 2007 PrestaShop SA and Contributors
* PrestaShop is an International Registered Trademark & Property of PrestaShop SA
*
* NOTICE OF LICENSE
*
* This source file is subject to the Academic Free License version 3.0
* that is bundled with this package in the file LICENSE.md.
* It is also available through the world-wide-web at this URL:
* https://opensource.org/licenses/AFL-3.0
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@prestashop.com so we can send you a copy immediately.
*
* @author PrestaShop SA and Contributors <contact@prestashop.com>
* @copyright Since 2007 PrestaShop SA and Contributors
* @license https://opensource.org/licenses/AFL-3.0 Academic Free License version 3.0
*/
namespace PrestaShop\Module\PsAccounts\Account\Session;
use PrestaShop\Module\PsAccounts\Account\Exception\RefreshTokenException;
use PrestaShop\Module\PsAccounts\Account\Token\Token;
use PrestaShop\Module\PsAccounts\Hook\ActionShopAccessTokenRefreshAfter;
use PrestaShop\Module\PsAccounts\Repository\ConfigurationRepository;
use PrestaShop\Module\PsAccounts\Service\OAuth2\Exception\InvalidScopeException;
use PrestaShop\Module\PsAccounts\Service\OAuth2\OAuth2Exception;
use PrestaShop\Module\PsAccounts\Service\OAuth2\OAuth2ServerException;
use PrestaShop\Module\PsAccounts\Service\OAuth2\OAuth2Service;
use PrestaShop\Module\PsAccounts\Service\OAuth2\Resource\AccessToken;
class ShopSession extends Session implements SessionInterface
{
/**
* @var ConfigurationRepository
*/
protected $configurationRepository;
/**
* @var OAuth2Service
*/
protected $oAuth2Service;
/**
* @var string
*/
protected $tokenAudience;
/**
* @param ConfigurationRepository $configurationRepository
* @param OAuth2Service $oAuth2Service
* @param string $tokenAudience
*/
public function __construct(
ConfigurationRepository $configurationRepository,
OAuth2Service $oAuth2Service,
$tokenAudience
) {
parent::__construct();
$this->configurationRepository = $configurationRepository;
$this->oAuth2Service = $oAuth2Service;
$this->tokenAudience = $tokenAudience;
}
/**
* @param bool $forceRefresh
* @param bool $throw
* @param array|null $scope
* @param array|null $audience
*
* @return Token
*
* @throws RefreshTokenException
*/
public function getValidToken($forceRefresh = false, $throw = true, array $scope = null, array $audience = null)
{
if ($scope === null) {
$scope = ($this->getStatusManager()->identityVerified() ? [
'shop.verified',
] : []);
}
if ($audience === null) {
$audience = [
'store/' . $this->getStatusManager()->getCloudShopId(),
$this->tokenAudience,
];
}
return parent::getValidToken($forceRefresh, $throw, $scope, $audience);
}
/**
* @param string $refreshToken
* @param array $scope
* @param array $audience
*
* @return Token
*
* @throws RefreshTokenException
*/
public function refreshToken($refreshToken = null, array $scope = [], array $audience = [])
{
try {
try {
$accessToken = $this->getAccessToken($scope, $audience);
} catch (InvalidScopeException $e) {
$accessToken = $this->fallbackRefresh($e, 'shop.verified', $scope, $audience);
}
$this->setToken(
$accessToken->access_token,
$accessToken->refresh_token
);
$token = $this->getToken();
\Hook::exec(ActionShopAccessTokenRefreshAfter::getName(), ['token' => $token]);
return $token;
} catch (OAuth2Exception $e) {
} catch (\Exception $e) {
} catch (\Throwable $e) {
}
throw new RefreshTokenException('Unable to refresh shop token : ' . $e->getMessage(), 0, $e);
}
/**
* @return Token
*/
public function getToken()
{
return new Token($this->configurationRepository->getAccessToken());
}
/**
* @param string $token
* @param string $refreshToken
*
* @return void
*/
public function setToken($token, $refreshToken = null)
{
$this->configurationRepository->updateAccessToken($token);
}
/**
* @return void
*/
public function cleanup()
{
$this->configurationRepository->updateAccessToken('');
}
/**
* @param array $scope
* @param array $audience
*
* @return AccessToken
*
* @throws OAuth2Exception
*/
protected function getAccessToken(array $scope = [], array $audience = [])
{
return $this->oAuth2Service->getAccessTokenByClientCredentials($scope, $audience);
}
/**
* @param OAuth2ServerException $e
* @param string $filterScope
* @param array $scope
* @param array $audience
*
* @return AccessToken
*
* @throws OAuth2Exception
*/
protected function fallbackRefresh($e, $filterScope, array $scope, array $audience)
{
if (in_array($filterScope, $scope) &&
str_contains($e->getMessage(), $filterScope)
) {
$this->getStatusManager()->setIsVerified(false);
$this->resetRefreshTokenErrors();
$accessToken = $this->getAccessToken(array_filter($scope, function ($scp) use ($filterScope) {
return $scp !== $filterScope;
}), $audience);
} else {
throw $e;
}
return $accessToken;
}
}