diff options
| author | Barry Warsaw | 2011-01-02 17:09:11 -0500 |
|---|---|---|
| committer | Barry Warsaw | 2011-01-02 17:09:11 -0500 |
| commit | 00e2ef1c318e00cbf0f862ed839f6c7e44b1c0a9 (patch) | |
| tree | 158da3cac60ec65e8a153c5fd46bee3934eb7b28 /src/mailman/rules/moderation.py | |
| parent | 0fd3cd5393d319da4111b3e196c03ec67b0b9c66 (diff) | |
| download | mailman-00e2ef1c318e00cbf0f862ed839f6c7e44b1c0a9.tar.gz mailman-00e2ef1c318e00cbf0f862ed839f6c7e44b1c0a9.tar.zst mailman-00e2ef1c318e00cbf0f862ed839f6c7e44b1c0a9.zip | |
Diffstat (limited to 'src/mailman/rules/moderation.py')
| -rw-r--r-- | src/mailman/rules/moderation.py | 58 |
1 files changed, 47 insertions, 11 deletions
diff --git a/src/mailman/rules/moderation.py b/src/mailman/rules/moderation.py index 034458553..733edd70c 100644 --- a/src/mailman/rules/moderation.py +++ b/src/mailman/rules/moderation.py @@ -21,49 +21,85 @@ from __future__ import absolute_import, unicode_literals __metaclass__ = type __all__ = [ - 'Moderation', + 'MemberModeration', + 'NonmemberModeration', ] +from zope.component import getUtility from zope.interface import implements from mailman.core.i18n import _ from mailman.interfaces.action import Action +from mailman.interfaces.member import MemberRole from mailman.interfaces.rules import IRule +from mailman.interfaces.usermanager import IUserManager -class Moderation: +class MemberModeration: """The member moderation rule.""" implements(IRule) - name = 'moderation' - description = _('Match messages sent by moderated members and nonmembers.') + name = 'member-moderation' + description = _('Match messages sent by moderated members.') record = True def check(self, mlist, msg, msgdata): """See `IRule`.""" for sender in msg.senders: member = mlist.members.get_member(sender) - action = (Action.defer if member is None + action = (None if member is None else member.moderation_action) - if action is not Action.defer: + if action is Action.defer: + # The regular moderation rules apply. + return False + elif action is not None: # We must stringify the moderation action so that it can be # stored in the pending request table. msgdata['moderation_action'] = action.enumname msgdata['moderation_sender'] = sender return True + # The sender is not a member so this rule does not match. + return False + + + +class NonmemberModeration: + """The nonmember moderation rule.""" + implements(IRule) + + name = 'nonmember-moderation' + description = _('Match messages sent by nonmembers.') + record = True + + def check(self, mlist, msg, msgdata): + """See `IRule`.""" + user_manager = getUtility(IUserManager) + # First ensure that all senders are already either members or + # nonmembers. If they are not subscribed in some role to the mailing + # list, make them nonmembers. + for sender in msg.senders: + if (mlist.members.get_member(sender) is None and + mlist.nonmembers.get_member(sender) is None): + # The address is neither a member nor nonmember. + address = user_manager.get_address(sender) + assert address is not None, ( + 'Posting address is not registered: {0}'.format(sender)) + address.subscribe(mlist, MemberRole.nonmember) + # Do nonmember moderation check. for sender in msg.senders: nonmember = mlist.nonmembers.get_member(sender) - action = (Action.defer if nonmember is None + action = (None if nonmember is None else nonmember.moderation_action) - if action is not Action.defer: + if action is Action.defer: + # The regular moderation rules apply. + return False + elif action is not None: # We must stringify the moderation action so that it can be # stored in the pending request table. msgdata['moderation_action'] = action.enumname msgdata['moderation_sender'] = sender return True - # XXX This is not correct. If the sender is neither a member nor a - # nonmember, we need to register them as a nonmember and give them the - # default action. + # The sender must be a member, so this rule does not match. return False |
