test(IT): Test Config General use cases (WIP)

Signed-off-by: Rubén D <nuxsmin@syspass.org>
This commit is contained in:
Rubén D
2024-09-06 08:06:01 +02:00
parent e2640355a4
commit 04554ed079
6 changed files with 235 additions and 206 deletions

View File

@@ -25,15 +25,18 @@
namespace SP\Modules\Web\Controllers\ConfigGeneral;
use Exception;
use Klein\Response;
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\Common\Attributes\Action;
use SP\Domain\Common\Dtos\ActionResponse;
use SP\Domain\Common\Enums\ResponseStatus;
use SP\Domain\Common\Enums\ResponseType;
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;
@@ -41,8 +44,8 @@ use SP\Modules\Web\Controllers\SimpleControllerBase;
use SP\Modules\Web\Controllers\Traits\JsonTrait;
use SP\Mvc\Controller\SimpleControllerHelper;
use function SP\__;
use function SP\__u;
use function SP\processException;
/**
* Class DownloadLogController
@@ -59,53 +62,44 @@ final class DownloadLogController extends SimpleControllerBase
parent::__construct($application, $simpleControllerHelper);
}
public function downloadLogAction(): string
#[Action(ResponseType::CALLBACK)]
public function downloadLogAction(): ActionResponse
{
if ($this->configData->isDemoEnabled()) {
return __('Ey, this is a DEMO!!');
return ActionResponse::warning(__('Ey, this is a DEMO!!'));
}
try {
Session::close();
Session::close();
$file = new FileHandler($this->pathsContext[Path::LOG_FILE]);
$file->checkFileExists();
$file = new FileHandler($this->pathsContext[Path::LOG_FILE]);
$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()
)
)
)
);
$this->eventDispatcher->notify(
'download.logFile',
new Event(
$this,
EventMessage::build(__u('File downloaded'))
->addDetail(__u('File'), $file->getName())
)
);
$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();
return new ActionResponse(
ResponseStatus::OK,
function (Response $response) use ($file) {
$response->header('Cache-Control', 'max-age=60, must-revalidate')
->header('Content-length', $file->getFileSize())
->header('Content-type', $file->getFileType())
->header('Content-Description', ' sysPass file')
->header('Content-transfer-encoding', 'chunked')
->header(
'Content-Disposition',
sprintf("attachment; filename=\"%s\"", basename($file->getName()))
)
->header('Set-Cookie', 'fileDownload=true; path=/')
->send();
$file->readChunked();
} catch (Exception $e) {
processException($e);
$this->eventDispatcher->notify('exception', new Event($e));
}
return '';
$file->readChunked();
}
);
}
/**
@@ -114,13 +108,7 @@ final class DownloadLogController extends SimpleControllerBase
*/
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);
}
$this->checks();
$this->checkAccess(AclActionsInterface::CONFIG_GENERAL);
}
}