. */ namespace SP\Modules\Web\Controllers\ConfigGeneral; use Exception; use SP\Core\Application; use SP\Core\Bootstrap\Path; use SP\Core\Bootstrap\PathsContext; use SP\Core\Context\Session; use SP\Core\Events\Event; use SP\Core\Events\EventMessage; use SP\Domain\Core\Acl\AclActionsInterface; use SP\Domain\Core\Acl\UnauthorizedPageException; use SP\Domain\Core\Exceptions\SessionTimeout; use SP\Domain\Core\Exceptions\SPException; use SP\Infrastructure\File\FileHandler; use SP\Modules\Web\Controllers\SimpleControllerBase; use SP\Modules\Web\Controllers\Traits\JsonTrait; use SP\Mvc\Controller\SimpleControllerHelper; use function SP\__u; use function SP\processException; /** * Class DownloadLogController */ final class DownloadLogController extends SimpleControllerBase { use JsonTrait; public function __construct( Application $application, SimpleControllerHelper $simpleControllerHelper, private readonly PathsContext $pathsContext ) { parent::__construct($application, $simpleControllerHelper); } public function downloadLogAction(): string { if ($this->configData->isDemoEnabled()) { return __('Ey, this is a DEMO!!'); } try { Session::close(); $file = new FileHandler($this->pathsContext[Path::LOG_FILE]); $file->checkFileExists(); $this->eventDispatcher->notify( 'download.logFile', new Event( $this, EventMessage::build() ->addDescription(__u('File downloaded')) ->addDetail( __u('File'), str_replace( $this->pathsContext[Path::APP], '', $file->getFile() ) ) ) ); $response = $this->router->response(); $response->header('Cache-Control', 'max-age=60, must-revalidate'); $response->header('Content-length', $file->getFileSize()); $response->header('Content-type', $file->getFileType()); $response->header('Content-Description', ' sysPass file'); $response->header('Content-transfer-encoding', 'chunked'); $response->header('Content-Disposition', 'attachment; filename="' . basename($file->getFile()) . '"'); $response->header('Set-Cookie', 'fileDownload=true; path=/'); $response->send(); $file->readChunked(); } catch (Exception $e) { processException($e); $this->eventDispatcher->notify('exception', new Event($e)); } return ''; } /** * @throws SessionTimeout * @throws SPException */ protected function initialize(): void { try { $this->checks(); $this->checkAccess(AclActionsInterface::CONFIG_GENERAL); } catch (UnauthorizedPageException $e) { $this->eventDispatcher->notify('exception', new Event($e)); $this->returnJsonResponseException($e); } } }