From 5b4e11fa5d73d9b138e60df36cbaa0a309e56c55 Mon Sep 17 00:00:00 2001 From: Nick Mathewson Date: Fri, 22 Jul 2005 14:55:09 +0000 Subject: Add getinfo logic for accounting; add options for helper nodes svn:r4632 --- src/or/hibernate.c | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) (limited to 'src/or/hibernate.c') diff --git a/src/or/hibernate.c b/src/or/hibernate.c index e8c5d69a05..0c5a112c1a 100644 --- a/src/or/hibernate.c +++ b/src/or/hibernate.c @@ -100,6 +100,8 @@ static void accounting_set_wakeup_time(void); * Functions for bandwidth accounting. * ************/ + + /** Configure accounting start/end time settings based on * options->AccountingStart. Return 0 on success, -1 on failure. If * validate_only is true, do not change the current settings. */ @@ -846,3 +848,41 @@ consider_hibernation(time_t now) } } +/** DOCDOC */ +int +accounting_getinfo_helper(const char *question, char **answer) +{ + if (!strcmp(question, "accounting/enabled")) { + *answer = tor_strdup(get_options()->AccountingMax ? "1" : "0"); + } else if (!strcmp(question, "accounting/hibernating")) { + if (hibernate_state == HIBERNATE_STATE_DORMANT) + *answer = tor_strdup("hard"); + else if (hibernate_state == HIBERNATE_STATE_LOWBANDWIDTH) + *answer = tor_strdup("soft"); + else + *answer = tor_strdup("awake"); + } else if (!strcmp(question, "accounting/bytes")) { + *answer = tor_malloc(32); + tor_snprintf(*answer, 32, U64_FORMAT" "U64_FORMAT, + U64_PRINTF_ARG(n_bytes_read_in_interval), + U64_PRINTF_ARG(n_bytes_written_in_interval)); + } else if (!strcmp(question, "accounting/bytes-left")) { + *answer = tor_malloc(32); + uint64_t limit = get_options()->AccountingMax; + tor_snprintf(*answer, 32, U64_FORMAT" "U64_FORMAT, + U64_PRINTF_ARG(limit - n_bytes_read_in_interval), + U64_PRINTF_ARG(limit - n_bytes_written_in_interval)); + } else if (!strcmp(question, "accounting/interval-start")) { + *answer = tor_malloc(ISO_TIME_LEN+1); + format_iso_time(*answer, interval_start_time); + } else if (!strcmp(question, "accounting/interval-wake")) { + *answer = tor_malloc(ISO_TIME_LEN+1); + format_iso_time(*answer, interval_wakeup_time); + } else if (!strcmp(question, "accounting/interval-end")) { + *answer = tor_malloc(ISO_TIME_LEN+1); + format_iso_time(*answer, interval_end_time); + } else { + *answer = NULL; + } + return 0; +} -- cgit v1.2.3-54-g00ecf