UserChangeEmailController.php 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. <?php
  2. namespace Controllers;
  3. use Libs\ResponseLib;
  4. use Models\UserModel;
  5. use Psr\Http\Message\ServerRequestInterface;
  6. class UserChangeEmailController
  7. {
  8. public function __invoke(ServerRequestInterface $request)
  9. {
  10. $userId = (int)($request->getAttribute('api_user_id') ?? 0);
  11. if ($userId <= 0) {
  12. return ResponseLib::sendFail('Unauthorized', [], 'E_VALIDATE')->withStatus(401);
  13. }
  14. $body = json_decode((string)$request->getBody(), true) ?? [];
  15. $email = $body['email'] ?? '';
  16. if (empty($email) || !filter_var($email, FILTER_VALIDATE_EMAIL)) {
  17. return ResponseLib::sendFail('Validation failed: invalid email', [], 'E_VALIDATE')->withStatus(400);
  18. }
  19. $model = new UserModel();
  20. $ok = $model->updateEmail($userId, $email);
  21. if (!$ok) {
  22. return ResponseLib::sendFail('Email already in use or update failed', [], 'E_VALIDATE')->withStatus(400);
  23. }
  24. return ResponseLib::sendOk(['user_id' => $userId, 'user_email' => $email], 'S_UPDATED');
  25. }
  26. }