| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							| 
									
										
										
										
											2009-08-25 18:14:12 -04:00
										 |  |  |  * StatusNet - the distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2009-08-25 18:12:20 -04:00
										 |  |  |  * Copyright (C) 2008, 2009, StatusNet, Inc. | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-26 10:41:36 -04:00
										 |  |  | if (!defined('STATUSNET') && !defined('LACONICA')) { | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |     exit(1); | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  | define('TWITTER_SERVICE', 1); // Twitter is foreign_service ID 1
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-14 04:50:16 +00:00
										 |  |  | require_once INSTALLDIR . '/plugins/TwitterBridge/twitterbasicauthclient.php'; | 
					
						
							|  |  |  | require_once INSTALLDIR . '/plugins/TwitterBridge/twitteroauthclient.php'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-09 17:53:35 -07:00
										 |  |  | function updateTwitter_user($twitter_id, $screen_name) | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  | { | 
					
						
							|  |  |  |     $uri = 'http://twitter.com/' . $screen_name; | 
					
						
							|  |  |  |     $fuser = new Foreign_user(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $fuser->query('BEGIN'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-09 20:01:46 +01:00
										 |  |  |     // Dropping down to SQL because regular DB_DataObject udpate stuff doesn't seem
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     // to work so good with tables that have multiple column primary keys
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Any time we update the uri for a forein user we have to make sure there
 | 
					
						
							|  |  |  |     // are no dupe entries first -- unique constraint on the uri column
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $qry = 'UPDATE foreign_user set uri = \'\' WHERE uri = '; | 
					
						
							|  |  |  |     $qry .= '\'' . $uri . '\'' . ' AND service = ' . TWITTER_SERVICE; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |     $fuser->query($qry); | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Update the user
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     $qry = 'UPDATE foreign_user SET nickname = '; | 
					
						
							|  |  |  |     $qry .= '\'' . $screen_name . '\'' . ', uri = \'' . $uri . '\' '; | 
					
						
							|  |  |  |     $qry .= 'WHERE id = ' . $twitter_id . ' AND service = ' . TWITTER_SERVICE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $fuser->query('COMMIT'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $fuser->free(); | 
					
						
							|  |  |  |     unset($fuser); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  | function add_twitter_user($twitter_id, $screen_name) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     $new_uri = 'http://twitter.com/' . $screen_name; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Clear out any bad old foreign_users with the new user's legit URL
 | 
					
						
							|  |  |  |     // This can happen when users move around or fakester accounts get
 | 
					
						
							|  |  |  |     // repoed, and things like that.
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     $luser = new Foreign_user(); | 
					
						
							|  |  |  |     $luser->uri = $new_uri; | 
					
						
							|  |  |  |     $luser->service = TWITTER_SERVICE; | 
					
						
							|  |  |  |     $result = $luser->delete(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |     if (empty($result)) { | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |         common_log(LOG_WARNING, | 
					
						
							|  |  |  |             "Twitter bridge - removed invalid Twitter user squatting on uri: $new_uri"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $luser->free(); | 
					
						
							|  |  |  |     unset($luser); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     // Otherwise, create a new Twitter user
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     $fuser = new Foreign_user(); | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     $fuser->nickname = $screen_name; | 
					
						
							|  |  |  |     $fuser->uri = 'http://twitter.com/' . $screen_name; | 
					
						
							|  |  |  |     $fuser->id = $twitter_id; | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     $fuser->service = TWITTER_SERVICE; | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     $fuser->created = common_sql_now(); | 
					
						
							|  |  |  |     $result = $fuser->insert(); | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |     if (empty($result)) { | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |         common_log(LOG_WARNING, | 
					
						
							|  |  |  |             "Twitter bridge - failed to add new Twitter user: $twitter_id - $screen_name."); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         common_log_db_error($fuser, 'INSERT', __FILE__); | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         common_debug("Twitter bridge - Added new Twitter user: $screen_name ($twitter_id)."); | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     return $result; | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Creates or Updates a Twitter user
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:33:23 -05:00
										 |  |  | function save_twitter_user($twitter_id, $screen_name) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     // Check to see whether the Twitter user is already in the system,
 | 
					
						
							|  |  |  |     // and update its screen name and uri if so.
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     $fuser = Foreign_user::getForeignUser($twitter_id, TWITTER_SERVICE); | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |     if (!empty($fuser)) { | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |         $result = true; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         // Only update if Twitter screen name has changed
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |         if ($fuser->nickname != $screen_name) { | 
					
						
							| 
									
										
										
										
											2009-10-09 17:53:35 -07:00
										 |  |  |             $result = updateTwitter_user($twitter_id, $screen_name); | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |             common_debug('Twitter bridge - Updated nickname (and URI) for Twitter user ' . | 
					
						
							|  |  |  |                 "$fuser->id to $screen_name, was $fuser->nickname"); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |         return $result; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     } else { | 
					
						
							|  |  |  |         return add_twitter_user($twitter_id, $screen_name); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-07 18:29:10 -07:00
										 |  |  |     $fuser->free(); | 
					
						
							|  |  |  |     unset($fuser); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-23 14:19:07 -05:00
										 |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | function is_twitter_bound($notice, $flink) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Check to see if notice should go to Twitter
 | 
					
						
							| 
									
										
										
										
											2009-02-26 13:36:38 -08:00
										 |  |  |     if (!empty($flink) && ($flink->noticesync & FOREIGN_NOTICE_SEND)) { | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // If it's not a Twitter-style reply, or if the user WANTS to send replies.
 | 
					
						
							|  |  |  |         if (!preg_match('/^@[a-zA-Z0-9_]{1,15}\b/u', $notice->content) || | 
					
						
							|  |  |  |             ($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY)) { | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |             return true; | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-26 13:36:38 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  |     return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function broadcast_twitter($notice) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-02-26 13:36:38 -08:00
										 |  |  |     $flink = Foreign_link::getByUserID($notice->profile_id, | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                                        TWITTER_SERVICE); | 
					
						
							| 
									
										
										
										
											2009-02-26 13:36:38 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-08 00:30:18 -07:00
										 |  |  |     if (is_twitter_bound($notice, $flink)) { | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |         if (TwitterOAuthClient::isPackedToken($flink->credentials)) { | 
					
						
							|  |  |  |             return broadcast_oauth($notice, $flink); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             return broadcast_basicauth($notice, $flink); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-01 19:00:18 +00:00
										 |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-08-30 18:35:44 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  | function broadcast_oauth($notice, $flink) { | 
					
						
							|  |  |  |     $user = $flink->getUser(); | 
					
						
							|  |  |  |     $statustxt = format_status($notice); | 
					
						
							| 
									
										
										
										
											2009-09-02 16:42:15 -04:00
										 |  |  |     // Convert !groups to #hashes
 | 
					
						
							|  |  |  |     $statustxt = preg_replace('/(^|\s)!([A-Za-z0-9]{1,64})/', "\\1#\\2", $statustxt); | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     $token = TwitterOAuthClient::unpackToken($flink->credentials); | 
					
						
							|  |  |  |     $client = new TwitterOAuthClient($token->key, $token->secret); | 
					
						
							|  |  |  |     $status = null; | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     try { | 
					
						
							|  |  |  |         $status = $client->statusesUpdate($statustxt); | 
					
						
							| 
									
										
										
										
											2009-11-25 18:04:08 +00:00
										 |  |  |     } catch (OAuthClientException $e) { | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |         return process_error($e, $flink, $notice); | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-08-10 07:00:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     if (empty($status)) { | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |         // This could represent a failure posting,
 | 
					
						
							|  |  |  |         // or the Twitter API might just be behaving flakey.
 | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-02 00:50:41 +00:00
										 |  |  |         $errmsg = sprintf('Twitter bridge - No data returned by Twitter API when ' . | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |                           'trying to post notice %d for User %s (user id %d).', | 
					
						
							|  |  |  |                           $notice->id, | 
					
						
							|  |  |  |                           $user->nickname, | 
					
						
							|  |  |  |                           $user->id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |         common_log(LOG_WARNING, $errmsg); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     // Notice crossed the great divide
 | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |     $msg = sprintf('Twitter bridge - posted notice %d to Twitter using ' . | 
					
						
							|  |  |  |                    'OAuth for User %s (user id %d).', | 
					
						
							|  |  |  |                    $notice->id, | 
					
						
							|  |  |  |                    $user->nickname, | 
					
						
							|  |  |  |                    $user->id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     common_log(LOG_INFO, $msg); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     return true; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  | function broadcast_basicauth($notice, $flink) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     $user = $flink->getUser(); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     $statustxt = format_status($notice); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 06:00:30 +00:00
										 |  |  |     $client = new TwitterBasicAuthClient($flink); | 
					
						
							|  |  |  |     $status = null; | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 06:00:30 +00:00
										 |  |  |     try { | 
					
						
							|  |  |  |         $status = $client->statusesUpdate($statustxt); | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |     } catch (BasicAuthException $e) { | 
					
						
							|  |  |  |         return process_error($e, $flink, $notice); | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     if (empty($status)) { | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-02 00:50:41 +00:00
										 |  |  |         $errmsg = sprintf('Twitter bridge - No data returned by Twitter API when ' . | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |                           'trying to post notice %d for %s (user id %d).', | 
					
						
							|  |  |  |                           $notice->id, | 
					
						
							|  |  |  |                           $user->nickname, | 
					
						
							|  |  |  |                           $user->id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |         common_log(LOG_WARNING, $errmsg); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |         $errmsg = sprintf('No data returned by Twitter API when ' . | 
					
						
							|  |  |  |                           'trying to post notice %d for %s (user id %d).', | 
					
						
							|  |  |  |                           $notice->id, | 
					
						
							|  |  |  |                           $user->nickname, | 
					
						
							|  |  |  |                           $user->id); | 
					
						
							|  |  |  |         common_log(LOG_WARNING, $errmsg); | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |         return false; | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |     $msg = sprintf('Twitter bridge - posted notice %d to Twitter using ' . | 
					
						
							|  |  |  |                    'HTTP basic auth for User %s (user id %d).', | 
					
						
							|  |  |  |                    $notice->id, | 
					
						
							|  |  |  |                    $user->nickname, | 
					
						
							|  |  |  |                    $user->id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |     common_log(LOG_INFO, $msg); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2009-09-02 00:50:41 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  | function process_error($e, $flink, $notice) | 
					
						
							| 
									
										
										
										
											2009-09-02 00:50:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |     $user = $flink->getUser(); | 
					
						
							|  |  |  |     $code = $e->getCode(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $logmsg = sprintf('Twitter bridge - %d posting notice %d for ' . | 
					
						
							|  |  |  |                       'User %s (user id: %d): %s.', | 
					
						
							|  |  |  |                       $code, | 
					
						
							|  |  |  |                       $notice->id, | 
					
						
							|  |  |  |                       $user->nickname, | 
					
						
							|  |  |  |                       $user->id, | 
					
						
							|  |  |  |                       $e->getMessage()); | 
					
						
							| 
									
										
										
										
											2009-02-26 13:36:38 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-02 00:50:41 +00:00
										 |  |  |     common_log(LOG_WARNING, $logmsg); | 
					
						
							| 
									
										
										
										
											2009-08-28 06:00:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 07:33:29 +00:00
										 |  |  |     if ($code == 401) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Probably a revoked or otherwise bad access token - nuke!
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         remove_twitter_link($flink); | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // For every other case, it's probably some flakiness so try
 | 
					
						
							|  |  |  |         // sending the notice again later (requeue).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  | function format_status($notice) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     // XXX: Hack to get around PHP cURL's use of @ being a a meta character
 | 
					
						
							|  |  |  |     return preg_replace('/^@/', ' @', $notice->content); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function remove_twitter_link($flink) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     $user = $flink->getUser(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     common_log(LOG_INFO, 'Removing Twitter bridge Foreign link for ' . | 
					
						
							| 
									
										
										
										
											2009-08-28 04:36:47 +00:00
										 |  |  |                "user $user->nickname (user id: $user->id)."); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     $result = $flink->delete(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (empty($result)) { | 
					
						
							|  |  |  |         common_log(LOG_ERR, 'Could not remove Twitter bridge ' . | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                    "Foreign_link for $user->nickname (user id: $user->id)!"); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  |         common_log_db_error($flink, 'DELETE', __FILE__); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // Notify the user that her Twitter bridge is down
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-03 22:46:01 +00:00
										 |  |  |     if (isset($user->email)) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |         $result = mail_twitter_bridge_removed($user); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |         if (!$result) { | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |             $msg = 'Unable to send email to notify ' . | 
					
						
							|  |  |  |               "$user->nickname (user id: $user->id) " . | 
					
						
							|  |  |  |               'that their Twitter bridge link was ' . | 
					
						
							|  |  |  |               'removed!'; | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |             common_log(LOG_WARNING, $msg); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-08-03 22:46:01 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-24 16:55:49 -04:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-10-23 23:38:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Send a mail message to notify a user that her Twitter bridge link | 
					
						
							|  |  |  |  * has stopped working, and therefore has been removed.  This can | 
					
						
							|  |  |  |  * happen when the user changes her Twitter password, or otherwise | 
					
						
							|  |  |  |  * revokes access. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param User $user   user whose Twitter bridge link has been removed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return boolean success flag | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function mail_twitter_bridge_removed($user) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     common_init_locale($user->language); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $profile = $user->getProfile(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-08 12:17:11 -08:00
										 |  |  |     $subject = sprintf(_m('Your Twitter bridge has been disabled.')); | 
					
						
							| 
									
										
										
										
											2009-10-23 23:38:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     $site_name = common_config('site', 'name'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-08 12:17:11 -08:00
										 |  |  |     $body = sprintf(_m('Hi, %1$s. We\'re sorry to inform you that your ' . | 
					
						
							| 
									
										
										
										
											2009-10-23 23:38:45 +00:00
										 |  |  |         'link to Twitter has been disabled. We no longer seem to have ' . | 
					
						
							|  |  |  |     'permission to update your Twitter status. (Did you revoke ' . | 
					
						
							|  |  |  |     '%3$s\'s access?)' . "\n\n" . | 
					
						
							|  |  |  |     'You can re-enable your Twitter bridge by visiting your ' . | 
					
						
							|  |  |  |     "Twitter settings page:\n\n\t%2\$s\n\n" . | 
					
						
							|  |  |  |         "Regards,\n%3\$s\n"), | 
					
						
							|  |  |  |         $profile->getBestName(), | 
					
						
							|  |  |  |         common_local_url('twittersettings'), | 
					
						
							|  |  |  |         common_config('site', 'name')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     common_init_locale(); | 
					
						
							|  |  |  |     return mail_to_user($user, $subject, $body); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 |