X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=bin%2Fworker.php;h=469dcb001e6419accd062df13597abc705cfbf2d;hb=39d073523662cce61e40daf51806624688b1aeba;hp=b4b265283ccba3d60ea44a38ffc9b6d48c0a92e0;hpb=78114c13d5ce27b36682a960859056d4ebf9d9be;p=friendica.git diff --git a/bin/worker.php b/bin/worker.php index b4b265283c..469dcb001e 100755 --- a/bin/worker.php +++ b/bin/worker.php @@ -5,62 +5,60 @@ * @brief Starts the background processing */ +use Dice\Dice; use Friendica\App; use Friendica\BaseObject; -use Friendica\Core\Addon; use Friendica\Core\Config; +use Friendica\Core\Update; use Friendica\Core\Worker; +use Psr\Log\LoggerInterface; + +// Get options +$shortopts = 'sn'; +$longopts = ['spawn', 'no_cron']; +$options = getopt($shortopts, $longopts); // 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; + if (substr($directory, 0, 1) != '/') { + $directory = $_SERVER["PWD"] . '/' . $directory; } - $directory = realpath($directory."/.."); + $directory = realpath($directory . '/..'); chdir($directory); } -require_once "boot.php"; -require_once "include/dba.php"; - -$a = new App(dirname(__DIR__)); -BaseObject::setApp($a); +require dirname(__DIR__) . '/vendor/autoload.php'; -require_once ".htconfig.php"; -dba::connect($db_host, $db_user, $db_pass, $db_data); -unset($db_host, $db_user, $db_pass, $db_data); +$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php'); +$dice = $dice->addRule(LoggerInterface::class,['constructParams' => ['worker']]); -Config::load(); +BaseObject::setDependencyInjection($dice); +$a = BaseObject::getApp(); // Check the database structure and possibly fixes it -check_db(true); +Update::check($a->getBasePath(), true, $a->getMode()); // Quit when in maintenance -if (Config::get('system', 'maintenance', false, true)) { +if (!$a->getMode()->has(App\Mode::MAINTENANCEDISABLED)) { return; } -$a->set_baseurl(Config::get('system', 'url')); - -Addon::loadHooks(); +$a->setBaseURL(Config::get('system', 'url')); -$spawn = (($_SERVER["argc"] == 2) && ($_SERVER["argv"][1] == "spawn")); +$spawn = array_key_exists('s', $options) || array_key_exists('spawn', $options); if ($spawn) { Worker::spawnWorker(); - killme(); + exit(); } -$run_cron = (($_SERVER["argc"] <= 1) || ($_SERVER["argv"][1] != "no_cron")); +$run_cron = !array_key_exists('n', $options) && !array_key_exists('no_cron', $options); Worker::processQueue($run_cron); Worker::unclaimProcess(); Worker::endProcess(); - -killme(); -