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

[or-cvs] r11370: fixed two bugs dealing with (1) client-side computation of v (tor/branches/114-dist-storage/src/or)



Author: kloesing
Date: 2007-09-04 06:45:12 -0400 (Tue, 04 Sep 2007)
New Revision: 11370

Modified:
   tor/branches/114-dist-storage/src/or/rendcommon.c
   tor/branches/114-dist-storage/src/or/rendservice.c
   tor/branches/114-dist-storage/src/or/test.c
Log:
fixed two bugs dealing with (1) client-side computation of v2 desc-ids and (2) server-side descriptor re-publication intervals; added test for (1)

Modified: tor/branches/114-dist-storage/src/or/rendcommon.c
===================================================================
--- tor/branches/114-dist-storage/src/or/rendcommon.c	2007-09-04 08:54:55 UTC (rev 11369)
+++ tor/branches/114-dist-storage/src/or/rendcommon.c	2007-09-04 10:45:12 UTC (rev 11370)
@@ -97,9 +97,10 @@
   return result;
 }
 
-/* Compute the <b>desc_id</b> for a given base32-encoded <b>service_id</b> and
- * base32-encoded <b>secret_cookie</b> at time <b>now</b> for replica number
- * <b>replica</b>. Return 0 for success, -1 otherwise. */
+/* Compute the binary <b>desc_id</b> for a given base32-encoded
+ * <b>service_id</b> and base32-encoded <b>secret_cookie</b> at time
+ * <b>now</b> for replica number <b>replica</b>. Return 0 for success,
+ * -1 otherwise. */
 int
 rend_compute_v2_desc_id(char *desc_id, const char *service_id_base32,
                         const char *secret_cookie_base32, time_t now,
@@ -121,7 +122,7 @@
                       "Illegal secret cookie.");
     return -1;
   }
-  if (replica < NUMBER_OF_NON_CONSECUTIVE_REPLICAS) {
+  if (replica >= NUMBER_OF_NON_CONSECUTIVE_REPLICAS) {
     log_warn(LD_REND, "Could not compute v2 descriptor ID: "
                       "Replica number out of range: %d", replica);
     return -1;

Modified: tor/branches/114-dist-storage/src/or/rendservice.c
===================================================================
--- tor/branches/114-dist-storage/src/or/rendservice.c	2007-09-04 08:54:55 UTC (rev 11369)
+++ tor/branches/114-dist-storage/src/or/rendservice.c	2007-09-04 10:45:12 UTC (rev 11370)
@@ -1052,11 +1052,13 @@
     smartlist_free(desc_strs);
     smartlist_free(desc_ids);
     /* Update next upload time. */
-    if (seconds_valid - TIME_PERIOD_TWO_V2_DESCS < rendpostperiod)
+    if (seconds_valid - TIME_PERIOD_TWO_V2_DESCS > rendpostperiod)
+      service->next_upload_time = now + rendpostperiod;
+    else if (seconds_valid < TIME_PERIOD_TWO_V2_DESCS)
+      service->next_upload_time = now + seconds_valid + 1;
+    else
       service->next_upload_time = now + seconds_valid -
                                   TIME_PERIOD_TWO_V2_DESCS + 1;
-    else
-      service->next_upload_time = now + rendpostperiod;
     /* Post also the next descriptors, if necessary. */
     if (seconds_valid < TIME_PERIOD_TWO_V2_DESCS) {
       desc_strs = smartlist_create();

Modified: tor/branches/114-dist-storage/src/or/test.c
===================================================================
--- tor/branches/114-dist-storage/src/or/test.c	2007-09-04 08:54:55 UTC (rev 11369)
+++ tor/branches/114-dist-storage/src/or/test.c	2007-09-04 10:45:12 UTC (rev 11370)
@@ -3182,9 +3182,12 @@
 test_v2_rend_desc(void)
 {
   rend_service_descriptor_t *generated, *parsed;
+  char service_id[DIGEST_LEN];
+  char service_id_base32[REND_SERVICE_ID_LEN+1];
   const char *next_desc;
   smartlist_t *desc_strs = smartlist_create();
   smartlist_t *desc_ids = smartlist_create();
+  char computed_desc_id[DIGEST_LEN];
   char parsed_desc_id[DIGEST_LEN];
   crypto_pk_env_t *pk1;
   time_t now;
@@ -3198,6 +3201,8 @@
   base32_encode(secret_cookie_base32, 24 + 1, secret_cookie_bin, 15);
   generated = tor_malloc_zero(sizeof(rend_service_descriptor_t));
   generated->pk = crypto_pk_dup_key(pk1);
+  crypto_pk_get_digest(generated->pk, service_id);
+  base32_encode(service_id_base32, REND_SERVICE_ID_LEN+1, service_id, 10);
   now = time(NULL);
   generated->timestamp = now;
   generated->n_intro_points = 3;
@@ -3224,12 +3229,16 @@
   }
   test_assert(rend_encode_v2_descriptors(desc_strs, desc_ids, generated, now,
                                          secret_cookie_base32, 0) > 0);
+  test_assert(rend_compute_v2_desc_id(computed_desc_id, service_id_base32,
+                                      secret_cookie_base32, now, 0) == 0);
+  test_assert(smartlist_digest_isin(desc_ids, computed_desc_id));
   test_assert(rend_parse_v2_service_descriptor(&parsed, parsed_desc_id,
                                                &intro_points_encrypted,
                                                &intro_points_size,
                                                &next_desc,
                                                desc_strs->list[0]) == 0);
   test_assert(parsed);
+  test_assert(smartlist_digest_isin(desc_ids, parsed_desc_id));
   test_assert(rend_decrypt_introduction_points(parsed, secret_cookie_base32,
                                                intro_points_encrypted,
                                                intro_points_size) == 3);