Mercurial > p > roundup > code
view templates/classic/detectors/userauditor.py @ 2623:4e1030d49cea
fix: Option defaults were applied as strings...
...not converted to internal representation;
add Option methods str2value and value2str for value conversion
from and to the strings kept in .ini file;
options MAIL_USERNAME, MAIL_TLS_KEYFILE and MAIL_TLS_CERTFILE
default to empty strings: NODEFAULT value is a configuration
error, and for these options it is ok to keep them unset.
| author | Alexander Smishlajev <a1s@users.sourceforge.net> |
|---|---|
| date | Sun, 25 Jul 2004 14:36:50 +0000 |
| parents | 00f0267db956 |
| children | 20f63b6b806f |
line wrap: on
line source
# Copyright (c) 2003 Richard Jones (richard@mechanicalcat.net) # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal # in the Software without restriction, including without limitation the rights # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell # copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # SOFTWARE. # #$Id: userauditor.py,v 1.2 2003-11-11 22:25:37 richard Exp $ def audit_user_fields(db, cl, nodeid, newvalues): ''' Make sure user properties are valid. - email address has no spaces in it - roles specified exist ''' if newvalues.has_key('address') and ' ' in newvalues['address']: raise ValueError, 'Email address must not contain spaces' if newvalues.has_key('roles'): roles = [x.lower().strip() for x in newvalues['roles'].split(',')] for rolename in roles: if not db.security.role.has_key(rolename): raise ValueError, 'Role "%s" does not exist'%rolename def init(db): # fire before changes are made db.user.audit('set', audit_user_fields) db.user.audit('create', audit_user_fields) # vim: set filetype=python ts=4 sw=4 et si
