| 
									
										
										
										
											2008-11-18 20:11:28 -05:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  |  * Laconica - a distributed open-source microblogging tool | 
					
						
							| 
									
										
										
										
											2009-06-20 16:12:55 -07:00
										 |  |  |  * Copyright (C) 2008, 2009, Control Yourself, 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-06 07:03:05 +00:00
										 |  |  | if (!defined('LACONICA')) { | 
					
						
							|  |  |  |     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
										 |  |  | 
 | 
					
						
							|  |  |  | function update_twitter_user($twitter_id, $screen_name) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     $uri = 'http://twitter.com/' . $screen_name; | 
					
						
							|  |  |  |     $fuser = new Foreign_user(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $fuser->query('BEGIN'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00: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-04-07 18:29:10 -07:00
										 |  |  |             $result = update_twitter_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-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-03 22:46:01 +00:00
										 |  |  |         $user = $flink->getUser(); | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // XXX: Hack to get around PHP cURL's use of @ being a a meta character
 | 
					
						
							|  |  |  |         $statustxt = preg_replace('/^@/', ' @', $notice->content); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-10 07:00:59 +00:00
										 |  |  |         $token = TwitterOAuthClient::unpackToken($flink->credentials); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $client = new TwitterOAuthClient($token->key, $token->secret); | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-03 22:46:01 +00:00
										 |  |  |         $status = null; | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-03 22:46:01 +00:00
										 |  |  |         try { | 
					
						
							| 
									
										
										
										
											2009-08-10 06:05:43 +00:00
										 |  |  |             $status = $client->statusesUpdate($statustxt); | 
					
						
							| 
									
										
										
										
											2009-08-03 22:46:01 +00:00
										 |  |  |         } catch (OAuthClientCurlException $e) { | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |             if ($e->getMessage() == 'The requested URL returned error: 401') { | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                 $errmsg = sprintf('User %1$s (user id: %2$s) has an invalid ' . | 
					
						
							|  |  |  |                                   'Twitter OAuth access token.', | 
					
						
							|  |  |  |                                   $user->nickname, $user->id); | 
					
						
							|  |  |  |                 common_log(LOG_WARNING, $errmsg); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                 // Bad auth token! We need to delete the foreign_link
 | 
					
						
							|  |  |  |                 // to Twitter and inform the user.
 | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                 remove_twitter_link($flink); | 
					
						
							|  |  |  |                 return true; | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |             } else { | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                 // Some other error happened, so we should probably
 | 
					
						
							|  |  |  |                 // try to send again later.
 | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                 $errmsg = sprintf('cURL error trying to send notice to Twitter ' . | 
					
						
							|  |  |  |                                   'for user %1$s (user id: %2$s) - ' . | 
					
						
							|  |  |  |                                   'code: %3$s message: $4$s.', | 
					
						
							|  |  |  |                                   $user->nickname, $user->id, | 
					
						
							|  |  |  |                                   $e->getCode(), $e->getMessage()); | 
					
						
							|  |  |  |                 common_log(LOG_WARNING, $errmsg); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |                 return false; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |         if (empty($status)) { | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +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-08-06 07:03:05 +00:00
										 |  |  |             $errmsg = sprint('No data returned by Twitter API when ' . | 
					
						
							|  |  |  |                              'trying to send update for %1$s (user id %2$s).', | 
					
						
							|  |  |  |                              $user->nickname, $user->id); | 
					
						
							|  |  |  |             common_log(LOG_WARNING, $errmsg); | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |         // Notice crossed the great divide
 | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-06 07:03:05 +00:00
										 |  |  |         $msg = sprintf('Twitter bridge posted notice %s to Twitter.', | 
					
						
							|  |  |  |                        $notice->id); | 
					
						
							|  |  |  |         common_log(LOG_INFO, $msg); | 
					
						
							| 
									
										
										
										
											2009-02-11 17:46:53 -08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-02-26 13:36:38 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-09 00:40:12 +00:00
										 |  |  |     return true; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function remove_twitter_link($flink) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     $user = $flink->getUser(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     common_log(LOG_INFO, 'Removing Twitter bridge Foreign link for ' . | 
					
						
							|  |  |  |         "user $user->nickname (user id: $user->id)."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     $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
										 |  |  | } |