From b6e17eb139367d8602ec8a96295f03cda42398a1 Mon Sep 17 00:00:00 2001
From: Tim Almdal
Date: Mon, 23 Feb 2009 02:47:29 +0000
Subject: 1) Updated the media feed with new fields 2) Created a comments feed
(/rss/comments) 3) Created a updates feed (/rss/updates)
User interface to follow
---
modules/rss/controllers/rss.php | 99 ++++++++++++++++++++++++++++++++++++++
modules/rss/views/comment.mrss.php | 43 +++++++++++++++++
modules/rss/views/feed.mrss.php | 8 +--
3 files changed, 147 insertions(+), 3 deletions(-)
create mode 100644 modules/rss/views/comment.mrss.php
diff --git a/modules/rss/controllers/rss.php b/modules/rss/controllers/rss.php
index 24ba7249..c550ec68 100644
--- a/modules/rss/controllers/rss.php
+++ b/modules/rss/controllers/rss.php
@@ -64,6 +64,48 @@ class Rss_Controller extends Controller {
print $view;
}
+ public function updates() {
+ $page = $this->input->get("page", 1);
+ if ($page < 1) {
+ url::redirect("rss/updates");
+ }
+
+ $orm = ORM::factory(item)
+ ->viewable()
+ ->where("type !=", "album")
+ ->orderby("created", DESC);
+ $items = $orm
+ ->find_all(self::$page_size, ($page - 1) * self::$page_size);
+ $max_pages = ceil($orm->count_last_query() / self::$page_size);
+
+ if ($page > $max_pages) {
+ url::redirect("rss/updates?page=$max_pages");
+ }
+
+ $view = new View("feed.mrss");
+ $view->title = t("Recent Updates");
+ $view->link = url::abs_site("albums/1");
+ $view->description = $item->description;
+ $view->feed_link = url::abs_site("rss/updates");
+ $view->children = $items;
+
+ if ($page > 1) {
+ $previous_page = $page - 1;
+ $view->previous_page_link = url::site("rss/updates?page={$previous_page}");
+ }
+
+ if ($page < $max_pages) {
+ $next_page = $page + 1;
+ $view->next_page_link = url::site("rss/updates?page={$next_page}");
+ }
+
+ // @todo do we want to add an upload date to the items table?
+ $view->pub_date = date("D, d M Y H:i:s T");
+
+ rest::http_content_type(rest::RSS);
+ print $view;
+ }
+
public function tags($id) {
$tag = ORM::factory("tag", $id);
if (!$tag->loaded) {
@@ -105,4 +147,61 @@ class Rss_Controller extends Controller {
rest::http_content_type(rest::RSS);
print $view;
}
+
+ public function comments($id=null) {
+ $page = $this->input->get("page", 1);
+ if ($page < 1) {
+ url::redirect("rss/comments/$id");
+ }
+
+ $orm = ORM::factory("comment")
+ ->where("state", "published")
+ ->orderby("created", "DESC");
+ if (!empty($id)) {
+ $orm->where("item_id", $id);
+ }
+
+ $comments = $orm->find_all(self::$page_size, ($page - 1) * self::$page_size);
+ $max_pages = ceil($orm->count_last_query() / self::$page_size);
+
+ if ($page > $max_pages) {
+ url::redirect("rss/comments/{$item->id}?page=$max_pages");
+ }
+
+ $view = new View("comment.mrss");
+ $view->title = htmlspecialchars(t("Recent Comments"));
+ $view->link = url::abs_site("albums/1");
+ $view->description = t("Recent Comments");
+ $view->feed_link = url::abs_site("rss/comments");
+ $view->pub_date = date("D, d M Y H:i:s T");
+
+ $view->children = array();
+ foreach ($comments as $comment) {
+ $item = $comment->item();
+ $view->children[] = array(
+ "pub_date" => date("D, d M Y H:i:s T", $comment->created),
+ "text" => htmlspecialchars($comment->text),
+ "thumb_url" => $item->thumb_url(),
+ "thumb_height" => $item->thumb_height,
+ "thumb_width" => $item->thumb_width,
+ "item_link" => htmlspecialchars(url::abs_site("{$item->type}s/$item->id")),
+ "title" =>htmlspecialchars($item->title),
+ "author" =>
+ empty($comment->guest_name) ? $comment->author()->full_name : $comment->guest_name
+ );
+ }
+
+ if ($page > 1) {
+ $previous_page = $page - 1;
+ $view->previous_page_link = url::site("rss/comments/{$item->id}?page={$previous_page}");
+ }
+
+ if ($page < $max_pages) {
+ $next_page = $page + 1;
+ $view->next_page_link = url::site("rss/comments/{$item->id}?page={$next_page}");
+ }
+
+ rest::http_content_type(rest::RSS);
+ print $view;
+ }
}
\ No newline at end of file
diff --git a/modules/rss/views/comment.mrss.php b/modules/rss/views/comment.mrss.php
new file mode 100644
index 00000000..8b7e4f70
--- /dev/null
+++ b/modules/rss/views/comment.mrss.php
@@ -0,0 +1,43 @@
+
+ echo "" ?>
+
+
+ gallery3
+ = $title ?>
+ = $link ?>
+ = htmlspecialchars($description) ?>
+ en-us
+
+
+ if (!empty($previous_page_link)): ?>
+
+ endif ?>
+ if (!empty($next_page_link)): ?>
+
+ endif ?>
+ = $pub_date ?>
+ = $pub_date ?>
+ foreach ($children as $child): ?>
+ -
+ = $child["title"]?>
+ = $child["item_link"] ?>
+ = $child["author"] ?>
+ = $child["item_link"] ?>
+ = $child["pub_date"] ?>
+
+ = $child["text"] ?>
+
+
"
+ height="= $child["thumb_height"] ?>" width="= $child["thumb_width"] ?>" />
+
+
+ ]]>
+
+
+ endforeach ?>
+
+
diff --git a/modules/rss/views/feed.mrss.php b/modules/rss/views/feed.mrss.php
index dbaee532..fbcd415e 100644
--- a/modules/rss/views/feed.mrss.php
+++ b/modules/rss/views/feed.mrss.php
@@ -23,11 +23,12 @@
foreach ($children as $child): ?>
-
= htmlspecialchars($child->title) ?>
- = url::abs_site("photos/$child->id") ?>
- = htmlspecialchars($child->description) ?>
- = url::abs_site("photos/$child->id") ?>
+ = url::abs_site("{$child->type}s/{$child->id}") ?>
+ = url::abs_site("{$child->type}s/{$child->id}") ?>
+ = date("D, d M Y H:i:s T", $child->createdb); ?>
= $child->description ?>
if (access::can("view_full", $child)): ?>