]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/userrss.php
Fix invite button for public sites
[quix0rs-gnu-social.git] / actions / userrss.php
index c758a44e2ab6c46cf29a68194c77b4104a239a6e..85ea2fd7fa4213722084a5eb904abf29a2225025 100644 (file)
@@ -1,7 +1,7 @@
 <?php
 /*
- * Laconica - a distributed open-source microblogging tool
- * Copyright (C) 2008, Controlez-Vous, Inc.
+ * StatusNet - the distributed open-source microblogging tool
+ * Copyright (C) 2008, 2009, StatusNet, Inc.
  *
  * 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
  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 
-if (!defined('LACONICA')) { exit(1); }
+if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); }
 
 require_once(INSTALLDIR.'/lib/rssaction.php');
 
 // Formatting of RSS handled by Rss10Action
 
-class UserrssAction extends Rss10Action {
+class UserrssAction extends Rss10Action
+{
+    var $tag  = null;
 
-    var $user = null;
-
-    function init()
+    function prepare($args)
     {
-        $nickname = $this->trimmed('nickname');
+        common_debug("UserrssAction");
+
+        parent::prepare($args);
+        $nickname   = $this->trimmed('nickname');
         $this->user = User::staticGet('nickname', $nickname);
+        $this->tag  = $this->trimmed('tag');
 
         if (!$this->user) {
-            common_user_error(_('No such user.'));
+            // TRANS: Client error displayed when user not found for an action.
+            $this->clientError(_('No such user.'));
             return false;
         } else {
+            if (!empty($this->tag)) {
+                $this->notices = $this->getTaggedNotices();
+            } else {
+                $this->notices = $this->getNotices();
+            }
             return true;
         }
     }
 
-    function get_notices($limit=0)
+    function getTaggedNotices()
     {
+        $notice = $this->user->getTaggedNotices(
+            $this->tag,
+            0,
+            ($this->limit == 0) ? NOTICES_PER_PAGE : $this->limit,
+            0,
+            0
+        );
 
-        $user = $this->user;
-        
-        if (is_null($user)) {
-            return null;
+        $notices = array();
+        while ($notice->fetch()) {
+            $notices[] = clone($notice);
         }
-        
-        $notice = $user->getNotices(0, ($limit == 0) ? NOTICES_PER_PAGE : $limit);
-        
+
+        return $notices;
+    }
+
+
+    function getNotices()
+    {
+        $notice = $this->user->getNotices(
+            0,
+            ($this->limit == 0) ? NOTICES_PER_PAGE : $this->limit
+        );
+
+        $notices = array();
         while ($notice->fetch()) {
             $notices[] = clone($notice);
         }
@@ -58,38 +84,47 @@ class UserrssAction extends Rss10Action {
         return $notices;
     }
 
-    function get_channel()
+    function getChannel()
     {
         $user = $this->user;
         $profile = $user->getProfile();
         $c = array('url' => common_local_url('userrss',
                                              array('nickname' =>
                                                    $user->nickname)),
-                   'title' => $user->nickname,
+                   // TRANS: Message is used as link title. %s is a user nickname.
+                   'title' => sprintf(_('%s timeline'), $user->nickname),
                    'link' => $profile->profileurl,
-                   'description' => sprintf(_('Microblog by %s'), $user->nickname));
+                   // TRANS: Message is used as link description. %1$s is a username, %2$s is a site name.
+                   'description' => sprintf(_('Updates from %1$s on %2$s!'),
+                                            $user->nickname, common_config('site', 'name')));
         return $c;
     }
 
-    function get_image()
+    function getImage()
     {
         $user = $this->user;
         $profile = $user->getProfile();
         if (!$profile) {
             common_log_db_error($user, 'SELECT', __FILE__);
-            $this->server_error(_('User without matching profile'));
+            // TRANS: Error message displayed when referring to a user without a profile.
+            $this->serverError(_('User has no profile.'));
             return null;
         }
         $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE);
         return ($avatar) ? $avatar->url : null;
     }
 
-    # override parent to add X-SUP-ID URL
-    
-    function init_rss($limit=0)
+    // override parent to add X-SUP-ID URL
+
+    function initRss($limit=0)
     {
-        $url = common_local_url('sup', null, $this->user->id);
+        $url = common_local_url('sup', null, null, $this->user->id);
         header('X-SUP-ID: '.$url);
-        parent::init_rss($limit);
+        parent::initRss($limit);
+    }
+
+    function isReadOnly($args)
+    {
+        return true;
     }
-}
\ No newline at end of file
+}