"Nick Mathewson" wrote:
>If the number of guards we have *tried* to connect to in
>the last PERIOD days is greater than
>CANDIDATE_THRESHOLD, do not attempt to connect
>to any other guards; only attempt the ones we have
>previously *tried* to connect to.

Torrc allows the use of multiple guards with numentryguards > 1. So if an adversary hasn't yet managed to compromise the guard this might lead to a DOS. The adversary may be interested in getting you to connect to *one* malicious guard at a time. It might be worth considering to perform a reach-ability test using a built circuit. I mention "built" because Tor wouldn't know if the connectable guard is adversary controlled. It might also be worth considering guards that successfully connect after a failure as suspect for a time. That is, they shouldn't be optimistically added to the list of guards unless absolutely needed.

>We need to make this play nicely with mobility. When
>a user has three guards on port 9001 and they move
>to a firewall that only allows 80/443, we'd prefer that
>they not simply grind to a halt. If nodes are configured
>to stop when too many of their guards have gone away,
>this will confuse them.

If 80/443 are the least restricted types of connection maybe it would be a good idea to try n of those before stopping. If they work but other guards fail it might be a symptom of a fascist firewall to warn about.

>If people need to turn FascistFirewall on and off, great.
>But if they just clear their state file as a workaround,
>that's not so good.

If FacistFirewall is 1 with some ports specified, and state isn't empty, don't consider the disjoint guards contributing to thresholds?

>If we could tie guard choice to location, that would
>help a great deal, but we'd need to answer the question,
>"Where am I on the network", which is not so easy to
>do passively if you're behind a NAT.

If network location were the combination of physicaladdr+dnsname+subnet would it be so bad if you're behind a NAT and dnsname were unavailable?

--leeroy