. */ namespace SP\Modules\Web\Controllers\ConfigEncryption; use Exception; use JsonException; use SP\Core\Acl\UnauthorizedPageException; use SP\Core\Application; use SP\Core\Crypt\Hash; use SP\Core\Crypt\Session as CryptSession; use SP\Core\Events\Event; use SP\Core\Events\EventMessage; use SP\Core\Exceptions\SessionTimeout; use SP\Domain\Core\Acl\AclActionsInterface; use SP\Domain\Crypt\Ports\MasterPassServiceInterface; use SP\Http\JsonResponse; use SP\Modules\Web\Controllers\SimpleControllerBase; use SP\Modules\Web\Controllers\Traits\JsonTrait; use SP\Mvc\Controller\SimpleControllerHelper; /** * Class RefreshController */ final class RefreshController extends SimpleControllerBase { use JsonTrait; private MasterPassServiceInterface $masterPassService; public function __construct( Application $application, SimpleControllerHelper $simpleControllerHelper, MasterPassServiceInterface $masterPassService ) { parent::__construct($application, $simpleControllerHelper); $this->masterPassService = $masterPassService; } /** * Refresh master password hash * * @return bool * @throws JsonException */ public function refreshAction(): bool { try { if ($this->config->getConfigData()->isDemoEnabled()) { return $this->returnJsonResponse(JsonResponse::JSON_WARNING, __u('Ey, this is a DEMO!!')); } $this->masterPassService->updateConfig(Hash::hashKey(CryptSession::getSessionKey($this->session))); $this->eventDispatcher->notify( 'refresh.masterPassword.hash', new Event($this, EventMessage::factory()->addDescription(__u('Master password hash updated'))) ); return $this->returnJsonResponse(JsonResponse::JSON_SUCCESS, __u('Master password hash updated')); } catch (Exception $e) { processException($e); $this->eventDispatcher->notify('exception', new Event($e)); return $this->returnJsonResponse( JsonResponse::JSON_ERROR, __u('Error while updating the master password hash') ); } } /** * @return void * @throws JsonException * @throws SessionTimeout */ protected function initialize(): void { try { $this->checks(); $this->checkAccess(AclActionsInterface::CONFIG_CRYPT); } catch (UnauthorizedPageException $e) { $this->eventDispatcher->notify('exception', new Event($e)); $this->returnJsonResponseException($e); } } }