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']);
    }
}