##// END OF EJS Templates
changes transient to expunge on cached repo instances, due to odd very rare problems with previos approach.
changes transient to expunge on cached repo instances, due to odd very rare problems with previos approach.

File last commit:

r735:dbec976d beta
r753:ee801aa6 beta
Show More
settings.py
178 lines | 7.1 KiB | text/x-python | PythonLexer
renamed project to rhodecode
r547 #!/usr/bin/env python
# encoding: utf-8
# settings controller for pylons
# Copyright (C) 2009-2010 Marcin Kuzminski <marcin@python-works.com>
#
# 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; version 2
# of the License or (at your opinion) any later version of the license.
#
# 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 General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
# MA 02110-1301, USA.
"""
Created on June 30, 2010
settings controller for pylons
@author: marcink
"""
from formencode import htmlfill
from pylons import tmpl_context as c, request, url
from pylons.controllers.util import redirect
from pylons.i18n.translation import _
from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAllDecorator
from rhodecode.lib.base import BaseController, render
from rhodecode.lib.utils import invalidate_cache, action_logger
from rhodecode.model.forms import RepoSettingsForm, RepoForkForm
Code refactoring,models renames...
r629 from rhodecode.model.repo import RepoModel
renamed project to rhodecode
r547 import formencode
import logging
import rhodecode.lib.helpers as h
import traceback
log = logging.getLogger(__name__)
class SettingsController(BaseController):
@LoginRequired()
Fixes for raw_id, needed for git...
r636 @HasRepoPermissionAllDecorator('repository.admin')
renamed project to rhodecode
r547 def __before__(self):
super(SettingsController, self).__before__()
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 def index(self, repo_name):
repo_model = RepoModel()
added action loggers to following repositories,...
r735 c.repo_info = repo = repo_model.get_by_repo_name(repo_name)
renamed project to rhodecode
r547 if not repo:
Fixes for raw_id, needed for git...
r636 h.flash(_('%s repository is not mapped to db perhaps'
renamed project to rhodecode
r547 ' it was created or renamed from the filesystem'
' please run the application again'
' in order to rescan repositories') % repo_name,
category='error')
Fixes for raw_id, needed for git...
r636
return redirect(url('home'))
renamed project to rhodecode
r547 defaults = c.repo_info.__dict__
defaults.update({'user':c.repo_info.user.username})
c.users_array = repo_model.get_users_js()
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 for p in c.repo_info.repo_to_perm:
Fixes for raw_id, needed for git...
r636 defaults.update({'perm_%s' % p.user.username:
renamed project to rhodecode
r547 p.permission.permission_name})
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 return htmlfill.render(
render('settings/repo_settings.html'),
defaults=defaults,
encoding="UTF-8",
force_defaults=False
Fixes for raw_id, needed for git...
r636 )
renamed project to rhodecode
r547
def update(self, repo_name):
repo_model = RepoModel()
changed_name = repo_name
_form = RepoSettingsForm(edit=True, old_data={'repo_name':repo_name})()
try:
form_result = _form.to_python(dict(request.POST))
repo_model.update(repo_name, form_result)
Moved out reposcan into hg Model....
r665 invalidate_cache('get_repo_cached_%s' % repo_name)
renamed project to rhodecode
r547 h.flash(_('Repository %s updated successfully' % repo_name),
category='success')
Fixes for raw_id, needed for git...
r636 changed_name = form_result['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, 'user_updated_repo',
changed_name, '', self.sa)
refactor codes and setup for python 2.5...
r564 except formencode.Invalid, errors:
added action loggers to following repositories,...
r735 c.repo_info = repo_model.get_by_repo_name(repo_name)
renamed project to rhodecode
r547 c.users_array = repo_model.get_users_js()
errors.value.update({'user':c.repo_info.user.username})
return htmlfill.render(
render('settings/repo_settings.html'),
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())
Moved out reposcan into hg Model....
r665 h.flash(_('error occurred during update of repository %s') \
renamed project to rhodecode
r547 % repo_name, category='error')
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 return redirect(url('repo_settings_home', repo_name=changed_name))
Fixes for raw_id, needed for git...
r636 def delete(self, repo_name):
renamed project to rhodecode
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)
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:
Fixes for raw_id, needed for git...
r636 h.flash(_('%s repository is not mapped to db perhaps'
renamed project to rhodecode
r547 ' it was moved or renamed from the filesystem'
' please run the application again'
' in order to rescan repositories') % repo_name,
category='error')
Fixes for raw_id, needed for git...
r636
return redirect(url('home'))
renamed project to rhodecode
r547 try:
refactor codes and setup for python 2.5...
r564 action_logger(self.rhodecode_user, 'user_deleted_repo',
Fixes for raw_id, needed for git...
r636 repo_name, '', self.sa)
repo_model.delete(repo)
Moved out reposcan into hg Model....
r665 invalidate_cache('get_repo_cached_%s' % repo_name)
renamed project to rhodecode
r547 h.flash(_('deleted repository %s') % repo_name, category='success')
except Exception:
h.flash(_('An error occurred during deletion of %s') % repo_name,
category='error')
Fixes for raw_id, needed for git...
r636
return redirect(url('home'))
renamed project to rhodecode
r547 def fork(self, repo_name):
repo_model = RepoModel()
added action loggers to following repositories,...
r735 c.repo_info = repo = repo_model.get_by_repo_name(repo_name)
renamed project to rhodecode
r547 if not repo:
Fixes for raw_id, needed for git...
r636 h.flash(_('%s repository is not mapped to db perhaps'
renamed project to rhodecode
r547 ' it was created or renamed from the filesystem'
' please run the application again'
' in order to rescan repositories') % repo_name,
category='error')
Fixes for raw_id, needed for git...
r636
return redirect(url('home'))
renamed project to rhodecode
r547 return render('settings/repo_fork.html')
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 def fork_create(self, repo_name):
repo_model = RepoModel()
added action loggers to following repositories,...
r735 c.repo_info = repo_model.get_by_repo_name(repo_name)
extended repo creation by repo type. fixed fork creation to maintain repo type.
r659 _form = RepoForkForm(old_data={'repo_type':c.repo_info.repo_type})()
renamed project to rhodecode
r547 form_result = {}
try:
form_result = _form.to_python(dict(request.POST))
form_result.update({'repo_name':repo_name})
renamed hg_app to rhodecode
r548 repo_model.create_fork(form_result, c.rhodecode_user)
Added fork name to journal...
r718 h.flash(_('forked %s repository as %s') \
renamed project to rhodecode
r547 % (repo_name, form_result['fork_name']),
category='success')
Added fork name to journal...
r718 action_logger(self.rhodecode_user,
'user_forked_repo:%s' % form_result['fork_name'],
repo_name, '', self.sa)
refactor codes and setup for python 2.5...
r564 except formencode.Invalid, errors:
renamed project to rhodecode
r547 c.new_repo = errors.value['fork_name']
r = render('settings/repo_fork.html')
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 return htmlfill.render(
r,
defaults=errors.value,
errors=errors.error_dict or {},
prefix_error=False,
Fixes for raw_id, needed for git...
r636 encoding="UTF-8")
return redirect(url('home'))