##// END OF EJS Templates
scm-app: allow to set documented pyro4 as scm_app_implementation....
scm-app: allow to set documented pyro4 as scm_app_implementation. The documented ini setting allows to set pyro4 as scm_app, while the backend code crashes on import of pyro4 module. This change allows to configure the app based on the .ini docs. if we pass pyro4 as backedn, we simply skip import and use the default pyro4 scm_app

File last commit:

r226:6371ca5e default
r632:064401fe default
Show More
home.py
289 lines | 9.4 KiB | text/x-python | PythonLexer
project: added all source files and assets
r1 # -*- coding: utf-8 -*-
# Copyright (C) 2010-2016 RhodeCode GmbH
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# 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 Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
"""
Home controller for RhodeCode Enterprise
"""
import logging
import time
dan
feature: Go To switcher now searches commit hashes as well
r62 import re
project: added all source files and assets
r1
dan
feature: Go To switcher now searches commit hashes as well
r62 from pylons import tmpl_context as c, request, url, config
project: added all source files and assets
r1 from pylons.i18n.translation import _
from sqlalchemy.sql import func
from rhodecode.lib.auth import (
dan
feature: Go To switcher now searches commit hashes as well
r62 LoginRequired, HasPermissionAllDecorator, AuthUser,
project: added all source files and assets
r1 HasRepoGroupPermissionAnyDecorator, XHRRequired)
from rhodecode.lib.base import BaseController, render
dan
feature: Go To switcher now searches commit hashes as well
r62 from rhodecode.lib.index import searcher_from_config
project: added all source files and assets
r1 from rhodecode.lib.ext_json import json
from rhodecode.lib.utils import jsonify
autocomplete: allow to pass in a GET flag to control if non-active users should be returned in...
r226 from rhodecode.lib.utils2 import safe_unicode, str2bool
project: added all source files and assets
r1 from rhodecode.model.db import Repository, RepoGroup
from rhodecode.model.repo import RepoModel
from rhodecode.model.repo_group import RepoGroupModel
from rhodecode.model.scm import RepoList, RepoGroupList
log = logging.getLogger(__name__)
class HomeController(BaseController):
def __before__(self):
super(HomeController, self).__before__()
def ping(self):
"""
Ping, doesn't require login, good for checking out the platform
"""
instance_id = getattr(c, 'rhodecode_instanceid', '')
return 'pong[%s] => %s' % (instance_id, self.ip_addr,)
@LoginRequired()
@HasPermissionAllDecorator('hg.admin')
def error_test(self):
"""
Test exception handling and emails on errors
"""
class TestException(Exception):
pass
msg = ('RhodeCode Enterprise %s test exception. Generation time: %s'
% (c.rhodecode_name, time.time()))
raise TestException(msg)
def _get_groups_and_repos(self, repo_group_id=None):
# repo groups groups
repo_group_list = RepoGroup.get_all_repo_groups(group_id=repo_group_id)
_perms = ['group.read', 'group.write', 'group.admin']
repo_group_list_acl = RepoGroupList(repo_group_list, perm_set=_perms)
repo_group_data = RepoGroupModel().get_repo_groups_as_dict(
repo_group_list=repo_group_list_acl, admin=False)
# repositories
repo_list = Repository.get_all_repos(group_id=repo_group_id)
_perms = ['repository.read', 'repository.write', 'repository.admin']
repo_list_acl = RepoList(repo_list, perm_set=_perms)
repo_data = RepoModel().get_repos_as_dict(
repo_list=repo_list_acl, admin=False)
return repo_data, repo_group_data
@LoginRequired()
def index(self):
c.repo_group = None
repo_data, repo_group_data = self._get_groups_and_repos()
# json used to render the grids
c.repos_data = json.dumps(repo_data)
c.repo_groups_data = json.dumps(repo_group_data)
return render('/index.html')
@LoginRequired()
@HasRepoGroupPermissionAnyDecorator('group.read', 'group.write',
'group.admin')
def index_repo_group(self, group_name):
"""GET /repo_group_name: Show a specific item"""
c.repo_group = RepoGroupModel()._get_repo_group(group_name)
repo_data, repo_group_data = self._get_groups_and_repos(
c.repo_group.group_id)
# json used to render the grids
c.repos_data = json.dumps(repo_data)
c.repo_groups_data = json.dumps(repo_group_data)
return render('index_repo_group.html')
def _get_repo_list(self, name_contains=None, repo_type=None, limit=20):
query = Repository.query()\
.order_by(func.length(Repository.repo_name))\
.order_by(Repository.repo_name)
if repo_type:
query = query.filter(Repository.repo_type == repo_type)
if name_contains:
ilike_expression = u'%{}%'.format(safe_unicode(name_contains))
query = query.filter(
Repository.repo_name.ilike(ilike_expression))
query = query.limit(limit)
all_repos = query.all()
repo_iter = self.scm_model.get_repos(all_repos)
return [
{
'id': obj['name'],
'text': obj['name'],
'type': 'repo',
dan
feature: Go To switcher now searches commit hashes as well
r62 'obj': obj['dbrepo'],
'url': url('summary_home', repo_name=obj['name'])
project: added all source files and assets
r1 }
for obj in repo_iter]
def _get_repo_group_list(self, name_contains=None, limit=20):
query = RepoGroup.query()\
.order_by(func.length(RepoGroup.group_name))\
.order_by(RepoGroup.group_name)
if name_contains:
ilike_expression = u'%{}%'.format(safe_unicode(name_contains))
query = query.filter(
RepoGroup.group_name.ilike(ilike_expression))
query = query.limit(limit)
all_groups = query.all()
repo_groups_iter = self.scm_model.get_repo_groups(all_groups)
return [
{
'id': obj.group_name,
'text': obj.group_name,
'type': 'group',
dan
feature: Go To switcher now searches commit hashes as well
r62 'obj': {},
'url': url('repo_group_home', group_name=obj.group_name)
project: added all source files and assets
r1 }
for obj in repo_groups_iter]
dan
feature: Go To switcher now searches commit hashes as well
r62 def _get_hash_commit_list(self, hash_starts_with=None, limit=20):
if not hash_starts_with or len(hash_starts_with) < 3:
return []
commit_hashes = re.compile('([0-9a-f]{2,40})').findall(hash_starts_with)
if len(commit_hashes) != 1:
return []
commit_hash_prefix = commit_hashes[0]
auth_user = AuthUser(
user_id=c.rhodecode_user.user_id, ip_addr=self.ip_addr)
searcher = searcher_from_config(config)
result = searcher.search(
'commit_id:%s*' % commit_hash_prefix, 'commit', auth_user)
return [
{
'id': entry['commit_id'],
'text': entry['commit_id'],
'type': 'commit',
'obj': {'repo': entry['repository']},
'url': url('changeset_home',
repo_name=entry['repository'], revision=entry['commit_id'])
}
for entry in result['results']]
project: added all source files and assets
r1 @LoginRequired()
@XHRRequired()
@jsonify
dan
feature: Go To switcher now searches commit hashes as well
r62 def goto_switcher_data(self):
project: added all source files and assets
r1 query = request.GET.get('query')
dan
feature: Go To switcher now searches commit hashes as well
r62 log.debug('generating goto switcher list, query %s', query)
project: added all source files and assets
r1
res = []
repo_groups = self._get_repo_group_list(query)
if repo_groups:
res.append({
'text': _('Groups'),
'children': repo_groups
})
repos = self._get_repo_list(query)
if repos:
res.append({
'text': _('Repositories'),
'children': repos
})
dan
feature: Go To switcher now searches commit hashes as well
r62 commits = self._get_hash_commit_list(query)
if commits:
unique_repos = {}
for commit in commits:
unique_repos.setdefault(commit['obj']['repo'], []
).append(commit)
for repo in unique_repos:
res.append({
'text': _('Commits in %(repo)s') % {'repo': repo},
'children': unique_repos[repo]
})
project: added all source files and assets
r1 data = {
'more': False,
'results': res
}
return data
@LoginRequired()
@XHRRequired()
@jsonify
def repo_list_data(self):
query = request.GET.get('query')
repo_type = request.GET.get('repo_type')
log.debug('generating repo list, query:%s', query)
res = []
repos = self._get_repo_list(query, repo_type=repo_type)
if repos:
res.append({
'text': _('Repositories'),
'children': repos
})
dan
feature: Go To switcher now searches commit hashes as well
r62
project: added all source files and assets
r1 data = {
'more': False,
'results': res
}
return data
@LoginRequired()
@XHRRequired()
@jsonify
def user_autocomplete_data(self):
query = request.GET.get('query')
autocomplete: allow to pass in a GET flag to control if non-active users should be returned in...
r226 active = str2bool(request.GET.get('active') or True)
project: added all source files and assets
r1
repo_model = RepoModel()
autocomplete: allow to pass in a GET flag to control if non-active users should be returned in...
r226 _users = repo_model.get_users(
name_contains=query, only_active=active)
project: added all source files and assets
r1
if request.GET.get('user_groups'):
# extend with user groups
autocomplete: allow to pass in a GET flag to control if non-active users should be returned in...
r226 _user_groups = repo_model.get_user_groups(
name_contains=query, only_active=active)
project: added all source files and assets
r1 _users = _users + _user_groups
return {'suggestions': _users}
@LoginRequired()
@XHRRequired()
@jsonify
def user_group_autocomplete_data(self):
autocomplete: add flags to show/hide active users, and also display this information...
r222 query = request.GET.get('query')
autocomplete: allow to pass in a GET flag to control if non-active users should be returned in...
r226 active = str2bool(request.GET.get('active') or True)
autocomplete: add flags to show/hide active users, and also display this information...
r222
repo_model = RepoModel()
autocomplete: allow to pass in a GET flag to control if non-active users should be returned in...
r226 _user_groups = repo_model.get_user_groups(
name_contains=query, only_active=active)
autocomplete: add flags to show/hide active users, and also display this information...
r222 _user_groups = _user_groups
return {'suggestions': _user_groups}