X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=xmpp%2Fxmpp.php;h=33da9715554de63a0c0b039aa831c01411dafc88;hb=b11e418f3570a5a61bab3fb3bc2660b92635b108;hp=7ac7eb3b9816ffbf637eae62af1757749696f6df;hpb=9ac7e18bdd6e0f9a513109edcc767f59af824e24;p=friendica-addons.git diff --git a/xmpp/xmpp.php b/xmpp/xmpp.php index 7ac7eb3b..33da9715 100644 --- a/xmpp/xmpp.php +++ b/xmpp/xmpp.php @@ -4,88 +4,191 @@ * Description: Embedded XMPP (Jabber) client * Version: 0.1 * Author: Michael Vogel + * Status: Unsupported */ -function xmpp_install() { - register_hook('page_end', 'addon/xmpp/xmpp.php', 'xmpp_script'); - register_hook('logged_in', 'addon/xmpp/xmpp.php', 'xmpp_login'); +use Friendica\App; +use Friendica\Core\Hook; +use Friendica\Core\Renderer; +use Friendica\DI; +use Friendica\Util\Strings; + +function xmpp_install() +{ + Hook::register('addon_settings', 'addon/xmpp/xmpp.php', 'xmpp_addon_settings'); + Hook::register('addon_settings_post', 'addon/xmpp/xmpp.php', 'xmpp_addon_settings_post'); + Hook::register('page_end', 'addon/xmpp/xmpp.php', 'xmpp_script'); + Hook::register('logged_in', 'addon/xmpp/xmpp.php', 'xmpp_login'); } -function xmpp_uninstall() { - unregister_hook('page_end', 'addon/xmpp/xmpp.php', 'xmpp_script'); - unregister_hook('logged_in', 'addon/xmpp/xmpp.php', 'xmpp_login'); +function xmpp_uninstall() +{ + Hook::unregister('addon_settings', 'addon/xmpp/xmpp.php', 'xmpp_addon_settings'); + Hook::unregister('addon_settings_post', 'addon/xmpp/xmpp.php', 'xmpp_addon_settings_post'); + Hook::unregister('page_end', 'addon/xmpp/xmpp.php', 'xmpp_script'); + Hook::unregister('logged_in', 'addon/xmpp/xmpp.php', 'xmpp_login'); } -function xmpp_login($a,$b) { - if (!$_SESSION["allow_api"]) { - $password = substr(random_string(),0,16); - set_pconfig(local_user(), "xmpp", "password", $password); +function xmpp_addon_settings_post() +{ + if (!local_user() || empty($_POST['xmpp-settings-submit'])) { + return; + } + + DI::pConfig()->set(local_user(), 'xmpp', 'enabled', $_POST['xmpp_enabled'] ?? false); + DI::pConfig()->set(local_user(), 'xmpp', 'individual', $_POST['xmpp_individual'] ?? false); + DI::pConfig()->set(local_user(), 'xmpp', 'bosh_proxy', $_POST['xmpp_bosh_proxy'] ?? ''); + + info(DI::l10n()->t('XMPP settings updated.') . EOL); +} + +function xmpp_addon_settings(App $a, &$s) +{ + if (!local_user()) { + return; + } + + /* Add our stylesheet to the xmpp so we can make our settings look nice */ + + DI::page()['htmlhead'] .= '' . "\r\n"; + + /* Get the current state of our config variable */ + + $enabled = intval(DI::pConfig()->get(local_user(), 'xmpp', 'enabled')); + $enabled_checked = (($enabled) ? ' checked="checked" ' : ''); + + $individual = intval(DI::pConfig()->get(local_user(), 'xmpp', 'individual')); + $individual_checked = (($individual) ? ' checked="checked" ' : ''); + + $bosh_proxy = DI::pConfig()->get(local_user(), "xmpp", "bosh_proxy"); + + /* Add some HTML to the existing form */ + $s .= ''; + $s .= '

' . DI::l10n()->t('XMPP-Chat (Jabber)') . '

'; + $s .= '
'; + $s .= ''; } -function xmpp_plugin_admin(&$a, &$o){ - $t = get_markup_template("admin.tpl", "addon/xmpp/"); +function xmpp_login() +{ + if (empty($_SESSION['allow_api'])) { + $password = Strings::getRandomHex(16); + DI::pConfig()->set(local_user(), 'xmpp', 'password', $password); + } +} - $o = replace_macros($t, array( - '$submit' => t('Save Settings'), - '$bosh_proxy' => array('bosh_proxy', t('BOSH proxy'), get_config('xmpp', 'bosh_proxy'), ''), - '$central_userbase' => array('central_userbase', t('Use central userbase'), get_config('xmpp', 'central_userbase'), t('If enabled, users will automatically login to an ejabberd server that has to be installed on this machine with synchronized credentials via the "auth_ejabberd.php" script.')), - )); +function xmpp_addon_admin(App $a, &$o) +{ + $t = Renderer::getMarkupTemplate('admin.tpl', 'addon/xmpp/'); + + $o = Renderer::replaceMacros($t, [ + '$submit' => DI::l10n()->t('Save Settings'), + '$bosh_proxy' => ['bosh_proxy', DI::l10n()->t('Jabber BOSH host'), DI::config()->get('xmpp', 'bosh_proxy'), ''], + '$central_userbase' => ['central_userbase', DI::l10n()->t('Use central userbase'), DI::config()->get('xmpp', 'central_userbase'), DI::l10n()->t('If enabled, users will automatically login to an ejabberd server that has to be installed on this machine with synchronized credentials via the "auth_ejabberd.php" script.')], + ]); } -function xmpp_plugin_admin_post(&$a){ - $bosh_proxy = ((x($_POST,'bosh_proxy')) ? trim($_POST['bosh_proxy']) : ''); - $central_userbase = ((x($_POST,'central_userbase')) ? intval($_POST['central_userbase']) : false); - set_config('xmpp','bosh_proxy',$bosh_proxy); - set_config('xmpp','central_userbase',$central_userbase); - info( t('Settings updated.'). EOL ); +function xmpp_addon_admin_post() +{ + $bosh_proxy = (!empty($_POST['bosh_proxy']) ? trim($_POST['bosh_proxy']) : ''); + $central_userbase = (!empty($_POST['central_userbase']) ? intval($_POST['central_userbase']) : false); + + DI::config()->set('xmpp', 'bosh_proxy', $bosh_proxy); + DI::config()->set('xmpp', 'central_userbase', $central_userbase); + + info(DI::l10n()->t('Settings updated.') . EOL); } -function xmpp_script(&$a,&$s) { - xmpp_converse($a,$s); - //xmpp_jappix($a,$s); +function xmpp_script(App $a) +{ + xmpp_converse($a); } -function xmpp_converse(&$a,&$s) { - if (!local_user()) +function xmpp_converse(App $a) +{ + if (!local_user()) { + return; + } + + if (($_GET['mode'] ?? '') == 'minimal') { + return; + } + + if (DI::mode()->isMobile() || DI::mode()->isMobile()) { + return; + } + + if (!DI::pConfig()->get(local_user(), "xmpp", "enabled")) { return; + } - if ($_GET["mode"] == "minimal") + if (in_array(DI::args()->getQueryString(), ["admin/federation/"])) { return; + } - $a->page['htmlhead'] .= ''."\n"; - $a->page['htmlhead'] .= ''."\n"; + DI::page()['htmlhead'] .= '' . "\n"; + DI::page()['htmlhead'] .= '' . "\n"; - $bosh_proxy = get_config("xmpp", "bosh_proxy"); + if (DI::config()->get("xmpp", "central_userbase") && !DI::pConfig()->get(local_user(), "xmpp", "individual")) { + $bosh_proxy = DI::config()->get("xmpp", "bosh_proxy"); - if (get_config("xmpp", "central_userbase")) { - $password = get_pconfig(local_user(), "xmpp", "password"); + $password = DI::pConfig()->get(local_user(), "xmpp", "password", '', true); if ($password == "") { - $password = substr(random_string(),0,16); - set_pconfig(local_user(), "xmpp", "password", $password); + $password = Strings::getRandomHex(16); + DI::pConfig()->set(local_user(), "xmpp", "password", $password); } - $jid = $a->user["nickname"]."@".$a->get_hostname()."/converse-".substr(random_string(),0,5);; + $jid = $a->user["nickname"] . "@" . DI::baseUrl()->getHostname() . "/converse-" . Strings::getRandomHex(5); $auto_login = "auto_login: true, authentication: 'login', jid: '$jid', password: '$password', - allow_logout: true, - auto_list_rooms: true,"; - } else + allow_logout: false,"; + } else { + $bosh_proxy = DI::pConfig()->get(local_user(), "xmpp", "bosh_proxy"); + $auto_login = ""; + } - if (in_array($a->argv[0], array("manage", "logout"))) + if ($bosh_proxy == "") { + return; + } + + if (in_array($a->argv[0], ["delegation", "logout"])) { $additional_commands = "converse.user.logout();\n"; - else + } else { $additional_commands = ""; + } $on_ready = ""; - //$on_ready = "converse.rooms.open(['support@conference.pirati.ca']);\n"; - -// converse.contacts.add('ike@jabber.piratenpartei.de'); $initialize = "converse.initialize({ bosh_service_url: '$bosh_proxy', @@ -110,7 +213,7 @@ function xmpp_converse(&$a,&$s) { xhr_user_search: false });\n"; - $a->page['htmlhead'] .= ""; } - -function xmpp_jappix(&$a,&$s) { - if (!local_user()) - return; - - if ($_GET["mode"] == "minimal") - return; - - $bosh_proxy = get_config("xmpp", "bosh_proxy"); - - if (get_config("xmpp", "central_userbase")) { - $password = get_pconfig(local_user(), "xmpp", "password"); - - if ($password == "") { - $password = substr(random_string(),0,16); - set_pconfig(local_user(), "xmpp", "password", $password); - } - - $user = $a->user["nickname"]; - $domain = $a->get_hostname(); - - $auto_login = "auto_login: true, - authentication: 'login', - jid: '$jid', - password: '$password', - allow_logout: false,"; - } else - $auto_login = ""; - - //$a->page['htmlhead'] .= ""; - - $a->page['htmlhead'] .= " - "; -} - -?>