shell bypass 403

UnknownSec Shell


name : WaitlistController.php
<?php

namespace App\Http\Controllers\Admin;

use App\Exports\AgoraHistoryExport;
use App\Exports\WaitlistItemsExport;
use App\Exports\WaitlistsExport;
use App\Http\Controllers\Controller;
use App\Models\Waitlist;
use App\Models\Webinar;
use Illuminate\Http\Request;
use Maatwebsite\Excel\Facades\Excel;

class WaitlistController extends Controller
{
    public function index(Request $request)
    {
        $this->authorize('admin_waitlists_lists');

        $waitlists = Webinar::query()
            ->where('enable_waitlist', true)
            ->paginate(10);

        foreach ($waitlists as $waitlist) {
            $query = Waitlist::query()->where('webinar_id', $waitlist->id);

            $waitlist->members = deepClone($query)->count();
            $waitlist->registered_members = deepClone($query)->whereNotNull('user_id')->count();

            $lastSubmission = deepClone($query)->orderBy('created_at', 'desc')->first();

            if (!empty($lastSubmission)) {
                $waitlist->last_submission = $lastSubmission->created_at;
            }
        }

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

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

    public function exportExcel(Request $request)
    {
        $this->authorize('admin_waitlists_exports');

        $waitlists = Webinar::query()
            ->where('enable_waitlist', true)
            ->get();

        foreach ($waitlists as $waitlist) {
            $query = Waitlist::query()->where('webinar_id', $waitlist->id);

            $waitlist->members = deepClone($query)->count();
            $waitlist->registered_members = deepClone($query)->whereNotNull('user_id')->count();

            $lastSubmission = deepClone($query)->orderBy('created_at', 'desc')->first();

            if (!empty($lastSubmission)) {
                $waitlist->last_submission = $lastSubmission->created_at;
            }
        }

        $export = new WaitlistsExport($waitlists);

        return Excel::download($export, 'waitlists.xlsx');
    }

    public function viewList(Request $request, $webinarId, $justReturnQuery = false)
    {
        $this->authorize('admin_waitlists_users');

        $webinar = Webinar::query()->findOrFail($webinarId);

        $query = Waitlist::query()->where('webinar_id', $webinarId);

        $from = $request->get('from');
        $to = $request->get('to');
        $search = $request->get('search');
        $registrationStatus = $request->get('registration_status');

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

        if (!empty($search)) {
            $query->where(function ($query) use ($search) {
                $query->where('full_name', 'like', "%$search%");
                $query->orWhereHas('user', function ($query) use ($search) {
                    $query->where('full_name', 'like', "%$search%");
                });
            });
        }

        if (!empty($registrationStatus)) {
            if ($registrationStatus == 'registered') {
                $query->whereNotNull('user_id');
            } else if ($registrationStatus == 'unregistered') {
                $query->whereNull('user_id');
            }
        }

        if ($justReturnQuery) {
            return $query;
        }

        $waitlists = $query
            ->with(['user'])
            ->orderBy('created_at', 'desc')
            ->paginate(10);

        $data = [
            'pageTitle' => trans('update.waitlists') . ' - ' . $webinar->title,
            'waitlists' => $waitlists,
            'waitlistId' => $webinarId,
            'webinarTitle' => $webinar->title,
        ];

        return view('admin.waitlists.users_list', $data);
    }

    public function clearList(Request $request, $webinarId)
    {
        $this->authorize('admin_waitlists_clear_list');

        Waitlist::query()->where('webinar_id', $webinarId)
            ->delete();

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

    public function disableWaitlist(Request $request, $webinarId)
    {
        $this->authorize('admin_waitlists_disable');

        $webinar = Webinar::query()->findOrFail($webinarId);

        $webinar->update([
            'enable_waitlist' => false
        ]);

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

    public function exportUsersList(Request $request, $webinarId)
    {
        $this->authorize('admin_waitlists_exports');

        $waitlists = $this->viewList($request, $webinarId, true)
            ->with(['user'])
            ->orderBy('created_at', 'desc')
            ->get();

        $export = new WaitlistItemsExport($waitlists);

        return Excel::download($export, 'waitlist_items.xlsx');
    }


    public function deleteWaitlistItems($waitlistId)
    {
        $this->authorize('admin_waitlists_users');

        Waitlist::query()
            ->where('id', $waitlistId)
            ->delete();

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

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

Courses

17 Courses
Course
Full Stack Web Development

Full Stack Web Development

in Web Development
83:20 Hours
10 Oct 2024
₹28,318.82
Course
Installment and Secure Host

Installment and Secure Host

in Business Strategy
5.00
1:30 Hours
16 Mar 2023
₹118
Course
New Update Features

New Update Features

in Language
4.00
1:30 Hours
21 Jun 2022
Free
Not conducted
Bestseller
New In-App Live System

New In-App Live System

in Communications
5.00
2:30 Hours
1 Mar 2026
₹11.80
Featured
New Learning Page

New Learning Page

in Lifestyle
5.00
3:30 Hours
1 Mar 2022
Free
Finished
How to Travel Around the World

How to Travel Around the World

in Lifestyle
5.00
2:30 Hours
2 Mar 2022
₹29.50

Type

More options