HEX
Server: Apache
System: Linux srv13.cpanelhost.cl 3.10.0-962.3.2.lve1.5.38.el7.x86_64 #1 SMP Thu Jun 18 05:28:41 EDT 2020 x86_64
User: cca63905 (4205)
PHP: 7.3.20
Disabled: NONE
Upload Files
File: //proc/self/cwd/nueva/modules/wnetsecurity/src/Repository/Configuration/AccessTokenRepository.php
<?php
/**
 * Copyright since 2014 Waynet Sp. z o.o.
 * PrestaShop is an International Registered Trademark & Property of PrestaShop SA
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Open Software License (OSL 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/OSL-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 kontakt@waynet.pl so we can send you a copy immediately.
 *
 * DISCLAIMER
 *
 * Do not edit or add to this file if you wish to upgrade PrestaShop to newer
 * versions in the future. If you wish to customize PrestaShop for your
 * needs please refer to https://devdocs.prestashop-project.org/ for more information.
 *
 * @author    Waynet Sp. z o.o. <kontakt@waynet.pl>
 * @copyright since 2014 Waynet Sp. z o.o.
 * @license   https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
 */

declare(strict_types=1);

namespace Waynet\Security\Repository\Configuration;

use Waynet\OAuth2\Client\Token\AccessTokenInterface;
use Waynet\OAuth2\Client\Token\AccessTokenRepositoryInterface;
use Waynet\OAuth2\Client\Token\BearerToken;
use Waynet\Security\Exception\UnableToDecryptDataException;

class AccessTokenRepository extends ResettableConfigurationRepository implements AccessTokenRepositoryInterface
{
    private const ACCESS_TOKEN = 'WNET_SECURITY_API_ACCESS_TOKEN';
    private const ACCESS_TOKEN_EXPIRES_AT = 'WNET_SECURITY_API_ACCESS_TOKEN_EXPIRES_AT';

    public function getToken(): ?AccessTokenInterface
    {
        if (!$token = $this->getAccessToken()) {
            return null;
        }

        return new BearerToken(
            $token,
            $this->getAccessTokenExpiresAt()
        );
    }

    public function saveToken(AccessTokenInterface $accessToken): void
    {
        $this->runTransaction(function () use ($accessToken) {
            return $this->setAccessToken($accessToken->getToken())
                && $this->setAccessTokenExpiresAt($accessToken->getExpiresAt());
        });
    }

    public function deleteToken(): void
    {
        $this->runTransaction(function () {
            return $this->setAccessToken(null)
                && $this->setAccessTokenExpiresAt(null);
        });
    }

    /**
     * @throws UnableToDecryptDataException|\Exception
     */
    private function getAccessToken(): ?string
    {
        return $this->getEncrypted(self::ACCESS_TOKEN);
    }

    private function setAccessToken(?string $accessToken): bool
    {
        return $this->setEncrypted(self::ACCESS_TOKEN, $accessToken);
    }

    private function getAccessTokenExpiresAt(): ?int
    {
        if (!$timestamp = (int) $this->get(self::ACCESS_TOKEN_EXPIRES_AT)) {
            return null;
        }

        return $timestamp;
    }

    private function setAccessTokenExpiresAt(?int $expiresAt): bool
    {
        return $this->set(self::ACCESS_TOKEN_EXPIRES_AT, $expiresAt);
    }
}