5

I have a situation where B2B and B2C communication needs to be sent securely and not visible to most SMTP hijackers. I don't care about conspiracy theories or NSA style attacks, but want to provide reasonable security for individuals who don't want their PII data exposed to less capable attackers.

This business requirement comes from Massachusetts data privacy laws that require PII for residents to be sent "encrypted" without much further elaboration of the technical requirements.

Our client's business relies heavily on email and the ability to send PII for life insurance, health insurance and other financial products.

To that end, I intend to use TLS to provide this security due to its ubiquity, ease of use, and that it co-operates well with financial compliance requirements. I envision creating a direct TLS tunnel between partner's MTA and ours. (Forced TLS not opportunistic)

The problem is that TLS "security" is buried in the SMTP headers, difficult to understand, and the borders of administration are hard to delineate. e.g.

  company1 ---->  MSFT Hosted Relay  -->  [TLS between providers] ----> Google Hosted --> Company 2

  company1 ---->  Proofpoint         -->  [TLS between providers] ----> Google Hosted --> Company 2

Question

Assume an insurance company needs to send a SSN in an email message (body or attachment). The next hop MTA is a Gmail, Yahoo, or other trusted private MTA.

  • How can I give the recipient confidence that the message was sent securely over TLS?

  • What alternative technical solutions or RFC would assist in giving me this assurance? (Perhaps a variant of DMARC/DKIM + TLS?)

makerofthings7
  • 50,488
  • 54
  • 253
  • 542
  • Since you're talking about an email message, why not use PGP? It protects the contents of the message from the sender straight to the receiver. – Adi Oct 03 '13 at 16:12
  • @Adnan, most finance companies reject PGP since it is difficult to integrate with compliance (SEC mandated surveillance) , not to mention PGP isn't used by most insurance-buying consumers. – makerofthings7 Oct 03 '13 at 16:21
  • 1
    I have worked in security in the finance industry for 17 years and I have implemented or reviewed PGP in various banks. It absolutely can be used and meets compliance requirements (as long as you don't use the desktop version) – Rory Alsop Oct 04 '13 at 07:08
  • @RoryAlsop You and Thomas Pornin mention the Gateway which I wasn't aware of, but need to see how it can work with consumers (who is my recipient) running on an iPad (with no Java or EXE for Portal Based Encryption). The challenges are high, and I'm simply looking for a solution that fits in this scenario. – makerofthings7 Oct 04 '13 at 07:35

7 Answers7

7

Your objective is to drive in a screw, and you want to use a hammer because you have one handy and it's easy to use. I'm afraid the most likely outcome is a sore thumb.

TLS is fundamentally about point-to-point security. It is only attached to the connection, not to the data. Email, on the other hand, is fundamentally designed to bounce through multiple hops. While the hops do leave a stamp tracing their actions, you would be dependent on the hosts to not be malicious (each hop can fake the whole message including the stamps of its predecessors), to not be fooled (e.g. into misauthenticating their predecessor), and to leave the stamps that you expect.

You can give the recipient confidence that the message was transmitted securely by delivering a signed, encrypted message produced by the sender. TLS is not useful for this. RFC that can help you include RFC 3156, RFC 4880 (OpenPGP Message Format), RFC 5750 and RFC 5751 (S/MIME).

In other words: use PGP or S/MIME.

Gilles 'SO- stop being evil'
  • 51,415
  • 13
  • 121
  • 180
  • 1
    You're right, but what if I simplify the problem to say Company A has an MTA, and so does Company B? The negotiation of security polices only happens for one hop. Also [this is related](http://security.stackexchange.com/a/30413/396) regarding trust in the DMZ. – makerofthings7 Oct 03 '13 at 23:20
  • @makerofthings7 may be you ought to edit your question with this simplification u suggested !! just a thought :) – Arun Oct 04 '13 at 05:35
6

In fact you cannot really given any guarantee in any case. You cannot reliably guarantee that a given email will be protected by TLS on each hop, because the relevant servers do so opportunistically, and the list of relevant servers can change without notice (dynamic routing, even at the SMTP level, is common for highly used servers). Even for an email which was sent, you can know whether the connections were TLS-protected only insofar as the relevant servers were kind enough to state it (and then, only in the Received: headers), and, there again, only if the same server were kind enough not to lie about it.

The format of data in the Received: headers is purely traditional, not standard, and not all servers use the same format. This header is meant to be human-readable, at least for a notion of "human" which matches the social environment of early RFC writers. As you have noticed, not every customer can be expected to be "that kind of human".

An even more important point is that the Received: header can only be seen in the email which was received. Imagine an evil individual who wants to read some emails sent by other people to other people. If that evil individual is <insert here your favourite spy agency>, then he just has to bribe an intern at one of the places hosting a SMTP server. But let's suppose that the bad guy is a freelancer. He will want to intercept the email while being transferred from SMTP server G (as "Gahoo") to SMTP server Y (as "Ymail")(fictitious names, of course). So he employs the poor-man's MitM, known as DNS poisoning: he poses as SMTP server Y in the eyes of SMTP server G.

G connects, the attackers claims not to support TLS (or to support TLS with a bad certificate, or whatever); G then gracefully degrades to non-TLS, and sends the email "as is". Then, the bad guy does not acknowledge reception of the email, and instead breaks the connection abruptly. SMTP server G considers that occurrence to be some random network error, tries again, this time connects to the actual Y server (possibly relayed by the attacker, it does not matter), does TLS, sends the email. On the receiving part, there will be no trace whatsoever of the aborted non-TLS transfer which ended in the attacker's machine. The email contains a lot of Received: headers which all claim that TLS was used throughout -- because they only talk about the successful email connection.


While you cannot guarantee that the email was well protected, you might succeed in convincing a non-technical customer that is was well protected. For instance by not telling him any of the above...

Bottom-line is that email is not secure, and never was. For email security, you need a true end-to-end solution, i.e. PGP or S/MIME (assuming they are properly employed, which is not a given).

Thomas Pornin
  • 322,884
  • 58
  • 787
  • 955
  • Hmm I'm searching for a compromise between ideal and practical security for what's deployed. Could a proposal exist that provides confidentiality (integrity, etc) not between users but as a policy between MTAs? Imagine PGP encryption between MTAs separated by multiple hops. The MITM nodes just do store-and-forward of an encrypted blob. The final node decrypts and submits to the server as unencrypted SMTP. No client software is needed. Keys could be exchanged via DNS or DNSSec (similar to how DKIM is done today). Sound viable? – makerofthings7 Oct 03 '13 at 19:02
  • PGP or S/MIME gateways [already exist](http://www.symantec.com/gateway-email-encryption). The problem, of course, is not technical; it is just that it works between two sites only if the two sites both have such a gateway. This is yet another protocol update issue, which, like IPv6, will be widely deployed only if everybody agrees to switch to it simultaneously. – Thomas Pornin Oct 03 '13 at 19:11
2

In the specific case outlined above, where you are sending from a known TLS-capable provider to a known TLS-capable receiver (with no inconvenient third-party backup MXs), you can trust the path, but there is no way for a recipient to confirm it other than by divining the Received headers (or SMTP logs on each hop) if TLS was used along the way.

Given the store-and-forward nature of SMTP, in the general case, you (the sender) can't know in advance that a specific message will arrive having used only TLS connections at every hop.

To the best of my knowledge, there is no interoperable way1 to instruct an SMTP server on a per-message basis to only use TLS; and no common method for an MUA to indicate it, like a DKIM visual indicator in some email clients. Given that the Received header format varies from MTA to MTA, that's a more difficult problem that it might seem.

With a non-technical user base, one alternative might be encrypted PDF, this comes with a shared-secret requirement... that too may fall afoul of mandated content inspection policies though.

Another alternative commonly used (which again has either a shared-secret or authentication requirement) is email a HTTPS link to the content.

I'm guessing that showing the user how to cut-and-paste the headers is out too, though even mxtoolbox shies away from parsing TLS details, it would in theory be possible.

A TLS solution is not a great fit: it's layer 5 (session), you're trying to provide layer 7 (application) layer security (and without swallowing all three of the confidentiality, integrity, authentication bitter pills...)


1 The SalesForce X-SFDC-TLS-NoRelay header seems to be a proprietary way, though I'm guessing here as I cannot find its documented intent.

mr.spuratic
  • 7,977
  • 26
  • 37
  • 1
    Not per-message, but it is possible to require TLS for specific domains - Cisco Ironport does this, for example, and I'm pretty sure I've done it with Postfix in the past. (This doesn't deal with issues like what the server you hand it off to does, but if for example you have two sister companies wanting to secure their exchanges, that's a reasonable way to armor the Internet hop. And it doesn't tell _users_ anything, but if IT can promise _bosses_ that that email is safe, that may be sufficient.) – gowenfawr Oct 04 '13 at 04:09
  • Exactly, it's currently only an MTA-only setting, and hence strictly per-hop. Most MTA's support this (even MS-Exchange), `sendmail` has peer-IP/name, recipient domain and address level controls (which is fine for outbound, but not so easy for selective inbound enforcement). – mr.spuratic Oct 04 '13 at 09:19
2

The solution is not to send the PII via e-mail. Send that info via a web site where you can ensure it is TLS encrypted and also is easy to access for the consumer and insurance agents alike.

Rod MacPherson
  • 1,067
  • 7
  • 11
0

I had the same question and discovered that mxtoolbox.com (now) provides an interface to query an SMTP server and report on whether it supports TLS. That's the only evidence we seem to be able to present that TLS is in place.

MSC
  • 101
  • 2
0

You should never send PII via a cleartext email. Even if the network hops are protected by TLS, you can't be certain that the data are encrypted at rest. In many cases the data are available to third or fourth parties-- e.g. Google notably will sift through its users' emails to figure out what advertisements to show you, or to detect patterns in spam-- and you cannot confirm that all of the various systems involved are properly secure or compliant. And even if they are, you can still suffer significant reputational loss if, say, you "privately" email one of your customers about erectile dysfunction, then suddenly he starts seeing ads for Viagra everywhere, because Google leaked a certain keyword into his ad network.

Two alternatives come to mind:

  1. Secure the content of the email with an encryption scheme like PGP.

  2. Don't put the content in the email at all. Instead, provide a link to a site where the user can sign in and view the content. This is how Citrix secure envelope service works, for example.

John Wu
  • 9,181
  • 1
  • 29
  • 39
0

Welcome to the problem of secure email. Lets look at your options:

  1. SMTP

    At a protocol level, SMTP has no concept of security. Like most early internet protocols (I'm looking at you DNS), it was designed assuming no malicious servers around. Assume NOTHING about stuff sent over SMTP for reasons documented in the other answers here

  2. PGP or S/MIME

    Both are application layer overlays securing fundamentally insecure lower layers. That's great but both require the network effect (of users) to work, a problem both inherit from their unavoidable usage of asymmetric encryption (the PKI problem). Considering email (as an application) has the largest number of internet users on the planet, I don't see that changing anytime soon. In a B2C (even in many B2C) situation you're sorely out of luck.

  3. Layer of indirection (aka "Illusion of security")

    This bring no security whatsoever BUT if you're trying to comply with the MA laws on not sending PII, you might be able to send a GUID based link in email, which when clicked present the actual information in a browser. OR use HTML emails where the PII text is actually an image loaded over SSL inside the email client. Technically you're not sending the actual PII over an insecure transport. I don't need to tell you but you need to consult a lawyer if this covers your business risk.

  4. Modify the business requirement ( <== recommended)

    Personally, this is what I'd pick. I'd avoid sending any PII in the email to begin with. If this is email marketing to new customers (B2C), you might actually creep them by putting PII in a cold-email. If you already have these customers (B2C), I'd recommend setting up a web based messaging center behind a login screen (assuming your business has a login portal for it's other stuff). Honestly, this is the approach taken by most banks and hospitals for the exact reason you're experiencing (nobody likes yet another messaging portal but are forced to). That way you can use regular email without PII for mass emails, escalate it to the web portal for cases were PII is required. Budget the builtout of the secure messaging portal (along with SSO integration) and present to the decision makers creating the business need of "must send PII in email" and let them decide if the price is worth the need.

DeepSpace101
  • 2,153
  • 3
  • 23
  • 35