| Server IP : / Your IP : 10.244.4.16 [ Web Server : nginx/1.25.3 System : Linux escuela-portal-app-54f56585bc-kst6g 5.15.0-1084-azure #93-Ubuntu SMP Sat Mar 15 14:12:29 UTC 2025 x86_64 User : root ( 0) PHP Version : 8.2.13 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, Domains : 0 Domains MySQL : OFF | cURL : ON | WGET : OFF | Perl : ON | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /var/www/app/app/Http/Controllers/Managment/ |
Upload File : |
<?php
namespace App\Http\Controllers\Managment;
use App\Http\Controllers\Controller;
use App\Models\Cycle;
use App\Models\Page;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use PhpParser\Node\NullableType;
class CycleController extends Controller
{
public function index()
{
return DB::table('cycles AS c')
->leftjoin('courses AS cr', 'c.id', 'cr.cycle_id')
->leftjoin('options AS m', 'c.modality_type_id', 'm.id')
->select(
array(
'c.id', 'c.name', 'c.imagen', 'c.certification', 'm.name AS modality', DB::raw('COUNT( DISTINCT cr.id) AS courses'),
)
)
->groupBy('c.id')->get();
}
public function store(Request $request)
{
try {
DB::transaction(function () use ($request) {
$cycle = Cycle::create($request->all());
$cycle->updateData($request->all(), true);
});
$response = true;
} catch (\Throwable $th) {
$response = $th;
}
return $response;
}
public function edit($id)
{
return Cycle::find($id)->getFullData();
}
public function update(Request $request, $id)
{
$response = false;
try {
DB::transaction(function () use ($request, $id) {
Cycle::find($id)->updateData($request->all());
});
$response = true;
} catch (\Throwable $th) {
$response = $th;
}
return $response;
}
public function destroy($id)
{
try {
DB::transaction(function () use ($id) {
$cycle = Cycle::find($id);
Page::where('slug', '/ciclos/' . $cycle->slug)->first()->delete();
$cycle->delete();
});
$response = true;
} catch (\Throwable $th) {
$response = $th;
}
return $response;
}
}