[bridgedb/develop] Rename b.e.server.MailDelivery → b.e.server.SMTPIncomingDelivery.

isis at torproject.org isis at torproject.org
Fri Jun 6 20:40:38 UTC 2014


commit f176af73c1e50394d8282ab9676eb8c86b28715c
Author: Isis Lovecruft <isis at torproject.org>
Date:   Mon Jun 2 21:03:34 2014 +0000

    Rename b.e.server.MailDelivery → b.e.server.SMTPIncomingDelivery.
    
     * ADD more documentation to b.e.server.SMTPIncomingDelivery.
---
 lib/bridgedb/email/server.py |   35 ++++++++++++++++++++++++-----------
 1 file changed, 24 insertions(+), 11 deletions(-)

diff --git a/lib/bridgedb/email/server.py b/lib/bridgedb/email/server.py
index a493be0..a23bbe8 100644
--- a/lib/bridgedb/email/server.py
+++ b/lib/bridgedb/email/server.py
@@ -205,17 +205,30 @@ class SMTPMessage(object):
         return smtp.rfc822.Message(rawMessage)
 
 
-
-
-
-
-class MailDelivery(object):
-    """Plugs into Twisted Mail and handles SMTP commands."""
+class SMTPIncomingDelivery(smtp.SMTP):
+    """Plugs into :class:`SMTPIncomingServerFactory` and handles SMTP commands
+    for incoming connections.
+
+    :type context: :class:`MailServerContext`
+    :ivar context: A context containing SMTP/Email configuration settings.
+    :ivar deferred: A :api:`deferred <twisted.internet.defer.Deferred>` which
+        will be returned when :meth:`reply` is called. Additional callbacks
+        may be set on this deferred in order to schedule additional actions
+        when the response is being sent.
+    :type fromCanonicalSMTP: str or ``None``
+    :ivar fromCanonicalSMTP: If set, this is the canonicalized domain name of
+       the address we received from incoming connection's ``MAIL FROM:``.
+    """
     implements(smtp.IMessageDelivery)
 
-    def setBridgeDBContext(self, context):
-        self.context = context
-        self.fromCanonical = None
+    context = None
+    deferred = defer.Deferred()
+    fromCanonicalSMTP = None
+
+    @classmethod
+    def setContext(cls, context):
+        """Set our :ivar:`context` to a new :class:`MailServerContext."""
+        cls.context = context
 
     def receivedHeader(self, helo, origin, recipients):
         """Create the ``Received:`` header for an incoming email.
@@ -244,7 +257,7 @@ class MailDelivery(object):
         :func:`socket.gethostname`) or our own FQDN, allow the connection.
 
         Otherwise, if the ``MAIL FROM:`` domain has a canonical domain in our
-        mapping (taken from :ivar:`context.canon <MailContext.canon>`, which
+        mapping (taken from :ivar:`context.canon <MailServerContext.canon>`, which
         is taken in turn from the ``EMAIL_DOMAIN_MAP``), then our
         :ivar:`fromCanonicalSMTP` is set to that domain.
 
@@ -317,7 +330,7 @@ class MailDelivery(object):
         if beforePlus != ourAddress.local:
             raise smtp.SMTPBadRcpt(str(recipient))
 
-        return lambda: MailMessage(self.context, self.fromCanonical)
+        return lambda: SMTPMessage(self.context, self.fromCanonicalSMTP)
 
 
 class MailFactory(smtp.SMTPFactory):





More information about the tor-commits mailing list