X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fshownotice.php;h=b60b6f5a722367c91ee4f65c1a6955bc18d6a9cd;hb=2c7518873eddafcd041fe73a509756155f35ac9a;hp=4d4876122c0195c0093706f70c2f469f741c149b;hpb=f0a30cc89ddf82e3c774800d24f0ea3664065d9c;p=quix0rs-gnu-social.git diff --git a/actions/shownotice.php b/actions/shownotice.php index 4d4876122c..b60b6f5a72 100644 --- a/actions/shownotice.php +++ b/actions/shownotice.php @@ -1,45 +1,115 @@ . + */ -class ShownoticeAction extends Action { +if (!defined('LACONICA')) { exit(1); } + +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 - - common_show_header($profile->nickname); - - $this->show_notice($notice); - + + $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(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($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_start_element('div', array('class' => 'notice')); - # FIXME: add the avatar - common_start_element('a', array('href' => $profile->profileurl, - 'class' => 'nickname'), - $profile->nickname); - # FIXME: URL, image, video, audio - common_element('span', array('class' => 'content'), $notice->content); - common_element('span', array('class' => 'date'), - common_date_string($notice->created)); - common_end_element('div'); + + 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.')); } }