diff options
Diffstat (limited to 'src/mailman/queue/incoming.py')
| -rw-r--r-- | src/mailman/queue/incoming.py | 66 |
1 files changed, 0 insertions, 66 deletions
diff --git a/src/mailman/queue/incoming.py b/src/mailman/queue/incoming.py deleted file mode 100644 index f8d671177..000000000 --- a/src/mailman/queue/incoming.py +++ /dev/null @@ -1,66 +0,0 @@ -# Copyright (C) 1998-2011 by the Free Software Foundation, Inc. -# -# This file is part of GNU Mailman. -# -# GNU Mailman is free software: you can redistribute it and/or modify it under -# the terms of the GNU General Public License as published by the Free -# Software Foundation, either version 3 of the License, or (at your option) -# any later version. -# -# GNU Mailman is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for -# more details. -# -# You should have received a copy of the GNU General Public License along with -# GNU Mailman. If not, see <http://www.gnu.org/licenses/>. - -"""Incoming queue runner. - -This runner's sole purpose in life is to decide the disposition of the -message. It can either be accepted for delivery, rejected (i.e. bounced), -held for moderator approval, or discarded. - -When accepted, the message is forwarded on to the `prep queue` where it is -prepared for delivery. Rejections, discards, and holds are processed -immediately. -""" - -from __future__ import absolute_import, unicode_literals - -__metaclass__ = type -__all__ = [ - 'IncomingRunner', - ] - - -from zope.component import getUtility - -from mailman.config import config -from mailman.core.chains import process -from mailman.interfaces.address import ExistingAddressError -from mailman.interfaces.usermanager import IUserManager -from mailman.queue import Runner - - - -class IncomingRunner(Runner): - """The incoming queue runner.""" - - def _dispose(self, mlist, msg, msgdata): - """See `IRunner`.""" - if msgdata.get('envsender') is None: - msgdata['envsender'] = mlist.no_reply_address - # Ensure that the email addresses of the message's senders are known - # to Mailman. This will be used in nonmember posting dispositions. - user_manager = getUtility(IUserManager) - for sender in msg.senders: - try: - user_manager.create_address(sender) - except ExistingAddressError: - pass - config.db.commit() - # Process the message through the mailing list's start chain. - process(mlist, msg, msgdata, mlist.start_chain) - # Do not keep this message queued. - return False |
