Sometimes errors overlap each other so that the 'Last Seen error' we log does not provide sufficient information on the cause of a problem. E.g. one worker might cause an SQL issue, which closes the EntityManager and a subsequent worker might overwrite this error with the information that the EntityManager is closed. With this commit, both those issues will be logged as an error. [MAILPOET-4699]
97 lines
3.5 KiB
PHP
97 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace MailPoet\Cron;
|
|
|
|
use MailPoet\Cron\Workers\WorkersFactory;
|
|
use MailPoet\Logging\LoggerFactory;
|
|
|
|
class Daemon {
|
|
public $timer;
|
|
|
|
/** @var CronHelper */
|
|
private $cronHelper;
|
|
|
|
/** @var CronWorkerRunner */
|
|
private $cronWorkerRunner;
|
|
|
|
/** @var WorkersFactory */
|
|
private $workersFactory;
|
|
|
|
/** @var LoggerFactory */
|
|
private $loggerFactory;
|
|
|
|
public function __construct(
|
|
CronHelper $cronHelper,
|
|
CronWorkerRunner $cronWorkerRunner,
|
|
WorkersFactory $workersFactory,
|
|
LoggerFactory $loggerFactory
|
|
) {
|
|
$this->timer = microtime(true);
|
|
$this->workersFactory = $workersFactory;
|
|
$this->cronWorkerRunner = $cronWorkerRunner;
|
|
$this->cronHelper = $cronHelper;
|
|
$this->loggerFactory = $loggerFactory;
|
|
}
|
|
|
|
public function run($settingsDaemonData) {
|
|
$settingsDaemonData['run_started_at'] = time();
|
|
$this->cronHelper->saveDaemon($settingsDaemonData);
|
|
|
|
$errors = [];
|
|
foreach ($this->getWorkers() as $worker) {
|
|
try {
|
|
if ($worker instanceof CronWorkerInterface) {
|
|
$this->cronWorkerRunner->run($worker);
|
|
} else {
|
|
$worker->process($this->timer); // BC for workers not implementing CronWorkerInterface
|
|
}
|
|
} catch (\Exception $e) {
|
|
$workerClassNameParts = explode('\\', get_class($worker));
|
|
$workerName = end($workerClassNameParts);
|
|
$errors[] = [
|
|
'worker' => $workerName,
|
|
'message' => $e->getMessage(),
|
|
];
|
|
|
|
/**
|
|
* ToDo: Use \LoggerFactory::TOPIC_CRON as logger topic, once it is available
|
|
*/
|
|
$this->loggerFactory->getLogger()->error($e->getMessage(), ['error' => $e, 'worker' => $workerName]);
|
|
}
|
|
}
|
|
|
|
if (!empty($errors)) {
|
|
$this->cronHelper->saveDaemonLastError($errors);
|
|
}
|
|
|
|
// Log successful execution
|
|
$this->cronHelper->saveDaemonRunCompleted(time());
|
|
}
|
|
|
|
private function getWorkers() {
|
|
yield $this->workersFactory->createMigrationWorker();
|
|
yield $this->workersFactory->createStatsNotificationsWorker(); // not CronWorkerInterface compatible
|
|
yield $this->workersFactory->createScheduleWorker(); // not CronWorkerInterface compatible
|
|
yield $this->workersFactory->createQueueWorker(); // not CronWorkerInterface compatible
|
|
yield $this->workersFactory->createSendingServiceKeyCheckWorker();
|
|
yield $this->workersFactory->createPremiumKeyCheckWorker();
|
|
yield $this->workersFactory->createSubscribersStatsReportWorker();
|
|
yield $this->workersFactory->createBounceWorker();
|
|
yield $this->workersFactory->createExportFilesCleanupWorker();
|
|
yield $this->workersFactory->createBeamerkWorker();
|
|
yield $this->workersFactory->createSubscribersEmailCountsWorker();
|
|
yield $this->workersFactory->createInactiveSubscribersWorker();
|
|
yield $this->workersFactory->createUnsubscribeTokensWorker();
|
|
yield $this->workersFactory->createWooCommerceSyncWorker();
|
|
yield $this->workersFactory->createAuthorizedSendingEmailsCheckWorker();
|
|
yield $this->workersFactory->createWooCommercePastOrdersWorker();
|
|
yield $this->workersFactory->createStatsNotificationsWorkerForAutomatedEmails();
|
|
yield $this->workersFactory->createSubscriberLinkTokensWorker();
|
|
yield $this->workersFactory->createSubscribersEngagementScoreWorker();
|
|
yield $this->workersFactory->createSubscribersLastEngagementWorker();
|
|
yield $this->workersFactory->createSubscribersCountCacheRecalculationWorker();
|
|
yield $this->workersFactory->createReEngagementEmailsSchedulerWorker();
|
|
yield $this->workersFactory->createNewsletterTemplateThumbnailsWorker();
|
|
}
|
|
}
|