summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--core/helpers/MY_url.php36
-rw-r--r--core/models/item.php19
-rw-r--r--modules/media_rss/views/feed.mrss.php18
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 ?>"