source: products/qPloneComments/trunk/skins/qplonecomments/discussion_reply.cpy @ 242

Last change on this file since 242 was 91, checked in by chervol, 18 years ago

tag the 0.3.0-eogogics version

  • Property svn:eol-style set to native
File size: 4.2 KB
Line 
1## Script (Python) "discussion_reply"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind state=state
7##bind subpath=traverse_subpath
8##parameters=subject,body_text,text_format='plain',username=None,password=None
9##title=Reply to content
10
11from Products.PythonScripts.standard import url_quote_plus
12from Products.CMFCore.utils import getToolByName
13from Products.qPloneComments.utils import manage_mails
14from Products.CMFPlone import MessageFactory
15qpcMF = MessageFactory('plonecomments')
16
17mtool = getToolByName(context, 'portal_membership')
18dtool = getToolByName(context, 'portal_discussion')
19
20req = context.REQUEST
21pp = getToolByName(context,'portal_properties')
22# Get properties
23isForAnonymous = pp['qPloneComments'].getProperty('enable_anonymous_commenting', False)
24ifModerate = pp['qPloneComments'].getProperty('enable_moderation', False)
25requireEmail = pp['qPloneComments'].getProperty('require_email', False)
26if username or password:
27    # The user username/password inputs on on the comment form were used,
28    # which might happen when anonymous commenting is enabled. If they typed
29    # something in to either of the inputs, we send them to 'logged_in'.
30    # 'logged_in' will redirect them back to this script if authentication
31    # succeeds with a query string which will post the message appropriately
32    # and show them the result.  if 'logged_in' fails, the user will be
33    # presented with the stock login failure page.  This all depends
34    # heavily on cookiecrumbler, but I believe that is a Plone requirement.
35    came_from = '%s?subject=%s&body_text=%s' % (req['URL'], subject, body_text)
36    came_from = url_quote_plus(came_from)
37    portal_url = context.portal_url()
38
39    return req.RESPONSE.redirect(
40        '%s/logged_in?__ac_name=%s'
41        '&__ac_password=%s'
42        '&came_from=%s' % (portal_url,
43                               url_quote_plus(username),
44                               url_quote_plus(password),
45                               came_from,
46                               )
47        )
48
49# if (the user is already logged in) or (if anonymous commenting is enabled and
50# they posted without typing a username or password into the form), we do
51# the following
52
53#########################################################
54# Get discussion item (reply) author and creating reply #
55comment_creator = req.get('Creator', None)
56if isForAnonymous and comment_creator:
57    # Get entered anonymous name
58    comment_creator = comment_creator
59else:
60    member = mtool.getAuthenticatedMember()
61    # Get Member Full name.If not entered - get user login name
62    comment_creator = member.getProperty('fullname')
63    if not comment_creator:
64        comment_creator = member.getUserName()
65tb = dtool.getDiscussionFor(context)
66if requireEmail:
67    if mtool.isAnonymousUser():
68        email = req.get('email', '')
69    else:
70        email = mtool.getAuthenticatedMember().getProperty('email')
71
72    id = tb.createReply(title=subject, text=body_text, Creator=comment_creator, email=email)
73else:
74    id = tb.createReply(title=subject, text=body_text, Creator=comment_creator)
75
76reply = tb.getReply(id)
77
78# TODO THIS NEEDS TO GO AWAY!
79if hasattr(dtool.aq_explicit, 'cookReply'):
80    dtool.cookReply(reply, text_format='plain')
81
82parent = tb.aq_parent
83# Send notification e-mail
84
85manage_mails(reply, context, 'aproving')
86if not ifModerate:
87    manage_mails(reply, context, 'publishing')
88
89# return to the discussable object.
90redirect_target = context.plone_utils.getDiscussionThread(tb)[0]
91view = redirect_target.getTypeInfo().getActionInfo('object/view',
92                                                   redirect_target)['url']
93anchor = reply.getId()
94
95# Inform user about awaiting moderation
96portal_status_message='Comment published.'
97if ifModerate and reply:
98    portal_status_message='Currently, all comments require approval before being published. Please check back later.'
99
100from Products.CMFPlone.utils import transaction_note
101transaction_note('Added comment to %s at %s' % (parent.title_or_id(),
102                                                reply.absolute_url()))
103
104context.plone_utils.addPortalMessage(qpcMF(portal_status_message))
105context.plone_utils.addPortalMessage(qpcMF(u'Comment added.'))
106target = '%s#%s' % (view, anchor)
107return req.RESPONSE.redirect(target)
Note: See TracBrowser for help on using the repository browser.