OrderCreateController.php 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <?php
  2. namespace Controllers;
  3. use Libs\ResponseLib;
  4. use Models\OrderModel;
  5. use Models\UserModel;
  6. use Psr\Http\Message\ServerRequestInterface;
  7. use Respect\Validation\Validator as v;
  8. use Respect\Validation\Exceptions\ValidationException;
  9. class OrderCreateController
  10. {
  11. private OrderModel $model;
  12. private UserModel $userModel;
  13. public function __construct()
  14. {
  15. $this->model = new OrderModel();
  16. $this->userModel = new UserModel();
  17. }
  18. public function __invoke(ServerRequestInterface $request)
  19. {
  20. $body = json_decode((string)$request->getBody(), true) ?? [];
  21. try {
  22. v::key('table_id', v::intType()->positive())
  23. ->key('user_name', v::stringType()->notEmpty()->alnum('_'))
  24. ->key('company_id', v::intType()->positive())
  25. ->key('order_name', v::stringType()->notEmpty()->alnum(' '))
  26. ->key('order_phone', v::optional(v::stringType()->notEmpty()->length(8, 20)), false)
  27. ->key('status_status', v::stringType()->notEmpty()->in(['Aberta', 'Finalizada', 'Cancelada']))
  28. ->key('kitchen_note', v::optional(v::stringType()), false)
  29. ->assert($body);
  30. } catch (ValidationException $e) {
  31. return ResponseLib::sendFail("Validation failed: " . $e->getFullMessage(), [], "E_VALIDATE")
  32. ->withStatus(400);
  33. }
  34. $tableId = (int) $body['table_id'];
  35. $companyId = (int) $body['company_id'];
  36. $orderName = $body['order_name'];
  37. $orderPhone = $body['order_phone'] ?? '';
  38. $statusStatus = $body['status_status'];
  39. $userName = $body['user_name'];
  40. $kitchenNote = isset($body['kitchen_note']) ? trim($body['kitchen_note']) : '';
  41. // Buscar user_id correspondente ao user_name
  42. $userId = $this->getUserIdByUserName($userName, $companyId);
  43. if (!$userId) {
  44. return ResponseLib::sendFail("Usuário '{$userName}' não encontrado", [], "E_USER_NOT_FOUND")
  45. ->withStatus(404);
  46. }
  47. // Buscar status_id correspondente ao status_status
  48. $statusId = $this->model->getStatusIdByName($statusStatus);
  49. if ($statusId === null) {
  50. return ResponseLib::sendFail("Invalid status_status provided: '{$statusStatus}'", [], "E_VALIDATE")
  51. ->withStatus(400);
  52. }
  53. $created = $this->model->createOrder(
  54. $tableId,
  55. $userId,
  56. $companyId,
  57. $orderName,
  58. $orderPhone,
  59. $statusId,
  60. $kitchenNote
  61. );
  62. return $created
  63. ? ResponseLib::sendOk(['created' => true, 'order_id' => $created])
  64. : ResponseLib::sendFail("Failed to create order", [], "E_DATABASE")->withStatus(500);
  65. }
  66. private function getUserIdByUserName(string $username, int $companyId): ?int
  67. {
  68. $users = $this->userModel->getUsersByCompany($companyId);
  69. foreach ($users as $user) {
  70. if ($user['user_name'] === $username) {
  71. return (int) $user['user_id'];
  72. }
  73. }
  74. return null;
  75. }
  76. }