HEX
Server: Apache/2.4.34 (Red Hat) OpenSSL/1.0.2k-fips
System: Linux WORDPRESS 3.10.0-1160.118.1.el7.x86_64 #1 SMP Thu Apr 4 03:33:23 EDT 2024 x86_64
User: digital (1020)
PHP: 7.2.24
Disabled: NONE
Upload Files
File: /datos/www/expodubai/wp-content/plugins/modern-events-calendar-lite/app/crons/auto-emails.php
<?php
/**
 *  WordPress initializing
 */
function mec_find_wordpress_base_path()
{
    $dir = dirname(__FILE__);
    
    do
    {
        if(file_exists($dir.'/wp-load.php') and file_exists($dir.'/wp-config.php')) return $dir;
    }
    while($dir = realpath($dir.'/..'));
    
    return NULL;
}

define('BASE_PATH', mec_find_wordpress_base_path().'/');
if(!defined('WP_USE_THEMES')) define('WP_USE_THEMES', false);

global $wp, $wp_query, $wp_the_query, $wp_rewrite, $wp_did_header;
require BASE_PATH.'wp-load.php';

/** @var $main MEC_main **/

// MEC libraries
$main = MEC::getInstance('app.libraries.main');

// Blogs
$blogs = array(1);

// Current Blog ID
$multisite = (function_exists('is_multisite') and is_multisite());
$current_blog_id = get_current_blog_id();

// Database
$db = $main->getDB();

// Multisite
if($multisite) $blogs = $db->select("SELECT `blog_id` FROM `#__blogs`", 'loadColumn');

$sent_emails = 0;
$now = current_time('Y-m-d H:i');

$now_start = strtotime($now);
$now_end = $now_start + 60;

foreach($blogs as $blog)
{
    // Switch to Blog
    if($multisite) switch_to_blog($blog);

    // MEC Settings
    $settings = $main->get_settings();

    // Auto Emails is disabled
    if(!isset($settings['auto_emails_module_status']) or (isset($settings['auto_emails_module_status']) and !$settings['auto_emails_module_status'])) continue;

    /**
     * Notification Sender Library
     * @var $notif MEC_notifications
     */
    $notif = $main->getNotifications();

    // All Emails
    $emails = get_posts(array('post_type'=>$main->get_email_post_type(), 'numberposts'=>-1, 'post_status'=>'publish'));

    // Send Emails
    foreach($emails as $email)
    {
        $time = get_post_meta($email->ID, 'mec_time', true);
        if($time == '') $time = 1;

        $type = get_post_meta($email->ID, 'mec_type', true);
        if($type == '') $type = 'day';

        $afterbefore = get_post_meta($email->ID, 'mec_afterbefore', true);
        if($afterbefore == '') $afterbefore = 'before';

        $all = get_post_meta($email->ID, 'mec_all', true);
        if($all == '') $all = 1;

        $events = get_post_meta($email->ID, 'mec_events', true);
        if(!is_array($events)) $events = array();

        if($type === 'day') $plus_minus = $time * (3600 * 24);
        elseif($type === 'hour') $plus_minus = $time * 3600;
        else $plus_minus = $time * 60;

        if($afterbefore === 'after') $plus_minus *= -1;

        $occ_start = $now_start + $plus_minus;
        $occ_end = $now_end + $plus_minus;

        $query = "SELECT `post_id`, `tstart`, `tend` FROM `#__mec_dates` WHERE `tstart`>=".$occ_start." AND `tend`<".$occ_end;
        if(!$all and count($events)) $query .= " AND `post_id` IN (".implode(',', $events).")";

        // Fetch Event Occurrences
        $occurrences = $db->select($query, 'loadObjectList');

        foreach($occurrences as $occurrence)
        {
            $bookings = $main->get_bookings($occurrence->post_id, $occurrence->tstart);

            foreach($bookings as $booking)
            {
                $result = $notif->auto_email($booking->ID, $email->post_title, $email->post_content, $occurrence->tstart);
                if($result) $sent_emails++;
            }
        }
    }
}

// Switch to Current Blog
if($multisite) switch_to_blog($current_blog_id);

echo sprintf(__('%s emails(s) sent.', 'modern-events-calendar-lite'), $sent_emails);
exit;