Files
@ f420e86db893
Branch filter:
Location: kallithea/pylons_app/controllers/summary.py - annotation
f420e86db893
4.2 KiB
text/x-python
drastic speed improvment in feed generation (was using old method)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 | 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 558eb7c5028f 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 3782a6d698af 5c376ac2d4c9 fdf9f6ee5217 a83a1799480c 558eb7c5028f 237470e64bb8 2256c78afe53 237470e64bb8 3fc3ce53659b 3fc3ce53659b 2256c78afe53 2256c78afe53 2256c78afe53 b68b2246e5a6 d5efb83590ef 670713507d03 670713507d03 670713507d03 b68b2246e5a6 b68b2246e5a6 fdf9f6ee5217 fdf9f6ee5217 670713507d03 b68b2246e5a6 fdf9f6ee5217 670713507d03 670713507d03 670713507d03 237470e64bb8 670713507d03 b68b2246e5a6 37a832dc4a82 37a832dc4a82 37a832dc4a82 37a832dc4a82 b68b2246e5a6 174785aa5dc4 7ec4463b6e53 7ec4463b6e53 7ec4463b6e53 174785aa5dc4 7ec4463b6e53 7ec4463b6e53 3fc3ce53659b 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 2256c78afe53 d5efb83590ef d5efb83590ef d5efb83590ef d5efb83590ef 2256c78afe53 2256c78afe53 d5efb83590ef d5efb83590ef d5efb83590ef d5efb83590ef d5efb83590ef d5efb83590ef 2256c78afe53 2256c78afe53 2256c78afe53 d5efb83590ef 558eb7c5028f b68b2246e5a6 558eb7c5028f | #!/usr/bin/env python
# encoding: utf-8
# summary 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 18, 2010
summary controller for pylons
@author: marcink
"""
from pylons import tmpl_context as c, request, url
from pylons_app.lib.auth import LoginRequired, HasRepoPermissionAnyDecorator
from pylons_app.lib.base import BaseController, render
from pylons_app.lib.utils import OrderedDict
from pylons_app.model.hg_model import HgModel
from pylons_app.model.db import Statistics
from webhelpers.paginate import Page
from pylons_app.lib.celerylib import run_task
from pylons_app.lib.celerylib.tasks import get_commits_stats
from datetime import datetime, timedelta
from time import mktime
import calendar
import logging
import json
log = logging.getLogger(__name__)
class SummaryController(BaseController):
@LoginRequired()
@HasRepoPermissionAnyDecorator('repository.read', 'repository.write',
'repository.admin')
def __before__(self):
super(SummaryController, self).__before__()
def index(self):
hg_model = HgModel()
c.repo_info = hg_model.get_repo(c.repo_name)
c.repo_changesets = Page(list(c.repo_info[:10]), page=1, items_per_page=20)
e = request.environ
uri = u'%(protocol)s://%(user)s@%(host)s/%(repo_name)s' % {
'protocol': e.get('wsgi.url_scheme'),
'user':str(c.hg_app_user.username),
'host':e.get('HTTP_HOST'),
'repo_name':c.repo_name, }
c.clone_repo_url = uri
c.repo_tags = OrderedDict()
for name, hash in c.repo_info.tags.items()[:10]:
c.repo_tags[name] = c.repo_info.get_changeset(hash)
c.repo_branches = OrderedDict()
for name, hash in c.repo_info.branches.items()[:10]:
c.repo_branches[name] = c.repo_info.get_changeset(hash)
td = datetime.today() + timedelta(days=1)
y, m, d = td.year, td.month, td.day
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,))
ts_max_y = mktime((y, m, d, 0, 0, 0, 0, 0, 0,))
run_task(get_commits_stats, c.repo_info.name, ts_min_y, ts_max_y)
c.ts_min = ts_min_m
c.ts_max = ts_max_y
stats = self.sa.query(Statistics)\
.filter(Statistics.repository == c.repo_info.dbrepo)\
.scalar()
if stats and stats.languages:
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,
key=lambda k: k[1])[:2]
)
)
print c.trending_languages
else:
c.commit_data = json.dumps({})
c.overview_data = json.dumps([[ts_min_y, 0], [ts_max_y, 0] ])
c.trending_languages = json.dumps({})
return render('summary/summary.html')
|