exists()) { $groups = Group::orphans()->get(); Groups::setUser($groups, $request->user()); } } // We do not use fluent call all over the call chain to ease tests $user = $request->user(); $groups = $user->groups()->withCount('twofaccounts')->get(); return GroupResource::collection(Groups::prependTheAllGroup($groups, $request->user())); } /** * Store a newly created resource in storage. * * @return \Illuminate\Http\JsonResponse */ public function store(GroupStoreRequest $request) { $this->authorize('create', Group::class); $validated = $request->validated(); $group = $request->user()->groups()->create($validated); return (new GroupResource($group)) ->response() ->setStatusCode(201); } /** * Display the specified resource. * * @return \App\Api\v1\Resources\GroupResource */ public function show(Group $group) { $this->authorize('view', $group); return new GroupResource($group); } /** * Update the specified resource in storage. * * @return \App\Api\v1\Resources\GroupResource */ public function update(GroupStoreRequest $request, Group $group) { $this->authorize('update', $group); $validated = $request->validated(); $group->update($validated); return new GroupResource($group); } /** * Associate the specified accounts with the group * * @return \App\Api\v1\Resources\GroupResource */ public function assignAccounts(GroupAssignRequest $request, Group $group) { $this->authorize('update', $group); $validated = $request->validated(); Groups::assign($validated['ids'], $request->user(), $group); return new GroupResource($group); } /** * Get accounts assigned to the group * * @return \App\Api\v1\Resources\TwoFAccountCollection */ public function accounts(Group $group) { $this->authorize('view', $group); return new TwoFAccountCollection($group->twofaccounts); } /** * Remove the specified resource from storage. * * @return \Illuminate\Http\JsonResponse */ public function destroy(Group $group) { $this->authorize('delete', $group); $group->delete(); return response()->json(null, 204); } }