converted from filters to conductors

This commit is contained in:
2023-03-10 13:46:30 +10:00
parent 6bee6b1ba7
commit 3bd5c064c3
2 changed files with 78 additions and 53 deletions

View File

@@ -3,9 +3,9 @@
namespace App\Http\Controllers\Api; namespace App\Http\Controllers\Api;
use App\Enum\HttpResponseCodes; use App\Enum\HttpResponseCodes;
use App\Filters\EventFilter;
use App\Http\Requests\EventRequest; use App\Http\Requests\EventRequest;
use App\Models\Event; use App\Models\Event;
use App\Conductors\EventConductor;
use Illuminate\Http\Request; use Illuminate\Http\Request;
class EventController extends ApiController class EventController extends ApiController
@@ -22,56 +22,70 @@ class EventController extends ApiController
/** /**
* Display a listing of the resource. * Display a listing of the resource.
* *
* @param EventFilter $filter The event filter. * @param Request $request The request.
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function index(EventFilter $filter) public function index(Request $request)
{ {
list($collection, $total) = EventConductor::request($request);
return $this->respondAsResource( return $this->respondAsResource(
$filter->filter(), $collection,
['total' => $filter->foundTotal()] ['total' => $total]
); );
} }
/** /**
* Store a newly created resource in storage. * Store a newly created resource in storage.
* *
* @param EventRequest $request The event store request. * @param Request $request The request.
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function store(EventRequest $request) public function store(Request $request)
{ {
$event = Event::create($request->all()); if(EventConductor::creatable()) {
return $this->respondAsResource( $event = Event::create($request->all());
(new EventFilter($request))->filter($event), return $this->respondAsResource(
null, EventConductor::model($request, $event),
HttpResponseCodes::HTTP_CREATED null,
); HttpResponseCodes::HTTP_CREATED
);
} else {
return $this->respondForbidden();
}
} }
/** /**
* Display the specified resource. * Display the specified resource.
* *
* @param EventFilter $filter The event filter. * @param Request $request The request.
* @param \App\Models\Event $event The specified event. * @param \App\Models\Event $event The specified event.
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function show(EventFilter $filter, Event $event) public function show(Request $request, Event $event)
{ {
return $this->respondAsResource($filter->filter($event)); if(EventConductor::viewable($event)) {
return $this->respondAsResource(EventConductor::model($request, $event));
}
return $this->respondForbidden();
} }
/** /**
* Update the specified resource in storage. * Update the specified resource in storage.
* *
* @param EventRequest $request The event update request. * @param Request $request The request.
* @param \App\Models\Event $event The specified event. * @param \App\Models\Event $event The specified event.
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function update(EventRequest $request, Event $event) public function update(Request $request, Event $event)
{ {
$event->update($request->all()); if(EventConductor::updatable($event)) {
return $this->respondAsResource((new EventFilter($request))->filter($event)); $event->update($request->all());
return $this->respondAsResource(EventConductor::model($request, $event));
} else {
return $this->respondForbidden();
}
} }
/** /**
@@ -82,7 +96,11 @@ class EventController extends ApiController
*/ */
public function destroy(Event $event) public function destroy(Event $event)
{ {
$event->delete(); if(EventConductor::destroyable($event)) {
return $this->respondNoContent(); $event->delete();
return $this->respondNoContent();
} else {
return $this->respondForbidden();
}
} }
} }

View File

@@ -23,6 +23,7 @@ use App\Models\User;
use App\Models\UserCode; use App\Models\UserCode;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash; use Illuminate\Support\Facades\Hash;
use App\Conductors\UserConductor;
class UserController extends ApiController class UserController extends ApiController
{ {
@@ -48,32 +49,33 @@ class UserController extends ApiController
/** /**
* Display a listing of the resource. * Display a listing of the resource.
* *
* @param \App\Filters\UserFilter $filter Filter object. * @param Request $request The request.
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function index(UserFilter $filter) public function index(Request $request)
{ {
$collection = $filter->filter(); list($collection, $total) = UserConductor::request($request);
return $this->respondAsResource( return $this->respondAsResource(
$collection, $collection,
['total' => $filter->foundTotal()] ['total' => $total]
); );
} }
/** /**
* Store a newly created user in the database. * Store a newly created user in the database.
* *
* @param UserStoreRequest $request The user update request. * @param Request $request The request.
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function store(UserStoreRequest $request) public function store(Request $request)
{ {
if ($request->user()->hasPermission('admin/user') !== true) { if(UserConductor::creatable()) {
$user = User::create($request->all());
return $this->respondAsResource(UserConductor::model($request, $user), [], HttpResponseCodes::HTTP_CREATED);
} else {
return $this->respondForbidden(); return $this->respondForbidden();
} }
$user = User::create($request->all());
return $this->respondAsResource((new UserFilter($request))->filter($user), [], HttpResponseCodes::HTTP_CREATED);
} }
@@ -84,9 +86,14 @@ class UserController extends ApiController
* @param User $user The user model. * @param User $user The user model.
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function show(UserFilter $filter, User $user) // public function show(UserFilter $filter, User $user)
public function show(Request $request, User $user)
{ {
return $this->respondAsResource($filter->filter($user)); if(UserConductor::viewable($user)) {
return $this->respondAsResource(UserConductor::model($request, $user));
}
return $this->respondForbidden();
} }
/** /**
@@ -98,23 +105,23 @@ class UserController extends ApiController
*/ */
public function update(UserUpdateRequest $request, User $user) public function update(UserUpdateRequest $request, User $user)
{ {
$input = []; if(UserConductor::updatable($user)) {
$updatable = ['username', 'first_name', 'last_name', 'email', 'phone', 'password']; $input = [];
$updatable = ['username', 'first_name', 'last_name', 'email', 'phone', 'password'];
if ($request->user()->hasPermission('admin/user') === true) { if ($request->user()->hasPermission('admin/user') === true) {
$updatable = array_merge($updatable, ['email_verified_at']); $updatable = array_merge($updatable, ['email_verified_at']);
} elseif ($request->user()->is($user) !== true) { }
return $this->respondForbidden();
$input = $request->only($updatable);
if (array_key_exists('password', $input) === true) {
$input['password'] = Hash::make($request->input('password'));
}
$user->update($input);
return $this->respondAsResource(UserConductor::model($request, $user));
} }
$input = $request->only($updatable);
if (array_key_exists('password', $input) === true) {
$input['password'] = Hash::make($request->input('password'));
}
$user->update($input);
return $this->respondAsResource((new UserFilter($request))->filter($user));
} }
@@ -126,12 +133,12 @@ class UserController extends ApiController
*/ */
public function destroy(User $user) public function destroy(User $user)
{ {
if ($user->hasPermission('admin/user') === false) { if(UserConductor::destroyable($user)) {
return $this->respondForbidden(); $user->delete();
return $this->respondNoContent();
} }
$user->delete(); return $this->respondForbidden();
return $this->respondNoContent();
} }
/** /**