2021-01-01 01:25:20 +08:00
|
|
|
<?php
|
|
|
|
|
2023-05-18 00:56:55 +08:00
|
|
|
namespace BookStack\Users\Controllers;
|
2021-01-01 01:25:20 +08:00
|
|
|
|
2023-05-19 03:53:39 +08:00
|
|
|
use BookStack\Http\Controller;
|
2023-05-18 00:56:55 +08:00
|
|
|
use BookStack\Users\Models\User;
|
2021-01-01 01:25:20 +08:00
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
|
|
|
class UserSearchController extends Controller
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Search users in the system, with the response formatted
|
|
|
|
* for use in a select-style list.
|
|
|
|
*/
|
|
|
|
public function forSelect(Request $request)
|
|
|
|
{
|
2021-12-15 02:47:22 +08:00
|
|
|
$hasPermission = signedInUser() && (
|
2021-12-15 21:49:20 +08:00
|
|
|
userCan('users-manage')
|
2021-12-15 02:47:22 +08:00
|
|
|
|| userCan('restrictions-manage-own')
|
|
|
|
|| userCan('restrictions-manage-all')
|
|
|
|
);
|
|
|
|
|
|
|
|
if (!$hasPermission) {
|
|
|
|
$this->showPermissionError();
|
|
|
|
}
|
|
|
|
|
2021-01-01 01:25:20 +08:00
|
|
|
$search = $request->get('search', '');
|
2021-12-15 02:47:22 +08:00
|
|
|
$query = User::query()
|
|
|
|
->orderBy('name', 'asc')
|
2021-01-01 01:25:20 +08:00
|
|
|
->take(20);
|
|
|
|
|
|
|
|
if (!empty($search)) {
|
2021-12-15 02:47:22 +08:00
|
|
|
$query->where('name', 'like', '%' . $search . '%');
|
2021-01-01 01:25:20 +08:00
|
|
|
}
|
|
|
|
|
2021-12-15 02:47:22 +08:00
|
|
|
return view('form.user-select-list', [
|
|
|
|
'users' => $query->get(),
|
|
|
|
]);
|
2021-01-01 01:25:20 +08:00
|
|
|
}
|
|
|
|
}
|