summaryrefslogtreecommitdiff
path: root/src/common/util.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2012-03-09 10:24:40 -0500
committerNick Mathewson <nickm@torproject.org>2012-05-16 12:15:08 -0400
commit801923ac2112d1a54eaf4126800724bea90055eb (patch)
tree872f3822b29a91ad8732aaf8adccaba68049a0f7 /src/common/util.c
parent7ae798ac3850008942472a0e9ad4f0c691433c8a (diff)
downloadtor-801923ac2112d1a54eaf4126800724bea90055eb.tar.gz
tor-801923ac2112d1a54eaf4126800724bea90055eb.zip
Remove more dubiosity in struct tm handling. related to bug5346
Diffstat (limited to 'src/common/util.c')
-rw-r--r--src/common/util.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/src/common/util.c b/src/common/util.c
index c44fe601e7..5fa0896ae5 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -1268,7 +1268,7 @@ format_rfc1123_time(char *buf, time_t t)
tor_assert(tm.tm_wday >= 0);
tor_assert(tm.tm_wday <= 6);
memcpy(buf, WEEKDAY_NAMES[tm.tm_wday], 3);
- tor_assert(tm.tm_wday >= 0);
+ tor_assert(tm.tm_mon >= 0);
tor_assert(tm.tm_mon <= 11);
memcpy(buf+8, MONTH_NAMES[tm.tm_mon], 3);
}
@@ -1298,7 +1298,8 @@ parse_rfc1123_time(const char *buf, time_t *t)
tor_free(esc);
return -1;
}
- if (tm_mday > 31 || tm_hour > 23 || tm_min > 59 || tm_sec > 61) {
+ if (tm_mday < 1 || tm_mday > 31 || tm_hour > 23 || tm_min > 59 ||
+ tm_sec > 60) {
char *esc = esc_for_log(buf);
log_warn(LD_GENERAL, "Got invalid RFC1123 time %s", esc);
tor_free(esc);
@@ -1368,7 +1369,7 @@ int
parse_iso_time(const char *cp, time_t *t)
{
struct tm st_tm;
- unsigned int year=0, month=0, day=0, hour=100, minute=100, second=100;
+ unsigned int year=0, month=0, day=0, hour=0, minute=0, second=0;
if (tor_sscanf(cp, "%u-%2u-%2u %2u:%2u:%2u", &year, &month,
&day, &hour, &minute, &second) < 6) {
char *esc = esc_for_log(cp);
@@ -1377,7 +1378,7 @@ parse_iso_time(const char *cp, time_t *t)
return -1;
}
if (year < 1970 || month < 1 || month > 12 || day < 1 || day > 31 ||
- hour > 23 || minute > 59 || second > 61) {
+ hour > 23 || minute > 59 || second > 60) {
char *esc = esc_for_log(cp);
log_warn(LD_GENERAL, "ISO time %s was nonsensical", esc);
tor_free(esc);
@@ -1457,11 +1458,11 @@ parse_http_time(const char *date, struct tm *tm)
}
if (tm->tm_year < 0 ||
- tm->tm_mon < 1 || tm->tm_mon > 12 ||
- tm->tm_mday < 0 || tm->tm_mday > 31 ||
+ tm->tm_mon < 0 || tm->tm_mon > 11 ||
+ tm->tm_mday < 1 || tm->tm_mday > 31 ||
tm->tm_hour < 0 || tm->tm_hour > 23 ||
tm->tm_min < 0 || tm->tm_min > 59 ||
- tm->tm_sec < 0 || tm->tm_sec > 61)
+ tm->tm_sec < 0 || tm->tm_sec > 60)
return -1; /* Out of range, or bad month. */
return 0;