From 8b2c05afc0a9f8ad7490fd46bb1c8249d03c2fb8 Mon Sep 17 00:00:00 2001 From: Tim Almdal Date: Thu, 19 Feb 2009 15:24:17 +0000 Subject: 1) Rename the module media_rss to rss 2) Protect the fullsize image with a permission check 3) Added a content:encoded element to each item which allows the image to show up in the body of the feed. --- modules/rss/controllers/rss.php | 108 ++++++++++++++++++++++++++++++++++ modules/rss/helpers/rss.php | 30 ++++++++++ modules/rss/helpers/rss_installer.php | 33 +++++++++++ modules/rss/helpers/rss_theme.php | 32 ++++++++++ modules/rss/module.info | 3 + modules/rss/views/feed.mrss.php | 68 +++++++++++++++++++++ 6 files changed, 274 insertions(+) create mode 100644 modules/rss/controllers/rss.php create mode 100644 modules/rss/helpers/rss.php create mode 100644 modules/rss/helpers/rss_installer.php create mode 100644 modules/rss/helpers/rss_theme.php create mode 100644 modules/rss/module.info create mode 100644 modules/rss/views/feed.mrss.php (limited to 'modules/rss') diff --git a/modules/rss/controllers/rss.php b/modules/rss/controllers/rss.php new file mode 100644 index 00000000..24ba7249 --- /dev/null +++ b/modules/rss/controllers/rss.php @@ -0,0 +1,108 @@ +input->get("page", 1); + if ($page < 1) { + url::redirect("rss/albums/{$item->id}"); + } + + $children = $item + ->viewable() + ->descendants(self::$page_size, ($page - 1) * self::$page_size, "photo"); + $max_pages = ceil($item->viewable()->descendants_count("photo") / self::$page_size); + + if ($page > $max_pages) { + url::redirect("rss/albums/{$item->id}?page=$max_pages"); + } + + $view = new View("feed.mrss"); + $view->title = $item->title; + $view->link = url::abs_site("albums/{$item->id}"); + $view->description = $item->description; + $view->feed_link = url::abs_site("rss/albums/{$item->id}"); + $view->children = $children; + + if ($page > 1) { + $previous_page = $page - 1; + $view->previous_page_link = url::site("rss/albums/{$item->id}?page={$previous_page}"); + } + + if ($page < $max_pages) { + $next_page = $page + 1; + $view->next_page_link = url::site("rss/albums/{$item->id}?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) { + return Kohana::show_404(); + } + + $page = $this->input->get("page", 1); + if ($page < 1) { + url::redirect("rss/tags/{$tag->id}"); + } + + $children = $tag->items(self::$page_size, ($page - 1) * self::$page_size, "photo"); + $max_pages = ceil($tag->count / self::$page_size); + + if ($page > $max_pages) { + url::redirect("rss/tags/{$tag->id}?page=$max_pages"); + } + + $view = new View("feed.mrss"); + $view->title = $tag->name; + $view->link = url::abs_site("tags/{$tag->id}"); + $view->description = t("Photos related to %tag_name", array("tag_name" => $tag->name)); + $view->feed_link = url::abs_site("rss/tags/{$tag->id}"); + $view->children = $children; + + if ($page > 1) { + $previous_page = $page - 1; + $view->previous_page_link = url::site("rss/tags/{$tag->id}?page={$previous_page}"); + } + + if ($page < $max_pages) { + $next_page = $page + 1; + $view->next_page_link = url::site("rss/tags/{$tag->id}?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; + } +} \ No newline at end of file diff --git a/modules/rss/helpers/rss.php b/modules/rss/helpers/rss.php new file mode 100644 index 00000000..728c2847 --- /dev/null +++ b/modules/rss/helpers/rss.php @@ -0,0 +1,30 @@ +is_album() ? $item->id : $item->parent_id; + return url::site("rss/albums/$id"); + } + + static function tag_feed($tag) { + return url::site("rss/tags/$tag->id}"); + } +} \ No newline at end of file diff --git a/modules/rss/helpers/rss_installer.php b/modules/rss/helpers/rss_installer.php new file mode 100644 index 00000000..aabd5664 --- /dev/null +++ b/modules/rss/helpers/rss_installer.php @@ -0,0 +1,33 @@ +item()) { + $url = rss::item_feed($theme->item()); + } else if ($theme->tag()) { + $url = rss::tag_feed($theme->tag()); + } + + if (!empty($url)) { + return ""; + } + } +} diff --git a/modules/rss/module.info b/modules/rss/module.info new file mode 100644 index 00000000..ffd26192 --- /dev/null +++ b/modules/rss/module.info @@ -0,0 +1,3 @@ +name = RSS +description = Provide a RSS feeds +version = 1 diff --git a/modules/rss/views/feed.mrss.php b/modules/rss/views/feed.mrss.php new file mode 100644 index 00000000..6015f471 --- /dev/null +++ b/modules/rss/views/feed.mrss.php @@ -0,0 +1,68 @@ + +" ?> + + + gallery3 + <?= htmlspecialchars($title) ?> + + + en-us + + + + + + + + -- cgit v1.2.3