2021-05-05 19:46:14 +08:00
|
|
|
<?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;
|
|
|
|
|
2021-05-06 17:10:49 +08:00
|
|
|
protected $printHidden = [
|
|
|
|
'email', 'created_at', 'updated_at', 'last_activity_at'
|
|
|
|
];
|
|
|
|
|
2021-05-05 19:46:14 +08:00
|
|
|
# TBD: Endpoints to create / update users
|
|
|
|
# protected $rules = [
|
|
|
|
# 'create' => [
|
|
|
|
# ],
|
|
|
|
# 'update' => [
|
|
|
|
# ],
|
|
|
|
# ];
|
|
|
|
|
|
|
|
public function __construct(User $user, UserRepo $userRepo)
|
|
|
|
{
|
|
|
|
$this->user = $user;
|
|
|
|
$this->userRepo = $userRepo;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-05-06 17:10:49 +08:00
|
|
|
* Get a listing of users
|
2021-05-05 19:46:14 +08:00
|
|
|
*/
|
|
|
|
public function list()
|
|
|
|
{
|
2021-05-06 17:10:49 +08:00
|
|
|
$this->checkPermission('users-manage');
|
|
|
|
|
2021-05-05 19:46:14 +08:00
|
|
|
$users = $this->userRepo->getUsersBuilder();
|
|
|
|
|
|
|
|
return $this->apiListingResponse($users, [
|
2021-05-06 17:10:49 +08:00
|
|
|
'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);
|
2021-05-05 19:46:14 +08:00
|
|
|
}
|
|
|
|
}
|