RegisterController.php 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <?php
  2. namespace Controllers;
  3. use Libs\Logger;
  4. use Libs\Payload;
  5. use Libs\Roles;
  6. use Libs\Validator;
  7. use Models\UserModel;
  8. use Psr\Http\Message\ServerRequestInterface;
  9. class RegisterController
  10. {
  11. private UserModel $userModel;
  12. public function __construct()
  13. {
  14. $this->userModel = new UserModel();
  15. }
  16. public function __invoke(ServerRequestInterface $request)
  17. {
  18. // company_id NÃO vem mais do body: é herdado do usuário autenticado (JWT).
  19. // Isso impede que alguém se registre sob uma empresa arbitrária.
  20. $userId = (int) ($request->getAttribute('user_id') ?? 0);
  21. if ($userId <= 0) {
  22. return Payload::fail('Unauthorized: Missing authenticated user', [], 'E_VALIDATE', 401);
  23. }
  24. $body = json_decode((string) $request->getBody(), true) ?: [];
  25. $name = $body['name'] ?? $body['user_name'] ?? null;
  26. $phone = $body['phone'] ?? $body['user_phone'] ?? '';
  27. $email = $body['email'] ?? $body['user_email'] ?? '';
  28. $role = $body['role'] ?? $body['user_role'] ?? '';
  29. $password = $body['password'] ?? '';
  30. $validator = (new Validator([
  31. 'name' => $name,
  32. 'phone' => $phone,
  33. 'email' => $email,
  34. 'role' => $role,
  35. 'password' => $password,
  36. ]))
  37. ->maxLength('name', 120)
  38. ->required('phone')->phone('phone')
  39. ->required('email')->email('email')->maxLength('email', 255)
  40. ->required('role')->maxLength('role', 10)
  41. ->required('password')->minLength('password', 8)->maxLength('password', 255);
  42. if ($validator->fails()) {
  43. return Payload::fail($validator->firstError(), [], 'E_VALIDATE', 400);
  44. }
  45. // Só permitimos papéis do catálogo oficial (admin/manager/operator).
  46. $normalizedRole = mb_strtolower(trim((string) $role));
  47. if (!Roles::isValid($normalizedRole)) {
  48. return Payload::fail(
  49. 'Invalid role. Allowed roles: ' . implode(', ', Roles::ALL),
  50. [],
  51. 'E_VALIDATE',
  52. 400
  53. );
  54. }
  55. $role = $normalizedRole;
  56. try {
  57. $companyId = $this->userModel->getCompanyIdByUserId($userId);
  58. if ($companyId === null) {
  59. return Payload::fail('User not found', [], 'E_NOT_FOUND', 404);
  60. }
  61. $userData = $this->userModel->createUser($companyId, $email, $password, $phone, $role, $name);
  62. if (!$userData) {
  63. return Payload::fail('Email already exists or creation failed', [], 'E_VALIDATE', 400);
  64. }
  65. return Payload::ok($userData, 'S_CREATED', 'User created.');
  66. } catch (\Throwable $e) {
  67. Logger::error('Failed to register user', ['error' => $e->getMessage()]);
  68. return Payload::fail('Failed to register user', [], 'E_GENERIC', 500);
  69. }
  70. }
  71. }