aboutsummaryrefslogtreecommitdiff
path: root/proposals/ideas
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2008-06-08 02:53:32 +0000
committerRoger Dingledine <arma@torproject.org>2008-06-08 02:53:32 +0000
commitabdf8187e972b6c21a4d402f9f89744fb4b33b93 (patch)
treefd98760d020a7b793aa8779c5ac8220edda9fc5f /proposals/ideas
parent1f78b40c67f73744bee0c7a9fc9b7cd4b13714fd (diff)
downloadtorspec-abdf8187e972b6c21a4d402f9f89744fb4b33b93.tar.gz
torspec-abdf8187e972b6c21a4d402f9f89744fb4b33b93.zip
include tags in the bootstrap status events. also document the
bootstrapping process and how the phases break down. svn:r15020
Diffstat (limited to 'proposals/ideas')
-rw-r--r--proposals/ideas/xxx-bootstrap-phases.txt165
1 files changed, 117 insertions, 48 deletions
diff --git a/proposals/ideas/xxx-bootstrap-phases.txt b/proposals/ideas/xxx-bootstrap-phases.txt
index e7d67d8..aba3ffb 100644
--- a/proposals/ideas/xxx-bootstrap-phases.txt
+++ b/proposals/ideas/xxx-bootstrap-phases.txt
@@ -17,8 +17,8 @@ Status: Open
This proposal describes a new client status event so Tor can give
more details to the controller. Section 2 describes the changes to the
controller protocol; Section 3 describes Tor's internal bootstrapping
- phases assuming everything goes correctly; and Section 4 describes
- how and when Tor chooses to issue bootstrap warnings.
+ phases, both when everything is going correctly and when Tor detects
+ a problem and issues a bootstrap warning.
2. Controller event syntax.
@@ -29,7 +29,7 @@ Status: Open
So in this case we send
650 STATUS_CLIENT NOTICE/WARN BOOTSTRAP \
- PROGRESS=num TAG=string SUMMARY=string
+ PROGRESS=num TAG=string SUMMARY=string WARNING=string
"Progress" gives a number between 0 and 100 for how far through
the bootstrapping process we are. "Summary" is a string that can be
@@ -41,66 +41,135 @@ Status: Open
The severity describes whether this is a normal bootstrap phase
(severity notice) or an indication of a bootstrapping problem
- (severity warn).
+ (severity warn). If severity warn, it should also include a "warning"
+ argument with any hints Tor has to offer about why it's having troubles
+ bootstrapping.
+
+ It is suggested that controllers start out in phase 0 ("starting"), and
+ then watch for either a bootstrap status event (meaning the Tor they're
+ using is sufficiently new to produce them) or a circuit_established
+ status event (meaning bootstrapping is finished).
3. The bootstrap phases.
- Phase 0: tag=STARTING
+ This section describes the various phases currently reported by
+ Tor. Controllers should not assume that the percentages and tags listed
+ here will continue to match up, or even that the tags will stay in
+ the same order. Some phases might also be skipped (not reported) if the
+ associated bootstrap step is already complete.
+
+ Phase 0:
+ tag=starting summary="starting"
+
+ Tor starts out in this phase. It doesn't actually send a status event
+ to say so.
+
+ Phase 5:
+ tag=conn_dir summary="Connecting to directory mirror"
+
+ Tor sends this event as soon as Tor has chosen a directory mirror ---
+ one of the authorities if bootstrapping for the first time or after
+ a long downtime, or one of the relays listed in its cached directory
+ information otherwise.
+
+ Tor will stay at this phase until it has successfully established
+ a TCP connection with some directory mirror. Problems in this phase
+ generally happen because Tor doesn't have a network connection, or
+ because the local firewall is dropping SYN packets.
+
+ Phase 10
+ tag=handshake_dir summary="Finishing handshake with directory mirror"
+
+ This event occurs when Tor establishes a TCP connection with a relay
+ (or its https proxy if it's using one). Tor remains in this phase until
+ the TLS handshake with the relay is finished.
+
+ Problems in this phase generally happen because Tor's firewall is
+ doing more sophisticated MITM attacks on it, or doing packet-level
+ keyword recognition of Tor's handshake.
+
+ Phase 15:
+ tag=onehop_create summary="Establishing one-hop circuit for dir info"
+
+ Once TLS is finished with a relay, Tor will send a CREATE_FAST cell
+ to establish a one-hop circuit for retrieving directory information.
+ It will remain in this phase until it receives the CREATED_FAST cell
+ back, indicating that the circuit is ready.
+
+ Phase 20:
+ tag=requesting_status summary="Asking for networkstatus consensus"
+
+ Once we've finished our one-hop circuit, we will start a new stream
+ for fetching the networkstatus consensus. We'll stay in this phase
+ until we get the 'connected' relay cell back, indicating that we've
+ established a directory connection.
+
+ Phase 25:
+ tag=loading_status summary="Loading networkstatus consensus"
+
+ Once we've established a directory connection, we will start fetching
+ the networkstatus consensus document. This could take a while; this
+ phase is a good opportunity for using the "progress" keyword to indicate
+ partial progress.
+
+ This phase could stall if the directory mirror we picked doesn't
+ have a copy of the networkstatus consensus so we have to ask another,
+ or it does give us a copy but we don't find it valid.
+
+ Phase 40:
+ tag=loading_keys summary="Loading authority key certs"
- Phase 5: tag=CONN_DIR
+ Sometimes when we've finished loading the networkstatus consensus,
+ we find that we don't have all the authority key certificates for the
+ keys that signed the consensus. At that point we put the consensus we
+ fetched on hold and fetch the keys so we can verify the signatures.
- Phase 10: tag=HANDSHAKE_DIR
+ Phase 45
+ tag=requesting_descriptors summary="Asking for relay descriptors"
- Phase 15: tag=ONEHOP_CREATE
+ Once we have a valid networkstatus consensus and we've checked all
+ its signatures, we start asking for relay descriptors. We stay in this
+ phase until we have received a 'connected' relay cell in response to
+ a request for descriptors.
- Phase 20: tag=REQUESTING_STATUS
+ Phase 50:
+ tag=loading_descriptors summary="Loading relay descriptors"
- Phase 25: tag=LOADING_STATUS
+ We will ask for relay descriptors from several different locations,
+ so this step will probably make up the bulk of the bootstrapping,
+ especially for users with slow connections. We stay in this phase until
+ we have descriptors for at least 1/4 of the usable relays listed in
+ the networkstatus consensus. This phase is also a good opportunity to
+ use the "progress" keyword to indicate partial steps.
- Phase 40: tag=LOADING_KEYS
+ Phase 80:
+ tag=conn_or summary="Connecting to entry guard"
- Phase 45: tag=REQUESTING_DESCRIPTORS
+ Once we have a valid consensus and enough relay descriptors, we choose
+ some entry guards and start trying to build some circuits. This step
+ is similar to the "conn_dir" phase above; the only difference is
+ the context.
- Phase 50: tag=LOADING_DESCRIPTORS
+ If a Tor starts with enough recent cached directory information,
+ its first bootstrap status event will be for the conn_or phase.
- Phase 80: tag=CONN_OR
+ Phase 85:
+ tag=handshake_or summary="Finishing handshake with entry guard"
- Phase 85: tag=HANDSHAKE_OR
+ This phase is similar to the "handshake_dir" phase, but it gets reached
+ if we finish a TCP connection to a Tor relay and we have already reached
+ the "conn_or" phase. We'll stay in this phase until we complete a TLS
+ handshake with a Tor relay.
- Phase 90: tag=CIRCUIT_CREATE
+ Phase 90:
+ tag=circuit_create "Establishing circuits"
- Phase 100: tag=DONE
+ Once we've finished our TLS handshake with an entry guard, we will
+ set about rying to make some 3-hop circuits in case we need them soon.
+ Phase 100:
+ tag=done summary="Done"
- 5: fetching authority key certs
- LOADING_KEYS
- (authority_certs_fetch_missing)
-10: Connecting to directory mirror
- CONN_DIR
- (circuit_handle_first_hop)
-15: Finishing handshake with directory mirror
- HANDSHAKE_DIR
- (connection_or_finished_connecting)
-20: Establishing one-hop circuit for dir info
- ONEHOP_CREATE
- (circuit_send_next_onion_skin)
-25: Asking for networkstatus consensus
- REQUESTING_STATUS
- (circuit_send_next_onion_skin)
-30: Fetching networkstatus consensus
- LOADING_STATUS
- (update_consensus_networkstatus_downloads)
-50: Fetching relay descriptors
- LOADING_DESCRIPTORS
- (update_router_have_minimum_dir_info)
-80: Connecting to entry guard
- CONN_OR
- (update_router_have_minimum_dir_info)
-85: Finishing handshake with entry guard
- HANDSHAKE_OR
- (connection_or_finished_connecting)
-90: Establishing circuit
- CIRCUIT_CREATE
- (circuit_send_next_onion_skin)
-100: Done
+ A full 3-hop circuit has been established. Tor is ready to handle
+ application connections now.