summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvan Prodromou <evan@prodromou.name>2008-05-22 07:29:54 -0400
committerEvan Prodromou <evan@prodromou.name>2008-05-22 07:29:54 -0400
commit310ef22fd996a21642cc63b33829cc1f397269d7 (patch)
treebc1f4088703abd351118b614a0f133198f23d549
parent5d0bd93eb3e958b41113afdce85643a82a1f5bb3 (diff)
abstract out RSS 1.0 generation to allow multiple streams
darcs-hash:20080522112954-84dde-aa5087977298f5169148383e82e22241e613b1f2.gz
-rw-r--r--actions/showstream.php2
-rw-r--r--actions/userrss.php80
-rw-r--r--doc/TODO7
-rw-r--r--lib/action.php12
-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
diff --git a/doc/TODO b/doc/TODO
index d6d0309f7..146a364c4 100644
--- a/doc/TODO
+++ b/doc/TODO
@@ -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