HEX
Server: Apache/2.4.65 (Ubuntu)
System: Linux ielts-store-v2 6.8.0-1036-gcp #38~22.04.1-Ubuntu SMP Thu Aug 14 01:19:18 UTC 2025 x86_64
User: root (0)
PHP: 7.2.34-54+ubuntu20.04.1+deb.sury.org+1
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,
Upload Files
File: //proc/self/cwd/wp-content/plugins/automatewoo/includes/Jobs/AbstractOneTimeActionSchedulerJob.php
<?php

namespace AutomateWoo\Jobs;

use AutomateWoo\Exceptions\InvalidArgument;
use AutomateWoo\Traits\ArrayValidator;
use Exception;

defined( 'ABSPATH' ) || exit;

/**
 * AbstractOneTimeActionSchedulerJob class.
 *
 * A "one time job" is a job that receives all the items it needs to process immediately instead of in batches.
 *
 * @since 5.2.0
 */
abstract class AbstractOneTimeActionSchedulerJob extends AbstractActionSchedulerJob implements OneTimeActionSchedulerJobInterface {

	use ArrayValidator;

	/**
	 * Process a single item.
	 *
	 * @param array $item A single item to process. Expects a validated item.
	 *
	 * @throws Exception If an error occurs. The exception will be logged by ActionScheduler.
	 */
	abstract protected function process_item( array $item );

	/**
	 * Init the batch schedule for the job.
	 *
	 * The job name is used to generate the schedule event name.
	 */
	public function init() {
		add_action( $this->get_process_item_hook(), [ $this, 'handle_process_item_action' ] );
	}

	/**
	 * Starts the job.
	 *
	 * @param array[] $items The items to process in the job.
	 *                       Items are stored in the database so don't include full objects.
	 *
	 * @throws InvalidArgument If an item is not valid.
	 */
	public function start( array $items = [] ) {
		// Validate all items before adding scheduling any.
		foreach ( $items as $item ) {
			$this->validate_item( $item );
		}

		foreach ( $items as $item ) {
			$this->action_scheduler->schedule_immediate( $this->get_process_item_hook(), [ $item ] );
		}
	}

	/**
	 * Handles the process item job action.
	 *
	 * @param array $item
	 *
	 * @throws Exception If an error occurs.
	 * @throws InvalidArgument If args or an item is invalid.
	 */
	public function handle_process_item_action( array $item ) {
		$this->validate_item( $item );
		$this->process_item( $item );
	}

	/**
	 * Validate an item to be processed by the job.
	 *
	 * @param array $item
	 *
	 * @throws InvalidArgument If the item is not valid.
	 */
	protected function validate_item( array $item ) {
		$this->validate_is_non_empty_array( $item );
	}

}