| 
									
										
										
										
											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) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-09-16 20:18:35 +08:00
										 |  |  |         $hasPermission = !user()->isGuest() && ( | 
					
						
							| 
									
										
										
										
											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
										 |  |  |     } | 
					
						
							|  |  |  | } |