Show More
summary.py
147 lines
| 5.5 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 | ||||
from datetime import datetime, timedelta | ||||
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': | |||
r910 | #for default(anonymous) user we don't need to pass credentials | |||
username = '' | ||||
password = '' | ||||
r674 | else: | |||
r910 | username = str(c.rhodecode_user.username) | |||
r674 | password = '' | |||
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() | ||||
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 | ||||
td = datetime.today() + timedelta(days=1) | ||||
r547 | y, m, d = td.year, td.month, td.day | |||
r637 | ||||
r547 | ts_min_y = mktime((y - 1, (td - timedelta(days=calendar.mdays[m])).month, | |||
d, 0, 0, 0, 0, 0, 0,)) | ||||
ts_min_m = mktime((y, (td - timedelta(days=calendar.mdays[m])).month, | ||||
d, 0, 0, 0, 0, 0, 0,)) | ||||
r637 | ||||
r547 | ts_max_y = mktime((y, m, d, 0, 0, 0, 0, 0, 0,)) | |||
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') | |||