Mercurial > kallithea
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')