From fab2b78542db654056e89a8bfc8c5df7c7ccdd05 Mon Sep 17 00:00:00 2001 From: Michael Vogel Date: Sat, 2 Mar 2013 14:48:42 +0100 Subject: [PATCH 1/5] gpluspost: Posting to Google+ using an RSS feed that is read via hootsuite --- communityhome/communityhome.php | 29 ++++--- gpluspost/gpluspost.php | 144 ++++++++++++++++++++++++++++++++ 2 files changed, 162 insertions(+), 11 deletions(-) create mode 100644 gpluspost/gpluspost.php diff --git a/communityhome/communityhome.php b/communityhome/communityhome.php index ba2af6de..cbcf86a0 100755 --- a/communityhome/communityhome.php +++ b/communityhome/communityhome.php @@ -23,17 +23,24 @@ function communityhome_uninstall() { function communityhome_home(&$a, &$o){ // custom css $a->page['htmlhead'] .= ''; - - $aside = array( - '$tab_1' => t('Login'), - '$tab_2' => t('OpenID'), - '$noOid' => get_config('system','no_openid'), - ); - - // login form - $aside['$login_title'] = t('Login'); - $aside['$login_form'] = login(($a->config['register_policy'] == REGISTER_CLOSED) ? false : true); - + + if (!get_config('communityhome','hidelogin')){ + $aside = array( + '$tab_1' => t('Login'), + '$tab_2' => t('OpenID'), + '$noOid' => get_config('system','no_openid'), + ); + + // login form + $aside['$login_title'] = t('Login'); + $aside['$login_form'] = login(($a->config['register_policy'] == REGISTER_CLOSED) ? false : true); + } else + $aside = array( + //'$tab_1' => t('Login'), + //'$tab_2' => t('OpenID'), + //'$noOid' => get_config('system','no_openid'), + ); + // last 12 users if (get_config('communityhome','showlastusers')===true){ $aside['$lastusers_title'] = t('Latest users'); diff --git a/gpluspost/gpluspost.php b/gpluspost/gpluspost.php new file mode 100644 index 00000000..4546f8b9 --- /dev/null +++ b/gpluspost/gpluspost.php @@ -0,0 +1,144 @@ + + */ + +function gpluspost_install() { +} + + +function gpluspost_uninstall() { +} + +function gpluspost_module() {} + +function gpluspost_init() { + global $a, $_SERVER; + + $uid = 1; + + if (isset($a->argv[1])) { + $uid = (int)$a->argv[1]; + } + $pid = 317976; + + $contacts = q("SELECT `name` from contact where ID=%d LIMIT 1", intval($uid)); + + header("content-type: application/atom+xml"); + echo ''."\n"; + echo ''."\n"; + echo "\t".'<![CDATA['.$a->config['sitename'].']]>'."\n"; + echo "\t".'\n"; + echo "\t".''."\n"; + echo "\t".$a->get_baseurl()."/\n"; + echo "\t".''."\n"; + echo "\t".date("c")."\n"; // To-Do + // Copyright ... + echo "\t".''.$a->config['sitename'].''."\n"; + + $pidlist = "262568,262567,269154,271508,270121,273721,314735,312616,311570,308771,308247,306100,295372,291096,290390,290389,283242,283060,280465,273725"; + $pids = explode(",", $pidlist); + + $items = q("SELECT `id` FROM `item` FORCE INDEX (`received`) WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 AND `item`.`allow_cid` = '' AND `item`.`allow_gid` = '' AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = '' AND `item`.`private` = 0 AND `item`.`wall` = 1 AND `item`.`id` = `item`.`parent` ORDER BY `received` DESC LIMIT 50"); + //foreach ($items AS $item) + // gpluspost_feeditem($item["id"]); + foreach ($pids AS $pid) + gpluspost_feeditem($pid); + + echo "\n"; + killme(); +} + +function gpluspost_feeditem($pid) { + global $a; + + require_once('include/bbcode.php'); + require_once("include/html2plain.php"); + + $max_char = 140; + + $items = q("SELECT `uri`, `plink`, `author-link`, `author-name`, `created`, `edited`, `id`, `title`, `body` from `item` WHERE id=%d", intval($pid)); + foreach ($items AS $item) { + // To-Do: + // extract the link from the body if there is exactly one link + + // Looking for the first image + $image = ''; + if(preg_match("/\[img\=([0-9]*)x([0-9]*)\](.*?)\[\/img\]/is",$item['body'],$matches)) + $image = $matches[3]; + + if ($image == '') + if(preg_match("/\[img\](.*?)\[\/img\]/is",$item['body'],$matches)) + $image = $matches[1]; + + $multipleimages = (strpos($item['body'], "[img") != strrpos($item['body'], "[img")); + + // When saved into the database the content is sent through htmlspecialchars + // That means that we have to decode all image-urls + $image = htmlspecialchars_decode($image); + + $link = ''; + // look for bookmark-bbcode and handle it with priority + if(preg_match("/\[bookmark\=([^\]]*)\](.*?)\[\/bookmark\]/is",$item['body'],$matches)) + $link = $matches[1]; + + $multiplelinks = (strpos($item['body'], "[bookmark") != strrpos($item['body'], "[bookmark")); + + $html = bbcode($item["body"], false, false); + $msg = trim(html2plain($html, 0, true)); + + // If there is no bookmark element then take the first link + if ($link == '') { + $links = collecturls($html); + if (sizeof($links) > 0) { + reset($links); + $link = current($links); + } + $multiplelinks = (sizeof($links) > 1); + } + + $msglink = ""; + if ($multiplelinks) + $msglink = $item["plink"]; + else if ($link != "") + $msglink = $link; + else if ($multipleimages) + $msglink = $item["plink"]; + else if ($image != "") + $msglink = $image; + + //if (($msglink == "") and strlen($msg) > $max_char) + if ($msglink == "") + $msglink = $item["plink"]; + + $html = trim(str_replace($msglink, "", $html)); + + // Fetching the title - or the first line + if ($item["title"] != "") + $title = $item["title"]; + else { + $lines = explode("\n", $msg); + $title = $lines[0]; + } + $title = str_replace("&", "&", $title); + //$html = str_replace("&", "&", $html); + + echo "\t".''."\n"; + echo "\t\t".'<![CDATA['.$title."]]>\n"; + echo "\t\t".''."\n"; + // + echo "\t\t".$item["uri"]."\n"; + //echo "\t\t".date("c", strtotime($item["edited"]))."\n"; + //echo "\t\t".date("c", strtotime($item["created"]))."\n"; + echo "\t\t".date("c")."\n"; + echo "\t\t".date("c")."\n"; + echo "\t\t\n\t\t\t\n"; + echo "\t\t\t".$item["author-link"]."\n\t\t\n"; + //echo ''; + echo "\t\t".'\n"; + echo "\t\n"; + } +} From 0c5ff14d87d13561619e241fe5e49a513b7a1046 Mon Sep 17 00:00:00 2001 From: Michael Vogel Date: Sat, 2 Mar 2013 22:24:57 +0100 Subject: [PATCH 2/5] gpluspost: Posting to G+ is now working --- fromgplus/fromgplus.php | 6 +- gpluspost/gpluspost.php | 207 +++++++++++++++++++++++++++++++++++----- 2 files changed, 188 insertions(+), 25 deletions(-) diff --git a/fromgplus/fromgplus.php b/fromgplus/fromgplus.php index 5bd82ed8..e28b3658 100644 --- a/fromgplus/fromgplus.php +++ b/fromgplus/fromgplus.php @@ -327,7 +327,8 @@ function fromgplus_fetch($a, $uid) { else $location = ""; - fromgplus_post($a, $uid, $item->provider->title, $post, $location); + fromgplus_post($a, $uid, "Google+", $post, $location); + //fromgplus_post($a, $uid, $item->provider->title, $post, $location); break; @@ -360,7 +361,8 @@ function fromgplus_fetch($a, $uid) { else $location = ""; - fromgplus_post($a, $uid, $item->provider->title, $post, $location); + fromgplus_post($a, $uid, "Google+", $post, $location); + //fromgplus_post($a, $uid, $item->provider->title, $post, $location); break; } } diff --git a/gpluspost/gpluspost.php b/gpluspost/gpluspost.php index 4546f8b9..327f9f32 100644 --- a/gpluspost/gpluspost.php +++ b/gpluspost/gpluspost.php @@ -2,15 +2,140 @@ /** * Name: G+ Post + * Description: Posts to a Google+ page with the help of Seesmic * Version: 0.1 * Author: Michael Vogel */ function gpluspost_install() { + register_hook('post_local', 'addon/gpluspost/gpluspost.php', 'gpluspost_post_local'); + register_hook('notifier_normal', 'addon/gpluspost/gpluspost.php', 'gpluspost_send'); + register_hook('jot_networks', 'addon/gpluspost/gpluspost.php', 'gpluspost_jot_nets'); + register_hook('connector_settings', 'addon/gpluspost/gpluspost.php', 'gpluspost_settings'); + register_hook('connector_settings_post', 'addon/gpluspost/gpluspost.php', 'gpluspost_settings_post'); } function gpluspost_uninstall() { + unregister_hook('post_local', 'addon/gpluspost/gpluspost.php', 'gpluspost_post_local'); + unregister_hook('notifier_normal', 'addon/gpluspost/gpluspost.php', 'gpluspost_send'); + unregister_hook('jot_networks', 'addon/gpluspost/gpluspost.php', 'gpluspost_jot_nets'); + unregister_hook('connector_settings', 'addon/gpluspost/gpluspost.php', 'gpluspost_settings'); + unregister_hook('connector_settings_post', 'addon/gpluspost/gpluspost.php', 'gpluspost_settings_post'); +} + +function gpluspost_jot_nets(&$a,&$b) { + if(! local_user()) + return; + + $post = get_pconfig(local_user(),'gpluspost','post'); + if(intval($post) == 1) { + $defpost = get_pconfig(local_user(),'gpluspost','post_by_default'); + $selected = ((intval($defpost) == 1) ? ' checked="checked" ' : ''); + $b .= '
' + . t('Post to Google+') . '
'; + } +} + +function gpluspost_settings(&$a,&$s) { + + if(! local_user()) + return; + + $enabled = get_pconfig(local_user(),'gpluspost','post'); + + $checked = (($enabled) ? ' checked="checked" ' : ''); + + $def_enabled = get_pconfig(local_user(),'gpluspost','post_by_default'); + + $def_checked = (($def_enabled) ? ' checked="checked" ' : ''); + + $s .= '
'; + $s .= '

' . t('Google+ Post Settings') . '

'; + $s .= '
'; + $s .= ''; + $s .= ''; + $s .= '
'; + + $s .= '
'; + $s .= ''; + $s .= ''; + $s .= '
'; + + /* provide a submit button */ + + $s .= '
'; + $s .= 'Register an account at Hootsuite, add your G+ page and add the feed-url there.
'; + //$s .= 'Feed-url: '.$a->get_baseurl().'/gpluspost/'.$a->user["uid"].'
'; + $s .= 'Feed-url: '.$a->get_baseurl().'/gpluspost/'.urlencode($a->user["nickname"]).''; +} + +function gpluspost_settings_post(&$a,&$b) { + + if(x($_POST,'gpluspost-submit')) { + set_pconfig(local_user(),'gpluspost','post',intval($_POST['gpluspost'])); + set_pconfig(local_user(),'gpluspost','post_by_default',intval($_POST['gpluspost_bydefault'])); + } +} + +function gpluspost_post_local(&$a,&$b) { + + if($b['edit']) + return; + + if((! local_user()) || (local_user() != $b['uid'])) + return; + + if($b['private'] || $b['parent']) + return; + + $post = intval(get_pconfig(local_user(),'gpluspost','post')); + + $enable = (($post && x($_REQUEST,'gpluspost_enable')) ? intval($_REQUEST['gpluspost_enable']) : 0); + + if(intval(get_pconfig(local_user(),'gpluspost','post_by_default'))) + $enable = 1; + + if(!$enable) + return; + + if(strlen($b['postopts'])) + $b['postopts'] .= ','; + + $b['postopts'] .= 'gplus'; +} + +function gpluspost_send(&$a,&$b) { + + logger('gpluspost_send: invoked for post '.$b['id']); + + if($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) + return; + + if(! strstr($b['postopts'],'gplus')) + return; + + if($b['parent'] != $b['id']) + return; + + // if post comes from Google+ don't send it back + if($b['app'] == "Google+") + return; + + $itemlist = get_pconfig($b["uid"],'gpluspost','itemlist'); + $items = explode(",", $itemlist); + + $i = 0; + $newitems = array($b['id']); + foreach ($items AS $item) + if ($i++ < 9) + $newitems[] = $item; + + $itemlist = implode(",", $newitems); + + logger('gpluspost_send: new itemlist: '.$itemlist." for uid ".$b["uid"]); + + set_pconfig($b["uid"],'gpluspost','itemlist', $itemlist); } function gpluspost_module() {} @@ -18,20 +143,24 @@ function gpluspost_module() {} function gpluspost_init() { global $a, $_SERVER; - $uid = 1; + $uid = 0; if (isset($a->argv[1])) { $uid = (int)$a->argv[1]; + if ($uid == 0) { + $contacts = q("SELECT `name`, `id` FROM contact WHERE `nick` = '%s' LIMIT 1", dbesc($a->argv[1])); + if ($contacts) + $uid = $contacts[0]["id"]; + } else + $contacts = q("SELECT `name` FROM contact WHERE ID=%d LIMIT 1", intval($uid)); } - $pid = 317976; - - $contacts = q("SELECT `name` from contact where ID=%d LIMIT 1", intval($uid)); header("content-type: application/atom+xml"); echo ''."\n"; echo ''."\n"; echo "\t".'<![CDATA['.$a->config['sitename'].']]>'."\n"; - echo "\t".'\n"; + if ($uid != 0) + echo "\t".'\n"; echo "\t".''."\n"; echo "\t".$a->get_baseurl()."/\n"; echo "\t".''."\n"; @@ -39,20 +168,49 @@ function gpluspost_init() { // Copyright ... echo "\t".''.$a->config['sitename'].''."\n"; - $pidlist = "262568,262567,269154,271508,270121,273721,314735,312616,311570,308771,308247,306100,295372,291096,290390,290389,283242,283060,280465,273725"; - $pids = explode(",", $pidlist); - - $items = q("SELECT `id` FROM `item` FORCE INDEX (`received`) WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 AND `item`.`allow_cid` = '' AND `item`.`allow_gid` = '' AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = '' AND `item`.`private` = 0 AND `item`.`wall` = 1 AND `item`.`id` = `item`.`parent` ORDER BY `received` DESC LIMIT 50"); - //foreach ($items AS $item) - // gpluspost_feeditem($item["id"]); - foreach ($pids AS $pid) - gpluspost_feeditem($pid); + if ($uid != 0) { + $itemlist = get_pconfig(local_user(),'gpluspost','itemlist'); + //$itemlist = "262568,262567,269154,271508,270121,273721,314735,312616,311570,308771,308247,306100,295372,291096,290390,290389,283242,283060,280465,273725"; + $items = explode(",", $itemlist); + foreach ($items AS $item) + gpluspost_feeditem($item, $uid); + } else { + $items = q("SELECT `id` FROM `item` FORCE INDEX (`received`) WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 and `item`.`moderated` = 0 AND `item`.`allow_cid` = '' AND `item`.`allow_gid` = '' AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = '' AND `item`.`private` = 0 AND `item`.`wall` = 1 AND `item`.`id` = `item`.`parent` ORDER BY `received` DESC LIMIT 10"); + foreach ($items AS $item) + gpluspost_feeditem($item["id"], $uid); + } echo "\n"; killme(); } -function gpluspost_feeditem($pid) { +function gpluspost_ShareAttributes($match) { + + $attributes = $match[1]; + + $author = ""; + preg_match("/author='(.*?)'/ism", $attributes, $matches); + if ($matches[1] != "") + $author = $matches[1]; + + preg_match('/author="(.*?)"/ism', $attributes, $matches); + if ($matches[1] != "") + $author = $matches[1]; + + $headline = '
'; + + $headline .= sprintf(t('%s:'), $author); + + $headline .= "
"; + + //$text = "
".$headline."
".$match[2]."
"; + //$text = "\n\t".$match[2].":\t"; + $text = $author.": ".$match[2]; + + return($text); +} + +function gpluspost_feeditem($pid, $uid) { global $a; require_once('include/bbcode.php'); @@ -62,8 +220,6 @@ function gpluspost_feeditem($pid) { $items = q("SELECT `uri`, `plink`, `author-link`, `author-name`, `created`, `edited`, `id`, `title`, `body` from `item` WHERE id=%d", intval($pid)); foreach ($items AS $item) { - // To-Do: - // extract the link from the body if there is exactly one link // Looking for the first image $image = ''; @@ -87,7 +243,10 @@ function gpluspost_feeditem($pid) { $multiplelinks = (strpos($item['body'], "[bookmark") != strrpos($item['body'], "[bookmark")); - $html = bbcode($item["body"], false, false); + $body = $item['body']; + $body = preg_replace_callback("/\[share(.*?)\]\s?(.*?)\s?\[\/share\]/ism","gpluspost_ShareAttributes", $body); + + $html = bbcode($body, false, false); $msg = trim(html2plain($html, 0, true)); // If there is no bookmark element then take the first link @@ -110,11 +269,11 @@ function gpluspost_feeditem($pid) { else if ($image != "") $msglink = $image; - //if (($msglink == "") and strlen($msg) > $max_char) if ($msglink == "") $msglink = $item["plink"]; - $html = trim(str_replace($msglink, "", $html)); + if ($image != $msglink) + $html = trim(str_replace($msglink, "", $html)); // Fetching the title - or the first line if ($item["title"] != "") @@ -123,6 +282,10 @@ function gpluspost_feeditem($pid) { $lines = explode("\n", $msg); $title = $lines[0]; } + + if ($uid == 0) + $title = $item["author-name"].": ".$title; + $title = str_replace("&", "&", $title); //$html = str_replace("&", "&", $html); @@ -131,10 +294,8 @@ function gpluspost_feeditem($pid) { echo "\t\t".''."\n"; // echo "\t\t".$item["uri"]."\n"; - //echo "\t\t".date("c", strtotime($item["edited"]))."\n"; - //echo "\t\t".date("c", strtotime($item["created"]))."\n"; - echo "\t\t".date("c")."\n"; - echo "\t\t".date("c")."\n"; + echo "\t\t".date("c", strtotime($item["edited"]))."\n"; + echo "\t\t".date("c", strtotime($item["created"]))."\n"; echo "\t\t\n\t\t\t\n"; echo "\t\t\t".$item["author-link"]."\n\t\t\n"; //echo ''; From 543c456110c79c965c786c8029d6c85c9c58a18f Mon Sep 17 00:00:00 2001 From: Michael Vogel Date: Sun, 3 Mar 2013 12:25:05 +0100 Subject: [PATCH 3/5] gpluspost: Atom-Feed is now working. Add-On is ready to use --- gpluspost/gpluspost.php | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/gpluspost/gpluspost.php b/gpluspost/gpluspost.php index 327f9f32..586e4254 100644 --- a/gpluspost/gpluspost.php +++ b/gpluspost/gpluspost.php @@ -107,7 +107,7 @@ function gpluspost_post_local(&$a,&$b) { function gpluspost_send(&$a,&$b) { - logger('gpluspost_send: invoked for post '.$b['id']); + logger('gpluspost_send: invoked for post '.$b['id']." ".$b['app']); if($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) return; @@ -119,8 +119,8 @@ function gpluspost_send(&$a,&$b) { return; // if post comes from Google+ don't send it back - if($b['app'] == "Google+") - return; + //if($b['app'] == "Google+") + // return; $itemlist = get_pconfig($b["uid"],'gpluspost','itemlist'); $items = explode(",", $itemlist); @@ -149,19 +149,25 @@ function gpluspost_init() { $uid = (int)$a->argv[1]; if ($uid == 0) { $contacts = q("SELECT `name`, `id` FROM contact WHERE `nick` = '%s' LIMIT 1", dbesc($a->argv[1])); - if ($contacts) + if ($contacts) { $uid = $contacts[0]["id"]; - } else + $nick = $a->argv[1]; + } + } else { $contacts = q("SELECT `name` FROM contact WHERE ID=%d LIMIT 1", intval($uid)); + $nick = $uid; + } } header("content-type: application/atom+xml"); echo ''."\n"; echo ''."\n"; echo "\t".'<![CDATA['.$a->config['sitename'].']]>'."\n"; - if ($uid != 0) + if ($uid != 0) { echo "\t".'\n"; - echo "\t".''."\n"; + echo "\t".''."\n"; + } else + echo "\t".''."\n"; echo "\t".$a->get_baseurl()."/\n"; echo "\t".''."\n"; echo "\t".date("c")."\n"; // To-Do @@ -169,8 +175,7 @@ function gpluspost_init() { echo "\t".''.$a->config['sitename'].''."\n"; if ($uid != 0) { - $itemlist = get_pconfig(local_user(),'gpluspost','itemlist'); - //$itemlist = "262568,262567,269154,271508,270121,273721,314735,312616,311570,308771,308247,306100,295372,291096,290390,290389,283242,283060,280465,273725"; + $itemlist = get_pconfig($uid,'gpluspost','itemlist'); $items = explode(",", $itemlist); foreach ($items AS $item) From 065c1ac1e94b0faacb441821103a617890a8c2f9 Mon Sep 17 00:00:00 2001 From: Michael Vogel Date: Sun, 3 Mar 2013 16:28:06 +0100 Subject: [PATCH 4/5] gpluspost: New option for loop prevention --- gpluspost/gpluspost.php | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/gpluspost/gpluspost.php b/gpluspost/gpluspost.php index 586e4254..7c69f2c6 100644 --- a/gpluspost/gpluspost.php +++ b/gpluspost/gpluspost.php @@ -43,13 +43,14 @@ function gpluspost_settings(&$a,&$s) { return; $enabled = get_pconfig(local_user(),'gpluspost','post'); - $checked = (($enabled) ? ' checked="checked" ' : ''); $def_enabled = get_pconfig(local_user(),'gpluspost','post_by_default'); - $def_checked = (($def_enabled) ? ' checked="checked" ' : ''); + $noloop_enabled = get_pconfig(local_user(),'gpluspost','no_loop_prevention'); + $noloop_checked = (($noloop_enabled) ? ' checked="checked" ' : ''); + $s .= '
'; $s .= '

' . t('Google+ Post Settings') . '

'; $s .= '
'; @@ -62,11 +63,15 @@ function gpluspost_settings(&$a,&$s) { $s .= ''; $s .= '
'; + $s .= '
'; + $s .= ''; + $s .= ''; + $s .= '
'; + /* provide a submit button */ $s .= '
'; $s .= 'Register an account at Hootsuite, add your G+ page and add the feed-url there.
'; - //$s .= 'Feed-url: '.$a->get_baseurl().'/gpluspost/'.$a->user["uid"].'
'; $s .= 'Feed-url: '.$a->get_baseurl().'/gpluspost/'.urlencode($a->user["nickname"]).''; } @@ -75,6 +80,7 @@ function gpluspost_settings_post(&$a,&$b) { if(x($_POST,'gpluspost-submit')) { set_pconfig(local_user(),'gpluspost','post',intval($_POST['gpluspost'])); set_pconfig(local_user(),'gpluspost','post_by_default',intval($_POST['gpluspost_bydefault'])); + set_pconfig(local_user(),'gpluspost','no_loop_prevention',intval($_POST['gpluspost_noloopprevention'])); } } @@ -119,8 +125,8 @@ function gpluspost_send(&$a,&$b) { return; // if post comes from Google+ don't send it back - //if($b['app'] == "Google+") - // return; + if (!get_pconfig($b["uid"],'gpluspost','no_loop_prevention') and ($b['app'] == "Google+")) + return; $itemlist = get_pconfig($b["uid"],'gpluspost','itemlist'); $items = explode(",", $itemlist); From e0ca11739192076d0ab3f3eaa8eded8abee63707 Mon Sep 17 00:00:00 2001 From: Michael Vogel Date: Sun, 3 Mar 2013 17:55:46 +0100 Subject: [PATCH 5/5] gpluspost: Posting couldn't be disabled - fixed --- gpluspost/gpluspost.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gpluspost/gpluspost.php b/gpluspost/gpluspost.php index 7c69f2c6..22fccdef 100644 --- a/gpluspost/gpluspost.php +++ b/gpluspost/gpluspost.php @@ -99,7 +99,7 @@ function gpluspost_post_local(&$a,&$b) { $enable = (($post && x($_REQUEST,'gpluspost_enable')) ? intval($_REQUEST['gpluspost_enable']) : 0); - if(intval(get_pconfig(local_user(),'gpluspost','post_by_default'))) + if($_REQUEST['api_source'] && intval(get_pconfig(local_user(),'gpluspost','post_by_default'))) $enable = 1; if(!$enable)