-##parameters=member_id='', given_name='', name='', member_email='', email_as_login='', password='', confirm='', add='', ajax=''
+##parameters=member_id='', given_name='', name='', member_email='', password='', confirm='', add='', came_from='', ajax=''
##
from Products.CMFCore.utils import getToolByName
from Products.CMFDefault.permissions import ManageUsers
from Products.Plinn.utils import translate
def _(message) : return translate(message, context).encode('utf-8')
-
mtool = getToolByName(script, 'portal_membership')
ptool = getToolByName(script, 'portal_properties')
rtool = getToolByName(script, 'portal_registration')
is_newmember = False
is_usermanager = mtool.checkPermission(ManageUsers, mtool)
-
form = context.REQUEST.form
+email_as_login = bool(form.get('email_as_login', True if context.REQUEST.method == 'GET' else False))
if add :
if validate_email :
password = confirm = rtool.generatePassword()
+ ok = True
else :
ok = context.validatePassword(**form)
- try :
- if email_as_login :
- member_id = member_email
- rtool.addMember(id=member_id, password=password,
- properties={'username': member_id,
- 'given_name' : given_name,
- 'name' : name,
- 'email': member_email})
- context.setStatus(True, _('Success!'))
- except ValueError, errmsg:
- context.setStatus(False, errmsg)
-
-
-
-# if add and \
-# context.validatePassword(**form) and \
-# context.members_add_control(**form) and \
-# context.setRedirect(atool, 'user/join', b_start=b_start, ajax=ajax):
-# return
+ if ok :
+ try :
+ if email_as_login :
+ member_id = member_email
+ rtool.addMember(id=member_id, password=password,
+ properties={'username': member_id,
+ 'given_name' : given_name,
+ 'name' : name,
+ 'email': member_email})
+ if validate_email :
+ rtool.requestPasswordReset(member_id, initial=True, came_from=came_from)
+ context.setStatus(True, _('Success!'))
+ is_newmember = True
+ is_anon = False
+ except ValueError, errmsg:
+ raise
+ context.setStatus(False, errmsg)
+
options = {}
-
-if context.REQUEST.get('portal_status_message', '') == 'Success!':
- is_anon = False
- is_newmember = True
-
options['member_id'] = member_id
options['given_name'] = given_name
options['name'] = name
options['member_email'] = member_email
+options['email_as_login'] = email_as_login
options['password'] = is_newmember and context.REQUEST.get('password', '') or ''
options['portal_url'] = portal_url
options['isAnon'] = is_anon
options['isNewMember'] = is_newmember
+options['isOrdinaryMember'] = not (mtool.isAnonymousUser() or is_newmember)
options['validate_email'] = validate_email
options['isAnonRegistration'] = rtool.getMode() == MODE_ANONYMOUS
options['isReviewedRegistration'] = rtool.getMode() == MODE_REVIEWED
+options['came_from'] = came_from
buttons = []
if is_newmember:
- target = atool.getActionInfo('user/logged_in')['url']
- buttons.append( {'name': 'login', 'value': 'Log in'} )
+ target = atool.getActionInfo('user/logged_in')['url']
+ buttons.append( {'name': 'login', 'value': 'Log in'} )
else:
- target = atool.getActionInfo('user/join')['url']
- buttons.append( {'name': 'add', 'value': _('Join')} )
+ target = atool.getActionInfo('user/join')['url']
+ buttons.append( {'name': 'add', 'value': _('Join')} )
options['form'] = { 'action': target,
- 'listButtonInfos': tuple(buttons) }
+ 'listButtonInfos': tuple(buttons) }
options['ajax']=ajax
return context.join_template(**options)