##// END OF EJS Templates
Bumped sqlalchemy version to 0.7, replaced timerproxy with new event system for sqlalchemy....
Bumped sqlalchemy version to 0.7, replaced timerproxy with new event system for sqlalchemy. TimerProxy is now longer valid profilling method for sqlalchemy

File last commit:

r1271:aa7e45ad beta
r1360:1f47adeb beta
Show More
users_groups.py
213 lines | 8.5 KiB | text/x-python | PythonLexer
started working on issue #56
r956 # -*- coding: utf-8 -*-
"""
rhodecode.controllers.admin.users_groups
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Users Groups crud controller for pylons
source code cleanup: remove trailing white space, normalize file endings
r1203
started working on issue #56
r956 :created_on: Jan 25, 2011
:author: marcink
source code cleanup: remove trailing white space, normalize file endings
r1203 :copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com>
started working on issue #56
r956 :license: GPLv3, see COPYING for more details.
"""
fixed license issue #149
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.
source code cleanup: remove trailing white space, normalize file endings
r1203 #
started working on issue #56
r956 # 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.
source code cleanup: remove trailing white space, normalize file endings
r1203 #
started working on issue #56
r956 # You should have received a copy of the GNU General Public License
fixed license issue #149
r1206 # along with this program. If not, see <http://www.gnu.org/licenses/>.
started working on issue #56
r956
import logging
import traceback
import formencode
from formencode import htmlfill
from pylons import request, session, tmpl_context as c, url, config
from pylons.controllers.util import abort, redirect
from pylons.i18n.translation import _
from rhodecode.lib import helpers as h
Major rewrite of auth objects. Moved parts of filling user data into user model....
r1117 from rhodecode.lib.auth import LoginRequired, HasPermissionAllDecorator
started working on issue #56
r956 from rhodecode.lib.base import BaseController, render
Fixed permissions for users groups, group can have create repo permission now....
r1271 from rhodecode.model.db import User, UsersGroup, Permission, UsersGroupToPerm
#56 fixed found bugs, implemented adding of new group + forms+validators...
r959 from rhodecode.model.forms import UserForm, UsersGroupForm
from rhodecode.model.users_group import UsersGroupModel
started working on issue #56
r956
log = logging.getLogger(__name__)
PEP8ify - controllers
r1245
started working on issue #56
r956 class UsersGroupsController(BaseController):
"""REST Controller styled on the Atom Publishing Protocol"""
# To properly map this controller, ensure your config/routing.py
# file has a resource setup:
# map.resource('users_group', 'users_groups')
@LoginRequired()
@HasPermissionAllDecorator('hg.admin')
def __before__(self):
c.admin_user = session.get('admin_user')
c.admin_username = session.get('admin_username')
super(UsersGroupsController, self).__before__()
c.available_permissions = config['available_permissions']
def index(self, format='html'):
"""GET /users_groups: All items in the collection"""
# url('users_groups')
#56 fixed found bugs, implemented adding of new group + forms+validators...
r959 c.users_groups_list = self.sa.query(UsersGroup).all()
started working on issue #56
r956 return render('admin/users_groups/users_groups.html')
def create(self):
"""POST /users_groups: Create a new item"""
# url('users_groups')
#56 fixed found bugs, implemented adding of new group + forms+validators...
r959 users_group_model = UsersGroupModel()
users_group_form = UsersGroupForm()()
try:
form_result = users_group_form.to_python(dict(request.POST))
users_group_model.create(form_result)
PEP8ify - controllers
r1245 h.flash(_('created users group %s') \
% form_result['users_group_name'], category='success')
#56 fixed found bugs, implemented adding of new group + forms+validators...
r959 #action_logger(self.rhodecode_user, 'new_user', '', '', self.sa)
except formencode.Invalid, errors:
return htmlfill.render(
render('admin/users_groups/users_group_add.html'),
defaults=errors.value,
errors=errors.error_dict or {},
prefix_error=False,
encoding="UTF-8")
except Exception:
log.error(traceback.format_exc())
h.flash(_('error occurred during creation of users group %s') \
% request.POST.get('users_group_name'), category='error')
return redirect(url('users_groups'))
started working on issue #56
r956
def new(self, format='html'):
"""GET /users_groups/new: Form to create a new item"""
# url('new_users_group')
#56 fixed found bugs, implemented adding of new group + forms+validators...
r959 return render('admin/users_groups/users_group_add.html')
started working on issue #56
r956
def update(self, id):
"""PUT /users_groups/id: Update an existing item"""
# Forms posted to this method should contain a hidden field:
# <input type="hidden" name="_method" value="PUT" />
# Or using helpers:
# h.form(url('users_group', id=ID),
# method='put')
# url('users_group', id=ID)
#56 implemented users groups editing,...
r972 users_group_model = UsersGroupModel()
c.users_group = users_group_model.get(id)
c.group_members = [(x.user_id, x.user.username) for x in
c.users_group.members]
c.available_members = [(x.user_id, x.username) for x in
self.sa.query(User).all()]
users_group_form = UsersGroupForm(edit=True,
old_data=c.users_group.get_dict(),
available_members=[str(x[0]) for x
in c.available_members])()
try:
form_result = users_group_form.to_python(request.POST)
users_group_model.update(id, form_result)
PEP8ify - controllers
r1245 h.flash(_('updated users group %s') \
% form_result['users_group_name'],
#56 implemented users groups editing,...
r972 category='success')
#action_logger(self.rhodecode_user, 'new_user', '', '', self.sa)
except formencode.Invalid, errors:
Fixed permissions for users groups, group can have create repo permission now....
r1271 e = errors.error_dict or {}
perm = Permission.get_by_key('hg.create.repository')
e.update({'create_repo_perm':
UsersGroupToPerm.has_perm(id, perm)})
#56 implemented users groups editing,...
r972 return htmlfill.render(
render('admin/users_groups/users_group_edit.html'),
defaults=errors.value,
Fixed permissions for users groups, group can have create repo permission now....
r1271 errors=e,
#56 implemented users groups editing,...
r972 prefix_error=False,
encoding="UTF-8")
except Exception:
log.error(traceback.format_exc())
h.flash(_('error occurred during update of users group %s') \
% request.POST.get('users_group_name'), category='error')
return redirect(url('users_groups'))
started working on issue #56
r956 def delete(self, id):
"""DELETE /users_groups/id: 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('users_group', id=ID),
# method='delete')
# url('users_group', id=ID)
#56 implemented users groups deletes
r973 users_group_model = UsersGroupModel()
try:
users_group_model.delete(id)
h.flash(_('successfully deleted users group'), category='success')
except Exception:
h.flash(_('An error occurred during deletion of users group'),
category='error')
return redirect(url('users_groups'))
started working on issue #56
r956
def show(self, id, format='html'):
"""GET /users_groups/id: Show a specific item"""
# url('users_group', id=ID)
def edit(self, id, format='html'):
"""GET /users_groups/id/edit: Form to edit an existing item"""
# url('edit_users_group', id=ID)
#56 implemented users groups editing,...
r972
c.users_group = self.sa.query(UsersGroup).get(id)
if not c.users_group:
return redirect(url('users_groups'))
c.users_group.permissions = {}
c.group_members = [(x.user_id, x.user.username) for x in
c.users_group.members]
c.available_members = [(x.user_id, x.username) for x in
self.sa.query(User).all()]
defaults = c.users_group.get_dict()
Fixed permissions for users groups, group can have create repo permission now....
r1271 perm = Permission.get_by_key('hg.create.repository')
defaults.update({'create_repo_perm':
UsersGroupToPerm.has_perm(id, perm)})
#56 implemented users groups editing,...
r972 return htmlfill.render(
render('admin/users_groups/users_group_edit.html'),
defaults=defaults,
encoding="UTF-8",
force_defaults=False
)
Fixed permissions for users groups, group can have create repo permission now....
r1271
def update_perm(self, id):
"""PUT /users_perm/id: Update an existing item"""
# url('users_group_perm', id=ID, method='put')
grant_perm = request.POST.get('create_repo_perm', False)
if grant_perm:
perm = Permission.get_by_key('hg.create.none')
UsersGroupToPerm.revoke_perm(id, perm)
perm = Permission.get_by_key('hg.create.repository')
UsersGroupToPerm.grant_perm(id, perm)
h.flash(_("Granted 'repository create' permission to user"),
category='success')
else:
perm = Permission.get_by_key('hg.create.repository')
UsersGroupToPerm.revoke_perm(id, perm)
perm = Permission.get_by_key('hg.create.none')
UsersGroupToPerm.grant_perm(id, perm)
h.flash(_("Revoked 'repository create' permission to user"),
category='success')
return redirect(url('edit_users_group', id=id))