UserService.php 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace App\Services;
  3. use App\Enums\UserStatusEnum;
  4. use App\Enums\UserTypeEnum;
  5. use App\Models\User;
  6. use Illuminate\Database\Eloquent\Collection;
  7. use Illuminate\Support\Facades\Auth;
  8. class UserService
  9. {
  10. public function authUser(): ?User
  11. {
  12. $user = Auth::user();
  13. return $user?->load(['position', 'sector']);
  14. }
  15. public function getAll(): Collection
  16. {
  17. return User::with(['position', 'sector'])->orderBy("created_at", "desc")->get();
  18. }
  19. public function getAllPaginated(array $filters = [], int $perPage = 10): \Illuminate\Pagination\LengthAwarePaginator
  20. {
  21. $query = User::with(['position', 'sector'])->orderBy('created_at', 'desc');
  22. if (!empty($filters['type'])) {
  23. $query->where('type', $filters['type']);
  24. }
  25. if (!empty($filters['status'])) {
  26. $query->where('status', $filters['status']);
  27. }
  28. if (!empty($filters['search'])) {
  29. $term = '%' . mb_strtolower($filters['search']) . '%';
  30. $query->where(function ($q) use ($term) {
  31. $q->whereRaw('UNACCENT(LOWER(name)) LIKE UNACCENT(?)', [$term])
  32. ->orWhereRaw('UNACCENT(LOWER(email)) LIKE UNACCENT(?)', [$term])
  33. ->orWhereRaw('UNACCENT(LOWER(COALESCE(cpf, \'\'))) LIKE UNACCENT(?)', [$term])
  34. ->orWhereRaw('UNACCENT(LOWER(COALESCE(registration, \'\'))) LIKE UNACCENT(?)', [$term]);
  35. });
  36. }
  37. return $query->paginate($perPage);
  38. }
  39. public function findById(int $id): ?User
  40. {
  41. return User::find($id);
  42. }
  43. public function create(array $data): User
  44. {
  45. return User::create($data);
  46. }
  47. public function update(int $id, array $data): ?User
  48. {
  49. $model = $this->findById($id);
  50. if (!$model) {
  51. return null;
  52. }
  53. if (isset($data['status'])) {
  54. $newStatus = $data['status'] instanceof UserStatusEnum
  55. ? $data['status']
  56. : UserStatusEnum::from($data['status']);
  57. if ($newStatus === UserStatusEnum::INACTIVE && $model->status !== UserStatusEnum::INACTIVE) {
  58. $data['excluded_at'] = now();
  59. } elseif ($newStatus !== UserStatusEnum::INACTIVE) {
  60. $data['excluded_at'] = null;
  61. }
  62. }
  63. $model->update($data);
  64. return $model->fresh();
  65. }
  66. public function delete(int $id): bool
  67. {
  68. $model = $this->findById($id);
  69. if (!$model) {
  70. return false;
  71. }
  72. return $model->delete();
  73. }
  74. public function getUserTypes(): array
  75. {
  76. return UserTypeEnum::toArray();
  77. }
  78. }