diff options
author | Paul Syverson <syverson@itd.nrl.navy.mil> | 2003-11-04 18:39:31 +0000 |
---|---|---|
committer | Paul Syverson <syverson@itd.nrl.navy.mil> | 2003-11-04 18:39:31 +0000 |
commit | 7f350d80b166d7bbc778eb06c6e0078a48195118 (patch) | |
tree | 588f0e49883b18cf3fd412c0750985fc5d228d09 /doc/tor-design.tex | |
parent | e1ac0c03de386b71ad1784de3fea70b0a9432442 (diff) | |
download | tor-7f350d80b166d7bbc778eb06c6e0078a48195118.tar tor-7f350d80b166d7bbc778eb06c6e0078a48195118.tar.gz |
More space hacks. No content removal.
svn:r758
Diffstat (limited to 'doc/tor-design.tex')
-rw-r--r-- | doc/tor-design.tex | 44 |
1 files changed, 20 insertions, 24 deletions
diff --git a/doc/tor-design.tex b/doc/tor-design.tex index 082279390..4b3e9e156 100644 --- a/doc/tor-design.tex +++ b/doc/tor-design.tex @@ -474,7 +474,7 @@ low-latency systems, Tor does not protect against such a strong adversary. Instead, we assume an adversary who can observe some fraction of network traffic; who can generate, modify, delete, or delay traffic on the network; who can operate onion routers of its own; and who can -compromise some fraction of the onion routers on the network. +compromise some fraction of the onion routers. In low-latency anonymity systems that use layered encryption, the adversary's typical goal is to observe both the initiator and the @@ -506,10 +506,9 @@ the network's reliability by attacking nodes or by performing antisocial activities from reliable servers and trying to get them taken down; making the network unreliable flushes users to other less anonymous systems, where they may be easier to attack. - -We consider each of these attacks in more detail below, and summarize +We summarize in Section~\ref{sec:attacks} how well the Tor design defends against -each of them. +each of these attacks. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% @@ -601,7 +600,6 @@ and to acknowledge), \emph{relay truncate} and \emph{relay truncated} (to tear down only part of the circuit, and to acknowledge), \emph{relay sendme} (used for congestion control), and \emph{relay drop} (used to implement long-range dummies). - We describe each of these cell types and commands in more detail below. \SubSection{Circuits and streams} @@ -623,11 +621,12 @@ even heavy users spend a negligible amount of time and CPU in building circuits, but only a limited number of requests can be linked to each other through a given exit node. Also, because circuits are built in the background, OPs can recover from failed circuit creation -without delaying streams and thereby harming user experience. +without delaying streams and thereby harming user experience.\\ -\subsubsection{Constructing a circuit} +\noindent {\large Constructing a circuit}\\ +%\subsubsection{Constructing a circuit} \label{subsubsec:constructing-a-circuit} - +% A user's OP constructs a circuit incrementally, negotiating a symmetric key with each OR on the circuit, one hop at a time. To begin creating a new circuit, the OP (call her Alice) sends a @@ -687,10 +686,11 @@ signature in the second step) because a single cell is too small to hold both a public key and a signature. Preliminary analysis with the NRL protocol analyzer \cite{meadows96} shows the above protocol to be secure (including providing perfect forward secrecy) under the -traditional Dolev-Yao model. - -\subsubsection{Relay cells} +traditional Dolev-Yao model.\\ +\noindent {\large Relay cells}\\ +%\subsubsection{Relay cells} +% Once Alice has established the circuit (so she shares keys with each OR on the circuit), she can send relay cells. Recall that every relay cell has a streamID in the relay header that indicates to which @@ -1382,11 +1382,10 @@ acknowledge his existence. \Section{Attacks and Defenses} \label{sec:attacks} -Below we summarize a variety of attacks, and discuss how well our -design withstands them. - -\subsubsection*{Passive attacks} +%Below we summarize a variety of attacks, and discuss how well our +%design withstands them.\\ +\noindent{\large Passive attacks}\\ \emph{Observing user traffic patterns.} Observing the connection from the user will not reveal her destination or data, but it will reveal traffic patterns (both sent and received). Profiling via user @@ -1452,10 +1451,9 @@ all circuits through the network, combined with those from the network edges to the targeted user and the responder website. While these are in principle feasible and surprises are always possible, these constitute a much more complicated attack, and there is no -current evidence of their practicality.} - -\subsubsection*{Active attacks} +current evidence of their practicality.}\\ +\noindent {\large Active attacks}\\ \emph{Compromise keys.} An attacker who learns the TLS session key can see control cells and encrypted relay cells on every circuit on that connection; learning a circuit @@ -1580,10 +1578,9 @@ prevent an attacker from subverting the official release itself (through threats, bribery, or insider attacks), we provide all releases in source code form, encourage source audits, and frequently warn our users never to trust any software (even from -us!) that comes without source. - -\subsubsection*{Directory attacks} +us!) that comes without source.\\ +\noindent{\large Directory attacks}\\ \emph{Destroy directory servers.} If a few directory servers drop out of operation, the others still arrive at a final directory. So long as any directory servers remain in operation, @@ -1629,10 +1626,9 @@ connection to it. A hostile OR could easily subvert this test by accepting TLS connections from ORs but ignoring all cells. Directory servers must actively test ORs by building circuits and streams as appropriate. The tradeoffs of a similar approach are discussed in -\cite{mix-acc}. +\cite{mix-acc}.\\ -\subsubsection*{Attacks against rendezvous points} - +\noindent {\large Attacks against rendezvous points}\\ \emph{Make many introduction requests.} An attacker could try to deny Bob service by flooding his Introduction Point with requests. Because the introduction point can block requests that |