test(IT): Test Client use cases

Signed-off-by: Rubén D <nuxsmin@syspass.org>
This commit is contained in:
Rubén D
2024-08-29 18:38:59 +02:00
parent 04edbc3b9f
commit e2d67fef14
13 changed files with 574 additions and 310 deletions

View File

@@ -25,16 +25,22 @@
namespace SP\Modules\Web\Controllers\Client;
use Exception;
use JsonException;
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\ResponseType;
use SP\Domain\Common\Services\ServiceException;
use SP\Domain\Core\Acl\AclActionsInterface;
use SP\Domain\Core\Exceptions\ConstraintException;
use SP\Domain\Core\Exceptions\QueryException;
use SP\Domain\Core\Exceptions\SPException;
use SP\Domain\Core\Exceptions\ValidationException;
use SP\Domain\Http\Dtos\JsonMessage;
use SP\Modules\Web\Controllers\Traits\JsonTrait;
use SP\Mvc\Controller\ItemTrait;
use function SP\__u;
/**
* Class SaveEditController
*/
@@ -46,49 +52,41 @@ final class SaveEditController extends ClientSaveBase
/**
* Saves edit action
*
* @param int $id
* @param int $id
*
* @return bool
* @throws JsonException
* @return ActionResponse
* @throws ValidationException
* @throws ServiceException
* @throws ConstraintException
* @throws QueryException
* @throws SPException
*/
public function saveEditAction(int $id): bool
#[Action(ResponseType::JSON)]
public function saveEditAction(int $id): ActionResponse
{
try {
if (!$this->acl->checkUserAccess(AclActionsInterface::CLIENT_EDIT)) {
return $this->returnJsonResponse(
JsonMessage::JSON_ERROR,
__u('You don\'t have permission to do this operation')
);
}
$this->form->validateFor(AclActionsInterface::CLIENT_EDIT, $id);
$this->clientService->update($this->form->getItemData());
$this->eventDispatcher->notify(
'edit.client',
new Event(
$this,
EventMessage::build()->addDescription(__u('Client updated'))->addDetail(__u('Client'), $id)
)
);
$this->updateCustomFieldsForItem(
AclActionsInterface::CLIENT,
$id,
$this->request,
$this->customFieldService
);
return $this->returnJsonResponse(JsonMessage::JSON_SUCCESS, __u('Client updated'));
} catch (ValidationException $e) {
return $this->returnJsonResponseException($e);
} catch (Exception $e) {
processException($e);
$this->eventDispatcher->notify('exception', new Event($e));
return $this->returnJsonResponseException($e);
if (!$this->acl->checkUserAccess(AclActionsInterface::CLIENT_EDIT)) {
return ActionResponse::error(__u('You don\'t have permission to do this operation'));
}
$this->form->validateFor(AclActionsInterface::CLIENT_EDIT, $id);
$this->clientService->update($this->form->getItemData());
$this->eventDispatcher->notify(
'edit.client',
new Event(
$this,
EventMessage::build()->addDescription(__u('Client updated'))->addDetail(__u('Client'), $id)
)
);
$this->updateCustomFieldsForItem(
AclActionsInterface::CLIENT,
$id,
$this->request,
$this->customFieldService
);
return ActionResponse::ok(__u('Client updated'));
}
}