diff options
-rw-r--r-- | core/helpers/MY_url.php | 36 | ||||
-rw-r--r-- | core/models/item.php | 19 | ||||
-rw-r--r-- | modules/media_rss/views/feed.mrss.php | 18 |
3 files changed, 56 insertions, 17 deletions
diff --git a/core/helpers/MY_url.php b/core/helpers/MY_url.php new file mode 100644 index 00000000..b67981ab --- /dev/null +++ b/core/helpers/MY_url.php @@ -0,0 +1,36 @@ +<?php defined("SYSPATH") or die("No direct script access."); +/** + * Gallery - a web based photo album viewer and editor + * Copyright (C) 2000-2008 Bharat Mediratta + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. + */ +<?php +class url extends url_Core { + /** + * Just like url::file() except that it returns an absolute URI + */ + public static function abs_file($path) { + return url::base(false, "http") . $path; + } + + /** + * Just like url::site() except that it returns an absolute URI and + * doesn't take a protocol parameter. + */ + public static function abs_site($path) { + return url::site($path, "http"); + } +}
\ No newline at end of file diff --git a/core/models/item.php b/core/models/item.php index af8a81fa..1c41805f 100644 --- a/core/models/item.php +++ b/core/models/item.php @@ -53,8 +53,9 @@ class Item_Model extends ORM_MPTT { * album: http://example.com/gallery3/var/resizes/album1/ * photo: http://example.com/gallery3/var/albums/album1/photo.jpg */ - public function url($index=false, $protocol=false) { - return $this->_relative_path(url::base($index, $protocol) . "var/albums", "", ""); + public function file_url($full_uri=false) { + $func = $full_uri ? "abs_file" : "file"; + return $this->_relative_path(url::$func("") . "var/albums", "", ""); } /** @@ -73,11 +74,12 @@ class Item_Model extends ORM_MPTT { * album: http://example.com/gallery3/var/resizes/album1/.thumb.jpg * photo: http://example.com/gallery3/var/albums/album1/photo.thumb.jpg */ - public function thumbnail_url($index=false, $protocol=false) { + public function thumbnail_url($full_uri=true) { + $func = $full_uri ? "abs_file" : "file"; if ($this->is_album()) { - return $this->_relative_path(url::base($index, $protocol) . "var/resizes", "", "/.thumb.jpg"); + return $this->_relative_path(url::$func(""), "var/resizes", "", "/.thumb.jpg"); } else { - return $this->_relative_path(url::base($index, $protocol) . "var/resizes", ".thumb", ""); + return $this->_relative_path(url::$func(""), "var/resizes", ".thumb", ""); } } @@ -97,11 +99,12 @@ class Item_Model extends ORM_MPTT { * album: http://example.com/gallery3/var/resizes/album1/.resize.jpg * photo: http://example.com/gallery3/var/albums/album1/photo.resize.jpg */ - public function resize_url($index=false, $protocol=false) { + public function resize_url($full_uri=true) { + $func = $full_uri ? "abs_file" : "file"; if ($this->is_album()) { - return $this->_relative_path(url::base($index, $protocol) . "var/resizes", "", "/.resize.jpg"); + return $this->_relative_path(url::$func("") . "var/resizes", "", "/.resize.jpg"); } else { - return $this->_relative_path(url::base($index, $protocol) . "var/resizes", ".resize", ""); + return $this->_relative_path(url::$func("") . "var/resizes", ".resize", ""); } } diff --git a/modules/media_rss/views/feed.mrss.php b/modules/media_rss/views/feed.mrss.php index 7ddbeff4..8c88b8a2 100644 --- a/modules/media_rss/views/feed.mrss.php +++ b/modules/media_rss/views/feed.mrss.php @@ -4,16 +4,16 @@ xmlns:atom="http://www.w3.org/2005/Atom"> <channel> <title><?= $item->title ?></title> - <link><?= url::site("albums/{$item->id}", "http") ?></link> + <link><?= url::abs_site("albums/{$item->id}") ?></link> <description><?= $item->description ?></description> <language>en-us</language> - <atom:link rel="self" href="<?= url::site("media_rss/feed/{$item->id}") ?>" type="application/rss+xml" /> + <atom:link rel="self" href="<?= url::abs_site("media_rss/feed/{$item->id}") ?>" type="application/rss+xml" /> <? if (isset($prevOffset)): ?> - <atom:link rel="previous" href="<?= url::site("media_rss/feed/{$item->id}?offset={$prevOffset}") ?>" + <atom:link rel="previous" href="<?= url::abs_site("media_rss/feed/{$item->id}?offset={$prevOffset}") ?>" type="application/rss+xml" /> <? endif; ?> <? if (isset($nextOffset)): ?> - <atom:link rel="next" href="<?= url::site("media_rss/feed/{$item->id}?offset={$nextOffset}") ?>" + <atom:link rel="next" href="<?= url::abs_site("media_rss/feed/{$item->id}?offset={$nextOffset}") ?>" type="application/rss+xml" /> <? endif; ?> <? @@ -23,23 +23,23 @@ <pubDate><?= $date ?></pubDate> <lastBuildDate><?= $date ?></lastBuildDate> <? foreach ($children as $child): ?> - <item> + <item> <title><?= $child->title ?></title> - <link><?= url::site("photos/$child->id", "http") ?></link> + <link><?= url::abs_site("photos/$child->id") ?></link> <guid isPermaLink="false"><?= $child->id ?></guid> <description><?= $child->description ?></description> <media:group> - <media:thumbnail url="<?= $child->thumbnail_url(false, "http") ?>" + <media:thumbnail url="<?= $child->thumbnail_url(true) ?>" height="<?= $child->thumbnail_height ?>" width="<?= $child->thumbnail_width ?>" /> - <media:content url="<?= $child->resize_url(false, "http") ?>" + <media:content url="<?= $child->resize_url(true) ?>" type="<?= $child->mime_type ?>" height="<?= $child->resize_height ?>" width="<?= $child->resize_width ?>" isDefault="true" /> - <media:content url="<?= $child->url(false, "http") ?>" + <media:content url="<?= $child->file_url(true) ?>" type="<?= $child->mime_type ?>" height="<?= $child->height ?>" width="<?= $child->width ?>" |