. */ namespace SP\Modules\Web\Controllers\ConfigGeneral; use Exception; use JsonException; 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\Infrastructure\File\FileHandler; use SP\Modules\Web\Controllers\SimpleControllerBase; use SP\Modules\Web\Controllers\Traits\JsonTrait; /** * Class DownloadLogController */ final class DownloadLogController extends SimpleControllerBase { use JsonTrait; public function downloadLogAction(): string { if ($this->configData->isDemoEnabled()) { return __('Ey, this is a DEMO!!'); } try { Session::close(); $file = new FileHandler(LOG_FILE); $file->checkFileExists(); $this->eventDispatcher->notify( 'download.logFile', new Event( $this, EventMessage::factory() ->addDescription(__u('File downloaded')) ->addDetail(__u('File'), str_replace(APP_ROOT, '', $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 JsonException * @throws SessionTimeout */ 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); } } }