]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/shownotice.php
moving delete profile to its own space.
[quix0rs-gnu-social.git] / actions / shownotice.php
index 2ede559e26e8b67656c6c17061379ca1570a6bf3..b60b6f5a722367c91ee4f65c1a6955bc18d6a9cd 100644 (file)
@@ -23,31 +23,93 @@ require_once(INSTALLDIR.'/lib/stream.php');
 
 class ShownoticeAction extends StreamAction {
 
-       function handle($args) {
-               parent::handle($args);
+       var $notice = NULL;
+       var $profile = NULL;
+       var $avatar = NULL;
+
+       function prepare($args) {
+
+               parent::prepare($args);
+
                $id = $this->arg('notice');
-               $notice = Notice::staticGet($id);
+               $this->notice = Notice::staticGet($id);
 
-               if (!$notice) {
-                       $this->no_such_notice();
+               if (!$this->notice) {
+                       $this->client_error(_('No such notice.'), 404);
+                       return false;
                }
 
-               if (!$notice->getProfile()) {
-                       $this->no_such_notice();
+               $this->profile = $this->notice->getProfile();
+
+               if (!$this->profile) {
+                       $this->server_error(_('Notice has no profile'), 500);
+                       return false;
                }
 
-               # Looks like we're good; show the header
+               $this->avatar = $this->profile->getAvatar(AVATAR_STREAM_SIZE);
+
+               return true;
+       }
+
+       function last_modified() {
+               return max(strtotime($this->notice->created),
+                                  strtotime($this->profile->modified),
+                                  ($this->avatar) ? strtotime($this->avatar->modified) : 0);
+       }
+
+       function etag() {
+               return 'W/"' . implode(':', array($this->arg('action'),
+                                                                                 common_language(),
+                                                                                 $this->notice->id,
+                                                                                 strtotime($this->notice->created),
+                                                                                 strtotime($this->profile->modified),
+                                                                                 ($this->avatar) ? strtotime($this->avatar->modified) : 0)) . '"';
+       }
+
+       function handle($args) {
+
+               parent::handle($args);
 
-               common_show_header($profile->nickname."'s status on ".common_date_string($notice->created));
+               common_show_header(sprintf(_('%1$s\'s status on %2$s'),
+                                                                  $this->profile->nickname,
+                                                                  common_exact_date($this->notice->created)),
+                                                  array($this, 'show_header'), NULL,
+                                                  array($this, 'show_top'));
 
                common_element_start('ul', array('id' => 'notices'));
-               $this->show_notice($notice);
+               $this->show_notice($this->notice);
                common_element_end('ul');
 
                common_show_footer();
        }
 
+       function show_header() {
+
+               $user = User::staticGet($this->profile->id);
+
+               if (!$user) {
+                       return;
+               }
+
+               if ($user->emailmicroid && $user->email && $this->notice->uri) {
+                       common_element('meta', array('name' => 'microid',
+                                                                                'content' => "mailto+http:sha1:" . sha1(sha1('mailto:' . $user->email) . sha1($this->notice->uri))));
+               }
+
+               if ($user->jabbermicroid && $user->jabber && $this->notice->uri) {
+                       common_element('meta', array('name' => 'microid',
+                                                                                'content' => "xmpp+http:sha1:" . sha1(sha1('xmpp:' . $user->jabber) . sha1($this->notice->uri))));
+               }
+       }
+
+       function show_top() {
+               $cur = common_current_user();
+               if ($cur && $cur->id == $this->profile->id) {
+                       common_notice_form();
+               }
+       }
+
        function no_such_notice() {
-               common_user_error('No such notice.');
+               common_user_error(_('No such notice.'));
        }
 }