]> granicus.if.org Git - php/commitdiff
- MFH: Fixed bug #42855 (dns_get_record() doesn't return all text from TXT record)
authorFelipe Pena <felipe@php.net>
Mon, 3 Nov 2008 11:35:11 +0000 (11:35 +0000)
committerFelipe Pena <felipe@php.net>
Mon, 3 Nov 2008 11:35:11 +0000 (11:35 +0000)
  patch by: misc at e2007 dot cynergi dot com

ext/standard/dns.c

index 39412adc86b067c9d1fc1d412603f5b5c224c53a..f0276b6081ea4851e6d3d429024355da7265be0e 100644 (file)
@@ -446,13 +446,22 @@ static u_char *php_parserr(u_char *cp, querybuf *answer, int type_to_fetch, int
                        cp += n;
                        break;
                case DNS_T_TXT:
-                       add_assoc_string(*subarray, "type", "TXT", 1);
-                       n = cp[0];
-                       tp = emalloc(n + 1);
-                       memcpy(tp, cp + 1, n);
-                       tp[n] = '\0';
-                       cp += dlen;
-                       add_assoc_stringl(*subarray, "txt", (char*)tp, n, 0);
+                       {
+                               int ll = 0;
+
+                               add_assoc_string(*subarray, "type", "TXT", 1);
+                               tp = emalloc(dlen + 1);
+                               
+                               while (ll < dlen) {
+                                       n = cp[ll];
+                                       memcpy(tp + ll , cp + ll + 1, n);
+                                       ll = ll + n + 1;
+                               }
+                               tp[dlen] = '\0';
+                               cp += dlen;
+
+                               add_assoc_stringl(*subarray, "txt", tp, dlen, 0);
+                       }
                        break;
                case DNS_T_SOA:
                        add_assoc_string(*subarray, "type", "SOA", 1);