diff options
author | Evan Prodromou <evan@prodromou.name> | 2008-05-22 07:29:54 -0400 |
---|---|---|
committer | Evan Prodromou <evan@prodromou.name> | 2008-05-22 07:29:54 -0400 |
commit | 310ef22fd996a21642cc63b33829cc1f397269d7 (patch) | |
tree | bc1f4088703abd351118b614a0f133198f23d549 | |
parent | 5d0bd93eb3e958b41113afdce85643a82a1f5bb3 (diff) |
abstract out RSS 1.0 generation to allow multiple streams
darcs-hash:20080522112954-84dde-aa5087977298f5169148383e82e22241e613b1f2.gz
-rw-r--r-- | actions/showstream.php | 2 | ||||
-rw-r--r-- | actions/userrss.php | 80 | ||||
-rw-r--r-- | doc/TODO | 7 | ||||
-rw-r--r-- | lib/action.php | 12 | ||||
-rw-r--r-- | lib/rssaction.php (renamed from actions/rss10.php) | 130 |
5 files changed, 162 insertions, 69 deletions
diff --git a/actions/showstream.php b/actions/showstream.php index dd849f093..3de9a6e23 100644 --- a/actions/showstream.php +++ b/actions/showstream.php @@ -64,7 +64,7 @@ class ShowstreamAction extends StreamAction { function show_header($user) { common_element('link', array('rel' => 'alternate', - 'href' => common_local_url('rss10', array('nickname' => + 'href' => common_local_url('userrss', array('nickname' => $user->nickname)), 'type' => 'application/rss+xml', 'title' => _t('Notice feed for ') . $user->nickname)); diff --git a/actions/userrss.php b/actions/userrss.php new file mode 100644 index 000000000..92a6bccc9 --- /dev/null +++ b/actions/userrss.php @@ -0,0 +1,80 @@ +<?php +/* + * Laconica - a distributed open-source microblogging tool + * Copyright (C) 2008, Controlez-Vous, 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 + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +if (!defined('LACONICA')) { exit(1); } + +require_once(INSTALLDIR.'/lib/rssaction.php'); + +// Formatting of RSS handled by Rss10Action + +class UserrssAction extends Rss10Action { + + var $user = NULL; + + function init() { + $nickname = $this->trimmed('nickname'); + $this->user = User::staticGet('nickname', $nickname); + + if (!$this->user) { + common_user_error(_t('No such nickname.')); + return false; + } else { + return true; + } + } + + function get_notices($limit=0) { + + $user = $this->user; + $notices = array(); + + $notice = DB_DataObject::factory('notice'); + $notice->profile_id = $user->id; # user id === profile id + $notice->orderBy('created DESC'); + if ($limit != 0) { + $notice->limit(0, $limit); + } + $notice->find(); + + while ($notice->fetch()) { + $notices[] = clone($notice); + } + + return $notices; + } + + function get_channel() { + $user = $this->user; + $profile = $user->getProfile(); + $c = array('url' => common_local_url('userrss', + array('nickname' => + $user->nickname)), + 'title' => $user->nickname, + 'link' => $profile->profileurl, + 'description' => _t('Microblog by ') . $user->nickname); + return $c; + } + + function get_image() { + $user = $this->user; + $profile = $user->getProfile(); + $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE); + return ($avatar) ? $avatar->url : NULL; + } +}
\ No newline at end of file @@ -52,9 +52,10 @@ - FOAF dump for user - license on showstream - license on shownotice +- license in RSS feeds - TOS checkbox on register - instructions -- deal with PHP quotes escaping ++ deal with PHP quotes escaping - fix spacing on notices - fix spacing in profile - limit entry in textarea to 140 chars @@ -64,10 +65,11 @@ - source link in footer menu - public stream link in top menu - AGPL notification +- gettext +- pretty URLs - release 0.2 - Automatically linkify URLs in notices - RDF dump of entire site -- pretty URLs - use only canonical email addresses - license per notice - allow mixed-case usernames @@ -80,7 +82,6 @@ - theme per profile - email confirmation for registration - change cookie handling for anon users to be more cache-friendly -- gettext - subscribe remote - add subscriber remote - send remote notice diff --git a/lib/action.php b/lib/action.php index c346c7513..67eaf9ed7 100644 --- a/lib/action.php +++ b/lib/action.php @@ -46,4 +46,16 @@ class Action { // lawsuit $this->args[$k] = ($strip) ? stripslashes($v) : $v; } } + + function boolean($key, $def=false) { + $arg = $this->arg($key); + return (is_null($arg)) ? $def : + (strcasecmp($arg, 'true')) ? true : + (strcasecmp($arg, 'yes')) ? true : + (strcasecmp($arg, '1')) ? true : + (strcasecmp($arg, 'false')) ? false : + (strcasecmp($arg, 'no')) ? false : + (strcasecmp($arg, '0')) ? false : + $def; + } } diff --git a/actions/rss10.php b/lib/rssaction.php index bae4e8652..9d4066ee5 100644 --- a/actions/rss10.php +++ b/lib/rssaction.php @@ -24,80 +24,61 @@ class Rss10Action extends Action { function handle($args) { parent::handle($args); - $nickname = $this->trimmed('nickname'); - - if (!$nickname) { - common_user_error(_t('No nickname provided.')); - } - - $user = User::staticGet('nickname', $nickname); - - if (!$user) { - common_user_error(_t('No such nickname.')); - } - $limit = (int) $this->trimmed('limit'); - $this->show_rss($user, $limit); + $this->show_rss($limit); } - - function show_rss($user, $limit=0) { - - global $config; - - header('Content-Type: application/rdf+xml'); - common_start_xml(); - common_element_start('rdf:RDF', array('xmlns:rdf' => - 'http://www.w3.org/1999/02/22-rdf-syntax-ns#', - 'xmlns:dc' => - 'http://purl.org/dc/elements/1.1/', - 'xmlns' => 'http://purl.org/rss/1.0/')); + function init() { + return true; + } + + function get_notices() { + return array(); + } - $notices = $this->get_notices($user, $limit); - $this->show_channel($user, $notices); - - foreach ($notices as $n) { - $this->show_item($n); - } - - common_element_end('rdf:RDF'); + function get_channel() { + return array('url' => '', + 'title' => '', + 'link' => '', + 'description' => ''); } - function get_notices($user, $limit=0) { - $notices = array(); + function get_image() { + return NULL; + } + + function show_rss($limit=0) { - $notice = DB_DataObject::factory('notice'); - $notice->profile_id = $user->id; # user id === profile id - $notice->orderBy('created DESC'); - if ($limit != 0) { - $notice->limit(0, $limit); + if (!$this->init()) { + return; } - $notice->find(); - while ($notice->fetch()) { - $notices[] = clone($notice); + $notices = $this->get_notices($limit); + + $this->init_rss(); + $this->show_channel($notices); + $this->show_image(); + + foreach ($notices as $n) { + $this->show_item($n); } - return $notices; + $this->end_rss(); } - - function show_channel($user, $notices) { - - # XXX: this is kind of indirect, eh? - $profile = $user->getProfile(); - $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE); + + function show_channel($notices) { + + $channel = $this->get_channel(); + $image = $this->get_image(); - common_element_start('channel', array('rdf:about' => - common_local_url('rss10', - array('nickname' => - $user->nickname)))); - common_element('title', NULL, $user->nickname); - common_element('link', NULL, $profile->profileurl); - common_element('description', NULL, _t('Microblog by ') . $user->nickname); + common_element_start('channel', array('rdf:about' => $channel['url'])); + common_element('title', NULL, $channel['title']); + common_element('link', NULL, $channel['link']); + common_element('description', NULL, $channel['description']); - if ($avatar) { - common_element('image', array('rdf:resource' => $avatar->url)); + if ($image) { + common_element('image', array('rdf:resource' => $image)); } common_element_start('items'); @@ -111,12 +92,16 @@ class Rss10Action extends Action { common_element_end('rdf:Seq'); common_element_end('items'); common_element_end('channel'); - - if ($avatar) { - common_element_start('image', array('rdf:about' => $avatar->url)); - common_element('title', NULL, $user->nickname); - common_element('link', NULL, $profile->profileurl); - common_element('url', NULL, $avatar->url); + } + + function show_image() { + $image = $this->get_image(); + if ($image) { + $channel = $this->get_channel(); + common_element_start('image', array('rdf:about' => $image)); + common_element('title', NULL, $channel['title']); + common_element('link', NULL, $channel['link']); + common_element('url', NULL, $image); common_element_end('image'); } } @@ -130,4 +115,19 @@ class Rss10Action extends Action { common_element('dc:date', NULL, common_date_w3dtf($notice->created)); common_element_end('item'); } + + function init_rss() { + header('Content-Type: application/rdf+xml'); + + common_start_xml(); + common_element_start('rdf:RDF', array('xmlns:rdf' => + 'http://www.w3.org/1999/02/22-rdf-syntax-ns#', + 'xmlns:dc' => + 'http://purl.org/dc/elements/1.1/', + 'xmlns' => 'http://purl.org/rss/1.0/')); + } + + function end_rss() { + common_element_end('rdf:RDF'); + } }
\ No newline at end of file |