X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=buffer%2Fbuffer.php;h=048a27dafcf2642b80262d520666e9e9d0c30952;hb=13f2734f42b88a477fa1aa3f8ac0cf6b2bd9c903;hp=f41ecf97e07e95ab913ab3f223e0b6fd2af743b5;hpb=aaf031258fc2829b3ed63d1f2b19b0d4c1c9eec2;p=friendica-addons.git diff --git a/buffer/buffer.php b/buffer/buffer.php index f41ecf97..048a27da 100644 --- a/buffer/buffer.php +++ b/buffer/buffer.php @@ -13,9 +13,13 @@ use Friendica\Core\Addon; use Friendica\Core\Config; use Friendica\Core\L10n; use Friendica\Core\PConfig; +use Friendica\Core\Protocol; +use Friendica\Database\DBA; use Friendica\Model\ItemContent; +use Friendica\Util\Proxy as ProxyUtils; -function buffer_install() { +function buffer_install() +{ Addon::registerHook('post_local', 'addon/buffer/buffer.php', 'buffer_post_local'); Addon::registerHook('notifier_normal', 'addon/buffer/buffer.php', 'buffer_send'); Addon::registerHook('jot_networks', 'addon/buffer/buffer.php', 'buffer_jot_nets'); @@ -23,42 +27,47 @@ function buffer_install() { Addon::registerHook('connector_settings_post', 'addon/buffer/buffer.php', 'buffer_settings_post'); } -function buffer_uninstall() { - Addon::unregisterHook('post_local', 'addon/buffer/buffer.php', 'buffer_post_local'); - Addon::unregisterHook('notifier_normal', 'addon/buffer/buffer.php', 'buffer_send'); - Addon::unregisterHook('jot_networks', 'addon/buffer/buffer.php', 'buffer_jot_nets'); +function buffer_uninstall() +{ + Addon::unregisterHook('post_local', 'addon/buffer/buffer.php', 'buffer_post_local'); + Addon::unregisterHook('notifier_normal', 'addon/buffer/buffer.php', 'buffer_send'); + Addon::unregisterHook('jot_networks', 'addon/buffer/buffer.php', 'buffer_jot_nets'); Addon::unregisterHook('connector_settings', 'addon/buffer/buffer.php', 'buffer_settings'); Addon::unregisterHook('connector_settings_post', 'addon/buffer/buffer.php', 'buffer_settings_post'); } -function buffer_module() {} - -function buffer_content(&$a) { +function buffer_module() +{ +} - if(! local_user()) { +function buffer_content(App $a) +{ + if (! local_user()) { notice(L10n::t('Permission denied.') . EOL); return ''; } - require_once("mod/settings.php"); + require_once "mod/settings.php"; settings_init($a); - if (isset($a->argv[1])) + if (isset($a->argv[1])) { switch ($a->argv[1]) { case "connect": $o = buffer_connect($a); break; + default: $o = print_r($a->argv, true); break; } - else + } else { $o = buffer_connect($a); + } return $o; } -function buffer_addon_admin(&$a, &$o) +function buffer_addon_admin(App $a, &$o) { $t = get_markup_template("admin.tpl", "addon/buffer/"); @@ -69,21 +78,25 @@ function buffer_addon_admin(&$a, &$o) '$client_secret' => ['client_secret', L10n::t('Client Secret'), Config::get('buffer', 'client_secret'), ''], ]); } -function buffer_addon_admin_post(&$a) + +function buffer_addon_admin_post(App $a) { - $client_id = ((x($_POST, 'client_id')) ? notags(trim($_POST['client_id'])) : ''); - $client_secret = ((x($_POST, 'client_secret')) ? notags(trim($_POST['client_secret'])): ''); - Config::set('buffer', 'client_id', $client_id); + $client_id = ((!empty($_POST['client_id'])) ? notags(trim($_POST['client_id'])) : ''); + $client_secret = ((!empty($_POST['client_secret'])) ? notags(trim($_POST['client_secret'])) : ''); + + Config::set('buffer', 'client_id' , $client_id); Config::set('buffer', 'client_secret', $client_secret); + info(L10n::t('Settings updated.'). EOL); } -function buffer_connect(&$a) { - +function buffer_connect(App $a) +{ if (isset($_REQUEST["error"])) { $o = L10n::t('Error when registering buffer connection:')." ".$_REQUEST["error"]; return $o; } + // Start a session. This is necessary to hold on to a few keys the callback script will also need session_start(); @@ -92,7 +105,7 @@ function buffer_connect(&$a) { $client_secret = Config::get('buffer','client_secret'); // The callback URL is the script that gets called after the user authenticates with buffer - $callback_url = $a->get_baseurl()."/buffer/connect"; + $callback_url = $a->getBaseURL()."/buffer/connect"; $buffer = new BufferApp($client_id, $client_secret, $callback_url); @@ -101,34 +114,38 @@ function buffer_connect(&$a) { } else { logger("buffer_connect: authenticated"); $o .= L10n::t("You are now authenticated to buffer. "); - $o .= '
'.L10n::t("return to the connector page").''; + $o .= '
' . L10n::t("return to the connector page") . ''; PConfig::set(local_user(), 'buffer','access_token', $buffer->access_token); } - return($o); + return $o; } -function buffer_jot_nets(&$a,&$b) { - if(! local_user()) +function buffer_jot_nets(App $a, &$b) +{ + if (!local_user()) { return; + } - $buffer_post = PConfig::get(local_user(),'buffer','post'); - if(intval($buffer_post) == 1) { - $buffer_defpost = PConfig::get(local_user(),'buffer','post_by_default'); + $buffer_post = PConfig::get(local_user(), 'buffer', 'post'); + + if (intval($buffer_post) == 1) { + $buffer_defpost = PConfig::get(local_user(), 'buffer', 'post_by_default'); $selected = ((intval($buffer_defpost) == 1) ? ' checked="checked" ' : ''); $b .= '
' . L10n::t('Post to Buffer') . '
'; } } -function buffer_settings(&$a,&$s) { - - if(! local_user()) +function buffer_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'] .= '' . "\r\n"; + $a->page['htmlhead'] .= '' . "\r\n"; /* Get the current state of our config variables */ @@ -154,9 +171,10 @@ function buffer_settings(&$a,&$s) { $access_token = PConfig::get(local_user(), "buffer", "access_token"); $s .= '
'; + if ($access_token == "") { $s .= '
'; - $s .= ''.L10n::t("Authenticate your Buffer connection").''; + $s .= ''.L10n::t("Authenticate your Buffer connection").''; $s .= '
'; } else { $s .= '
'; @@ -174,6 +192,9 @@ function buffer_settings(&$a,&$s) { $s .= ''; $s .= '
'; + // The callback URL is the script that gets called after the user authenticates with buffer + $callback_url = $a->getBaseURL() . '/buffer/connect'; + $buffer = new BufferApp($client_id, $client_secret, $callback_url, $access_token); $profiles = $buffer->go('/profiles'); @@ -200,33 +221,32 @@ function buffer_settings(&$a,&$s) { /* provide a submit button */ $s .= '
'; - } -function buffer_settings_post(&$a,&$b) { - - if(x($_POST,'buffer-submit')) { - if(x($_POST,'buffer_delete')) { - PConfig::set(local_user(),'buffer','access_token',''); - PConfig::set(local_user(),'buffer','post',false); - PConfig::set(local_user(),'buffer','post_by_default',false); +function buffer_settings_post(App $a, array &$b) +{ + if (!empty($_POST['buffer-submit'])) { + if (!empty($_POST['buffer_delete'])) { + PConfig::set(local_user(), 'buffer', 'access_token' , ''); + PConfig::set(local_user(), 'buffer', 'post' , false); + PConfig::set(local_user(), 'buffer', 'post_by_default', false); } else { - PConfig::set(local_user(),'buffer','post',intval($_POST['buffer'])); - PConfig::set(local_user(),'buffer','post_by_default',intval($_POST['buffer_bydefault'])); + PConfig::set(local_user(), 'buffer', 'post' , intval($_POST['buffer'])); + PConfig::set(local_user(), 'buffer', 'post_by_default', intval($_POST['buffer_bydefault'])); } } } -function buffer_post_local(&$a,&$b) { - +function buffer_post_local(App $a, array &$b) +{ if (!local_user() || (local_user() != $b['uid'])) { return; } $buffer_post = intval(PConfig::get(local_user(),'buffer','post')); - $buffer_enable = (($buffer_post && x($_REQUEST,'buffer_enable')) ? intval($_REQUEST['buffer_enable']) : 0); + $buffer_enable = (($buffer_post && !empty($_REQUEST['buffer_enable'])) ? intval($_REQUEST['buffer_enable']) : 0); if ($b['api_source'] && intval(PConfig::get(local_user(),'buffer','post_by_default'))) { $buffer_enable = 1; @@ -243,23 +263,23 @@ function buffer_post_local(&$a,&$b) { $b['postopts'] .= 'buffer'; } -function buffer_send(App $a, &$b) +function buffer_send(App $a, array &$b) { - if($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) { + if ($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) { return; } - if(! strstr($b['postopts'],'buffer')) { + if (!strstr($b['postopts'],'buffer')) { return; } - if($b['parent'] != $b['id']) { + if ($b['parent'] != $b['id']) { return; } // Dont't post if the post doesn't belong to us. // This is a check for forum postings - $self = dba::selectFirst('contact', ['id'], ['uid' => $b['uid'], 'self' => true]); + $self = DBA::selectFirst('contact', ['id'], ['uid' => $b['uid'], 'self' => true]); if ($b['contact-id'] != $self['id']) { return; } @@ -271,6 +291,7 @@ function buffer_send(App $a, &$b) $client_id = Config::get("buffer", "client_id"); $client_secret = Config::get("buffer", "client_secret"); $access_token = PConfig::get($b['uid'], "buffer","access_token"); + $callback_url = ""; if ($access_token) { $buffer = new BufferApp($client_id, $client_secret, $callback_url, $access_token); @@ -286,36 +307,32 @@ function buffer_send(App $a, &$b) $send = false; switch ($profile->service) { - case 'appdotnet': - $send = ($b["extid"] != NETWORK_APPNET); - $limit = 256; - $markup = false; - $includedlinks = true; - $htmlmode = 6; - break; case 'facebook': - $send = ($b["extid"] != NETWORK_FACEBOOK); + $send = ($b["extid"] != Protocol::FACEBOOK); $limit = 0; $markup = false; $includedlinks = false; $htmlmode = 9; break; + case 'google': - $send = ($b["extid"] != NETWORK_GPLUS); + $send = ($b["extid"] != Protocol::GPLUS); $limit = 0; $markup = true; $includedlinks = false; $htmlmode = 9; break; + case 'twitter': - $send = ($b["extid"] != NETWORK_TWITTER); + $send = ($b["extid"] != Protocol::TWITTER); $limit = 280; $markup = false; $includedlinks = true; $htmlmode = 8; break; + case 'linkedin': - $send = ($b["extid"] != NETWORK_LINKEDIN); + $send = ($b["extid"] != Protocol::LINKEDIN); $limit = 700; $markup = false; $includedlinks = true; @@ -330,47 +347,34 @@ function buffer_send(App $a, &$b) // Markup for Google+ if ($markup) { - if ($item["title"] != "") - $item["title"] = "*".$item["title"]."*"; + if ($item["title"] != "") { + $item["title"] = "*" . $item["title"] . "*"; + } - $item["body"] = preg_replace("(\[b\](.*?)\[\/b\])ism",'*$1*',$item["body"]); - $item["body"] = preg_replace("(\[i\](.*?)\[\/i\])ism",'_$1_',$item["body"]); - $item["body"] = preg_replace("(\[s\](.*?)\[\/s\])ism",'-$1-',$item["body"]); + $item["body"] = preg_replace("(\[b\](.*?)\[\/b\])ism", '*$1*', $item["body"]); + $item["body"] = preg_replace("(\[i\](.*?)\[\/i\])ism", '_$1_', $item["body"]); + $item["body"] = preg_replace("(\[s\](.*?)\[\/s\])ism", '-$1-', $item["body"]); } $post = ItemContent::getPlaintextPost($item, $limit, $includedlinks, $htmlmode); logger("buffer_send: converted message ".$b["id"]." result: ".print_r($post, true), LOGGER_DEBUG); // The image proxy is used as a sanitizer. Buffer seems to be really picky about pictures - require_once("mod/proxy.php"); - if (isset($post["image"])) - $post["image"] = proxy_url($post["image"]); - - if (isset($post["preview"])) - $post["preview"] = proxy_url($post["preview"]); - - //if ($includedlinks) { - // if (isset($post["url"])) - // $post["url"] = Network::shortenUrl($post["url"]); - // if (isset($post["image"])) - // $post["image"] = Network::shortenUrl($post["image"]); - // if (isset($post["preview"])) - // $post["preview"] = Network::shortenUrl($post["preview"]); - //} + if (isset($post["image"])) { + $post["image"] = ProxyUtils::proxifyUrl($post["image"]); + } + + if (isset($post["preview"])) { + $post["preview"] = ProxyUtils::proxifyUrl($post["preview"]); + } // Seems like a bug to me - // Buffer doesn't add links to Twitter and App.net (but pictures) - //if ($includedlinks && isset($post["url"])) - if (($profile->service == "twitter") && isset($post["url"]) && ($post["type"] != "photo")) - $post["text"] .= " ".$post["url"]; - elseif (($profile->service == "appdotnet") && isset($post["url"]) && isset($post["title"]) && ($post["type"] != "photo")) { - $post["title"] = Plaintext::shorten($post["title"], 90); - $post["text"] = Plaintext::shorten($post["text"], $limit - (24 + strlen($post["title"]))); - $post["text"] .= "\n[".$post["title"]."](".$post["url"].")"; - } elseif (($profile->service == "appdotnet") && isset($post["url"]) && ($post["type"] != "photo")) - $post["text"] .= " ".$post["url"]; - elseif ($profile->service == "google") + // Buffer doesn't add links to Twitter (but pictures) + if (($profile->service == "twitter") && isset($post["url"]) && ($post["type"] != "photo")) { + $post["text"] .= " " . $post["url"]; + } elseif ($profile->service == "google") { $post["text"] .= html_entity_decode(" ", ENT_QUOTES, 'UTF-8'); // Send a special blank to identify the post through the "fromgplus" addon + } $message = []; $message["text"] = $post["text"]; @@ -378,28 +382,34 @@ function buffer_send(App $a, &$b) $message["shorten"] = false; $message["now"] = true; - if (isset($post["title"])) + if (isset($post["title"])) { $message["media[title]"] = $post["title"]; + } - if (isset($post["description"])) + if (isset($post["description"])) { $message["media[description]"] = $post["description"]; + } - if (isset($post["url"]) && ($post["type"] != "photo")) + if (isset($post["url"]) && ($post["type"] != "photo")) { $message["media[link]"] = $post["url"]; + } if (isset($post["image"])) { $message["media[picture]"] = $post["image"]; - if ($post["type"] == "photo") + + if ($post["type"] == "photo") { $message["media[thumbnail]"] = $post["image"]; + } } - if (isset($post["preview"])) + if (isset($post["preview"])) { $message["media[thumbnail]"] = $post["preview"]; + } //print_r($message); - logger("buffer_send: data for message ".$b["id"].": ".print_r($message, true), LOGGER_DEBUG); + logger("buffer_send: data for message " . $b["id"] . ": " . print_r($message, true), LOGGER_DEBUG); $ret = $buffer->go('/updates/create', $message); - logger("buffer_send: send message ".$b["id"]." result: ".print_r($ret, true), LOGGER_DEBUG); + logger("buffer_send: send message " . $b["id"] . " result: " . print_r($ret, true), LOGGER_DEBUG); } } }