]> granicus.if.org Git - curl/commitdiff
mime: refuse to add subparts to one of their own descendants.
authorPatrick Monnerat <patrick@monnerat.net>
Sun, 8 Oct 2017 17:49:52 +0000 (18:49 +0100)
committerPatrick Monnerat <patrick@monnerat.net>
Sun, 8 Oct 2017 17:49:52 +0000 (18:49 +0100)
Reported-by: Alexey Melnichuk
Fixes #1962

lib/mime.c

index 4b6881703b1c62bc8f8fe9b294d9153ca33bbc35..04746ed09d150121ad91768041aa4e77ae507e29 100644 (file)
@@ -26,6 +26,8 @@
 
 #include "mime.h"
 #include "non-ascii.h"
+#include "urldata.h"
+#include "sendf.h"
 
 #if !defined(CURL_DISABLE_HTTP) || !defined(CURL_DISABLE_SMTP) || \
     !defined(CURL_DISABLE_IMAP)
@@ -1409,6 +1411,8 @@ CURLcode curl_mime_data_cb(curl_mimepart *part, curl_off_t datasize,
 CURLcode Curl_mime_set_subparts(curl_mimepart *part,
                                 curl_mime *subparts, int take_ownership)
 {
+  curl_mime *root;
+
   if(!part)
     return CURLE_BAD_FUNCTION_ARGUMENT;
 
@@ -1427,6 +1431,17 @@ CURLcode Curl_mime_set_subparts(curl_mimepart *part,
     if(subparts->parent)
       return CURLE_BAD_FUNCTION_ARGUMENT;
 
+    /* Should not be the part's root. */
+    root = part->parent;
+    if(root) {
+      while(root->parent && root->parent->parent)
+        root = root->parent->parent;
+      if(subparts == root) {
+        failf(part->easy, "Can't add itself as a subpart!");
+        return CURLE_BAD_FUNCTION_ARGUMENT;
+      }
+    }
+
     subparts->parent = part;
     part->readfunc = mime_subparts_read;
     part->seekfunc = mime_subparts_seek;