From: Nick Mathewson Date: Sun, 1 Jan 2006 23:09:19 +0000 (+0000) Subject: Fix assertion-trigger bug found by sjmurdoch X-Git-Tag: tor-0.1.1.11-alpha~96 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=04db9de8474a07ecabfdc34f4715f54ff2c630dc;p=thirdparty%2Ftor.git Fix assertion-trigger bug found by sjmurdoch svn:r5689 --- diff --git a/src/common/util.c b/src/common/util.c index 3528ec3063..28dd3938f3 100644 --- a/src/common/util.c +++ b/src/common/util.c @@ -646,6 +646,10 @@ tor_timegm(struct tm *tm) unsigned long year, days, hours, minutes; int i; year = tm->tm_year + 1900; + if (year < 1970 || tm->tm_mon < 0 || tm->tm_mon > 11) { + warn(LD_BUG, "Out-of-range argument to tor_timegm"); + return 0; + } tor_assert(year >= 1970); tor_assert(tm->tm_mon >= 0); tor_assert(tm->tm_mon <= 11); @@ -714,9 +718,14 @@ parse_rfc1123_time(const char *buf, time_t *t) warn(LD_GENERAL, "Got invalid RFC1123 time \"%s\"", buf); return -1; } - tm.tm_mon = m; + + if (tm.tm_year < 1970) { + warn(LD_GENERAL, "Got invalid RFC1123 time \"%s\". (Before 1970)", buf); + return -1; + } tm.tm_year -= 1900; + *t = tor_timegm(&tm); return 0; } @@ -760,6 +769,10 @@ parse_iso_time(const char *cp, time_t *t) st_tm.tm_min = minute; st_tm.tm_sec = second; #endif + if (st_tm.tm_year < 70) { + warn(LD_GENERAL, "Got invalid ISO time \"%s\". (Before 1970)", cp); + return -1; + } *t = tor_timegm(&st_tm); return 0; }