repo_strip.py
113 lines
| 4.0 KiB
| text/x-python
|
PythonLexer
r1723 | # -*- coding: utf-8 -*- | |||
r2487 | # Copyright (C) 2017-2018 RhodeCode GmbH | |||
r1723 | # | |||
# 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 | ||||
from pyramid.view import view_config | ||||
from rhodecode.apps._base import RepoAppView | ||||
from rhodecode.lib import audit_logger | ||||
r1809 | from rhodecode.lib import helpers as h | |||
r2014 | from rhodecode.lib.auth import ( | |||
LoginRequired, HasRepoPermissionAnyDecorator, CSRFRequired) | ||||
r1723 | from rhodecode.lib.ext_json import json | |||
log = logging.getLogger(__name__) | ||||
class StripView(RepoAppView): | ||||
def load_default_context(self): | ||||
c = self._get_local_tmpl_context() | ||||
r2351 | ||||
r1723 | return c | |||
@LoginRequired() | ||||
@HasRepoPermissionAnyDecorator('repository.admin') | ||||
@view_config( | ||||
r2014 | route_name='edit_repo_strip', request_method='GET', | |||
r1723 | renderer='rhodecode:templates/admin/repos/repo_edit.mako') | |||
def strip(self): | ||||
c = self.load_default_context() | ||||
c.active = 'strip' | ||||
c.strip_limit = 10 | ||||
return self._get_template_context(c) | ||||
@LoginRequired() | ||||
@HasRepoPermissionAnyDecorator('repository.admin') | ||||
r1811 | @CSRFRequired() | |||
r1723 | @view_config( | |||
route_name='strip_check', request_method='POST', | ||||
renderer='json', xhr=True) | ||||
def strip_check(self): | ||||
from rhodecode.lib.vcs.backends.base import EmptyCommit | ||||
data = {} | ||||
rp = self.request.POST | ||||
for i in range(1, 11): | ||||
chset = 'changeset_id-%d' % (i,) | ||||
check = rp.get(chset) | ||||
r1809 | ||||
r1723 | if check: | |||
data[i] = self.db_repo.get_changeset(rp[chset]) | ||||
if isinstance(data[i], EmptyCommit): | ||||
r1809 | data[i] = {'rev': None, 'commit': h.escape(rp[chset])} | |||
r1723 | else: | |||
data[i] = {'rev': data[i].raw_id, 'branch': data[i].branch, | ||||
r2155 | 'author': h.escape(data[i].author), | |||
'comment': h.escape(data[i].message)} | ||||
r1723 | else: | |||
break | ||||
return data | ||||
@LoginRequired() | ||||
@HasRepoPermissionAnyDecorator('repository.admin') | ||||
r1811 | @CSRFRequired() | |||
r1723 | @view_config( | |||
route_name='strip_execute', request_method='POST', | ||||
renderer='json', xhr=True) | ||||
def strip_execute(self): | ||||
from rhodecode.model.scm import ScmModel | ||||
c = self.load_default_context() | ||||
user = self._rhodecode_user | ||||
rp = self.request.POST | ||||
data = {} | ||||
for idx in rp: | ||||
commit = json.loads(rp[idx]) | ||||
# If someone put two times the same branch | ||||
if commit['branch'] in data.keys(): | ||||
continue | ||||
try: | ||||
ScmModel().strip( | ||||
r2014 | repo=self.db_repo, | |||
r1723 | commit_id=commit['rev'], branch=commit['branch']) | |||
r3061 | log.info('Stripped commit %s from repo `%s` by %s', | |||
commit['rev'], self.db_repo_name, user) | ||||
r1723 | data[commit['rev']] = True | |||
r1806 | audit_logger.store_web( | |||
r1829 | 'repo.commit.strip', action_data={'commit_id': commit['rev']}, | |||
repo=self.db_repo, user=self._rhodecode_user, commit=True) | ||||
r1723 | ||||
except Exception as e: | ||||
data[commit['rev']] = False | ||||
r3061 | log.debug('Stripped commit %s from repo `%s` failed by %s, exeption %s', | |||
commit['rev'], self.db_repo_name, user, e.message) | ||||
r1723 | return data | |||