[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] Allow multiple ORs with same nickname in routerlist
Update of /home/or/cvsroot/src/or
In directory moria.mit.edu:/tmp/cvs-serv25397/src/or
Modified Files:
routerlist.c
Log Message:
Allow multiple ORs with same nickname in routerlist
Index: routerlist.c
===================================================================
RCS file: /home/or/cvsroot/src/or/routerlist.c,v
retrieving revision 1.115
retrieving revision 1.116
diff -u -d -r1.115 -r1.116
--- routerlist.c 6 Aug 2004 22:47:41 -0000 1.115
+++ routerlist.c 7 Aug 2004 03:38:07 -0000 1.116
@@ -440,43 +440,37 @@
int router_add_to_routerlist(routerinfo_t *router) {
int i;
routerinfo_t *r;
+ char id_digest[DIGEST_LEN];
+
+ crypto_pk_get_digest(router->identity_pkey, id_digest);
+
/* If we have a router with this name, and the identity key is the same,
* choose the newer one. If the identity key has changed, drop the router.
*/
for (i = 0; i < smartlist_len(routerlist->routers); ++i) {
r = smartlist_get(routerlist->routers, i);
- /* XXXX008 should just compare digests instead. */
- if (!strcasecmp(router->nickname, r->nickname)) {
- if (!crypto_pk_cmp_keys(router->identity_pkey, r->identity_pkey)) {
- if (router->published_on > r->published_on) {
- log_fn(LOG_DEBUG, "Replacing entry for router '%s'",
- router->nickname);
- /* Remember whether we trust this router as a dirserver. */
- if (r->is_trusted_dir)
- router->is_trusted_dir = 1;
- /* If the address hasn't changed; no need to re-resolve. */
- if (!strcasecmp(r->address, router->address))
- router->addr = r->addr;
- routerinfo_free(r);
- smartlist_set(routerlist->routers, i, router);
- return 0;
- } else {
- log_fn(LOG_DEBUG, "Skipping old entry for router '%s'",
- router->nickname);
- /* If we now trust 'router', then we trust the one in the routerlist
- * too. */
- if (router->is_trusted_dir)
- r->is_trusted_dir = 1;
- /* Update the is_running status to whatever we were told. */
- r->is_running = router->is_running;
- routerinfo_free(router);
- return -1;
- }
+ if (!crypto_pk_cmp_keys(router->identity_pkey, r->identity_pkey)) {
+ if (router->published_on > r->published_on) {
+ log_fn(LOG_DEBUG, "Replacing entry for router '%s/%s' [%s]",
+ router->nickname, r->nickname, hex_str(id_digest,DIGEST_LEN));
+ /* Remember whether we trust this router as a dirserver. */
+ if (r->is_trusted_dir)
+ router->is_trusted_dir = 1;
+ /* If the address hasn't changed; no need to re-resolve. */
+ if (!strcasecmp(r->address, router->address))
+ router->addr = r->addr;
+ routerinfo_free(r);
+ smartlist_set(routerlist->routers, i, router);
+ return 0;
} else {
- /* XXXX008 It's okay to have two keys for a nickname as soon as
- * all the 007 clients are dead. */
- log_fn(LOG_WARN, "Identity key mismatch for router '%s'",
+ log_fn(LOG_DEBUG, "Skipping old entry for router '%s'",
router->nickname);
+ /* If we now trust 'router', then we trust the one in the routerlist
+ * too. */
+ if (router->is_trusted_dir)
+ r->is_trusted_dir = 1;
+ /* Update the is_running status to whatever we were told. */
+ r->is_running = router->is_running;
routerinfo_free(router);
return -1;
}