File "StatusApiController.php"

Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/app/Http/Controllers/Api/V1/Admin/StatusApiController.php
File size: 2.33 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\StoreStatusRequest;
use App\Http\Requests\Admin\UpdateStatusRequest;
use App\Http\Resources\Admin\StatusResource;
use App\Models\Status;
use Illuminate\Support\Facades\Gate;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Log;
use Symfony\Component\HttpFoundation\Response;

class StatusApiController extends Controller
{
    public function index(Request $request)
    {
        abort_if(Gate::denies('status_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
        $statuses = Status::when($request->filled('name'), function ($query) use ($request){
            $query->where('name', 'like', "%{$request->get('name')}%");
        })
            ->where('id', '<>', 12)
            ->orderBy('sort')->get();

        StatusResource::withoutWrapping();
        return StatusResource::collection($statuses);
    }

    public function store(StoreStatusRequest $request)
    {
        $status = Status::create($request->all());

        return (new StatusResource($status))
            ->response()
            ->setStatusCode(Response::HTTP_CREATED);
    }

    public function show(Status $status)
    {
        abort_if(Gate::denies('status_show'), Response::HTTP_FORBIDDEN, '403 Forbidden');

        return new StatusResource($status);
    }

    public function update(UpdateStatusRequest $request, Status $status)
    {
        $status->update($request->all());

        return (new StatusResource($status))
            ->response()
            ->setStatusCode(Response::HTTP_CREATED);
    }

    public function destroy(Status $status)
    {
        abort_if(Gate::denies('status_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden');

        try {
            $status->delete();
            return response()
                ->json(['message' => 'Status deleted successfully'], Response::HTTP_OK);
        }catch (\Exception $e){
            Log::channel('db_errors')->info('Record Deletion Error : Status -> '.$status->id);
            Log::channel('db_errors')->info($e->getMessage());
            return response()
                ->json([
                    'message' => "Record not deleted.",
                    'errors' => ["error" => ["Unable to delete status."]]
                ], Response::HTTP_INTERNAL_SERVER_ERROR);
        }
    }
}