From f92982c59c0db3d86a6a05231c720a39bbbb3d2d Mon Sep 17 00:00:00 2001 From: Mike Miller Date: Wed, 9 Jan 2013 06:42:32 +0200 Subject: Tags by name (includes a G2 mapping) --- modules/tag/controllers/tag_name.php | 33 +++++++++++++++++++++++++++++++++ modules/tag/models/tag.php | 18 ++++++++++++++++-- 2 files changed, 49 insertions(+), 2 deletions(-) create mode 100644 modules/tag/controllers/tag_name.php (limited to 'modules/tag') diff --git a/modules/tag/controllers/tag_name.php b/modules/tag/controllers/tag_name.php new file mode 100644 index 00000000..1a1179fe --- /dev/null +++ b/modules/tag/controllers/tag_name.php @@ -0,0 +1,33 @@ +where("name", "=", $tag_name)->find(); + if (!$tag->loaded()) { + // No matching tag was found. If this was an imported tag, this is probably a bug. + // If the user typed the URL manually, it might just be wrong + throw new Kohana_404_Exception(); + } + + url::redirect($tag->abs_url()); + } + +} diff --git a/modules/tag/models/tag.php b/modules/tag/models/tag.php index 298e4647..213ea0df 100644 --- a/modules/tag/models/tag.php +++ b/modules/tag/models/tag.php @@ -141,7 +141,7 @@ class Tag_Model_Core extends ORM { /** * Return the server-relative url to this item, eg: - * /gallery3/index.php/tags/35 + * /gallery3/index.php/tags/35/Bob * * @param string $query the query string (eg "page=3") */ @@ -152,4 +152,18 @@ class Tag_Model_Core extends ORM { } return $url; } -} \ No newline at end of file + + /** + * Return the full url to this item, eg: + * http://example.com/gallery3/index.php/tags/35/Bob + * + * @param string $query the query string (eg "page=3") + */ + public function abs_url($query=null) { + $url = url::abs_site("tag/{$this->id}/" . urlencode($this->name)); + if ($query) { + $url .= "?$query"; + } + return $url; + } +} -- cgit v1.2.3