With automatic tor HS support in place we should probably not be providing absolute protection for local peers, since HS inbound could be used to attack pretty easily. Instead, this counts on the latency metric inside AttemptToEvictConnection to privilege actually local peers.
This change also makes eviction generally more aggressive by making it willing to evict the unprotected peer in a netgroup, if the new connection comes from a netgroup where we have no unprotected peers.
It also makes sure that in the case of tying group size to select the group with the newest member, since newest time is the final selection criteria.
The third commit protects four peers that most recently sent us a valid transaction to our memory pool. This metric is costly for attackers to control since it requires sending acceptable transactions, and an attacker which is blocking transactions is inherently disadvantaged for this criteria.