From f18b516c7a72a27bcb667ffb35054c0e9d61fe52 Mon Sep 17 00:00:00 2001 From: Jean Baptiste Favre Date: Fri, 14 Jun 2013 23:27:24 +0200 Subject: [PATCH] Get rid of t.co links for notice's text version. Usefull for client using API. Complements merge-request #205 by @mmn --- plugins/TwitterBridge/twitterimport.php | 28 ++++++++++++++++++------- 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/plugins/TwitterBridge/twitterimport.php b/plugins/TwitterBridge/twitterimport.php index 1c362d6fe8..e3b51c0908 100644 --- a/plugins/TwitterBridge/twitterimport.php +++ b/plugins/TwitterBridge/twitterimport.php @@ -172,8 +172,8 @@ class TwitterImport $notice->is_local = Notice::GATEWAY; - $notice->content = html_entity_decode($status->text, ENT_QUOTES, 'UTF-8'); - $notice->rendered = $this->linkify($status); + $notice->content = html_entity_decode($this->linkify($status, FALSE), ENT_QUOTES, 'UTF-8'); + $notice->rendered = $this->linkify($status, TRUE); if (Event::handle('StartNoticeSave', array(&$notice))) { @@ -540,7 +540,7 @@ class TwitterImport const HASHTAG = 2; const MENTION = 3; - function linkify($status) + function linkify($status, $html = FALSE) { $text = $status->text; @@ -596,13 +596,21 @@ class TwitterImport $orig = $this->twitEscape(mb_substr($text, $start, $end - $start)); switch($type) { case self::URL: - $linkText = $this->makeUrlLink($object, $orig); + $linkText = $this->makeUrlLink($object, $orig, $html); break; case self::HASHTAG: - $linkText = $this->makeHashtagLink($object, $orig); + if ($html) { + $linkText = $this->makeHashtagLink($object, $orig); + }else{ + $linkText = $orig; + } break; case self::MENTION: - $linkText = $this->makeMentionLink($object, $orig); + if ($html) { + $linkText = $this->makeMentionLink($object, $orig); + }else{ + $linkText = $orig; + } break; default: $linkText = $orig; @@ -630,9 +638,13 @@ class TwitterImport return htmlspecialchars(html_entity_decode($str, ENT_COMPAT, 'UTF-8')); } - function makeUrlLink($object, $orig) + function makeUrlLink($object, $orig, $html) { - return "{$orig}"; + if ($html) { + return ''.htmlspecialchars($object->display_url).''; + }else{ + return htmlspecialchars($object->expanded_url); + } } function makeHashtagLink($object, $orig)