X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=bin%2Fauth_ejabberd.php;h=3a95532464a7f2e70a60b09c8b35fc5274d4bfc6;hb=63c8a908804bb019898732af972d04f286eec041;hp=11df438952a06e96ee700a7d6345cba1c90007d8;hpb=3aa77685fcccff9739384136b4894de43200fa8c;p=friendica.git diff --git a/bin/auth_ejabberd.php b/bin/auth_ejabberd.php index 11df438952..3a95532464 100755 --- a/bin/auth_ejabberd.php +++ b/bin/auth_ejabberd.php @@ -1,6 +1,23 @@ #!/usr/bin/env php . + * * ejabberd extauth script for the integration with friendica * * Originally written for joomla by Dalibor Karlovic @@ -18,9 +35,11 @@ * - Change the access mode so it is readable only to the user ejabberd and has exec * $ chmod 700 /path/to/friendica/bin/auth_ejabberd.php * - * - Edit your ejabberd.cfg file, comment out your auth_method and add: - * {auth_method, external}. - * {extauth_program, "/path/to/friendica/bin/auth_ejabberd.php"}. + * - Edit your ejabberd.yml file and add after "shaper:": + * + * auth_method: [external] + * extauth_program: "/path/to/friendica/bin/auth_ejabberd.php" + * auth_use_cache: false * * - Restart your ejabberd service, you should be able to login with your friendica auth info * @@ -32,11 +51,16 @@ * */ -use Friendica\App; -use Friendica\Core\Config; -use Friendica\Factory; -use Friendica\Util\BasePath; -use Friendica\Util\ExAuth; +if (php_sapi_name() !== 'cli') { + header($_SERVER["SERVER_PROTOCOL"] . ' 403 Forbidden'); + exit(); +} + +use Dice\Dice; +use Friendica\App\Mode; +use Friendica\Core\Logger\Capability\LogChannel; +use Friendica\Security\ExAuth; +use Psr\Log\LoggerInterface; if (sizeof($_SERVER["argv"]) == 0) { die(); @@ -54,14 +78,22 @@ chdir($directory); require dirname(__DIR__) . '/vendor/autoload.php'; -$basedir = BasePath::create(dirname(__DIR__), $_SERVER); -$configLoader = new Config\ConfigCacheLoader($basedir); -$config = Factory\ConfigFactory::createCache($configLoader); -$logger = Factory\LoggerFactory::create('auth_ejabberd', $config); +$dice = (new Dice())->addRules(include __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::AUTH_JABBERED]]); + +\Friendica\DI::init($dice); +\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class)); + +// Check the database structure and possibly fixes it +\Friendica\Core\Update::check(\Friendica\DI::basePath(), true); -$a = new App($config, $logger); +$appMode = $dice->create(Mode::class); -if ($a->getMode()->isNormal()) { - $oAuth = new ExAuth(); +if ($appMode->isNormal()) { + /** @var ExAuth $oAuth */ + $oAuth = $dice->create(ExAuth::class); $oAuth->readStdin(); }