Merge pull request #390 from annando/1612-twitter-api-changes

Twitter: We now support quotes and long posts
This commit is contained in:
Tobias Diekershoff 2016-12-09 11:41:10 +01:00 committed by GitHub
commit 7ca6d421f9

View file

@ -1181,6 +1181,8 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $picture) {
$tags = ""; $tags = "";
$plain = $body;
if (isset($item->entities->urls)) { if (isset($item->entities->urls)) {
$type = ""; $type = "";
$footerurl = ""; $footerurl = "";
@ -1188,6 +1190,9 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $picture) {
$footer = ""; $footer = "";
foreach ($item->entities->urls AS $url) { foreach ($item->entities->urls AS $url) {
$plain = str_replace($url->url, '', $plain);
if ($url->url AND $url->expanded_url AND $url->display_url) { if ($url->url AND $url->expanded_url AND $url->display_url) {
$expanded_url = original_url($url->expanded_url); $expanded_url = original_url($url->expanded_url);
@ -1261,7 +1266,7 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $picture) {
$body = add_page_info_to_body($body); $body = add_page_info_to_body($body);
if ($no_tags) if ($no_tags)
return(array("body" => $body, "tags" => "")); return array("body" => $body, "tags" => "", "plain" => $plain);
$tags_arr = array(); $tags_arr = array();
@ -1317,7 +1322,7 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $picture) {
$tags = implode($tags_arr, ","); $tags = implode($tags_arr, ",");
} }
return(array("body" => $body, "tags" => $tags)); return array("body" => $body, "tags" => $tags, "plain" => $plain);
} }
function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing_contact) { function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing_contact) {
@ -1330,14 +1335,16 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
$postarray['uid'] = $uid; $postarray['uid'] = $uid;
$postarray['wall'] = 0; $postarray['wall'] = 0;
$postarray['uri'] = "twitter::".$post->id_str; $postarray['uri'] = "twitter::".$post->id_str;
$postarray['object'] = json_encode($post);
$r = q("SELECT * FROM `item` WHERE `extid` = '%s' AND `uid` = %d LIMIT 1", $r = q("SELECT * FROM `item` WHERE `extid` = '%s' AND `uid` = %d LIMIT 1",
dbesc($postarray['uri']), dbesc($postarray['uri']),
intval($uid) intval($uid)
); );
if (count($r)) if (count($r)) {
return(array()); return(array());
}
$contactid = 0; $contactid = 0;
@ -1384,9 +1391,10 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
$postarray['owner-name'] = $r[0]["name"]; $postarray['owner-name'] = $r[0]["name"];
$postarray['owner-link'] = $r[0]["url"]; $postarray['owner-link'] = $r[0]["url"];
$postarray['owner-avatar'] = $r[0]["photo"]; $postarray['owner-avatar'] = $r[0]["photo"];
} else } else {
return(array()); return(array());
} }
}
// Don't create accounts of people who just comment something // Don't create accounts of people who just comment something
$create_user = false; $create_user = false;
} else { } else {
@ -1402,10 +1410,11 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
$postarray['owner-avatar'] = twitter_fix_avatar($post->user->profile_image_url_https); $postarray['owner-avatar'] = twitter_fix_avatar($post->user->profile_image_url_https);
} }
if(($contactid == 0) AND !$only_existing_contact) if(($contactid == 0) AND !$only_existing_contact) {
$contactid = $self['id']; $contactid = $self['id'];
elseif ($contactid <= 0) } elseif ($contactid <= 0) {
return(array()); return(array());
}
$postarray['contact-id'] = $contactid; $postarray['contact-id'] = $contactid;
@ -1421,7 +1430,11 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
$postarray['allow_cid'] = '<' . $self['id'] . '>'; $postarray['allow_cid'] = '<' . $self['id'] . '>';
} }
if (is_string($post->full_text)) {
$postarray['body'] = $post->full_text;
} else {
$postarray['body'] = $post->text; $postarray['body'] = $post->text;
}
$picture = ""; $picture = "";
@ -1445,72 +1458,45 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
$converted = twitter_expand_entities($a, $postarray['body'], $post, false, $picture); $converted = twitter_expand_entities($a, $postarray['body'], $post, false, $picture);
$postarray['body'] = $converted["body"]; $postarray['body'] = $converted["body"];
$postarray['tag'] = $converted["tags"]; $postarray['tag'] = $converted["tags"];
$postarray['created'] = datetime_convert('UTC','UTC',$post->created_at); $postarray['created'] = datetime_convert('UTC','UTC',$post->created_at);
$postarray['edited'] = datetime_convert('UTC','UTC',$post->created_at); $postarray['edited'] = datetime_convert('UTC','UTC',$post->created_at);
if (is_string($post->place->name)) $statustext = $converted["plain"];
if (is_string($post->place->name)) {
$postarray["location"] = $post->place->name; $postarray["location"] = $post->place->name;
}
if (is_string($post->place->full_name)) if (is_string($post->place->full_name)) {
$postarray["location"] = $post->place->full_name; $postarray["location"] = $post->place->full_name;
}
if (is_array($post->geo->coordinates)) if (is_array($post->geo->coordinates)) {
$postarray["coord"] = $post->geo->coordinates[0]." ".$post->geo->coordinates[1]; $postarray["coord"] = $post->geo->coordinates[0]." ".$post->geo->coordinates[1];
}
if (is_array($post->coordinates->coordinates)) if (is_array($post->coordinates->coordinates)) {
$postarray["coord"] = $post->coordinates->coordinates[1]." ".$post->coordinates->coordinates[0]; $postarray["coord"] = $post->coordinates->coordinates[1]." ".$post->coordinates->coordinates[0];
}
if (is_object($post->retweeted_status)) { if (is_object($post->retweeted_status)) {
$retweet = twitter_createpost($a, $uid, $post->retweeted_status, $self, false, false);
$postarray['body'] = $post->retweeted_status->text; $retweet['contact-id'] = $postarray['contact-id'];
$retweet['owner-name'] = $postarray['owner-name'];
$retweet['owner-link'] = $postarray['owner-link'];
$retweet['owner-avatar'] = $postarray['owner-avatar'];
$picture = ""; $postarray = $retweet;
// media
if (is_array($post->retweeted_status->entities->media)) {
foreach($post->retweeted_status->entities->media AS $media) {
switch($media->type) {
case 'photo':
//$postarray['body'] = str_replace($media->url, "\n\n[img]".$media->media_url_https."[/img]\n", $postarray['body']);
//$has_picture = true;
$postarray['body'] = str_replace($media->url, "", $postarray['body']);
$postarray['object-type'] = ACTIVITY_OBJ_IMAGE;
$picture = $media->media_url_https;
break;
default:
$postarray['body'] .= print_r($media, true);
}
}
} }
$converted = twitter_expand_entities($a, $postarray['body'], $post->retweeted_status, false, $picture); if (is_object($post->quoted_status)) {
$postarray['body'] = $converted["body"]; $quoted = twitter_createpost($a, $uid, $post->quoted_status, $self, false, false);
$postarray['tag'] = $converted["tags"];
twitter_fetch_contact($uid, $post->retweeted_status->user, false); $postarray['body'] = $statustext;
// Deactivated at the moment, since there are problems with answers to retweets $postarray['body'] .= "\n".share_header($quoted['author-name'], $quoted['author-link'], $quoted['author-avatar'], "",
if (false AND !intval(get_config('system','wall-to-wall_share'))) { $quoted['created'], $quoted['plink']);
$postarray['body'] = "[share author='".$post->retweeted_status->user->name.
"' profile='https://twitter.com/".$post->retweeted_status->user->screen_name. $postarray['body'] .= $quoted['body'].'[/share]';
"' avatar='".$post->retweeted_status->user->profile_image_url_https.
"' posted='".datetime_convert('UTC','UTC',$post->retweeted_status->created_at).
"' link='https://twitter.com/".$post->retweeted_status->user->screen_name."/status/".$post->retweeted_status->id_str."']".
$postarray['body'];
$postarray['body'] .= "[/share]";
} else {
// Let retweets look like wall-to-wall posts
$postarray['author-name'] = $post->retweeted_status->user->name;
$postarray['author-link'] = "https://twitter.com/".$post->retweeted_status->user->screen_name;
$postarray['author-avatar'] = twitter_fix_avatar($post->retweeted_status->user->profile_image_url_https);
//if (($post->retweeted_status->user->screen_name != "") AND ($post->retweeted_status->id_str != "")) {
// $postarray['plink'] = "https://twitter.com/".$post->retweeted_status->user->screen_name."/status/".$post->retweeted_status->id_str;
// $postarray['uri'] = "twitter::".$post->retweeted_status->id_str;
//}
} }
}
return($postarray); return($postarray);
} }
@ -1679,7 +1665,7 @@ function twitter_fetchhometimeline($a, $uid) {
return; return;
} }
$parameters = array("exclude_replies" => false, "trim_user" => false, "contributor_details" => true, "include_rts" => true); $parameters = array("exclude_replies" => false, "trim_user" => false, "contributor_details" => true, "include_rts" => true, "tweet_mode" => "extended");
//$parameters["count"] = 200; //$parameters["count"] = 200;