OrderbookUpdateStatusController.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. namespace Controllers;
  3. use Libs\ResponseLib;
  4. use Models\OrderbookModel;
  5. use Psr\Http\Message\ServerRequestInterface;
  6. use Respect\Validation\Exceptions\ValidationException;
  7. use Respect\Validation\Validator as val;
  8. class OrderbookUpdateStatusController
  9. {
  10. private OrderbookModel $orderbookModel;
  11. public function __construct()
  12. {
  13. $this->orderbookModel = new OrderbookModel();
  14. }
  15. public function __invoke(ServerRequestInterface $request)
  16. {
  17. $companyId = (int)($request->getAttribute('api_company_id') ?? 0);
  18. if ($companyId <= 0) {
  19. return ResponseLib::sendFail('Empresa autenticada não encontrada', [], 'E_VALIDATE')->withStatus(401);
  20. }
  21. $body = json_decode((string)$request->getBody(), true) ?? [];
  22. try {
  23. val::key('orderbook_id', val::intType()->positive())
  24. ->key('status_id', val::intType()->min(0))
  25. ->assert($body);
  26. } catch (ValidationException $e) {
  27. return ResponseLib::sendFail('Validation failed: ' . $e->getFullMessage(), [], 'E_VALIDATE')->withStatus(400);
  28. }
  29. $orderbookId = (int)$body['orderbook_id'];
  30. $statusId = (int)$body['status_id'];
  31. try {
  32. $orderbook = $this->orderbookModel->findByIdWithToken($orderbookId);
  33. } catch (\Throwable $e) {
  34. return ResponseLib::sendFail('Falha ao consultar orderbook: ' . $e->getMessage(), [], 'E_DATABASE')->withStatus(500);
  35. }
  36. if (!$orderbook) {
  37. return ResponseLib::sendFail('Orderbook não encontrado', ['orderbook_id' => $orderbookId], 'E_NOT_FOUND')->withStatus(404);
  38. }
  39. $orderCompanyId = (int)($orderbook['company_id'] ?? 0);
  40. if ($orderCompanyId <= 0 || $orderCompanyId !== $companyId) {
  41. return ResponseLib::sendFail('Orderbook não pertence à empresa autenticada', ['orderbook_id' => $orderbookId], 'E_FORBIDDEN')->withStatus(403);
  42. }
  43. try {
  44. $this->orderbookModel->updateStatus($orderbookId, $statusId);
  45. } catch (\Throwable $e) {
  46. return ResponseLib::sendFail('Falha ao atualizar status do orderbook: ' . $e->getMessage(), [], 'E_DATABASE')->withStatus(500);
  47. }
  48. return ResponseLib::sendOk([
  49. 'orderbook_id' => $orderbookId,
  50. 'status_id' => $statusId,
  51. ], 'S_ORDERBOOK_STATUS_UPDATED');
  52. }
  53. }