]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Adjust datetime parsing to be more robust. We now pass the length of the
authorNeil Conway <neilc@samurai.com>
Thu, 26 May 2005 02:14:32 +0000 (02:14 +0000)
committerNeil Conway <neilc@samurai.com>
Thu, 26 May 2005 02:14:32 +0000 (02:14 +0000)
commitab82f60119077b2f6277da8ad4badd1a91980cb5
treefd02d83dd7ef9c5ccd9039a59bf845f691074a99
parentd1d5c0fe2e7d00024524f752911b2e5ab63516eb
Adjust datetime parsing to be more robust. We now pass the length of the
working buffer into ParseDateTime() and reject too-long input there,
rather than checking the length of the input string before calling
ParseDateTime(). The old method was bogus because ParseDateTime() can use
a variable amount of working space, depending on the content of the
input string (e.g. how many fields need to be NUL terminated). This fixes
a minor stack overrun -- I don't _think_ it's exploitable, although I
won't claim to be an expert.

Along the way, fix a bug reported by Mark Dilger: the working buffer
allocated by interval_in() was too short, which resulted in rejecting
some perfectly valid interval input values. I added a regression test for
this fix.
src/backend/utils/adt/date.c
src/backend/utils/adt/datetime.c
src/backend/utils/adt/nabstime.c
src/backend/utils/adt/timestamp.c
src/include/utils/datetime.h
src/test/regress/expected/interval.out
src/test/regress/sql/interval.sql