X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=blockem%2Fblockem.php;h=aaa69399538cd5c2971f5a1890644e09ed175ee8;hb=814edd45411175e03aac12f1faf80bacc9008f85;hp=9134bd0b654fea63fdfaeba3bd3fc01a4d4c4a08;hpb=7ab2c715a4001e9aebbc1db70b5fcac7e61f463f;p=friendica-addons.git diff --git a/blockem/blockem.php b/blockem/blockem.php old mode 100755 new mode 100644 index 9134bd0b..aaa69399 --- a/blockem/blockem.php +++ b/blockem/blockem.php @@ -1,39 +1,40 @@ - * + * */ - -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\Core\Addon; +use Friendica\Core\L10n; +use Friendica\Core\PConfig; + +function blockem_install() +{ + Addon::registerHook('prepare_body_content_filter', 'addon/blockem/blockem.php', 'blockem_prepare_body_content_filter'); + 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'); } - -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() +{ + Addon::unregisterHook('prepare_body_content_filter', 'addon/blockem/blockem.php', 'blockem_prepare_body_content_filter'); + 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'); } - - - - -function blockem_addon_settings(&$a,&$s) { +function blockem_addon_settings(&$a, &$s) +{ if(! local_user()) return; @@ -43,18 +44,25 @@ function blockem_addon_settings(&$a,&$s) { $a->page['htmlhead'] .= '' . "\r\n"; - $words = get_pconfig(local_user(),'blockem','words'); + $words = PConfig::get(local_user(), 'blockem', 'words'); if(! $words) $words = ''; - $s .= '
'; - $s .= '

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

'; + $s .= ''; + $s .= '

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

'; + $s .= '
'; + $s .= ''; + $s .= '
'; return; @@ -66,20 +74,14 @@ function blockem_addon_settings_post(&$a,&$b) { return; if($_POST['blockem-submit']) { - set_pconfig(local_user(),'blockem','words',trim($_POST['blockem-words'])); - info( t('BLOCKEM Settings saved.') . EOL); + 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(&$a,&$b) { - if(! local_user()) - return; - - $words = null; - if(local_user()) { - $words = get_pconfig(local_user(),'blockem','words'); - } + $words = PConfig::get($b['uid'],'blockem','words'); if($words) { $arr = explode(',',$words); } @@ -94,31 +96,58 @@ function blockem_prepare_body(&$a,&$b) { continue; } - if(link_compare($b['item']['author-link'],$word)) { + if(link_compare($b['url'],$word)) { $found = true; break; } } } if($found) { - $rnd = random_string(8); - $b['html'] = ''; + $b['abort'] = true; } } +function blockem_prepare_body_content_filter(\Friendica\App $a, &$hook_data) +{ + if (!local_user()) { + return; + } + + $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 (link_compare($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_display_item(&$a,&$b) { if(strstr($b['output']['body'],'id="blockem-wrap-')) - $b['output']['thumb'] = $a->get_baseurl() . "/images/default-profile-sm.jpg"; + $b['output']['thumb'] = $a->get_baseurl() . "/images/person-80.jpg"; } - function blockem_conversation_start(&$a,&$b) { if(! local_user()) return; - $words = get_pconfig(local_user(),'blockem','words'); + $words = PConfig::get(local_user(),'blockem','words'); if($words) { $a->data['blockem'] = explode(',',$words); } @@ -157,9 +186,9 @@ function blockem_item_photo_menu(&$a,&$b) { } } if($blocked) - $b['menu'][ t('Unblock Author')] = 'javascript:blockemUnblock("' . $author . '");'; + $b['menu'][L10n::t('Unblock Author')] = 'javascript:blockemUnblock(\'' . $author . '\');'; else - $b['menu'][ t('Block Author')] = 'javascript:blockemBlock("' . $author . '");'; + $b['menu'][L10n::t('Block Author')] = 'javascript:blockemBlock(\'' . $author . '\');'; } function blockem_module() {} @@ -170,7 +199,7 @@ function blockem_init(&$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)) @@ -179,7 +208,7 @@ function blockem_init(&$a) { } if(array_key_exists('unblock',$_GET) && $_GET['unblock']) { $arr = explode(',',$words); - $newarr = array(); + $newarr = []; if(count($arr)) { foreach($arr as $x) { @@ -190,7 +219,7 @@ function blockem_init(&$a) { $words = implode(',',$newarr); } - set_pconfig(local_user(),'blockem','words',$words); - info( t('blockem settings updated') . EOL ); + PConfig::set(local_user(),'blockem','words',$words); + info(L10n::t('blockem settings updated') . EOL ); killme(); }