summaryrefslogtreecommitdiff
path: root/modules/rss/controllers
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2009-06-14 21:51:54 -0700
committerBharat Mediratta <bharat@menalto.com>2009-06-14 21:51:54 -0700
commit32ea4406c87049b25d3d82351097e69f13168311 (patch)
tree43c12a5dcf25b3414772b0bfe88fca27318a7ed9 /modules/rss/controllers
parent00fad54c0babfb0643c2ab9da98b4b74af84d466 (diff)
Refactor the way that the rss module works so that we're not allowing
the url to dictate arbitrary static method calls. * Each xxx_rss helper has a single feed() call which takes an id as the argument * xxx_rss::available_feedS() only returns feeds when they're applicable (ie if you're viewing a tag, it won't show you an item feed). * Feed urls are now in the module/feed_id form so that we can bind a feed id to a given module * Tightened up the Rss_Controller by using url::merge and some other tricks. * Made the slideshow module express its own feed.
Diffstat (limited to 'modules/rss/controllers')
-rw-r--r--modules/rss/controllers/rss.php38
1 files changed, 22 insertions, 16 deletions
diff --git a/modules/rss/controllers/rss.php b/modules/rss/controllers/rss.php
index 29300d58..e9dd9fff 100644
--- a/modules/rss/controllers/rss.php
+++ b/modules/rss/controllers/rss.php
@@ -20,37 +20,43 @@
class Rss_Controller extends Controller {
public static $page_size = 20;
- public function feed($method, $id=null) {
+ public function feed($module_id, $feed_id, $id=null) {
$page = $this->input->get("page", 1);
- $feed_uri = "rss/feed/$method" . (empty($id) ? "" : "/$id");
if ($page < 1) {
- url::redirect($feed_uri);
+ url::redirect(url::merge(array("page" => 1)));
}
- $feed = rss::feed_data($method, ($page - 1) * self::$page_size, self::$page_size, $id);
- $max_pages = $feed->max_pages;
- if ($max_pages && $page > $max_pages) {
- url::redirect("$feed_uri?page={$max_pages}");
+ // Run the appropriate feed callback
+ if (module::is_active($module_id)) {
+ $class_name = "{$module_id}_rss";
+ if (method_exists($class_name, "feed")) {
+ $feed = call_user_func(
+ array($class_name, "feed"), $feed_id,
+ ($page - 1) * self::$page_size, self::$page_size, $id);
+ }
+ }
+ if (empty($feed)) {
+ Kohana::show_404();
+ }
+
+ if ($feed->max_pages && $page > $feed->max_pages) {
+ url::redirect(url::merge(array("page" => $feed->max_pages)));
}
$view = new View(empty($feed->view) ? "feed.mrss" : $feed->view);
unset($feed->view);
- $feed->uri = url::abs_site($feed_uri);
$view->feed = $feed;
+ $view->pub_date = date("D, d M Y H:i:s T");
+ $feed->uri = url::abs_site(Router::$current_uri);
if ($page > 1) {
- $previous_page = $page - 1;
- $feed->previous_page_uri = url::site("$feed_uri?page={$previous_page}");
+ $feed->previous_page_uri = url::abs_site(url::merge(array("page" => $page - 1)));
}
-
- if ($page < $max_pages) {
- $next_page = $page + 1;
- $feed->next_page_uri = url::site("$feed_uri?page={$next_page}");
+ if ($page < $feed->max_pages) {
+ $feed->next_page_uri = url::abs_site(url::merge(array("page" => $page + 1)));
}
- $view->pub_date = date("D, d M Y H:i:s T");
-
rest::http_content_type(rest::RSS);
print $view;
}