diff rhodecode/controllers/tags.py @ 547:1e757ac98988

renamed project to rhodecode
author Marcin Kuzminski <marcin@python-works.com>
date Wed, 06 Oct 2010 03:18:16 +0200
parents pylons_app/controllers/tags.py@174785aa5dc4
children 7e536d1af60d
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/rhodecode/controllers/tags.py	Wed Oct 06 03:18:16 2010 +0200
@@ -0,0 +1,47 @@
+#!/usr/bin/env python
+# encoding: utf-8
+# tags controller for pylons
+# Copyright (C) 2009-2010 Marcin Kuzminski <marcin@python-works.com>
+# 
+# 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; version 2
+# of the License or (at your opinion) any later version of the license.
+# 
+# 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.
+"""
+Created on April 21, 2010
+tags controller for pylons
+@author: marcink
+"""
+from pylons import tmpl_context as c
+from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAnyDecorator
+from rhodecode.lib.base import BaseController, render
+from rhodecode.lib.utils import OrderedDict
+from rhodecode.model.hg_model import HgModel
+import logging
+log = logging.getLogger(__name__)
+
+class TagsController(BaseController):
+    
+    @LoginRequired()
+    @HasRepoPermissionAnyDecorator('repository.read', 'repository.write', 'repository.admin')       
+    def __before__(self):
+        super(TagsController, self).__before__()
+        
+    def index(self):
+        hg_model = HgModel()
+        c.repo_info = hg_model.get_repo(c.repo_name)
+        c.repo_tags = OrderedDict()
+        for name, hash_ in c.repo_info.tags.items():
+            c.repo_tags[name] = c.repo_info.get_changeset(hash_)
+        
+        return render('tags/tags.html')