Mercurial > kallithea
diff rhodecode/controllers/forks.py @ 1301:7e75af301842 beta
Added simple forks page, resolves issue #179
author | Marcin Kuzminski <marcin@python-works.com> |
---|---|
date | Mon, 02 May 2011 13:02:58 +0200 |
parents | |
children | f9559677c953 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/rhodecode/controllers/forks.py Mon May 02 13:02:58 2011 +0200 @@ -0,0 +1,56 @@ +# -*- coding: utf-8 -*- +""" + rhodecode.controllers.forks + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + + forks controller for rhodecode + + :created_on: Apr 23, 2011 + :author: marcink + :copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com> + :license: GPLv3, see COPYING for more details. +""" +# 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 3 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, see <http://www.gnu.org/licenses/>. +import logging + +from pylons import tmpl_context as c, request + +from rhodecode.lib.helpers import Page +from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAnyDecorator +from rhodecode.lib.base import BaseRepoController, render +from rhodecode.model.db import Repository, User, UserFollowing + +log = logging.getLogger(__name__) + + +class ForksController(BaseRepoController): + + @LoginRequired() + @HasRepoPermissionAnyDecorator('repository.read', 'repository.write', + 'repository.admin') + def __before__(self): + super(ForksController, self).__before__() + + def forks(self, repo_name): + p = int(request.params.get('page', 1)) + repo_id = Repository.by_repo_name(repo_name).repo_id + d = Repository.get_repo_forks(repo_id) + c.forks_pager = Page(d, page=p, items_per_page=20) + + c.forks_data = render('/forks/forks_data.html') + + if request.params.get('partial'): + return c.forks_data + + return render('/forks/forks.html')