File "RolesApiController.php"
Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/app/Http/Controllers/Api/V1/Admin/RolesApiController.php
File size: 2.5 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace App\Http\Controllers\Api\V1\Admin;
use App\Http\Controllers\Controller;
use App\Http\Requests\Admin\StoreRoleRequest;
use App\Http\Requests\Admin\UpdateRoleRequest;
use App\Http\Resources\Admin\RoleResource;
use App\Http\Resources\Admin\RoleResourceWithChecks;
use App\Models\Role;
use Gate;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class RolesApiController extends Controller
{
public function index(Request $request)
{
abort_if(Gate::denies('role_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$roles = Role::when($request->filled('title'), function ($query) use ($request){
$query->where('title', 'like', "%{$request->get('title')}%");
})
->where('id', '<>', 1)
->orderBy('created_at', 'DESC')->get();
RoleResource::withoutWrapping();
return RoleResource::collection($roles);
}
public function store(StoreRoleRequest $request)
{
$role = Role::create($request->all());
$role->permissions()->sync($request->input('permissions', []));
return (new RoleResource($role))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function show(Role $role)
{
abort_if(Gate::denies('role_show'), Response::HTTP_FORBIDDEN, '403 Forbidden');
RoleResourceWithChecks::withoutWrapping();
return new RoleResourceWithChecks($role->load(['permissions']));
}
public function update(UpdateRoleRequest $request, Role $role)
{
$role->update($request->all());
$role->permissions()->sync($request->input('permissions', []));
return (new RoleResource($role))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function destroy(Role $role)
{
abort_if(Gate::denies('role_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden');
try {
$role->delete();
return response()
->json(['message' => 'Role deleted successfully'], Response::HTTP_OK);
}catch (\Exception $e){
\Log::channel('db_errors')->info('Record Deletion Error : Role -> '.$role->id);
\Log::channel('db_errors')->info($e->getMessage());
return response()
->json([
'message' => "Record not deleted.",
'errors' => ["error" => ["Unable to delete role."]]
], Response::HTTP_INTERNAL_SERVER_ERROR);
}
}
}