2FAuth/app/Api/v1/Controllers/GroupController.php

127 lines
3.2 KiB
PHP
Raw Normal View History

2020-10-25 23:50:13 +01:00
<?php
namespace App\Api\v1\Controllers;
2020-10-25 23:50:13 +01:00
use App\Api\v1\Requests\GroupAssignRequest;
2022-11-22 15:15:52 +01:00
use App\Api\v1\Requests\GroupStoreRequest;
use App\Api\v1\Resources\GroupResource;
use App\Api\v1\Resources\TwoFAccountCollection;
2022-11-22 15:15:52 +01:00
use App\Facades\Groups;
use App\Http\Controllers\Controller;
2022-11-22 15:15:52 +01:00
use App\Models\Group;
use App\Models\User;
use Illuminate\Http\Request;
2020-10-25 23:50:13 +01:00
class GroupController extends Controller
{
/**
* Display all user groups.
2020-10-25 23:50:13 +01:00
*
* @return \Illuminate\Http\Resources\Json\AnonymousResourceCollection
2020-10-25 23:50:13 +01:00
*/
public function index(Request $request)
2020-10-25 23:50:13 +01:00
{
// Quick fix for #176
if (config('auth.defaults.guard') === 'reverse-proxy-guard' && User::count() === 1) {
if (Group::orphans()->exists()) {
$groups = Group::orphans()->get();
Groups::setUser($groups, $request->user());
}
}
2023-12-20 16:55:58 +01:00
// We do not use fluent call all over the call chain to ease tests
2023-03-10 22:59:46 +01:00
$user = $request->user();
$groups = $user->groups()->withCount('twofaccounts')->get();
2020-10-25 23:50:13 +01:00
return GroupResource::collection(Groups::prependTheAllGroup($groups, $request->user()));
2020-10-25 23:50:13 +01:00
}
/**
* Store a newly created resource in storage.
*
2021-11-26 11:18:58 +01:00
* @return \Illuminate\Http\JsonResponse
2020-10-25 23:50:13 +01:00
*/
public function store(GroupStoreRequest $request)
2020-10-25 23:50:13 +01:00
{
$this->authorize('create', Group::class);
$validated = $request->validated();
2020-10-25 23:50:13 +01:00
$group = $request->user()->groups()->create($validated);
2020-10-25 23:50:13 +01:00
return (new GroupResource($group))
->response()
->setStatusCode(201);
2020-10-25 23:50:13 +01:00
}
/**
* Display the specified resource.
*
2021-11-26 11:18:58 +01:00
* @return \App\Api\v1\Resources\GroupResource
2020-10-25 23:50:13 +01:00
*/
public function show(Group $group)
2020-10-25 23:50:13 +01:00
{
$this->authorize('view', $group);
return new GroupResource($group);
2020-10-25 23:50:13 +01:00
}
/**
* Update the specified resource in storage.
*
2021-11-26 11:18:58 +01:00
* @return \App\Api\v1\Resources\GroupResource
2020-10-25 23:50:13 +01:00
*/
public function update(GroupStoreRequest $request, Group $group)
2020-10-25 23:50:13 +01:00
{
$this->authorize('update', $group);
$validated = $request->validated();
2020-10-25 23:50:13 +01:00
$group->update($validated);
2020-10-25 23:50:13 +01:00
return new GroupResource($group);
2020-10-25 23:50:13 +01:00
}
/**
* Associate the specified accounts with the group
*
2021-11-26 11:18:58 +01:00
* @return \App\Api\v1\Resources\GroupResource
2020-10-25 23:50:13 +01:00
*/
public function assignAccounts(GroupAssignRequest $request, Group $group)
2020-10-25 23:50:13 +01:00
{
$this->authorize('update', $group);
$validated = $request->validated();
2020-10-28 17:51:32 +01:00
Groups::assign($validated['ids'], $request->user(), $group);
2020-10-25 23:50:13 +01:00
2022-11-22 15:15:52 +01:00
return new GroupResource($group);
2020-10-25 23:50:13 +01:00
}
/**
* Get accounts assigned to the group
*
2021-11-26 11:18:58 +01:00
* @return \App\Api\v1\Resources\TwoFAccountCollection
*/
public function accounts(Group $group)
{
$this->authorize('view', $group);
return new TwoFAccountCollection($group->twofaccounts);
}
2020-10-25 23:50:13 +01:00
/**
* Remove the specified resource from storage.
*
2021-11-26 11:18:58 +01:00
* @return \Illuminate\Http\JsonResponse
2020-10-25 23:50:13 +01:00
*/
public function destroy(Group $group)
2020-10-25 23:50:13 +01:00
{
$this->authorize('delete', $group);
$group->delete();
2020-10-25 23:50:13 +01:00
return response()->json(null, 204);
}
}