HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: 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,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/alq-cali.bikenow.co/app/Http/Controllers/Api/PopupEmbedApiController.php
<?php

namespace App\Http\Controllers\Api;

use App\PopupEmbed;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Auth;
use Carbon\Carbon;

class PopupEmbedApiController extends Controller
{
    public function get()
    {
        $userId = Auth::user()->id;
        $popUpsForUser = PopupEmbed::select('popup_embeds.*')
            ->leftjoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
            ->leftJoin('tags', function ($join) {
                $join->on('tags.id', '=', 'popup_tags.tag_id')
                    ->where('tags.active', 1);
            })
            ->leftjoin('user_tags', 'user_tags.tag_id', '=', 'popup_tags.tag_id')
            ->where(function ($q) use ($userId) {
                $q->where('user_tags.user_id', $userId)
                    ->orWhereNull('popup_tags.id')
                    ->orWhereNull('tags.id');
            })
            ->where('popup_embeds.active', true)
            ->get();

        $popUpsForAll = PopupEmbed::select('popup_embeds.*')
            ->leftjoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
            ->whereNull('popup_tags.id')
            ->where('popup_embeds.active', true)
            ->get();

        return response()->json($popUpsForUser->merge($popUpsForAll), 200);
    }

    public function getPopups($target, $typeAcademy = null)
    {
        $userId = Auth::user()->id;
        $now = Carbon::now();
        /*\Log::info('PARAMETROS POPUPS:', [
            'target' => $target,
            'typeAcademy' => $typeAcademy,
            'type' => gettype($typeAcademy),
        ]);*/
    //  Popups para el usuario
    $popUpsForUser = PopupEmbed::select('popup_embeds.*')
        ->leftJoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
        ->leftJoin('tags', function ($join) {
            $join->on('tags.id', '=', 'popup_tags.tag_id')
                 ->where('tags.active', 1);
        })
        ->leftJoin('user_tags', 'user_tags.tag_id', '=', 'popup_tags.tag_id')
        ->where(function ($q) use ($userId) {
            $q->where('user_tags.user_id', $userId)
              ->orWhereNull('popup_tags.id')
              ->orWhereNull('tags.id');
        })
        ->where('popup_embeds.active', true)
        ->where('popup_embeds.target', 'LIKE', '%' . $target . '%')
        ->where(function ($query) use ($now) {
            $query->whereNull('popup_embeds.start_date')
                  ->orWhere(function ($subQuery) use ($now) {
                      $subQuery->where('popup_embeds.start_date', '<=', $now)
                               ->where('popup_embeds.end_date', '>=', $now);
                  });
        });

    // Filtro de tipo de academia
    if (!empty($typeAcademy)) {
        $popUpsForUser->where(function ($q) use ($typeAcademy) {
            $q->where('popup_embeds.type_academy', $typeAcademy)
              ->orWhere('popup_embeds.type_academy', 'all');
        });
    }
    //Ejecuta la consulta
    $popUpsForUser = $popUpsForUser->get();

    // Popups globales (sin tags)
    $popUpsForAll = PopupEmbed::select('popup_embeds.*')
        ->leftJoin('popup_tags', 'popup_embeds.id', '=', 'popup_tags.popup_id')
        ->whereNull('popup_tags.id')
        ->where('popup_embeds.active', true)
        ->where('popup_embeds.target', 'LIKE', '%' . $target . '%')
        ->where(function ($query) use ($now) {
            $query->whereNull('popup_embeds.start_date')
                  ->orWhere(function ($subQuery) use ($now) {
                      $subQuery->where('popup_embeds.start_date', '<=', $now)
                               ->where('popup_embeds.end_date', '>=', $now);
                  });
        });

    if (!empty($typeAcademy)) {
        $popUpsForAll->where(function ($q) use ($typeAcademy) {
            $q->where('popup_embeds.type_academy', $typeAcademy)
              ->orWhere('popup_embeds.type_academy', 'all');
        });
    }
    // Ejecuta la consulta
    $popUpsForAll = $popUpsForAll->get();
    $popups = $popUpsForUser->merge($popUpsForAll);

    return response()->json($popups, 200);
}}