. */ declare(strict_types=1); namespace FireflyIII\Api\V1\Controllers; use FireflyIII\Api\V1\Requests\UserRequest; use FireflyIII\Exceptions\FireflyException; use FireflyIII\Repositories\User\UserRepositoryInterface; use FireflyIII\Transformers\UserTransformer; use FireflyIII\User; use Illuminate\Http\JsonResponse; use Illuminate\Http\Request; use Illuminate\Pagination\LengthAwarePaginator; use League\Fractal\Manager; use League\Fractal\Pagination\IlluminatePaginatorAdapter; use League\Fractal\Resource\Collection as FractalCollection; use League\Fractal\Resource\Item; use League\Fractal\Serializer\JsonApiSerializer; /** * Class UserController. * * @SuppressWarnings(PHPMD.CouplingBetweenObjects) */ class UserController extends Controller { /** @var UserRepositoryInterface The user repository */ private $repository; /** * UserController constructor. * @codeCoverageIgnore */ public function __construct() { parent::__construct(); $this->middleware( function ($request, $next) { /** @var UserRepositoryInterface repository */ $this->repository = app(UserRepositoryInterface::class); return $next($request); } ); } /** * Remove the specified resource from storage. * * @param \FireflyIII\User $user * * @return JsonResponse * @throws FireflyException * @codeCoverageIgnore */ public function delete(User $user): JsonResponse { /** @var User $admin */ $admin = auth()->user(); if ($admin->id !== $user->id && $this->repository->hasRole($admin, 'owner')) { $this->repository->destroy($user); return response()->json([], 204); } throw new FireflyException('No access to method.'); // @codeCoverageIgnore } /** * Display a listing of the resource. * * @param Request $request * * @return JsonResponse * @codeCoverageIgnore */ public function index(Request $request): JsonResponse { // user preferences $pageSize = (int)app('preferences')->getForUser(auth()->user(), 'listPageSize', 50)->data; // make manager $manager = new Manager(); $baseUrl = $request->getSchemeAndHttpHost() . '/api/v1'; $manager->setSerializer(new JsonApiSerializer($baseUrl)); // build collection $collection = $this->repository->all(); $count = $collection->count(); $users = $collection->slice(($this->parameters->get('page') - 1) * $pageSize, $pageSize); // make paginator: $paginator = new LengthAwarePaginator($users, $count, $pageSize, $this->parameters->get('page')); $paginator->setPath(route('api.v1.users.index') . $this->buildParams()); // make resource /** @var UserTransformer $transformer */ $transformer = app(UserTransformer::class); $transformer->setParameters($this->parameters); $resource = new FractalCollection($users, $transformer, 'users'); $resource->setPaginator(new IlluminatePaginatorAdapter($paginator)); return response()->json($manager->createData($resource)->toArray())->header('Content-Type', 'application/vnd.api+json'); } /** * Show a single user. * * @param Request $request * @param User $user * * @return JsonResponse * @codeCoverageIgnore */ public function show(Request $request, User $user): JsonResponse { // make manager $manager = new Manager(); $baseUrl = $request->getSchemeAndHttpHost() . '/api/v1'; $manager->setSerializer(new JsonApiSerializer($baseUrl)); // make resource /** @var UserTransformer $transformer */ $transformer = app(UserTransformer::class); $transformer->setParameters($this->parameters); $resource = new Item($user, $transformer, 'users'); return response()->json($manager->createData($resource)->toArray())->header('Content-Type', 'application/vnd.api+json'); } /** * Store a new user. * * @param UserRequest $request * * @return JsonResponse */ public function store(UserRequest $request): JsonResponse { $data = $request->getAll(); $user = $this->repository->store($data); // make manager $manager = new Manager(); $baseUrl = $request->getSchemeAndHttpHost() . '/api/v1'; $manager->setSerializer(new JsonApiSerializer($baseUrl)); // make resource /** @var UserTransformer $transformer */ $transformer = app(UserTransformer::class); $transformer->setParameters($this->parameters); $resource = new Item($user, $transformer, 'users'); return response()->json($manager->createData($resource)->toArray())->header('Content-Type', 'application/vnd.api+json'); } /** * Update a user. * * @param UserRequest $request * @param User $user * * @return JsonResponse */ public function update(UserRequest $request, User $user): JsonResponse { $data = $request->getAll(); $user = $this->repository->update($user, $data); // make manager $manager = new Manager(); $baseUrl = $request->getSchemeAndHttpHost() . '/api/v1'; $manager->setSerializer(new JsonApiSerializer($baseUrl)); // make resource /** @var UserTransformer $transformer */ $transformer = app(UserTransformer::class); $transformer->setParameters($this->parameters); $resource = new Item($user, $transformer, 'users'); return response()->json($manager->createData($resource)->toArray())->header('Content-Type', 'application/vnd.api+json'); } }