File "VendorsApiController.php"
Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/app/Http/Controllers/Api/V1/Admin/VendorsApiController.php
File size: 2.7 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\StoreVendorRequest;
use App\Http\Requests\Admin\UpdateVendorRequest;
use App\Http\Resources\Admin\VendorResource;
use App\Models\Vendor;
use Gate;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class VendorsApiController extends Controller
{
public function index(Request $request)
{
abort_if(Gate::denies('vendor_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$vendors = Vendor::when($request->filled('name'), function ($query) use ($request) {
$searchQuery = $request->get('name');
$query->whereRaw("name like '%".addslashes($searchQuery)."%' OR email like '%".addslashes($searchQuery)."%' OR phone like '%".addslashes($searchQuery)."%' OR address like '%".addslashes($searchQuery)."%' OR account_number like '%".addslashes($searchQuery)."%' OR payment_terms like '%".addslashes($searchQuery)."%' OR credit_card_ending like '%".addslashes($searchQuery)."%'");
})->orderBy('created_at', 'DESC')->paginate(50);
return new VendorResource($vendors);
}
public function getVendors()
{
$vendors = Vendor::orderBy('name')->get();
return new VendorResource($vendors);
}
public function store(StoreVendorRequest $request)
{
$vendor = Vendor::create($request->all());
return (new VendorResource($vendor))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function show(Vendor $vendor)
{
abort_if(Gate::denies('vendor_show'), Response::HTTP_FORBIDDEN, '403 Forbidden');
return new VendorResource($vendor);
}
public function update(UpdateVendorRequest $request, Vendor $vendor)
{
$vendor->update($request->all());
return (new VendorResource($vendor))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function destroy(Vendor $vendor)
{
abort_if(Gate::denies('vendor_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden');
try {
$vendor->delete();
return response()
->json(['message' => 'Vendor deleted successfully'], Response::HTTP_OK);
}catch (\Exception $e){
\Log::channel('db_errors')->info('Record Deletion Error : Vendor -> '.$vendor->id);
\Log::channel('db_errors')->info($e->getMessage());
return response()
->json([
'message' => "Record not deleted.",
'errors' => ["error" => ["Unable to delete vendor."]]
], Response::HTTP_INTERNAL_SERVER_ERROR);
}
}
}