loops/organize/member.py
helmutm a70fe7d830 Work in progress: self-service registration (member registration)
git-svn-id: svn://svn.cy55.de/Zope3/src/loops/trunk@1220 fd906abe-77d9-0310-91a1-e0d9ade77398
2006-05-22 15:46:31 +00:00

88 lines
3.3 KiB
Python

#
# Copyright (c) 2006 Helmut Merz helmutm@cy55.de
#
# 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 2 of the License, or
# (at your option) any later version.
#
# 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
"""
Member registration adapter(s).
$Id$
"""
from zope.app import zapi
from zope import interface, component
from zope.component import adapts
from zope.interface import implements
from zope.app.authentication.interfaces import IPluggableAuthentication
from zope.app.authentication.interfaces import IAuthenticatorPlugin
from zope.app.authentication.principalfolder import InternalPrincipal
from zope.app.security.interfaces import IAuthentication
from zope.i18nmessageid import MessageFactory
from zope.cachedescriptors.property import Lazy
from cybertools.typology.interfaces import IType
from loops.interfaces import ILoops
from loops.concept import Concept
from loops.organize.interfaces import IMemberRegistrationManager
from loops.organize.interfaces import raiseValidationError
_ = MessageFactory('zope')
class MemberRegistrationManager(object):
implements(IMemberRegistrationManager)
adapts(ILoops)
authPluginId = 'loops'
def __init__(self, context):
self.context = context
def register(self, userId, password, lastName, firstName=u'', **kw):
# step 1: create an internal principal in the loops principal folder:
pau = zapi.getUtility(IAuthentication, context=self.context)
if not IPluggableAuthentication.providedBy(pau):
raiseValidationError(_(u'There is no pluggable authentication '
'utility available.'))
if not self.authPluginId in pau.authenticatorPlugins:
raiseValidationError(_(u'There is no loops authenticator '
'plugin available.'))
pFolder = component.queryUtility(IAuthenticatorPlugin, self.authPluginId,
context=pau)
title = firstName and ' '.join((firstName, lastName)) or lastName
# TODO: encrypt password:
principal = InternalPrincipal(userId, password, title)
pFolder[userId] = principal
# step 1: create a corresponding person concept:
cm = self.context.getConceptManager()
id = userId
num = 0
while id in cm:
num +=1
id = userid + str(num)
person = cm[id] = Concept(title)
# TODO: the name of the person type object must be kept flexible!
person.conceptType = cm['person']
personAdapter = IType(person).typeInterface(person)
personAdapter.firstName = firstName
personAdapter.lastName = lastName
personAdapter.userId = '.'.join((self.authPluginId, userId))
return personAdapter
def changePassword(self, oldPw, newPw):
pass