X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=bin%2Fworker.php;h=5698cf16ddfaca79eb69b0e1aa04d3efa515435c;hb=974f7bffc82d024a38b4709c6b250677a217f65a;hp=3d2fc3fa9fd13c0df36d0170ccf8205c3cf52241;hpb=baa1094489df3e53006dd963f7a890a03f737789;p=friendica.git diff --git a/bin/worker.php b/bin/worker.php index 3d2fc3fa9f..5698cf16dd 100755 --- a/bin/worker.php +++ b/bin/worker.php @@ -1,13 +1,38 @@ #!/usr/bin/env php . + * + * Starts the background processing */ + +if (php_sapi_name() !== 'cli') { + header($_SERVER["SERVER_PROTOCOL"] . ' 403 Forbidden'); + exit(); +} + +use Dice\Dice; use Friendica\App; -use Friendica\Core\Config; +use Friendica\Core\Process; +use Friendica\Core\Update; use Friendica\Core\Worker; -use Friendica\Core\L10n; +use Friendica\DI; +use Psr\Log\LoggerInterface; // Get options $shortopts = 'sn'; @@ -26,28 +51,29 @@ if (!file_exists("boot.php") && (sizeof($_SERVER["argv"]) != 0)) { 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']]); -$lang = L10n::getBrowserLanguage(); -L10n::loadTranslationTable($lang); +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 (!$a->getMode()->has(App\Mode::MAINTENANCEDISABLED)) { +if (!DI::mode()->has(App\Mode::MAINTENANCEDISABLED)) { return; } -$a->setBaseURL(Config::get('system', 'url')); +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('n', $options) && !array_key_exists('no_cron', $options); @@ -56,4 +82,4 @@ Worker::processQueue($run_cron); Worker::unclaimProcess(); -Worker::endProcess(); +DI::process()->end();