diff --git a/include/api.php b/include/api.php index 1d4f5d5874..e51942ca63 100644 --- a/include/api.php +++ b/include/api.php @@ -2358,7 +2358,6 @@ $ret = Array(); foreach($r as $item) { - api_share_as_retweet($item); localize_item($item); list($status_user, $owner_user) = api_item_get_user($a,$item); @@ -2448,24 +2447,26 @@ # $IsRetweet = (($item['owner-name'] != $item['author-name']) OR ($item['owner-avatar'] != $item['author-avatar'])); - if ($item['is_retweet'] AND ($item["id"] == $item["parent"])) { - $retweeted_status = $status; - try { - $retweeted_status["user"] = api_get_user($a,$item["retweet-author-link"]); - } catch( BadRequestException $e ) { - // user not found. should be found? - // TODO: check if the user should be found... - $retweeted_status["user"] = array(); + if ($item["id"] == $item["parent"]) { + $retweeted_item = api_share_as_retweet($item); + if ($retweeted_item !== false) { + $retweeted_status = $status; + try { + $retweeted_status["user"] = api_get_user($a,$retweeted_item["author-link"]); + } catch( BadRequestException $e ) { + // user not found. should be found? + // TODO: check if the user should be found... + $retweeted_status["user"] = array(); + } + + $rt_converted = api_convert_item($retweeted_item); + + $retweeted_status['text'] = $rt_converted["text"]; + $retweeted_status['statusnet_html'] = $rt_converted["html"]; + $retweeted_status['friendica_activities'] = api_format_items_activities($retweeted_item); + $retweeted_status['created_at'] = api_date($retweeted_item['created']); + $status['retweeted_status'] = $retweeted_status; } - - $status["retweeted_status"] = $retweeted_status; - $status["retweeted_status"]["body"] = $item["retweet-body"]; - $status["retweeted_status"]["author-name"] = $item["retweet-author-name"]; - $status["retweeted_status"]["author-link"] = $item["retweet-author-link"]; - $status["retweeted_status"]["author-avatar"] = $item["retweet-author-avatar"]; - $status["retweeted_status"]["plink"] = $item["retweet-plink"]; - - //echo "
"; var_dump($status); killme(); } // "uid" and "self" are only needed for some internal stuff, so remove it from here @@ -3024,23 +3025,36 @@ } api_register_func('api/friendica/remoteauth', 'api_friendica_remoteauth', true); - + /** + * @brief Return the item shared, if the item contains only the [share] tag + * + * @param array $item Sharer item + * @return array Shared item or false if not a reshare + */ function api_share_as_retweet(&$item) { $body = trim($item["body"]); // Skip if it isn't a pure repeated messages // Does it start with a share? if (strpos($body, "[share") > 0) - return(false); + return false; // Does it end with a share? if (strlen($body) > (strrpos($body, "[/share]") + 8)) - return(false); + return false; $attributes = preg_replace("/\[share(.*?)\]\s?(.*?)\s?\[\/share\]\s?/ism","$1",$body); - // Skip if there is no shared message in there - if ($body == $attributes) - return(false); + // Skip if there is no shared message in there + if ($body == $attributes) + return false; + + // NOTE: we could check te guid="" attribute and then try to load original post + // from database given the guid: we can see the original post via web under + // /display/, but all the logic to fetch an item from db based on guid + // looks like is in display_init() and would need a big refractor to be usable here. + // so, we build the original item starting from the reshare. + + $reshared_item = $item; $author = ""; preg_match("/author='(.*?)'/ism", $attributes, $matches); @@ -3078,18 +3092,31 @@ if ($matches[1] != "") $link = $matches[1]; + $posted = ""; + preg_match("/posted='(.*?)'/ism", $attributes, $matches); + if ($matches[1] != "") + $posted= $matches[1]; + + preg_match('/posted="(.*?)"/ism', $attributes, $matches); + if ($matches[1] != "") + $posted = $matches[1]; + $shared_body = preg_replace("/\[share(.*?)\]\s?(.*?)\s?\[\/share\]\s?/ism","$2",$body); - if (($shared_body == "") OR ($profile == "") OR ($author == "") OR ($avatar == "")) - return(false); + if (($shared_body == "") || ($profile == "") || ($author == "") || ($avatar == "") || ($posted == "")) + return false; - $item["retweet-body"] = $shared_body; - $item["retweet-author-name"] = $author; - $item["retweet-author-link"] = $profile; - $item["retweet-author-avatar"] = $avatar; - $item["retweet-plink"] = $link; - $item["is_retweet"] = true; - return(true); + + + $reshared_item["body"] = $shared_body; + $reshared_item["author-name"] = $author; + $reshared_item["author-link"] = $profile; + $reshared_item["author-avatar"] = $avatar; + $reshared_item["plink"] = $link; + $reshared_item["created"] = $posted; + $reshared_item["edited"] = $posted; + + return $reshared_item; }