<?php
/**
* @file mod/worker.php
- * @brief Module for running the poller as frontend process
+ * @brief Module for running the worker as frontend process
*/
-require_once("include/poller.php");
-use \Friendica\Core\Config;
-use \Friendica\Core\PConfig;
+use Friendica\Core\Config;
+use Friendica\Core\Worker;
+use Friendica\Util\DateTimeFormat;
-function worker_init($a){
+function worker_init()
+{
if (!Config::get("system", "frontend_worker")) {
return;
// We don't need the following lines if we can execute background jobs.
// So we just wake up the worker if it sleeps.
if (function_exists("proc_open")) {
- call_worker_if_idle();
+ Worker::executeIfIdle();
return;
}
- clear_worker_processes();
+ Worker::clearProcesses();
$workers = q("SELECT COUNT(*) AS `processes` FROM `process` WHERE `command` = 'worker.php'");
return;
}
- $a->start_process();
+ Worker::startProcess();
logger("Front end worker started: ".getmypid());
- call_worker();
-
- if ($r = poller_worker_process()) {
+ Worker::callWorker();
+ if ($r = Worker::workerProcess()) {
// On most configurations this parameter wouldn't have any effect.
// But since it doesn't destroy anything, we just try to get more execution time in any way.
set_time_limit(0);
- poller_execute($r[0]);
+ $fields = ['executed' => DateTimeFormat::utcNow(), 'pid' => getmypid(), 'done' => false];
+ $condition = ['id' => $r[0]["id"], 'pid' => 0];
+ if (dba::update('workerqueue', $fields, $condition)) {
+ Worker::execute($r[0]);
+ }
}
- call_worker();
+ Worker::callWorker();
+
+ Worker::unclaimProcess();
- $a->end_process();
+ Worker::endProcess();
logger("Front end worker ended: ".getmypid());