##// END OF EJS Templates
integrations: remoed utf8 markers
integrations: remoed utf8 markers

File last commit:

r5053:8da271d0 default
r5063:27cbd2f1 default
Show More
repo_group_advanced.py
105 lines | 4.0 KiB | text/x-python | PythonLexer
apps: removed utf8 marker
r5053
repo-groups: moved to pyramid
r2175
code: update copyrights to 2020
r4306 # Copyright (C) 2011-2020 RhodeCode GmbH
repo-groups: moved to pyramid
r2175 #
# 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/
import logging
application: not use config.scan(), and replace all @add_view decorator into a explicit add_view call for faster app start.
r4610
repo-groups: moved to pyramid
r2175 from pyramid.httpexceptions import HTTPFound
from rhodecode.apps._base import RepoGroupAppView
from rhodecode.lib import helpers as h
from rhodecode.lib import audit_logger
from rhodecode.lib.auth import (
LoginRequired, CSRFRequired, HasRepoGroupPermissionAnyDecorator)
from rhodecode.model.repo_group import RepoGroupModel
from rhodecode.model.meta import Session
log = logging.getLogger(__name__)
application: not use config.scan(), and replace all @add_view decorator into a explicit add_view call for faster app start.
r4610 class RepoGroupAdvancedSettingsView(RepoGroupAppView):
repo-groups: moved to pyramid
r2175 def load_default_context(self):
c = self._get_local_tmpl_context()
return c
@LoginRequired()
@HasRepoGroupPermissionAnyDecorator('group.admin')
def edit_repo_group_advanced(self):
dan
cache-commits: add option to refresh caches manually from advanced pages.
r4159 _ = self.request.translate
repo-groups: moved to pyramid
r2175 c = self.load_default_context()
c.active = 'advanced'
c.repo_group = self.db_repo_group
dan
cache-commits: add option to refresh caches manually from advanced pages.
r4159
# update commit cache if GET flag is present
if self.request.GET.get('update_commit_cache'):
self.db_repo_group.update_commit_cache()
h.flash(_('updated commit cache'), category='success')
repo-groups: moved to pyramid
r2175 return self._get_template_context(c)
@LoginRequired()
@HasRepoGroupPermissionAnyDecorator('group.admin')
@CSRFRequired()
def edit_repo_group_delete(self):
_ = self.request.translate
_ungettext = self.request.plularize
c = self.load_default_context()
c.repo_group = self.db_repo_group
repos = c.repo_group.repositories.all()
if repos:
msg = _ungettext(
'This repository group contains %(num)d repository and cannot be deleted',
'This repository group contains %(num)d repositories and cannot be'
' deleted',
len(repos)) % {'num': len(repos)}
h.flash(msg, category='warning')
raise HTTPFound(
h.route_path('edit_repo_group_advanced',
repo_group_name=self.db_repo_group_name))
children = c.repo_group.children.all()
if children:
msg = _ungettext(
'This repository group contains %(num)d subgroup and cannot be deleted',
'This repository group contains %(num)d subgroups and cannot be deleted',
len(children)) % {'num': len(children)}
h.flash(msg, category='warning')
raise HTTPFound(
h.route_path('edit_repo_group_advanced',
repo_group_name=self.db_repo_group_name))
try:
old_values = c.repo_group.get_api_data()
RepoGroupModel().delete(self.db_repo_group_name)
audit_logger.store_web(
'repo_group.delete', action_data={'old_data': old_values},
user=c.rhodecode_user)
Session().commit()
h.flash(_('Removed repository group `%s`') % self.db_repo_group_name,
category='success')
except Exception:
log.exception("Exception during deletion of repository group")
h.flash(_('Error occurred during deletion of repository group %s')
% self.db_repo_group_name, category='error')
raise HTTPFound(h.route_path('repo_groups'))