projects
/
runtime.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
e6c156a
)
Fixed MIME multipart decoding buffer overflow. Thanks to Matt
author
Pekka Riikonen
<priikone@silcnet.org>
Fri, 8 Jun 2007 20:38:16 +0000
(20:38 +0000)
committer
Pekka Riikonen
<priikone@silcnet.org>
Fri, 8 Jun 2007 20:38:16 +0000
(20:38 +0000)
Miller for patch.
lib/silcutil/silcmime.c
patch
|
blob
|
history
diff --git
a/lib/silcutil/silcmime.c
b/lib/silcutil/silcmime.c
index f719e77961694509b9868e4dd8c4b966576315bd..b551b3bd4a4c9b055c72c68388a55702853b4d83 100644
(file)
--- a/
lib/silcutil/silcmime.c
+++ b/
lib/silcutil/silcmime.c
@@
-198,6
+198,7
@@
SilcMime silc_mime_decode(SilcMime mime, const unsigned char *data,
if (field && strstr(field, "multipart")) {
char b[1024];
SilcMime p;
+ unsigned int len;
mime->multiparts = silc_dlist_init();
if (!mime->multiparts)
@@
-213,7
+214,10
@@
SilcMime silc_mime_decode(SilcMime mime, const unsigned char *data,
if (!strchr(field, ';'))
goto err;
memset(b, 0, sizeof(b));
- strncat(b, value, strchr(field, ';') - value);
+ len = strchr(field, ';') - value;
+ if (len > sizeof(b) - 1)
+ goto err;
+ strncpy(b, value, len);
if (strchr(b, '"'))
*strchr(b, '"') = '\0';
mime->multitype = silc_memdup(b, strlen(b));