TableUpdateController.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. <?php
  2. namespace Controllers;
  3. use Libs\ResponseLib;
  4. use Models\TableModel;
  5. use Psr\Http\Message\ServerRequestInterface;
  6. use Respect\Validation\Validator as v;
  7. use Respect\Validation\Exceptions\ValidationException;
  8. class TableUpdateController
  9. {
  10. private TableModel $model;
  11. public function __construct()
  12. {
  13. $this->model = new TableModel();
  14. }
  15. public function __invoke(ServerRequestInterface $request)
  16. {
  17. $body = json_decode((string)$request->getBody(), true) ?? [];
  18. // Validação dos campos com Respect Validation
  19. try {
  20. v::key('table_number', v::alnum(' ')->notEmpty())
  21. ->key('company_id', v::intType()->positive())
  22. ->key('status_status', v::stringType()->notEmpty())
  23. ->assert($body);
  24. } catch (ValidationException $e) {
  25. return ResponseLib::sendFail("Validation failed: " . $e->getFullMessage(), [], "E_VALIDATE")->withStatus(422);
  26. }
  27. $tableNumber = $body['table_number'];
  28. $companyId = $body['company_id'];
  29. $statusStatus = $body['status_status'];
  30. $statusId = $this->model->getStatusIdByName($statusStatus);
  31. if ($statusId === null) {
  32. return ResponseLib::sendFail("Invalid status_status: '{$statusStatus}'", [], "E_VALIDATE")->withStatus(400);
  33. }
  34. $updated = $this->model->updateTableByNumber((string)$tableNumber, (int)$companyId, $statusId);
  35. return $updated
  36. ? ResponseLib::sendOk(['updated' => true])
  37. : ResponseLib::sendFail("Failed to Update Status or Table Not Found", [], "E_DATABASE")->withStatus(404);
  38. }
  39. }