UserDeleteController.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. <?php
  2. namespace Controllers;
  3. use Libs\ResponseLib;
  4. use Models\UserModel;
  5. use Psr\Http\Message\ServerRequestInterface;
  6. use Respect\Validation\Validator as v;
  7. use Respect\Validation\Exceptions\ValidationException;
  8. class UserDeleteController
  9. {
  10. private UserModel $model;
  11. public function __construct()
  12. {
  13. $this->model = new UserModel();
  14. }
  15. public function __invoke(ServerRequestInterface $request)
  16. {
  17. $body = json_decode((string)$request->getBody(), true) ?? [];
  18. try {
  19. v::key('company_id', v::intType()->positive())
  20. ->key('user_name', v::stringType()->notEmpty()->alnum(' _')) // permite espaço e underline
  21. ->assert($body);
  22. } catch (ValidationException $e) {
  23. return ResponseLib::sendFail("Validation failed: " . $e->getFullMessage(), [], "E_VALIDATE")
  24. ->withStatus(400);
  25. }
  26. $companyId = (int) $body['company_id'];
  27. $username = $body['user_name'];
  28. $deleted = $this->model->deleteUserByName($username, $companyId);
  29. return $deleted
  30. ? ResponseLib::sendOk(['deleted' => true])
  31. : ResponseLib::sendFail("Failed to delete user or user not found", [], "E_DATABASE")->withStatus(403);
  32. }
  33. }