X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=blockem%2Fblockem.php;h=e0c0a74a29894870218f17afc584c9f1c0e97373;hb=59fe5be9873bea6ff9b50095e76bd530f54772c3;hp=45272e00628d5dfa6bee3107ddb83a54ed41ebc1;hpb=dbe8118e406510d85404d9577f83d68782cfe2a0;p=friendica-addons.git diff --git a/blockem/blockem.php b/blockem/blockem.php index 45272e00..e0c0a74a 100644 --- a/blockem/blockem.php +++ b/blockem/blockem.php @@ -4,157 +4,166 @@ * Description: Allows users to hide content by collapsing posts and replies. * Version: 1.0 * Author: Mike Macgirvin - * + * Author: Roland Haeder */ -use Friendica\Core\Addon; + +use Friendica\App; +use Friendica\Core\Hook; use Friendica\Core\L10n; use Friendica\Core\PConfig; +use Friendica\Util\Strings; function blockem_install() { - Addon::registerHook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body'); - Addon::registerHook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item'); - Addon::registerHook('addon_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings'); - Addon::registerHook('addon_settings_post', 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); - Addon::registerHook('conversation_start', 'addon/blockem/blockem.php', 'blockem_conversation_start'); - Addon::registerHook('item_photo_menu', 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); - Addon::registerHook('enotify_store', 'addon/blockem/blockem.php', 'blockem_enotify_store'); + Hook::register('prepare_body_content_filter', 'addon/blockem/blockem.php', 'blockem_prepare_body_content_filter'); + Hook::register('display_item' , 'addon/blockem/blockem.php', 'blockem_display_item'); + Hook::register('addon_settings' , 'addon/blockem/blockem.php', 'blockem_addon_settings'); + Hook::register('addon_settings_post' , 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); + Hook::register('conversation_start' , 'addon/blockem/blockem.php', 'blockem_conversation_start'); + Hook::register('item_photo_menu' , 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); + Hook::register('enotify_store' , 'addon/blockem/blockem.php', 'blockem_enotify_store'); } function blockem_uninstall() { - Addon::unregisterHook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body'); - Addon::unregisterHook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item'); - Addon::unregisterHook('addon_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings'); - Addon::unregisterHook('addon_settings_post', 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); - Addon::unregisterHook('conversation_start', 'addon/blockem/blockem.php', 'blockem_conversation_start'); - Addon::unregisterHook('item_photo_menu', 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); - Addon::unregisterHook('enotify_store', 'addon/blockem/blockem.php', 'blockem_enotify_store'); + Hook::unregister('prepare_body_content_filter', 'addon/blockem/blockem.php', 'blockem_prepare_body_content_filter'); + Hook::unregister('prepare_body' , 'addon/blockem/blockem.php', 'blockem_prepare_body'); + Hook::unregister('display_item' , 'addon/blockem/blockem.php', 'blockem_display_item'); + Hook::unregister('addon_settings' , 'addon/blockem/blockem.php', 'blockem_addon_settings'); + Hook::unregister('addon_settings_post' , 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); + Hook::unregister('conversation_start' , 'addon/blockem/blockem.php', 'blockem_conversation_start'); + Hook::unregister('item_photo_menu' , 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); + Hook::unregister('enotify_store' , 'addon/blockem/blockem.php', 'blockem_enotify_store'); } -function blockem_addon_settings(&$a, &$s) +function blockem_addon_settings (App $a, &$s) { - - if(! local_user()) + if (!local_user()) { return; + } - /* Add our stylesheet to the page so we can make our settings look nice */ - - $a->page['htmlhead'] .= '' . "\r\n"; - + /* Add our stylesheet to the page so we can make our settings look nice */ + $a->page['htmlhead'] .= '' . "\r\n"; $words = PConfig::get(local_user(), 'blockem', 'words'); - if(! $words) + + if (!$words) { $words = ''; + } - $s .= ''; - $s .= '

' . L10n::t('"Blockem"') . '

'; - $s .= '
'; - $s .= ''; return; } -function blockem_addon_settings_post(&$a,&$b) { - - if(! local_user()) +function blockem_addon_settings_post(App $a, array &$b) +{ + if (!local_user()) { return; + } - if($_POST['blockem-submit']) { - PConfig::set(local_user(),'blockem','words',trim($_POST['blockem-words'])); + if (!empty($_POST['blockem-submit'])) { + PConfig::set(local_user(), 'blockem', 'words', trim($_POST['blockem-words'])); info(L10n::t('BLOCKEM Settings saved.') . EOL); } } -function blockem_enotify_store(&$a,&$b) { +function blockem_enotify_store(App $a, array &$b) +{ + $words = PConfig::get($b['uid'], 'blockem', 'words'); - $words = PConfig::get($b['uid'],'blockem','words'); - if($words) { - $arr = explode(',',$words); - } - else { + if ($words) { + $arr = explode(',', $words); + } else { return; } $found = false; - if(count($arr)) { - foreach($arr as $word) { - if(! strlen(trim($word))) { + + if (count($arr)) { + foreach ($arr as $word) { + if (!strlen(trim($word))) { continue; } - if(link_compare($b['url'],$word)) { + if (Strings::compareLink($b['url'], $word)) { $found = true; break; } } } - if($found) { + + if ($found) { $b['abort'] = true; } } -function blockem_prepare_body(&$a,&$b) { - - if(! local_user()) +function blockem_prepare_body_content_filter(App $a, array &$hook_data) +{ + if (!local_user()) { return; - - $words = null; - if(local_user()) { - $words = PConfig::get(local_user(),'blockem','words'); } - if($words) { - $arr = explode(',',$words); + + $profiles_string = null; + + if (local_user()) { + $profiles_string = PConfig::get(local_user(), 'blockem', 'words'); } - else { + + if ($profiles_string) { + $profiles_array = explode(',', $profiles_string); + } else { return; } $found = false; - if(count($arr)) { - foreach($arr as $word) { - if(! strlen(trim($word))) { - continue; - } - if(link_compare($b['item']['author-link'],$word)) { - $found = true; - break; - } + foreach ($profiles_array as $word) { + if (Strings::compareLink($hook_data['item']['author-link'], trim($word))) { + $found = true; + break; } } - if($found) { - $rnd = random_string(8); - $b['html'] = ''; + + if ($found) { + $hook_data['filter_reasons'][] = L10n::t('Filtered user: %s', $hook_data['item']['author-name']); } } -function blockem_display_item(&$a,&$b) { - if(strstr($b['output']['body'],'id="blockem-wrap-')) - $b['output']['thumb'] = $a->get_baseurl() . "/images/person-80.jpg"; +function blockem_display_item(App $a, array &$b = null) +{ + if (!empty($b['output']['body']) && strstr($b['output']['body'], 'id="blockem-wrap-')) { + $b['output']['thumb'] = $a->getBaseURL() . "/images/person-80.jpg"; + } } -function blockem_conversation_start(&$a,&$b) { - - if(! local_user()) +function blockem_conversation_start(App $a, array &$b) +{ + if (!local_user()) { return; + } - $words = PConfig::get(local_user(),'blockem','words'); - if($words) { - $a->data['blockem'] = explode(',',$words); + $words = PConfig::get(local_user(), 'blockem', 'words'); + + if ($words) { + $a->data['blockem'] = explode(',', $words); } + $a->page['htmlhead'] .= <<< EOT EOT; - } -function blockem_item_photo_menu(&$a,&$b) { - - if((! local_user()) || ($b['item']['self'])) +function blockem_item_photo_menu(App $a, array &$b) +{ + if (!local_user() || $b['item']['self']) { return; + } $blocked = false; $author = $b['item']['author-link']; - if(is_array($a->data['blockem'])) { + + if (!empty($a->data['blockem'])) { foreach($a->data['blockem'] as $bloke) { - if(link_compare($bloke,$author)) { + if (Strings::compareLink($bloke,$author)) { $blocked = true; break; } } } - if($blocked) + if ($blocked) { $b['menu'][L10n::t('Unblock Author')] = 'javascript:blockemUnblock(\'' . $author . '\');'; - else + } else { $b['menu'][L10n::t('Block Author')] = 'javascript:blockemBlock(\'' . $author . '\');'; + } } -function blockem_module() {} - - -function blockem_init(&$a) { +function blockem_module() +{ +} - if(! local_user()) +function blockem_init(App $a) +{ + if (!local_user()) { return; + } - $words = PConfig::get(local_user(),'blockem','words'); + $words = PConfig::get(local_user(), 'blockem', 'words'); - if(array_key_exists('block',$_GET) && $_GET['block']) { - if(strlen($words)) + if (array_key_exists('block', $_GET) && $_GET['block']) { + if (strlen($words)) { $words .= ','; + } + $words .= trim($_GET['block']); } - if(array_key_exists('unblock',$_GET) && $_GET['unblock']) { + + if (array_key_exists('unblock', $_GET) && $_GET['unblock']) { $arr = explode(',',$words); $newarr = []; - if(count($arr)) { - foreach($arr as $x) { - if(! link_compare(trim($x),trim($_GET['unblock']))) + if (count($arr)) { + foreach ($arr as $x) { + if (!Strings::compareLink(trim($x), trim($_GET['unblock']))) { $newarr[] = $x; + } } } - $words = implode(',',$newarr); + + $words = implode(',', $newarr); } - PConfig::set(local_user(),'blockem','words',$words); - info(L10n::t('blockem settings updated') . EOL ); - killme(); + PConfig::set(local_user(), 'blockem', 'words', $words); + info(L10n::t('blockem settings updated') . EOL); + exit(); }