]> git.mxchange.org Git - friendica-addons.git/blobdiff - blockem/blockem.php
Diaspora - set host to empty if it doesn't exist.
[friendica-addons.git] / blockem / blockem.php
index b0e4d805baab4b1bfe564336478f4dfabd0e0bf8..e0c0a74a29894870218f17afc584c9f1c0e97373 100644 (file)
 <?php
-
-
 /**
  * Name: blockem
- * Description: block people
+ * Description: Allows users to hide content by collapsing posts and replies.
  * Version: 1.0
  * Author: Mike Macgirvin <http://macgirvin.com/profile/mike>
- * 
+ * Author: Roland Haeder <https://f.haeder.net/roland>
  */
 
-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'] .= '<link rel="stylesheet"  type="text/css" href="' . $a->get_baseurl() . '/addon/blockem/blockem.css' . '" media="all" />' . "\r\n";
+       /* Add our stylesheet to the page so we can make our settings look nice */
+       $a->page['htmlhead'] .= '<link rel="stylesheet"  type="text/css" href="' . $a->getBaseURL() . '/addon/blockem/blockem.css' . '" media="all" />' . "\r\n";
 
+       $words = PConfig::get(local_user(), 'blockem', 'words');
 
-       $words = get_pconfig(local_user(),'blockem','words');
-       if(! $words)
+       if (!$words) {
                $words = '';
+       }
+
+       $s .= '<span id="settings_blockem_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_blockem_expanded\'); openClose(\'settings_blockem_inflated\');">';
+       $s .= '<h3>' . L10n::t('Blockem') . '</h3>';
+       $s .= '</span>';
+       $s .= '<div id="settings_blockem_expanded" class="settings-block" style="display: none;">';
+       $s .= '<span class="fakelink" onclick="openClose(\'settings_blockem_expanded\'); openClose(\'settings_blockem_inflated\');">';
+       $s .= '<h3>' . L10n::t('Blockem') . '</h3>';
+       $s .= '</span>';
 
-    $s .= '<div class="settings-block">';
-    $s .= '<h3>' . t('"Blockem" Settings') . '</h3>';
-    $s .= '<div id="blockem-wrapper">';
-    $s .= '<label id="blockem-label" for="blockem-words">' . t('Comma separated profile URLS to block') . ' </label>';
-    $s .= '<textarea id="blockem-words" type="text" name="blockem-words" >' . htmlspecialchars($words) . '</textarea>';
-    $s .= '</div><div class="clear"></div>';
+       $s .= '<div id="blockem-wrapper">';
+       $s .= '<div id="blockem-desc">'. L10n::t("Hides user's content by collapsing posts. Also replaces their avatar with generic image.") . ' </div>';
+       $s .= '<label id="blockem-label" for="blockem-words">' . L10n::t('Comma separated profile URLS:') . ' </label>';
+       $s .= '<textarea id="blockem-words" type="text" name="blockem-words" >' . htmlspecialchars($words) . '</textarea>';
+       $s .= '</div><div class="clear"></div>';
 
-    $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="blockem-submit" name="blockem-submit" class="settings-submit" value="' . t('Submit') . '" /></div></div>';
+       $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="blockem-submit" name="blockem-submit" class="settings-submit" value="' . L10n::t('Save Settings') . '" /></div></div>';
 
        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'] = '<div id="blockem-wrap-' . $rnd . '" class="fakelink" onclick=openClose(\'blockem-' . $rnd . '\'); >' . sprintf( t('Blocked %s - Click to open/close'),$word ) . '</div><div id="blockem-' . $rnd . '" style="display: none; " >' . $b['html'] . '</div>';  
+
+       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('/\<img(.*?)src=\"(.*?)\" class=\"wall\-item\-photo(.*?)\>/','<img$1src="' . $a->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
 
 <script>
@@ -138,56 +180,68 @@ function blockemUnblock(author) {
 </script>
 
 EOT;
-
 }
 
-function blockem_item_photo_menu(&$a,&$b) {
+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();
+}