mturk / rpms / apr-util

Forked from rpms/apr-util 3 years ago
Clone
84416ca
--- apr/apr-util/branches/0.9.x/xml/apr_xml.c	2009/06/03 15:37:44	781436
84416ca
+++ apr/apr-util/branches/0.9.x/xml/apr_xml.c	2009/06/03 15:38:19	781437
84416ca
@@ -339,6 +339,25 @@
84416ca
     return APR_SUCCESS;
84416ca
 }
84416ca
 
84416ca
+#if XML_MAJOR_VERSION > 1
84416ca
+/* Stop the parser if an entity declaration is hit. */
84416ca
+static void entity_declaration(void *userData, const XML_Char *entityName,
84416ca
+                               int is_parameter_entity, const XML_Char *value,
84416ca
+                               int value_length, const XML_Char *base,
84416ca
+                               const XML_Char *systemId, const XML_Char *publicId,
84416ca
+                               const XML_Char *notationName)
84416ca
+{
84416ca
+    apr_xml_parser *parser = userData;
84416ca
+
84416ca
+    XML_StopParser(parser->xp, XML_FALSE);
84416ca
+}
84416ca
+#else
84416ca
+/* A noop default_handler. */
84416ca
+static void default_handler(void *userData, const XML_Char *s, int len)
84416ca
+{
84416ca
+}
84416ca
+#endif
84416ca
+
84416ca
 APU_DECLARE(apr_xml_parser *) apr_xml_parser_create(apr_pool_t *pool)
84416ca
 {
84416ca
     apr_xml_parser *parser = apr_pcalloc(pool, sizeof(*parser));
84416ca
@@ -364,6 +383,19 @@
84416ca
     XML_SetElementHandler(parser->xp, start_handler, end_handler);
84416ca
     XML_SetCharacterDataHandler(parser->xp, cdata_handler);
84416ca
 
84416ca
+    /* Prevent the "billion laughs" attack against expat by disabling
84416ca
+     * internal entity expansion.  With 2.x, forcibly stop the parser
84416ca
+     * if an entity is declared - this is safer and a more obvious
84416ca
+     * failure mode.  With older versions, installing a noop
84416ca
+     * DefaultHandler means that internal entities will be expanded as
84416ca
+     * the empty string, which is also sufficient to prevent the
84416ca
+     * attack. */
84416ca
+#if XML_MAJOR_VERSION > 1
84416ca
+    XML_SetEntityDeclHandler(parser->xp, entity_declaration);
84416ca
+#else
84416ca
+    XML_SetDefaultHandler(parser->xp, default_handler);
84416ca
+#endif
84416ca
+
84416ca
     return parser;
84416ca
 }
84416ca