settings.py
208 lines
| 8.1 KiB
| text/x-python
|
PythonLexer
r861 | # -*- coding: utf-8 -*- | |||
""" | ||||
rhodecode.controllers.settings | ||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
Settings controller for rhodecode | ||||
r1203 | ||||
r861 | :created_on: Jun 30, 2010 | |||
:author: marcink | ||||
r1203 | :copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com> | |||
r861 | :license: GPLv3, see COPYING for more details. | |||
""" | ||||
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. | ||||
r1203 | # | |||
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. | ||||
r1203 | # | |||
r547 | # You should have received a copy of the GNU General Public License | |||
r1206 | # along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
r861 | ||||
import logging | ||||
import traceback | ||||
r1067 | import formencode | |||
r861 | ||||
r1067 | from formencode import htmlfill | |||
r861 | ||||
r547 | from pylons import tmpl_context as c, request, url | |||
from pylons.controllers.util import redirect | ||||
from pylons.i18n.translation import _ | ||||
r861 | ||||
import rhodecode.lib.helpers as h | ||||
r1056 | ||||
from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAllDecorator, \ | ||||
r1060 | HasRepoPermissionAnyDecorator, NotAnonymous | |||
r1045 | from rhodecode.lib.base import BaseRepoController, render | |||
r547 | from rhodecode.lib.utils import invalidate_cache, action_logger | |||
r1056 | ||||
r547 | from rhodecode.model.forms import RepoSettingsForm, RepoForkForm | |||
r629 | from rhodecode.model.repo import RepoModel | |||
r1633 | from rhodecode.model.db import RepoGroup | |||
r547 | ||||
log = logging.getLogger(__name__) | ||||
r1212 | ||||
r1045 | class SettingsController(BaseRepoController): | |||
r547 | ||||
@LoginRequired() | ||||
def __before__(self): | ||||
super(SettingsController, self).__before__() | ||||
r1594 | ||||
def __load_defaults(self): | ||||
r1633 | c.repo_groups = RepoGroup.groups_choices() | |||
r1594 | c.repo_groups_choices = map(lambda k: unicode(k[0]), c.repo_groups) | |||
repo_model = RepoModel() | ||||
c.users_array = repo_model.get_users_js() | ||||
c.users_groups_array = repo_model.get_users_groups_js() | ||||
r1054 | @HasRepoPermissionAllDecorator('repository.admin') | |||
r547 | def index(self, repo_name): | |||
repo_model = RepoModel() | ||||
r735 | c.repo_info = repo = repo_model.get_by_repo_name(repo_name) | |||
r547 | if not repo: | |||
r636 | h.flash(_('%s repository is not mapped to db perhaps' | |||
r860 | ' it was created or renamed from the file system' | |||
r547 | ' please run the application again' | |||
' in order to rescan repositories') % repo_name, | ||||
category='error') | ||||
r636 | ||||
return redirect(url('home')) | ||||
r1015 | ||||
r1594 | self.__load_defaults() | |||
r1015 | ||||
r1594 | defaults = RepoModel()._get_defaults(repo_name) | |||
r636 | ||||
r1067 | return htmlfill.render( | |||
r547 | render('settings/repo_settings.html'), | |||
defaults=defaults, | ||||
encoding="UTF-8", | ||||
force_defaults=False | ||||
r636 | ) | |||
r547 | ||||
r1054 | @HasRepoPermissionAllDecorator('repository.admin') | |||
r547 | def update(self, repo_name): | |||
repo_model = RepoModel() | ||||
changed_name = repo_name | ||||
r1594 | ||||
self.__load_defaults() | ||||
r1212 | _form = RepoSettingsForm(edit=True, | |||
r1594 | old_data={'repo_name': repo_name}, | |||
repo_groups=c.repo_groups_choices)() | ||||
r547 | try: | |||
form_result = _form.to_python(dict(request.POST)) | ||||
r1594 | ||||
r547 | repo_model.update(repo_name, form_result) | |||
r665 | invalidate_cache('get_repo_cached_%s' % repo_name) | |||
r547 | h.flash(_('Repository %s updated successfully' % repo_name), | |||
category='success') | ||||
r1594 | changed_name = form_result['repo_name_full'] | |||
r660 | action_logger(self.rhodecode_user, 'user_updated_repo', | |||
r1594 | changed_name, '', self.sa) | |||
r564 | except formencode.Invalid, errors: | |||
r735 | c.repo_info = repo_model.get_by_repo_name(repo_name) | |||
r547 | c.users_array = repo_model.get_users_js() | |||
r1212 | errors.value.update({'user': c.repo_info.user.username}) | |||
r1067 | return htmlfill.render( | |||
r547 | render('settings/repo_settings.html'), | |||
defaults=errors.value, | ||||
errors=errors.error_dict or {}, | ||||
prefix_error=False, | ||||
r636 | encoding="UTF-8") | |||
r547 | except Exception: | |||
log.error(traceback.format_exc()) | ||||
r665 | h.flash(_('error occurred during update of repository %s') \ | |||
r547 | % repo_name, category='error') | |||
r636 | ||||
r547 | return redirect(url('repo_settings_home', repo_name=changed_name)) | |||
r1054 | @HasRepoPermissionAllDecorator('repository.admin') | |||
r636 | def delete(self, repo_name): | |||
r547 | """DELETE /repos/repo_name: Delete an existing item""" | |||
# Forms posted to this method should contain a hidden field: | ||||
# <input type="hidden" name="_method" value="DELETE" /> | ||||
# Or using helpers: | ||||
# h.form(url('repo_settings_delete', repo_name=ID), | ||||
# method='delete') | ||||
# url('repo_settings_delete', repo_name=ID) | ||||
r636 | ||||
r547 | repo_model = RepoModel() | |||
r735 | repo = repo_model.get_by_repo_name(repo_name) | |||
r547 | if not repo: | |||
r636 | h.flash(_('%s repository is not mapped to db perhaps' | |||
r547 | ' it was moved or renamed from the filesystem' | |||
' please run the application again' | ||||
' in order to rescan repositories') % repo_name, | ||||
category='error') | ||||
r636 | ||||
return redirect(url('home')) | ||||
r547 | try: | |||
r564 | action_logger(self.rhodecode_user, 'user_deleted_repo', | |||
r636 | repo_name, '', self.sa) | |||
repo_model.delete(repo) | ||||
r665 | invalidate_cache('get_repo_cached_%s' % repo_name) | |||
r547 | h.flash(_('deleted repository %s') % repo_name, category='success') | |||
except Exception: | ||||
r1366 | log.error(traceback.format_exc()) | |||
r547 | h.flash(_('An error occurred during deletion of %s') % repo_name, | |||
category='error') | ||||
r636 | ||||
return redirect(url('home')) | ||||
r1056 | @NotAnonymous() | |||
r1060 | @HasRepoPermissionAnyDecorator('repository.read', 'repository.write', | |||
'repository.admin') | ||||
r547 | def fork(self, repo_name): | |||
repo_model = RepoModel() | ||||
r735 | c.repo_info = repo = repo_model.get_by_repo_name(repo_name) | |||
r547 | if not repo: | |||
r636 | h.flash(_('%s repository is not mapped to db perhaps' | |||
r860 | ' it was created or renamed from the file system' | |||
r547 | ' please run the application again' | |||
' in order to rescan repositories') % repo_name, | ||||
category='error') | ||||
r636 | ||||
return redirect(url('home')) | ||||
r547 | return render('settings/repo_fork.html') | |||
r636 | ||||
r1056 | @NotAnonymous() | |||
r1060 | @HasRepoPermissionAnyDecorator('repository.read', 'repository.write', | |||
'repository.admin') | ||||
r547 | def fork_create(self, repo_name): | |||
repo_model = RepoModel() | ||||
r735 | c.repo_info = repo_model.get_by_repo_name(repo_name) | |||
r1212 | _form = RepoForkForm(old_data={'repo_type': c.repo_info.repo_type})() | |||
r547 | form_result = {} | |||
try: | ||||
form_result = _form.to_python(dict(request.POST)) | ||||
r1212 | form_result.update({'repo_name': repo_name}) | |||
r1121 | repo_model.create_fork(form_result, self.rhodecode_user) | |||
r718 | h.flash(_('forked %s repository as %s') \ | |||
r547 | % (repo_name, form_result['fork_name']), | |||
category='success') | ||||
r718 | action_logger(self.rhodecode_user, | |||
'user_forked_repo:%s' % form_result['fork_name'], | ||||
repo_name, '', self.sa) | ||||
r564 | except formencode.Invalid, errors: | |||
r547 | c.new_repo = errors.value['fork_name'] | |||
r = render('settings/repo_fork.html') | ||||
r636 | ||||
r1067 | return htmlfill.render( | |||
r547 | r, | |||
defaults=errors.value, | ||||
errors=errors.error_dict or {}, | ||||
prefix_error=False, | ||||
r636 | encoding="UTF-8") | |||
r1366 | except Exception: | |||
log.error(traceback.format_exc()) | ||||
h.flash(_('An error occurred during repository forking %s') % | ||||
repo_name, category='error') | ||||
r636 | return redirect(url('home')) | |||