[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r12633: Reject uploaded descriptors and extrainfo documents if they' (in tor/trunk: . src/or)



Author: arma
Date: 2007-12-02 01:11:53 -0500 (Sun, 02 Dec 2007)
New Revision: 12633

Modified:
   tor/trunk/ChangeLog
   tor/trunk/src/or/dirserv.c
   tor/trunk/src/or/or.h
Log:
Reject uploaded descriptors and extrainfo documents if they're
huge. Otherwise we'll cache them all over the network and it'll
clog everything up.


Modified: tor/trunk/ChangeLog
===================================================================
--- tor/trunk/ChangeLog	2007-12-02 06:11:26 UTC (rev 12632)
+++ tor/trunk/ChangeLog	2007-12-02 06:11:53 UTC (rev 12633)
@@ -1,4 +1,4 @@
-Changes in version 0.2.0.13-alpha - 2007-11-??
+Changes in version 0.2.0.13-alpha - 2007-12-??
   o Major bugfixes:
     - Only update guard status (usable / not usable) once we have
       enough directory information. This was causing us to always pick
@@ -21,6 +21,9 @@
       crashed if we had tried to parse one). Bugfix on 0.2.0.x; patch
       by Karsten Loesing.
     - Fix building with dmalloc 5.5.2 with glibc.
+    - Reject uploaded descriptors and extrainfo documents if they're
+      huge. Otherwise we'll cache them all over the network and it'll
+      clog everything up.
 
   o Minor features:
     - On USR1, when dmalloc is in use, log the top 10 memory

Modified: tor/trunk/src/or/dirserv.c
===================================================================
--- tor/trunk/src/or/dirserv.c	2007-12-02 06:11:26 UTC (rev 12632)
+++ tor/trunk/src/or/dirserv.c	2007-12-02 06:11:53 UTC (rev 12633)
@@ -640,6 +640,22 @@
   char *desc = NULL;
   size_t desclen = 0;
 
+  /* If it's too big, refuse it now. Otherwise we'll cache it all over the
+   * network and it'll clog everything up. */
+  if (ri->cache_info.signed_descriptor_len > MAX_DESCRIPTOR_UPLOAD_SIZE) {
+    log_notice(LD_DIR, "Somebody attempted to publish a router descriptor "
+               "with size %d. Either this is an attack, or the "
+               "MAX_DESCRIPTOR_UPLOAD_SIZE (%d) constant is too low.",
+               (int)ri->cache_info.signed_descriptor_len,
+               MAX_DESCRIPTOR_UPLOAD_SIZE);
+    *msg = "Router descriptor was too large";
+    control_event_or_authdir_new_descriptor("REJECTED",
+               ri->cache_info.signed_descriptor_body,
+               ri->cache_info.signed_descriptor_len, *msg);
+    routerinfo_free(ri);
+    return -1;
+  }
+
   /* Check whether this descriptor is semantically identical to the last one
    * from this server.  (We do this here and not in router_add_to_routerlist
    * because we want to be able to accept the newest router descriptor that
@@ -703,6 +719,20 @@
     extrainfo_free(ei);
     return -1;
   }
+
+  /* If it's too big, refuse it now. Otherwise we'll cache it all over the
+   * network and it'll clog everything up. */
+  if (ei->cache_info.signed_descriptor_len > MAX_EXTRAINFO_UPLOAD_SIZE) {
+    log_notice(LD_DIR, "Somebody attempted to publish an extrainfo "
+               "with size %d. Either this is an attack, or the "
+               "MAX_EXTRAINFO_UPLOAD_SIZE (%d) constant is too low.",
+               (int)ei->cache_info.signed_descriptor_len,
+               MAX_EXTRAINFO_UPLOAD_SIZE);
+    *msg = "Extrainfo document was too large";
+    extrainfo_free(ei);
+    return -1;
+  }
+
   if ((r = routerinfo_incompatible_with_extrainfo(ri, ei, NULL, msg))) {
     extrainfo_free(ei);
     return r < 0 ? 0 : -1;

Modified: tor/trunk/src/or/or.h
===================================================================
--- tor/trunk/src/or/or.h	2007-12-02 06:11:26 UTC (rev 12632)
+++ tor/trunk/src/or/or.h	2007-12-02 06:11:53 UTC (rev 12633)
@@ -141,6 +141,14 @@
  * as an upload. */
 #define MAX_DIR_UL_SIZE 500000
 
+/** Maximum size, in bytes, of a single router descriptor uploaded to us
+ * as a directory authority. Caches and clients fetch whatever descriptors
+ * the authorities tell them to fetch, and don't care about size. */
+#define MAX_DESCRIPTOR_UPLOAD_SIZE 20000
+
+/** Maximum size of a single extrainfo document, as above. */
+#define MAX_EXTRAINFO_UPLOAD_SIZE 50000
+
 /** How long do we keep DNS cache entries before purging them (regardless of
  * their TTL)? */
 #define MAX_DNS_ENTRY_AGE (30*60)