forked from friendica/friendica-addons
The function for fetching the original url is removed from the addons and added to the core.
This commit is contained in:
parent
76fac5069c
commit
7f37e843c7
3 changed files with 24 additions and 348 deletions
|
@ -53,11 +53,11 @@ function appnetpost_settings(&$a,&$s) {
|
||||||
$def_checked = (($def_enabled) ? ' checked="checked" ' : '');
|
$def_checked = (($def_enabled) ? ' checked="checked" ' : '');
|
||||||
|
|
||||||
$s .= '<span id="settings_appnetpost_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_appnetpost_expanded\'); openClose(\'settings_appnetpost_inflated\');">';
|
$s .= '<span id="settings_appnetpost_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_appnetpost_expanded\'); openClose(\'settings_appnetpost_inflated\');">';
|
||||||
$s .= '<h3>' . t('App.net') . '</h3>';
|
$s .= '<h3>' . t('App.net Export') . '</h3>';
|
||||||
$s .= '</span>';
|
$s .= '</span>';
|
||||||
$s .= '<div id="settings_appnetpost_expanded" class="settings-block" style="display: none;">';
|
$s .= '<div id="settings_appnetpost_expanded" class="settings-block" style="display: none;">';
|
||||||
$s .= '<span class="fakelink" onclick="openClose(\'settings_appnetpost_expanded\'); openClose(\'settings_appnetpost_inflated\');">';
|
$s .= '<span class="fakelink" onclick="openClose(\'settings_appnetpost_expanded\'); openClose(\'settings_appnetpost_inflated\');">';
|
||||||
$s .= '<h3>' . t('App.net') . '</h3>';
|
$s .= '<h3>' . t('App.net Export') . '</h3>';
|
||||||
$s .= '</span>';
|
$s .= '</span>';
|
||||||
|
|
||||||
$s .= '<div id="appnetpost-enable-wrapper">';
|
$s .= '<div id="appnetpost-enable-wrapper">';
|
||||||
|
@ -196,65 +196,6 @@ function appnetpost_init() {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
function appnetpost_original_url($url, $depth=1) {
|
|
||||||
|
|
||||||
if ($depth > 10)
|
|
||||||
return($url);
|
|
||||||
|
|
||||||
$siteinfo = array();
|
|
||||||
$ch = curl_init();
|
|
||||||
curl_setopt($ch, CURLOPT_URL, $url);
|
|
||||||
curl_setopt($ch, CURLOPT_HEADER, 1);
|
|
||||||
curl_setopt($ch, CURLOPT_NOBODY, 0);
|
|
||||||
curl_setopt($ch, CURLOPT_TIMEOUT, 3);
|
|
||||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
|
||||||
curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:24.0) Gecko/20100101 Firefox/24.0');
|
|
||||||
|
|
||||||
$header = curl_exec($ch);
|
|
||||||
$curl_info = @curl_getinfo($ch);
|
|
||||||
$http_code = $curl_info['http_code'];
|
|
||||||
curl_close($ch);
|
|
||||||
|
|
||||||
if ((($curl_info['http_code'] == "301") OR ($curl_info['http_code'] == "302"))
|
|
||||||
AND (($curl_info['redirect_url'] != "") OR ($curl_info['location'] != ""))) {
|
|
||||||
if ($curl_info['redirect_url'] != "")
|
|
||||||
return(appnetpost_original_url($curl_info['redirect_url'], ++$depth));
|
|
||||||
else
|
|
||||||
return(appnetpost_original_url($curl_info['location'], ++$depth));
|
|
||||||
}
|
|
||||||
|
|
||||||
$pos = strpos($header, "\r\n\r\n");
|
|
||||||
|
|
||||||
if ($pos)
|
|
||||||
$body = trim(substr($header, $pos));
|
|
||||||
else
|
|
||||||
$body = $header;
|
|
||||||
|
|
||||||
$doc = new DOMDocument();
|
|
||||||
@$doc->loadHTML($body);
|
|
||||||
|
|
||||||
$xpath = new DomXPath($doc);
|
|
||||||
|
|
||||||
$list = $xpath->query("//meta[@content]");
|
|
||||||
foreach ($list as $node) {
|
|
||||||
$attr = array();
|
|
||||||
if ($node->attributes->length)
|
|
||||||
foreach ($node->attributes as $attribute)
|
|
||||||
$attr[$attribute->name] = $attribute->value;
|
|
||||||
|
|
||||||
if (@$attr["http-equiv"] == 'refresh') {
|
|
||||||
$path = $attr["content"];
|
|
||||||
$pathinfo = explode(";", $path);
|
|
||||||
$content = "";
|
|
||||||
foreach ($pathinfo AS $value)
|
|
||||||
if (substr(strtolower($value), 0, 4) == "url=")
|
|
||||||
return(appnetpost_original_url(substr($value, 4), ++$depth));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return($url);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (! function_exists( 'short_link' )) {
|
if (! function_exists( 'short_link' )) {
|
||||||
function short_link($url) {
|
function short_link($url) {
|
||||||
require_once('library/slinky.php');
|
require_once('library/slinky.php');
|
||||||
|
@ -387,7 +328,7 @@ function appnetpost_feeditem($pid, $uid) {
|
||||||
if ($title == "")
|
if ($title == "")
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
//$origlink = appnetpost_original_url($origlink);
|
//$origlink = original_url($origlink);
|
||||||
|
|
||||||
$html = nl2br($title);
|
$html = nl2br($title);
|
||||||
|
|
||||||
|
|
|
@ -59,11 +59,11 @@ function gpluspost_settings(&$a,&$s) {
|
||||||
$skip_checked = (($skip_enabled) ? ' checked="checked" ' : '');
|
$skip_checked = (($skip_enabled) ? ' checked="checked" ' : '');
|
||||||
|
|
||||||
$s .= '<span id="settings_gpluspost_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_gpluspost_expanded\'); openClose(\'settings_gpluspost_inflated\');">';
|
$s .= '<span id="settings_gpluspost_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_gpluspost_expanded\'); openClose(\'settings_gpluspost_inflated\');">';
|
||||||
$s .= '<h3>' . t('Google+') . '</h3>';
|
$s .= '<h3>' . t('Google+ Export') . '</h3>';
|
||||||
$s .= '</span>';
|
$s .= '</span>';
|
||||||
$s .= '<div id="settings_gpluspost_expanded" class="settings-block" style="display: none;">';
|
$s .= '<div id="settings_gpluspost_expanded" class="settings-block" style="display: none;">';
|
||||||
$s .= '<span class="fakelink" onclick="openClose(\'settings_gpluspost_expanded\'); openClose(\'settings_gpluspost_inflated\');">';
|
$s .= '<span class="fakelink" onclick="openClose(\'settings_gpluspost_expanded\'); openClose(\'settings_gpluspost_inflated\');">';
|
||||||
$s .= '<h3>' . t('Google+') . '</h3>';
|
$s .= '<h3>' . t('Google+ Export') . '</h3>';
|
||||||
$s .= '</span>';
|
$s .= '</span>';
|
||||||
|
|
||||||
$s .= '<div id="gpluspost-enable-wrapper">';
|
$s .= '<div id="gpluspost-enable-wrapper">';
|
||||||
|
@ -214,70 +214,12 @@ function gpluspost_init() {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
function gpluspost_original_url($url, $depth=1) {
|
|
||||||
|
|
||||||
if ($depth > 10)
|
|
||||||
return($url);
|
|
||||||
|
|
||||||
$siteinfo = array();
|
|
||||||
$ch = curl_init();
|
|
||||||
curl_setopt($ch, CURLOPT_URL, $url);
|
|
||||||
curl_setopt($ch, CURLOPT_HEADER, 1);
|
|
||||||
curl_setopt($ch, CURLOPT_NOBODY, 0);
|
|
||||||
curl_setopt($ch, CURLOPT_TIMEOUT, 3);
|
|
||||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
|
||||||
curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:24.0) Gecko/20100101 Firefox/24.0');
|
|
||||||
|
|
||||||
$header = curl_exec($ch);
|
|
||||||
$curl_info = @curl_getinfo($ch);
|
|
||||||
$http_code = $curl_info['http_code'];
|
|
||||||
curl_close($ch);
|
|
||||||
|
|
||||||
if ((($curl_info['http_code'] == "301") OR ($curl_info['http_code'] == "302"))
|
|
||||||
AND (($curl_info['redirect_url'] != "") OR ($curl_info['location'] != ""))) {
|
|
||||||
if ($curl_info['redirect_url'] != "")
|
|
||||||
return(gpluspost_original_url($curl_info['redirect_url'], ++$depth));
|
|
||||||
else
|
|
||||||
return(gpluspost_original_url($curl_info['location'], ++$depth));
|
|
||||||
}
|
|
||||||
|
|
||||||
$pos = strpos($header, "\r\n\r\n");
|
|
||||||
|
|
||||||
if ($pos)
|
|
||||||
$body = trim(substr($header, $pos));
|
|
||||||
else
|
|
||||||
$body = $header;
|
|
||||||
|
|
||||||
$doc = new DOMDocument();
|
|
||||||
@$doc->loadHTML($body);
|
|
||||||
|
|
||||||
$xpath = new DomXPath($doc);
|
|
||||||
|
|
||||||
$list = $xpath->query("//meta[@content]");
|
|
||||||
foreach ($list as $node) {
|
|
||||||
$attr = array();
|
|
||||||
if ($node->attributes->length)
|
|
||||||
foreach ($node->attributes as $attribute)
|
|
||||||
$attr[$attribute->name] = $attribute->value;
|
|
||||||
|
|
||||||
if (@$attr["http-equiv"] == 'refresh') {
|
|
||||||
$path = $attr["content"];
|
|
||||||
$pathinfo = explode(";", $path);
|
|
||||||
$content = "";
|
|
||||||
foreach ($pathinfo AS $value)
|
|
||||||
if (substr(strtolower($value), 0, 4) == "url=")
|
|
||||||
return(gpluspost_original_url(substr($value, 4), ++$depth));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return($url);
|
|
||||||
}
|
|
||||||
|
|
||||||
function gpluspost_feeditem($pid, $uid) {
|
function gpluspost_feeditem($pid, $uid) {
|
||||||
global $a;
|
global $a;
|
||||||
|
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
require_once("include/html2plain.php");
|
require_once("include/html2plain.php");
|
||||||
|
require_once("include/network.php");
|
||||||
|
|
||||||
$skipwithoutlink = get_pconfig($uid,'gpluspost','skip_without_link');
|
$skipwithoutlink = get_pconfig($uid,'gpluspost','skip_without_link');
|
||||||
|
|
||||||
|
@ -365,7 +307,7 @@ function gpluspost_feeditem($pid, $uid) {
|
||||||
|
|
||||||
$title = trim(str_replace($msglink, "", $title));
|
$title = trim(str_replace($msglink, "", $title));
|
||||||
|
|
||||||
$msglink = gpluspost_original_url($msglink);
|
$msglink = original_url($msglink);
|
||||||
|
|
||||||
if ($uid == 0)
|
if ($uid == 0)
|
||||||
$title = $item["author-name"].": ".$title;
|
$title = $item["author-name"].": ".$title;
|
||||||
|
|
|
@ -230,12 +230,14 @@ function twitter_settings(&$a,&$s) {
|
||||||
$create_userenabled = get_pconfig(local_user(),'twitter','create_user');
|
$create_userenabled = get_pconfig(local_user(),'twitter','create_user');
|
||||||
$create_userchecked = (($create_userenabled) ? ' checked="checked" ' : '');
|
$create_userchecked = (($create_userenabled) ? ' checked="checked" ' : '');
|
||||||
|
|
||||||
|
$globalshortening = get_config('twitter','intelligent_shortening');
|
||||||
|
|
||||||
$s .= '<span id="settings_twitter_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_twitter_expanded\'); openClose(\'settings_twitter_inflated\');">';
|
$s .= '<span id="settings_twitter_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_twitter_expanded\'); openClose(\'settings_twitter_inflated\');">';
|
||||||
$s .= '<h3>'. t('Twitter') .'</h3>';
|
$s .= '<h3>'. t('Twitter Import/Export/Mirror') .'</h3>';
|
||||||
$s .= '</span>';
|
$s .= '</span>';
|
||||||
$s .= '<div id="settings_twitter_expanded" class="settings-block" style="display: none;">';
|
$s .= '<div id="settings_twitter_expanded" class="settings-block" style="display: none;">';
|
||||||
$s .= '<span class="fakelink" onclick="openClose(\'settings_twitter_expanded\'); openClose(\'settings_twitter_inflated\');">';
|
$s .= '<span class="fakelink" onclick="openClose(\'settings_twitter_expanded\'); openClose(\'settings_twitter_inflated\');">';
|
||||||
$s .= '<h3>'. t('Twitter') .'</h3>';
|
$s .= '<h3>'. t('Twitter Import/Export/Mirror') .'</h3>';
|
||||||
$s .= '</span>';
|
$s .= '</span>';
|
||||||
|
|
||||||
if ( (!$ckey) && (!$csecret) ) {
|
if ( (!$ckey) && (!$csecret) ) {
|
||||||
|
@ -296,13 +298,16 @@ function twitter_settings(&$a,&$s) {
|
||||||
$s .= '<input id="twitter-mirror" type="checkbox" name="twitter-mirror" value="1" '. $mirrorchecked . '/>';
|
$s .= '<input id="twitter-mirror" type="checkbox" name="twitter-mirror" value="1" '. $mirrorchecked . '/>';
|
||||||
$s .= '<div class="clear"></div>';
|
$s .= '<div class="clear"></div>';
|
||||||
|
|
||||||
$s .= '<label id="twitter-shortening-label" for="twitter-shortening">'.t('Shortening method that optimizes the tweet').'</label>';
|
if (!$globalshortening) {
|
||||||
$s .= '<input id="twitter-shortening" type="checkbox" name="twitter-shortening" value="1" '. $shorteningchecked . '/>';
|
$s .= '<label id="twitter-shortening-label" for="twitter-shortening">'.t('Shortening method that optimizes the tweet').'</label>';
|
||||||
$s .= '<div class="clear"></div>';
|
$s .= '<input id="twitter-shortening" type="checkbox" name="twitter-shortening" value="1" '. $shorteningchecked . '/>';
|
||||||
|
$s .= '<div class="clear"></div>';
|
||||||
|
|
||||||
$s .= '<label id="twitter-sendtaglinks-label" for="twitter-sendtaglinks">'.t('Send linked #-tags and @-names to Twitter').'</label>';
|
$s .= '<label id="twitter-sendtaglinks-label" for="twitter-sendtaglinks">'.t('Send linked #-tags and @-names to Twitter').'</label>';
|
||||||
$s .= '<input id="twitter-sendtaglinks" type="checkbox" name="twitter-sendtaglinks" value="1" '. $linkschecked . '/>';
|
$s .= '<input id="twitter-sendtaglinks" type="checkbox" name="twitter-sendtaglinks" value="1" '. $linkschecked . '/>';
|
||||||
$s .= '</div><div class="clear"></div>';
|
$s .= '<div class="clear"></div>';
|
||||||
|
}
|
||||||
|
$s .= '</div>';
|
||||||
|
|
||||||
$s .= '<label id="twitter-import-label" for="twitter-import">'.t('Import the remote timeline').'</label>';
|
$s .= '<label id="twitter-import-label" for="twitter-import">'.t('Import the remote timeline').'</label>';
|
||||||
$s .= '<input id="twitter-import" type="checkbox" name="twitter-import" value="1" '. $importchecked . '/>';
|
$s .= '<input id="twitter-import" type="checkbox" name="twitter-import" value="1" '. $importchecked . '/>';
|
||||||
|
@ -1006,7 +1011,6 @@ function twitter_fetchtimeline($a, $uid) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//$converted = twitter_convertmsg($a, $_REQUEST['body'], true, $has_picture);
|
|
||||||
$converted = twitter_expand_entities($a, $_REQUEST['body'], $post->retweeted_status, true, $has_picture);
|
$converted = twitter_expand_entities($a, $_REQUEST['body'], $post->retweeted_status, true, $has_picture);
|
||||||
$_REQUEST['body'] = $converted["body"];
|
$_REQUEST['body'] = $converted["body"];
|
||||||
|
|
||||||
|
@ -1030,7 +1034,6 @@ function twitter_fetchtimeline($a, $uid) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//$converted = twitter_convertmsg($a, $_REQUEST["body"], true, $has_picture);
|
|
||||||
$converted = twitter_expand_entities($a, $_REQUEST["body"], $post, true, $has_picture);
|
$converted = twitter_expand_entities($a, $_REQUEST["body"], $post, true, $has_picture);
|
||||||
$_REQUEST['body'] = $converted["body"];
|
$_REQUEST['body'] = $converted["body"];
|
||||||
}
|
}
|
||||||
|
@ -1305,6 +1308,7 @@ function twitter_fetchuser($a, $uid, $screen_name = "", $user_id = "") {
|
||||||
|
|
||||||
function twitter_expand_entities($a, $body, $item, $no_tags = false, $dontincludemedia) {
|
function twitter_expand_entities($a, $body, $item, $no_tags = false, $dontincludemedia) {
|
||||||
require_once("include/oembed.php");
|
require_once("include/oembed.php");
|
||||||
|
require_once("include/network.php");
|
||||||
|
|
||||||
$tags = "";
|
$tags = "";
|
||||||
|
|
||||||
|
@ -1317,7 +1321,7 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $dontinclud
|
||||||
foreach ($item->entities->urls AS $url) {
|
foreach ($item->entities->urls AS $url) {
|
||||||
if ($url->url AND $url->expanded_url AND $url->display_url) {
|
if ($url->url AND $url->expanded_url AND $url->display_url) {
|
||||||
|
|
||||||
$expanded_url = twitter_original_url($url->expanded_url);
|
$expanded_url = original_url($url->expanded_url);
|
||||||
|
|
||||||
$oembed_data = oembed_fetch_url($expanded_url);
|
$oembed_data = oembed_fetch_url($expanded_url);
|
||||||
|
|
||||||
|
@ -1341,7 +1345,6 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $dontinclud
|
||||||
$body = str_replace($url->url,
|
$body = str_replace($url->url,
|
||||||
"[url=".$expanded_url."]".$expanded_url."[/url]",
|
"[url=".$expanded_url."]".$expanded_url."[/url]",
|
||||||
$body);
|
$body);
|
||||||
//"[url=".$expanded_url."]".$url->display_url."[/url]",
|
|
||||||
else {
|
else {
|
||||||
$img_str = fetch_url($expanded_url, true, $redirects, 4);
|
$img_str = fetch_url($expanded_url, true, $redirects, 4);
|
||||||
|
|
||||||
|
@ -1358,7 +1361,6 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $dontinclud
|
||||||
$type = $oembed_data->type;
|
$type = $oembed_data->type;
|
||||||
$footerurl = $expanded_url;
|
$footerurl = $expanded_url;
|
||||||
$footerlink = "[url=".$expanded_url."]".$expanded_url."[/url]";
|
$footerlink = "[url=".$expanded_url."]".$expanded_url."[/url]";
|
||||||
//$footerlink = "[url=".$expanded_url."]".$url->display_url."[/url]";
|
|
||||||
|
|
||||||
$body = str_replace($url->url, $footerlink, $body);
|
$body = str_replace($url->url, $footerlink, $body);
|
||||||
}
|
}
|
||||||
|
@ -1367,7 +1369,7 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $dontinclud
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($footerurl != "")
|
if ($footerurl != "")
|
||||||
$footer = twitter_siteinfo($footerurl, $dontincludemedia);
|
$footer = add_page_info($footerurl);
|
||||||
|
|
||||||
if (($footerlink != "") AND (trim($footer) != "")) {
|
if (($footerlink != "") AND (trim($footer) != "")) {
|
||||||
$removedlink = trim(str_replace($footerlink, "", $body));
|
$removedlink = trim(str_replace($footerlink, "", $body));
|
||||||
|
@ -1375,7 +1377,7 @@ function twitter_expand_entities($a, $body, $item, $no_tags = false, $dontinclud
|
||||||
if (strstr($body, $removedlink))
|
if (strstr($body, $removedlink))
|
||||||
$body = $removedlink;
|
$body = $removedlink;
|
||||||
|
|
||||||
$body .= "\n\n[class=type-".$type."]".$footer."[/class]";
|
$body .= $footer;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($no_tags)
|
if ($no_tags)
|
||||||
|
@ -1546,7 +1548,6 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//$converted = twitter_convertmsg($a, $postarray['body'], false, $has_picture);
|
|
||||||
$converted = twitter_expand_entities($a, $postarray['body'], $post, false, $has_picture);
|
$converted = twitter_expand_entities($a, $postarray['body'], $post, false, $has_picture);
|
||||||
$postarray['body'] = $converted["body"];
|
$postarray['body'] = $converted["body"];
|
||||||
$postarray['tag'] = $converted["tags"];
|
$postarray['tag'] = $converted["tags"];
|
||||||
|
@ -1584,7 +1585,6 @@ function twitter_createpost($a, $uid, $post, $self, $create_user, $only_existing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//$converted = twitter_convertmsg($a, $postarray['body'], false, $has_picture);
|
|
||||||
$converted = twitter_expand_entities($a, $postarray['body'], $post->retweeted_status, false, $has_picture);
|
$converted = twitter_expand_entities($a, $postarray['body'], $post->retweeted_status, false, $has_picture);
|
||||||
$postarray['body'] = $converted["body"];
|
$postarray['body'] = $converted["body"];
|
||||||
$postarray['tag'] = $converted["tags"];
|
$postarray['tag'] = $converted["tags"];
|
||||||
|
@ -1839,213 +1839,6 @@ function twitter_fetchhometimeline($a, $uid) {
|
||||||
set_pconfig($uid, 'twitter', 'lastmentionid', $lastid);
|
set_pconfig($uid, 'twitter', 'lastmentionid', $lastid);
|
||||||
}
|
}
|
||||||
|
|
||||||
function twitter_original_url($url, $depth=1, $fetchbody = false) {
|
|
||||||
if ($depth > 10)
|
|
||||||
return($url);
|
|
||||||
|
|
||||||
$siteinfo = array();
|
|
||||||
$ch = curl_init();
|
|
||||||
curl_setopt($ch, CURLOPT_URL, $url);
|
|
||||||
curl_setopt($ch, CURLOPT_HEADER, 1);
|
|
||||||
|
|
||||||
if ($fetchbody)
|
|
||||||
curl_setopt($ch, CURLOPT_NOBODY, 0);
|
|
||||||
else
|
|
||||||
curl_setopt($ch, CURLOPT_NOBODY, 1);
|
|
||||||
|
|
||||||
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
|
|
||||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
|
||||||
curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:24.0) Gecko/20100101 Firefox/24.0');
|
|
||||||
|
|
||||||
$header = curl_exec($ch);
|
|
||||||
$curl_info = @curl_getinfo($ch);
|
|
||||||
$http_code = $curl_info['http_code'];
|
|
||||||
curl_close($ch);
|
|
||||||
|
|
||||||
if ((($curl_info['http_code'] == "301") OR ($curl_info['http_code'] == "302"))
|
|
||||||
AND (($curl_info['redirect_url'] != "") OR ($curl_info['location'] != ""))) {
|
|
||||||
if ($curl_info['redirect_url'] != "")
|
|
||||||
return(twitter_original_url($curl_info['redirect_url'], ++$depth, $fetchbody));
|
|
||||||
else
|
|
||||||
return(twitter_original_url($curl_info['location'], ++$depth, $fetchbody));
|
|
||||||
}
|
|
||||||
|
|
||||||
$pos = strpos($header, "\r\n\r\n");
|
|
||||||
|
|
||||||
if ($pos)
|
|
||||||
$body = trim(substr($header, $pos));
|
|
||||||
else
|
|
||||||
$body = $header;
|
|
||||||
|
|
||||||
if (trim($body) == "")
|
|
||||||
return(twitter_original_url($url, ++$depth, true));
|
|
||||||
|
|
||||||
$doc = new DOMDocument();
|
|
||||||
@$doc->loadHTML($body);
|
|
||||||
|
|
||||||
$xpath = new DomXPath($doc);
|
|
||||||
|
|
||||||
$list = $xpath->query("//meta[@content]");
|
|
||||||
foreach ($list as $node) {
|
|
||||||
$attr = array();
|
|
||||||
if ($node->attributes->length)
|
|
||||||
foreach ($node->attributes as $attribute)
|
|
||||||
$attr[$attribute->name] = $attribute->value;
|
|
||||||
|
|
||||||
if (@$attr["http-equiv"] == 'refresh') {
|
|
||||||
$path = $attr["content"];
|
|
||||||
$pathinfo = explode(";", $path);
|
|
||||||
$content = "";
|
|
||||||
foreach ($pathinfo AS $value)
|
|
||||||
if (substr(strtolower($value), 0, 4) == "url=")
|
|
||||||
return(twitter_original_url(substr($value, 4), ++$depth));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return($url);
|
|
||||||
}
|
|
||||||
|
|
||||||
function twitter_siteinfo($url, $dontincludemedia) {
|
|
||||||
require_once("mod/parse_url.php");
|
|
||||||
|
|
||||||
// Fetch site infos - but only from the meta data
|
|
||||||
$data = parseurl_getsiteinfo($url, true);
|
|
||||||
|
|
||||||
if ($dontincludemedia)
|
|
||||||
unset($data["images"]);
|
|
||||||
|
|
||||||
if (!is_string($data["text"]) AND (sizeof($data["images"]) == 0) AND ($data["title"] == $url))
|
|
||||||
return("");
|
|
||||||
|
|
||||||
if (is_string($data["title"]))
|
|
||||||
$text .= "[bookmark=".$url."]".trim($data["title"])."[/bookmark]\n";
|
|
||||||
|
|
||||||
// Add a spoiler to the extra information
|
|
||||||
//if ((sizeof($data["images"]) > 0) OR is_string($data["text"]))
|
|
||||||
// $text .= "[spoiler]";
|
|
||||||
|
|
||||||
if (sizeof($data["images"]) > 0) {
|
|
||||||
$imagedata = $data["images"][0];
|
|
||||||
//$text .= '[img='.$imagedata["width"].'x'.$imagedata["height"].']'.$imagedata["src"].'[/img]' . "\n";
|
|
||||||
$text .= '[img]'.$imagedata["src"].'[/img]'."\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_string($data["text"]))
|
|
||||||
$text .= "[quote]".$data["text"]."[/quote]";
|
|
||||||
|
|
||||||
//if ((sizeof($data["images"]) > 0) OR is_string($data["text"]))
|
|
||||||
// $text .= "[/spoiler]";
|
|
||||||
|
|
||||||
return($text);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function twitter_convertmsg($a, $body, $no_tags = false, $dontincludemedia) {
|
|
||||||
|
|
||||||
require_once("include/oembed.php");
|
|
||||||
|
|
||||||
$links = preg_match_all("/([^\]\='".'"'."]|^)(https?\:\/\/[a-zA-Z0-9\:\/\-\?\&\;\.\=\_\~\#\%\$\!\+\,]+)/ism", $body,$matches,PREG_SET_ORDER);
|
|
||||||
|
|
||||||
$footer = "";
|
|
||||||
$footerurl = "";
|
|
||||||
$type = "";
|
|
||||||
|
|
||||||
if ($links) {
|
|
||||||
foreach ($matches AS $match) {
|
|
||||||
$expanded_url = twitter_original_url($match[2]);
|
|
||||||
|
|
||||||
$oembed_data = oembed_fetch_url($expanded_url);
|
|
||||||
|
|
||||||
if ($type == "")
|
|
||||||
$type = $oembed_data->type;
|
|
||||||
|
|
||||||
if ($oembed_data->type != "link")
|
|
||||||
$body = str_replace($match[2], "\n[url]".$expanded_url."[/url]\n", $body);
|
|
||||||
else {
|
|
||||||
$img_str = fetch_url($expanded_url, true, $redirects, 4);
|
|
||||||
|
|
||||||
$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/") {
|
|
||||||
$type = "photo";
|
|
||||||
$body = str_replace($match[2], "[img]".$expanded_url."[/img]", $body);
|
|
||||||
$dontincludemedia = true;
|
|
||||||
} else {
|
|
||||||
$type = $oembed_data->type;
|
|
||||||
$footerurl = $expanded_url;
|
|
||||||
$footerlink = "[url=".$expanded_url."]".$expanded_url."[/url]";
|
|
||||||
|
|
||||||
$body = str_replace($match[2], $footerlink, $body);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($footerurl != "")
|
|
||||||
$footer = twitter_siteinfo($footerurl, $dontincludemedia);
|
|
||||||
|
|
||||||
if (($footerlink != "") AND (trim($footer) != "")) {
|
|
||||||
$removedlink = trim(str_replace($footerlink, "", $body));
|
|
||||||
|
|
||||||
if (strstr($body, $removedlink))
|
|
||||||
$body = $removedlink;
|
|
||||||
|
|
||||||
$body .= "\n\n[class=type-".$type."]".$footer."[/class]";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($no_tags)
|
|
||||||
return(array("body" => $body, "tags" => ""));
|
|
||||||
|
|
||||||
$str_tags = '';
|
|
||||||
|
|
||||||
$tags = get_tags($body);
|
|
||||||
|
|
||||||
if(count($tags)) {
|
|
||||||
foreach($tags as $tag) {
|
|
||||||
if (strstr(trim($tag), " "))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if(strpos($tag,'#') === 0) {
|
|
||||||
if(strpos($tag,'[url='))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// don't link tags that are already embedded in links
|
|
||||||
|
|
||||||
if(preg_match('/\[(.*?)' . preg_quote($tag,'/') . '(.*?)\]/',$body))
|
|
||||||
continue;
|
|
||||||
if(preg_match('/\[(.*?)\]\((.*?)' . preg_quote($tag,'/') . '(.*?)\)/',$body))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
$basetag = str_replace('_',' ',substr($tag,1));
|
|
||||||
$body = str_replace($tag,'#[url=' . $a->get_baseurl() . '/search?tag=' . rawurlencode($basetag) . ']' . $basetag . '[/url]',$body);
|
|
||||||
if(strlen($str_tags))
|
|
||||||
$str_tags .= ',';
|
|
||||||
$str_tags .= '#[url=' . $a->get_baseurl() . '/search?tag=' . rawurlencode($basetag) . ']' . $basetag . '[/url]';
|
|
||||||
continue;
|
|
||||||
} elseif(strpos($tag,'@') === 0) {
|
|
||||||
$basetag = substr($tag,1);
|
|
||||||
$body = str_replace($tag,'@[url=https://twitter.com/' . rawurlencode($basetag) . ']' . $basetag . '[/url]',$body);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$cnt = preg_match_all('/@\[url=(.*?)\[\/url\]/ism',$body,$matches,PREG_SET_ORDER);
|
|
||||||
if($cnt) {
|
|
||||||
foreach($matches as $mtch) {
|
|
||||||
if(strlen($str_tags))
|
|
||||||
$str_tags .= ',';
|
|
||||||
$str_tags .= '@[url=' . $mtch[1] . '[/url]';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return(array("body"=>$body, "tags"=>$str_tags));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function twitter_fetch_own_contact($a, $uid) {
|
function twitter_fetch_own_contact($a, $uid) {
|
||||||
$ckey = get_config('twitter', 'consumerkey');
|
$ckey = get_config('twitter', 'consumerkey');
|
||||||
$csecret = get_config('twitter', 'consumersecret');
|
$csecret = get_config('twitter', 'consumersecret');
|
||||||
|
|
Loading…
Reference in a new issue