296
submitted 1 year ago by kixik@lemmy.ml to c/firefox@lemmy.ml
all 30 comments
sorted by: hot top controversial new old
[-] justinh_tx@lemmy.ml 14 points 1 year ago

If a packet is traversing an ISP's network the ISP should have to know where it is coming from and where it is going, right? So even if you "encrypt the first hello" packet, the ISP would still know where it was routed, right?

I'll freely admit I have only a very basic (and likely outdated) understanding of IP networking, but I don't see how this protects my browsing habits from my ISP. Even if they can't understand my "hello" to lemmy.ml, they still know I'm talking to lemmy.ml's IP address about something.

What am I missing?

[-] jmcs@discuss.tchncs.de 19 points 1 year ago

Your ISP is mostly going to be seeing AWS, Azure, GCP, Cloudflare, etc IP addresses.

[-] Bitrot@lemmy.sdf.org 12 points 1 year ago* (last edited 1 year ago)

They would know you’re talking to that IP, not necessarily lemmy.ml. It is very common for multiple sites to be hosted on the same ip. The reason SNI exists is so the browser can tell the server which site it was looking for in an encrypted session. If it is 1:1 then it would be true.

[-] onelikeandidie@lemmy.world 8 points 1 year ago

When you type in www.example.com, you request the IP of the server for that site using a DNS server. The DNS server sends you the IP and then you connect to it. If they are using https for DNS it means that your ISP or onlookers have to reverse which domain you're accessing from that IP to know that you're accessing www.example.com.

At least I think that's what is happening.

[-] Bitrot@lemmy.sdf.org 11 points 1 year ago* (last edited 1 year ago)

The problem doesn’t involve DNS, it’s after that step.

SNI is when your browser connects to the server. A server may host multiple sites on the same IP, so your browser says “I would like to open an encrypted session to lemmy.ml”. It does this in the clear. If it was an unencrypted http site it would be in headers, but in https those headers aren’t passed until after the encrypted session is set up, so there has to be some way for the server to know the specific site. Anybody listening to SNI traffic knows the exact site you connected to, even if there are hundreds at that ip.

This adds a public key to the DNS record, so your browser is able to encrypt that initial hello message before the https session is encrypted. Someone listening might see something like “ECH: randomgibberish” but the server can decrypt it.

[-] venusenvy47@reddthat.com 6 points 1 year ago

If I understand correctly, someone other than your ISP could see the name of the website, since it isn't encrypted. I think it would bounce through several servers that could possibly read the data.

[-] SquigglyEmpire@lemmy.world 3 points 1 year ago

This makes it so that your ISP doesn't see the actual name of the server/site you're communicating with, only the IP address. Without Encrypted Hello they're able to see both.

[-] venusenvy47@reddthat.com 4 points 1 year ago

I would think that an IP address tells you the domain name by doing a simple DNS lookup.

[-] SquigglyEmpire@lemmy.world 4 points 1 year ago* (last edited 1 year ago)

In many cases you can, but there's never a guarantee that a given IP address will have reverse DNS records configured for resolve it into. On top of that, if it's a major site it's likely hosted behind a content delivery network that may a share a single IP address across thousands or even millions of completely unrelated servers. Cloudflare does some pretty interesting stuff with that approach: https://blog.cloudflare.com/cloudflare-servers-dont-own-ips-anymore/ edit: bad at typing

[-] achsonaja@lemm.ee 1 points 1 year ago

Yeah I think it has the same limitations that pretty much anything not through a vpn has because you still have to tell your isp where to send the data. Your isp will still see some things, even if it’s encrypted (metadata, DPI, habits, and things beyond my knowledge). This sounds like a step in the right direction for the majority of people though, even if it’s minor.

I kind of see it like differentiating between them seeing lemmy.ml via this vs lemmy.ml/thing-i-want-private/peronal.html without it, but I could be wrong about that.

[-] Bitrot@lemmy.sdf.org 4 points 1 year ago* (last edited 1 year ago)

HTTPS already prevents them from knowing exactly what content you’re looking at. Hiding SNI prevents them from knowing exactly what site you are connecting to via HTTPS.

They can still figure that out if you’re using unencrypted DNS or if there is a 1:1 IP to rDNS mapping though.

[-] achsonaja@lemm.ee 8 points 1 year ago

Does this rely on DOH? Seems like if I’m running my own recursive DNS that this won’t apply to me.

[-] iopq@lemmy.world 3 points 1 year ago

Your request still has an unencrypted client hello, so you wasted all that DoH effort by sending the website name in clear text

[-] library_napper@monyet.cc 7 points 1 year ago

Ok, but how many servers support it?

[-] tranxuanthang@lemm.ee 15 points 1 year ago

All sites that are proxied through Cloudflare, even free tier. So it's safe to say half of internet are supported ECH already.

[-] library_napper@monyet.cc 3 points 1 year ago

That's a low bar. I can't even access most of those sites due to misconfiguration of the antibot settings.

I'm mostly asking for the websites that I run, which are not behind CF.

[-] taladar@sh.itjust.works 5 points 1 year ago

ECH is designed to interoperate with these practices and respect the existing DoH opt-outs in Firefox

This makes no sense. Just because I don't want to bypass my local DNS server it shouldn't leave my TLS Hello packets unencrypted.

[-] Bitrot@lemmy.sdf.org 4 points 1 year ago

I had missed this originally, very disappointing choice by Mozilla.

this post was submitted on 05 Oct 2023
296 points (100.0% liked)

Firefox

17937 readers
21 users here now

A place to discuss the news and latest developments on the open-source browser Firefox

founded 4 years ago
MODERATORS