From c37c3b425021eb485376b8b776c248afb2a9b2a6 Mon Sep 17 00:00:00 2001 From: Victor Shyba Date: Mon, 23 Feb 2015 15:54:10 -0300 Subject: for #174, only 5.X.X are permanent bounces --- service/pixelated/adapter/model/mail.py | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'service/pixelated/adapter/model/mail.py') diff --git a/service/pixelated/adapter/model/mail.py b/service/pixelated/adapter/model/mail.py index a8d752c5..3ea7c95a 100644 --- a/service/pixelated/adapter/model/mail.py +++ b/service/pixelated/adapter/model/mail.py @@ -391,7 +391,10 @@ class PixelatedMail(Mail): def _extract_bounced_address(self, part): part_header = dict(part.get('headers', {})) if 'Final-Recipient' in part_header: - return part_header['Final-Recipient'].split(';')[1].strip() + if self._bounce_permanent(part_header): + return part_header['Final-Recipient'].split(';')[1].strip() + else: + return False elif 'part_map' in part: for subpart in part['part_map'].values(): result = self._extract_bounced_address(subpart) @@ -399,6 +402,11 @@ class PixelatedMail(Mail): return result else: continue + return False + + def _bounce_permanent(self, part_headers): + status = part_headers.get('Status', '') + return status.startswith('5') def as_dict(self): dict_mail = {'header': {k.lower(): v for k, v in self.headers.items()}, -- cgit v1.2.3