mirror of
				https://github.com/BookStackApp/BookStack.git
				synced 2025-10-26 17:31:27 +03:00 
			
		
		
		
	* add /users/{id} to get a single user
* add variable to print fields that are otherwise hidden (e.g. email)
		
	
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace BookStack\Http\Controllers\Api;
 | |
| 
 | |
| use BookStack\Exceptions\PermissionsException;
 | |
| use BookStack\Auth\User;
 | |
| use BookStack\Auth\UserRepo;
 | |
| use Exception;
 | |
| use Illuminate\Http\Request;
 | |
| 
 | |
| class UserApiController extends ApiController
 | |
| {
 | |
|     protected $user;
 | |
|     protected $userRepo;
 | |
| 
 | |
|     protected $printHidden = [
 | |
|         'email', 'created_at', 'updated_at', 'last_activity_at'
 | |
|     ];
 | |
| 
 | |
| # TBD: Endpoints to create / update users
 | |
| #     protected $rules = [
 | |
| #         'create' => [
 | |
| #         ],
 | |
| #         'update' => [
 | |
| #         ],
 | |
| #     ];
 | |
| 
 | |
|     public function __construct(User $user, UserRepo $userRepo)
 | |
|     {
 | |
|         $this->user = $user;
 | |
|         $this->userRepo = $userRepo;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get a listing of users
 | |
|      */
 | |
|     public function list()
 | |
|     {
 | |
|         $this->checkPermission('users-manage');
 | |
| 
 | |
|         $users = $this->userRepo->getUsersBuilder();
 | |
| 
 | |
|         return $this->apiListingResponse($users, [
 | |
|             'id', 'name', 'slug', 'email',
 | |
|             'created_at', 'updated_at', 'last_activity_at',
 | |
|         ], $this->printHidden);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * View the details of a single user
 | |
|      */
 | |
|     public function read(string $id)
 | |
|     {
 | |
|         $this->checkPermission('users-manage');
 | |
| 
 | |
|         $singleUser = $this->userRepo->getById($id);
 | |
|         $singleUser = $singleUser->makeVisible($this->printHidden);
 | |
| 
 | |
|         return response()->json($singleUser);
 | |
|     }
 | |
| }
 |