X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=blockem%2Fblockem.php;h=1880b9be44e5029bcc36a7da1e20c78746177bc8;hb=7cad0140496e2338726f12eb3c60cc64ee219b8e;hp=f8c30dc6c46ee86c34f3faec71d277b26e9d5335;hpb=7fcc7b9bb000857638466f5e38ee695ea3c67020;p=friendica-addons.git diff --git a/blockem/blockem.php b/blockem/blockem.php index f8c30dc6..1880b9be 100644 --- a/blockem/blockem.php +++ b/blockem/blockem.php @@ -1,111 +1,233 @@ - * + * 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'); - +use Friendica\App; +use Friendica\Core\Hook; +use Friendica\DI; +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_addon_settings (App $a, &$s) +{ + if (!local_user()) { + return; + } -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'); + /* Add our stylesheet to the page so we can make our settings look nice */ + DI::page()['htmlhead'] .= '' . "\r\n"; -} + $words = DI::pConfig()->get(local_user(), 'blockem', 'words'); + if (!$words) { + $words = ''; + } + $s .= ''; + $s .= '

' . DI::l10n()->t('Blockem') . '

'; + $s .= '
'; + $s .= ''; -function blockem_addon_settings(&$a,&$s) { + return; - if(! local_user()) - return; +} - /* Add our stylesheet to the page so we can make our settings look nice */ +function blockem_addon_settings_post(App $a, array &$b) +{ + if (!local_user()) { + return; + } - $a->page['htmlhead'] .= '' . "\r\n"; + if (!empty($_POST['blockem-submit'])) { + DI::pConfig()->set(local_user(), 'blockem', 'words', trim($_POST['blockem-words'])); + } +} +function blockem_enotify_store(App $a, array &$b) +{ + $words = DI::pConfig()->get($b['uid'], 'blockem', 'words'); - $words = get_pconfig(local_user(),'blockem','words'); - if(! $words) - $words = ''; + if ($words) { + $arr = explode(',', $words); + } else { + return; + } - $s .= '
'; - $s .= '

' . t('"Blockem" Settings') . '

'; - $s .= '
'; - $s .= ''; - $s .= ''; - $s .= '
'; + $found = false; - $s .= '
'; + if (count($arr)) { + foreach ($arr as $word) { + if (!strlen(trim($word))) { + continue; + } - return; + if (Strings::compareLink($b['url'], $word)) { + $found = true; + break; + } + } + } + if ($found) { + // empty out the fields + $b = []; + } } -function blockem_addon_settings_post(&$a,&$b) { +function blockem_prepare_body_content_filter(App $a, array &$hook_data) +{ + if (!local_user()) { + return; + } + + $profiles_string = null; + + if (local_user()) { + $profiles_string = DI::pConfig()->get(local_user(), 'blockem', 'words'); + } - if(! local_user()) + if ($profiles_string) { + $profiles_array = explode(',', $profiles_string); + } else { return; + } + + $found = false; - if($_POST['blockem-submit']) { - set_pconfig(local_user(),'blockem','words',trim($_POST['blockem-words'])); - info( t('BLOCKEM Settings saved.') . EOL); + foreach ($profiles_array as $word) { + if (Strings::compareLink($hook_data['item']['author-link'], trim($word))) { + $found = true; + break; + } + } + + if ($found) { + $hook_data['filter_reasons'][] = DI::l10n()->t('Filtered user: %s', $hook_data['item']['author-name']); } } -function blockem_prepare_body(&$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'] = DI::baseUrl()->get() . "/images/person-80.jpg"; + } +} - if(! local_user()) +function blockem_conversation_start(App $a, array &$b) +{ + if (!local_user()) { return; - - $words = null; - if(local_user()) { - $words = get_pconfig(local_user(),'blockem','words'); } - if($words) { - $arr = explode(',',$words); + + $words = DI::pConfig()->get(local_user(), 'blockem', 'words'); + + if ($words) { + $a->data['blockem'] = explode(',', $words); } - else { + + DI::page()['htmlhead'] .= <<< EOT + + + +EOT; +} + +function blockem_item_photo_menu(App $a, array &$b) +{ + if (!local_user() || $b['item']['self']) { return; } - $found = false; - if(count($arr)) { - foreach($arr as $word) { - if(! strlen(trim($word))) { - continue; - } + $blocked = false; + $author = $b['item']['author-link']; - if(link_compare($b['item']['author-link'],$word)) { - $found = true; + if (!empty($a->data['blockem'])) { + foreach($a->data['blockem'] as $bloke) { + if (Strings::compareLink($bloke,$author)) { + $blocked = true; break; } } } - if($found) { - $rnd = random_string(8); - $b['html'] = ''; + if ($blocked) { + $b['menu'][DI::l10n()->t('Unblock Author')] = 'javascript:blockemUnblock(\'' . $author . '\');'; + } else { + $b['menu'][DI::l10n()->t('Block Author')] = 'javascript:blockemBlock(\'' . $author . '\');'; } } - -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']); +function blockem_module() +{ } +function blockem_init(App $a) +{ + if (!local_user()) { + return; + } + + $words = DI::pConfig()->get(local_user(), 'blockem', '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']) { + $arr = explode(',',$words); + $newarr = []; + + if (count($arr)) { + foreach ($arr as $x) { + if (!Strings::compareLink(trim($x), trim($_GET['unblock']))) { + $newarr[] = $x; + } + } + } + + $words = implode(',', $newarr); + } + + DI::pConfig()->set(local_user(), 'blockem', 'words', $words); + exit(); +}