GroupController.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. namespace App\Api\v1\Controllers;
  3. use App\Api\v1\Requests\GroupAssignRequest;
  4. use App\Api\v1\Requests\GroupStoreRequest;
  5. use App\Api\v1\Resources\GroupResource;
  6. use App\Api\v1\Resources\TwoFAccountCollection;
  7. use App\Facades\Groups;
  8. use App\Http\Controllers\Controller;
  9. use App\Models\Group;
  10. class GroupController extends Controller
  11. {
  12. /**
  13. * Display a listing of the resource.
  14. *
  15. * @return \Illuminate\Http\Resources\Json\AnonymousResourceCollection
  16. */
  17. public function index()
  18. {
  19. $groups = Groups::getAll();
  20. return GroupResource::collection($groups);
  21. }
  22. /**
  23. * Store a newly created resource in storage.
  24. *
  25. * @param \App\Api\v1\Requests\GroupStoreRequest $request
  26. * @return \Illuminate\Http\JsonResponse
  27. */
  28. public function store(GroupStoreRequest $request)
  29. {
  30. $validated = $request->validated();
  31. $group = Groups::create($validated);
  32. return (new GroupResource($group))
  33. ->response()
  34. ->setStatusCode(201);
  35. }
  36. /**
  37. * Display the specified resource.
  38. *
  39. * @param \App\Models\Group $group
  40. * @return \App\Api\v1\Resources\GroupResource
  41. */
  42. public function show(Group $group)
  43. {
  44. return new GroupResource($group);
  45. }
  46. /**
  47. * Update the specified resource in storage.
  48. *
  49. * @param \App\Api\v1\Requests\GroupStoreRequest $request
  50. * @param \App\Models\Group $group
  51. * @return \App\Api\v1\Resources\GroupResource
  52. */
  53. public function update(GroupStoreRequest $request, Group $group)
  54. {
  55. $validated = $request->validated();
  56. Groups::update($group, $validated);
  57. return new GroupResource($group);
  58. }
  59. /**
  60. * Associate the specified accounts with the group
  61. *
  62. * @param \App\Api\v1\Requests\GroupAssignRequest $request
  63. * @param \App\Models\Group $group
  64. * @return \App\Api\v1\Resources\GroupResource
  65. */
  66. public function assignAccounts(GroupAssignRequest $request, Group $group)
  67. {
  68. $validated = $request->validated();
  69. Groups::assign($validated['ids'], $group);
  70. return new GroupResource($group);
  71. }
  72. /**
  73. * Get accounts assign to the group
  74. *
  75. * @param \App\Models\Group $group
  76. * @return \App\Api\v1\Resources\TwoFAccountCollection
  77. */
  78. public function accounts(Group $group)
  79. {
  80. $twofaccounts = Groups::getAccounts($group);
  81. return new TwoFAccountCollection($twofaccounts);
  82. }
  83. /**
  84. * Remove the specified resource from storage.
  85. *
  86. * @param \App\Models\Group $group
  87. * @return \Illuminate\Http\JsonResponse
  88. */
  89. public function destroy(Group $group)
  90. {
  91. Groups::delete($group->id);
  92. return response()->json(null, 204);
  93. }
  94. }