diff options
Diffstat (limited to 'modules/rss/controllers')
-rw-r--r-- | modules/rss/controllers/rss.php | 49 |
1 files changed, 26 insertions, 23 deletions
diff --git a/modules/rss/controllers/rss.php b/modules/rss/controllers/rss.php index 80803dfd..e9dd9fff 100644 --- a/modules/rss/controllers/rss.php +++ b/modules/rss/controllers/rss.php @@ -18,42 +18,45 @@ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. */ class Rss_Controller extends Controller { - public static $page_size = 30; + 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); + } } - unset($feed["max_pages"]); - - $view = new View(empty($feed["view"]) ? "feed.mrss" : $feed["view"]); - unset($feed["view"]); - - foreach ($feed as $field => $value) { - $view->$field = $value; + if (empty($feed)) { + Kohana::show_404(); } - $view->feed_link = url::abs_site($feed_uri); - if ($page > 1) { - $previous_page = $page - 1; - $view->previous_page_link = url::site("$feed_uri?page={$previous_page}"); + if ($feed->max_pages && $page > $feed->max_pages) { + url::redirect(url::merge(array("page" => $feed->max_pages))); } - if ($page < $max_pages) { - $next_page = $page + 1; - $view->next_page_link = url::site("$feed_uri?page={$next_page}"); - } + $view = new View(empty($feed->view) ? "feed.mrss" : $feed->view); + unset($feed->view); + $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) { + $feed->previous_page_uri = url::abs_site(url::merge(array("page" => $page - 1))); + } + if ($page < $feed->max_pages) { + $feed->next_page_uri = url::abs_site(url::merge(array("page" => $page + 1))); + } + rest::http_content_type(rest::RSS); print $view; } |