File "PermissionsApiController.php"
Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/app/Http/Controllers/Api/V1/Admin/PermissionsApiController.php
File size: 2.07 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\StorePermissionRequest;
use App\Http\Requests\Admin\UpdatePermissionRequest;
use App\Http\Resources\Admin\PermissionResource;
use App\Models\Permission;
use Gate;
use Symfony\Component\HttpFoundation\Response;
class PermissionsApiController extends Controller
{
public function index()
{
abort_if(Gate::denies('permission_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
return new PermissionResource(Permission::all());
}
public function store(StorePermissionRequest $request)
{
$permission = Permission::create($request->all());
return (new PermissionResource($permission))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function show(Permission $permission)
{
abort_if(Gate::denies('permission_show'), Response::HTTP_FORBIDDEN, '403 Forbidden');
return new PermissionResource($permission);
}
public function update(UpdatePermissionRequest $request, Permission $permission)
{
$permission->update($request->all());
return (new PermissionResource($permission))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function destroy(Permission $permission)
{
abort_if(Gate::denies('permission_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden');
try {
$permission->delete();
return response()
->json(['message' => 'Permission deleted successfully'], Response::HTTP_OK);
}catch (\Exception $e){
\Log::channel('db_errors')->info('Record Deletion Error : Permission -> '.$permission->id);
\Log::channel('db_errors')->info($e->getMessage());
return response()
->json([
'message' => "Record not deleted.",
'errors' => ["error" => ["Unable to delete permission."]]
], Response::HTTP_INTERNAL_SERVER_ERROR);
}
}
}