From a2ff679d2d6d6f6f54774fc3016cdb1216cefbc9 Mon Sep 17 00:00:00 2001 From: Tobias Diekershoff Date: Sat, 31 Mar 2012 10:19:36 +0200 Subject: [PATCH] Twitter: add option to send #tag links to connected account --- twitter/twitter.css | 15 ++++++++++++--- twitter/twitter.php | 21 +++++++++++++++------ 2 files changed, 27 insertions(+), 9 deletions(-) diff --git a/twitter/twitter.css b/twitter/twitter.css index 899cfd173..75747979e 100755 --- a/twitter/twitter.css +++ b/twitter/twitter.css @@ -12,7 +12,7 @@ } #twitter-disconnect-label { float: left; - width: 200px; + width: 250px; margin-bottom: 25px; } @@ -21,16 +21,25 @@ } #twitter-enable-label { float: left; - width: 200px; + width: 250px; margin-bottom: 5px; } +#twitter-default-label { + float: left; + width: 250px; +} +#twitter-sendtaglinks-label { + float: left; + width: 250px; + margin-bottom: 25px; +} #twitter-checkbox { float: left; } #twitter-pin-label { float: left; - width: 200px; + width: 250px; margin-bottom: 25px; } diff --git a/twitter/twitter.php b/twitter/twitter.php index acd60fb2a..006c16152 100755 --- a/twitter/twitter.php +++ b/twitter/twitter.php @@ -2,7 +2,7 @@ /** * Name: Twitter Connector * Description: Relay public postings to a connected Twitter account - * Version: 1.0.2 + * Version: 1.0.3 * Author: Tobias Diekershoff */ @@ -93,6 +93,7 @@ function twitter_settings_post ($a,$post) { del_pconfig( local_user(), 'twitter', 'oauthsecret' ); del_pconfig( local_user(), 'twitter', 'post' ); del_pconfig( local_user(), 'twitter', 'post_by_default' ); + del_pconfig( local_user(), 'twitter', 'post_taglinks'); } else { if (isset($_POST['twitter-pin'])) { // if the user supplied us with a PIN from Twitter, let the magic of OAuth happen @@ -109,6 +110,7 @@ function twitter_settings_post ($a,$post) { set_pconfig(local_user(),'twitter', 'oauthtoken', $token['oauth_token']); set_pconfig(local_user(),'twitter', 'oauthsecret', $token['oauth_token_secret']); set_pconfig(local_user(),'twitter', 'post', 1); + set_pconfig(local_user(),'twitter', 'post_taglinks', 1); // reload the Addon Settings page, if we don't do it see Bug #42 goaway($a->get_baseurl().'/settings/connectors'); } else { @@ -116,6 +118,7 @@ function twitter_settings_post ($a,$post) { // to post a tweet for every new __public__ posting to the wall set_pconfig(local_user(),'twitter','post',intval($_POST['twitter-enable'])); set_pconfig(local_user(),'twitter','post_by_default',intval($_POST['twitter-default'])); + set_pconfig(local_user(),'twitter','post_taglinks',intval($_POST['twitter-sendtaglinks'])); info( t('Twitter settings updated.') . EOL); }} } @@ -136,6 +139,8 @@ function twitter_settings(&$a,&$s) { $checked = (($enabled) ? ' checked="checked" ' : ''); $defenabled = get_pconfig(local_user(),'twitter','post_by_default'); $defchecked = (($defenabled) ? ' checked="checked" ' : ''); + $linksenabled = get_pconfig(local_user(),'twitter','post_taglinks'); + $linkschecked = (($linksenabled) ? ' checked="checked" ' : ''); $s .= '
'; $s .= '

'. t('Twitter Posting Settings') .'

'; @@ -192,6 +197,9 @@ function twitter_settings(&$a,&$s) { $s .= '
'; $s .= ''; $s .= ''; + $s .= '
'; + $s .= ''; + $s .= ''; $s .= '
'; $s .= '
'; @@ -306,12 +314,13 @@ function twitter_post_hook(&$a,&$b) { $tmp = preg_replace( '/\[\\/?youtube(\\s+.*?\]|\])/i', '', $tmp); $tmp = preg_replace( '/\[\\/?vimeo(\\s+.*?\]|\])/i', '', $tmp); $tmp = preg_replace( '/\[\\/?audio(\\s+.*?\]|\])/i', '', $tmp); + $linksenabled = get_pconfig($b['uid'],'twitter','post_taglinks'); // if a #tag is linked, don't send the [url] over to SN - // this is commented out by default as it means backlinks - // to friendica, if you don't like this feel free to - // uncomment the following line -// $tmp = preg_replace( '/#\[url\=(\w+.*?)\](\w+.*?)\[\/url\]/i', '#$2', $tmp); - // preserve links to webpages + // that is, don't send if the option is not set in the + // connector settings + if ($linksenabled=='0') { + $tmp = preg_replace( '/#\[url\=(\w+.*?)\](\w+.*?)\[\/url\]/i', '#$2', $tmp); + } $tmp = preg_replace( '/\[url\=(https?\:\/\/[a-zA-Z0-9\:\/\-\?\&\;\.\=\_\~\#\%\$\!\+\,]+)\](\w+.*?)\[\/url\]/i', '$2 $1', $tmp); $tmp = preg_replace( '/\[bookmark\=(https?\:\/\/[a-zA-Z0-9\:\/\-\?\&\;\.\=\_\~\#\%\$\!\+\,]+)\](\w+.*?)\[\/bookmark\]/i', '$2 $1', $tmp); // find all http or https links in the body of the entry and