| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 | Author: Geoff GoodellTitle: Allow controller to manage circuit extensionsDate: 12 March 2006History:  This was once bug 268.  Moving it into the proposal system for posterity.Test:Tor controllers should have a means of learning more about circuits builtthrough Tor routers.  Specifically, if a Tor controller is connected to a Torrouter, it should be able to subscribe to a new class of events, perhaps"onion" or "router" events.  A Tor router SHOULD then ensure that thecontroller is informed:(a) (NEW) when it receives a connection from some other location, in whichcase it SHOULD indicate (1) a unique identifier for the circuit, and (2) aServerID in the event of an OR connection from another Tor router, andHostname otherwise.(b) (REQUEST) when it receives a request to extend an existing circuit to asuccessive Tor router, in which case it SHOULD provide (1) the uniqueidentifier for the circuit, (2) a Hostname (or, if possible, ServerID) of theprevious Tor router in the circuit, and (3) a ServerID for the requestedsuccessive Tor router in the circuit;(c) (EXTEND) Tor will attempt to extend the circuit to some other router, inwhich case it SHOULD provide the same fields as provided for REQUEST.(d) (SUCCEEDED) The circuit has been successfully extended to some therrouter, in which case it SHOULD provide the same fields as provided forREQUEST.We also need a new configuration option analogous to _leavestreamsunattached,specifying whether the controller is to manage circuit extensions or not.Perhaps we can call it "_leavecircuitsunextended".  When set to 0, Tormanages everything as usual.  When set to 1, a circuit received by the Torrouter cannot transition from "REQUEST" to "EXTEND" state without beingdirected by a new controller command.  The controller command probably doesnot need any arguments, since circuits are extended per client sourcerouting, and all that the controller does is accept or reject the extension.This feature can be used as a basis for enforcing routing policy.
 |