source: products/quintagroup.plonecomments/trunk/quintagroup/plonecomments/browser/comments.py @ 1625

Last change on this file since 1625 was 1625, checked in by kroman0, 14 years ago

Fixed InitializeClass? and md5 for Plone4(python2.6)

File size: 6.9 KB
Line 
1import urllib
2try:
3    import hashlib as md5
4except ImportError:
5    import md5
6
7from Acquisition import aq_inner
8from AccessControl import getSecurityManager
9
10from Products.CMFPlone.utils import IndexIterator
11from Products.CMFPlone.utils import getToolByName
12from Products.CMFFormController.ControllerState import ControllerState
13from Products.Five.browser.pagetemplatefile import ViewPageTemplateFile
14from quintagroup.plonecomments.utils import manage_mails
15
16from plone.app.layout.viewlets import comments
17from plone.app.kss.plonekssview import PloneKSSView
18
19class CommentsViewlet(comments.CommentsViewlet):
20    """A custom version of the comments viewlet
21    """
22    render = ViewPageTemplateFile('comments.pt')
23
24    def is_moderation_enabled(self):
25        """ Returns a boolean indicating whether the user has enabled moderation
26            in the qPloneComments configlet
27        """
28        portal_properties = getToolByName(self.context, 'portal_properties')
29        try:
30            return portal_properties.qPloneComments.getProperty('enable_moderation', None)
31        except AttributeError:
32            return False
33
34    def can_moderate(self):
35        """ Returns a boolean indicating whether the user has the 'Moderate Discussion'
36            permission
37        """
38        return getSecurityManager().checkPermission('Moderate Discussion', aq_inner(self.context))
39
40    def getGravatar(self, reply):
41        purl = getToolByName(self.context, 'portal_url')
42        mtool = getToolByName(self.context, 'portal_membership')           
43        portrait_url = purl() + '/defaultUser.gif' 
44        email = ''
45
46        creator = reply.Creator()
47        if creator and not creator=='Anonymous User':
48            mtool = getToolByName(self.context, "portal_membership")
49            member = mtool.getMemberById(creator)
50            email = member and member.getProperty('email','') or ''
51            mem_id = getattr(member,'getId',lambda:'Anonymous User')()
52            portrait = mtool.getPersonalPortrait(mem_id)
53            portrait_url =  portrait.absolute_url()
54        else:
55            email = reply.getProperty('email',d='')
56
57        if not email or not 'defaultUser.gif' in portrait_url:
58            return portrait_url
59
60        size = 40
61        gravatar_url = "http://www.gravatar.com/avatar.php?"
62        # construct the url
63        gravatar_url += urllib.urlencode({'gravatar_id':md5.md5(email).hexdigest(),
64            'default':portrait_url, 'size':str(size)})
65        return gravatar_url
66       
67
68    def authenticated_report_abuse_enabled(self):
69        """ """
70        portal_properties = getToolByName(self.context, 'portal_properties')
71        prop_sheet = portal_properties['qPloneComments']
72        value =  prop_sheet.getProperty('enable_authenticated_report_abuse', False)
73        return value
74
75    def anonymous_report_abuse_enabled(self):
76        """ """
77        portal_properties = getToolByName(self.context, 'portal_properties')
78        prop_sheet = portal_properties['qPloneComments']
79        value =  prop_sheet.getProperty('enable_anonymous_report_abuse', False)
80        return value
81
82    def ajax_report_abuse_enabled(self):
83        """ """
84        portal_properties = getToolByName(self.context, 'portal_properties')
85        prop_sheet = portal_properties['qPloneComments']
86        value =  prop_sheet.getProperty('enable_ajax_report_abuse', False)
87        return value
88
89    def email_from_address(self):
90        """ """
91        portal_url = getToolByName(self.context, 'portal_url')
92        portal = portal_url.getPortalObject()
93        return portal.email_from_address
94
95    def member(self):
96        """ """
97        pm = getToolByName(self.context, 'portal_membership')
98        return pm.getAuthenticatedMember()
99
100    def tabindex(self):
101        """ Needed for BBB, tabindex has been deprecated.
102        """
103        return IndexIterator()
104
105    def portal_url(self):
106        """ """
107        return getToolByName(self.context, 'portal_url')
108
109
110
111class CommentsKSS(PloneKSSView):
112    """ Operations on the report abuse form using KSS.
113    """   
114
115    def submit_abuse_report(self):
116        """ Send an email with the abuse report message and hide abuse report form.
117        """
118        errors = {}
119        context = aq_inner(self.context)
120        request = context.REQUEST
121        portal = getToolByName(self.context, 'portal_url').getPortalObject()
122        if hasattr(context, 'captcha_validator'):
123            dummy_controller_state = ControllerState(
124                                            id='comments.pt',
125                                            context=context,
126                                            button='submit',
127                                            status='success',
128                                            errors={},
129                                            next_action=None,)
130            # get the form controller
131            controller = portal.portal_form_controller
132            # send the validate script to the form controller with the dummy state object
133            controller_state = controller.validate(dummy_controller_state, request, ['captcha_validator',])
134            errors.update(controller_state.errors)
135
136        message = request.get('message')
137        if not message:
138            errors.update({'message': 'Please provide a message'})
139
140        mtool = getToolByName(self.context, "portal_membership")
141        member = mtool.getAuthenticatedMember()
142        comment_id = self.context.request.get('comment_id')
143        ksscore = self.getCommandSet('core')
144        if errors:
145            html = self.macroContent('context/report_abuse_form/macros/form',
146                                     errors=errors,
147                                     show_form=True,
148                                     tabindex=IndexIterator(),
149                                     member=member,
150                                     **request.form)
151            node = ksscore.getHtmlIdSelector('span-reply-form-holder-%s' % comment_id)
152            ksscore.replaceInnerHTML(node,  html)
153            return self.render()
154
155        # report_abuse(context, context, message, comment)
156        manage_mails(context, self.context, 'report_abuse')
157
158        html = self.macroContent('context/report_abuse_form/macros/form',
159                                 tabindex=IndexIterator(),
160                                 member=member,
161                                 **request.form)
162        node = ksscore.getHtmlIdSelector('span-reply-form-holder-%s' % comment_id)
163        html = '<br/><span style="color:red">You have reported this comment for abuse.</span>'
164        self.commands.addCommand('remove_abuse_report_form', 
165                                 node, 
166                                 comment_id=comment_id, 
167                                 html=html)
168
169        node = ksscore.getHtmlIdSelector('div-captcha-%s' % comment_id)
170        html = self.macroContent('context/report_abuse_form/macros/captcha',
171                                 **request.form)
172        ksscore.replaceInnerHTML(node,  html)
173        return self.render()
Note: See TracBrowser for help on using the repository browser.