diff options
Diffstat (limited to 'modules/gallery/controllers')
| -rw-r--r-- | modules/gallery/controllers/admin_theme_options.php | 2 | ||||
| -rw-r--r-- | modules/gallery/controllers/albums.php | 11 | ||||
| -rw-r--r-- | modules/gallery/controllers/file_proxy.php | 2 | ||||
| -rw-r--r-- | modules/gallery/controllers/items.php | 8 | ||||
| -rw-r--r-- | modules/gallery/controllers/movies.php | 7 | ||||
| -rw-r--r-- | modules/gallery/controllers/photos.php | 7 | 
6 files changed, 30 insertions, 7 deletions
| diff --git a/modules/gallery/controllers/admin_theme_options.php b/modules/gallery/controllers/admin_theme_options.php index 27a67bdb..9de54c78 100644 --- a/modules/gallery/controllers/admin_theme_options.php +++ b/modules/gallery/controllers/admin_theme_options.php @@ -58,6 +58,8 @@ class Admin_Theme_Options_Controller extends Admin_Controller {        module::set_var("gallery", "footer_text", $form->edit_theme->footer_text->value);        module::set_var("gallery", "show_credits", $form->edit_theme->show_credits->value); +      module::event("theme_edit_form_completed", $form); +        message::success(t("Updated theme details"));        url::redirect("admin/theme_options");      } else { diff --git a/modules/gallery/controllers/albums.php b/modules/gallery/controllers/albums.php index 32db48d4..76032655 100644 --- a/modules/gallery/controllers/albums.php +++ b/modules/gallery/controllers/albums.php @@ -18,7 +18,16 @@   * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA  02110-1301, USA.   */  class Albums_Controller extends Items_Controller { -  public function _show($album) { +  public function index() { +    $this->show(ORM::factory("item", 1)); +  } + +  public function show($album) { +    if (!is_object($album)) { +      // show() must be public because we route to it in url::parse_url(), so make +      // sure that we're actually receiving an object +      Kohana::show_404(); +    }      $page_size = module::get_var("gallery", "page_size", 9);      if (!access::can("view", $album)) {        if ($album->id == 1) { diff --git a/modules/gallery/controllers/file_proxy.php b/modules/gallery/controllers/file_proxy.php index 53afe0e4..8c46de08 100644 --- a/modules/gallery/controllers/file_proxy.php +++ b/modules/gallery/controllers/file_proxy.php @@ -112,7 +112,7 @@ class File_Proxy_Controller extends Controller {      Session::abort_save();      // Dump out the image.  If the item is a movie, then its thumbnail will be a JPG. -    if (in_array($item->mime_type, array("video/x-flv", "video/mp4"))) { +    if ($item->is_movie() && $type != "albums") {        header("Content-type: image/jpeg");      } else {        header("Content-Type: $item->mime_type"); diff --git a/modules/gallery/controllers/items.php b/modules/gallery/controllers/items.php index 86782469..f261e3a9 100644 --- a/modules/gallery/controllers/items.php +++ b/modules/gallery/controllers/items.php @@ -23,10 +23,12 @@ class Items_Controller extends Controller {      if (!$item->loaded()) {        throw new Kohana_404_Exception();      } +      // Redirect to the more specific resource type, since it will render -    // differently.  We could also just delegate here, but it feels more appropriate -    // to have a single canonical resource mapping. +    // differently.  We can't delegate here because we may have gotten to this +    // page via /items/<id> which means that we don't have a type-specific controller.  Also, we +    // want to drive a single canonical resource mapping where possible.      access::required("view", $item); -    return $this->_show($item); +    url::redirect($item->abs_url());    }  } diff --git a/modules/gallery/controllers/movies.php b/modules/gallery/controllers/movies.php index e017b8c8..6e25e6ea 100644 --- a/modules/gallery/controllers/movies.php +++ b/modules/gallery/controllers/movies.php @@ -18,7 +18,12 @@   * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA  02110-1301, USA.   */  class Movies_Controller extends Items_Controller { -  public function _show($movie) { +  public function show($movie) { +    if (!is_object($movie)) { +      // show() must be public because we route to it in url::parse_url(), so make +      // sure that we're actually receiving an object +      Kohana::show_404(); +    }      access::required("view", $movie);      $where = array(array("type", "!=", "album")); diff --git a/modules/gallery/controllers/photos.php b/modules/gallery/controllers/photos.php index 5431fcfe..f7c5039e 100644 --- a/modules/gallery/controllers/photos.php +++ b/modules/gallery/controllers/photos.php @@ -18,7 +18,12 @@   * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA  02110-1301, USA.   */  class Photos_Controller extends Items_Controller { -  public function _show($photo) { +  public function show($photo) { +    if (!is_object($photo)) { +      // show() must be public because we route to it in url::parse_url(), so make +      // sure that we're actually receiving an object +      Kohana::show_404(); +    }      access::required("view", $photo);      $where = array(array("type", "!=", "album")); | 
