summaryrefslogtreecommitdiff
path: root/src/or/geoip.c
diff options
context:
space:
mode:
authorKarsten Loesing <karsten.loesing@gmx.net>2009-12-17 11:20:31 +0100
committerKarsten Loesing <karsten.loesing@gmx.net>2009-12-17 11:20:31 +0100
commit498c293afe3570210e964456e6cf5a8f315dbfc6 (patch)
tree3c84cad57e5354b7165ffc6ac596df587e403702 /src/or/geoip.c
parente1e5c1b3aba96afbd6fa3b5ece262720dd45a80e (diff)
downloadtor-498c293afe3570210e964456e6cf5a8f315dbfc6.tar.gz
tor-498c293afe3570210e964456e6cf5a8f315dbfc6.zip
Make changes to latest bridge-stats fixes as suggested by Nick.
Diffstat (limited to 'src/or/geoip.c')
-rw-r--r--src/or/geoip.c62
1 files changed, 41 insertions, 21 deletions
diff --git a/src/or/geoip.c b/src/or/geoip.c
index a43daaf067..535e9affff 100644
--- a/src/or/geoip.c
+++ b/src/or/geoip.c
@@ -988,7 +988,7 @@ geoip_dirreq_stats_write(time_t now)
statsdir = get_datadir_fname("stats");
if (check_private_dir(statsdir, CPD_CREATE) < 0)
goto done;
- filename = get_datadir_fname("stats"PATH_SEPARATOR"dirreq-stats");
+ filename = get_datadir_fname2("stats", "dirreq-stats");
data_v2 = geoip_get_client_history_dirreq(now,
GEOIP_CLIENT_NETWORKSTATUS_V2);
data_v3 = geoip_get_client_history_dirreq(now,
@@ -1098,9 +1098,12 @@ static char *
parse_bridge_stats_controller(const char *stats_str, time_t now)
{
char stats_end_str[ISO_TIME_LEN+1], stats_start_str[ISO_TIME_LEN+1],
- *controller_str, *eos;
- const char *stats_end_line = "bridge-stats-end",
- *ips_line = "bridge-ips", *tmp;
+ *controller_str, *eos, *eol, *summary;
+ const char *stats_end_first = "bridge-stats-end ",
+ *stats_end_middle = "\nbridge-stats-end ",
+ *ips_first = "bridge-ips",
+ *ips_middle = "\nbridge-ips",
+ *tmp;
time_t stats_end_time;
size_t controller_len;
int seconds;
@@ -1108,39 +1111,56 @@ parse_bridge_stats_controller(const char *stats_str, time_t now)
/* Parse timestamp and number of seconds from
"bridge-stats-end YYYY-MM-DD HH:MM:SS (N s)" */
- tmp = strstr(stats_str, stats_end_line);
- if (!tmp || strlen(tmp) < strlen(stats_end_line) + 1 + ISO_TIME_LEN + 6)
+ if (!strncmp(stats_str, stats_end_first, strlen(stats_end_first))) {
+ tmp = stats_str + strlen(stats_end_first);
+ } else {
+ tmp = strstr(stats_str, stats_end_middle);
+ if (!tmp)
+ return NULL;
+ tmp += strlen(stats_end_middle);
+ }
+ if (strlen(tmp) < ISO_TIME_LEN + 6)
return NULL;
- strlcpy(stats_end_str, tmp + strlen(stats_end_line) + 1,
- sizeof(stats_end_str));
+ strlcpy(stats_end_str, tmp, sizeof(stats_end_str));
if (parse_iso_time(stats_end_str, &stats_end_time) < 0)
return NULL;
if (stats_end_time < now - (25*60*60) ||
stats_end_time > now + (1*60*60))
return NULL;
- seconds = (int)strtol(tmp + strlen(stats_end_line) + 1 +
- ISO_TIME_LEN + 2, &eos, 10);
+ seconds = (int)strtol(tmp + ISO_TIME_LEN + 2, &eos, 10);
if (!eos || seconds < 23*60*60)
return NULL;
format_iso_time(stats_start_str, stats_end_time - seconds);
/* Parse: "bridge-ips CC=N,CC=N,..." */
- tmp = strstr(tmp, ips_line);
- if (!tmp || strlen(tmp) < strlen(ips_line))
- return NULL;
- if (strlen(tmp) > strlen(ips_line) + 2)
- tmp += strlen(ips_line) + 1;
+ if (!strncmp(stats_str, ips_first, strlen(ips_first))) {
+ tmp = stats_str + strlen(ips_first);
+ } else {
+ tmp = strstr(stats_str, ips_middle);
+ if (!tmp)
+ return NULL;
+ tmp += strlen(ips_middle);
+ }
+ if (strlen(tmp) > 2 && !strncmp(tmp, " ", 1))
+ tmp += 1;
else
tmp = "";
+ summary = tor_malloc(strlen(tmp) + 1);
+ strlcpy(summary, tmp, strlen(tmp) + 1);
+ eol = strstr(summary, "\n");
+ if (eol)
+ eol[0] = '\0';
controller_len = strlen("TimeStarted=\"\" CountrySummary=") +
- ISO_TIME_LEN + strlen(tmp) + 1;
+ strlen(summary) + 42;
controller_str = tor_malloc(controller_len);
if (tor_snprintf(controller_str, controller_len,
"TimeStarted=\"%s\" CountrySummary=%s",
- stats_start_str, tmp) < 0) {
+ stats_start_str, summary) < 0) {
tor_free(controller_str);
+ tor_free(summary);
return NULL;
}
+ tor_free(summary);
return controller_str;
}
@@ -1178,11 +1198,11 @@ geoip_bridge_stats_write(time_t now)
statsdir = get_datadir_fname("stats");
if (check_private_dir(statsdir, CPD_CREATE) < 0)
goto done;
- filename = get_datadir_fname("stats"PATH_SEPARATOR"bridge-stats");
+ filename = get_datadir_fname2("stats", "bridge-stats");
data = geoip_get_client_history_bridge(now, GEOIP_CLIENT_CONNECT);
format_iso_time(written, now);
len = strlen("bridge-stats-end (999999 s)\nbridge-ips \n") +
- ISO_TIME_LEN + (data ? strlen(data) : 0) + 1;
+ ISO_TIME_LEN + (data ? strlen(data) : 0) + 42;
out = tor_malloc(len);
if (tor_snprintf(out, len, "bridge-stats-end %s (%u s)\nbridge-ips %s\n",
written, (unsigned) (now - start_of_bridge_stats_interval),
@@ -1216,7 +1236,7 @@ load_bridge_stats(time_t now)
char *fname, *contents, *controller_str;
if (bridge_stats_extrainfo)
return;
- fname = get_datadir_fname("stats"PATH_SEPARATOR"bridge-stats");
+ fname = get_datadir_fname2("stats", "bridge-stats");
contents = read_file_to_str(fname, 0, NULL);
if (contents) {
controller_str = parse_bridge_stats_controller(contents, now);
@@ -1277,7 +1297,7 @@ geoip_entry_stats_write(time_t now)
statsdir = get_datadir_fname("stats");
if (check_private_dir(statsdir, CPD_CREATE) < 0)
goto done;
- filename = get_datadir_fname("stats"PATH_SEPARATOR"entry-stats");
+ filename = get_datadir_fname2("stats", "entry-stats");
data = geoip_get_client_history_dirreq(now, GEOIP_CLIENT_CONNECT);
format_iso_time(written, now);
out = start_writing_to_stdio_file(filename, OPEN_FLAGS_APPEND,