friendica_2021.01_tupambae_.../bin/worker.php

60 lines
1.3 KiB
PHP
Raw Normal View History

2017-12-14 17:38:51 +01:00
#!/usr/bin/env php
2010-07-19 05:49:54 +02:00
<?php
2017-12-14 17:38:51 +01:00
/**
2018-03-19 04:25:21 +01:00
* @file bin/worker.php
2017-12-14 17:38:51 +01:00
* @brief Starts the background processing
*/
use Friendica\App;
2017-04-30 06:01:26 +02:00
use Friendica\Core\Config;
use Friendica\Core\Worker;
use Friendica\Core\Update;
2018-12-30 21:42:56 +01:00
use Friendica\Util\LoggerFactory;
2017-04-30 06:01:26 +02:00
// Get options
$shortopts = 'sn';
$longopts = ['spawn', 'no_cron'];
$options = getopt($shortopts, $longopts);
2017-11-19 23:00:43 +01:00
// Ensure that worker.php is executed from the base path of the installation
if (!file_exists("boot.php") && (sizeof($_SERVER["argv"]) != 0)) {
$directory = dirname($_SERVER["argv"][0]);
if (substr($directory, 0, 1) != '/') {
$directory = $_SERVER["PWD"] . '/' . $directory;
2017-06-04 22:03:37 +02:00
}
$directory = realpath($directory . '/..');
chdir($directory);
}
2011-04-16 08:40:43 +02:00
require dirname(__DIR__) . '/vendor/autoload.php';
2018-12-30 21:42:56 +01:00
$logger = LoggerFactory::create('worker');
$a = new App(dirname(__DIR__), $logger);
// Check the database structure and possibly fixes it
Update::check(true);
2017-09-30 19:42:03 +02:00
// Quit when in maintenance
if (!$a->getMode()->has(App\Mode::MAINTENANCEDISABLED)) {
return;
}
$a->setBaseURL(Config::get('system', 'url'));
2017-02-27 00:16:49 +01:00
$spawn = array_key_exists('s', $options) || array_key_exists('spawn', $options);
2017-12-14 17:38:51 +01:00
if ($spawn) {
Worker::spawnWorker();
2018-12-26 06:40:12 +01:00
exit();
2017-12-14 17:38:51 +01:00
}
$run_cron = !array_key_exists('n', $options) && !array_key_exists('no_cron', $options);
2017-12-14 17:38:51 +01:00
Worker::processQueue($run_cron);
Worker::unclaimProcess();
Worker::endProcess();