Merge pull request #141 from annando/master

Posting enhancements for Twitter, Statusnet, Pump.io and Wordpress
This commit is contained in:
Tobias Diekershoff 2013-07-21 23:00:28 -07:00
commit a8d96f4f85
8 changed files with 61 additions and 51 deletions

View file

@ -529,40 +529,6 @@ function fbpost_post_hook(&$a,&$b) {
// if($b['verb'] == ACTIVITY_DISLIKE) // if($b['verb'] == ACTIVITY_DISLIKE)
// $msg = trim(strip_tags(bbcode($msg))); // $msg = trim(strip_tags(bbcode($msg)));
// Old code
/*$search_str = $a->get_baseurl() . '/search';
if(preg_match("/\[url=(.*?)\](.*?)\[\/url\]/is",$msg,$matches)) {
// don't use hashtags for message link
if(strpos($matches[2],$search_str) === false) {
$link = $matches[1];
if(substr($matches[2],0,5) != '[img]')
$linkname = $matches[2];
}
}
// strip tag links to avoid link clutter, this really should be
// configurable because we're losing information
$msg = preg_replace("/\#\[url=(.*?)\](.*?)\[\/url\]/is",'#$2',$msg);
// provide the link separately for normal links
$msg = preg_replace("/\[url=(.*?)\](.*?)\[\/url\]/is",'$2 $1',$msg);
if(preg_match("/\[img\](.*?)\[\/img\]/is",$msg,$matches))
$image = $matches[1];
$msg = preg_replace("/\[img\](.*?)\[\/img\]/is", t('Image: ') . '$1', $msg);
if((strpos($link,z_root()) !== false) && (! $image))
$image = $a->get_baseurl() . '/images/friendica-64.jpg';
$msg = trim(strip_tags(bbcode($msg)));*/
// New code
// Looking for the first image // Looking for the first image
$image = ''; $image = '';
if(preg_match("/\[img\=([0-9]*)x([0-9]*)\](.*?)\[\/img\]/is",$b['body'],$matches)) if(preg_match("/\[img\=([0-9]*)x([0-9]*)\](.*?)\[\/img\]/is",$b['body'],$matches))
@ -1052,11 +1018,14 @@ function fbpost_fetchwall($a, $uid) {
$_SESSION["authenticated"] = true; $_SESSION["authenticated"] = true;
$_SESSION["uid"] = $uid; $_SESSION["uid"] = $uid;
unset($_REQUEST);
$_REQUEST["type"] = "wall"; $_REQUEST["type"] = "wall";
$_REQUEST["api_source"] = true; $_REQUEST["api_source"] = true;
$_REQUEST["profile_uid"] = $uid; $_REQUEST["profile_uid"] = $uid;
$_REQUEST["source"] = "Facebook"; $_REQUEST["source"] = "Facebook";
$_REQUEST["title"] = "";
$_REQUEST["body"] = (isset($item->message) ? escape_tags($item->message) : ''); $_REQUEST["body"] = (isset($item->message) ? escape_tags($item->message) : '');
if(isset($item->name) and isset($item->link)) if(isset($item->name) and isset($item->link))

View file

@ -109,6 +109,7 @@ function fromgplus_post($a, $uid, $source, $body, $location) {
$_SESSION['authenticated'] = true; $_SESSION['authenticated'] = true;
$_SESSION['uid'] = $uid; $_SESSION['uid'] = $uid;
unset($_REQUEST);
$_REQUEST['type'] = 'wall'; $_REQUEST['type'] = 'wall';
$_REQUEST['api_source'] = true; $_REQUEST['api_source'] = true;

View file

@ -43,9 +43,11 @@ function public_server_register_account($a,$b) {
); );
}; };
function public_server_cron($a,$b) { function public_server_cron($a,$b) {
logger("public_server: cron start");
require_once('include/enotify.php'); require_once('include/enotify.php');
$r = q("select * from user where account_expires_on < UTC_TIMESTAMP() + INTERVAL 5 DAY and account_expires_on > '0000-00-00 00:00:00' and $r = q("select * from user where account_expires_on < UTC_TIMESTAMP() + INTERVAL 5 DAY and account_expires_on > '0000-00-00 00:00:00' and
expire_notification_sent = '0000-00-00 00:00:00' "); expire_notification_sent = '0000-00-00 00:00:00' ");
@ -116,6 +118,7 @@ function public_server_cron($a,$b) {
} }
} }
logger("public_server: cron end");
} }

View file

@ -1013,7 +1013,8 @@ class oauth_client_class
{ {
$values = array( $values = array(
'oauth_consumer_key'=>$this->client_id, 'oauth_consumer_key'=>$this->client_id,
'oauth_nonce'=>md5(uniqid(rand(), true)), //'oauth_nonce'=>md5(uniqid(rand(), true)),
'oauth_nonce'=>sha1(uniqid(mt_rand(), true).uniqid(mt_rand(), true)),
'oauth_signature_method'=>$this->signature_method, 'oauth_signature_method'=>$this->signature_method,
'oauth_timestamp'=>time(), 'oauth_timestamp'=>time(),
'oauth_version'=>'1.0', 'oauth_version'=>'1.0',
@ -2173,4 +2174,4 @@ class oauth_client_class
*/ */
?> ?>

View file

@ -363,13 +363,24 @@ function pumpio_send(&$a,&$b) {
if ($title != '') if ($title != '')
$title = "<h4>".$title."</h4>"; $title = "<h4>".$title."</h4>";
$content = bbcode($b['body'], false, false);
// Enhance the way, videos are displayed
$content = preg_replace('/<a.*?href="(https?:\/\/www.youtube.com\/.*?)".*?>(.*?)<\/a>/ism',"\n[url]$1[/url]\n",$content);
$content = preg_replace('/<a.*?href="(https?:\/\/youtu.be\/.*?)".*?>(.*?)<\/a>/ism',"\n$1\n",$content);
$content = preg_replace('/<a.*?href="(https?:\/\/vimeo.com\/.*?)".*?>(.*?)<\/a>/ism',"\n$1\n",$content);
$content = preg_replace('/<a.*?href="(https?:\/\/player.vimeo.com\/.*?)".*?>(.*?)<\/a>/ism',"\n$1\n",$content);
$URLSearchString = "^\[\]";
$content = preg_replace_callback("/\[url\]([$URLSearchString]*)\[\/url\]/ism",'tryoembed',$content);
$params = array(); $params = array();
$params["verb"] = "post"; $params["verb"] = "post";
$params["object"] = array( $params["object"] = array(
'objectType' => "note", 'objectType' => "note",
'content' => $title.bbcode($b['body'], false, false)); 'content' => $title.$content);
if ($public) if ($public)
$params["to"] = array(Array( $params["to"] = array(Array(
@ -385,14 +396,16 @@ function pumpio_send(&$a,&$b) {
$client->client_id = $consumer_key; $client->client_id = $consumer_key;
$client->client_secret = $consumer_secret; $client->client_secret = $consumer_secret;
$username = $user.'@'.$host;
$success = $client->CallAPI( $success = $client->CallAPI(
'https://'.$host.'/api/user/'.$user.'/feed', 'https://'.$host.'/api/user/'.$user.'/feed',
'POST', $params, array('FailOnAccessError'=>true, 'RequestContentType'=>'application/json'), $user); 'POST', $params, array('FailOnAccessError'=>true, 'RequestContentType'=>'application/json'), $user);
if($success) if($success)
logger('pumpio_send: success'); logger('pumpio_send '.$username.': success');
else else
logger('pumpio_send: general error: ' . print_r($user,true)); logger('pumpio_send '.$username.': general error: ' . print_r($user,true));
} }
} }
@ -456,10 +469,12 @@ function pumpio_fetchtimeline($a, $uid) {
logger('pumpio: fetching for user '.$uid.' '.$url.' C:'.$client->client_id.' CS:'.$client->client_secret.' T:'.$client->access_token.' TS:'.$client->access_token_secret); logger('pumpio: fetching for user '.$uid.' '.$url.' C:'.$client->client_id.' CS:'.$client->client_secret.' T:'.$client->access_token.' TS:'.$client->access_token_secret);
$username = $user.'@'.$host;
$success = $client->CallAPI($url, 'GET', array(), array('FailOnAccessError'=>true), $user); $success = $client->CallAPI($url, 'GET', array(), array('FailOnAccessError'=>true), $user);
if (!$success) { if (!$success) {
logger('pumpio: error fetching posts for user '.$uid." ".print_r($user, true)); logger('pumpio: error fetching posts for user '.$uid." ".$username." ".print_r($user, true));
return; return;
} }
@ -498,6 +513,7 @@ function pumpio_fetchtimeline($a, $uid) {
$_SESSION["authenticated"] = true; $_SESSION["authenticated"] = true;
$_SESSION["uid"] = $uid; $_SESSION["uid"] = $uid;
unset($_REQUEST);
$_REQUEST["type"] = "wall"; $_REQUEST["type"] = "wall";
$_REQUEST["api_source"] = true; $_REQUEST["api_source"] = true;
$_REQUEST["profile_uid"] = $uid; $_REQUEST["profile_uid"] = $uid;
@ -505,6 +521,8 @@ function pumpio_fetchtimeline($a, $uid) {
if ($post->object->displayName != "") if ($post->object->displayName != "")
$_REQUEST["title"] = html2bbcode($post->object->displayName); $_REQUEST["title"] = html2bbcode($post->object->displayName);
else
$_REQUEST["title"] = "";
$_REQUEST["body"] = html2bbcode($post->object->content); $_REQUEST["body"] = html2bbcode($post->object->content);

View file

@ -563,13 +563,13 @@ function statusnet_shortenmsg($b, $max_char) {
else if ($lastchar != "\n") else if ($lastchar != "\n")
$msg = substr($msg, 0, -3)."..."; $msg = substr($msg, 0, -3)."...";
} }
$msg = str_replace("\n", " ", $msg); //$msg = str_replace("\n", " ", $msg);
// Removing multiple spaces - again // Removing multiple spaces - again
while (strpos($msg, " ") !== false) while (strpos($msg, " ") !== false)
$msg = str_replace(" ", " ", $msg); $msg = str_replace(" ", " ", $msg);
return(array("msg"=>trim($msg." ".$msglink), "image"=>$image)); return(array("msg"=>trim($msg."\n".$msglink), "image"=>$image));
} }
function statusnet_post_hook(&$a,&$b) { function statusnet_post_hook(&$a,&$b) {
@ -855,6 +855,9 @@ function statusnet_fetchtimeline($a, $uid) {
if ($first_time) if ($first_time)
continue; continue;
if ($post->source == "activity")
continue;
if (is_object($post->retweeted_status)) if (is_object($post->retweeted_status))
continue; continue;
@ -865,6 +868,7 @@ function statusnet_fetchtimeline($a, $uid) {
$_SESSION["authenticated"] = true; $_SESSION["authenticated"] = true;
$_SESSION["uid"] = $uid; $_SESSION["uid"] = $uid;
unset($_REQUEST);
$_REQUEST["type"] = "wall"; $_REQUEST["type"] = "wall";
$_REQUEST["api_source"] = true; $_REQUEST["api_source"] = true;
$_REQUEST["profile_uid"] = $uid; $_REQUEST["profile_uid"] = $uid;
@ -872,6 +876,8 @@ function statusnet_fetchtimeline($a, $uid) {
//$_REQUEST["date"] = $post->created_at; //$_REQUEST["date"] = $post->created_at;
$_REQUEST["title"] = "";
$_REQUEST["body"] = $post->text; $_REQUEST["body"] = $post->text;
if (is_string($post->place->name)) if (is_string($post->place->name))
$_REQUEST["location"] = $post->place->name; $_REQUEST["location"] = $post->place->name;

View file

@ -445,14 +445,14 @@ function twitter_shortenmsg($b) {
else if ($lastchar != "\n") else if ($lastchar != "\n")
$msg = substr($msg, 0, -3)."..."; $msg = substr($msg, 0, -3)."...";
} }
$msg = str_replace("\n", " ", $msg); //$msg = str_replace("\n", " ", $msg);
// Removing multiple spaces - again // Removing multiple spaces - again
while (strpos($msg, " ") !== false) while (strpos($msg, " ") !== false)
$msg = str_replace(" ", " ", $msg); $msg = str_replace(" ", " ", $msg);
//return(trim($msg." ".$msglink)); //return(trim($msg." ".$msglink));
return(trim($msg." ".$orig_link)); return(trim($msg."\n".$orig_link));
} }
function twitter_post_hook(&$a,&$b) { function twitter_post_hook(&$a,&$b) {
@ -678,6 +678,7 @@ function twitter_fetchtimeline($a, $uid) {
$_SESSION["authenticated"] = true; $_SESSION["authenticated"] = true;
$_SESSION["uid"] = $uid; $_SESSION["uid"] = $uid;
unset($_REQUEST);
$_REQUEST["type"] = "wall"; $_REQUEST["type"] = "wall";
$_REQUEST["api_source"] = true; $_REQUEST["api_source"] = true;
$_REQUEST["profile_uid"] = $uid; $_REQUEST["profile_uid"] = $uid;
@ -685,6 +686,8 @@ function twitter_fetchtimeline($a, $uid) {
//$_REQUEST["date"] = $post->created_at; //$_REQUEST["date"] = $post->created_at;
$_REQUEST["title"] = "";
$_REQUEST["body"] = $post->text; $_REQUEST["body"] = $post->text;
if (is_string($post->place->name)) if (is_string($post->place->name))
$_REQUEST["location"] = $post->place->name; $_REQUEST["location"] = $post->place->name;

View file

@ -189,21 +189,30 @@ function wppost_send(&$a,&$b) {
// If no bookmark is found then take the first line // If no bookmark is found then take the first line
if ($wptitle == '') { if ($wptitle == '') {
$title = html2plain(bbcode($b['body']), 0, true); $title = html2plain(bbcode($b['body'], false, false), 0, true)."\n";
$pos = strpos($title, "\n"); $pos = strpos($title, "\n");
if (($pos == 0) or ($pos > 60)) $trailer = "";
$pos = 60; if (($pos == 0) or ($pos > 100)) {
$pos = 100;
$trailer = "...";
}
$wptitle = substr($title, 0, $pos); $wptitle = substr($title, 0, $pos).$trailer;
} }
} }
$title = '<title>' . (($wptitle) ? $wptitle : t('Post from Friendica')) . '</title>'; $title = '<title>' . (($wptitle) ? $wptitle : t('Post from Friendica')) . '</title>';
$post = $title . bbcode($b['body']); $post = bbcode($b['body'], false, false);
// If a link goes to youtube then remove the stuff around it. Wordpress detects youtube links and embeds it
$post = preg_replace('/<a.*?href="(https?:\/\/www.youtube.com\/.*?)".*?>(.*?)<\/a>/ism',"\n$1\n",$post);
$post = preg_replace('/<a.*?href="(https?:\/\/youtu.be\/.*?)".*?>(.*?)<\/a>/ism',"\n$1\n",$post);
$post = $title.$post;
$wp_backlink = intval(get_pconfig($b['uid'],'wppost','backlink')); $wp_backlink = intval(get_pconfig($b['uid'],'wppost','backlink'));
if($wp_backlink && $b['plink']) if($wp_backlink && $b['plink'])
$post .= EOL . EOL . '<a href="' . $b['plink'] . '">' $post .= EOL . EOL . '<a href="' . $b['plink'] . '">'
. t('Read the original post and comment stream on Friendica') . '</a>' . EOL . EOL; . t('Read the original post and comment stream on Friendica') . '</a>' . EOL . EOL;
$post = xmlify($post); $post = xmlify($post);