X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fshownotice.php;h=b60b6f5a722367c91ee4f65c1a6955bc18d6a9cd;hb=2abe10b8ea4b5d69fc7f6513bf465541454ca2cf;hp=4bf4238cd44ecd9f8d1e9aa2458861aa1800811a;hpb=9d9588a3deefbd908210ea3b47575e6d1e70939d;p=quix0rs-gnu-social.git diff --git a/actions/shownotice.php b/actions/shownotice.php index 4bf4238cd4..b60b6f5a72 100644 --- a/actions/shownotice.php +++ b/actions/shownotice.php @@ -19,60 +19,97 @@ if (!defined('LACONICA')) { exit(1); } -class ShownoticeAction extends Action { +require_once(INSTALLDIR.'/lib/stream.php'); + +class ShownoticeAction extends StreamAction { + + var $notice = NULL; + var $profile = NULL; + var $avatar = NULL; + + function prepare($args) { + + parent::prepare($args); - function handle($args) { - parent::handle($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." status on ".$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')); - $this->show_notice($notice); + common_element_start('ul', array('id' => 'notices')); + $this->show_notice($this->notice); + common_element_end('ul'); common_show_footer(); } - function no_such_notice() { - common_user_error('No such notice.'); + 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_notice($notice) { - $profile = $notice->getProfile(); - # XXX: RDFa - common_element_start('div', array('class' => 'notice greenBg')); - $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE); - if ($avatar) { - common_element('img', array('src' => $avatar->url, - 'class' => 'avatar profile', - 'width' => AVATAR_PROFILE_SIZE, - 'height' => AVATAR_PROFILE_SIZE, - 'alt' => - ($profile->fullname) ? $profile->fullname : - $profile->nickname)); + function show_top() { + $cur = common_current_user(); + if ($cur && $cur->id == $this->profile->id) { + common_notice_form(); } - common_element('a', array('href' => $profile->profileurl, - 'class' => 'nickname', - 'title' => - ($profile->fullname) ? $profile->fullname : - $profile->nickname), - $profile->nickname); - # FIXME: URL, image, video, audio - common_element_start('span', array('class' => 'content')); - common_raw(common_render_content($notice->content, $notice)); - common_element_end('span'); - common_element('span', array('class' => 'date'), - common_date_string($notice->created)); - common_element_end('div'); + } + + function no_such_notice() { + common_user_error(_('No such notice.')); } }