##// END OF EJS Templates
Added separate create repository views for non administrative users....
Added separate create repository views for non administrative users. Fixed permission issue with private repos

File last commit:

r371:5cd6616b default
r380:ca54622e default
Show More
user_model.py
126 lines | 4.1 KiB | text/x-python | PythonLexer
Rewrite of user managment, improved forms, added some user info
r238 #!/usr/bin/env python
# encoding: utf-8
licensing updates, code cleanups
r252 # Model for users
# 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 April 9, 2010
Model for users
@author: marcink
"""
Rewrite of user managment, improved forms, added some user info
r238 from pylons_app.model.db import User
from pylons_app.model.meta import Session
protected againts changing default user.
r314 from pylons.i18n.translation import _
Implemented basic repository managment. Implemented repo2db mappings, model, helpers updates and code cleanups
r265 import logging
log = logging.getLogger(__name__)
Rewrite of user managment, improved forms, added some user info
r238
protected againts changing default user.
r314 class DefaultUserException(Exception):pass
Rewrite of user managment, improved forms, added some user info
r238 class UserModel(object):
def __init__(self):
self.sa = Session()
def get_user(self, id):
return self.sa.query(User).get(id)
def create(self, form_data):
try:
new_user = User()
for k, v in form_data.items():
setattr(new_user, k, v)
self.sa.add(new_user)
self.sa.commit()
Implemented basic repository managment. Implemented repo2db mappings, model, helpers updates and code cleanups
r265 except Exception as e:
log.error(e)
Rewrite of user managment, improved forms, added some user info
r238 self.sa.rollback()
raise
Added user registration, changed login url schema, moved it into _admin/ for safety
r363 def create_registration(self, form_data):
try:
new_user = User()
for k, v in form_data.items():
if k != 'admin' or k != 'active':
setattr(new_user, k, v)
setattr(new_user, 'active', True)
self.sa.add(new_user)
self.sa.commit()
except Exception as e:
log.error(e)
self.sa.rollback()
raise
routes python 2.5 compatible...
r371 def update(self, uid, form_data):
Rewrite of user managment, improved forms, added some user info
r238 try:
routes python 2.5 compatible...
r371 new_user = self.sa.query(User).get(uid)
protected againts changing default user.
r314 if new_user.username == 'default':
raise DefaultUserException(
_("You can't Edit this user since it's"
" crucial for entire application"))
Rewrite of user managment, improved forms, added some user info
r238 for k, v in form_data.items():
if k == 'new_password' and v != '':
new_user.password = v
else:
setattr(new_user, k, v)
self.sa.add(new_user)
self.sa.commit()
Implemented basic repository managment. Implemented repo2db mappings, model, helpers updates and code cleanups
r265 except Exception as e:
log.error(e)
Rewrite of user managment, improved forms, added some user info
r238 self.sa.rollback()
raise
routes python 2.5 compatible...
r371
def update_my_account(self, uid, form_data):
try:
new_user = self.sa.query(User).get(uid)
if new_user.username == 'default':
raise DefaultUserException(
_("You can't Edit this user since it's"
" crucial for entire application"))
for k, v in form_data.items():
if k == 'new_password' and v != '':
new_user.password = v
else:
if k not in ['admin', 'active']:
setattr(new_user, k, v)
self.sa.add(new_user)
self.sa.commit()
except Exception as e:
log.error(e)
self.sa.rollback()
raise
Implemented basic repository managment. Implemented repo2db mappings, model, helpers updates and code cleanups
r265 def delete(self, id):
protected againts changing default user.
r314
Implemented basic repository managment. Implemented repo2db mappings, model, helpers updates and code cleanups
r265 try:
protected againts changing default user.
r314
user = self.sa.query(User).get(id)
if user.username == 'default':
raise DefaultUserException(
_("You can't remove this user since it's"
" crucial for entire application"))
self.sa.delete(user)
Implemented basic repository managment. Implemented repo2db mappings, model, helpers updates and code cleanups
r265 self.sa.commit()
except Exception as e:
log.error(e)
self.sa.rollback()
raise