forked from friendica/friendica-addons
Merge pull request #142 from annando/master
Twitter export - now with twitpic
This commit is contained in:
commit
b7b162a510
|
@ -392,6 +392,21 @@ function twitter_shortenmsg($b) {
|
||||||
// If there is no bookmark element then take the first link
|
// If there is no bookmark element then take the first link
|
||||||
if ($link == '') {
|
if ($link == '') {
|
||||||
$links = collecturls($html);
|
$links = collecturls($html);
|
||||||
|
|
||||||
|
foreach($links AS $singlelink) {
|
||||||
|
$img_str = fetch_url($singlelink);
|
||||||
|
|
||||||
|
$tempfile = tempnam(get_config("system","temppath"), "cache");
|
||||||
|
file_put_contents($tempfile, $img_str);
|
||||||
|
$mime = image_type_to_mime_type(exif_imagetype($tempfile));
|
||||||
|
unlink($tempfile);
|
||||||
|
|
||||||
|
if (substr($mime, 0, 6) == "image/") {
|
||||||
|
$image = $singlelink;
|
||||||
|
unset($links[$singlelink]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (sizeof($links) > 0) {
|
if (sizeof($links) > 0) {
|
||||||
reset($links);
|
reset($links);
|
||||||
$link = current($links);
|
$link = current($links);
|
||||||
|
@ -414,12 +429,16 @@ function twitter_shortenmsg($b) {
|
||||||
|
|
||||||
// If the message is short enough then don't modify it.
|
// If the message is short enough then don't modify it.
|
||||||
if ((strlen(trim($origmsg)) <= $max_char) AND ($msglink == ""))
|
if ((strlen(trim($origmsg)) <= $max_char) AND ($msglink == ""))
|
||||||
return(trim($origmsg));
|
return(array("msg"=>trim($origmsg), "image"=>""));
|
||||||
|
|
||||||
|
// If the message is short enough and contains a picture then post the picture as well
|
||||||
|
if ((strlen(trim($origmsg)) <= ($max_char - 40)) AND strpos($origmsg, $msglink))
|
||||||
|
return(array("msg"=>trim($origmsg), "image"=>$image));
|
||||||
|
|
||||||
// If the message is short enough and the link exists in the original message don't modify it as well
|
// If the message is short enough and the link exists in the original message don't modify it as well
|
||||||
// -3 because of the bad shortener of twitter
|
// -3 because of the bad shortener of twitter
|
||||||
if ((strlen(trim($origmsg)) <= ($max_char - 3)) AND strpos($origmsg, $msglink))
|
if ((strlen(trim($origmsg)) <= ($max_char - 3)) AND strpos($origmsg, $msglink))
|
||||||
return(trim($origmsg));
|
return(array("msg"=>trim($origmsg), "image"=>""));
|
||||||
|
|
||||||
// Preserve the unshortened link
|
// Preserve the unshortened link
|
||||||
$orig_link = $msglink;
|
$orig_link = $msglink;
|
||||||
|
@ -444,6 +463,20 @@ function twitter_shortenmsg($b) {
|
||||||
$msg = substr($msg, 0, $pos);
|
$msg = substr($msg, 0, $pos);
|
||||||
else if ($lastchar != "\n")
|
else if ($lastchar != "\n")
|
||||||
$msg = substr($msg, 0, -3)."...";
|
$msg = substr($msg, 0, -3)."...";
|
||||||
|
|
||||||
|
// if the post contains a picture and a link then the system tries to cut the post earlier.
|
||||||
|
// So the link and the picture can be posted.
|
||||||
|
if (($image != "") AND ($orig_link != $image)) {
|
||||||
|
$msg2 = substr($msg, 0, ($max_char - 40) - (strlen($msglink)));
|
||||||
|
$lastchar = substr($msg2, -1);
|
||||||
|
$msg2 = substr($msg2, 0, -1);
|
||||||
|
$pos = strrpos($msg2, "\n");
|
||||||
|
if ($pos > 0)
|
||||||
|
$msg = substr($msg2, 0, $pos);
|
||||||
|
else if ($lastchar == "\n")
|
||||||
|
$msg = trim($msg2);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
//$msg = str_replace("\n", " ", $msg);
|
//$msg = str_replace("\n", " ", $msg);
|
||||||
|
|
||||||
|
@ -451,8 +484,24 @@ function twitter_shortenmsg($b) {
|
||||||
while (strpos($msg, " ") !== false)
|
while (strpos($msg, " ") !== false)
|
||||||
$msg = str_replace(" ", " ", $msg);
|
$msg = str_replace(" ", " ", $msg);
|
||||||
|
|
||||||
//return(trim($msg." ".$msglink));
|
// Removing multiple newlines
|
||||||
return(trim($msg."\n".$orig_link));
|
//while (strpos($msg, "\n\n") !== false)
|
||||||
|
// $msg = str_replace("\n\n", "\n", $msg);
|
||||||
|
|
||||||
|
// Looking if the link points to an image
|
||||||
|
$img_str = fetch_url($orig_link);
|
||||||
|
|
||||||
|
$tempfile = tempnam(get_config("system","temppath"), "cache");
|
||||||
|
file_put_contents($tempfile, $img_str);
|
||||||
|
$mime = image_type_to_mime_type(exif_imagetype($tempfile));
|
||||||
|
unlink($tempfile);
|
||||||
|
|
||||||
|
if (($image == $orig_link) OR (substr($mime, 0, 6) == "image/"))
|
||||||
|
return(array("msg"=>trim($msg), "image"=>$orig_link));
|
||||||
|
else if (($image != $orig_link) AND ($image != "") AND (strlen($msg."\n".$orig_link) <= 100))
|
||||||
|
return(array("msg"=>trim($msg."\n".$orig_link), "image"=>$image));
|
||||||
|
else
|
||||||
|
return(array("msg"=>trim($msg."\n".$orig_link), "image"=>""));
|
||||||
}
|
}
|
||||||
|
|
||||||
function twitter_post_hook(&$a,&$b) {
|
function twitter_post_hook(&$a,&$b) {
|
||||||
|
@ -574,15 +623,33 @@ function twitter_post_hook(&$a,&$b) {
|
||||||
|
|
||||||
$msg = trim($msg);
|
$msg = trim($msg);
|
||||||
} else
|
} else
|
||||||
$msg = twitter_shortenmsg($b);
|
$msgarr = twitter_shortenmsg($b);
|
||||||
|
$msg = $msgarr["msg"];
|
||||||
|
$image = $msgarr["image"];
|
||||||
|
|
||||||
// and now tweet it :-)
|
// and now tweet it :-)
|
||||||
if(strlen($msg)) {
|
if(strlen($msg) and ($image == "")) {
|
||||||
$result = $tweet->post('statuses/update', array('status' => $msg));
|
$result = $tweet->post('statuses/update', array('status' => $msg));
|
||||||
logger('twitter_post send, result: ' . print_r($result, true), LOGGER_DEBUG);
|
logger('twitter_post send, result: ' . print_r($result, true), LOGGER_DEBUG);
|
||||||
if ($result->error) {
|
if ($result->error) {
|
||||||
logger('Send to Twitter failed: "' . $result->error . '"');
|
logger('Send to Twitter failed: "' . $result->error . '"');
|
||||||
}
|
}
|
||||||
|
} else if(strlen($msg) and ($image != "")) {
|
||||||
|
$img_str = fetch_url($image);
|
||||||
|
|
||||||
|
$tempfile = tempnam(get_config("system","temppath"), "cache");
|
||||||
|
file_put_contents($tempfile, $img_str);
|
||||||
|
$mime = image_type_to_mime_type(exif_imagetype($tempfile));
|
||||||
|
unlink($tempfile);
|
||||||
|
|
||||||
|
$filename = "upload";
|
||||||
|
|
||||||
|
$result = $tweet->post('statuses/update_with_media', array('media[]' => "{$img_str};type=".$mime.";filename={$filename}" , 'status' => $msg));
|
||||||
|
|
||||||
|
logger('twitter_post_with_media send, result: ' . print_r($result, true), LOGGER_DEBUG);
|
||||||
|
if ($result->error) {
|
||||||
|
logger('Send to Twitter failed: "' . $result->error . '"');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue