lms/app/Services/UserService.php
Ahmed Darrazi 4aa98c1921
All checks were successful
Build & Push Docker Image / docker (push) Successful in 1m48s
lang bugfix
2025-12-18 20:59:36 +01:00

61 lines
1.8 KiB
PHP

<?php
namespace App\Services;
use App\Enums\UserType;
use App\Models\User;
use App\Notifications\VerifyEmailNotification;
use Illuminate\Support\Facades\DB;
use Illuminate\Pagination\LengthAwarePaginator;
use Illuminate\Database\Eloquent\Collection;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Str;
class UserService
{
public function getUsers(array $data): LengthAwarePaginator|Collection
{
$page = array_key_exists('per_page', $data) ? intval($data['per_page']) : 10;
$users = User::where('role', '!=', 'admin')
->where('role', '!=', 'instructor')
->when(array_key_exists('search', $data), function ($query) use ($data) {
return $query->where('name', 'LIKE', '%' . $data['search'] . '%')
->orWhere('email', 'LIKE', '%' . $data['search'] . '%');
})
->orderBy('created_at', 'desc');
if (array_key_exists('paginate', $data) && $data['paginate']) {
return $users->paginate($page);
}
return $users->get();
}
public function updateUser(int | string $id, array $data): void
{
DB::transaction(function () use ($data, $id) {
User::find($id)->update($data);
}, 5);
}
public function inviteUser(array $data): User
{
return DB::transaction(function () use ($data) {
$user = User::create([
'name' => $data['name'],
'email' => $data['email'],
'role' => UserType::STUDENT->value,
'status' => $data['status'] ?? 1,
'password' => Hash::make(Str::random(32)),
]);
DB::afterCommit(function () use ($user) {
$user->notify(new VerifyEmailNotification(true));
});
return $user;
}, 5);
}
}