putting the p back in vpn an overlay network to resist
play

Putting the P back in VPN: An Overlay Network to Resist Traffic - PowerPoint PPT Presentation

Putting the P back in VPN: An Overlay Network to Resist Traffic Analysis Roger Dingledine The Free Haven Project http://freehaven.net/tor/ July 29, Black Hat 2004 Talk Outline Motivation: Why anonymous communication? Personal privacy


  1. Putting the P back in VPN: An Overlay Network to Resist Traffic Analysis Roger Dingledine The Free Haven Project http://freehaven.net/tor/ July 29, Black Hat 2004

  2. Talk Outline  Motivation: Why anonymous communication? − Personal privacy − Corporate and governmental security − Note: Anonymous comm. = Traffic analysis resistant comm.  Characterizing anonymity: Properties and Types  Mixes and proxies: Anonymity building blocks  Onion Routing: Lower latency, Higher Security  Features of Tor: 2 nd Generation Onion Routing  Hidden Servers and Rendezvous Points  Summary and Future Work

  3. Public Networks are Vulnerable to Traffic Analysis  In a Public Network (Internet):  Packet (message) headers identify recipients  Packet routes can be tracked Public Network Responder Initiator Encryption does not hide routing information.

  4. Who Needs Anonymity?  Socially sensitive communicants: − Chat rooms and web forums for abuse survivors, people with illnesses  Law Enforcement: − Anonymous tips or crime reporting − Surveillance and honeypots (sting operations)  Corporations: − Hiding collaborations of sensitive business units or partners − Hide procurement suppliers or patterns − Competitive analysis  Political Dissidents, Whistleblowers  Censorship resistant publishers

  5. Who Needs Anonymity?  You: − Where are you sending email (who is emailing you) − What web sites are you browsing − Where do you work, where are you from − What do you buy, what kind of physicians do you visit, what books do you read, ...

  6. Who Needs Anonymity?  Government

  7. Government Needs Anonymity? Yes, for...  Open source intelligence gathering − Hiding individual analysts is not enough − That a query was from a govt. source may be sensitive  Defense in depth on open and classified networks − Networks with only cleared users (but a million of them)  Dynamic and semitrusted international coalitions − Network can be shared without revealing existence or amount of communication between all parties  Elections and Voting

  8. Government Needs Anonymity? Yes, for...  Networks partially under known hostile control − To attack comm. enemy must take down whole network  Politically sensitive negotiations  Road Warriors  Protecting procurement patterns  Homeland Security Information to/from municipalities, industry,...  Anonymous tips (national security, congressional investigations, etc. In addition to law enforcement)

  9. Existing Protections Can be Improved by Anonymity  Virtual Hidden Networks − Traditional VPNs are not private − Anyone can see the network − Often adversary can see amount of communication − Onion Routing can provide anonymity to hide existence of private network and reduce countermeasure cost

  10. Existing Protections Improved by Anonymity Location Hidden Survivable Services for  − Homeland Security info to/from every town and industry − Censorship resistant publishers − Businesses with high value customers Hidden Server Properties  − Servers accessible from anywhere − Resist attacks from authorized users − Resist Distributed DoS − Resist physical attack − Minimize redundancy, Reduce costs − Provide the above better than: firewalls, multiple redundant servers, physically hardened sites, IP filter, IP traceback

  11. Who Needs Anonymity?  And yes criminals

  12. Who Needs Anonymity?  And yes criminals But they already have it. We need to protect everyone else.

  13. Anonymity Loves Company  You can't be anonymous by yourself − Can have confidentiality by yourself  A network that protects only DoD network users won't hide that connections from that network are from Defense Dept.  You must carry traffic for others to protect yourself  But those others don't want to trust their traffic to just one entity either. Network needs distributed trust .

  14. Anonymous From Whom? Adversary Model Recipient of your message  Sender of your message  => Need Channel and Data Anonymity Observer of network from outside  Network Infrastructure (Insider)  => Need Channel Anonymity Note: Anonymous authenticated communication makes  perfect sense Communicant identification should be inside the basic  channel, not a property of the channel

  15. Focus of this work is anonymity of the communication pipe, not what goes through it

  16. Grab the code and try it out  Published under the BSD license  Not encumbered by Onion Routing patent  Works on Linux, BSD, OS X, Solaris, Win32  Packaged for Debian, Gentoo, FreeBSD  Runs in user space, no need for kernel mods or root http://freehaven.net/tor/

  17. How Do You Get Communication Anonymity?  Many technical approaches  Overview of two extensively used approaches − Mixes − Proxies

  18. What does a mix do? message 1 message 2 message 3 Mix message 4 Randomly permutes and decrypts inputs

  19. What does a mix do? ? message 2 Key property: Adversary can't tell which ciphertext corresponds to a given message

  20. A look under the hood

  21. Basic Mix (Chaum ‘81) PK 3 PK 1 PK 2 Server 3 Server 2 Server 1

  22. Encryption of Message PK 3 PK 1 PK 2 message Ciphertext = E PK1 [E PK2 [E PK3 [message]]]

  23. Basic Chaum-type Mix Server 1 Server 2 Server 3 m1 m2 decrypt m2 decrypt m2 decrypt and and and permute permute permute m2 m3 m3 m1 m3 m1 m1 m3

  24. One honest server preserves privacy Server 1 Server 3 Server 2 ? m3

  25. What if you need quick interaction?  Web browsing, Remote login, Chat, etc.  Mixnets introduced for email and other high latency apps  Each layer of message requires expensive public-key crypto

  26. Basic Anonymizing Proxy anonymizing proxy anonymizing proxy • Channels appear to come from proxy, not true originator • Appropriate for Web connections, etc.: SSL, TLS, SSH (lower cost symmetric encryption) • Examples: The Anonymizer • Advantages: Simple, Focuses lots of traffic for more anonymity • Main Disadvantage: Single point of failure, compromise, attack

  27. Onion Routing Traffic Analysis Resistant Infrastructure  Main Idea: Combine Advantages of mixes and proxies  Use (expensive) public-key crypto to establish circuits  Use (cheaper) symmetric-key crypto to move data − Like SSL/TLS based proxies  Distributed trust like mixes  Related Work (some implemented, some just designs): − ISDN Mixes − Crowds, JAP Webmixes, Freedom Network − Tarzan, Morphmix

  28. Network Structure  Onion routers form an overlay network − Clique topology (for now) − TLS encrypted connections  Proxy interfaces between client machine and onion routing overlay network Client Initiator Responder Internet

  29. Tor

  30. Tor The Onion Routing

  31. Tor Tor's Onion Routing

  32. Tor Circuit Setup • Client Proxy establishes session key + circuit w/ Onion Router 1 Onion Router 1 Client Initiator

  33. Tor Circuit Setup • Client Proxy establishes session key + circuit w/ Onion Router 1 Onion Router 1 • Proxy tunnels through that circuit to extend to Onion Router 2 Onion Router 2 Client Initiator

  34. Tor Circuit Setup • Client Proxy establishes session key + circuit w/ Onion Router 1 Onion Router 1 • Proxy tunnels through that circuit to extend to Onion Router 2 Onion Router 2 • Etc Client Initiator

  35. Tor Circuit Usage • Client Proxy establishes session key + circuit w/ Onion Router 1 Onion Router 1 • Proxy tunnels through that circuit to extend to Onion Router 2 Onion Router 2 • Etc • Client applications connect and communicate over Tor circuit Client Initiator

  36. Tor Circuit Usage • Client Proxy establishes session key + circuit w/ Onion Router 1 Onion Router 1 • Proxy tunnels through that circuit to extend to Onion Router 2 Onion Router 2 • Etc • Client applications connect and communicate over Tor circuit Client Initiator

  37. Tor Circuit Usage • Client Proxy establishes session key + circuit w/ Onion Router 1 Onion Router 1 • Proxy tunnels through that circuit to extend to Onion Router 2 Onion Router 2 • Etc • Client applications connect and communicate over Tor circuit Client Initiator

  38. Where do I go to connect to the network?  Directory Servers − Maintain list of which onion routers are up, their locations, current keys, exit policies, etc. − Directory server keys ship with the code − Control which nodes can join network  Important to guard against Sybil attack and related problems − These directories are cached and served by other servers, to reduce bottlenecks

  39. Some Tor Properties  Simple modular design, Restricted ambitions − 26K lines of C code − Even servers run in user space, no need to be root − Just anonymize the pipe  Can use, e.g., privoxy as front end if desired to anonymize data − SOCKS compliant TCP: includes Web, remote login, mail, chat, more  No need to build proxies for every application − Flexible exit policies, each node chooses what applications/destinations can emerge from it

Recommend


More recommend