summary.py
141 lines
| 5.2 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 | ||||
r939 | :copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com> | |||
r763 | :license: GPLv3, see COPYING for more details. | |||
""" | ||||
r1217 | # 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. | ||||
# | ||||
r547 | # 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. | ||||
r1217 | # | |||
r547 | # You should have received a copy of the GNU General Public License | |||
r1217 | # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
r763 | ||||
r810 | import calendar | |||
import logging | ||||
from time import mktime | ||||
r939 | 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() | |||
c.repo_info = scm_model.get_repo(c.repo_name) | ||||
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) | ||||
c.repo_changesets = Page(c.repo_info, page=1, items_per_page=10, | ||||
url=url_generator) | ||||
r547 | e = request.environ | |||
r637 | ||||
r674 | if self.rhodecode_user.username == 'default': | |||
password = ':default' | ||||
else: | ||||
password = '' | ||||
uri = u'%(protocol)s://%(user)s%(password)s@%(host)s%(prefix)s/%(repo_name)s' % { | ||||
r547 | 'protocol': e.get('wsgi.url_scheme'), | |||
r548 | 'user':str(c.rhodecode_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() | ||||
for name, hash in c.repo_info.tags.items()[:10]: | ||||
r643 | try: | |||
c.repo_tags[name] = c.repo_info.get_changeset(hash) | ||||
except ChangesetError: | ||||
c.repo_tags[name] = EmptyChangeset(hash) | ||||
r637 | ||||
r547 | c.repo_branches = OrderedDict() | |||
for name, hash in c.repo_info.branches.items()[:10]: | ||||
r643 | try: | |||
c.repo_branches[name] = c.repo_info.get_changeset(hash) | ||||
except ChangesetError: | ||||
c.repo_branches[name] = EmptyChangeset(hash) | ||||
r637 | ||||
r939 | td = date.today() + timedelta(days=1) | |||
td_1m = td - timedelta(days=calendar.mdays[td.month]) | ||||
td_1y = td - timedelta(days=365) | ||||
r637 | ||||
r939 | ts_min_m = mktime(td_1m.timetuple()) | |||
ts_min_y = mktime(td_1y.timetuple()) | ||||
ts_max_y = mktime(td.timetuple()) | ||||
r637 | ||||
r810 | if c.repo_info.dbrepo.enable_statistics: | |||
c.no_data_msg = _('No data loaded yet') | ||||
run_task(get_commits_stats, c.repo_info.name, ts_min_y, ts_max_y) | ||||
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)\ | |||
.filter(Statistics.repository == c.repo_info.dbrepo)\ | ||||
.scalar() | ||||
r637 | ||||
r547 | if stats and stats.languages: | |||
r820 | c.no_data = False is c.repo_info.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 | ||||
r547 | return render('summary/summary.html') | |||