X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=bin%2Fworker.php;h=1b70a2095544a2d26b15160b230ddb9f733c4f21;hb=87f054a6423109c5037657d529a48bf5eb65d592;hp=d821fe626a6b47183ed6937df97544f385af8b33;hpb=f2b97f932095ed76656be09e3ba94646187808dc;p=friendica.git diff --git a/bin/worker.php b/bin/worker.php index d821fe626a..1b70a20955 100755 --- a/bin/worker.php +++ b/bin/worker.php @@ -1,63 +1,79 @@ #!/usr/bin/env php . + * + * Starts the background processing */ +use Dice\Dice; use Friendica\App; -use Friendica\Core\Addon; -use Friendica\Core\Config; +use Friendica\Core\Update; use Friendica\Core\Worker; +use Friendica\DI; +use Psr\Log\LoggerInterface; // Get options -$shortopts = 'sc'; -$longopts = ['spawn', 'cron']; +$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 dirname(__DIR__) . '/vendor/autoload.php'; -$a = new App(dirname(__DIR__)); +$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php'); +$dice = $dice->addRule(LoggerInterface::class,['constructParams' => ['worker']]); -Config::load(); +DI::init($dice); +$a = DI::app(); // Check the database structure and possibly fixes it -check_db(true); +Update::check($a->getBasePath(), true, DI::mode()); // Quit when in maintenance -if (Config::get('system', 'maintenance', false, true)) { +if (!DI::mode()->has(App\Mode::MAINTENANCEDISABLED)) { return; } -$a->set_baseurl(Config::get('system', 'url')); - -Addon::loadHooks(); +DI::baseUrl()->saveByURL(DI::config()->get('system', 'url')); $spawn = array_key_exists('s', $options) || array_key_exists('spawn', $options); if ($spawn) { Worker::spawnWorker(); - killme(); + exit(); } -$run_cron = array_key_exists('c', $options) || array_key_exists('cron', $options); +$run_cron = !array_key_exists('n', $options) && !array_key_exists('no_cron', $options); Worker::processQueue($run_cron); Worker::unclaimProcess(); Worker::endProcess(); - -killme();