2022-02-13 13:56:26 +01:00
|
|
|
<?php
|
|
|
|
|
2023-05-17 18:56:55 +02:00
|
|
|
namespace BookStack\Users\Queries;
|
2022-02-13 13:56:26 +01:00
|
|
|
|
2023-05-17 18:56:55 +02:00
|
|
|
use BookStack\Users\Models\User;
|
2022-10-30 16:16:06 +01:00
|
|
|
use BookStack\Util\SimpleListOptions;
|
2022-02-13 13:56:26 +01:00
|
|
|
use Illuminate\Pagination\LengthAwarePaginator;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all the users with their permissions in a paginated format.
|
|
|
|
* Note: Due to the use of email search this should only be used when
|
|
|
|
* user is assumed to be trusted. (Admin users).
|
|
|
|
* Email search can be abused to extract email addresses.
|
|
|
|
*/
|
2022-10-30 13:02:06 +01:00
|
|
|
class UsersAllPaginatedAndSorted
|
2022-02-13 13:56:26 +01:00
|
|
|
{
|
2022-10-30 16:16:06 +01:00
|
|
|
public function run(int $count, SimpleListOptions $listOptions): LengthAwarePaginator
|
2022-02-13 13:56:26 +01:00
|
|
|
{
|
2022-10-30 16:16:06 +01:00
|
|
|
$sort = $listOptions->getSort();
|
2022-10-29 16:23:21 +02:00
|
|
|
if ($sort === 'created_at') {
|
|
|
|
$sort = 'users.created_at';
|
|
|
|
}
|
2022-02-13 13:56:26 +01:00
|
|
|
|
|
|
|
$query = User::query()->select(['*'])
|
|
|
|
->scopes(['withLastActivityAt'])
|
|
|
|
->with(['roles', 'avatar'])
|
|
|
|
->withCount('mfaValues')
|
2022-10-30 16:16:06 +01:00
|
|
|
->orderBy($sort, $listOptions->getOrder());
|
2022-02-13 13:56:26 +01:00
|
|
|
|
2022-10-30 16:16:06 +01:00
|
|
|
if ($listOptions->getSearch()) {
|
|
|
|
$term = '%' . $listOptions->getSearch() . '%';
|
2022-02-13 13:56:26 +01:00
|
|
|
$query->where(function ($query) use ($term) {
|
|
|
|
$query->where('name', 'like', $term)
|
|
|
|
->orWhere('email', 'like', $term);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return $query->paginate($count);
|
|
|
|
}
|
2022-02-13 14:16:43 +01:00
|
|
|
}
|