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/g2_import/controllers/g2.php | 7 ++++++- modules/tag/controllers/tag_name.php | 33 +++++++++++++++++++++++++++++++++ modules/tag/models/tag.php | 18 ++++++++++++++++-- 3 files changed, 55 insertions(+), 3 deletions(-) create mode 100644 modules/tag/controllers/tag_name.php (limited to 'modules') diff --git a/modules/g2_import/controllers/g2.php b/modules/g2_import/controllers/g2.php index 6c960893..98eb57f1 100644 --- a/modules/g2_import/controllers/g2.php +++ b/modules/g2_import/controllers/g2.php @@ -34,6 +34,11 @@ class G2_Controller extends Controller { $path = $input->get("path"); $id = $input->get("g2_itemId"); + /* Tags are handled specially, since there's no mapping for them */ + if (($path && 0 === strpos($path, "tag/"))) { + url::redirect("tag_name/" . substr($path, 4)); + } + if (($path && $path != 'index.php' && $path != 'main.php') || $id) { if ($id) { // Requests by id are either core.DownloadItem or core.ShowItem requests. Later versions of @@ -94,4 +99,4 @@ class G2_Controller extends Controller { throw new Kohana_404_Exception(); } } -} \ No newline at end of file +} 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