#!/usr/bin/env php
<?php
/**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2021, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
* - 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
*
*
*/
+if (php_sapi_name() !== 'cli') {
+ header($_SERVER["SERVER_PROTOCOL"] . ' 403 Forbidden');
+ exit();
+}
+
use Dice\Dice;
use Friendica\App\Mode;
-use Friendica\Util\ExAuth;
+use Friendica\Security\ExAuth;
use Psr\Log\LoggerInterface;
if (sizeof($_SERVER["argv"]) == 0) {
$appMode = $dice->create(Mode::class);
if ($appMode->isNormal()) {
- $oAuth = new ExAuth();
+ /** @var ExAuth $oAuth */
+ $oAuth = $dice->create(ExAuth::class);
$oAuth->readStdin();
}