summary.py
171 lines
| 6.0 KiB
| text/x-python
|
PythonLexer
r763 | # -*- coding: utf-8 -*- | |||
""" | ||||
r860 | rhodecode.controllers.summary | |||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
r763 | ||||
Summary controller for Rhodecode | ||||
r820 | ||||
r763 | :created_on: Apr 18, 2010 | |||
:author: marcink | ||||
r902 | :copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com> | |||
r763 | :license: GPLv3, see COPYING for more details. | |||
""" | ||||
r547 | # 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. | ||||
r763 | ||||
r810 | import calendar | |||
import logging | ||||
from time import mktime | ||||
r937 | from datetime import datetime, timedelta, date | |||
r810 | ||||
from vcs.exceptions import ChangesetError | ||||
r547 | from pylons import tmpl_context as c, request, url | |||
r810 | from pylons.i18n.translation import _ | |||
from rhodecode.model.scm import ScmModel | ||||
from rhodecode.model.db import Statistics | ||||
r547 | from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAnyDecorator | |||
from rhodecode.lib.base import BaseController, render | ||||
r643 | from rhodecode.lib.utils import OrderedDict, EmptyChangeset | |||
r810 | ||||
r547 | from rhodecode.lib.celerylib import run_task | |||
from rhodecode.lib.celerylib.tasks import get_commits_stats | ||||
r810 | ||||
from webhelpers.paginate import Page | ||||
r592 | try: | |||
import json | ||||
except ImportError: | ||||
#python 2.5 compatibility | ||||
import simplejson as json | ||||
r547 | log = logging.getLogger(__name__) | |||
class SummaryController(BaseController): | ||||
r637 | ||||
r547 | @LoginRequired() | |||
@HasRepoPermissionAnyDecorator('repository.read', 'repository.write', | ||||
r637 | 'repository.admin') | |||
r547 | def __before__(self): | |||
super(SummaryController, self).__before__() | ||||
r637 | ||||
r547 | def index(self): | |||
r734 | scm_model = ScmModel() | |||
r1038 | c.repo, dbrepo = scm_model.get(c.repo_name) | |||
c.dbrepo = dbrepo | ||||
r734 | c.following = scm_model.is_following_repo(c.repo_name, | |||
c.rhodecode_user.user_id) | ||||
r637 | def url_generator(**kw): | |||
return url('shortlog_home', repo_name=c.repo_name, **kw) | ||||
r1038 | c.repo_changesets = Page(c.repo, page=1, items_per_page=10, | |||
r637 | url=url_generator) | |||
r547 | e = request.environ | |||
r637 | ||||
r674 | if self.rhodecode_user.username == 'default': | |||
r910 | #for default(anonymous) user we don't need to pass credentials | |||
username = '' | ||||
password = '' | ||||
r674 | else: | |||
r910 | username = str(c.rhodecode_user.username) | |||
r936 | password = '@' | |||
r674 | ||||
r936 | uri = u'%(protocol)s://%(user)s%(password)s%(host)s%(prefix)s/%(repo_name)s' % { | |||
r547 | 'protocol': e.get('wsgi.url_scheme'), | |||
r910 | 'user':username, | |||
r674 | 'password':password, | |||
r547 | 'host':e.get('HTTP_HOST'), | |||
'prefix':e.get('SCRIPT_NAME'), | ||||
'repo_name':c.repo_name, } | ||||
c.clone_repo_url = uri | ||||
c.repo_tags = OrderedDict() | ||||
r1038 | for name, hash in c.repo.tags.items()[:10]: | |||
r643 | try: | |||
r1038 | c.repo_tags[name] = c.repo.get_changeset(hash) | |||
r643 | except ChangesetError: | |||
c.repo_tags[name] = EmptyChangeset(hash) | ||||
r637 | ||||
r547 | c.repo_branches = OrderedDict() | |||
r1038 | for name, hash in c.repo.branches.items()[:10]: | |||
r643 | try: | |||
r1038 | c.repo_branches[name] = c.repo.get_changeset(hash) | |||
r643 | except ChangesetError: | |||
c.repo_branches[name] = EmptyChangeset(hash) | ||||
r637 | ||||
r937 | td = date.today() + timedelta(days=1) | |||
td_1m = td - timedelta(days=calendar.mdays[td.month]) | ||||
td_1y = td - timedelta(days=365) | ||||
r637 | ||||
r937 | ts_min_m = mktime(td_1m.timetuple()) | |||
ts_min_y = mktime(td_1y.timetuple()) | ||||
ts_max_y = mktime(td.timetuple()) | ||||
r637 | ||||
r1038 | if dbrepo.enable_statistics: | |||
r810 | c.no_data_msg = _('No data loaded yet') | |||
r1038 | run_task(get_commits_stats, c.repo.name, ts_min_y, ts_max_y) | |||
r810 | else: | |||
r820 | c.no_data_msg = _('Statistics update are disabled for this repository') | |||
r547 | c.ts_min = ts_min_m | |||
c.ts_max = ts_max_y | ||||
r637 | ||||
r547 | stats = self.sa.query(Statistics)\ | |||
r1038 | .filter(Statistics.repository == dbrepo)\ | |||
r547 | .scalar() | |||
r637 | ||||
r547 | if stats and stats.languages: | |||
r1038 | c.no_data = False is dbrepo.enable_statistics | |||
r547 | lang_stats = json.loads(stats.languages) | |||
c.commit_data = stats.commit_activity | ||||
c.overview_data = stats.commit_activity_combined | ||||
c.trending_languages = json.dumps(OrderedDict( | ||||
sorted(lang_stats.items(), reverse=True, | ||||
r763 | key=lambda k: k[1])[:10] | |||
r547 | ) | |||
) | ||||
else: | ||||
c.commit_data = json.dumps({}) | ||||
r800 | c.overview_data = json.dumps([[ts_min_y, 0], [ts_max_y, 10] ]) | |||
r547 | c.trending_languages = json.dumps({}) | |||
r800 | c.no_data = True | |||
r637 | ||||
r1038 | c.enable_downloads = dbrepo.enable_downloads | |||
r962 | if c.enable_downloads: | |||
r1038 | c.download_options = self._get_download_links(c.repo) | |||
r942 | ||||
r547 | return render('summary/summary.html') | |||
r942 | ||||
def _get_download_links(self, repo): | ||||
download_l = [] | ||||
branches_group = ([], _("Branches")) | ||||
tags_group = ([], _("Tags")) | ||||
for name, chs in c.repository_branches.items(): | ||||
#chs = chs.split(':')[-1] | ||||
branches_group[0].append((chs, name),) | ||||
download_l.append(branches_group) | ||||
for name, chs in c.repository_tags.items(): | ||||
#chs = chs.split(':')[-1] | ||||
tags_group[0].append((chs, name),) | ||||
download_l.append(tags_group) | ||||
return download_l | ||||