aboutsummaryrefslogtreecommitdiff
path: root/doc/spec/proposals/ideas/xxx-separate-streams-by-port.txt
blob: f26c1e580feb1f9845bf48ded3b75d2687a350f2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
Filename: xxx-separate-streams-by-port.txt
Title: Separate streams across circuits by destination port
Author: Robert Hogan
Created: 21-Oct-2008
Status: Draft

Here's a patch Robert Hogan wrote to use only one destination port per
circuit. It's based on a wishlist item Roger wrote, to never send AIM
usernames over the same circuit that we're hoping to browse anonymously
through. The remaining open question is: how many extra circuits does this
cause an ordinary user to create? My guess is not very many, but I'm wary
of putting this in until we have some better estimate. On the other hand,
not putting it in means that we have a known security flaw. Hm.

Index: src/or/or.h
===================================================================
--- src/or/or.h (revision 17143)
+++ src/or/or.h (working copy)
@@ -1874,6 +1874,7 @@

   uint8_t state; /**< Current status of this circuit. */
   uint8_t purpose; /**< Why are we creating this circuit? */
+  uint16_t service; /**< Port conn must have to use this circuit. */

   /** How many relay data cells can we package (read from edge streams)
    * on this circuit before we receive a circuit-level sendme cell asking
Index: src/or/circuituse.c
===================================================================
--- src/or/circuituse.c (revision 17143)
+++ src/or/circuituse.c (working copy)
@@ -62,10 +62,16 @@
       return 0;
   }

-  if (purpose == CIRCUIT_PURPOSE_C_GENERAL)
+  if (purpose == CIRCUIT_PURPOSE_C_GENERAL) {
     if (circ->timestamp_dirty &&
        circ->timestamp_dirty+get_options()->MaxCircuitDirtiness <= now)
       return 0;
+    /* If the circuit is dirty and used for services on another port,
+      then it is not suitable. */
+    if (circ->service && conn->socks_request->port &&
+       (circ->service != conn->socks_request->port))
+      return 0;
+  }

   /* decide if this circ is suitable for this conn */

@@ -1351,7 +1357,9 @@
     if (connection_ap_handshake_send_resolve(conn) < 0)
       return -1;
   }
-
+  if (conn->socks_request->port
+     && (TO_CIRCUIT(circ)->purpose == CIRCUIT_PURPOSE_C_GENERAL))
+    TO_CIRCUIT(circ)->service = conn->socks_request->port;
   return 1;
 }