##// END OF EJS Templates
Added timeout option to gunicorn example config
Added timeout option to gunicorn example config

File last commit:

r3960:5293d4bb merge default
r3964:8c11a295 beta
Show More
repos.py
578 lines | 22.7 KiB | text/x-python | PythonLexer
some extra fixes added docs string
r824 # -*- coding: utf-8 -*-
"""
rhodecode.controllers.admin.repos
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
source code cleanup: remove trailing white space, normalize file endings
r1203
#227 Initial version of repository groups permissions system...
r1982 Repositories controller for RhodeCode
source code cleanup: remove trailing white space, normalize file endings
r1203
some extra fixes added docs string
r824 :created_on: Apr 7, 2010
:author: marcink
2012 copyrights
r1824 :copyright: (C) 2010-2012 Marcin Kuzminski <marcin@python-works.com>
some extra fixes added docs string
r824 :license: GPLv3, see COPYING for more details.
"""
fixed license issue #149
r1206 # 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.
source code cleanup: remove trailing white space, normalize file endings
r1203 #
renamed project to rhodecode
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.
source code cleanup: remove trailing white space, normalize file endings
r1203 #
renamed project to rhodecode
r547 # You should have received a copy of the GNU General Public License
fixed license issue #149
r1206 # along with this program. If not, see <http://www.gnu.org/licenses/>.
some extra fixes added docs string
r824
import logging
import traceback
import formencode
renamed project to rhodecode
r547 from formencode import htmlfill
some extra fixes added docs string
r824
Implemented #738 Giving a user WRITE+ permissions on folder should not allow repo creation in root folder....
r3333 from webob.exc import HTTPInternalServerError, HTTPForbidden
#235 forking page repo group selection...
r1722 from pylons import request, session, tmpl_context as c, url
from pylons.controllers.util import redirect
renamed project to rhodecode
r547 from pylons.i18n.translation import _
#235 forking page repo group selection...
r1722 from sqlalchemy.exc import IntegrityError
some extra fixes added docs string
r824
rewrote admin repos page....
r2664 import rhodecode
renamed project to rhodecode
r547 from rhodecode.lib import helpers as h
from rhodecode.lib.auth import LoginRequired, HasPermissionAllDecorator, \
Implemented #738 Giving a user WRITE+ permissions on folder should not allow repo creation in root folder....
r3333 HasPermissionAnyDecorator, HasRepoPermissionAllDecorator, NotAnonymous,\
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 HasPermissionAny, HasReposGroupPermissionAny, HasRepoPermissionAnyDecorator
Mads Kiilerich
repo edit: it is a repo thing more than an admin thing - show it that way in ui and url
r3288 from rhodecode.lib.base import BaseRepoController, render
removed duplicated logic of how we invalidate caches for repos
r3693 from rhodecode.lib.utils import action_logger, repo_name_slug
implemented public journal for anonymous users, admin can control which repositories...
r1085 from rhodecode.lib.helpers import get_token
#235 forking page repo group selection...
r1722 from rhodecode.model.meta import Session
Implemented #379 defaults settings page for creation of repositories...
r3056 from rhodecode.model.db import User, Repository, UserFollowing, RepoGroup,\
repository extra fields implementation...
r3308 RhodeCodeSetting, RepositoryField
moved permission management into separate entity....
r3628 from rhodecode.model.forms import RepoForm, RepoFieldForm, RepoPermsForm
Do read only checks on attach as fork of repo list....
r3864 from rhodecode.model.scm import ScmModel, RepoGroupList, RepoList
Code refactoring,models renames...
r629 from rhodecode.model.repo import RepoModel
rewrote admin repos page....
r2664 from rhodecode.lib.compat import json
user lowernames of repos for better sorting
r2935 from sqlalchemy.sql.expression import func
recursive forks detach...
r3641 from rhodecode.lib.exceptions import AttachedForksError
consistent handling of grant/revoke of permissions widgets...
r3715 from rhodecode.lib.utils2 import safe_int
some extra fixes added docs string
r824
renamed project to rhodecode
r547 log = logging.getLogger(__name__)
PEP8ify - controllers
r1245
Mads Kiilerich
repo edit: it is a repo thing more than an admin thing - show it that way in ui and url
r3288 class ReposController(BaseRepoController):
implemented public journal for anonymous users, admin can control which repositories...
r1085 """
REST Controller styled on the Atom Publishing Protocol"""
renamed project to rhodecode
r547 # To properly map this controller, ensure your config/routing.py
# file has a resource setup:
# map.resource('repo', 'repos')
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 @LoginRequired()
def __before__(self):
super(ReposController, self).__before__()
Fixes for raw_id, needed for git...
r636
Changes for repo groups
r1159 def __load_defaults(self):
- Manage User’s Groups: create, delete, rename, add/remove users inside....
r3714 acl_groups = RepoGroupList(RepoGroup.query().all(),
filter out repo groups choices to only ones that you have write+ access to. Before it was read+ access and you got proper...
r3239 perm_set=['group.write', 'group.admin'])
c.repo_groups = RepoGroup.groups_choices(groups=acl_groups)
unified generation of repo groups choices...
r1547 c.repo_groups_choices = map(lambda k: unicode(k[0]), c.repo_groups)
#235 forking page repo group selection...
r1722
Changes for repo groups
r1159 repo_model = RepoModel()
c.users_array = repo_model.get_users_js()
c.users_groups_array = repo_model.get_users_groups_js()
validating choices for landing_rev
r2460 choices, c.landing_revs = ScmModel().get_repo_landing_revs()
c.landing_revs_choices = choices
Changes for repo groups
r1159
def __load_data(self, repo_name=None):
#109, added optional clone uri when creating repo....
r1112 """
Load defaults settings for edit, and update
source code cleanup: remove trailing white space, normalize file endings
r1203
#109, added optional clone uri when creating repo....
r1112 :param repo_name:
"""
Changes for repo groups
r1159 self.__load_defaults()
Refactoring of model get functions
r1530 c.repo_info = db_repo = Repository.get_by_repo_name(repo_name)
added validation of params on settings table
r1561 repo = db_repo.scm_instance
#109, added optional clone uri when creating repo....
r1112
if c.repo_info is None:
- #683 fixed difference between messages about not mapped repositories
r3110 h.not_mapped_error(repo_name)
#109, added optional clone uri when creating repo....
r1112 return redirect(url('repos'))
Fixed some issues with edit form...
r3089 ##override defaults for exact repo info here git/hg etc
validating choices for landing_rev
r2460 choices, c.landing_revs = ScmModel().get_repo_landing_revs(c.repo_info)
c.landing_revs_choices = choices
New default permissions definition for user group create
r3734 c.default_user_id = User.get_default_user().user_id
fixes #288...
r1594 c.in_public_journal = UserFollowing.query()\
#109, added optional clone uri when creating repo....
r1112 .filter(UserFollowing.user_id == c.default_user_id)\
.filter(UserFollowing.follows_repository == c.repo_info).scalar()
if c.repo_info.stats:
- fixed issue with missing commits on some repos commands...
r1807 # this is on what revision we ended up so we add +1 for count
last_rev = c.repo_info.stats.stat_on_revision + 1
#109, added optional clone uri when creating repo....
r1112 else:
last_rev = 0
c.stats_revision = last_rev
- fixed issue with missing commits on some repos commands...
r1807 c.repo_last_rev = repo.count() if repo.revisions else 0
#109, added optional clone uri when creating repo....
r1112
if last_rev == 0 or c.repo_last_rev == 0:
c.stats_percentage = 0
else:
c.stats_percentage = '%.2f' % ((float((last_rev)) /
c.repo_last_rev) * 100)
repository extra fields implementation...
r3308 c.repo_fields = RepositoryField.query()\
.filter(RepositoryField.repository == db_repo).all()
fixes #288...
r1594 defaults = RepoModel()._get_defaults(repo_name)
auto white-space removal
r1818
Do read only checks on attach as fork of repo list....
r3864 _repos = Repository.query().order_by(Repository.repo_name).all()
read_access_repos = RepoList(_repos)
implements #239 manual marking of repos as forks for admins
r1755 c.repos_list = [('', _('--REMOVE FORK--'))]
Do read only checks on attach as fork of repo list....
r3864 c.repos_list += [(x.repo_id, x.repo_name)
for x in read_access_repos
if x.repo_id != c.repo_info.repo_id]
Initial version of landing revisions ref #483...
r2459
Fixed issue #501 error on setting set_as_fork to same repo...
r2629 defaults['id_fork_of'] = db_repo.fork.repo_id if db_repo.fork else ''
#109, added optional clone uri when creating repo....
r1112 return defaults
renamed project to rhodecode
r547 def index(self, format='html'):
"""GET /repos: All items in the collection"""
# url('repos')
show admin menu and list for users who are admins of repos....
r3865 repo_list = Repository.query()\
.order_by(func.lower(Repository.repo_name))\
.all()
Admin view will see repos_groups in main list
r1344
show admin menu and list for users who are admins of repos....
r3865 c.repos_list = RepoList(repo_list, perm_set=['repository.admin'])
Use common function for generation of grid data...
r3154 repos_data = RepoModel().get_repos_as_dict(repos_list=c.repos_list,
fixes issue #739 Delete/Edit repositories should only point to admin links if the user is an super admin.
r3245 admin=True,
super_user_actions=True)
Use common function for generation of grid data...
r3154 #json used to render the grid
c.data = json.dumps(repos_data)
rewrote admin repos page....
r2664
renamed project to rhodecode
r547 return render('admin/repos/repos.html')
Fixes for raw_id, needed for git...
r636
Implemented #738 Giving a user WRITE+ permissions on folder should not allow repo creation in root folder....
r3333 @NotAnonymous()
renamed project to rhodecode
r547 def create(self):
implemented public journal for anonymous users, admin can control which repositories...
r1085 """
POST /repos: Create a new item"""
renamed project to rhodecode
r547 # url('repos')
#235 forking page repo group selection...
r1722
Changes for repo groups
r1159 self.__load_defaults()
renamed project to rhodecode
r547 form_result = {}
try:
validating choices for landing_rev
r2460 form_result = RepoForm(repo_groups=c.repo_groups_choices,
landing_revs=c.landing_revs_choices)()\
Changes for repo groups
r1159 .to_python(dict(request.POST))
Implemented #738 Giving a user WRITE+ permissions on folder should not allow repo creation in root folder....
r3333
redirect to summary page after repo was created
r2660 new_repo = RepoModel().create(form_result,
self.rhodecode_user.user_id)
#109, added optional clone uri when creating repo....
r1112 if form_result['clone_uri']:
Mads Kiilerich
consistently capitalize initial letter in flash messages
r3565 h.flash(_('Created repository %s from %s') \
#109, added optional clone uri when creating repo....
r1112 % (form_result['repo_name'], form_result['clone_uri']),
category='success')
else:
linkify names on fork/create repos in tooltip messages
r3547 repo_url = h.link_to(form_result['repo_name'],
fix flash link to repos that are in groups
r3668 h.url('summary_home', repo_name=form_result['repo_name_full']))
Mads Kiilerich
consistently capitalize initial letter in flash messages
r3565 h.flash(h.literal(_('Created repository %s') % repo_url),
linkify names on fork/create repos in tooltip messages
r3547 category='success')
renamed project to rhodecode
r547
if request.POST.get('user_created'):
#235 forking page repo group selection...
r1722 # created by regular non admin user
refactor codes and setup for python 2.5...
r564 action_logger(self.rhodecode_user, 'user_created_repo',
Implemented #467 Journal logs comments on changesets...
r2375 form_result['repo_name_full'], self.ip_addr,
self.sa)
renamed project to rhodecode
r547 else:
refactor codes and setup for python 2.5...
r564 action_logger(self.rhodecode_user, 'admin_created_repo',
Implemented #467 Journal logs comments on changesets...
r2375 form_result['repo_name_full'], self.ip_addr,
self.sa)
sqlalchemy sessions cleanup in admin...
r2662 Session().commit()
refactor codes and setup for python 2.5...
r564 except formencode.Invalid, errors:
renamed project to rhodecode
r547 return htmlfill.render(
Implemented #738 Giving a user WRITE+ permissions on folder should not allow repo creation in root folder....
r3333 render('admin/repos/repo_add.html'),
renamed project to rhodecode
r547 defaults=errors.value,
errors=errors.error_dict or {},
prefix_error=False,
Fixes for raw_id, needed for git...
r636 encoding="UTF-8")
renamed project to rhodecode
r547
except Exception:
log.error(traceback.format_exc())
Mads Kiilerich
Fix a lot of casings - use standard casing in most places
r3654 msg = _('Error creating repository %s') \
renamed project to rhodecode
r547 % form_result.get('repo_name')
h.flash(msg, category='error')
Implemented #738 Giving a user WRITE+ permissions on folder should not allow repo creation in root folder....
r3333 if c.rhodecode_user.is_admin:
return redirect(url('repos'))
return redirect(url('home'))
redirect to summary page after repo was created
r2660 #redirect to our new repo !
return redirect(url('summary_home', repo_name=new_repo.repo_name))
Fixes for raw_id, needed for git...
r636
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @NotAnonymous()
def create_repository(self):
"""GET /_admin/create_repository: Form to create a new item"""
new_repo = request.GET.get('repo', '')
parent_group = request.GET.get('parent_group')
if not HasPermissionAny('hg.admin', 'hg.create.repository')():
#you're not super admin nor have global create permissions,
#but maybe you have at least write permission to a parent group ?
_gr = RepoGroup.get(parent_group)
gr_name = _gr.group_name if _gr else None
if not HasReposGroupPermissionAny('group.admin', 'group.write')(group_name=gr_name):
raise HTTPForbidden
use the GET parent_group param to pre-fill the group choice
r3233
- Manage User’s Groups: create, delete, rename, add/remove users inside....
r3714 acl_groups = RepoGroupList(RepoGroup.query().all(),
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 perm_set=['group.write', 'group.admin'])
c.repo_groups = RepoGroup.groups_choices(groups=acl_groups)
c.repo_groups_choices = map(lambda k: unicode(k[0]), c.repo_groups)
choices, c.landing_revs = ScmModel().get_repo_landing_revs()
use the GET parent_group param to pre-fill the group choice
r3233
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 c.new_repo = repo_name_slug(new_repo)
Fixed some issues with edit form...
r3089 ## apply the defaults from defaults page
defaults = RhodeCodeSetting.get_default_repo_settings(strip_prefix=True)
use the GET parent_group param to pre-fill the group choice
r3233 if parent_group:
defaults.update({'repo_group': parent_group})
Fixed some issues with edit form...
r3089 return htmlfill.render(
render('admin/repos/repo_add.html'),
defaults=defaults,
errors={},
prefix_error=False,
encoding="UTF-8"
)
Fixes for raw_id, needed for git...
r636
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
renamed project to rhodecode
r547 def update(self, repo_name):
implemented public journal for anonymous users, admin can control which repositories...
r1085 """
PUT /repos/repo_name: Update an existing item"""
renamed project to rhodecode
r547 # Forms posted to this method should contain a hidden field:
# <input type="hidden" name="_method" value="PUT" />
# Or using helpers:
# h.form(url('repo', repo_name=ID),
# method='put')
# url('repo', repo_name=ID)
Changes for repo groups
r1159 self.__load_defaults()
renamed project to rhodecode
r547 repo_model = RepoModel()
changed_name = repo_name
Readme renderer now uses landing_rev parameter to render the readme based on...
r2603 #override the choices with extracted revisions !
choices, c.landing_revs = ScmModel().get_repo_landing_revs(repo_name)
c.landing_revs_choices = choices
Pass in old groups data to CanWriteToGroup validator for later skipping group checks....
r3524 repo = Repository.get_by_repo_name(repo_name)
fix required repo_type param on repo edit form
r3863 old_data = {
'repo_name': repo_name,
'repo_group': repo.group.get_dict() if repo.group else {},
'repo_type': repo.repo_type,
}
_form = RepoForm(edit=True, old_data=old_data,
validating choices for landing_rev
r2460 repo_groups=c.repo_groups_choices,
landing_revs=c.landing_revs_choices)()
fix required repo_type param on repo edit form
r3863
renamed project to rhodecode
r547 try:
form_result = _form.to_python(dict(request.POST))
Fixed some issues with edit form...
r3089 repo = repo_model.update(repo_name, **form_result)
removed duplicated logic of how we invalidate caches for repos
r3693 ScmModel().mark_for_invalidation(repo_name)
Takumi IINO
i18n improve
r2570 h.flash(_('Repository %s updated successfully') % repo_name,
renamed project to rhodecode
r547 category='success')
fixes #260 Put repo in group, then move group to another group -> repo becomes unavailable
r1539 changed_name = repo.repo_name
#48 rewrote action logger, translated action logger messages, added some extra messages. Linked and showed pushed revisions in logs
r660 action_logger(self.rhodecode_user, 'admin_updated_repo',
Implemented #467 Journal logs comments on changesets...
r2375 changed_name, self.ip_addr, self.sa)
sqlalchemy sessions cleanup in admin...
r2662 Session().commit()
refactor codes and setup for python 2.5...
r564 except formencode.Invalid, errors:
#109, added optional clone uri when creating repo....
r1112 defaults = self.__load_data(repo_name)
defaults.update(errors.value)
renamed project to rhodecode
r547 return htmlfill.render(
render('admin/repos/repo_edit.html'),
#109, added optional clone uri when creating repo....
r1112 defaults=defaults,
renamed project to rhodecode
r547 errors=errors.error_dict or {},
prefix_error=False,
encoding="UTF-8")
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 except Exception:
log.error(traceback.format_exc())
Mads Kiilerich
consistently capitalize initial letter in flash messages
r3565 h.flash(_('Error occurred during update of repository %s') \
renamed project to rhodecode
r547 % repo_name, category='error')
return redirect(url('edit_repo', repo_name=changed_name))
Fixes for raw_id, needed for git...
r636
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
renamed project to rhodecode
r547 def delete(self, repo_name):
implemented public journal for anonymous users, admin can control which repositories...
r1085 """
DELETE /repos/repo_name: Delete an existing item"""
renamed project to rhodecode
r547 # Forms posted to this method should contain a hidden field:
# <input type="hidden" name="_method" value="DELETE" />
# Or using helpers:
# h.form(url('repo', repo_name=ID),
# method='delete')
# url('repo', repo_name=ID)
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 repo_model = RepoModel()
added action loggers to following repositories,...
r735 repo = repo_model.get_by_repo_name(repo_name)
renamed project to rhodecode
r547 if not repo:
- #683 fixed difference between messages about not mapped repositories
r3110 h.not_mapped_error(repo_name)
renamed project to rhodecode
r547 return redirect(url('repos'))
try:
implemented #689 Deleting Repositories with Forks Should Be Easier...
r3391 _forks = repo.forks.count()
recursive forks detach...
r3641 handle_forks = None
implemented #689 Deleting Repositories with Forks Should Be Easier...
r3391 if _forks and request.POST.get('forks'):
do = request.POST['forks']
if do == 'detach_forks':
recursive forks detach...
r3641 handle_forks = 'detach'
Mads Kiilerich
consistently capitalize initial letter in flash messages
r3565 h.flash(_('Detached %s forks') % _forks, category='success')
implemented #689 Deleting Repositories with Forks Should Be Easier...
r3391 elif do == 'delete_forks':
recursive forks detach...
r3641 handle_forks = 'delete'
Mads Kiilerich
consistently capitalize initial letter in flash messages
r3565 h.flash(_('Deleted %s forks') % _forks, category='success')
recursive forks detach...
r3641 repo_model.delete(repo, forks=handle_forks)
refactor codes and setup for python 2.5...
r564 action_logger(self.rhodecode_user, 'admin_deleted_repo',
recursive forks detach...
r3641 repo_name, self.ip_addr, self.sa)
removed duplicated logic of how we invalidate caches for repos
r3693 ScmModel().mark_for_invalidation(repo_name)
Mads Kiilerich
consistently capitalize initial letter in flash messages
r3565 h.flash(_('Deleted repository %s') % repo_name, category='success')
sqlalchemy sessions cleanup in admin...
r2662 Session().commit()
recursive forks detach...
r3641 except AttachedForksError:
h.flash(_('Cannot delete %s it still contains attached forks')
% repo_name, category='warning')
fixed #47 adding a new repo that have a group chosen had wrong paths.
r1361
recursive forks detach...
r3641 except Exception:
renamed project to rhodecode
r547 log.error(traceback.format_exc())
fixed spelling mistakes, and some minor docs bugs
r860 h.flash(_('An error occurred during deletion of %s') % repo_name,
renamed project to rhodecode
r547 category='error')
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 return redirect(url('repos'))
Fixes for raw_id, needed for git...
r636
white space cleanup
r1869 @HasRepoPermissionAllDecorator('repository.admin')
moved permission management into separate entity....
r3628 def set_repo_perm_member(self, repo_name):
form = RepoPermsForm()().to_python(request.POST)
- Manage User’s Groups: create, delete, rename, add/remove users inside....
r3714 RepoModel()._update_permissions(repo_name, form['perms_new'],
form['perms_updates'])
moved permission management into separate entity....
r3628 #TODO: implement this
#action_logger(self.rhodecode_user, 'admin_changed_repo_permissions',
# repo_name, self.ip_addr, self.sa)
Session().commit()
Mads Kiilerich
Fix a lot of casings - use standard casing in most places
r3654 h.flash(_('Repository permissions updated'), category='success')
moved permission management into separate entity....
r3628 return redirect(url('edit_repo', repo_name=repo_name))
@HasRepoPermissionAllDecorator('repository.admin')
consistent handling of grant/revoke of permissions widgets...
r3715 def delete_repo_perm_member(self, repo_name):
implemented public journal for anonymous users, admin can control which repositories...
r1085 """
DELETE an existing repository permission user
source code cleanup: remove trailing white space, normalize file endings
r1203
fixed @repo into :repo for docs...
r604 :param repo_name:
renamed project to rhodecode
r547 """
try:
consistent handling of grant/revoke of permissions widgets...
r3715 obj_type = request.POST.get('obj_type')
obj_id = None
if obj_type == 'user':
obj_id = safe_int(request.POST.get('user_id'))
elif obj_type == 'user_group':
obj_id = safe_int(request.POST.get('user_group_id'))
if obj_type == 'user':
RepoModel().revoke_user_permission(repo=repo_name, user=obj_id)
elif obj_type == 'user_group':
RepoModel().revoke_users_group_permission(
repo=repo_name, group_name=obj_id
)
moved permission management into separate entity....
r3628 #TODO: implement this
#action_logger(self.rhodecode_user, 'admin_revoked_repo_permissions',
# repo_name, self.ip_addr, self.sa)
sqlalchemy sessions cleanup in admin...
r2662 Session().commit()
#227 Initial version of repository groups permissions system...
r1982 except Exception:
log.error(traceback.format_exc())
consistent handling of grant/revoke of permissions widgets...
r3715 h.flash(_('An error occurred during revoking of permission'),
#56 added ajax removal of users groups,...
r1015 category='error')
raise HTTPInternalServerError()
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
#56 added ajax removal of users groups,...
r1015 def repo_stats(self, repo_name):
implemented public journal for anonymous users, admin can control which repositories...
r1085 """
DELETE an existing repository statistics
source code cleanup: remove trailing white space, normalize file endings
r1203
added cache reset, stats reset, and delete into repository settings in admin....
r708 :param repo_name:
"""
try:
#227 Initial version of repository groups permissions system...
r1982 RepoModel().delete_stats(repo_name)
sqlalchemy sessions cleanup in admin...
r2662 Session().commit()
added cache reset, stats reset, and delete into repository settings in admin....
r708 except Exception, e:
Implemented basic locking functionality....
r2726 log.error(traceback.format_exc())
fixed spelling mistakes, and some minor docs bugs
r860 h.flash(_('An error occurred during deletion of repository stats'),
added cache reset, stats reset, and delete into repository settings in admin....
r708 category='error')
return redirect(url('edit_repo', repo_name=repo_name))
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
added cache reset, stats reset, and delete into repository settings in admin....
r708 def repo_cache(self, repo_name):
implemented public journal for anonymous users, admin can control which repositories...
r1085 """
INVALIDATE existing repository cache
source code cleanup: remove trailing white space, normalize file endings
r1203
added cache reset, stats reset, and delete into repository settings in admin....
r708 :param repo_name:
"""
try:
ScmModel().mark_for_invalidation(repo_name)
sqlalchemy sessions cleanup in admin...
r2662 Session().commit()
added cache reset, stats reset, and delete into repository settings in admin....
r708 except Exception, e:
Implemented basic locking functionality....
r2726 log.error(traceback.format_exc())
fixed error for empty revisions on admin repo edit
r711 h.flash(_('An error occurred during cache invalidation'),
added cache reset, stats reset, and delete into repository settings in admin....
r708 category='error')
return redirect(url('edit_repo', repo_name=repo_name))
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
Implemented basic locking functionality....
r2726 def repo_locking(self, repo_name):
"""
Unlock repository when it is locked !
:param repo_name:
"""
try:
repo = Repository.get_by_repo_name(repo_name)
if request.POST.get('set_lock'):
Repository.lock(repo, c.rhodecode_user.user_id)
elif request.POST.get('set_unlock'):
Repository.unlock(repo)
except Exception, e:
log.error(traceback.format_exc())
h.flash(_('An error occurred during unlocking'),
category='error')
return redirect(url('edit_repo', repo_name=repo_name))
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAnyDecorator('repository.write', 'repository.admin')
def toggle_locking(self, repo_name):
"""
Toggle locking of repository by simple GET call to url
:param repo_name:
"""
try:
repo = Repository.get_by_repo_name(repo_name)
if repo.enable_locking:
if repo.locked[0]:
Repository.unlock(repo)
Mads Kiilerich
Fix a lot of casings - use standard casing in most places
r3654 action = _('Unlocked')
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 else:
Repository.lock(repo, c.rhodecode_user.user_id)
Mads Kiilerich
Fix a lot of casings - use standard casing in most places
r3654 action = _('Locked')
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629
h.flash(_('Repository has been %s') % action,
category='success')
except Exception, e:
log.error(traceback.format_exc())
h.flash(_('An error occurred during unlocking'),
category='error')
return redirect(url('summary_home', repo_name=repo_name))
@HasRepoPermissionAllDecorator('repository.admin')
implemented public journal for anonymous users, admin can control which repositories...
r1085 def repo_public_journal(self, repo_name):
"""
Set's this repository to be visible in public journal,
in other words assing default user to follow this repo
source code cleanup: remove trailing white space, normalize file endings
r1203
implemented public journal for anonymous users, admin can control which repositories...
r1085 :param repo_name:
"""
cur_token = request.POST.get('auth_token')
token = get_token()
if cur_token == token:
try:
Refactoring of model get functions
r1530 repo_id = Repository.get_by_repo_name(repo_name).repo_id
New default permissions definition for user group create
r3734 user_id = User.get_default_user().user_id
implemented public journal for anonymous users, admin can control which repositories...
r1085 self.scm_model.toggle_following_repo(repo_id, user_id)
h.flash(_('Updated repository visibility in public journal'),
category='success')
sqlalchemy sessions cleanup in admin...
r2662 Session().commit()
Don't catch all exceptions
r3631 except Exception:
implemented public journal for anonymous users, admin can control which repositories...
r1085 h.flash(_('An error occurred during setting this'
' repository in public journal'),
category='error')
else:
h.flash(_('Token mismatch'), category='error')
return redirect(url('edit_repo', repo_name=repo_name))
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
#109, added manual pull of changes for repositories that have remote location filled in....
r1114 def repo_pull(self, repo_name):
"""
Runs task to update given repository with remote changes,
ie. make pull on remote location
source code cleanup: remove trailing white space, normalize file endings
r1203
#109, added manual pull of changes for repositories that have remote location filled in....
r1114 :param repo_name:
"""
try:
replaced all global calls to template context (rhodecode_user), into instance attributes
r1121 ScmModel().pull_changes(repo_name, self.rhodecode_user.username)
#109, added manual pull of changes for repositories that have remote location filled in....
r1114 h.flash(_('Pulled from remote location'), category='success')
except Exception, e:
move out setting rc_extras for in-memory-push handlers to separate function
r3826 log.error(traceback.format_exc())
#109, added manual pull of changes for repositories that have remote location filled in....
r1114 h.flash(_('An error occurred during pull from remote location'),
category='error')
implemented public journal for anonymous users, admin can control which repositories...
r1085
#109, added manual pull of changes for repositories that have remote location filled in....
r1114 return redirect(url('edit_repo', repo_name=repo_name))
implemented public journal for anonymous users, admin can control which repositories...
r1085
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
implements #239 manual marking of repos as forks for admins
r1755 def repo_as_fork(self, repo_name):
"""
Mark given repository as a fork of another
auto white-space removal
r1818
implements #239 manual marking of repos as forks for admins
r1755 :param repo_name:
"""
try:
fork_id = request.POST.get('id_fork_of')
repo = ScmModel().mark_as_fork(repo_name, fork_id,
self.rhodecode_user.username)
fork = repo.fork.repo_name if repo.fork else _('Nothing')
Fixed issue #501 error on setting set_as_fork to same repo...
r2629 Session().commit()
h.flash(_('Marked repo %s as fork of %s') % (repo_name, fork),
implements #239 manual marking of repos as forks for admins
r1755 category='success')
except Exception, e:
Fixed issue #501 error on setting set_as_fork to same repo...
r2629 log.error(traceback.format_exc())
implements #239 manual marking of repos as forks for admins
r1755 h.flash(_('An error occurred during this operation'),
category='error')
return redirect(url('edit_repo', repo_name=repo_name))
@HasPermissionAllDecorator('hg.admin')
renamed project to rhodecode
r547 def show(self, repo_name, format='html'):
"""GET /repos/repo_name: Show a specific item"""
# url('repo', repo_name=ID)
Fixes for raw_id, needed for git...
r636
#749 and #516 Removed dupliciting of repo settings for rhodecode admins and repo admins...
r3629 @HasRepoPermissionAllDecorator('repository.admin')
renamed project to rhodecode
r547 def edit(self, repo_name, format='html'):
"""GET /repos/repo_name/edit: Form to edit an existing item"""
# url('edit_repo', repo_name=ID)
#109, added optional clone uri when creating repo....
r1112 defaults = self.__load_data(repo_name)
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 return htmlfill.render(
render('admin/repos/repo_edit.html'),
defaults=defaults,
encoding="UTF-8",
force_defaults=False
Fixes for raw_id, needed for git...
r636 )
repository extra fields implementation...
r3308
@HasPermissionAllDecorator('hg.admin')
def create_repo_field(self, repo_name):
try:
form_result = RepoFieldForm()().to_python(dict(request.POST))
new_field = RepositoryField()
new_field.repository = Repository.get_by_repo_name(repo_name)
new_field.field_key = form_result['new_field_key']
new_field.field_type = form_result['new_field_type'] # python type
new_field.field_value = form_result['new_field_value'] # set initial blank value
new_field.field_desc = form_result['new_field_desc']
new_field.field_label = form_result['new_field_label']
Session().add(new_field)
Session().commit()
except Exception, e:
log.error(traceback.format_exc())
msg = _('An error occurred during creation of field')
if isinstance(e, formencode.Invalid):
msg += ". " + e.msg
h.flash(msg, category='error')
return redirect(url('edit_repo', repo_name=repo_name))
@HasPermissionAllDecorator('hg.admin')
def delete_repo_field(self, repo_name, field_id):
field = RepositoryField.get_or_404(field_id)
try:
Session().delete(field)
Session().commit()
except Exception, e:
log.error(traceback.format_exc())
msg = _('An error occurred during removal of field')
h.flash(msg, category='error')
return redirect(url('edit_repo', repo_name=repo_name))