Friendica Communications Platform (please note that this is a clone of the repository at github, issues are handled there) https://friendi.ca
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

86 lines
2.7KB

  1. #!/usr/bin/env php
  2. <?php
  3. /**
  4. * @copyright Copyright (C) 2020, Friendica
  5. *
  6. * @license GNU AGPL version 3 or any later version
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU Affero General Public License as
  10. * published by the Free Software Foundation, either version 3 of the
  11. * License, or (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU Affero General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Affero General Public License
  19. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  20. *
  21. * ejabberd extauth script for the integration with friendica
  22. *
  23. * Originally written for joomla by Dalibor Karlovic <dado@krizevci.info>
  24. * modified for Friendica by Michael Vogel <icarus@dabo.de>
  25. * published under GPL
  26. *
  27. * Latest version of the original script for joomla is available at:
  28. * http://87.230.15.86/~dado/ejabberd/joomla-login
  29. *
  30. * Installation:
  31. *
  32. * - Change it's owner to whichever user is running the server, ie. ejabberd
  33. * $ chown ejabberd:ejabberd /path/to/friendica/bin/auth_ejabberd.php
  34. *
  35. * - Change the access mode so it is readable only to the user ejabberd and has exec
  36. * $ chmod 700 /path/to/friendica/bin/auth_ejabberd.php
  37. *
  38. * - Edit your ejabberd.yml file and add after "shaper:":
  39. *
  40. * auth_method: [external]
  41. * extauth_program: "/path/to/friendica/bin/auth_ejabberd.php"
  42. * auth_use_cache: false
  43. *
  44. * - Restart your ejabberd service, you should be able to login with your friendica auth info
  45. *
  46. * Other hints:
  47. * - if your users have a space or a @ in their nickname, they'll run into trouble
  48. * registering with any client so they should be instructed to replace these chars
  49. * " " (space) is replaced with "%20"
  50. * "@" is replaced with "(a)"
  51. *
  52. */
  53. use Dice\Dice;
  54. use Friendica\App\Mode;
  55. use Friendica\Util\ExAuth;
  56. use Psr\Log\LoggerInterface;
  57. if (sizeof($_SERVER["argv"]) == 0) {
  58. die();
  59. }
  60. $directory = dirname($_SERVER["argv"][0]);
  61. if (substr($directory, 0, 1) != DIRECTORY_SEPARATOR) {
  62. $directory = $_SERVER["PWD"] . DIRECTORY_SEPARATOR . $directory;
  63. }
  64. $directory = realpath($directory . DIRECTORY_SEPARATOR . "..");
  65. chdir($directory);
  66. require dirname(__DIR__) . '/vendor/autoload.php';
  67. $dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
  68. $dice = $dice->addRule(LoggerInterface::class,['constructParams' => ['auth_ejabberd']]);
  69. \Friendica\DI::init($dice);
  70. $appMode = $dice->create(Mode::class);
  71. if ($appMode->isNormal()) {
  72. $oAuth = new ExAuth();
  73. $oAuth->readStdin();
  74. }