X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=blockem%2Fblockem.php;h=2a2cd3d265b1a47d373fa09bef617ede73077701;hb=0afd633346b517894ff8e92c705bd5d052dd06a2;hp=b0e4d805baab4b1bfe564336478f4dfabd0e0bf8;hpb=d72decea96ac533d1616287cedd848680aed80b3;p=friendica-addons.git
diff --git a/blockem/blockem.php b/blockem/blockem.php
index b0e4d805..2a2cd3d2 100644
--- a/blockem/blockem.php
+++ b/blockem/blockem.php
@@ -1,31 +1,33 @@
- *
+ *
*/
+use Friendica\Core\Addon;
+use Friendica\Core\PConfig;
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');
+ Addon::registerHook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body');
+ Addon::registerHook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item');
+ Addon::registerHook('plugin_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings');
+ Addon::registerHook('plugin_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');
+ Addon::unregisterHook('prepare_body', 'addon/blockem/blockem.php', 'blockem_prepare_body');
+ Addon::unregisterHook('display_item', 'addon/blockem/blockem.php', 'blockem_display_item');
+ Addon::unregisterHook('plugin_settings', 'addon/blockem/blockem.php', 'blockem_addon_settings');
+ Addon::unregisterHook('plugin_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' );
}
@@ -43,18 +45,24 @@ 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 .= '' . t('"Blockem"') . '
';
+ $s .= '';
+ $s .= '
';
+ $s .= '
';
+ $s .= '' . t('"Blockem"') . '
';
+ $s .= '';
+
$s .= '
';
$s .= '';
$s .= '';
$s .= '
';
- $s .= '
';
+ $s .= '
';
return;
@@ -66,11 +74,40 @@ function blockem_addon_settings_post(&$a,&$b) {
return;
if($_POST['blockem-submit']) {
- set_pconfig(local_user(),'blockem','words',trim($_POST['blockem-words']));
+ PConfig::set(local_user(),'blockem','words',trim($_POST['blockem-words']));
info( t('BLOCKEM Settings saved.') . EOL);
}
}
+
+function blockem_enotify_store(&$a,&$b) {
+
+ $words = PConfig::get($b['uid'],'blockem','words');
+ if($words) {
+ $arr = explode(',',$words);
+ }
+ else {
+ return;
+ }
+
+ $found = false;
+ if(count($arr)) {
+ foreach($arr as $word) {
+ if(! strlen(trim($word))) {
+ continue;
+ }
+
+ if(link_compare($b['url'],$word)) {
+ $found = true;
+ break;
+ }
+ }
+ }
+ if($found) {
+ $b['abort'] = true;
+ }
+}
+
function blockem_prepare_body(&$a,&$b) {
if(! local_user())
@@ -78,7 +115,7 @@ function blockem_prepare_body(&$a,&$b) {
$words = null;
if(local_user()) {
- $words = get_pconfig(local_user(),'blockem','words');
+ $words = PConfig::get(local_user(),'blockem','words');
}
if($words) {
$arr = explode(',',$words);
@@ -101,15 +138,15 @@ function blockem_prepare_body(&$a,&$b) {
}
}
if($found) {
- $rnd = random_string(8);
- $b['html'] = '' . sprintf( t('Blocked %s - Click to open/close'),$word ) . '
' . $b['html'] . '
';
+ $rnd = random_string(8);
+ $b['html'] = '' . sprintf( t('Blocked %s - Click to open/close'),$word ) . '
' . $b['html'] . '
';
}
}
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']);
+ if(strstr($b['output']['body'],'id="blockem-wrap-'))
+ $b['output']['thumb'] = $a->get_baseurl() . "/images/person-80.jpg";
}
@@ -118,7 +155,7 @@ 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);
}
@@ -143,6 +180,9 @@ EOT;
function blockem_item_photo_menu(&$a,&$b) {
+ if((! local_user()) || ($b['item']['self']))
+ return;
+
$blocked = false;
$author = $b['item']['author-link'];
if(is_array($a->data['blockem'])) {
@@ -154,9 +194,9 @@ function blockem_item_photo_menu(&$a,&$b) {
}
}
if($blocked)
- $b['menu'][ t('Unblock Author')] = 'javascript:blockemUnblock("' . $author . '");';
+ $b['menu'][ t('Unblock Author')] = 'javascript:blockemUnblock(\'' . $author . '\');';
else
- $b['menu'][ t('Block Author')] = 'javascript:blockemBlock("' . $author . '");';
+ $b['menu'][ t('Block Author')] = 'javascript:blockemBlock(\'' . $author . '\');';
}
function blockem_module() {}
@@ -167,7 +207,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))
@@ -176,7 +216,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) {
@@ -187,7 +227,7 @@ function blockem_init(&$a) {
$words = implode(',',$newarr);
}
- set_pconfig(local_user(),'blockem','words',$words);
+ PConfig::set(local_user(),'blockem','words',$words);
info( t('blockem settings updated') . EOL );
killme();
-}
\ No newline at end of file
+}