Add custom content rules string substitutions
- Add content rules string substitutions for comment: - id - text - author email - author user name - author full name
This commit is contained in:
parent
ab926d6a10
commit
13830715a7
@ -1,8 +1,101 @@
|
|||||||
""" Content rules handlers
|
""" Content rules handlers
|
||||||
"""
|
"""
|
||||||
|
from plone.app.discussion import PloneAppDiscussionMessageFactory as _
|
||||||
|
|
||||||
|
|
||||||
|
try:
|
||||||
|
from plone.stringinterp.adapters import BaseSubstitution
|
||||||
|
except ImportError:
|
||||||
|
class BaseSubstitution(object):
|
||||||
|
""" Fallback class if plone.stringinterp is not available
|
||||||
|
"""
|
||||||
|
def __init__(self, context, **kwargs):
|
||||||
|
self.context = context
|
||||||
|
|
||||||
|
try:
|
||||||
from plone.app.contentrules.handlers import execute
|
from plone.app.contentrules.handlers import execute
|
||||||
|
except ImportError:
|
||||||
|
execute = lambda context, event: False
|
||||||
|
|
||||||
|
|
||||||
def execute_comment(event):
|
def execute_comment(event):
|
||||||
""" Execute comment content rules
|
""" Execute comment content rules
|
||||||
"""
|
"""
|
||||||
execute(event.object, event)
|
execute(event.object, event)
|
||||||
|
|
||||||
|
class CommentSubstitution(BaseSubstitution):
|
||||||
|
""" Comment string substitution
|
||||||
|
"""
|
||||||
|
def __init__(self, context, **kwargs):
|
||||||
|
super(CommentSubstitution, self).__init__(context, **kwargs)
|
||||||
|
self._session = None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def session(self):
|
||||||
|
""" User session
|
||||||
|
"""
|
||||||
|
if self._session is None:
|
||||||
|
sdm = getattr(self.context, 'session_data_manager', None)
|
||||||
|
self._session = sdm.getSessionData(create=False) if sdm else {}
|
||||||
|
return self._session
|
||||||
|
|
||||||
|
@property
|
||||||
|
def comment(self):
|
||||||
|
""" Get changed inline comment
|
||||||
|
"""
|
||||||
|
return self.session.get('comment', {})
|
||||||
|
|
||||||
|
class Id(CommentSubstitution):
|
||||||
|
""" Comment id string substitution
|
||||||
|
"""
|
||||||
|
category = _(u'Comments')
|
||||||
|
description = _(u'Comment id')
|
||||||
|
|
||||||
|
def safe_call(self):
|
||||||
|
""" Safe call
|
||||||
|
"""
|
||||||
|
return self.comment.get('comment_id', u'')
|
||||||
|
|
||||||
|
class Text(CommentSubstitution):
|
||||||
|
""" Comment text
|
||||||
|
"""
|
||||||
|
category = _(u'Comments')
|
||||||
|
description = _(u'Comment text')
|
||||||
|
|
||||||
|
def safe_call(self):
|
||||||
|
""" Safe call
|
||||||
|
"""
|
||||||
|
return self.comment.get('text', u'')
|
||||||
|
|
||||||
|
class AuthorUserName(CommentSubstitution):
|
||||||
|
""" Comment author user name string substitution
|
||||||
|
"""
|
||||||
|
category = _(u'Comments')
|
||||||
|
description = _(u'Comment author user name')
|
||||||
|
|
||||||
|
def safe_call(self):
|
||||||
|
""" Safe call
|
||||||
|
"""
|
||||||
|
return self.comment.get('author_username', u'')
|
||||||
|
|
||||||
|
class AuthorFullName(CommentSubstitution):
|
||||||
|
""" Comment author full name string substitution
|
||||||
|
"""
|
||||||
|
category = _(u'Comments')
|
||||||
|
description = _(u'Comment author full name')
|
||||||
|
|
||||||
|
def safe_call(self):
|
||||||
|
""" Safe call
|
||||||
|
"""
|
||||||
|
return self.comment.get('author_name', u'')
|
||||||
|
|
||||||
|
class AuthorEmail(CommentSubstitution):
|
||||||
|
""" Comment author email string substitution
|
||||||
|
"""
|
||||||
|
category = _(u'Comments')
|
||||||
|
description = _(u'Comment author email')
|
||||||
|
|
||||||
|
def safe_call(self):
|
||||||
|
""" Safe call
|
||||||
|
"""
|
||||||
|
return self.comment.get('author_email', u'')
|
||||||
|
@ -57,4 +57,40 @@
|
|||||||
|
|
||||||
</configure>
|
</configure>
|
||||||
|
|
||||||
|
<!-- Content rules strings -->
|
||||||
|
<adapter
|
||||||
|
for="zope.interface.Interface"
|
||||||
|
provides="plone.stringinterp.interfaces.IStringSubstitution"
|
||||||
|
factory=".contentrules.Id"
|
||||||
|
name="comment_id"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<adapter
|
||||||
|
for="zope.interface.Interface"
|
||||||
|
provides="plone.stringinterp.interfaces.IStringSubstitution"
|
||||||
|
factory=".contentrules.Text"
|
||||||
|
name="comment_text"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<adapter
|
||||||
|
for="zope.interface.Interface"
|
||||||
|
provides="plone.stringinterp.interfaces.IStringSubstitution"
|
||||||
|
factory=".contentrules.AuthorUserName"
|
||||||
|
name="comment_user_id"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<adapter
|
||||||
|
for="zope.interface.Interface"
|
||||||
|
provides="plone.stringinterp.interfaces.IStringSubstitution"
|
||||||
|
factory=".contentrules.AuthorFullName"
|
||||||
|
name="comment_user_fullname"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<adapter
|
||||||
|
for="zope.interface.Interface"
|
||||||
|
provides="plone.stringinterp.interfaces.IStringSubstitution"
|
||||||
|
factory=".contentrules.AuthorEmail"
|
||||||
|
name="comment_user_email"
|
||||||
|
/>
|
||||||
|
|
||||||
</configure>
|
</configure>
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
""" Custom discussion events
|
""" Custom discussion events
|
||||||
"""
|
"""
|
||||||
from zope.interface import implements
|
from zope.interface import implements
|
||||||
|
from plone.app.discussion.interfaces import IComment
|
||||||
from plone.app.discussion.interfaces import IDiscussionEvent
|
from plone.app.discussion.interfaces import IDiscussionEvent
|
||||||
from plone.app.discussion.interfaces import ICommentAddedEvent
|
from plone.app.discussion.interfaces import ICommentAddedEvent
|
||||||
from plone.app.discussion.interfaces import ICommentRemovedEvent
|
from plone.app.discussion.interfaces import ICommentRemovedEvent
|
||||||
@ -18,6 +19,17 @@ class DiscussionEvent(object):
|
|||||||
for key, value in kwargs.items():
|
for key, value in kwargs.items():
|
||||||
setattr(self, key, value)
|
setattr(self, key, value)
|
||||||
|
|
||||||
|
# Add comment on session to easily define content-rules dynamic strings
|
||||||
|
sdm = getattr(context, 'session_data_manager', None)
|
||||||
|
session = sdm.getSessionData(create=True) if sdm else None
|
||||||
|
|
||||||
|
if session:
|
||||||
|
sessionComment = dict(
|
||||||
|
(field, getattr(comment, field, None)) for field in IComment
|
||||||
|
if not field.startswith('_')
|
||||||
|
)
|
||||||
|
session.set('comment', sessionComment)
|
||||||
|
|
||||||
class CommentAddedEvent(DiscussionEvent):
|
class CommentAddedEvent(DiscussionEvent):
|
||||||
""" Event to be triggered when a Comment is added
|
""" Event to be triggered when a Comment is added
|
||||||
"""
|
"""
|
||||||
|
Loading…
Reference in New Issue
Block a user