mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-12-03 00:53:32 +01:00
Make changes to latest bridge-stats fixes as suggested by Nick.
This commit is contained in:
parent
e1e5c1b3ab
commit
498c293afe
@ -80,7 +80,6 @@ connection_or_clear_identity_map(void)
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
digestmap_free(orconn_identity_map, NULL);
|
digestmap_free(orconn_identity_map, NULL);
|
||||||
orconn_identity_map = NULL;
|
orconn_identity_map = NULL;
|
||||||
}
|
}
|
||||||
|
@ -988,7 +988,7 @@ geoip_dirreq_stats_write(time_t now)
|
|||||||
statsdir = get_datadir_fname("stats");
|
statsdir = get_datadir_fname("stats");
|
||||||
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
||||||
goto done;
|
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,
|
data_v2 = geoip_get_client_history_dirreq(now,
|
||||||
GEOIP_CLIENT_NETWORKSTATUS_V2);
|
GEOIP_CLIENT_NETWORKSTATUS_V2);
|
||||||
data_v3 = geoip_get_client_history_dirreq(now,
|
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)
|
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],
|
char stats_end_str[ISO_TIME_LEN+1], stats_start_str[ISO_TIME_LEN+1],
|
||||||
*controller_str, *eos;
|
*controller_str, *eos, *eol, *summary;
|
||||||
const char *stats_end_line = "bridge-stats-end",
|
const char *stats_end_first = "bridge-stats-end ",
|
||||||
*ips_line = "bridge-ips", *tmp;
|
*stats_end_middle = "\nbridge-stats-end ",
|
||||||
|
*ips_first = "bridge-ips",
|
||||||
|
*ips_middle = "\nbridge-ips",
|
||||||
|
*tmp;
|
||||||
time_t stats_end_time;
|
time_t stats_end_time;
|
||||||
size_t controller_len;
|
size_t controller_len;
|
||||||
int seconds;
|
int seconds;
|
||||||
@ -1108,39 +1111,56 @@ parse_bridge_stats_controller(const char *stats_str, time_t now)
|
|||||||
|
|
||||||
/* Parse timestamp and number of seconds from
|
/* Parse timestamp and number of seconds from
|
||||||
"bridge-stats-end YYYY-MM-DD HH:MM:SS (N s)" */
|
"bridge-stats-end YYYY-MM-DD HH:MM:SS (N s)" */
|
||||||
tmp = strstr(stats_str, stats_end_line);
|
if (!strncmp(stats_str, stats_end_first, strlen(stats_end_first))) {
|
||||||
if (!tmp || strlen(tmp) < strlen(stats_end_line) + 1 + ISO_TIME_LEN + 6)
|
tmp = stats_str + strlen(stats_end_first);
|
||||||
|
} else {
|
||||||
|
tmp = strstr(stats_str, stats_end_middle);
|
||||||
|
if (!tmp)
|
||||||
return NULL;
|
return NULL;
|
||||||
strlcpy(stats_end_str, tmp + strlen(stats_end_line) + 1,
|
tmp += strlen(stats_end_middle);
|
||||||
sizeof(stats_end_str));
|
}
|
||||||
|
if (strlen(tmp) < ISO_TIME_LEN + 6)
|
||||||
|
return NULL;
|
||||||
|
strlcpy(stats_end_str, tmp, sizeof(stats_end_str));
|
||||||
if (parse_iso_time(stats_end_str, &stats_end_time) < 0)
|
if (parse_iso_time(stats_end_str, &stats_end_time) < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
if (stats_end_time < now - (25*60*60) ||
|
if (stats_end_time < now - (25*60*60) ||
|
||||||
stats_end_time > now + (1*60*60))
|
stats_end_time > now + (1*60*60))
|
||||||
return NULL;
|
return NULL;
|
||||||
seconds = (int)strtol(tmp + strlen(stats_end_line) + 1 +
|
seconds = (int)strtol(tmp + ISO_TIME_LEN + 2, &eos, 10);
|
||||||
ISO_TIME_LEN + 2, &eos, 10);
|
|
||||||
if (!eos || seconds < 23*60*60)
|
if (!eos || seconds < 23*60*60)
|
||||||
return NULL;
|
return NULL;
|
||||||
format_iso_time(stats_start_str, stats_end_time - seconds);
|
format_iso_time(stats_start_str, stats_end_time - seconds);
|
||||||
|
|
||||||
/* Parse: "bridge-ips CC=N,CC=N,..." */
|
/* Parse: "bridge-ips CC=N,CC=N,..." */
|
||||||
tmp = strstr(tmp, ips_line);
|
if (!strncmp(stats_str, ips_first, strlen(ips_first))) {
|
||||||
if (!tmp || strlen(tmp) < strlen(ips_line))
|
tmp = stats_str + strlen(ips_first);
|
||||||
|
} else {
|
||||||
|
tmp = strstr(stats_str, ips_middle);
|
||||||
|
if (!tmp)
|
||||||
return NULL;
|
return NULL;
|
||||||
if (strlen(tmp) > strlen(ips_line) + 2)
|
tmp += strlen(ips_middle);
|
||||||
tmp += strlen(ips_line) + 1;
|
}
|
||||||
|
if (strlen(tmp) > 2 && !strncmp(tmp, " ", 1))
|
||||||
|
tmp += 1;
|
||||||
else
|
else
|
||||||
tmp = "";
|
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=") +
|
controller_len = strlen("TimeStarted=\"\" CountrySummary=") +
|
||||||
ISO_TIME_LEN + strlen(tmp) + 1;
|
strlen(summary) + 42;
|
||||||
controller_str = tor_malloc(controller_len);
|
controller_str = tor_malloc(controller_len);
|
||||||
if (tor_snprintf(controller_str, controller_len,
|
if (tor_snprintf(controller_str, controller_len,
|
||||||
"TimeStarted=\"%s\" CountrySummary=%s",
|
"TimeStarted=\"%s\" CountrySummary=%s",
|
||||||
stats_start_str, tmp) < 0) {
|
stats_start_str, summary) < 0) {
|
||||||
tor_free(controller_str);
|
tor_free(controller_str);
|
||||||
|
tor_free(summary);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
tor_free(summary);
|
||||||
return controller_str;
|
return controller_str;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1178,11 +1198,11 @@ geoip_bridge_stats_write(time_t now)
|
|||||||
statsdir = get_datadir_fname("stats");
|
statsdir = get_datadir_fname("stats");
|
||||||
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
||||||
goto done;
|
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);
|
data = geoip_get_client_history_bridge(now, GEOIP_CLIENT_CONNECT);
|
||||||
format_iso_time(written, now);
|
format_iso_time(written, now);
|
||||||
len = strlen("bridge-stats-end (999999 s)\nbridge-ips \n") +
|
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);
|
out = tor_malloc(len);
|
||||||
if (tor_snprintf(out, len, "bridge-stats-end %s (%u s)\nbridge-ips %s\n",
|
if (tor_snprintf(out, len, "bridge-stats-end %s (%u s)\nbridge-ips %s\n",
|
||||||
written, (unsigned) (now - start_of_bridge_stats_interval),
|
written, (unsigned) (now - start_of_bridge_stats_interval),
|
||||||
@ -1216,7 +1236,7 @@ load_bridge_stats(time_t now)
|
|||||||
char *fname, *contents, *controller_str;
|
char *fname, *contents, *controller_str;
|
||||||
if (bridge_stats_extrainfo)
|
if (bridge_stats_extrainfo)
|
||||||
return;
|
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);
|
contents = read_file_to_str(fname, 0, NULL);
|
||||||
if (contents) {
|
if (contents) {
|
||||||
controller_str = parse_bridge_stats_controller(contents, now);
|
controller_str = parse_bridge_stats_controller(contents, now);
|
||||||
@ -1277,7 +1297,7 @@ geoip_entry_stats_write(time_t now)
|
|||||||
statsdir = get_datadir_fname("stats");
|
statsdir = get_datadir_fname("stats");
|
||||||
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
||||||
goto done;
|
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);
|
data = geoip_get_client_history_dirreq(now, GEOIP_CLIENT_CONNECT);
|
||||||
format_iso_time(written, now);
|
format_iso_time(written, now);
|
||||||
out = start_writing_to_stdio_file(filename, OPEN_FLAGS_APPEND,
|
out = start_writing_to_stdio_file(filename, OPEN_FLAGS_APPEND,
|
||||||
|
@ -1377,7 +1377,7 @@ rep_hist_exit_stats_write(time_t now)
|
|||||||
statsdir = get_datadir_fname("stats");
|
statsdir = get_datadir_fname("stats");
|
||||||
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
||||||
goto done;
|
goto done;
|
||||||
filename = get_datadir_fname("stats"PATH_SEPARATOR"exit-stats");
|
filename = get_datadir_fname2("stats", "exit-stats");
|
||||||
format_iso_time(t, now);
|
format_iso_time(t, now);
|
||||||
log_info(LD_HIST, "Writing exit port statistics to disk for period "
|
log_info(LD_HIST, "Writing exit port statistics to disk for period "
|
||||||
"ending at %s.", t);
|
"ending at %s.", t);
|
||||||
@ -2734,7 +2734,7 @@ rep_hist_buffer_stats_write(time_t now)
|
|||||||
statsdir = get_datadir_fname("stats");
|
statsdir = get_datadir_fname("stats");
|
||||||
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
if (check_private_dir(statsdir, CPD_CREATE) < 0)
|
||||||
goto done;
|
goto done;
|
||||||
filename = get_datadir_fname("stats"PATH_SEPARATOR"buffer-stats");
|
filename = get_datadir_fname2("stats", "buffer-stats");
|
||||||
out = start_writing_to_stdio_file(filename, OPEN_FLAGS_APPEND,
|
out = start_writing_to_stdio_file(filename, OPEN_FLAGS_APPEND,
|
||||||
0600, &open_file);
|
0600, &open_file);
|
||||||
if (!out)
|
if (!out)
|
||||||
|
Loading…
Reference in New Issue
Block a user