settings.py
190 lines
| 7.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 | ||||
r1824 | :copyright: (C) 2010-2012 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 | ||||
r2833 | from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAllDecorator,\ | |||
HasRepoPermissionAnyDecorator | ||||
r1045 | from rhodecode.lib.base import BaseRepoController, render | |||
r547 | from rhodecode.lib.utils import invalidate_cache, action_logger | |||
r1056 | ||||
r1722 | from rhodecode.model.forms import RepoSettingsForm | |||
r629 | from rhodecode.model.repo import RepoModel | |||
r2833 | from rhodecode.model.db import RepoGroup, Repository | |||
r1722 | from rhodecode.model.meta import Session | |||
r2460 | from rhodecode.model.scm import ScmModel | |||
r547 | ||||
log = logging.getLogger(__name__) | ||||
r1212 | ||||
r1045 | class SettingsController(BaseRepoController): | |||
r547 | ||||
@LoginRequired() | ||||
def __before__(self): | ||||
super(SettingsController, self).__before__() | ||||
r1722 | ||||
r1594 | def __load_defaults(self): | |||
r2835 | c.repo_groups = RepoGroup.groups_choices(check_perms=True) | |||
r1594 | c.repo_groups_choices = map(lambda k: unicode(k[0]), c.repo_groups) | |||
r1722 | ||||
r1594 | repo_model = RepoModel() | |||
c.users_array = repo_model.get_users_js() | ||||
c.users_groups_array = repo_model.get_users_groups_js() | ||||
r2460 | choices, c.landing_revs = ScmModel().get_repo_landing_revs() | |||
c.landing_revs_choices = choices | ||||
r1722 | ||||
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 | ||||
r1722 | ||||
r1594 | self.__load_defaults() | |||
r1722 | ||||
r1212 | _form = RepoSettingsForm(edit=True, | |||
r1594 | old_data={'repo_name': repo_name}, | |||
r2460 | repo_groups=c.repo_groups_choices, | |||
landing_revs=c.landing_revs_choices)() | ||||
r547 | try: | |||
form_result = _form.to_python(dict(request.POST)) | ||||
r1722 | ||||
r547 | repo_model.update(repo_name, form_result) | |||
r665 | invalidate_cache('get_repo_cached_%s' % repo_name) | |||
Takumi IINO
|
r2570 | h.flash(_('Repository %s updated successfully') % repo_name, | ||
r547 | category='success') | |||
r1594 | changed_name = form_result['repo_name_full'] | |||
r660 | action_logger(self.rhodecode_user, 'user_updated_repo', | |||
r2375 | changed_name, self.ip_addr, self.sa) | |||
r2833 | Session().commit() | |||
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', | |||
r2375 | repo_name, self.ip_addr, self.sa) | |||
r636 | repo_model.delete(repo) | |||
r665 | invalidate_cache('get_repo_cached_%s' % repo_name) | |||
r547 | h.flash(_('deleted repository %s') % repo_name, category='success') | |||
r2833 | Session().commit() | |||
r547 | except Exception: | |||
r1366 | log.error(traceback.format_exc()) | |||
r547 | h.flash(_('An error occurred during deletion of %s') % repo_name, | |||
category='error') | ||||
r636 | ||||
r3083 | return redirect(url('admin_settings_my_account', anchor='my')) | |||
r2833 | ||||
@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) | ||||
action = _('unlocked') | ||||
else: | ||||
Repository.lock(repo, c.rhodecode_user.user_id) | ||||
action = _('locked') | ||||
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)) | ||||