<?php namespace App\Http\Controllers\Api\Auth; use App\Abstracts\Http\ApiController; use App\Http\Requests\Auth\Role as Request; use App\Models\Auth\Role; use App\Jobs\Auth\CreateRole; use App\Jobs\Auth\DeleteRole; use App\Jobs\Auth\UpdateRole; use App\Transformers\Auth\Role as Transformer; class Roles extends ApiController { /** * Display a listing of the resource. * * @return \Dingo\Api\Http\Response */ public function index() { $roles = Role::with('permissions')->collect(); return $this->response->paginator($roles, new Transformer()); } /** * Display the specified resource. * * @param Role $role * @return \Dingo\Api\Http\Response */ public function show(Role $role) { return $this->item($role, new Transformer()); } /** * Store a newly created resource in storage. * * @param $request * @return \Dingo\Api\Http\Response */ public function store(Request $request) { $role = $this->dispatch(new CreateRole($request)); return $this->response->created(route('api.roles.show', $role->id), $this->item($role, new Transformer())); } /** * Update the specified resource in storage. * * @param $role * @param $request * @return \Dingo\Api\Http\Response */ public function update(Role $role, Request $request) { $role = $this->dispatch(new UpdateRole($role, $request)); return $this->item($role->fresh(), new Transformer()); } /** * Remove the specified resource from storage. * * @param Role $role * @return \Dingo\Api\Http\Response */ public function destroy(Role $role) { try { $this->dispatch(new DeleteRole($role)); return $this->response->noContent(); } catch(\Exception $e) { $this->response->errorUnauthorized($e->getMessage()); } } }