diff options
author | Bharat Mediratta <bharat@menalto.com> | 2009-06-14 21:51:54 -0700 |
---|---|---|
committer | Bharat Mediratta <bharat@menalto.com> | 2009-06-14 21:51:54 -0700 |
commit | 32ea4406c87049b25d3d82351097e69f13168311 (patch) | |
tree | 43c12a5dcf25b3414772b0bfe88fca27318a7ed9 /modules/rss/controllers/rss.php | |
parent | 00fad54c0babfb0643c2ab9da98b4b74af84d466 (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/rss.php')
-rw-r--r-- | modules/rss/controllers/rss.php | 38 |
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; } |