• File: FetchInfoBlocksTask.php
  • Full Path: /home/matthif/www/wp-content/plugins/wpforms-lite/src/Emails/FetchInfoBlocksTask.php
  • Date Modified: 02/16/2024 11:45 AM
  • File size: 2.07 KB
  • MIME-type: text/x-php
  • Charset: utf-8
<?php

namespace WPForms\Emails;

use 
WPForms\Tasks\Task;

/**
 * Action Scheduler task to fetch and cache Email Summaries Info Blocks.
 *
 * @since 1.6.4
 */
class FetchInfoBlocksTask extends Task {

    
/**
     * Action name for this task.
     *
     * @since 1.6.4
     */
    
const ACTION 'wpforms_email_summaries_fetch_info_blocks';

    
/**
     * Option name to store the timestamp of the last run.
     *
     * @since 1.6.4
     */
    
const LAST_RUN 'wpforms_email_summaries_fetch_info_blocks_last_run';

    
/**
     * Class constructor.
     *
     * @since 1.6.4
     */
    
public function __construct() {

        
parent::__constructself::ACTION );

        
$this->init();
    }

    
/**
     * Initialize the task with all the proper checks.
     *
     * @since 1.6.4
     */
    
public function init() {

        
$this->hooks();

        
$tasks wpforms()->get'tasks' );

        
// Add new if none exists.
        
if ( $tasks->is_scheduledself::ACTION ) !== false ) {
            return;
        }

        
$this->recurring$this->generate_start_date(), WEEK_IN_SECONDS )->register();
    }

    
/**
     * Add hooks.
     *
     * @since 1.7.3
     */
    
private function hooks() {

        
// Register the action handler.
        
add_actionself::ACTION, [ $this'process' ] );
    }

    
/**
     * Randomly pick a timestamp which is not more than 1 week in the future
     * starting before Email Summaries dispatch happens.
     *
     * @since 1.6.4
     *
     * @return int
     */
    
private function generate_start_date() {

        
$tracking = [];

        
$tracking['days']    = wp_rand0) * DAY_IN_SECONDS;
        
$tracking['hours']   = wp_rand023 ) * HOUR_IN_SECONDS;
        
$tracking['minutes'] = wp_rand059 ) * MINUTE_IN_SECONDS;
        
$tracking['seconds'] = wp_rand059 );

        return 
strtotime'previous monday 1pm' ) + array_sum$tracking );
    }

    
/**
     * Process the task.
     *
     * @since 1.6.4
     */
    
public function process() {

        
$last_run get_optionself::LAST_RUN );

        
// Make sure we do not run it more than once a day.
        
if (
            
$last_run !== false &&
            ( 
time() - $last_run ) < DAY_IN_SECONDS
        
) {
            return;
        }

        ( new 
InfoBlocks() )->cache_all();

        
// Update the last run option to the current timestamp.
        
update_optionself::LAST_RUNtime() );
    }
}