- Adds new task scheduler configuration class
- Introduces method to start cron on demand when there are scheduled newsletters or queues in progress
This commit is contained in:
@ -107,7 +107,7 @@ class Initializer {
|
|||||||
$this->setupShortcodes();
|
$this->setupShortcodes();
|
||||||
$this->setupHooks();
|
$this->setupHooks();
|
||||||
$this->setupImages();
|
$this->setupImages();
|
||||||
$this->runQueueSupervisor();
|
$this->setupTaskScheduler();
|
||||||
|
|
||||||
$this->plugin_initialized = true;
|
$this->plugin_initialized = true;
|
||||||
} catch(\Exception $e) {
|
} catch(\Exception $e) {
|
||||||
@ -192,14 +192,9 @@ class Initializer {
|
|||||||
$router->init();
|
$router->init();
|
||||||
}
|
}
|
||||||
|
|
||||||
function runQueueSupervisor() {
|
function setupTaskScheduler() {
|
||||||
if(php_sapi_name() === 'cli') return;
|
$task_scheduler = new TaskScheduler();
|
||||||
try {
|
$task_scheduler->init();
|
||||||
$supervisor = new Supervisor();
|
|
||||||
$supervisor->checkDaemon();
|
|
||||||
} catch(\Exception $e) {
|
|
||||||
// Prevent Daemon exceptions from breaking out and breaking UI
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function setupImages() {
|
function setupImages() {
|
||||||
|
65
lib/Config/TaskScheduler.php
Normal file
65
lib/Config/TaskScheduler.php
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
<?php
|
||||||
|
namespace MailPoet\Config;
|
||||||
|
|
||||||
|
use MailPoet\Cron\Supervisor;
|
||||||
|
use MailPoet\Cron\Workers\Scheduler as SchedulerWorker;
|
||||||
|
use MailPoet\Cron\Workers\SendingQueue\SendingQueue as SendingQueueWorker;
|
||||||
|
use MailPoet\Models\Setting;
|
||||||
|
|
||||||
|
if(!defined('ABSPATH')) exit;
|
||||||
|
|
||||||
|
class TaskScheduler {
|
||||||
|
const METHOD_WORDPRESS = 'WordPress';
|
||||||
|
const METHOD_MAILPOET = 'MailPoet';
|
||||||
|
|
||||||
|
function __construct() {
|
||||||
|
$this->method = self::getCurrentMethod();
|
||||||
|
}
|
||||||
|
|
||||||
|
function init() {
|
||||||
|
// configure task scheduler only outside of cli environment
|
||||||
|
if(php_sapi_name() === 'cli') return;
|
||||||
|
switch($this->method) {
|
||||||
|
case self::METHOD_MAILPOET:
|
||||||
|
return $this->configureMailpoetScheduler();
|
||||||
|
break;
|
||||||
|
case self::METHOD_WORDPRESS:
|
||||||
|
return $this->configureWordpressScheduler();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new \Exception(__("Task scheduler is not configured"));
|
||||||
|
break;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
function configureMailpoetScheduler() {
|
||||||
|
try {
|
||||||
|
$supervisor = new Supervisor();
|
||||||
|
$supervisor->checkDaemon();
|
||||||
|
} catch(\Exception $e) {
|
||||||
|
// exceptions should not prevent the rest of the site loading
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function configureWordpressScheduler() {
|
||||||
|
$scheduled_queues = SchedulerWorker::getScheduledQueues();
|
||||||
|
$running_queues = SendingQueueWorker::getRunningQueues();
|
||||||
|
// run cron only when there are scheduled queues ready to be processed
|
||||||
|
// or are already being processed
|
||||||
|
if($scheduled_queues || $running_queues) {
|
||||||
|
return $this->configureMailpoetScheduler();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
static function getAvailableMethods() {
|
||||||
|
return array(
|
||||||
|
'mailpoet' => self::METHOD_MAILPOET,
|
||||||
|
'wordpress' => self::METHOD_WORDPRESS
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
static function getCurrentMethod() {
|
||||||
|
return Setting::getValue('task_scheduler.method');
|
||||||
|
}
|
||||||
|
}
|
@ -24,9 +24,7 @@ class Scheduler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function process() {
|
function process() {
|
||||||
$scheduled_queues = SendingQueue::where('status', 'scheduled')
|
$scheduled_queues = self::getScheduledQueues();
|
||||||
->whereLte('scheduled_at', Carbon::createFromTimestamp(current_time('timestamp')))
|
|
||||||
->findMany();
|
|
||||||
if(!count($scheduled_queues)) return;
|
if(!count($scheduled_queues)) return;
|
||||||
foreach($scheduled_queues as $i => $queue) {
|
foreach($scheduled_queues as $i => $queue) {
|
||||||
$newsletter = Newsletter::filter('filterWithOptions')
|
$newsletter = Newsletter::filter('filterWithOptions')
|
||||||
@ -185,4 +183,10 @@ class Scheduler {
|
|||||||
$notification_history :
|
$notification_history :
|
||||||
false;
|
false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static function getScheduledQueues() {
|
||||||
|
return SendingQueue::where('status', 'scheduled')
|
||||||
|
->whereLte('scheduled_at', Carbon::createFromTimestamp(current_time('timestamp')))
|
||||||
|
->findMany();
|
||||||
|
}
|
||||||
}
|
}
|
@ -27,7 +27,7 @@ class SendingQueue {
|
|||||||
|
|
||||||
function process() {
|
function process() {
|
||||||
$this->mailer_task->checkSendingLimit();
|
$this->mailer_task->checkSendingLimit();
|
||||||
foreach($this->getQueues() as $queue) {
|
foreach(self::getRunningQueues() as $queue) {
|
||||||
// get and pre-process newsletter (render, replace shortcodes/links, etc.)
|
// get and pre-process newsletter (render, replace shortcodes/links, etc.)
|
||||||
$newsletter = $this->newsletter_task->getAndPreProcess($queue->asArray());
|
$newsletter = $this->newsletter_task->getAndPreProcess($queue->asArray());
|
||||||
if(!$newsletter) {
|
if(!$newsletter) {
|
||||||
@ -168,6 +168,13 @@ class SendingQueue {
|
|||||||
->findMany();
|
->findMany();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static function getRunningQueues() {
|
||||||
|
return SendingQueueModel::orderByDesc('priority')
|
||||||
|
->whereNull('deleted_at')
|
||||||
|
->whereNull('status')
|
||||||
|
->findMany();
|
||||||
|
}
|
||||||
|
|
||||||
function updateQueue($queue) {
|
function updateQueue($queue) {
|
||||||
$queue->count_processed =
|
$queue->count_processed =
|
||||||
count($queue->subscribers['processed']) + count($queue->subscribers['failed']);
|
count($queue->subscribers['processed']) + count($queue->subscribers['failed']);
|
||||||
|
Reference in New Issue
Block a user