MeController.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. namespace Controllers;
  3. use Libs\Database;
  4. use Libs\ResponseLib;
  5. use Psr\Http\Message\ServerRequestInterface;
  6. class MeController
  7. {
  8. public function __invoke(ServerRequestInterface $request)
  9. {
  10. $userId = (int) ($request->getAttribute('user_id') ?? 0);
  11. if ($userId <= 0) {
  12. return ResponseLib::sendFail("Unauthorized: Missing authenticated user", [], "E_VALIDATE")->withStatus(401);
  13. }
  14. $pdo = Database::pdo();
  15. $stmt = $pdo->prepare(
  16. 'SELECT
  17. u.user_id,
  18. u.company_id,
  19. u.user_name,
  20. u.user_phone,
  21. u.user_email,
  22. u.user_role,
  23. u.user_created_at,
  24. c.company_name,
  25. c.company_cnpj,
  26. c.company_logo,
  27. c.company_created_at
  28. FROM "user" u
  29. INNER JOIN company c ON c.company_id = u.company_id
  30. WHERE u.user_id = :user_id
  31. AND u.user_deleted_at = \'infinity\'
  32. AND c.company_deleted_at = \'infinity\'
  33. LIMIT 1'
  34. );
  35. $stmt->execute(['user_id' => $userId]);
  36. $user = $stmt->fetch(\PDO::FETCH_ASSOC);
  37. if (!$user) {
  38. return ResponseLib::sendFail("User not found", [], "E_NOT_FOUND")->withStatus(404);
  39. }
  40. $data = [
  41. 'user_id' => (int) $user['user_id'],
  42. 'company_id' => (int) $user['company_id'],
  43. 'user_name' => $user['user_name'],
  44. 'user_phone' => $user['user_phone'],
  45. 'user_email' => $user['user_email'],
  46. 'user_role' => $user['user_role'],
  47. 'user_created_at' => $user['user_created_at'],
  48. 'company' => [
  49. 'company_id' => (int) $user['company_id'],
  50. 'company_name' => $user['company_name'],
  51. 'company_cnpj' => $user['company_cnpj'],
  52. 'company_logo' => $user['company_logo'],
  53. 'company_created_at' => $user['company_created_at'],
  54. ],
  55. ];
  56. return ResponseLib::sendOk($data);
  57. }
  58. }