Files
2025-06-24 14:14:35 +02:00

130 lines
4.0 KiB
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
*/
use Lcobucci\JWT\Parser;
use PrestaShop\Module\PsAccounts\Controller\AbstractShopRestController;
use PrestaShop\Module\PsAccounts\Repository\ConfigurationRepository;
use PrestaShop\Module\PsAccounts\Repository\ShopTokenRepository;
use PrestaShop\Module\PsAccounts\Repository\UserTokenRepository;
use PrestaShop\Module\PsAccounts\Service\ShopLinkAccountService;
class ps_AccountsApiV1ShopLinkAccountModuleFrontController extends AbstractShopRestController
{
/**
* @var ConfigurationRepository
*/
private $configuration;
/**
* @var Parser
*/
private $jwtParser;
/**
* @var UserTokenRepository
*/
private $userTokenRepository;
/**
* @var ShopTokenRepository
*/
private $shopTokenRepository;
/**
* @var ShopLinkAccountService
*/
private $shopLinkAccountService;
/**
* ps_AccountsApiV1ShopAccountModuleFrontController constructor.
*
* @throws Exception
*/
public function __construct()
{
parent::__construct();
$this->configuration = $this->module->getService(ConfigurationRepository::class);
$this->userTokenRepository = $this->module->getService(UserTokenRepository::class);
$this->shopTokenRepository = $this->module->getService(ShopTokenRepository::class);
$this->shopLinkAccountService = $this->module->getService(ShopLinkAccountService::class);
$this->jwtParser = new Parser();
}
/**
* Expected Payload keys :
* - shop_token
* - shop_refresh_token
* - user_token
* - user_refresh_token
* - employee_id
*
* @param Shop $shop
* @param array $payload
*
* @return array|void
*
* @throws Exception
*/
public function update($shop, array $payload)
{
list($shopRefreshToken, $userRefreshToken, $shopToken, $userToken, $employeeId) = [
$payload['shop_refresh_token'],
$payload['user_refresh_token'],
$payload['shop_token'],
$payload['user_token'],
// FIXME : temporary fix
(array_key_exists('employee_id', $payload) ? $payload['employee_id'] : ''),
];
$verifyTokens = $this->module->getParameter('ps_accounts.verify_account_tokens');
if ($verifyTokens) {
$shopToken = $this->shopTokenRepository->verifyToken($shopToken, $shopRefreshToken);
$userToken = $this->userTokenRepository->verifyToken($userToken, $userRefreshToken);
}
$this->shopTokenRepository->updateCredentials($shopToken, $shopRefreshToken);
$this->userTokenRepository->updateCredentials($userToken, $userRefreshToken);
$this->configuration->updateEmployeeId($employeeId);
return [
'success' => true,
'message' => 'Link Account stored successfully',
];
}
/**
* @param Shop $shop
* @param array $payload
*
* @return array|void
*/
public function delete($shop, array $payload)
{
$this->shopLinkAccountService->resetLinkAccount();
return [
'success' => true,
'message' => 'Link Account deleted successfully',
];
}
}