BatchPress

A little plugin to help process data in batches.


BatchPress

BatchPress is a little plugin to help process data in batches, with BatchPress you can run, monitor and cancel batched jobs.

Install: composer require lambry/batchpress

screenshot

Usage

To use BatchPress create a new class per job and register those classes using the batchpress/jobs filter.

Job class outline:

  • Required: label property to describe the job.
  • Required: process method which is passed a single item for processing; any info/errors can be returned and will be displayed in the log.
  • Optional Required: items method is optional if the upload property is set to true, in this case it can be used to filter the uploaded content before staring the job. If upload if false or not defined the method is then required to return an array of items for processing.
  • Optional: upload property to tell BatchPress if a CSV upload is required.
  • Optional: batch property to set the number of items to process per batch.
  • Optional: description property to provide extra details about the job.

Basic Example

class Update {
  public $batch = 10;
  public $label = 'Update data';

  // Prepare an array of items for processing
  public function items() : array { }

  // Process each item and optionally return log info
  public function process($item) : mixed { }
}

Example with CSV upload

class Import {
  public $batch = 10;
  public $upload = true;
  public $label = 'Import data';

  // Optionally filter and format the uploaded content before processing
  public function items(array $data) : array { }

  // Process each item and optionally return log info
  public function process($item) : mixed { }
}

Registering jobs

add_filter('batchpress/jobs', fn() => [Update::class, Import::class]);

Helpers

BatchPress provides some helper methods as well, to use them just include the Helpers trait in your job class.

use Lambry\BatchPress\Helpers;

class Update {
  use Helpers;

  public function process($item) : mixed {
    // Adding an image to a post
    $id = this->uploadImage($item['url'], $item['id'], $item['title']);
    // Adding a file to a post
    $id = this->uploadFile($item['url'], $item['id'], $item['title']);
  }
}