X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fshownotice.php;h=f9531b3c40378bf27cd4e5fc13c4896a0f1381f4;hb=4272da4e9e2ab9c99b4b9897f04c92cd7987cb8b;hp=2ede559e26e8b67656c6c17061379ca1570a6bf3;hpb=10654ebf3572f07b178b2cc7e017b04e6f9e3084;p=quix0rs-gnu-social.git diff --git a/actions/shownotice.php b/actions/shownotice.php index 2ede559e26..f9531b3c40 100644 --- a/actions/shownotice.php +++ b/actions/shownotice.php @@ -29,16 +29,22 @@ class ShownoticeAction extends StreamAction { $notice = Notice::staticGet($id); if (!$notice) { - $this->no_such_notice(); + $this->client_error(_('No such notice.'), 404); + return; } - if (!$notice->getProfile()) { - $this->no_such_notice(); + $profile = $notice->getProfile(); + + if (!$profile) { + $this->server_error(_('Notice has no profile'), 500); + return; } # Looks like we're good; show the header - common_show_header($profile->nickname."'s status on ".common_date_string($notice->created)); + common_show_header(sprintf(_('%1$s\'s status on %2$s'), $profile->nickname, common_exact_date($notice->created)), + array($this, 'show_header'), $notice, + array($this, 'show_top')); common_element_start('ul', array('id' => 'notices')); $this->show_notice($notice); @@ -47,7 +53,33 @@ class ShownoticeAction extends StreamAction { common_show_footer(); } + function show_header($notice) + { + $profile = $notice->getProfile(); + $user = User::staticGet($profile->id); + if (!$user) { + return; + } + if ($user->emailmicroid && $user->email && $notice->uri) { + common_element('meta', array('name' => 'microid', + 'content' => "mailto+http:sha1:" . sha1(sha1('mailto:' . $user->email) . sha1($notice->uri)))); + } + if ($user->jabbermicroid && $user->jabber && $notice->uri) { + common_element('meta', array('name' => 'microid', + 'content' => "xmpp+http:sha1:" . sha1(sha1('xmpp:' . $user->jabber) . sha1($notice->uri)))); + } + } + + function show_top($notice) { + $user = $notice->getProfile(); + $cur = common_current_user(); + + if ($cur && $cur->id == $user->id) { + common_notice_form(); + } + } + function no_such_notice() { - common_user_error('No such notice.'); + common_user_error(_('No such notice.')); } }