mikel / mail

A Really Ruby Mail Library
MIT License
3.61k stars 935 forks source link

Attachments/parts not parsed from real-world email #1329

Open steobrien opened 5 years ago

steobrien commented 5 years ago

Here’s an anonymized version of an email we came across (a Jira notification):

Raw email ``` Delivered-To: examplep@company.com Received: by 2002:a05:6000:108d:0:0:0:0 with SMTP id y13csp13744073wrw; Wed, 13 Mar 2019 14:50:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqy7mPKcRctqXcBKcg5CVl4NueHCPf3g06cgi9tpGswLpM7zNJcetyO8G0irZe8DHF/gqJFo X-Received: by 2002:ac8:7606:: with SMTP id t6mr16598956qtq.243.1552513805290; Wed, 13 Mar 2019 14:50:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552513805; cv=none; d=google.com; s=arc-20160816; b=moZWmZHtDWtOYtKPhoXN36zWN/TS1dpQqsyDQlrNX22q79KeA2OVUQJSfoKOT/LWIH b3kXF6IvIVpAjq0LYvagbl+u6YX79rDQDeC2J2eoioRB5LcpihZDyEy/68LzSUy89BsZ +ZhVlKTvqMV68qS9iLddoOg9NxdXStiOQ1e/ZAqtk6dLA7SrGjLSVt/vfWNoZFQ1YGfd Z/5Ccbq1qX0ZF8zVssEHVeRZoKbfPI5lcu2w633TagujbD8rN64XyfNs62bCtH9ET+SH ynZpJMobFRzGJ+4i5B9tS+HvmeMP9JUuDfQmFwgyiP6DiSxvLWAi14fvi+JqbnBsoPDn S2Bg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=feedback-id:precedence:auto-submitted:mime-version:subject :message-id:to:from:date:dkim-signature:dkim-signature; bh=DBHSNv0eq5QWpQ6X0SJlqwYKN6RZlnR94Fb5PlhzeEs=; b=niQS1cFFh0nWd3p/QtX98fF1P8lIhl8AZju3uKnUb6YO1CV6C7781pA37noEm1l7Nq 3vnB02eK5AvfmT6Gwwi0mF7/+DpQghcsO1r5t9K3n3HORrTT7/MhsXXez0D14KHwYGKq b5OYFKCkanQsC3KTOTf+p4iTtVG4kM6Eysb6Ru9tpA6YfGBtUy+wmK2+GP2N2HeytnFQ X+Z5DM5SQyMkAU/b8+TdJIHbpwRn7uVMI4dRYCj8dhU6cHSVu65C4RU5Ch947Cfyp+uQ +u/Zm0RxEl/dUBwNoghDfH+91BSnX8KPn4Q/DhJcBMb6B0MVDUHb+jAKOOb+ZbNHdG6s i2tw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@company.com header.s=bnhupe3uxaibdavzdli42szjrzik6ehc header.b="gUU+w1q/"; dkim=pass header.i=@service.com header.s=6gbrjpgwjskckoa6a5zn6fwqkn67xbtw header.b=m+k2E4A6; spf=pass (google.com: domain of 010001697908a842-5d693d79-52c1-46db-8087-fa32f516e764-000000@service.com designates 54.240.8.97 as permitted sender) smtp.mailfrom=010001697908a842-5d693d79-52c1-46db-8087-fa32f516e764-000000@service.com Return-Path: <010001697908a842-5d693d79-52c1-46db-8087-fa32f516e764-000000@service.com> Received: from a8-97.smtp-out.service.com (a8-97.smtp-out.service.com. [54.240.8.97]) by mx.google.com with ESMTPS id g4si1444434qki.69.2019.03.13.14.50.05 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Wed, 13 Mar 2019 14:50:05 -0700 (PDT) Received-SPF: pass (google.com: domain of 010001697908a842-5d693d79-52c1-46db-8087-fa32f516e764-000000@service.com designates 54.240.8.97 as permitted sender) client-ip=54.240.8.97; Authentication-Results: mx.google.com; dkim=pass header.i=@company.com header.s=bnhupe3uxaibdavzdli42szjrzik6ehc header.b="gUU+w1q/"; dkim=pass header.i=@service.com header.s=6gbrjpgwjskckoa6a5zn6fwqkn67xbtw header.b=m+k2E4A6; spf=pass (google.com: domain of 010001697908a842-5d693d79-52c1-46db-8087-fa32f516e764-000000@service.com designates 54.240.8.97 as permitted sender) smtp.mailfrom=010001697908a842-5d693d79-52c1-46db-8087-fa32f516e764-000000@service.com DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/simple; s=bnhupe3uxaibdavzdli42szjrzik6ehc; d=company.com; t=1552513804; h=Date:From:To:Message-ID:Subject:MIME-Version:Content-Type; bh=j+lW4T6pS6/mp8Pv87KwMxkt/FkLpXHTDDZ4Tihd8hs=; b=gUU+w1q/AX7PazrauLMCvcfwRa/cD1w4JmCvVfUYRjszL75/FR9NpStT63B7Hho8 xAZzKseHoOyokyIeP3zWiPYHasj9yT9M31ILskY3qo/MMxpyCv2h6PThGXTWkZ9MU9q YNA05NGxk5Qbq+MfbX0TMt4QdKXXLq9L+oqfBRpM= DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/simple; s=6gbrjpgwjskckoa6a5zn6fwqkn67xbtw; d=service.com; t=1552513804; h=Date:From:To:Message-ID:Subject:MIME-Version:Content-Type:Feedback-ID; bh=j+lW4T6pS6/mp8Pv87KwMxkt/FkLpXHTDDZ4Tihd8hs=; b=m+k2E4A6UTg2rO82PmmWew8riveshOhTlA+EtcjZe1AxjD2eELbXe9dkpPlw1c/Y FlAIYCLhKKzUYD8+uIw2RBkXSzqir9oeqJLBgl5+L02hi38oGklXQixgM/Ba737OHU5 MsSRnox82SlunbBiMfX2o1o894FjPoudHjc78JF4= Date: Wed, 13 Mar 2019 21:50:04 +0000 From: "Other Person (JIRA)" To: examplep@company.com Message-ID: <010001697908a842-5d693d79-52c1-46db-8087-fa32f516e764-000000@email.service.com> Subject: [JIRA] Other Person mentioned you on EXAMPLE-117 (JIRA) MIME-Version: 1.0 Content-Type: multipart/related; boundary="----=_Part_1167_2042902750.1552513803256" X-JIRA-FingerPrint: 7d29f0bc8cd3f727e720af4f92fbbd00 Auto-Submitted: auto-generated Precedence: bulk X-SES-Outgoing: 2019.03.13-54.240.8.97 Feedback-ID: 1.us-east-1./wVgWJaec4m7FrrjdJPulCbkcLW8wy7kXqubSLnQq/k=:service ------=_Part_1167_2042902750.1552513803256 Content-Type: text/html; charset=UTF-8 Content-Transfer-Encoding: quoted-printable =20 =20 =20 =20 Message Title=20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20
=20 =20 =20 =20 =20 =20
Other Person mentioned you on= 3D"Story" EXAMPLE-117
=20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20 =20
 =20
=20 =20 =20 =20 =20
Re: Link to COMPANY Pay Affilia= te UI in Example UI
=20 =20 =20 =20 =20

Test Test, Example Test, need your help= with that: https://confl= uence.corp.company.com/display/HASPAY/Testing+Testingit+UI+of+Example+with+T= EST+XXX+UI

This is the first draft = solution description to resolve this problem. I'm going to elaborate it to = specific requirements further.

Can you = please:

=20
    =20
  • read this d= escription,
  • =20
  • give your f= eedback: is there something that I'm missing? does this go along with your = ideas of how we should resolve it?
  • =20
  • give your c= omments (you can comment right on that Confluence page) on the sentences ma= rked with 'TBD',
  • =20
  • guide me to= any other person who can give more details on those questions.
  • =20

Thanks!

=20 =20 =20 =20 =20
= =20 =20 =20 =20 =20 =20
3D"Add Add Comment
 
=20 =20 =20 =20 =20 =20
Th= is message was sent by Atlassian JIRA (v7.9.0#79000-sha1:3ca552e) =20 =20 =20 =20 =20
3D"Atlassian
=20 ------=_Part_1167_2042902750.1552513803256 Content-Type: image/png Content-Transfer-Encoding: base64 Content-Disposition: inline Content-ID: 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 +79PLOd7+YfRKgAAAABJRU5ErkJggg== ------=_Part_1167_2042902750.1552513803256 Content-Type: image/png Content-Transfer-Encoding: base64 Content-Disposition: inline Content-ID: iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAADAFBMVEX///+1tbWzs7OysrKrq6um pqalpaWdnZ2ZmZn///+VlZWPj4/7+/vu7u7p6enn5+fl5eXk5OTh4eHW1tbT09PMzMzJycm6urq5 ubm1tbWzs7OysrKrq6upqamlpaWKioqFhYWRkZGKioqHh4eDg4OAgIB/f398fHx6enp4eHh2dnZ0 dHRycnJwcHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAIFWMjAAAAIXRSTlMAIiIzZoiZu8zd3d3u7u7u7u7u7u7u7u7u7u7u7u7u7u6n leogAAAAG3RFWHRqaXJhLXN5c3RlbS1pbWFnZS10eXBlAGljb266KjlFAAAAo0lEQVR42l2P2wrC MAyG09Pa1SqKzIk3QwTf/3G8UByKyK4EcV0POqzDaTUQwv+R/EkA/gKFJGyuQrFH/+iAWJnGOCCp THcmALms6ne7ykpNeFHpft75xZWsL/XX0bMppj7eUXNseQykI7eZu3+0GpfYuVz1ephriwAnxdkD QVwIsTVAoTUswZNBuPRkw6X01cqzZtMbdWB0aFqIANqb349ZLJ5XFjQIuveaPQAAAABJRU5ErkJg gg== ------=_Part_1167_2042902750.1552513803256 Content-Type: image/png Content-Transfer-Encoding: base64 Content-Disposition: inline Content-ID: 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 nvfbckn7YgAAAABJRU5ErkJggg== ------=_Part_1167_2042902750.1552513803256 Content-Type: image/png Content-Transfer-Encoding: base64 Content-Disposition: inline Content-ID: iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAHXRFWHRqaXJhLXN5c3RlbS1pbWFn ZS10eXBlAGF2YXRhcuQCGmEAAADzSURBVHjaY2AYBUggdZeVQfJOm+1A/Dx5l81/KuP3QLw/aZe1 CW7Ld9l8poHF6Ph3ym5rCwwHpOy02U0Hy2H4MIYDaBTsOKMD0wH0sxyMh54DOk5l/X/3/dV/QuDD z7f/e88UUN8BxFiO7AiqO4BUMOqAUQeMOmBkOODvvz//f/39OXAOmHKhElzsYnMEzR2w+e4CuNzS 6/30dcCRp9v+p+62R5Hf/3g9fRxw6/3F/xl7nLCqOffyEO0c8Prb8/+PPt36n7/fG6ea3H0e/+9/ vA5WO/waJLR3wEA3Sge8WT7gHROYI6Ah8ZpGXbPDOC0fsQAAPF0rYTBnzJQAAAAASUVORK5CYII= ------=_Part_1167_2042902750.1552513803256-- ```

This mail displays correctly in clients like Gmail, and is parsed by other tools like http://www.mimedecoder.com/.

However, Mail does not detect the attachments:

parsed = Mail.read_from_string(raw)
parsed.attachments.count
# => 0

parsed.parts.count
# => 0

One last detail: I noticed that there was an error with parsing the Received header, but a quick spike to tolerate malformed content there (https://github.com/considerhq/mail/compare/s/tolerant-received?expand=1) did not help with attachments parsing.

lao9 commented 5 years ago

I think I was able to isolate the source of this issue. Without the Content-Location: [something] field to the attachment section, Mail is unable to recognize the attachments. Here is a small sample:

This Works

Mime-Version: 1.0 (Apple Message framework v730)
Content-Type: multipart/mixed; boundary=Apple-Mail-13-196941151
Message-Id: <9169D984-4E0B-45EF-82D4-8F5E53AD7012@example.com>
From: foo@example.com
Subject: testing
Date: Mon, 6 Jun 2005 22:21:22 +0200
To: blah@example.com

--Apple-Mail-13-196941151
Content-Transfer-Encoding: quoted-printable
Content-Type: text/plain;
    charset=ISO-8859-1;
    delsp=yes;
    format=flowed

This is the first part.

--Apple-Mail-13-196941151
Content-Type: image/jpeg
Content-Transfer-Encoding: base64
Content-Location: Photo25.jpg
Content-ID: <qbFGyPQAS8>
Content-Disposition: inline

jamisSqGSIb3DQEHAqCAMIjamisxCzAJBgUrDgMCGgUAMIAGCSqGSjamisEHAQAAoIIFSjCCBUYw
ggQujamisQICBD++ukQwDQYJKojamisNAQEFBQAwMTELMAkGA1UEBhMCRjamisAKBgNVBAoTA1RE
QzEUMBIGjamisxMLVERDIE9DRVMgQ0jamisNMDQwMjI5MTE1OTAxWhcNMDYwMjamisIyOTAxWjCB
gDELMAkGA1UEjamisEsxKTAnBgNVBAoTIEjamisuIG9yZ2FuaXNhdG9yaXNrIHRpbjamisRuaW5=

--Apple-Mail-13-196941151--

Does Not Work

Mime-Version: 1.0 (Apple Message framework v730)
Content-Type: multipart/mixed; 
boundary=Apple-Mail-13-196941151
Message-Id: <9169D984-4E0B-45EF-82D4-8F5E53AD7012@example.com>
From: foo@example.com
Subject: testing
Date: Mon, 6 Jun 2005 22:21:22 +0200
To: blah@example.com

--Apple-Mail-13-196941151
Content-Transfer-Encoding: quoted-printable
Content-Type: text/plain;
    charset=ISO-8859-1;
    delsp=yes;
    format=flowed

This is the first part.

--Apple-Mail-13-196941151
Content-Type: image/jpeg
Content-Transfer-Encoding: base64
Content-ID: <qbFGyPQAS8>
Content-Disposition: inline

jamisSqGSIb3DQEHAqCAMIjamisxCzAJBgUrDgMCGgUAMIAGCSqGSjamisEHAQAAoIIFSjCCBUYw
ggQujamisQICBD++ukQwDQYJKojamisNAQEFBQAwMTELMAkGA1UEBhMCRjamisAKBgNVBAoTA1RE
QzEUMBIGjamisxMLVERDIE9DRVMgQ0jamisNMDQwMjI5MTE1OTAxWhcNMDYwMjamisIyOTAxWjCB
gDELMAkGA1UEjamisEsxKTAnBgNVBAoTIEjamisuIG9yZ2FuaXNhdG9yaXNrIHRpbjamisRuaW5=

--Apple-Mail-13-196941151--

Is this intentional?

saghaulor commented 4 years ago

@steobrien what are the line endings in your problematic email? I've noticed that the Mail::Body#extract_parts method requires CRLF line endings, and sometimes we seem to receive mail with only LF endings. When this happens, the email isn't parsed correctly. Perhaps this is your issue?

steobrien commented 4 years ago

Thanks for the tip. Don't have time to check right now, but @lao9 captured a failing test case in her PR, if that could be of interest to you: https://github.com/mikel/mail/pull/1350/files#diff-525687bb61fad571b82fcb18ffc06375