File "VariationApiController.php"
Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/app/Http/Controllers/Api/V1/Admin/VariationApiController.php
File size: 3.14 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\StoreVariationRequest;
use App\Http\Requests\Admin\UpdateVariationRequest;
use App\Http\Resources\Admin\VariationResource;
use App\Models\Variation;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
use Illuminate\Support\Facades\Gate;
class VariationApiController extends Controller
{
public function index(Request $request)
{
abort_if(Gate::denies('variation_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$variations = Variation::when($request->filled('value'), function ($query) use ($request){
$searchQuery = $request->get('value');
$query->whereRaw("type like '%".addslashes($searchQuery)."%' OR value like '%".addslashes($searchQuery)."%'");
})->orderBy('created_at', 'DESC');
$variations = (int)$request->input("page") > 0 ? $variations->paginate(50) : $variations->get();
return VariationResource::collection($variations);
}
public function activeVariations(Request $request)
{
abort_if(Gate::denies('variation_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$variations = Variation::when($request->filled('type'), function ($query) use ($request){
$query->where('type', 'like', "%{$request->get('type')}%");
})->when($request->filled('value'), function ($query) use ($request){
$query->where('value', 'like', "%{$request->get('value')}%");
})
->where('status', 1)
->orderBy('created_at', 'DESC')->get();
VariationResource::withoutWrapping();
return VariationResource::collection($variations);
}
public function store(StoreVariationRequest $request)
{
$variation = Variation::create($request->validated());
return (new VariationResource($variation))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function show(Variation $variation)
{
abort_if(Gate::denies('variation_show'), Response::HTTP_FORBIDDEN, '403 Forbidden');
return new VariationResource($variation);
}
public function update(UpdateVariationRequest $request, Variation $variation)
{
$variation->update($request->validated());
return (new VariationResource($variation))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function destroy(Variation $variation)
{
abort_if(Gate::denies('variation_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden');
try {
$variation->delete();
return response(['message' => 'Variation deleted successfully'], Response::HTTP_OK);
}catch (\Exception $e){
\Log::channel('db_errors')->info('Record Deletion Error : Variation -> '.$variation->id);
\Log::channel('db_errors')->info($e->getMessage());
return response([
'message' => "Record not deleted.",
'errors' => ["error" => ["Unable to delete variation."]]
], Response::HTTP_INTERNAL_SERVER_ERROR);
}
}
}