Do plain CBV when template missing.

This commit is contained in:
Stuart Gathman
2007-01-04 18:01:11 +00:00
parent d01dc65f39
commit 5ad6d321bd
2 changed files with 29 additions and 21 deletions
+5 -5
View File
@@ -5,6 +5,9 @@
# Send DSNs, do call back verification, # Send DSNs, do call back verification,
# and generate DSN messages from a template # and generate DSN messages from a template
# $Log$ # $Log$
# Revision 1.12 2006/07/26 16:37:35 customdesigned
# Support timeout.
#
# Revision 1.11 2006/06/21 21:07:11 customdesigned # Revision 1.11 2006/06/21 21:07:11 customdesigned
# Include header fields in DSN template. # Include header fields in DSN template.
# #
@@ -79,6 +82,8 @@ def send_dsn(mailfrom,receiver,msg=None,timeout=600):
def create_msg(q,rcptlist,origmsg=None,template=None): def create_msg(q,rcptlist,origmsg=None,template=None):
"Create a DSN message from a template. Template must be '\n' separated." "Create a DSN message from a template. Template must be '\n' separated."
if not template:
return None
heloname = q.h heloname = q.h
sender = q.s sender = q.s
connectip = q.i connectip = q.i
@@ -98,11 +103,6 @@ def create_msg(q,rcptlist,origmsg=None,template=None):
msg.add_header('X-Mailer','PyMilter-'+Milter.__version__) msg.add_header('X-Mailer','PyMilter-'+Milter.__version__)
msg.set_type('text/plain') msg.set_type('text/plain')
if not template:
if spf_result and spf_result.startswith('softfail'):
template = softfail_msg
else:
template = nospf_msg
hdrs,body = template.split('\n\n',1) hdrs,body = template.split('\n\n',1)
for ln in hdrs.splitlines(): for ln in hdrs.splitlines():
name,val = ln.split(':',1) name,val = ln.split(':',1)
+24 -16
View File
@@ -1,6 +1,9 @@
#!/usr/bin/env python #!/usr/bin/env python
# A simple milter that has grown quite a bit. # A simple milter that has grown quite a bit.
# $Log$ # $Log$
# Revision 1.77 2006/12/31 03:07:20 customdesigned
# Use HELO identity if good when MAILFROM is bad.
#
# Revision 1.76 2006/12/30 18:58:53 customdesigned # Revision 1.76 2006/12/30 18:58:53 customdesigned
# Skip reputation/whitelist/blacklist when rejecting on SPF. Add X-Hello-SPF. # Skip reputation/whitelist/blacklist when rejecting on SPF. Add X-Hello-SPF.
# #
@@ -81,7 +84,7 @@ subjpats = (
r'^subjectbounce', r'^subjectbounce',
r'^returned mail', r'^returned mail',
r'^undeliver', r'^undeliver',
r'^delivery\b.*\bfailure', r'^delivery\b.*\bfail',
r'^delivery problem', r'^delivery problem',
r'\buser unknown\b', r'\buser unknown\b',
r'^failed', r'^failed',
@@ -1683,24 +1686,29 @@ class bmsMilter(Milter.Milter):
self.log('CBV:',sender,'(cached)') self.log('CBV:',sender,'(cached)')
res = cbv_cache[sender] res = cbv_cache[sender]
else: else:
self.log('CBV:',sender) fname = template_name+'.txt'
try: try:
template = file(template_name+'.txt').read() template = file(template_name+'.txt').read()
except IOError: template = None self.log('CBV:',sender,'Using:',fname)
except IOError:
template = None
self.log('CBV:',sender,'PLAIN')
m = dsn.create_msg(q,self.recipients,msg,template) m = dsn.create_msg(q,self.recipients,msg,template)
if srs: if m:
# Add SRS coded sender to various headers. When (incorrectly) if srs:
# replying to our DSN, any of these which are preserved # Add SRS coded sender to various headers. When (incorrectly)
# allow us to track the source. # replying to our DSN, any of these which are preserved
msgid = srs.forward(sender,self.receiver) # allow us to track the source.
m.add_header('Message-Id','<%s>'%msgid) msgid = srs.forward(sender,self.receiver)
if 'x-mailer' in m: m.add_header('Message-Id','<%s>'%msgid)
m.replace_header('x-mailer','"%s" <%s>' % (m['x-mailer'],msgid)) if 'x-mailer' in m:
else: m.replace_header('x-mailer','"%s" <%s>' % (m['x-mailer'],msgid))
m.add_header('X-Mailer','"Python Milter" <%s>'%msgid) else:
m.add_header('Sender','"Python Milter" <%s>'%msgid) m.add_header('X-Mailer','"Python Milter" <%s>'%msgid)
m = m.as_string() m.add_header('Sender','"Python Milter" <%s>'%msgid)
print >>open(template_name+'.last_dsn','w'),m m = m.as_string()
print >>open(template_name+'.last_dsn','w'),m
# if missing template, do plain CBV
res = dsn.send_dsn(sender,self.receiver,m,timeout=timeout) res = dsn.send_dsn(sender,self.receiver,m,timeout=timeout)
if res: if res:
desc = "CBV: %d %s" % res[:2] desc = "CBV: %d %s" % res[:2]