mirror of
https://github.com/friendica/friendica
synced 2025-01-04 22:40:50 +01:00
Merge pull request #14628 from Art4/refactor-entrypoint-worker.php
Refactor entrypoint `worker.php`
This commit is contained in:
commit
3f39b6366f
3 changed files with 54 additions and 54 deletions
|
@ -10,6 +10,7 @@ parameters:
|
||||||
- bin/auth_ejabberd.php
|
- bin/auth_ejabberd.php
|
||||||
- bin/console.php
|
- bin/console.php
|
||||||
- bin/daemon.php
|
- bin/daemon.php
|
||||||
|
- bin/worker.php
|
||||||
- index.php
|
- index.php
|
||||||
- src/
|
- src/
|
||||||
|
|
||||||
|
|
|
@ -15,64 +15,17 @@ if (php_sapi_name() !== 'cli') {
|
||||||
}
|
}
|
||||||
|
|
||||||
use Dice\Dice;
|
use Dice\Dice;
|
||||||
use Friendica\App\Mode;
|
|
||||||
use Friendica\Core\Logger\Capability\LogChannel;
|
|
||||||
use Friendica\Core\Update;
|
|
||||||
use Friendica\Core\Worker;
|
|
||||||
use Friendica\DI;
|
|
||||||
use Psr\Log\LoggerInterface;
|
|
||||||
|
|
||||||
// Get options
|
// Get options
|
||||||
$shortopts = 'sn';
|
$options = getopt('sn', ['spawn', 'no_cron']);
|
||||||
$longopts = ['spawn', 'no_cron'];
|
|
||||||
$options = getopt($shortopts, $longopts);
|
|
||||||
|
|
||||||
// Ensure that worker.php is executed from the base path of the installation
|
// Ensure that worker.php is executed from the base path of the installation
|
||||||
if (!file_exists("index.php") && (sizeof($_SERVER["argv"]) != 0)) {
|
chdir(dirname(__DIR__));
|
||||||
$directory = dirname($_SERVER["argv"][0]);
|
|
||||||
|
|
||||||
if (substr($directory, 0, 1) != '/') {
|
|
||||||
$directory = $_SERVER["PWD"] . '/' . $directory;
|
|
||||||
}
|
|
||||||
$directory = realpath($directory . '/..');
|
|
||||||
|
|
||||||
chdir($directory);
|
|
||||||
}
|
|
||||||
|
|
||||||
require dirname(__DIR__) . '/vendor/autoload.php';
|
require dirname(__DIR__) . '/vendor/autoload.php';
|
||||||
|
|
||||||
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
$dice = (new Dice())->addRules(require(dirname(__DIR__) . '/static/dependencies.config.php'));
|
||||||
/** @var \Friendica\Core\Addon\Capability\ICanLoadAddons $addonLoader */
|
|
||||||
$addonLoader = $dice->create(\Friendica\Core\Addon\Capability\ICanLoadAddons::class);
|
|
||||||
$dice = $dice->addRules($addonLoader->getActiveAddonConfig('dependencies'));
|
|
||||||
$dice = $dice->addRule(LoggerInterface::class, ['constructParams' => [LogChannel::WORKER]]);
|
|
||||||
|
|
||||||
DI::init($dice);
|
$app = \Friendica\App::fromDice($dice);
|
||||||
\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class));
|
|
||||||
|
|
||||||
DI::mode()->setExecutor(Mode::WORKER);
|
$app->processWorker($options ?: []);
|
||||||
|
|
||||||
// Check the database structure and possibly fixes it
|
|
||||||
Update::check(DI::basePath(), true);
|
|
||||||
|
|
||||||
// Quit when in maintenance
|
|
||||||
if (!DI::mode()->has(Mode::MAINTENANCEDISABLED)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$spawn = array_key_exists('s', $options) || array_key_exists('spawn', $options);
|
|
||||||
|
|
||||||
if ($spawn) {
|
|
||||||
Worker::spawnWorker();
|
|
||||||
exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
$run_cron = !array_key_exists('n', $options) && !array_key_exists('no_cron', $options);
|
|
||||||
|
|
||||||
$process = DI::process()->create(getmypid(), basename(__FILE__));
|
|
||||||
|
|
||||||
Worker::processQueue($run_cron, $process);
|
|
||||||
|
|
||||||
Worker::unclaimProcess($process);
|
|
||||||
|
|
||||||
DI::process()->delete($process);
|
|
||||||
|
|
50
src/App.php
50
src/App.php
|
@ -21,6 +21,7 @@ use Friendica\Core\Config\Factory\Config;
|
||||||
use Friendica\Core\KeyValueStorage\Capability\IManageKeyValuePairs;
|
use Friendica\Core\KeyValueStorage\Capability\IManageKeyValuePairs;
|
||||||
use Friendica\Core\Renderer;
|
use Friendica\Core\Renderer;
|
||||||
use Friendica\Core\Session\Capability\IHandleUserSessions;
|
use Friendica\Core\Session\Capability\IHandleUserSessions;
|
||||||
|
use Friendica\Core\Worker\Repository\Process as ProcessRepository;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\Database\Definition\DbaDefinition;
|
use Friendica\Database\Definition\DbaDefinition;
|
||||||
use Friendica\Database\Definition\ViewDefinition;
|
use Friendica\Database\Definition\ViewDefinition;
|
||||||
|
@ -48,8 +49,6 @@ use Friendica\Util\Profiler;
|
||||||
use Psr\Http\Message\ServerRequestInterface;
|
use Psr\Http\Message\ServerRequestInterface;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Our main application structure for the life of this page.
|
* Our main application structure for the life of this page.
|
||||||
*
|
*
|
||||||
|
@ -436,6 +435,53 @@ class App
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function processWorker(array $options): void
|
||||||
|
{
|
||||||
|
$this->setupContainerForAddons();
|
||||||
|
|
||||||
|
$this->setupContainerForLogger(LogChannel::WORKER);
|
||||||
|
|
||||||
|
$this->setupLegacyServiceLocator();
|
||||||
|
|
||||||
|
$this->registerErrorHandler();
|
||||||
|
|
||||||
|
/** @var Mode */
|
||||||
|
$mode = $this->container->create(Mode::class);
|
||||||
|
|
||||||
|
$mode->setExecutor(Mode::WORKER);
|
||||||
|
|
||||||
|
/** @var BasePath */
|
||||||
|
$basePath = $this->container->create(BasePath::class);
|
||||||
|
|
||||||
|
// Check the database structure and possibly fixes it
|
||||||
|
Update::check($basePath->getPath(), true);
|
||||||
|
|
||||||
|
// Quit when in maintenance
|
||||||
|
if (!$mode->has(Mode::MAINTENANCEDISABLED)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$spawn = array_key_exists('s', $options) || array_key_exists('spawn', $options);
|
||||||
|
|
||||||
|
if ($spawn) {
|
||||||
|
Worker::spawnWorker();
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
$run_cron = !array_key_exists('n', $options) && !array_key_exists('no_cron', $options);
|
||||||
|
|
||||||
|
/** @var ProcessRepository */
|
||||||
|
$processRepository = $this->container->create(ProcessRepository::class);
|
||||||
|
|
||||||
|
$process = $processRepository->create(getmypid(), 'worker.php');
|
||||||
|
|
||||||
|
Worker::processQueue($run_cron, $process);
|
||||||
|
|
||||||
|
Worker::unclaimProcess($process);
|
||||||
|
|
||||||
|
$processRepository->delete($process);
|
||||||
|
}
|
||||||
|
|
||||||
private function setupContainerForAddons(): void
|
private function setupContainerForAddons(): void
|
||||||
{
|
{
|
||||||
/** @var \Friendica\Core\Addon\Capability\ICanLoadAddons $addonLoader */
|
/** @var \Friendica\Core\Addon\Capability\ICanLoadAddons $addonLoader */
|
||||||
|
|
Loading…
Reference in a new issue