aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2010-11-12 14:13:17 -0500
committerNick Mathewson <nickm@torproject.org>2010-11-12 14:13:17 -0500
commit3d7772ece3128097f4d541585e525c61f6ea27c2 (patch)
treecab8cee7627067f9c09d189eb8e666ee14914bab /src
parentd61736aa6a226a935b8dbfd90bc86b60a99149b1 (diff)
parent8833381d9c6ae274599b16fc11cec7527b12c465 (diff)
downloadtor-3d7772ece3128097f4d541585e525c61f6ea27c2.tar.gz
tor-3d7772ece3128097f4d541585e525c61f6ea27c2.zip
Merge remote branch 'karsten/enhancement1883'
Diffstat (limited to 'src')
-rw-r--r--src/or/geoip.c20
-rw-r--r--src/or/geoip.h1
-rw-r--r--src/or/router.c10
3 files changed, 31 insertions, 0 deletions
diff --git a/src/or/geoip.c b/src/or/geoip.c
index ee8d72ee1d..ae0776a571 100644
--- a/src/or/geoip.c
+++ b/src/or/geoip.c
@@ -44,6 +44,9 @@ static strmap_t *country_idxplus1_by_lc_code = NULL;
/** A list of all known geoip_entry_t, sorted by ip_low. */
static smartlist_t *geoip_entries = NULL;
+/** SHA1 digest of the GeoIP file to include in extra-info descriptors. */
+static char geoip_digest[DIGEST_LEN];
+
/** Return the index of the <b>country</b>'s entry in the GeoIP DB
* if it is a valid 2-letter country code, otherwise return -1.
*/
@@ -201,6 +204,7 @@ geoip_load_file(const char *filename, or_options_t *options)
FILE *f;
const char *msg = "";
int severity = options_need_geoip_info(options, &msg) ? LOG_WARN : LOG_INFO;
+ crypto_digest_env_t *geoip_digest_env = NULL;
clear_geoip_db();
if (!(f = fopen(filename, "r"))) {
log_fn(severity, LD_GENERAL, "Failed to open GEOIP file %s. %s",
@@ -214,11 +218,13 @@ geoip_load_file(const char *filename, or_options_t *options)
smartlist_free(geoip_entries);
}
geoip_entries = smartlist_create();
+ geoip_digest_env = crypto_new_digest_env();
log_notice(LD_GENERAL, "Parsing GEOIP file.");
while (!feof(f)) {
char buf[512];
if (fgets(buf, (int)sizeof(buf), f) == NULL)
break;
+ crypto_digest_add_bytes(geoip_digest_env, buf, strlen(buf));
/* FFFF track full country name. */
geoip_parse_entry(buf);
}
@@ -231,6 +237,11 @@ geoip_load_file(const char *filename, or_options_t *options)
* country. */
refresh_all_country_info();
+ /* Remember file digest so that we can include it in our extra-info
+ * descriptors. */
+ crypto_digest_get_digest(geoip_digest_env, geoip_digest, DIGEST_LEN);
+ crypto_free_digest_env(geoip_digest_env);
+
return 0;
}
@@ -278,6 +289,15 @@ geoip_is_loaded(void)
return geoip_countries != NULL && geoip_entries != NULL;
}
+/** Return the hex-encoded SHA1 digest of the loaded GeoIP file. The
+ * result does not need to be deallocated, but will be overwritten by the
+ * next call of hex_str(). */
+const char *
+geoip_db_digest(void)
+{
+ return hex_str(geoip_digest, DIGEST_LEN);
+}
+
/** Entry in a map from IP address to the last time we've seen an incoming
* connection from that IP address. Used by bridges only, to track which
* countries have them blocked. */
diff --git a/src/or/geoip.h b/src/or/geoip.h
index 68e01deecc..ac38c00da5 100644
--- a/src/or/geoip.h
+++ b/src/or/geoip.h
@@ -21,6 +21,7 @@ int geoip_get_country_by_ip(uint32_t ipaddr);
int geoip_get_n_countries(void);
const char *geoip_get_country_name(country_t num);
int geoip_is_loaded(void);
+const char *geoip_db_digest(void);
country_t geoip_get_country(const char *countrycode);
void geoip_note_client_seen(geoip_client_action_t action,
diff --git a/src/or/router.c b/src/or/router.c
index a188d50f94..4d3c66f4d5 100644
--- a/src/or/router.c
+++ b/src/or/router.c
@@ -2012,6 +2012,16 @@ extrainfo_dump_to_string(char *s, size_t maxlen, extrainfo_t *extrainfo,
if (result<0)
return -1;
+ if (geoip_is_loaded()) {
+ if (tor_snprintf(s + strlen(s), maxlen - strlen(s),
+ "geoip-db-digest %s\n",
+ geoip_db_digest()) < 0) {
+ log_warn(LD_DIR, "Could not write geoip-db-digest to extra-info "
+ "descriptor.");
+ return -1;
+ }
+ }
+
if (options->ExtraInfoStatistics && write_stats_to_extrainfo) {
char *contents = NULL;
log_info(LD_GENERAL, "Adding stats to extra-info descriptor.");