5 * @brief Starts the background processing
8 use Friendica\Core\Config;
9 use Friendica\Core\Worker;
10 use Friendica\Core\Update;
11 use Friendica\Util\LoggerFactory;
15 $longopts = ['spawn', 'no_cron'];
16 $options = getopt($shortopts, $longopts);
18 // Ensure that worker.php is executed from the base path of the installation
19 if (!file_exists("boot.php") && (sizeof($_SERVER["argv"]) != 0)) {
20 $directory = dirname($_SERVER["argv"][0]);
22 if (substr($directory, 0, 1) != '/') {
23 $directory = $_SERVER["PWD"] . '/' . $directory;
25 $directory = realpath($directory . '/..');
30 require dirname(__DIR__) . '/vendor/autoload.php';
32 $logger = LoggerFactory::create('worker');
34 $a = new App(dirname(__DIR__), $logger);
36 // Check the database structure and possibly fixes it
39 // Quit when in maintenance
40 if (!$a->getMode()->has(App\Mode::MAINTENANCEDISABLED)) {
44 $a->setBaseURL(Config::get('system', 'url'));
46 $spawn = array_key_exists('s', $options) || array_key_exists('spawn', $options);
49 Worker::spawnWorker();
53 $run_cron = !array_key_exists('n', $options) && !array_key_exists('no_cron', $options);
55 Worker::processQueue($run_cron);
57 Worker::unclaimProcess();