X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=blockem%2Fblockem.php;h=e0c0a74a29894870218f17afc584c9f1c0e97373;hb=59fe5be9873bea6ff9b50095e76bd530f54772c3;hp=43f34554e24071cc92a492c2121a4b8d244f8632;hpb=d7bd2246c18f5880fc3c083bf3d698fe4f29fcb6;p=friendica-addons.git diff --git a/blockem/blockem.php b/blockem/blockem.php old mode 100755 new mode 100644 index 43f34554..e0c0a74a --- a/blockem/blockem.php +++ b/blockem/blockem.php @@ -1,127 +1,169 @@ - * + * Author: Roland Haeder */ -function blockem_install() { - register_hook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body'); - register_hook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item'); - register_hook('plugin_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings'); - register_hook('plugin_settings_post', 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); - register_hook('conversation_start', 'addon/blockem/blockem.php', 'blockem_conversation_start'); - register_hook('item_photo_menu', 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); +use Friendica\App; +use Friendica\Core\Hook; +use Friendica\Core\L10n; +use Friendica\Core\PConfig; +use Friendica\Util\Strings; + +function blockem_install() +{ + 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() { - unregister_hook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body'); - unregister_hook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item'); - unregister_hook('plugin_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings'); - unregister_hook('plugin_settings_post', 'addon/blockem/blockem.php', 'blockem_addon_settings_post'); - unregister_hook('conversation_start', 'addon/blockem/blockem.php', 'blockem_conversation_start'); - unregister_hook('item_photo_menu', 'addon/blockem/blockem.php', 'blockem_item_photo_menu'); - +function blockem_uninstall() +{ + 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) { - - if(! local_user()) +function blockem_addon_settings (App $a, &$s) +{ + 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'); - $words = get_pconfig(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']) { - set_pconfig(local_user(),'blockem','words',trim($_POST['blockem-words'])); - info( t('BLOCKEM Settings saved.') . EOL); + if (!empty($_POST['blockem-submit'])) { + PConfig::set(local_user(), 'blockem', 'words', trim($_POST['blockem-words'])); + info(L10n::t('BLOCKEM Settings saved.') . EOL); } } -function blockem_prepare_body(&$a,&$b) { +function blockem_enotify_store(App $a, array &$b) +{ + $words = PConfig::get($b['uid'], 'blockem', 'words'); - if(! local_user()) - return; - - $words = null; - if(local_user()) { - $words = get_pconfig(local_user(),'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['item']['author-link'],$word)) { + if (Strings::compareLink($b['url'], $word)) { $found = true; break; } } } - if($found) { - $rnd = random_string(8); - $b['html'] = ''; + + if ($found) { + $b['abort'] = true; } } +function blockem_prepare_body_content_filter(App $a, array &$hook_data) +{ + if (!local_user()) { + return; + } -function blockem_display_item(&$a,&$b) { - if(strstr($b['output'],'id="blockem-wrap-')) - $b['output'] = preg_replace('/\/','get_baseurl() . "/images/default-profile-sm.jpg" . '" class="wall-item-photo$3>',$b['output']); -} + $profiles_string = null; + + if (local_user()) { + $profiles_string = PConfig::get(local_user(), 'blockem', 'words'); + } + + if ($profiles_string) { + $profiles_array = explode(',', $profiles_string); + } else { + return; + } + + $found = false; + + foreach ($profiles_array as $word) { + if (Strings::compareLink($hook_data['item']['author-link'], trim($word))) { + $found = true; + break; + } + } + if ($found) { + $hook_data['filter_reasons'][] = L10n::t('Filtered user: %s', $hook_data['item']['author-name']); + } +} -function blockem_conversation_start(&$a,&$b) { +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"; + } +} - if(! local_user()) +function blockem_conversation_start(App $a, array &$b) +{ + if (!local_user()) { return; + } + + $words = PConfig::get(local_user(), 'blockem', 'words'); - $words = get_pconfig(local_user(),'blockem','words'); - if($words) { - $a->data['blockem'] = explode(',',$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) - $b['menu'][ t('Unblock Author')] = 'javascript:blockemUnblock("' . $author . '");'; - else - $b['menu'][ t('Block Author')] = 'javascript:blockemBlock("' . $author . '");'; + if ($blocked) { + $b['menu'][L10n::t('Unblock Author')] = 'javascript:blockemUnblock(\'' . $author . '\');'; + } 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 = get_pconfig(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 = array(); + $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); } - set_pconfig(local_user(),'blockem','words',$words); - info( t('blockem settings updated') . EOL ); - killme(); -} \ No newline at end of file + PConfig::set(local_user(), 'blockem', 'words', $words); + info(L10n::t('blockem settings updated') . EOL); + exit(); +}