| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * StatusNet, the distributed open-source microblogging tool | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Show the friends timeline | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * LICENCE: 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/>. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category  Personal | 
					
						
							|  |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Zach Copley <zach@status.net> | 
					
						
							|  |  |  |  * @copyright 2009 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!defined('STATUSNET')) { | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  | require_once INSTALLDIR.'/lib/apibareauth.php'; | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  | class ApiFriendsTimelineAction extends ApiBareAuthAction | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |     var $user    = null; | 
					
						
							|  |  |  |     var $notices = null; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Take arguments for running | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $args $_REQUEST args | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean success flag | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function prepare($args) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::prepare($args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         $this->page     = (int)$this->arg('page', 1); | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |         $this->count    = (int)$this->arg('count', 20); | 
					
						
							|  |  |  |         $this->max_id   = (int)$this->arg('max_id', 0); | 
					
						
							|  |  |  |         $this->since_id = (int)$this->arg('since_id', 0); | 
					
						
							|  |  |  |         $this->since    = $this->arg('since'); | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         if ($this->requiresAuth()) { | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |             if ($this->checkBasicAuthUser() == false) { | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         $this->user = $this->getTargetUser($this->arg('id')); | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         if (empty($this->user)) { | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |             $this->clientError(_('No such user!'), 404, $this->arg('format')); | 
					
						
							|  |  |  |             return; | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         $this->notices = $this->getNotices(); | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 14:11:12 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Handle the request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Just show the notices | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $args $_REQUEST data (unused) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |     function handle($args) { | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         parent::handle($args); | 
					
						
							|  |  |  |         $this->showTimeline(); | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 14:11:12 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Show the timeline of notices | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return void | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |     function showTimeline() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $profile    = $this->user->getProfile(); | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |         $sitename   = common_config('site', 'name'); | 
					
						
							|  |  |  |         $title      = sprintf(_("%s and friends"), $user->nickname); | 
					
						
							|  |  |  |         $taguribase = common_config('integration', 'taguri'); | 
					
						
							|  |  |  |         $id         = "tag:$taguribase:FriendsTimeline:" . $user->id; | 
					
						
							|  |  |  |         $link       = common_local_url('all', | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |                                        array('nickname' => $user->nickname)); | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |         $subtitle   = sprintf(_('Updates from %1$s and friends on %2$s!'), | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |                               $user->nickname, $sitename); | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         switch($this->arg('format')) { | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |             case 'xml': | 
					
						
							|  |  |  |                 $this->show_xml_timeline($this->notices); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case 'rss': | 
					
						
							|  |  |  |                 $this->show_rss_timeline($this->notices, $title, $link, $subtitle); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case 'atom': | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 $target_id = $this->arg('id'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if (isset($target_id)) { | 
					
						
							|  |  |  |                     $selfuri = common_root_url() . | 
					
						
							|  |  |  |                         'api/statuses/friends_timeline/' . | 
					
						
							|  |  |  |                         $target_id . '.atom'; | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                     $selfuri = common_root_url() . | 
					
						
							|  |  |  |                         'api/statuses/friends_timeline.atom'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 $this->show_atom_timeline($this->notices, $title, $id, $link, | 
					
						
							|  |  |  |                                           $subtitle, null, $selfuri); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             case 'json': | 
					
						
							|  |  |  |                 $this->show_json_timeline($this->notices); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |                 $this->clientError(_('API method not found!'), $code = 404); | 
					
						
							|  |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 14:11:12 -07:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get notices | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array notices | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |     function getNotices() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         $notices = array(); | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($this->auth_user) && $this->auth_user->id == $this->user->id) { | 
					
						
							|  |  |  |             $notice = $this->user->noticeInbox(($this->page-1) * $this->count, | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |                                                $this->count, $this->since_id, | 
					
						
							|  |  |  |                                                $this->max_id, $this->since); | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |         } else { | 
					
						
							|  |  |  |             $notice = $this->user->noticesWithFriends(($this->page-1) * $this->count, | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |                                                       $this->count, $this->since_id, | 
					
						
							|  |  |  |                                                       $this->max_id, $this->since); | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         while ($notice->fetch()) { | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |             $notices[] = clone($notice); | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-25 16:58:35 -07:00
										 |  |  |         return $notices; | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Is this page read-only? | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return boolean true | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function isReadOnly($args) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |      * When was this feed last modified? | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function lastModified() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-09-27 14:11:12 -07:00
										 |  |  |         if (!empty($this->notices) && (count($this->notices) > 0)) { | 
					
						
							|  |  |  |             return strtotime($this->notices[0]->created); | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 14:11:12 -07:00
										 |  |  |         return null; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * An entity tag for this page | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Returns an Etag based on the action name, language, user ID, and | 
					
						
							|  |  |  |      * timestamps of the first and last notice in the timeline | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string etag | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function etag() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!empty($this->notices) && (count($this->notices) > 0)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $last = count($this->notices) - 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return implode(':', | 
					
						
							|  |  |  |                 array($this->arg('action'), | 
					
						
							|  |  |  |                       common_language(), | 
					
						
							|  |  |  |                       $this->user->id, | 
					
						
							|  |  |  |                       strtotime($this->notices[0]->created), | 
					
						
							|  |  |  |                       strtotime($this->notices[$last]->created))) . '"'; | 
					
						
							| 
									
										
										
										
											2009-09-24 18:13:46 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 14:11:12 -07:00
										 |  |  |         return null; | 
					
						
							| 
									
										
										
										
											2009-09-23 13:45:51 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-27 14:11:12 -07:00
										 |  |  | } |