determining which are the ORs a Tor circuit is using
Sambuddho Chakravarty
sc2516 at columbia.edu
Tue Nov 11 23:43:47 UTC 2008
Hello
On Tue, 2008-11-11 at 17:32 -0500, Roger Dingledine wrote:
> Btw, please pick only one mailing list to send your mail to. Your
> follow-up mail actually sent it to three lists, not just two. This is
> not cool. :)
>
> On Tue, Nov 11, 2008 at 02:50:14PM -0500, Sambuddho Chakravarty wrote:
> > Hello All
> > I have a general question. I am using the default torrc (without
> > specifying which ORs to select and letting the client determine the
> > "best" ones for itself). Is there a way to detect which are the ORs the
> > client picks up for the entry , middleman and exit nodes (rather than
> > hacking into the source code of the tor client). I am using a rather
> > dated version of the client - 0.1.2.18.
>
> The traditional way to do this is to open your Tor's control port,
> and then attach a controller program (lika Vidalia, but you can write
> your own too with the torctl libraries) to ask questions like this. See
> doc/spec/control-spec.txt for many more details.
>
> For example, if you send
> setevents extended circ stream
>
> Then for streams you get lines like this
>
> 650 STREAM 17 NEW 0 www.google.com:80 SOURCE_ADDR=127.0.0.1:51279 PURPOSE=USER
> 650 STREAM 17 SENTCONNECT 5 www.google.com:80
> 650 STREAM 17 REMAP 5 72.14.235.104:80 SOURCE=EXIT
> 650 STREAM 17 SUCCEEDED 5 72.14.235.104:80
> 650 STREAM 18 NEW 0 www.google.com.tw:80 SOURCE_ADDR=127.0.0.1:51280 PURPOSE=USER
> 650 STREAM 18 SENTCONNECT 5 www.google.com.tw:80
> 650 STREAM 18 REMAP 5 72.14.235.99:80 SOURCE=EXIT
> 650 STREAM 18 SUCCEEDED 5 72.14.235.99:80
> 650 STREAM 17 CLOSED 5 72.14.235.104:80 REASON=END REMOTE_REASON=unknown
>
> and interspersed with that you get circ info like
> 650 CIRC 10 LAUNCHED PURPOSE=GENERAL
> 650 CIRC 10 EXTENDED $43AF24071B400911629D5BC9FC20DE335F9DFC00 PURPOSE=GENERAL
> 650 CIRC 10 EXTENDED $43AF24071B400911629D5BC9FC20DE335F9DFC00,ratator PURPOSE=GENERAL
> 650 CIRC 10 EXTENDED $43AF24071B400911629D5BC9FC20DE335F9DFC00,ratator,$D3EAC880BECBE5F80DB4609F225D351CC4F72395 PURPOSE=GENERAL
> 650 CIRC 10 BUILT $43AF24071B400911629D5BC9FC20DE335F9DFC00,ratator,$D3EAC880BEC
>
Does this correlate to the place in the code in the file circuitbuilt.c
where you are signalling a circiut to go from closed state to open
state.
circuit_send_next_onion_skin()
{
..
if (!hop) {
/* done building the circuit. whew. */
circuit_set_state(TO_CIRCUIT(circ), CIRCUIT_STATE_OPEN);
log_info(LD_CIRC,"circuit built!");
circuit_reset_failure_count(0);
if (!has_completed_circuit && !circ->build_state->onehop_tunnel) {
or_options_t *options = get_options();
has_completed_circuit=1;
/* FFFF Log a count of known routers here */
log(LOG_NOTICE, LD_GENERAL,
"Tor has successfully opened a circuit. "
"Looks like client functionality is working.");
}
Thanks
Sambuddho
> You can also do a command like
> getinfo circuit-status
> which will spit out a summary:
>
> getinfo circuit-status
> 250+circuit-status=
> 9 EXTENDED gremlin,pickaproxy
> 8 BUILT BostonUCompSci,$D0FF59689F9148D47B03DC03025853C80315A930,$D1C0C9FF2F88EB291DD436A1485DD471EB80D40F
> 6 BUILT gremlin,myrnaloy,godzilla,tor26
> 4 BUILT gremlin,SEC,vallenator
> 3 BUILT $43AF24071B400911629D5BC9FC20DE335F9DFC00,$8318A0A99B26785C6AB59FB3A290F6A04ADDD42C,vallenator
> 2 BUILT BostonUCompSci,$2682892CB12EDA0B69049C42A8483A680F70F56F,$83044401FD17BB48723049ED5BF7F1E9A9AB1A00,EviDancerDirServer
> 1 BUILT gremlin,SEC,$F701FBB7B5B70B765751D71DA8FE40E517223331
> .
>
> --Roger
>
>
More information about the tor-talk
mailing list