source: products/qPloneComments/tags/2.2.0/skins/qplonecomments/2.5/discussion_reply.cpy @ 1591

Last change on this file since 1591 was 1, checked in by myroslav, 19 years ago

Building directory structure

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