HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
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/zaklada/wp-content/plugins/coming-soon/app/subscriber.php
<?php

/*
 * subscribers Datatable
 */
function seedprod_lite_subscribers_datatable()
{
    if (check_ajax_referer('seedprod_nonce')) {
        $data = array('');
        $current_page = 1;
        if (!empty(absint($_GET['current_page']))) {
            $current_page = absint($_GET['current_page']);
        }
        $per_page=100;

        $filter = null;
        if (!empty($_GET['filter'])) {
            $filter = sanitize_text_field($_GET['filter']);
            if ($filter == 'all') {
                $filter = null;
            }
        }

        if (!empty($_GET['s'])) {
            $filter = null;
        }

        $results = array();
        //var_dump($results);
        $data = array();
        foreach ($results as $v) {
     
                // Format Date
        $created_at = date(get_option('date_format').' '.get_option('time_format'), strtotime($v->created));


            // Load Data
            $data[] = array(
                     'id' => $v->id,
                     'email' => $v->email,
                     'name' => $v->fname.' '.$v->lname,
                     'created_at' => $created_at,
                     'page_uuid' => $v->page_uuid,
                     );
        }

        $totalitems = 0;
        $views = array();

        // Get recent subscriber data
        $chart_timeframe = 7;
        if(!empty($_GET['interval'])){
            $chart_timeframe = absint($_GET['interval']);
        }

        $recent_subscribers = array();
        

        $now = new \DateTime("$chart_timeframe days ago", new \DateTimeZone('America/New_York'));
        $interval = new \DateInterval('P1D'); // 1 Day interval
        $period = new \DatePeriod($now, $interval, $chart_timeframe); // 7 Days

        $recent_subscribers_data = array(
            array("Year","Subscribers"),
        );
        foreach ($period as $day) {
            $key = $day->format('Y-m-d');
            $display_key = $day->format('M j');
            $no_val = true;
            foreach ($recent_subscribers as $v) {
                if ($key == $v->created) {
                    $recent_subscribers_data[] = array($display_key,absint($v->count));
                    $no_val = false;
                }
            }
            if ($no_val) {
                $recent_subscribers_data[] = array($display_key,0);
            }
        }
     
        $response = array(
                 'recent_subscribers' => $recent_subscribers_data,
                 'rows' => $data,
                 'lpage_name' => '',
                 'totalitems' => $totalitems,
                 'totalpages' => ceil($totalitems/$per_page),
                 'currentpage'=> $current_page,
                 'views'=>$views,
             );
     
        wp_send_json($response);
    }
}

function seedprod_lite_subscribers_get_data_total($filter = null)
{
    global $wpdb;

    $tablename = $wpdb->prefix . 'csp3_subscribers';

    $sql = "SELECT count(id) FROM $tablename";

    if(!empty($_GET['id'])){
        $sql .= ' WHERE page_uuid = '.esc_sql($_GET['id']);
    }else{
        $sql .= ' WHERE 1 =1 ';
    }

    if (!empty($_GET['s'])) {
        $sql .= ' AND email LIKE "%'. esc_sql(trim(sanitize_text_field($_GET['s']))).'%"';
    }

    $results = $wpdb->get_var($sql);
    return $results;
}

function seedprod_lite_subscribers_get_views($filter = null)
{
    $views = array();
    $current = (!empty($filter) ? $filter : 'all');

    global $wpdb;
    $tablename = $wpdb->prefix . 'csp3_subscribers';

    //All link
    $sql = "SELECT count(id) FROM $tablename";

    if(!empty($_GET['id'])){
        $sql .= ' WHERE lpage_id = '.esc_sql($_GET['id']);
    }else{
        $sql .= ' WHERE 1 =1 ';
    }

    $results = $wpdb->get_var($sql);
    $class = ($current == 'all' ? ' class="current"' :'');
    $all_url = remove_query_arg('filter');
    $views['all'] = $results;

    return $views;
}


/*
* Update Subscriber
*/
function seedprod_lite_update_subscriber_count()
{
    if (check_ajax_referer('seedprod_lite_update_subscriber_count')) {
        update_option('seedprod_subscriber_count', 1);
    } 

}