mnGoSearch buffer overflow in UdmDocToTextBuf()

ID 87CC48FD-5FDD-11D8-80E3-0020ED76EF5A
Type freebsd
Reporter FreeBSD
Modified 2004-02-15T00:00:00


Jedi/Sector One <> reported the following on the full-disclosure list:

Every document is stored in multiple parts according to its sections (description, body, etc) in databases. And when the content has to be sent to the client, UdmDocToTextBuf() concatenates those parts together and skips metadata. Unfortunately, that function lacks bounds checking and a buffer overflow can be triggered by indexing a large enough document. 'len' is fixed to 10K [in UdmDocToTextBuf] in searchd.c . S->val length depends on the length of the original document and on the indexer settings (the sample configuration file has low limits that work around the bug, though). Exploitation should be easy, moreover textbuf points to the stack.