File "CouponApiController.php"
Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/app/Http/Controllers/Api/V1/Admin/CouponApiController.php
File size: 2.49 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\CouponStoreRequest;
use App\Http\Requests\Admin\CouponUpdateRequest;
use App\Http\Resources\Admin\CouponResource;
use App\Models\Coupon;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Gate;
use Symfony\Component\HttpFoundation\Response;
class CouponApiController extends Controller
{
public function index(Request $request)
{
abort_if(Gate::denies('coupon_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$coupons = Coupon::when($request->filled('search'), function ($query) use ($request) {
$query->where('code', 'LIKE', "%{$request->get('search')}%")
->orWhere('discount_type', 'LIKE', "%{$request->get('search')}%")
->orWhere('discount_value', 'LIKE', "%{$request->get('search')}%")
->orWhere('expiry_date', 'LIKE', "%{$request->get('search')}%")
->orWhere('number_of_usage', 'LIKE', "%{$request->get('search')}%")
->orWhere('redemption_count', 'LIKE', "%{$request->get('search')}%");
})->orderBy('id', 'DESC')->paginate(50);
return new CouponResource($coupons);
}
public function store(CouponStoreRequest $request)
{
$coupon = Coupon::create($request->validated());
return (new CouponResource($coupon))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function show(Coupon $coupon)
{
abort_if(Gate::denies('coupon_show'), Response::HTTP_FORBIDDEN, '403 Forbidden');
return new CouponResource($coupon);
}
public function update(CouponUpdateRequest $request, Coupon $coupon)
{
$coupon->update($request->validated());
return (new CouponResource($coupon))
->response()
->setStatusCode(Response::HTTP_CREATED);
}
public function toggleStatus(Coupon $coupon)
{
abort_if(Gate::denies('coupon_edit'), Response::HTTP_FORBIDDEN, '403 Forbidden');
$coupon->status = !$coupon->status;
$coupon->save();
return response(['message' => 'Coupon status updated successfully.'], Response::HTTP_OK);
}
public function verifyCoupon($code)
{
$coupon = validateCouponDetails($code);
return response()->json([
'coupon' => $coupon['coupon'],
'message' => $coupon['message'],
'errors' => $coupon['errors'],
])->setStatusCode($coupon['code']);
}
}