shell bypass 403

UnknownSec Shell


name : ContentDeleteRequestController.php
<?php

namespace App\Http\Controllers\Admin;

use App\Http\Controllers\Controller;
use App\Models\ContentDeleteRequest;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class ContentDeleteRequestController extends Controller
{

    public function index(Request $request)
    {
        $this->authorize("admin_content_delete_requests_lists");

        $query = ContentDeleteRequest::query()
            ->select('*', DB::raw("case
            when status = 'pending' then 'a'
            when status = 'approved' then 'b'
            when status = 'rejected' then 'c'
            end as status_order
        "));

        $requests = $this->handleFilters($request, $query)
            ->orderBy('status_order', 'asc')
            ->orderBy('created_at', 'desc')
            ->with([
                'user' => function ($qu) {
                    $qu->select('id', 'full_name', 'role_name', 'email', 'mobile');
                }
            ])->paginate(10);


        $data = [
            'pageTitle' => trans('update.content_delete_requests'),
            'requests' => $requests
        ];

        return view('admin.content_delete_requests.index', $data);
    }

    private function handleFilters(Request $request, $query)
    {
        $from = $request->get('from');
        $to = $request->get('to');
        $search = $request->get('search');
        $content_type = $request->get('content_type');
        $status = $request->get('status');

        // $from and $to
        $query = fromAndToDateFilter($from, $to, $query, 'created_at');

        if (!empty($search)) {
            $query->where(function ($query) use ($search) {
                $query->whereHas('webinar', function ($query) use ($search) {
                    $query->whereTranslationLike('title', "%$search%");
                });

                $query->orWhereHas('bundle', function ($query) use ($search) {
                    $query->whereTranslationLike('title', "%$search%");
                });

                $query->orWhereHas('product', function ($query) use ($search) {
                    $query->whereTranslationLike('title', "%$search%");
                });

                $query->orWhereHas('post', function ($query) use ($search) {
                    $query->whereTranslationLike('title', "%$search%");
                });
            });
        }

        if (!empty($content_type)) {
            switch ($content_type) {
                case 'course':
                    $query->where('targetable_type', 'App\Models\Webinar');
                    break;
                case 'bundle':
                    $query->where('targetable_type', 'App\Models\Bundle');
                    break;
                case 'product':
                    $query->where('targetable_type', 'App\Models\Product');
                    break;
                case 'post':
                    $query->where('targetable_type', 'App\Models\Blog');
                    break;
            }
        }

        if (!empty($status)) {
            $query->where('status', $status);
        }

        return $query;
    }

    public function approve($id)
    {
        $this->authorize("admin_content_delete_requests_actions");

        $deleteRequest = ContentDeleteRequest::query()->findOrFail($id);

        $deleteRequest->update([
            'status' => 'approved',
        ]);

        $contentItem = $deleteRequest->getContentItem();
        $contentType = $deleteRequest->getContentType();

        if (!empty($contentItem)) {
            $sales = null;
            $customersCount = null;

            if ($contentType == "course" or $contentType == "bundle") {
                $sales = $contentItem->sales->whereNull('refund_at')->sum('total_amount');
                $customersCount = $contentItem->sales->whereNull('refund_at')->count();
            } elseif ($contentType == "product") {
                $sales = $contentItem->sales()->sum('total_amount');
                $customersCount = $contentItem->salesCount();
            }

            $deleteRequest->update([
                'content_title' => $contentItem->title,
                'content_published_date' => $contentItem->created_at,
                'customers_count' => $customersCount,
                'sales' => $sales,
            ]);

            /* Remove Content */
            $contentItem->delete();
        }

        $toastData = [
            'title' => trans('public.request_success'),
            'msg' => trans('update.content_delete_request_approved_successful'),
            'status' => 'success'
        ];
        return back()->with(['toast' => $toastData]);
    }

    public function reject($id)
    {
        $this->authorize("admin_content_delete_requests_actions");

        $deleteRequest = ContentDeleteRequest::query()->findOrFail($id);

        $deleteRequest->update([
            'status' => 'rejected',
        ]);

        $toastData = [
            'title' => trans('public.request_success'),
            'msg' => trans('update.content_delete_request_rejected_successful'),
            'status' => 'success'
        ];
        return back()->with(['toast' => $toastData]);
    }
}

© 2025 UnknownSec
Courses | Anyleson - Learning Platform
INR (₹)
India Rupee
$
United States Dollar

Courses

17 Courses
Course
Web Design for Beginners

Web Design for Beginners

in Design
4.25
1:45 Hours
8 Jul 2021
₹11.80
40% Offer
The Future of Energy

The Future of Energy

in Science
2.50
1:10 Hours
8 Jul 2021
₹42.48 ₹70.80
20% Offer
Health And Fitness Masterclass

Health And Fitness Masterclass

in Health & Fitness
5.00
1:00 Hours
1 Jul 2021
₹18.88 ₹23.60
20% Offer
Learn and Understand AngularJS

Learn and Understand AngularJS

in Web Development
2.75
1:00 Hours
10 Dec 2023
₹18.88 ₹23.60
Finished
Effective Time Management

Effective Time Management

in Management
5.00
1:30 Hours
1 Aug 2023
₹35.40

Type

More options